Skip to content

Commit

Permalink
Fix Cannot add an action twice: Document Code (null) (closes #1233)
Browse files Browse the repository at this point in the history
  • Loading branch information
mkondratek committed Apr 3, 2024
1 parent 1e1859f commit af373c2
Show file tree
Hide file tree
Showing 5 changed files with 31 additions and 40 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package com.sourcegraph.cody.edit

import com.intellij.openapi.actionSystem.AnActionEvent
import com.intellij.openapi.actionSystem.DataContext
import com.intellij.openapi.diagnostic.Logger
import com.intellij.openapi.editor.Caret
Expand All @@ -8,9 +9,19 @@ import com.intellij.openapi.editor.actionSystem.EditorAction
import com.intellij.openapi.editor.actionSystem.EditorActionHandler
import com.intellij.openapi.project.DumbAware
import com.sourcegraph.cody.autocomplete.action.CodyAction
import com.sourcegraph.cody.config.CodyApplicationSettings
import com.sourcegraph.config.ConfigUtil
import com.sourcegraph.utils.CodyEditorUtil

class DocumentCodeAction : EditorAction(DocumentCodeActionHandler()), CodyAction, DumbAware
class DocumentCodeAction : EditorAction(DocumentCodeActionHandler()), CodyAction, DumbAware {
override fun update(e: AnActionEvent) {
super.update(e)

e.presentation.isVisible =
ConfigUtil.isFeatureFlagEnabled("cody.feature.inline-edits") ||
CodyApplicationSettings.instance.isInlineEditionEnabled
}
}

class DocumentCodeActionHandler : EditorActionHandler() {
private val logger = Logger.getInstance(DocumentCodeActionHandler::class.java)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package com.sourcegraph.cody.edit

import com.intellij.openapi.actionSystem.AnActionEvent
import com.intellij.openapi.actionSystem.DataContext
import com.intellij.openapi.diagnostic.Logger
import com.intellij.openapi.editor.Caret
Expand All @@ -8,9 +9,19 @@ import com.intellij.openapi.editor.actionSystem.EditorAction
import com.intellij.openapi.editor.actionSystem.EditorActionHandler
import com.intellij.openapi.project.DumbAware
import com.sourcegraph.cody.autocomplete.action.CodyAction
import com.sourcegraph.cody.config.CodyApplicationSettings
import com.sourcegraph.config.ConfigUtil
import com.sourcegraph.utils.CodyEditorUtil

class EditCodeAction : EditorAction(EditCodeActionHandler()), CodyAction, DumbAware
class EditCodeAction : EditorAction(EditCodeActionHandler()), CodyAction, DumbAware {
override fun update(e: AnActionEvent) {
super.update(e)

e.presentation.isVisible =
ConfigUtil.isFeatureFlagEnabled("cody.feature.inline-edits") ||
CodyApplicationSettings.instance.isInlineEditionEnabled
}
}

class EditCodeActionHandler : EditorActionHandler() {
private val logger = Logger.getInstance(EditCodeActionHandler::class.java)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,10 @@
package com.sourcegraph.cody.initialization

import com.intellij.openapi.actionSystem.ActionManager
import com.intellij.openapi.actionSystem.Constraints
import com.intellij.openapi.actionSystem.DefaultActionGroup
import com.intellij.openapi.application.ApplicationManager
import com.intellij.openapi.project.Project
import com.intellij.openapi.startup.StartupActivity
import com.sourcegraph.cody.CodyFocusChangeListener
import com.sourcegraph.cody.agent.CodyAgentService
import com.sourcegraph.cody.auth.SelectOneOfTheAccountsAsActive
import com.sourcegraph.cody.config.CodyApplicationSettings
import com.sourcegraph.cody.config.SettingsMigration
import com.sourcegraph.cody.config.ui.CheckUpdatesTask
import com.sourcegraph.cody.statusbar.CodyStatusService
Expand All @@ -34,28 +29,5 @@ class PostStartupActivity : StartupActivity.DumbAware {
CodyStatusService.resetApplication(project)
CodyFocusChangeListener().runActivity(project)
EndOfTrialNotificationScheduler.createAndStart(project)
initializeInlineEdits()
}

// TODO: This should go away (along with the feature flag) once Inline Edits are stable/released.
private fun initializeInlineEdits() {
ApplicationManager.getApplication().invokeLater {
if (ConfigUtil.isFeatureFlagEnabled("cody.feature.inline-edits") ||
CodyApplicationSettings.instance.isInlineEditionEnabled) {
val actionManager = ActionManager.getInstance()
(actionManager.getAction("CodyEditorActions") as? DefaultActionGroup)?.apply {
pushFrontAction(actionManager, "cody.documentCodeAction", this)
pushFrontAction(actionManager, "cody.editCodeAction", this)
}
}
}
}

private fun pushFrontAction(
actionManager: ActionManager,
actionId: String,
group: DefaultActionGroup
) {
actionManager.getAction(actionId)?.let { group.add(it, Constraints.FIRST) }
}
}
2 changes: 1 addition & 1 deletion src/main/resources/CodyBundle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,6 @@ LlmDropdown.disabled.text=Start a new chat to change the model
# Chat actions
action.cody.openChat.text=Open Chat
action.cody.newChat.text=New Chat
action.cody.newChat.description=New Chat
action.cody.newChat.description=New chat
action.cody.exportChats.text=Export All Chats As JSON
action.cody.exportChats.description=Export All Chats As JSON
15 changes: 6 additions & 9 deletions src/main/resources/META-INF/plugin.xml
Original file line number Diff line number Diff line change
Expand Up @@ -220,6 +220,7 @@
icon="/icons/codyLogoSm.svg" searchable="false"
class="com.sourcegraph.cody.CodyActionGroup">
<add-to-group anchor="last" group-id="EditorPopupMenu"/>
<separator/>
</group>

<action id="cody.command.Explain"
Expand All @@ -229,7 +230,7 @@
<keyboard-shortcut first-keystroke="control shift E"
keymap="Mac OS X 10.5+"/>
<keyboard-shortcut first-keystroke="alt shift 1" keymap="$default"/>
<add-to-group group-id="CodyEditorActions"/>
<add-to-group group-id="CodyEditorActions" anchor="last"/>
</action>

<action id="cody.command.Smell"
Expand All @@ -239,7 +240,7 @@
<keyboard-shortcut first-keystroke="control shift S"
keymap="Mac OS X 10.5+"/>
<keyboard-shortcut first-keystroke="alt shift 2" keymap="$default"/>
<add-to-group group-id="CodyEditorActions"/>
<add-to-group group-id="CodyEditorActions" anchor="last"/>
</action>

<action id="cody.command.Test"
Expand All @@ -249,14 +250,13 @@
<keyboard-shortcut first-keystroke="control shift T"
keymap="Mac OS X 10.5+"/>
<keyboard-shortcut first-keystroke="alt shift 3" keymap="$default"/>
<add-to-group group-id="CodyEditorActions"/>
<add-to-group group-id="CodyEditorActions" anchor="last"/>
</action>

<action
id="cody.restartAgent"
class="com.sourcegraph.cody.agent.action.CodyAgentRestartAction"
text="Restart Cody Agent"/>

<group id="CodyChatActionsGroup">
<reference ref="cody.newChat"/>
</group>
Expand All @@ -266,17 +266,14 @@
id="cody.editCodeAction"
class="com.sourcegraph.cody.edit.EditCodeAction"
text="Edit Code">
<!-- TODO: Put these back in and remove the feature flag when they are ready. -->
<!-- <add-to-group group-id="CodyEditorActions"/>-->

<add-to-group group-id="CodyEditorActions" anchor="first"/>
</action>

<action
id="cody.documentCodeAction"
class="com.sourcegraph.cody.edit.DocumentCodeAction"
text="Document Code">
<!-- TODO: Put these back in and remove the feature flag when they are ready. -->
<!-- <add-to-group group-id="CodyEditorActions"/>-->
<add-to-group group-id="CodyEditorActions" anchor="first"/>
</action>

<action
Expand Down

0 comments on commit af373c2

Please sign in to comment.