1use gpui::{Action, actions};
  2use schemars::JsonSchema;
  3use serde::{Deserialize, Serialize};
  4
  5// If the zed binary doesn't use anything in this crate, it will be optimized away
  6// and the actions won't initialize. So we just provide an empty initialization function
  7// to be called from main.
  8//
  9// These may provide relevant context:
 10// https://github.com/rust-lang/rust/issues/47384
 11// https://github.com/mmastrac/rust-ctor/issues/280
 12pub fn init() {}
 13
 14/// Opens a URL in the system's default web browser.
 15#[derive(Clone, PartialEq, Deserialize, JsonSchema, Action)]
 16#[action(namespace = zed)]
 17#[serde(deny_unknown_fields)]
 18pub struct OpenBrowser {
 19    pub url: String,
 20}
 21
 22/// Opens a zed:// URL within the application.
 23#[derive(Clone, PartialEq, Deserialize, JsonSchema, Action)]
 24#[action(namespace = zed)]
 25#[serde(deny_unknown_fields)]
 26pub struct OpenZedUrl {
 27    pub url: String,
 28}
 29
 30/// Opens the keymap to either add a keybinding or change an existing one
 31#[derive(PartialEq, Clone, Default, Action, JsonSchema, Serialize, Deserialize)]
 32#[action(namespace = zed, no_json, no_register)]
 33pub struct ChangeKeybinding {
 34    pub action: String,
 35}
 36
 37actions!(
 38    zed,
 39    [
 40        /// Opens the settings editor.
 41        #[action(deprecated_aliases = ["zed_actions::OpenSettingsEditor"])]
 42        OpenSettings,
 43        /// Opens the settings JSON file.
 44        #[action(deprecated_aliases = ["zed_actions::OpenSettings"])]
 45        OpenSettingsFile,
 46        /// Opens the default keymap file.
 47        OpenDefaultKeymap,
 48        /// Opens the user keymap file.
 49        #[action(deprecated_aliases = ["zed_actions::OpenKeymap"])]
 50        OpenKeymapFile,
 51        /// Opens the keymap editor.
 52        #[action(deprecated_aliases = ["zed_actions::OpenKeymapEditor"])]
 53        OpenKeymap,
 54        /// Opens account settings.
 55        OpenAccountSettings,
 56        /// Opens server settings.
 57        OpenServerSettings,
 58        /// Quits the application.
 59        Quit,
 60        /// Shows information about Zed.
 61        About,
 62        /// Opens the documentation website.
 63        OpenDocs,
 64        /// Views open source licenses.
 65        OpenLicenses,
 66        /// Opens the telemetry log.
 67        OpenTelemetryLog,
 68    ]
 69);
 70
 71#[derive(PartialEq, Clone, Copy, Debug, Deserialize, JsonSchema)]
 72#[serde(rename_all = "snake_case")]
 73pub enum ExtensionCategoryFilter {
 74    Themes,
 75    IconThemes,
 76    Languages,
 77    Grammars,
 78    LanguageServers,
 79    ContextServers,
 80    AgentServers,
 81    SlashCommands,
 82    IndexedDocsProviders,
 83    Snippets,
 84    DebugAdapters,
 85}
 86
 87/// Opens the extensions management interface.
 88#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
 89#[action(namespace = zed)]
 90#[serde(deny_unknown_fields)]
 91pub struct Extensions {
 92    /// Filters the extensions page down to extensions that are in the specified category.
 93    #[serde(default)]
 94    pub category_filter: Option<ExtensionCategoryFilter>,
 95    /// Focuses just the extension with the specified ID.
 96    #[serde(default)]
 97    pub id: Option<String>,
 98}
 99
100/// Decreases the font size in the editor buffer.
101#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
102#[action(namespace = zed)]
103#[serde(deny_unknown_fields)]
104pub struct DecreaseBufferFontSize {
105    #[serde(default)]
106    pub persist: bool,
107}
108
109/// Increases the font size in the editor buffer.
110#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
111#[action(namespace = zed)]
112#[serde(deny_unknown_fields)]
113pub struct IncreaseBufferFontSize {
114    #[serde(default)]
115    pub persist: bool,
116}
117
118/// Increases the font size in the editor buffer.
119#[derive(PartialEq, Clone, Debug, Deserialize, JsonSchema, Action)]
120#[action(namespace = zed)]
121#[serde(deny_unknown_fields)]
122pub struct OpenSettingsAt {
123    /// A path to a specific setting (e.g. `theme.mode`)
124    pub path: String,
125}
126
127/// Resets the buffer font size to the default value.
128#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
129#[action(namespace = zed)]
130#[serde(deny_unknown_fields)]
131pub struct ResetBufferFontSize {
132    #[serde(default)]
133    pub persist: bool,
134}
135
136/// Decreases the font size of the user interface.
137#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
138#[action(namespace = zed)]
139#[serde(deny_unknown_fields)]
140pub struct DecreaseUiFontSize {
141    #[serde(default)]
142    pub persist: bool,
143}
144
145/// Increases the font size of the user interface.
146#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
147#[action(namespace = zed)]
148#[serde(deny_unknown_fields)]
149pub struct IncreaseUiFontSize {
150    #[serde(default)]
151    pub persist: bool,
152}
153
154/// Resets the UI font size to the default value.
155#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
156#[action(namespace = zed)]
157#[serde(deny_unknown_fields)]
158pub struct ResetUiFontSize {
159    #[serde(default)]
160    pub persist: bool,
161}
162
163/// Resets all zoom levels (UI and buffer font sizes, including in the agent panel) to their default values.
164#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
165#[action(namespace = zed)]
166#[serde(deny_unknown_fields)]
167pub struct ResetAllZoom {
168    #[serde(default)]
169    pub persist: bool,
170}
171
172pub mod dev {
173    use gpui::actions;
174
175    actions!(
176        dev,
177        [
178            /// Toggles the developer inspector for debugging UI elements.
179            ToggleInspector
180        ]
181    );
182}
183
184pub mod workspace {
185    use gpui::actions;
186
187    actions!(
188        workspace,
189        [
190            #[action(deprecated_aliases = ["editor::CopyPath", "outline_panel::CopyPath", "project_panel::CopyPath"])]
191            CopyPath,
192            #[action(deprecated_aliases = ["editor::CopyRelativePath", "outline_panel::CopyRelativePath", "project_panel::CopyRelativePath"])]
193            CopyRelativePath,
194            /// Opens the selected file with the system's default application.
195            #[action(deprecated_aliases = ["project_panel::OpenWithSystem"])]
196            OpenWithSystem,
197        ]
198    );
199}
200
201pub mod git {
202    use gpui::actions;
203
204    actions!(
205        git,
206        [
207            /// Checks out a different git branch.
208            CheckoutBranch,
209            /// Switches to a different git branch.
210            Switch,
211            /// Selects a different repository.
212            SelectRepo,
213            /// Opens the git branch selector.
214            #[action(deprecated_aliases = ["branches::OpenRecent"])]
215            Branch,
216            /// Opens the git stash selector.
217            ViewStash
218        ]
219    );
220}
221
222pub mod toast {
223    use gpui::actions;
224
225    actions!(
226        toast,
227        [
228            /// Runs the action associated with a toast notification.
229            RunAction
230        ]
231    );
232}
233
234pub mod command_palette {
235    use gpui::actions;
236
237    actions!(
238        command_palette,
239        [
240            /// Toggles the command palette.
241            Toggle,
242        ]
243    );
244}
245
246pub mod feedback {
247    use gpui::actions;
248
249    actions!(
250        feedback,
251        [
252            /// Opens email client to send feedback to Zed support.
253            EmailZed,
254            /// Opens the bug report form.
255            FileBugReport,
256            /// Opens the feature request form.
257            RequestFeature
258        ]
259    );
260}
261
262pub mod theme_selector {
263    use gpui::Action;
264    use schemars::JsonSchema;
265    use serde::Deserialize;
266
267    /// Toggles the theme selector interface.
268    #[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
269    #[action(namespace = theme_selector)]
270    #[serde(deny_unknown_fields)]
271    pub struct Toggle {
272        /// A list of theme names to filter the theme selector down to.
273        pub themes_filter: Option<Vec<String>>,
274    }
275}
276
277pub mod icon_theme_selector {
278    use gpui::Action;
279    use schemars::JsonSchema;
280    use serde::Deserialize;
281
282    /// Toggles the icon theme selector interface.
283    #[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
284    #[action(namespace = icon_theme_selector)]
285    #[serde(deny_unknown_fields)]
286    pub struct Toggle {
287        /// A list of icon theme names to filter the theme selector down to.
288        pub themes_filter: Option<Vec<String>>,
289    }
290}
291
292pub mod settings_profile_selector {
293    use gpui::Action;
294    use schemars::JsonSchema;
295    use serde::Deserialize;
296
297    #[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
298    #[action(namespace = settings_profile_selector)]
299    pub struct Toggle;
300}
301
302pub mod agent {
303    use gpui::actions;
304
305    actions!(
306        agent,
307        [
308            /// Opens the agent settings panel.
309            #[action(deprecated_aliases = ["agent::OpenConfiguration"])]
310            OpenSettings,
311            /// Opens the agent onboarding modal.
312            OpenOnboardingModal,
313            /// Opens the ACP onboarding modal.
314            OpenAcpOnboardingModal,
315            /// Opens the Claude Code onboarding modal.
316            OpenClaudeCodeOnboardingModal,
317            /// Resets the agent onboarding state.
318            ResetOnboarding,
319            /// Starts a chat conversation with the agent.
320            Chat,
321            /// Toggles the language model selector dropdown.
322            #[action(deprecated_aliases = ["assistant::ToggleModelSelector", "assistant2::ToggleModelSelector"])]
323            ToggleModelSelector,
324            /// Triggers re-authentication on Gemini
325            ReauthenticateAgent,
326            /// Add the current selection as context for threads in the agent panel.
327            #[action(deprecated_aliases = ["assistant::QuoteSelection", "agent::QuoteSelection"])]
328            AddSelectionToThread,
329            /// Resets the agent panel zoom levels (agent UI and buffer font sizes).
330            ResetAgentZoom,
331        ]
332    );
333}
334
335pub mod assistant {
336    use gpui::{Action, actions};
337    use schemars::JsonSchema;
338    use serde::Deserialize;
339    use uuid::Uuid;
340
341    actions!(
342        agent,
343        [
344            #[action(deprecated_aliases = ["assistant::ToggleFocus"])]
345            ToggleFocus
346        ]
347    );
348
349    actions!(
350        assistant,
351        [
352            /// Shows the assistant configuration panel.
353            ShowConfiguration
354        ]
355    );
356
357    /// Opens the rules library for managing agent rules and prompts.
358    #[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema, Action)]
359    #[action(namespace = agent, deprecated_aliases = ["assistant::OpenRulesLibrary", "assistant::DeployPromptLibrary"])]
360    #[serde(deny_unknown_fields)]
361    pub struct OpenRulesLibrary {
362        #[serde(skip)]
363        pub prompt_to_select: Option<Uuid>,
364    }
365
366    /// Deploys the assistant interface with the specified configuration.
367    #[derive(Clone, Default, Deserialize, PartialEq, JsonSchema, Action)]
368    #[action(namespace = assistant)]
369    #[serde(deny_unknown_fields)]
370    pub struct InlineAssist {
371        pub prompt: Option<String>,
372    }
373}
374
375pub mod debugger {
376    use gpui::actions;
377
378    actions!(
379        debugger,
380        [
381            /// Opens the debugger onboarding modal.
382            OpenOnboardingModal,
383            /// Resets the debugger onboarding state.
384            ResetOnboarding
385        ]
386    );
387}
388
389/// Opens the recent projects interface.
390#[derive(PartialEq, Clone, Deserialize, Default, JsonSchema, Action)]
391#[action(namespace = projects)]
392#[serde(deny_unknown_fields)]
393pub struct OpenRecent {
394    #[serde(default)]
395    pub create_new_window: bool,
396}
397
398/// Creates a project from a selected template.
399#[derive(PartialEq, Clone, Deserialize, Default, JsonSchema, Action)]
400#[action(namespace = projects)]
401#[serde(deny_unknown_fields)]
402pub struct OpenRemote {
403    #[serde(default)]
404    pub from_existing_connection: bool,
405    #[serde(default)]
406    pub create_new_window: bool,
407}
408
409/// Where to spawn the task in the UI.
410#[derive(Default, Clone, Copy, Debug, PartialEq, Eq, Serialize, Deserialize, JsonSchema)]
411#[serde(rename_all = "snake_case")]
412pub enum RevealTarget {
413    /// In the central pane group, "main" editor area.
414    Center,
415    /// In the terminal dock, "regular" terminal items' place.
416    #[default]
417    Dock,
418}
419
420/// Spawns a task with name or opens tasks modal.
421#[derive(Debug, PartialEq, Clone, Deserialize, JsonSchema, Action)]
422#[action(namespace = task)]
423#[serde(untagged)]
424pub enum Spawn {
425    /// Spawns a task by the name given.
426    ByName {
427        task_name: String,
428        #[serde(default)]
429        reveal_target: Option<RevealTarget>,
430    },
431    /// Spawns a task by the name given.
432    ByTag {
433        task_tag: String,
434        #[serde(default)]
435        reveal_target: Option<RevealTarget>,
436    },
437    /// Spawns a task via modal's selection.
438    ViaModal {
439        /// Selected task's `reveal_target` property override.
440        #[serde(default)]
441        reveal_target: Option<RevealTarget>,
442    },
443}
444
445impl Spawn {
446    pub fn modal() -> Self {
447        Self::ViaModal {
448            reveal_target: None,
449        }
450    }
451}
452
453/// Reruns the last task.
454#[derive(PartialEq, Clone, Deserialize, Default, JsonSchema, Action)]
455#[action(namespace = task)]
456#[serde(deny_unknown_fields)]
457pub struct Rerun {
458    /// Controls whether the task context is reevaluated prior to execution of a task.
459    /// If it is not, environment variables such as ZED_COLUMN, ZED_FILE are gonna be the same as in the last execution of a task
460    /// If it is, these variables will be updated to reflect current state of editor at the time task::Rerun is executed.
461    /// default: false
462    #[serde(default)]
463    pub reevaluate_context: bool,
464    /// Overrides `allow_concurrent_runs` property of the task being reran.
465    /// Default: null
466    #[serde(default)]
467    pub allow_concurrent_runs: Option<bool>,
468    /// Overrides `use_new_terminal` property of the task being reran.
469    /// Default: null
470    #[serde(default)]
471    pub use_new_terminal: Option<bool>,
472
473    /// If present, rerun the task with this ID, otherwise rerun the last task.
474    #[serde(skip)]
475    pub task_id: Option<String>,
476}
477
478pub mod outline {
479    use std::sync::OnceLock;
480
481    use gpui::{AnyView, App, Window, actions};
482
483    actions!(
484        outline,
485        [
486            #[action(name = "Toggle")]
487            ToggleOutline
488        ]
489    );
490    /// A pointer to outline::toggle function, exposed here to sewer the breadcrumbs <-> outline dependency.
491    pub static TOGGLE_OUTLINE: OnceLock<fn(AnyView, &mut Window, &mut App)> = OnceLock::new();
492}
493
494actions!(
495    zed_predict_onboarding,
496    [
497        /// Opens the Zed Predict onboarding modal.
498        OpenZedPredictOnboarding
499    ]
500);
501actions!(
502    git_onboarding,
503    [
504        /// Opens the git integration onboarding modal.
505        OpenGitIntegrationOnboarding
506    ]
507);
508
509actions!(
510    debug_panel,
511    [
512        /// Toggles focus on the debug panel.
513        ToggleFocus
514    ]
515);
516actions!(
517    debugger,
518    [
519        /// Toggles the enabled state of a breakpoint.
520        ToggleEnableBreakpoint,
521        /// Removes a breakpoint.
522        UnsetBreakpoint,
523        /// Opens the project debug tasks configuration.
524        OpenProjectDebugTasks,
525    ]
526);
527
528#[derive(Debug, Clone, PartialEq, Eq, Hash)]
529pub struct WslConnectionOptions {
530    pub distro_name: String,
531    pub user: Option<String>,
532}
533
534#[cfg(target_os = "windows")]
535pub mod wsl_actions {
536    use gpui::Action;
537    use schemars::JsonSchema;
538    use serde::Deserialize;
539
540    /// Opens a folder inside Wsl.
541    #[derive(PartialEq, Clone, Deserialize, Default, JsonSchema, Action)]
542    #[action(namespace = projects)]
543    #[serde(deny_unknown_fields)]
544    pub struct OpenFolderInWsl {
545        #[serde(default)]
546        pub create_new_window: bool,
547    }
548
549    /// Open a wsl distro.
550    #[derive(PartialEq, Clone, Deserialize, Default, JsonSchema, Action)]
551    #[action(namespace = projects)]
552    #[serde(deny_unknown_fields)]
553    pub struct OpenWsl {
554        #[serde(default)]
555        pub create_new_window: bool,
556    }
557}