mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-04 18:59:08 +01:00
Rerun Command Button (#1265)
Adds a button in widgets with a "cmd" controller that allows the command to be rerun without accessing a context menu.
This commit is contained in:
parent
86a83cb290
commit
d96542f691
@ -88,7 +88,7 @@ The `WidgetConfigType` takes the usual options common to all widgets. The `MetaT
|
|||||||
| Key | Description |
|
| Key | Description |
|
||||||
| --------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| --------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| "view" | A string that specifies the general type of widget. In the case of custom terminal widgets, this must be set to `"term"`. |
|
| "view" | A string that specifies the general type of widget. In the case of custom terminal widgets, this must be set to `"term"`. |
|
||||||
| "controller" | A string that specifies the type of command being used. For more persistent shell sessions, set it to "shell". For one off commands, set it to "cmd". Note that it is often possible to achieve the same result through each depending on the command being used. |
|
| "controller" | A string that specifies the type of command being used. For more persistent shell sessions, set it to "shell". For one off commands, set it to `"cmd"`. When `"cmd"` is set, the widget has an additional refresh button in its header that allows the command to be re-run. |
|
||||||
| "cmd" | (optional) When the `"controller"` is set to `"cmd"`, this option provides the actual command to be run. Note that because it is run as a command, there is no shell session unless you are launching a command that contains a shell session itself. Defaults to an empty string. |
|
| "cmd" | (optional) When the `"controller"` is set to `"cmd"`, this option provides the actual command to be run. Note that because it is run as a command, there is no shell session unless you are launching a command that contains a shell session itself. Defaults to an empty string. |
|
||||||
| "cmd:interactive" | (optional) When the `"controller"` is set to `"term", this boolean adds the interactive flag to the launched terminal. Defaults to false. |
|
| "cmd:interactive" | (optional) When the `"controller"` is set to `"term", this boolean adds the interactive flag to the launched terminal. Defaults to false. |
|
||||||
| "cmd:login" | (optional) When the `"controller"` is set to `"term"`, this boolean adds the login flag to the term command. Defaults to false. |
|
| "cmd:login" | (optional) When the `"controller"` is set to `"term"`, this boolean adds the login flag to the term command. Defaults to false. |
|
||||||
|
@ -61,6 +61,7 @@ class TermViewModel {
|
|||||||
fontSizeAtom: jotai.Atom<number>;
|
fontSizeAtom: jotai.Atom<number>;
|
||||||
termThemeNameAtom: jotai.Atom<string>;
|
termThemeNameAtom: jotai.Atom<string>;
|
||||||
noPadding: jotai.PrimitiveAtom<boolean>;
|
noPadding: jotai.PrimitiveAtom<boolean>;
|
||||||
|
endIconButtons: jotai.Atom<IconButtonDecl[]>;
|
||||||
|
|
||||||
constructor(blockId: string, nodeModel: BlockNodeModel) {
|
constructor(blockId: string, nodeModel: BlockNodeModel) {
|
||||||
this.viewType = "term";
|
this.viewType = "term";
|
||||||
@ -176,6 +177,20 @@ class TermViewModel {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
this.noPadding = jotai.atom(true);
|
this.noPadding = jotai.atom(true);
|
||||||
|
this.endIconButtons = jotai.atom((get) => {
|
||||||
|
const blockData = get(this.blockAtom);
|
||||||
|
if (blockData?.meta?.["controller"] != "cmd") {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
return [
|
||||||
|
{
|
||||||
|
elemtype: "iconbutton",
|
||||||
|
icon: "refresh",
|
||||||
|
click: this.forceRestartController.bind(this),
|
||||||
|
title: "Force Restart Controller",
|
||||||
|
},
|
||||||
|
];
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
setTermMode(mode: "term" | "vdom") {
|
setTermMode(mode: "term" | "vdom") {
|
||||||
@ -296,6 +311,20 @@ class TermViewModel {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
forceRestartController() {
|
||||||
|
const termsize = {
|
||||||
|
rows: this.termRef.current?.terminal?.rows,
|
||||||
|
cols: this.termRef.current?.terminal?.cols,
|
||||||
|
};
|
||||||
|
const prtn = RpcApi.ControllerResyncCommand(TabRpcClient, {
|
||||||
|
tabid: globalStore.get(atoms.staticTabId),
|
||||||
|
blockid: this.blockId,
|
||||||
|
forcerestart: true,
|
||||||
|
rtopts: { termsize: termsize },
|
||||||
|
});
|
||||||
|
prtn.catch((e) => console.log("error controller resync (force restart)", e));
|
||||||
|
}
|
||||||
|
|
||||||
getSettingsMenuItems(): ContextMenuItem[] {
|
getSettingsMenuItems(): ContextMenuItem[] {
|
||||||
const fullConfig = globalStore.get(atoms.fullConfigAtom);
|
const fullConfig = globalStore.get(atoms.fullConfigAtom);
|
||||||
const termThemes = fullConfig?.termthemes ?? {};
|
const termThemes = fullConfig?.termthemes ?? {};
|
||||||
@ -354,19 +383,7 @@ class TermViewModel {
|
|||||||
fullMenu.push({ type: "separator" });
|
fullMenu.push({ type: "separator" });
|
||||||
fullMenu.push({
|
fullMenu.push({
|
||||||
label: "Force Restart Controller",
|
label: "Force Restart Controller",
|
||||||
click: () => {
|
click: this.forceRestartController.bind(this),
|
||||||
const termsize = {
|
|
||||||
rows: this.termRef.current?.terminal?.rows,
|
|
||||||
cols: this.termRef.current?.terminal?.cols,
|
|
||||||
};
|
|
||||||
const prtn = RpcApi.ControllerResyncCommand(TabRpcClient, {
|
|
||||||
tabid: globalStore.get(atoms.staticTabId),
|
|
||||||
blockid: this.blockId,
|
|
||||||
forcerestart: true,
|
|
||||||
rtopts: { termsize: termsize },
|
|
||||||
});
|
|
||||||
prtn.catch((e) => console.log("error controller resync (force restart)", e));
|
|
||||||
},
|
|
||||||
});
|
});
|
||||||
if (blockData?.meta?.["term:vdomtoolbarblockid"]) {
|
if (blockData?.meta?.["term:vdomtoolbarblockid"]) {
|
||||||
fullMenu.push({ type: "separator" });
|
fullMenu.push({ type: "separator" });
|
||||||
|
Loading…
Reference in New Issue
Block a user