mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-10 19:58:00 +01:00
implement delete session, bug fixes
This commit is contained in:
parent
057637660c
commit
6340a3e9ff
@ -559,7 +559,7 @@ class ScreenTabs extends React.Component<{session : Session}, {}> {
|
|||||||
if (screen == null) {
|
if (screen == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
GlobalModel.activateScreen(screen.sessionId, screen.screenId);
|
GlobalModel.submitCommand(sprintf("/s %s", screenId));
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
@ -572,7 +572,7 @@ class ScreenTabs extends React.Component<{session : Session}, {}> {
|
|||||||
return (
|
return (
|
||||||
<div className="screen-tabs">
|
<div className="screen-tabs">
|
||||||
<For each="screen" index="index" of={session.screens}>
|
<For each="screen" index="index" of={session.screens}>
|
||||||
<div key={screen.screenId} className={cn("screen-tab", {"is-active": session.activeScreenId.get() == screen.screenId})} onClick={() => this.handleSwitchScreen(screen.screenId)}>
|
<div key={screen.screenId} className={cn("screen-tab", {"is-active": session.activeScreenId.get() == screen.screenId})} onClick={() => this.handleSwitchScreen(screen.screenId, index+1)}>
|
||||||
{screen.name.get()}
|
{screen.name.get()}
|
||||||
<If condition={index+1 <= 9}>
|
<If condition={index+1 <= 9}>
|
||||||
<div className="tab-index">⌘{index+1}</div>
|
<div className="tab-index">⌘{index+1}</div>
|
||||||
|
11
src/model.ts
11
src/model.ts
@ -534,7 +534,7 @@ class Model {
|
|||||||
if (newScreenId == null) {
|
if (newScreenId == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this.activateScreen(activeSession.sessionId, newScreenId);
|
this.submitCommand(sprintf("/s %s", newScreenId));
|
||||||
}
|
}
|
||||||
|
|
||||||
onDigitCmd(e : any, arg : {digit: number}, mods : KeyModsType) {
|
onDigitCmd(e : any, arg : {digit: number}, mods : KeyModsType) {
|
||||||
@ -558,13 +558,17 @@ class Model {
|
|||||||
}
|
}
|
||||||
if ("sessions" in message) {
|
if ("sessions" in message) {
|
||||||
let sessionUpdateMsg : SessionUpdateType = message;
|
let sessionUpdateMsg : SessionUpdateType = message;
|
||||||
console.log("update-sessions", sessionUpdateMsg.sessions);
|
|
||||||
mobx.action(() => {
|
mobx.action(() => {
|
||||||
let oldActiveScreen = this.getActiveScreen();
|
let oldActiveScreen = this.getActiveScreen();
|
||||||
genMergeData(this.sessionList, sessionUpdateMsg.sessions, (s : Session) => s.sessionId, (sdata : SessionDataType) => sdata.sessionid, (sdata : SessionDataType) => new Session(sdata), (s : Session) => s.sessionIdx.get());
|
genMergeData(this.sessionList, sessionUpdateMsg.sessions, (s : Session) => s.sessionId, (sdata : SessionDataType) => sdata.sessionid, (sdata : SessionDataType) => new Session(sdata), (s : Session) => s.sessionIdx.get());
|
||||||
let newActiveScreen = this.getActiveScreen();
|
let newActiveScreen = this.getActiveScreen();
|
||||||
if (oldActiveScreen != newActiveScreen) {
|
if (oldActiveScreen != newActiveScreen) {
|
||||||
this.activateScreen(newActiveScreen.sessionId, newActiveScreen.screenId, oldActiveScreen);
|
if (newActiveScreen == null) {
|
||||||
|
this.activateScreen(this.activeSessionId.get(), null, oldActiveScreen);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.activateScreen(newActiveScreen.sessionId, newActiveScreen.screenId, oldActiveScreen);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})();
|
})();
|
||||||
|
|
||||||
@ -741,6 +745,7 @@ class Model {
|
|||||||
})();
|
})();
|
||||||
let curScreen = this.getActiveScreen();
|
let curScreen = this.getActiveScreen();
|
||||||
if (curScreen == null) {
|
if (curScreen == null) {
|
||||||
|
this.ws.pushMessage({type: "watchscreen", sessionid: sessionId});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this.ws.pushMessage({type: "watchscreen", sessionid: curScreen.sessionId, screenid: curScreen.screenId});
|
this.ws.pushMessage({type: "watchscreen", sessionid: curScreen.sessionId, screenid: curScreen.screenId});
|
||||||
|
Loading…
Reference in New Issue
Block a user