@ottocode/web-sdk 0.1.177 → 0.1.178
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/git/GitSidebar.d.ts.map +1 -1
- package/dist/components/git/GitSidebar.js +10 -4
- package/dist/components/git/GitSidebar.js.map +1 -1
- package/dist/components/index.d.ts +5 -3
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +5 -3
- package/dist/components/index.js.map +1 -1
- package/dist/components/research/ResearchSidebar.d.ts.map +1 -1
- package/dist/components/research/ResearchSidebar.js +40 -33
- package/dist/components/research/ResearchSidebar.js.map +1 -1
- package/dist/components/session-files/SessionFilesSidebar.d.ts.map +1 -1
- package/dist/components/session-files/SessionFilesSidebar.js +8 -1
- package/dist/components/session-files/SessionFilesSidebar.js.map +1 -1
- package/dist/components/settings/SettingsSidebar.d.ts.map +1 -1
- package/dist/components/settings/SettingsSidebar.js +21 -14
- package/dist/components/settings/SettingsSidebar.js.map +1 -1
- package/dist/components/terminals/TerminalPanelToggle.d.ts +2 -0
- package/dist/components/terminals/TerminalPanelToggle.d.ts.map +1 -0
- package/dist/components/terminals/TerminalPanelToggle.js +13 -0
- package/dist/components/terminals/TerminalPanelToggle.js.map +1 -0
- package/dist/components/terminals/TerminalTabBar.d.ts +10 -0
- package/dist/components/terminals/TerminalTabBar.d.ts.map +1 -0
- package/dist/components/terminals/TerminalTabBar.js +22 -0
- package/dist/components/terminals/TerminalTabBar.js.map +1 -0
- package/dist/components/terminals/TerminalViewer.d.ts +2 -1
- package/dist/components/terminals/TerminalViewer.d.ts.map +1 -1
- package/dist/components/terminals/TerminalViewer.js +102 -75
- package/dist/components/terminals/TerminalViewer.js.map +1 -1
- package/dist/components/terminals/TerminalsPanel.d.ts +2 -0
- package/dist/components/terminals/TerminalsPanel.d.ts.map +1 -0
- package/dist/components/terminals/TerminalsPanel.js +121 -0
- package/dist/components/terminals/TerminalsPanel.js.map +1 -0
- package/dist/components/terminals/index.d.ts +9 -3
- package/dist/components/terminals/index.d.ts.map +1 -1
- package/dist/components/terminals/index.js +9 -3
- package/dist/components/terminals/index.js.map +1 -1
- package/dist/components/ui/ResizeHandle.d.ts +11 -0
- package/dist/components/ui/ResizeHandle.d.ts.map +1 -0
- package/dist/components/ui/ResizeHandle.js +35 -0
- package/dist/components/ui/ResizeHandle.js.map +1 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -3
- package/dist/index.js.map +1 -1
- package/dist/stores/index.d.ts +1 -0
- package/dist/stores/index.d.ts.map +1 -1
- package/dist/stores/index.js +1 -0
- package/dist/stores/index.js.map +1 -1
- package/dist/stores/panelWidthStore.d.ts +20 -0
- package/dist/stores/panelWidthStore.d.ts.map +1 -0
- package/dist/stores/panelWidthStore.js +12 -0
- package/dist/stores/panelWidthStore.js.map +1 -0
- package/dist/stores/terminalStore.d.ts +17 -1
- package/dist/stores/terminalStore.d.ts.map +1 -1
- package/dist/stores/terminalStore.js +27 -20
- package/dist/stores/terminalStore.js.map +1 -1
- package/package.json +3 -3
- package/dist/components/terminals/TerminalList.d.ts +0 -8
- package/dist/components/terminals/TerminalList.d.ts.map +0 -1
- package/dist/components/terminals/TerminalList.js +0 -32
- package/dist/components/terminals/TerminalList.js.map +0 -1
- package/dist/components/terminals/TerminalsSidebar.d.ts +0 -2
- package/dist/components/terminals/TerminalsSidebar.d.ts.map +0 -1
- package/dist/components/terminals/TerminalsSidebar.js +0 -34
- package/dist/components/terminals/TerminalsSidebar.js.map +0 -1
- package/dist/components/terminals/TerminalsSidebarToggle.d.ts +0 -2
- package/dist/components/terminals/TerminalsSidebarToggle.d.ts.map +0 -1
- package/dist/components/terminals/TerminalsSidebarToggle.js +0 -13
- package/dist/components/terminals/TerminalsSidebarToggle.js.map +0 -1
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { memo } from 'react';
|
|
3
|
+
import { Terminal } from 'lucide-react';
|
|
4
|
+
import { useTerminalStore } from '../../stores/terminalStore';
|
|
5
|
+
import { useTerminals } from '../../hooks/useTerminals';
|
|
6
|
+
export const TerminalPanelToggle = memo(function TerminalPanelToggle() {
|
|
7
|
+
const isOpen = useTerminalStore((s) => s.isOpen);
|
|
8
|
+
const togglePanel = useTerminalStore((s) => s.togglePanel);
|
|
9
|
+
const { data } = useTerminals();
|
|
10
|
+
const count = data?.count ?? 0;
|
|
11
|
+
return (_jsxs("button", { type: "button", onClick: togglePanel, className: `relative h-14 w-full transition-colors touch-manipulation flex items-center justify-center ${isOpen ? 'bg-muted border-r-2 border-primary' : 'hover:bg-muted/50'}`, title: "Terminals", children: [_jsx(Terminal, { className: "w-5 h-5 text-muted-foreground mx-auto" }), count > 0 && (_jsx("span", { className: "absolute top-1 right-1 w-5 h-5 bg-primary text-primary-foreground text-xs rounded-full flex items-center justify-center font-semibold", children: count > 9 ? '9+' : count }))] }));
|
|
12
|
+
});
|
|
13
|
+
//# sourceMappingURL=TerminalPanelToggle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TerminalPanelToggle.js","sourceRoot":"","sources":["../../../src/components/terminals/TerminalPanelToggle.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC;AAC7B,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAExD,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,CAAC,SAAS,mBAAmB;IACnE,MAAM,MAAM,GAAG,gBAAgB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IACjD,MAAM,WAAW,GAAG,gBAAgB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;IAC3D,MAAM,EAAE,IAAI,EAAE,GAAG,YAAY,EAAE,CAAC;IAEhC,MAAM,KAAK,GAAG,IAAI,EAAE,KAAK,IAAI,CAAC,CAAC;IAE/B,OAAO,CACN,kBACC,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,WAAW,EACpB,SAAS,EAAE,8FACV,MAAM,CAAC,CAAC,CAAC,oCAAoC,CAAC,CAAC,CAAC,mBACjD,EAAE,EACF,KAAK,EAAC,WAAW,aAEjB,KAAC,QAAQ,IAAC,SAAS,EAAC,uCAAuC,GAAG,EAC7D,KAAK,GAAG,CAAC,IAAI,CACb,eAAM,SAAS,EAAC,uIAAuI,YACrJ,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,GACnB,CACP,IACO,CACT,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Terminal } from '../../hooks/useTerminals';
|
|
2
|
+
interface TerminalTabBarProps {
|
|
3
|
+
terminals: Terminal[];
|
|
4
|
+
onNewTerminal: () => void;
|
|
5
|
+
onKillTerminal: (id: string) => void;
|
|
6
|
+
isCreating?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare const TerminalTabBar: import("react").NamedExoticComponent<TerminalTabBarProps>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=TerminalTabBar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TerminalTabBar.d.ts","sourceRoot":"","sources":["../../../src/components/terminals/TerminalTabBar.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAEzD,UAAU,mBAAmB;IAC5B,SAAS,EAAE,QAAQ,EAAE,CAAC;IACtB,aAAa,EAAE,MAAM,IAAI,CAAC;IAC1B,cAAc,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,UAAU,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,cAAc,2DAqEzB,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { memo } from 'react';
|
|
3
|
+
import { Plus, X, Bot, User } from 'lucide-react';
|
|
4
|
+
import { useTerminalStore } from '../../stores/terminalStore';
|
|
5
|
+
export const TerminalTabBar = memo(function TerminalTabBar({ terminals, onNewTerminal, onKillTerminal, isCreating, }) {
|
|
6
|
+
const activeTabId = useTerminalStore((s) => s.activeTabId);
|
|
7
|
+
const selectTab = useTerminalStore((s) => s.selectTab);
|
|
8
|
+
return (_jsxs("div", { className: "flex items-center gap-0 overflow-x-auto scrollbar-none", children: [terminals.map((t) => {
|
|
9
|
+
const isActive = t.id === activeTabId;
|
|
10
|
+
const isRunning = t.status === 'running';
|
|
11
|
+
return (_jsxs("div", { className: `group flex items-center gap-1.5 px-3 h-9 border-r border-border cursor-pointer select-none shrink-0 transition-colors ${isActive
|
|
12
|
+
? 'bg-background text-foreground'
|
|
13
|
+
: 'bg-muted/30 text-muted-foreground hover:bg-muted/60'}`, onClick: () => selectTab(t.id), onKeyDown: (e) => {
|
|
14
|
+
if (e.key === 'Enter')
|
|
15
|
+
selectTab(t.id);
|
|
16
|
+
}, role: "tab", "aria-selected": isActive, tabIndex: 0, children: [_jsx("span", { className: "shrink-0", children: t.createdBy === 'llm' ? (_jsx(Bot, { className: "w-3 h-3 text-blue-500" })) : (_jsx(User, { className: "w-3 h-3 text-green-500" })) }), _jsx("span", { className: "text-xs font-medium truncate max-w-[120px]", children: t.title || t.purpose }), !isRunning && (_jsx("span", { className: "w-1.5 h-1.5 rounded-full bg-orange-500 shrink-0" })), _jsx("button", { type: "button", className: "shrink-0 p-0.5 rounded opacity-0 group-hover:opacity-100 hover:bg-muted transition-opacity", onClick: (e) => {
|
|
17
|
+
e.stopPropagation();
|
|
18
|
+
onKillTerminal(t.id);
|
|
19
|
+
}, title: "Close terminal", children: _jsx(X, { className: "w-3 h-3" }) })] }, t.id));
|
|
20
|
+
}), _jsx("button", { type: "button", className: "flex items-center justify-center w-8 h-9 shrink-0 text-muted-foreground hover:text-foreground hover:bg-muted/50 transition-colors", onClick: onNewTerminal, disabled: isCreating, title: "New terminal", children: _jsx(Plus, { className: "w-3.5 h-3.5" }) })] }));
|
|
21
|
+
});
|
|
22
|
+
//# sourceMappingURL=TerminalTabBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TerminalTabBar.js","sourceRoot":"","sources":["../../../src/components/terminals/TerminalTabBar.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC;AAC7B,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAU9D,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,cAAc,CAAC,EAC1D,SAAS,EACT,aAAa,EACb,cAAc,EACd,UAAU,GACW;IACrB,MAAM,WAAW,GAAG,gBAAgB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;IAC3D,MAAM,SAAS,GAAG,gBAAgB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAEvD,OAAO,CACN,eAAK,SAAS,EAAC,wDAAwD,aACrE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACpB,MAAM,QAAQ,GAAG,CAAC,CAAC,EAAE,KAAK,WAAW,CAAC;gBACtC,MAAM,SAAS,GAAG,CAAC,CAAC,MAAM,KAAK,SAAS,CAAC;gBAEzC,OAAO,CACN,eAEC,SAAS,EAAE,yHACV,QAAQ;wBACP,CAAC,CAAC,+BAA+B;wBACjC,CAAC,CAAC,qDACJ,EAAE,EACF,OAAO,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,EAC9B,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE;wBAChB,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO;4BAAE,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;oBACxC,CAAC,EACD,IAAI,EAAC,KAAK,mBACK,QAAQ,EACvB,QAAQ,EAAE,CAAC,aAEX,eAAM,SAAS,EAAC,UAAU,YACxB,CAAC,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,CACxB,KAAC,GAAG,IAAC,SAAS,EAAC,uBAAuB,GAAG,CACzC,CAAC,CAAC,CAAC,CACH,KAAC,IAAI,IAAC,SAAS,EAAC,wBAAwB,GAAG,CAC3C,GACK,EACP,eAAM,SAAS,EAAC,4CAA4C,YAC1D,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,OAAO,GACf,EACN,CAAC,SAAS,IAAI,CACd,eAAM,SAAS,EAAC,iDAAiD,GAAG,CACpE,EACD,iBACC,IAAI,EAAC,QAAQ,EACb,SAAS,EAAC,4FAA4F,EACtG,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;gCACd,CAAC,CAAC,eAAe,EAAE,CAAC;gCACpB,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;4BACtB,CAAC,EACD,KAAK,EAAC,gBAAgB,YAEtB,KAAC,CAAC,IAAC,SAAS,EAAC,SAAS,GAAG,GACjB,KArCJ,CAAC,CAAC,EAAE,CAsCJ,CACN,CAAC;YACH,CAAC,CAAC,EACF,iBACC,IAAI,EAAC,QAAQ,EACb,SAAS,EAAC,mIAAmI,EAC7I,OAAO,EAAE,aAAa,EACtB,QAAQ,EAAE,UAAU,EACpB,KAAK,EAAC,cAAc,YAEpB,KAAC,IAAI,IAAC,SAAS,EAAC,aAAa,GAAG,GACxB,IACJ,CACN,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
interface TerminalViewerProps {
|
|
2
2
|
terminalId: string;
|
|
3
|
+
onExit?: (terminalId: string) => void;
|
|
3
4
|
}
|
|
4
|
-
export declare function TerminalViewer({ terminalId }: TerminalViewerProps): import("react/jsx-runtime").JSX.Element;
|
|
5
|
+
export declare function TerminalViewer({ terminalId, onExit }: TerminalViewerProps): import("react/jsx-runtime").JSX.Element;
|
|
5
6
|
export {};
|
|
6
7
|
//# sourceMappingURL=TerminalViewer.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TerminalViewer.d.ts","sourceRoot":"","sources":["../../../src/components/terminals/TerminalViewer.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"TerminalViewer.d.ts","sourceRoot":"","sources":["../../../src/components/terminals/TerminalViewer.tsx"],"names":[],"mappings":"AA2FA,UAAU,mBAAmB;IAC5B,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;CACtC;AAED,wBAAgB,cAAc,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,EAAE,mBAAmB,2CAgRzE"}
|
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { useEffect, useRef, useState } from 'react';
|
|
2
|
+
import { useEffect, useRef, useState, useCallback } from 'react';
|
|
3
3
|
import { init, Terminal, FitAddon } from 'ghostty-web';
|
|
4
|
-
import { ArrowLeft, X } from 'lucide-react';
|
|
5
|
-
import { Button } from '../ui/Button';
|
|
6
4
|
import { useTerminals } from '../../hooks/useTerminals';
|
|
7
|
-
import { useTerminalStore } from '../../stores/terminalStore';
|
|
8
5
|
import { getRuntimeApiBaseUrl } from '../../lib/config';
|
|
9
6
|
import { client } from '@ottocode/api';
|
|
10
7
|
const FONT_FAMILY = '"JetBrainsMono NFM", monospace';
|
|
8
|
+
const SSE_RECONNECT_DELAY = 1500;
|
|
9
|
+
const SSE_MAX_RETRIES = 5;
|
|
11
10
|
function resolveBackgroundColor() {
|
|
12
11
|
if (typeof document === 'undefined')
|
|
13
12
|
return '#121216';
|
|
@@ -80,42 +79,93 @@ function resolveApiBaseUrl() {
|
|
|
80
79
|
}
|
|
81
80
|
return getRuntimeApiBaseUrl();
|
|
82
81
|
}
|
|
83
|
-
export function TerminalViewer({ terminalId }) {
|
|
84
|
-
const
|
|
82
|
+
export function TerminalViewer({ terminalId, onExit }) {
|
|
83
|
+
const containerRef = useRef(null);
|
|
85
84
|
const xtermRef = useRef(null);
|
|
86
85
|
const fitAddonRef = useRef(null);
|
|
87
86
|
const eventSourceRef = useRef(null);
|
|
87
|
+
const retryCountRef = useRef(0);
|
|
88
|
+
const retryTimerRef = useRef(null);
|
|
88
89
|
const [ready, setReady] = useState(false);
|
|
89
90
|
const { data: terminals } = useTerminals();
|
|
90
|
-
const { selectTerminal } = useTerminalStore();
|
|
91
91
|
const terminal = terminals?.terminals.find((t) => t.id === terminalId);
|
|
92
|
-
const
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
92
|
+
const fitTerminal = useCallback(() => {
|
|
93
|
+
if (fitAddonRef.current) {
|
|
94
|
+
try {
|
|
95
|
+
fitAddonRef.current.fit();
|
|
96
|
+
}
|
|
97
|
+
catch {
|
|
98
|
+
// container might not be visible yet
|
|
99
|
+
}
|
|
99
100
|
}
|
|
100
|
-
|
|
101
|
-
|
|
101
|
+
}, []);
|
|
102
|
+
const connectSSE = useCallback((xterm, baseUrl) => {
|
|
103
|
+
if (eventSourceRef.current) {
|
|
104
|
+
eventSourceRef.current.close();
|
|
105
|
+
eventSourceRef.current = null;
|
|
102
106
|
}
|
|
103
|
-
|
|
107
|
+
const eventSource = new EventSource(`${baseUrl}/v1/terminals/${terminalId}/output`);
|
|
108
|
+
eventSourceRef.current = eventSource;
|
|
109
|
+
let gotFirstData = false;
|
|
110
|
+
eventSource.onmessage = (event) => {
|
|
111
|
+
try {
|
|
112
|
+
const data = JSON.parse(event.data);
|
|
113
|
+
if (data.type === 'data') {
|
|
114
|
+
xterm.write(data.line);
|
|
115
|
+
if (!gotFirstData) {
|
|
116
|
+
gotFirstData = true;
|
|
117
|
+
setTimeout(() => setReady(true), 200);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
else if (data.type === 'exit') {
|
|
121
|
+
xterm.write(`\r\n\x1b[33m[Process exited with code ${data.exitCode}]\x1b[0m\r\n`);
|
|
122
|
+
if (onExit) {
|
|
123
|
+
onExit(terminalId);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
catch {
|
|
128
|
+
// ignore parse errors
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
eventSource.onerror = () => {
|
|
132
|
+
eventSource.close();
|
|
133
|
+
if (eventSourceRef.current === eventSource) {
|
|
134
|
+
eventSourceRef.current = null;
|
|
135
|
+
}
|
|
136
|
+
if (retryCountRef.current < SSE_MAX_RETRIES) {
|
|
137
|
+
retryCountRef.current++;
|
|
138
|
+
retryTimerRef.current = setTimeout(() => {
|
|
139
|
+
if (xtermRef.current) {
|
|
140
|
+
connectSSE(xtermRef.current, baseUrl);
|
|
141
|
+
}
|
|
142
|
+
}, SSE_RECONNECT_DELAY);
|
|
143
|
+
}
|
|
144
|
+
};
|
|
145
|
+
eventSource.onopen = () => {
|
|
146
|
+
retryCountRef.current = 0;
|
|
147
|
+
};
|
|
148
|
+
}, [terminalId]);
|
|
104
149
|
useEffect(() => {
|
|
105
|
-
if (!
|
|
150
|
+
if (!containerRef.current || !terminalId)
|
|
106
151
|
return;
|
|
107
152
|
let disposed = false;
|
|
108
153
|
let xterm = null;
|
|
109
154
|
let fitAddon = null;
|
|
110
|
-
let
|
|
155
|
+
let resizeObserver = null;
|
|
111
156
|
setReady(false);
|
|
157
|
+
retryCountRef.current = 0;
|
|
112
158
|
if (eventSourceRef.current) {
|
|
113
159
|
eventSourceRef.current.close();
|
|
114
160
|
eventSourceRef.current = null;
|
|
115
161
|
}
|
|
162
|
+
if (retryTimerRef.current) {
|
|
163
|
+
clearTimeout(retryTimerRef.current);
|
|
164
|
+
retryTimerRef.current = null;
|
|
165
|
+
}
|
|
116
166
|
const setup = async () => {
|
|
117
167
|
await init();
|
|
118
|
-
if (disposed || !
|
|
168
|
+
if (disposed || !containerRef.current)
|
|
119
169
|
return;
|
|
120
170
|
await loadEmbeddedFont();
|
|
121
171
|
await document.fonts.ready;
|
|
@@ -148,19 +198,19 @@ export function TerminalViewer({ terminalId }) {
|
|
|
148
198
|
fontFamily: FONT_FAMILY,
|
|
149
199
|
cursorBlink: true,
|
|
150
200
|
convertEol: true,
|
|
151
|
-
scrollback:
|
|
201
|
+
scrollback: 5000,
|
|
152
202
|
});
|
|
153
203
|
fitAddon = new FitAddon();
|
|
154
204
|
xterm.loadAddon(fitAddon);
|
|
155
|
-
xterm.open(
|
|
205
|
+
xterm.open(containerRef.current);
|
|
156
206
|
xterm.focus();
|
|
157
207
|
await new Promise((resolve) => {
|
|
158
208
|
requestAnimationFrame(() => {
|
|
159
209
|
try {
|
|
160
210
|
fitAddon?.fit();
|
|
161
211
|
}
|
|
162
|
-
catch
|
|
163
|
-
|
|
212
|
+
catch {
|
|
213
|
+
// container might not be visible
|
|
164
214
|
}
|
|
165
215
|
resolve();
|
|
166
216
|
});
|
|
@@ -178,66 +228,34 @@ export function TerminalViewer({ terminalId }) {
|
|
|
178
228
|
if (xterm) {
|
|
179
229
|
sendResize(xterm.cols, xterm.rows);
|
|
180
230
|
}
|
|
181
|
-
|
|
182
|
-
eventSourceRef.current = eventSource;
|
|
183
|
-
let gotFirstData = false;
|
|
184
|
-
eventSource.onmessage = (event) => {
|
|
185
|
-
try {
|
|
186
|
-
const data = JSON.parse(event.data);
|
|
187
|
-
if (data.type === 'data') {
|
|
188
|
-
xterm?.write(data.line);
|
|
189
|
-
if (!gotFirstData) {
|
|
190
|
-
gotFirstData = true;
|
|
191
|
-
setTimeout(() => {
|
|
192
|
-
if (!disposed)
|
|
193
|
-
setReady(true);
|
|
194
|
-
}, 350);
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
else if (data.type === 'exit') {
|
|
198
|
-
xterm?.write(`\r\n\x1b[33m[Process exited with code ${data.exitCode}]\x1b[0m\r\n`);
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
catch (error) {
|
|
202
|
-
console.error('Failed to parse terminal output:', error);
|
|
203
|
-
}
|
|
204
|
-
};
|
|
205
|
-
eventSource.onerror = (error) => {
|
|
206
|
-
if (eventSource.readyState !== EventSource.CLOSED) {
|
|
207
|
-
console.error('[TerminalViewer] SSE error:', error);
|
|
208
|
-
}
|
|
209
|
-
eventSource.close();
|
|
210
|
-
if (eventSourceRef.current === eventSource) {
|
|
211
|
-
eventSourceRef.current = null;
|
|
212
|
-
}
|
|
213
|
-
};
|
|
231
|
+
connectSSE(xterm, baseUrl);
|
|
214
232
|
xterm.onData((data) => {
|
|
215
233
|
fetch(`${baseUrl}/v1/terminals/${terminalId}/input`, {
|
|
216
234
|
method: 'POST',
|
|
217
235
|
headers: { 'Content-Type': 'application/json' },
|
|
218
236
|
body: JSON.stringify({ input: data }),
|
|
219
|
-
}).catch((
|
|
220
|
-
console.error('Failed to send terminal input:', error);
|
|
221
|
-
});
|
|
237
|
+
}).catch(() => { });
|
|
222
238
|
});
|
|
223
239
|
xterm.onResize(({ cols, rows }) => {
|
|
224
240
|
sendResize(cols, rows);
|
|
225
241
|
});
|
|
226
242
|
xtermRef.current = xterm;
|
|
227
243
|
fitAddonRef.current = fitAddon;
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
244
|
+
resizeObserver = new ResizeObserver(() => {
|
|
245
|
+
requestAnimationFrame(() => {
|
|
246
|
+
if (fitAddonRef.current && !disposed) {
|
|
247
|
+
try {
|
|
248
|
+
fitAddonRef.current.fit();
|
|
249
|
+
}
|
|
250
|
+
catch {
|
|
251
|
+
// ignore
|
|
252
|
+
}
|
|
235
253
|
}
|
|
236
|
-
}
|
|
237
|
-
};
|
|
238
|
-
|
|
254
|
+
});
|
|
255
|
+
});
|
|
256
|
+
resizeObserver.observe(containerRef.current);
|
|
239
257
|
setTimeout(() => {
|
|
240
|
-
if (!disposed
|
|
258
|
+
if (!disposed)
|
|
241
259
|
setReady(true);
|
|
242
260
|
}, 2000);
|
|
243
261
|
};
|
|
@@ -246,18 +264,27 @@ export function TerminalViewer({ terminalId }) {
|
|
|
246
264
|
});
|
|
247
265
|
return () => {
|
|
248
266
|
disposed = true;
|
|
267
|
+
if (retryTimerRef.current) {
|
|
268
|
+
clearTimeout(retryTimerRef.current);
|
|
269
|
+
retryTimerRef.current = null;
|
|
270
|
+
}
|
|
249
271
|
if (eventSourceRef.current) {
|
|
250
272
|
eventSourceRef.current.close();
|
|
251
273
|
eventSourceRef.current = null;
|
|
252
274
|
}
|
|
253
|
-
if (
|
|
254
|
-
|
|
275
|
+
if (resizeObserver) {
|
|
276
|
+
resizeObserver.disconnect();
|
|
255
277
|
}
|
|
256
278
|
if (xterm) {
|
|
257
279
|
xterm.dispose();
|
|
258
280
|
}
|
|
281
|
+
xtermRef.current = null;
|
|
282
|
+
fitAddonRef.current = null;
|
|
259
283
|
};
|
|
260
|
-
}, [terminalId]);
|
|
261
|
-
|
|
284
|
+
}, [terminalId, connectSSE]);
|
|
285
|
+
useEffect(() => {
|
|
286
|
+
fitTerminal();
|
|
287
|
+
}, [fitTerminal]);
|
|
288
|
+
return (_jsx("div", { className: "flex h-full flex-col overflow-hidden bg-background", children: _jsxs("div", { className: "relative flex-1 min-h-0 overflow-hidden", children: [_jsx("div", { ref: containerRef, className: "absolute inset-0 bg-background" }), _jsx("div", { className: "absolute inset-0 bg-background flex items-center justify-center pointer-events-none transition-opacity duration-300", style: { opacity: ready ? 0 : 1 }, children: _jsxs("div", { className: "flex items-center gap-2 text-muted-foreground", children: [_jsxs("svg", { className: "animate-spin h-4 w-4", viewBox: "0 0 24 24", fill: "none", "aria-hidden": "true", children: [_jsx("circle", { className: "opacity-25", cx: "12", cy: "12", r: "10", stroke: "currentColor", strokeWidth: "4" }), _jsx("path", { className: "opacity-75", fill: "currentColor", d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4z" })] }), _jsx("span", { className: "text-xs", children: "Loading terminal\u2026" })] }) })] }) }));
|
|
262
289
|
}
|
|
263
290
|
//# sourceMappingURL=TerminalViewer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TerminalViewer.js","sourceRoot":"","sources":["../../../src/components/terminals/TerminalViewer.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"TerminalViewer.js","sourceRoot":"","sources":["../../../src/components/terminals/TerminalViewer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TerminalsPanel.d.ts","sourceRoot":"","sources":["../../../src/components/terminals/TerminalsPanel.tsx"],"names":[],"mappings":"AAgBA,eAAO,MAAM,cAAc,8CAyMzB,CAAC"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { memo, useCallback, useRef, useEffect } from 'react';
|
|
3
|
+
import { Terminal as TerminalIcon, Maximize2, Minimize2, ChevronDown, } from 'lucide-react';
|
|
4
|
+
import { useTerminalStore } from '../../stores/terminalStore';
|
|
5
|
+
import { useTerminals, useCreateTerminal, useKillTerminal } from '../../hooks/useTerminals';
|
|
6
|
+
import { TerminalTabBar } from './TerminalTabBar';
|
|
7
|
+
import { TerminalViewer } from './TerminalViewer';
|
|
8
|
+
const MIN_HEIGHT = 150;
|
|
9
|
+
const MAX_HEIGHT_RATIO = 0.85;
|
|
10
|
+
export const TerminalsPanel = memo(function TerminalsPanel() {
|
|
11
|
+
const isOpen = useTerminalStore((s) => s.isOpen);
|
|
12
|
+
const panelHeight = useTerminalStore((s) => s.panelHeight);
|
|
13
|
+
const setPanelHeight = useTerminalStore((s) => s.setPanelHeight);
|
|
14
|
+
const activeTabId = useTerminalStore((s) => s.activeTabId);
|
|
15
|
+
const selectTab = useTerminalStore((s) => s.selectTab);
|
|
16
|
+
const closePanel = useTerminalStore((s) => s.closePanel);
|
|
17
|
+
const isMaximized = useTerminalStore((s) => s.isMaximized);
|
|
18
|
+
const toggleMaximize = useTerminalStore((s) => s.toggleMaximize);
|
|
19
|
+
const togglePanel = useTerminalStore((s) => s.togglePanel);
|
|
20
|
+
const { data: terminals } = useTerminals();
|
|
21
|
+
const createTerminal = useCreateTerminal();
|
|
22
|
+
const killTerminal = useKillTerminal();
|
|
23
|
+
const dragRef = useRef(null);
|
|
24
|
+
const terminalsList = terminals?.terminals ?? [];
|
|
25
|
+
const autoCreatingRef = useRef(false);
|
|
26
|
+
const terminalsListRef = useRef(terminalsList);
|
|
27
|
+
terminalsListRef.current = terminalsList;
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
if (isOpen &&
|
|
30
|
+
terminalsList.length > 0 &&
|
|
31
|
+
(!activeTabId || !terminalsList.find((t) => t.id === activeTabId))) {
|
|
32
|
+
selectTab(terminalsList[0].id);
|
|
33
|
+
}
|
|
34
|
+
}, [isOpen, terminalsList, activeTabId, selectTab]);
|
|
35
|
+
useEffect(() => {
|
|
36
|
+
if (isOpen && terminals && terminalsList.length === 0 && !autoCreatingRef.current && !createTerminal.isPending) {
|
|
37
|
+
autoCreatingRef.current = true;
|
|
38
|
+
createTerminal.mutateAsync({
|
|
39
|
+
command: 'bash',
|
|
40
|
+
purpose: 'Manual shell',
|
|
41
|
+
}).then((result) => {
|
|
42
|
+
selectTab(result.terminalId);
|
|
43
|
+
}).catch(() => { }).finally(() => {
|
|
44
|
+
autoCreatingRef.current = false;
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
}, [isOpen, terminals, terminalsList.length, createTerminal, selectTab]);
|
|
48
|
+
const handleNewTerminal = useCallback(async () => {
|
|
49
|
+
try {
|
|
50
|
+
const result = await createTerminal.mutateAsync({
|
|
51
|
+
command: 'bash',
|
|
52
|
+
purpose: 'Manual shell',
|
|
53
|
+
});
|
|
54
|
+
selectTab(result.terminalId);
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
// ignore
|
|
58
|
+
}
|
|
59
|
+
}, [createTerminal, selectTab]);
|
|
60
|
+
const handleKillTerminal = useCallback(async (id) => {
|
|
61
|
+
try {
|
|
62
|
+
await killTerminal.mutateAsync(id);
|
|
63
|
+
if (activeTabId === id) {
|
|
64
|
+
const remaining = terminalsListRef.current.filter((t) => t.id !== id);
|
|
65
|
+
if (remaining.length > 0) {
|
|
66
|
+
selectTab(remaining[0].id);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
selectTab(null);
|
|
70
|
+
closePanel();
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
catch {
|
|
75
|
+
// ignore
|
|
76
|
+
}
|
|
77
|
+
}, [killTerminal, activeTabId, selectTab, closePanel]);
|
|
78
|
+
useEffect(() => {
|
|
79
|
+
const handleKeyDown = (e) => {
|
|
80
|
+
if (e.key === '`' && e.ctrlKey) {
|
|
81
|
+
e.preventDefault();
|
|
82
|
+
togglePanel();
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
window.addEventListener('keydown', handleKeyDown);
|
|
86
|
+
return () => window.removeEventListener('keydown', handleKeyDown);
|
|
87
|
+
}, [togglePanel]);
|
|
88
|
+
const handleResizeStart = useCallback((e) => {
|
|
89
|
+
e.preventDefault();
|
|
90
|
+
dragRef.current = {
|
|
91
|
+
startY: e.clientY,
|
|
92
|
+
startHeight: panelHeight,
|
|
93
|
+
};
|
|
94
|
+
const handleMouseMove = (ev) => {
|
|
95
|
+
if (!dragRef.current)
|
|
96
|
+
return;
|
|
97
|
+
const delta = dragRef.current.startY - ev.clientY;
|
|
98
|
+
const newHeight = dragRef.current.startHeight + delta;
|
|
99
|
+
const maxH = window.innerHeight * MAX_HEIGHT_RATIO;
|
|
100
|
+
setPanelHeight(Math.min(Math.max(MIN_HEIGHT, newHeight), maxH));
|
|
101
|
+
};
|
|
102
|
+
const handleMouseUp = () => {
|
|
103
|
+
dragRef.current = null;
|
|
104
|
+
document.removeEventListener('mousemove', handleMouseMove);
|
|
105
|
+
document.removeEventListener('mouseup', handleMouseUp);
|
|
106
|
+
document.body.style.cursor = '';
|
|
107
|
+
document.body.style.userSelect = '';
|
|
108
|
+
};
|
|
109
|
+
document.addEventListener('mousemove', handleMouseMove);
|
|
110
|
+
document.addEventListener('mouseup', handleMouseUp);
|
|
111
|
+
document.body.style.cursor = 'row-resize';
|
|
112
|
+
document.body.style.userSelect = 'none';
|
|
113
|
+
}, [panelHeight, setPanelHeight]);
|
|
114
|
+
if (!isOpen)
|
|
115
|
+
return null;
|
|
116
|
+
const height = isMaximized ? '100%' : `${panelHeight}px`;
|
|
117
|
+
return (_jsxs("div", { className: "border-t border-border bg-background flex flex-col shrink-0", style: { height, minHeight: MIN_HEIGHT }, children: [!isMaximized && (_jsx("div", { className: "h-1 cursor-row-resize hover:bg-primary/30 active:bg-primary/50 transition-colors shrink-0", onMouseDown: handleResizeStart })), _jsxs("div", { className: "h-9 border-b border-border flex items-center shrink-0", children: [_jsxs("div", { className: "flex items-center gap-1.5 px-3 shrink-0 border-r border-border h-full", children: [_jsx(TerminalIcon, { className: "w-3.5 h-3.5 text-muted-foreground" }), _jsx("span", { className: "text-xs font-medium text-muted-foreground", children: "Terminal" }), terminalsList.length > 0 && (_jsxs("span", { className: "text-[10px] text-muted-foreground/70", children: ["(", terminalsList.length, ")"] }))] }), _jsx(TerminalTabBar, { terminals: terminalsList, onNewTerminal: handleNewTerminal, onKillTerminal: handleKillTerminal, isCreating: createTerminal.isPending }), _jsxs("div", { className: "ml-auto flex items-center gap-0.5 px-2 shrink-0", children: [_jsx("button", { type: "button", className: "p-1 rounded text-muted-foreground hover:text-foreground hover:bg-muted transition-colors", onClick: toggleMaximize, title: isMaximized ? 'Restore' : 'Maximize', children: isMaximized ? (_jsx(Minimize2, { className: "w-3.5 h-3.5" })) : (_jsx(Maximize2, { className: "w-3.5 h-3.5" })) }), _jsx("button", { type: "button", className: "p-1 rounded text-muted-foreground hover:text-foreground hover:bg-muted transition-colors", onClick: closePanel, title: "Close panel", children: _jsx(ChevronDown, { className: "w-3.5 h-3.5" }) })] })] }), _jsx("div", { className: "flex-1 min-h-0 overflow-hidden", children: activeTabId ? (_jsx(TerminalViewer, { terminalId: activeTabId, onExit: handleKillTerminal })) : (_jsxs("div", { className: "flex flex-col items-center justify-center h-full text-muted-foreground", children: [_jsx(TerminalIcon, { className: "w-8 h-8 mb-2 opacity-40" }), _jsx("div", { className: "text-xs", children: terminalsList.length === 0
|
|
118
|
+
? 'No terminals running'
|
|
119
|
+
: 'Select a terminal tab' })] })) })] }));
|
|
120
|
+
});
|
|
121
|
+
//# sourceMappingURL=TerminalsPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TerminalsPanel.js","sourceRoot":"","sources":["../../../src/components/terminals/TerminalsPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,11 @@
|
|
|
1
|
-
export {
|
|
2
|
-
export {
|
|
1
|
+
export { TerminalsPanel } from './TerminalsPanel';
|
|
2
|
+
export { TerminalPanelToggle } from './TerminalPanelToggle';
|
|
3
|
+
export { TerminalTabBar } from './TerminalTabBar';
|
|
3
4
|
export { TerminalViewer } from './TerminalViewer';
|
|
4
|
-
|
|
5
|
+
/** @deprecated Use TerminalsPanel instead */
|
|
6
|
+
export { TerminalsPanel as TerminalsSidebar } from './TerminalsPanel';
|
|
7
|
+
/** @deprecated Use TerminalPanelToggle instead */
|
|
8
|
+
export { TerminalPanelToggle as TerminalsSidebarToggle } from './TerminalPanelToggle';
|
|
9
|
+
/** @deprecated Use TerminalTabBar instead */
|
|
10
|
+
export { TerminalTabBar as TerminalList } from './TerminalTabBar';
|
|
5
11
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/terminals/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/terminals/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,6CAA6C;AAC7C,OAAO,EAAE,cAAc,IAAI,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACtE,kDAAkD;AAClD,OAAO,EAAE,mBAAmB,IAAI,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AACtF,6CAA6C;AAC7C,OAAO,EAAE,cAAc,IAAI,YAAY,EAAE,MAAM,kBAAkB,CAAC"}
|
|
@@ -1,5 +1,11 @@
|
|
|
1
|
-
export {
|
|
2
|
-
export {
|
|
1
|
+
export { TerminalsPanel } from './TerminalsPanel';
|
|
2
|
+
export { TerminalPanelToggle } from './TerminalPanelToggle';
|
|
3
|
+
export { TerminalTabBar } from './TerminalTabBar';
|
|
3
4
|
export { TerminalViewer } from './TerminalViewer';
|
|
4
|
-
|
|
5
|
+
/** @deprecated Use TerminalsPanel instead */
|
|
6
|
+
export { TerminalsPanel as TerminalsSidebar } from './TerminalsPanel';
|
|
7
|
+
/** @deprecated Use TerminalPanelToggle instead */
|
|
8
|
+
export { TerminalPanelToggle as TerminalsSidebarToggle } from './TerminalPanelToggle';
|
|
9
|
+
/** @deprecated Use TerminalTabBar instead */
|
|
10
|
+
export { TerminalTabBar as TerminalList } from './TerminalTabBar';
|
|
5
11
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/terminals/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/terminals/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,6CAA6C;AAC7C,OAAO,EAAE,cAAc,IAAI,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACtE,kDAAkD;AAClD,OAAO,EAAE,mBAAmB,IAAI,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AACtF,6CAA6C;AAC7C,OAAO,EAAE,cAAc,IAAI,YAAY,EAAE,MAAM,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
interface ResizeHandleProps {
|
|
2
|
+
panelKey: string;
|
|
3
|
+
side: 'left' | 'right';
|
|
4
|
+
minWidth: number;
|
|
5
|
+
maxWidth: number;
|
|
6
|
+
defaultWidth: number;
|
|
7
|
+
onWidthChange?: (width: number) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare const ResizeHandle: import("react").NamedExoticComponent<ResizeHandleProps>;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=ResizeHandle.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResizeHandle.d.ts","sourceRoot":"","sources":["../../../src/components/ui/ResizeHandle.tsx"],"names":[],"mappings":"AAGA,UAAU,iBAAiB;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACxC;AAED,eAAO,MAAM,YAAY,yDAqDvB,CAAC"}
|