mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-04 18:59:08 +01:00
use Button element for close trigger
This commit is contained in:
parent
85c49032f7
commit
641c8da1c7
@ -5,12 +5,10 @@ import { boundMethod } from "autobind-decorator";
|
|||||||
import { If, For } from "tsx-control-statements/components";
|
import { If, For } from "tsx-control-statements/components";
|
||||||
import cn from "classnames";
|
import cn from "classnames";
|
||||||
import { GlobalCommandRunner, GlobalModel, Screen } from "@/models";
|
import { GlobalCommandRunner, GlobalModel, Screen } from "@/models";
|
||||||
import { Button, TextField, Dropdown } from "@/elements";
|
import { TextField, Dropdown } from "@/elements";
|
||||||
import { getRemoteStr, getRemoteStrWithAlias } from "@/common/prompt/prompt";
|
import { getRemoteStrWithAlias } from "@/common/prompt/prompt";
|
||||||
import * as util from "@/util/util";
|
import * as util from "@/util/util";
|
||||||
import { TabIcon } from "@/elements/tabicon";
|
import { TabIcon } from "@/elements/tabicon";
|
||||||
import { ReactComponent as EllipseIcon } from "@/assets/icons/ellipse.svg";
|
|
||||||
import { ReactComponent as Check12Icon } from "@/assets/icons/check12.svg";
|
|
||||||
import { ReactComponent as GlobeIcon } from "@/assets/icons/globe.svg";
|
import { ReactComponent as GlobeIcon } from "@/assets/icons/globe.svg";
|
||||||
import { ReactComponent as StatusCircleIcon } from "@/assets/icons/statuscircle.svg";
|
import { ReactComponent as StatusCircleIcon } from "@/assets/icons/statuscircle.svg";
|
||||||
import * as appconst from "@/app/appconst";
|
import * as appconst from "@/app/appconst";
|
||||||
@ -18,52 +16,6 @@ import * as appconst from "@/app/appconst";
|
|||||||
import "./screenview.less";
|
import "./screenview.less";
|
||||||
import "./tabs.less";
|
import "./tabs.less";
|
||||||
|
|
||||||
@mobxReact.observer
|
|
||||||
class NewTabSettings extends React.Component<{ screen: Screen }, {}> {
|
|
||||||
errorMessage: OV<string | null> = mobx.observable.box(null, { name: "NewTabSettings-errorMessage" });
|
|
||||||
|
|
||||||
constructor(props) {
|
|
||||||
super(props);
|
|
||||||
}
|
|
||||||
|
|
||||||
@boundMethod
|
|
||||||
clickNewConnection(): void {
|
|
||||||
GlobalModel.remotesModel.openAddModal({ remoteedit: true });
|
|
||||||
}
|
|
||||||
|
|
||||||
render() {
|
|
||||||
let { screen } = this.props;
|
|
||||||
let rptr = screen.curRemote.get();
|
|
||||||
return (
|
|
||||||
<div className="newtab-container">
|
|
||||||
<div className="newtab-section name-section">
|
|
||||||
<TabNameTextField screen={screen} errorMessage={this.errorMessage} />
|
|
||||||
</div>
|
|
||||||
<div className="newtab-spacer" />
|
|
||||||
<div className="newtab-section conn-section">
|
|
||||||
<div className="unselectable">
|
|
||||||
You're connected to <b>[{getRemoteStrWithAlias(rptr)}]</b>. Do you want to change it?
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<TabRemoteSelector screen={screen} errorMessage={this.errorMessage} />
|
|
||||||
</div>
|
|
||||||
<div className="text-caption cr-help-text">
|
|
||||||
To change connection from the command line use `/connect [alias|user@host]`
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div className="newtab-spacer" />
|
|
||||||
<div className="newtab-section">
|
|
||||||
<TabIconSelector screen={screen} errorMessage={this.errorMessage} />
|
|
||||||
</div>
|
|
||||||
<div className="newtab-spacer" />
|
|
||||||
<div className="newtab-section">
|
|
||||||
<TabColorSelector screen={screen} errorMessage={this.errorMessage} />
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@mobxReact.observer
|
@mobxReact.observer
|
||||||
class TabNameTextField extends React.Component<{ screen: Screen; errorMessage?: OV<string> }, {}> {
|
class TabNameTextField extends React.Component<{ screen: Screen; errorMessage?: OV<string> }, {}> {
|
||||||
@boundMethod
|
@boundMethod
|
||||||
@ -240,4 +192,4 @@ class TabRemoteSelector extends React.Component<{ screen: Screen; errorMessage?:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export { NewTabSettings, TabColorSelector, TabIconSelector, TabNameTextField, TabRemoteSelector };
|
export { TabColorSelector, TabIconSelector, TabNameTextField, TabRemoteSelector };
|
||||||
|
@ -40,7 +40,7 @@
|
|||||||
border-bottom: none;
|
border-bottom: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.close-icon {
|
.close-button {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
right: 10px;
|
right: 10px;
|
||||||
top: 10px;
|
top: 10px;
|
||||||
|
@ -15,10 +15,9 @@ import { ScreenTabs } from "./screen/tabs";
|
|||||||
import { ErrorBoundary } from "@/common/error/errorboundary";
|
import { ErrorBoundary } from "@/common/error/errorboundary";
|
||||||
import { boundMethod } from "autobind-decorator";
|
import { boundMethod } from "autobind-decorator";
|
||||||
import type { Screen } from "@/models";
|
import type { Screen } from "@/models";
|
||||||
import { Button, TermStyleBlock } from "@/elements";
|
import { Button, Dropdown, TermStyleBlock } from "@/elements";
|
||||||
import { commandRtnHandler } from "@/util/util";
|
import { commandRtnHandler } from "@/util/util";
|
||||||
import { getTermThemes } from "@/util/themeutil";
|
import { getTermThemes } from "@/util/themeutil";
|
||||||
import { Dropdown } from "@/elements/dropdown";
|
|
||||||
import { getRemoteStrWithAlias } from "@/common/prompt/prompt";
|
import { getRemoteStrWithAlias } from "@/common/prompt/prompt";
|
||||||
import { TabColorSelector, TabIconSelector, TabNameTextField, TabRemoteSelector } from "./screen/newtabsettings";
|
import { TabColorSelector, TabIconSelector, TabNameTextField, TabRemoteSelector } from "./screen/newtabsettings";
|
||||||
import * as util from "@/util/util";
|
import * as util from "@/util/util";
|
||||||
@ -253,9 +252,9 @@ class WorkspaceView extends React.Component<{}, {}> {
|
|||||||
<ScreenTabs key={"tabs-" + sessionId} session={session} />
|
<ScreenTabs key={"tabs-" + sessionId} session={session} />
|
||||||
<If condition={activeScreen != null}>
|
<If condition={activeScreen != null}>
|
||||||
<div key="pulldown" className={cn("tab-settings-pulldown", { closed: !showTabSettings })}>
|
<div key="pulldown" className={cn("tab-settings-pulldown", { closed: !showTabSettings })}>
|
||||||
<button className="close-icon" onClick={this.toggleTabSettings}>
|
<Button className="close-button secondary ghost" onClick={this.toggleTabSettings}>
|
||||||
<i className="fa-solid fa-sharp fa-xmark-large" />
|
<i className="fa-solid fa-sharp fa-xmark-large" />
|
||||||
</button>
|
</Button>
|
||||||
<TabSettings key={activeScreen.screenId} screen={activeScreen} />
|
<TabSettings key={activeScreen.screenId} screen={activeScreen} />
|
||||||
<If condition={showTabSettings && !isHidden}>
|
<If condition={showTabSettings && !isHidden}>
|
||||||
<TabSettingsPulldownKeybindings />
|
<TabSettingsPulldownKeybindings />
|
||||||
|
Loading…
Reference in New Issue
Block a user