@opentabs-dev/browser-extension 0.0.62 → 0.0.64
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/background-message-handlers.d.ts +3 -1
- package/dist/background-message-handlers.d.ts.map +1 -1
- package/dist/background-message-handlers.js +77 -4
- package/dist/background-message-handlers.js.map +1 -1
- package/dist/background.js +83 -69
- package/dist/extension-messages.d.ts +8 -1
- package/dist/extension-messages.d.ts.map +1 -1
- package/dist/message-router.d.ts.map +1 -1
- package/dist/message-router.js +2 -0
- package/dist/message-router.js.map +1 -1
- package/dist/offscreen/index.js +1 -1
- package/dist/offscreen/index.js.map +1 -1
- package/dist/side-panel/App.d.ts.map +1 -1
- package/dist/side-panel/App.js +26 -5
- package/dist/side-panel/App.js.map +1 -1
- package/dist/side-panel/bridge.d.ts +5 -3
- package/dist/side-panel/bridge.d.ts.map +1 -1
- package/dist/side-panel/bridge.js +10 -3
- package/dist/side-panel/bridge.js.map +1 -1
- package/dist/side-panel/components/BrowserToolsCard.d.ts +1 -2
- package/dist/side-panel/components/BrowserToolsCard.d.ts.map +1 -1
- package/dist/side-panel/components/BrowserToolsCard.js +7 -28
- package/dist/side-panel/components/BrowserToolsCard.js.map +1 -1
- package/dist/side-panel/components/ConfirmationDialog.d.ts.map +1 -1
- package/dist/side-panel/components/ConfirmationDialog.js +2 -1
- package/dist/side-panel/components/ConfirmationDialog.js.map +1 -1
- package/dist/side-panel/components/EmptyStates.d.ts.map +1 -1
- package/dist/side-panel/components/EmptyStates.js +17 -3
- package/dist/side-panel/components/EmptyStates.js.map +1 -1
- package/dist/side-panel/components/NpmPluginCard.d.ts.map +1 -1
- package/dist/side-panel/components/NpmPluginCard.js +1 -1
- package/dist/side-panel/components/NpmPluginCard.js.map +1 -1
- package/dist/side-panel/components/PluginCard.d.ts +2 -2
- package/dist/side-panel/components/PluginCard.d.ts.map +1 -1
- package/dist/side-panel/components/PluginCard.js +55 -33
- package/dist/side-panel/components/PluginCard.js.map +1 -1
- package/dist/side-panel/components/PluginList.d.ts +3 -4
- package/dist/side-panel/components/PluginList.d.ts.map +1 -1
- package/dist/side-panel/components/PluginList.js +136 -4
- package/dist/side-panel/components/PluginList.js.map +1 -1
- package/dist/side-panel/components/PluginMenu.d.ts +3 -1
- package/dist/side-panel/components/PluginMenu.d.ts.map +1 -1
- package/dist/side-panel/components/PluginMenu.js +2 -2
- package/dist/side-panel/components/PluginMenu.js.map +1 -1
- package/dist/side-panel/components/SearchResults.d.ts +5 -2
- package/dist/side-panel/components/SearchResults.d.ts.map +1 -1
- package/dist/side-panel/components/SearchResults.js +5 -4
- package/dist/side-panel/components/SearchResults.js.map +1 -1
- package/dist/side-panel/components/ToolRow.d.ts +6 -2
- package/dist/side-panel/components/ToolRow.d.ts.map +1 -1
- package/dist/side-panel/components/ToolRow.js +9 -3
- package/dist/side-panel/components/ToolRow.js.map +1 -1
- package/dist/side-panel/components/retro/Button.d.ts +1 -1
- package/dist/side-panel/components/retro/Loader.d.ts +1 -1
- package/dist/side-panel/components/retro/Loader.d.ts.map +1 -1
- package/dist/side-panel/components/retro/Loader.js +1 -0
- package/dist/side-panel/components/retro/Loader.js.map +1 -1
- package/dist/side-panel/components/storybook-helpers.d.ts +13 -0
- package/dist/side-panel/components/storybook-helpers.d.ts.map +1 -0
- package/dist/side-panel/components/storybook-helpers.js +55 -0
- package/dist/side-panel/components/storybook-helpers.js.map +1 -0
- package/dist/side-panel/components/tool-groups.d.ts +16 -0
- package/dist/side-panel/components/tool-groups.d.ts.map +1 -0
- package/dist/side-panel/components/tool-groups.js +31 -0
- package/dist/side-panel/components/tool-groups.js.map +1 -0
- package/dist/side-panel/constants.d.ts +1 -1
- package/dist/side-panel/constants.js +1 -1
- package/dist/side-panel/group-transitions.d.ts +55 -0
- package/dist/side-panel/group-transitions.d.ts.map +1 -0
- package/dist/side-panel/group-transitions.js +84 -0
- package/dist/side-panel/group-transitions.js.map +1 -0
- package/dist/side-panel/side-panel.js +2421 -1629
- package/dist/side-panel/styles.css +1 -1
- package/manifest.json +1 -1
- package/package.json +3 -2
|
@@ -2,6 +2,7 @@ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-run
|
|
|
2
2
|
import { useState } from 'react';
|
|
3
3
|
import { Button } from './retro/Button.js';
|
|
4
4
|
import { Dialog } from './retro/Dialog.js';
|
|
5
|
+
import { Switch } from './retro/Switch.js';
|
|
5
6
|
/**
|
|
6
7
|
* Clamps a tracked index to valid bounds after the list shrinks.
|
|
7
8
|
* When the item at `currentIndex` is removed, the index stays the same,
|
|
@@ -30,7 +31,7 @@ const ConfirmationDialog = ({ confirmations, onRespond }) => {
|
|
|
30
31
|
return (_jsx(Dialog, { open: count > 0, onOpenChange: open => {
|
|
31
32
|
if (!open)
|
|
32
33
|
handleDeny();
|
|
33
|
-
}, children: _jsxs(Dialog.Content, { onInteractOutside: e => e.preventDefault(), onEscapeKeyDown: e => e.preventDefault(), children: [_jsxs(Dialog.Header, { children: [_jsx("span", { className: "font-head text-sm", children: "Approve Tool" }), count > 1 && (_jsxs("span", { className: "font-mono text-xs", children: [safeIndex + 1, " of ", count] }))] }), _jsx(Dialog.Body, { className: "space-y-2", children: current && (_jsxs(_Fragment, { children: [_jsxs("div", { children: [_jsx("span", { className: "text-muted-foreground text-xs", children: "Tool" }), _jsx("div", { className: "font-mono text-sm", children: current.tool })] }), _jsxs("div", { children: [_jsx("span", { className: "text-muted-foreground text-xs", children: "Plugin" }), _jsx("div", { className: "font-sans text-sm", children: current.plugin })] }), current.params && Object.keys(current.params).length > 0 && (_jsxs("details", { className: "mt-2", children: [_jsx("summary", { className: "cursor-pointer text-xs", children: "Parameters" }), _jsx("pre", { className: "mt-1 max-h-40 overflow-auto rounded border border-border bg-card px-2 py-1 font-mono text-xs leading-tight", children: JSON.stringify(current.params, null, 2) })] })), _jsxs("
|
|
34
|
+
}, children: _jsxs(Dialog.Content, { onInteractOutside: e => e.preventDefault(), onEscapeKeyDown: e => e.preventDefault(), children: [_jsxs(Dialog.Header, { children: [_jsx("span", { className: "font-head text-sm", children: "Approve Tool" }), count > 1 && (_jsxs("span", { className: "font-mono text-xs", children: [safeIndex + 1, " of ", count] }))] }), _jsx(Dialog.Body, { className: "space-y-2", children: current && (_jsxs(_Fragment, { children: [_jsxs("div", { children: [_jsx("span", { className: "text-muted-foreground text-xs", children: "Tool" }), _jsx("div", { className: "font-mono text-sm", children: current.tool })] }), _jsxs("div", { children: [_jsx("span", { className: "text-muted-foreground text-xs", children: "Plugin" }), _jsx("div", { className: "font-sans text-sm", children: current.plugin })] }), current.params && Object.keys(current.params).length > 0 && (_jsxs("details", { className: "mt-2", children: [_jsx("summary", { className: "cursor-pointer text-xs", children: "Parameters" }), _jsx("pre", { className: "mt-1 max-h-40 overflow-auto rounded border border-border bg-card px-2 py-1 font-mono text-xs leading-tight", children: JSON.stringify(current.params, null, 2) })] })), _jsxs("div", { className: "mt-3 flex items-center gap-2", children: [_jsx(Switch, { checked: alwaysAllow, onCheckedChange: setAlwaysAllow, "aria-label": "Always allow this tool" }), _jsxs("div", { children: [_jsx("span", { className: "text-sm", children: "Always allow this tool" }), _jsx("p", { className: "text-muted-foreground text-xs", children: "Sets permission to Auto" })] })] })] })) }), _jsxs(Dialog.Footer, { children: [count > 1 && (_jsxs(_Fragment, { children: [_jsx("button", { type: "button", className: "mr-auto cursor-pointer font-mono text-muted-foreground text-xs hover:text-foreground disabled:cursor-not-allowed disabled:opacity-40", disabled: safeIndex === 0, onClick: () => setCurrentIndex(i => i - 1), children: "prev" }), _jsx("button", { type: "button", className: "mr-2 cursor-pointer font-mono text-muted-foreground text-xs hover:text-foreground disabled:cursor-not-allowed disabled:opacity-40", disabled: safeIndex >= count - 1, onClick: () => setCurrentIndex(i => i + 1), children: "next" })] })), _jsx(Button, { size: "sm", variant: "outline", onClick: handleDeny, children: "Deny" }), _jsx(Button, { size: "sm", onClick: handleAllow, children: "Allow" })] })] }) }));
|
|
34
35
|
};
|
|
35
36
|
export { ConfirmationDialog, resolveDisplayIndex };
|
|
36
37
|
//# sourceMappingURL=ConfirmationDialog.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfirmationDialog.js","sourceRoot":"","sources":["../../../src/side-panel/components/ConfirmationDialog.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAc3C;;;;;GAKG;AACH,MAAM,mBAAmB,GAAG,CAAC,YAAoB,EAAE,KAAa,EAAU,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;AAE/G,MAAM,kBAAkB,GAAG,CAAC,EAAE,aAAa,EAAE,SAAS,EAA2B,EAAE,EAAE;IACnF,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IACpD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAEtD,MAAM,KAAK,GAAG,aAAa,CAAC,MAAM,CAAC;IACnC,MAAM,SAAS,GAAG,mBAAmB,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IAC3D,MAAM,OAAO,GAAG,aAAa,CAAC,SAAS,CAAC,CAAC;IAEzC,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,IAAI,CAAC,OAAO;YAAE,OAAO;QACrB,SAAS,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,EAAE,WAAW,IAAI,SAAS,CAAC,CAAC;QACzD,cAAc,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC,CAAC;IAEF,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,IAAI,CAAC,OAAO;YAAE,OAAO;QACrB,SAAS,CAAC,OAAO,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;QAC9B,cAAc,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC,CAAC;IAEF,OAAO,CACL,KAAC,MAAM,IACL,IAAI,EAAE,KAAK,GAAG,CAAC,EACf,YAAY,EAAE,IAAI,CAAC,EAAE;YACnB,IAAI,CAAC,IAAI;gBAAE,UAAU,EAAE,CAAC;QAC1B,CAAC,YACD,MAAC,MAAM,CAAC,OAAO,IAAC,iBAAiB,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,EAAE,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,aAClG,MAAC,MAAM,CAAC,MAAM,eACZ,eAAM,SAAS,EAAC,mBAAmB,6BAAoB,EACtD,KAAK,GAAG,CAAC,IAAI,CACZ,gBAAM,SAAS,EAAC,mBAAmB,aAChC,SAAS,GAAG,CAAC,UAAM,KAAK,IACpB,CACR,IACa,EAChB,KAAC,MAAM,CAAC,IAAI,IAAC,SAAS,EAAC,WAAW,YAC/B,OAAO,IAAI,CACV,8BACE,0BACE,eAAM,SAAS,EAAC,+BAA+B,qBAAY,EAC3D,cAAK,SAAS,EAAC,mBAAmB,YAAE,OAAO,CAAC,IAAI,GAAO,IACnD,EACN,0BACE,eAAM,SAAS,EAAC,+BAA+B,uBAAc,EAC7D,cAAK,SAAS,EAAC,mBAAmB,YAAE,OAAO,CAAC,MAAM,GAAO,IACrD,EACL,OAAO,CAAC,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,CAC3D,mBAAS,SAAS,EAAC,MAAM,aACvB,kBAAS,SAAS,EAAC,wBAAwB,2BAAqB,EAChE,cAAK,SAAS,EAAC,4GAA4G,YACxH,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GACpC,IACE,CACX,EACD,
|
|
1
|
+
{"version":3,"file":"ConfirmationDialog.js","sourceRoot":"","sources":["../../../src/side-panel/components/ConfirmationDialog.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EmptyStates.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/EmptyStates.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"EmptyStates.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/EmptyStates.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAqGpE,QAAA,MAAM,iBAAiB,GAAI,YAAY;IAAE,MAAM,CAAC,EAAE,gBAAgB,CAAA;CAAE,4CAGnE,CAAC;AAEF,QAAA,MAAM,YAAY,+CAKjB,CAAC;AAEF,OAAO,EAAE,iBAAiB,EAAE,YAAY,EAAE,CAAC"}
|
|
@@ -1,8 +1,22 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Check, Copy, KeyRound, Unplug } from 'lucide-react';
|
|
2
3
|
import { useEffect, useState } from 'react';
|
|
3
4
|
import { DEFAULT_SERVER_PORT, SERVER_PORT_KEY } from '../../constants.js';
|
|
4
5
|
import { Empty } from './retro/Empty.js';
|
|
5
6
|
import { Loader } from './retro/Loader.js';
|
|
7
|
+
const CopyButton = ({ text }) => {
|
|
8
|
+
const [copied, setCopied] = useState(false);
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
if (!copied)
|
|
11
|
+
return;
|
|
12
|
+
const timer = setTimeout(() => setCopied(false), 1500);
|
|
13
|
+
return () => clearTimeout(timer);
|
|
14
|
+
}, [copied]);
|
|
15
|
+
return (_jsx("button", { type: "button", "aria-label": "Copy command", onClick: () => {
|
|
16
|
+
navigator.clipboard.writeText(text);
|
|
17
|
+
setCopied(true);
|
|
18
|
+
}, className: "absolute top-1/2 right-2 -translate-y-1/2 cursor-pointer text-muted-foreground hover:text-foreground", children: copied ? _jsx(Check, { className: "h-3.5 w-3.5" }) : _jsx(Copy, { className: "h-3.5 w-3.5" }) }));
|
|
19
|
+
};
|
|
6
20
|
const ConnectionRefusedState = () => {
|
|
7
21
|
const [port, setPort] = useState(DEFAULT_SERVER_PORT);
|
|
8
22
|
useEffect(() => {
|
|
@@ -26,14 +40,14 @@ const ConnectionRefusedState = () => {
|
|
|
26
40
|
return () => chrome.storage.onChanged.removeListener(onChanged);
|
|
27
41
|
}, []);
|
|
28
42
|
const command = port === DEFAULT_SERVER_PORT ? 'opentabs start' : `opentabs start --port ${port}`;
|
|
29
|
-
return (_jsx(Empty, { className: "border-destructive/60", children: _jsxs(Empty.Content, { children: [_jsx(Empty.Title, { children: "Cannot Reach MCP Server" }), _jsx(Empty.Separator, { className: "bg-destructive" }), _jsx(Empty.Description, { children: "Start the MCP server:" }), _jsx("code", { className: "rounded border-2 border-destructive/40 bg-destructive/10 px-3 py-2 font-mono text-sm", children: command })] }) }));
|
|
43
|
+
return (_jsx(Empty, { className: "border-destructive/60", children: _jsxs(Empty.Content, { children: [_jsx(Empty.Icon, { className: "h-10 w-10 text-destructive/60", children: _jsx(Unplug, { className: "h-full w-full" }) }), _jsx(Empty.Title, { children: "Cannot Reach MCP Server" }), _jsx(Empty.Separator, { className: "bg-destructive" }), _jsx(Empty.Description, { children: "Start the MCP server:" }), _jsxs("div", { className: "relative", children: [_jsx("code", { className: "block rounded border-2 border-destructive/40 bg-destructive/10 px-3 py-2 pr-9 font-mono text-sm", children: command }), _jsx(CopyButton, { text: command })] }), _jsxs("div", { className: "flex items-center gap-2 text-muted-foreground", role: "status", children: [_jsx(Loader, { size: "sm", variant: "muted" }), _jsx("span", { className: "text-xs", children: "Reconnecting..." })] })] }) }));
|
|
30
44
|
};
|
|
31
|
-
const AuthFailedState = () => (_jsx(Empty, { className: "border-destructive/60", children: _jsxs(Empty.Content, { children: [_jsx(Empty.Title, { children: "Authentication Failed" }), _jsx(Empty.Separator, { className: "bg-destructive" }), _jsx(Empty.Description, { children: "The extension\u2019s secret does not match the server. Reload the extension to pick up the latest secret:" }), _jsx("code", { className: "rounded border-2 border-destructive/40 bg-destructive/10 px-3 py-2 font-mono text-sm", children: "chrome://extensions/ \u2192 reload" })] }) }));
|
|
45
|
+
const AuthFailedState = () => (_jsx(Empty, { className: "border-destructive/60", children: _jsxs(Empty.Content, { children: [_jsx(Empty.Icon, { className: "h-10 w-10 text-destructive/60", children: _jsx(KeyRound, { className: "h-full w-full" }) }), _jsx(Empty.Title, { children: "Authentication Failed" }), _jsx(Empty.Separator, { className: "bg-destructive" }), _jsx(Empty.Description, { children: "The extension\u2019s secret does not match the server. Reload the extension to pick up the latest secret:" }), _jsxs("div", { className: "relative", children: [_jsx("code", { className: "block rounded border-2 border-destructive/40 bg-destructive/10 px-3 py-2 pr-9 font-mono text-sm", children: "chrome://extensions/ \u2192 reload" }), _jsx(CopyButton, { text: "chrome://extensions/" })] })] }) }));
|
|
32
46
|
const DisconnectedState = ({ reason }) => {
|
|
33
47
|
if (reason === 'auth_failed')
|
|
34
48
|
return _jsx(AuthFailedState, {});
|
|
35
49
|
return _jsx(ConnectionRefusedState, {});
|
|
36
50
|
};
|
|
37
|
-
const LoadingState = () => _jsx(Loader, { size: "md" });
|
|
51
|
+
const LoadingState = () => (_jsxs("div", { className: "flex flex-col items-center gap-3", children: [_jsx(Loader, { size: "md" }), _jsx("span", { className: "font-sans text-muted-foreground text-sm", children: "Connecting..." })] }));
|
|
38
52
|
export { DisconnectedState, LoadingState };
|
|
39
53
|
//# sourceMappingURL=EmptyStates.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EmptyStates.js","sourceRoot":"","sources":["../../../src/side-panel/components/EmptyStates.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAE1E,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAE3C,MAAM,sBAAsB,GAAG,GAAG,EAAE;IAClC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,mBAAmB,CAAC,CAAC;IAEtD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC,IAAI,CAC5C,MAAM,CAAC,EAAE;YACP,MAAM,MAAM,GAAG,MAAM,CAAC,eAAe,CAAuB,CAAC;YAC7D,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,MAAM,IAAI,CAAC,IAAI,MAAM,IAAI,KAAK,EAAE,CAAC;gBACjE,OAAO,CAAC,MAAM,CAAC,CAAC;YAClB,CAAC;QACH,CAAC,EACD,GAAG,EAAE;YACH,qCAAqC;QACvC,CAAC,CACF,CAAC;QAEF,MAAM,SAAS,GAAG,CAAC,OAAwD,EAAE,IAAY,EAAE,EAAE;YAC3F,IAAI,IAAI,KAAK,OAAO,IAAI,CAAC,CAAC,eAAe,IAAI,OAAO,CAAC;gBAAE,OAAO;YAC9D,MAAM,QAAQ,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC,QAA8B,CAAC;YACzE,IAAI,OAAO,QAAQ,KAAK,QAAQ,IAAI,QAAQ,IAAI,CAAC,IAAI,QAAQ,IAAI,KAAK,EAAE,CAAC;gBACvE,OAAO,CAAC,QAAQ,CAAC,CAAC;YACpB,CAAC;QACH,CAAC,CAAC;QACF,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QAChD,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;IAClE,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,OAAO,GAAG,IAAI,KAAK,mBAAmB,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,yBAAyB,IAAI,EAAE,CAAC;IAElG,OAAO,CACL,KAAC,KAAK,IAAC,SAAS,EAAC,uBAAuB,YACtC,MAAC,KAAK,CAAC,OAAO,eACZ,KAAC,KAAK,CAAC,KAAK,0CAAsC,EAClD,KAAC,KAAK,CAAC,SAAS,IAAC,SAAS,EAAC,gBAAgB,GAAG,EAC9C,KAAC,KAAK,CAAC,WAAW,wCAA0C,EAC5D,eAAM,SAAS,EAAC,
|
|
1
|
+
{"version":3,"file":"EmptyStates.js","sourceRoot":"","sources":["../../../src/side-panel/components/EmptyStates.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NpmPluginCard.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/NpmPluginCard.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAQpD,UAAU,kBAAkB;IAC1B,MAAM,EAAE,kBAAkB,CAAC;IAC3B,UAAU,EAAE,OAAO,CAAC;IACpB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,SAAS,EAAE,MAAM,IAAI,CAAC;CACvB;AAED,QAAA,MAAM,aAAa;+CAA8C,kBAAkB;;
|
|
1
|
+
{"version":3,"file":"NpmPluginCard.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/NpmPluginCard.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAQpD,UAAU,kBAAkB;IAC1B,MAAM,EAAE,kBAAkB,CAAC;IAC3B,UAAU,EAAE,OAAO,CAAC;IACpB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,SAAS,EAAE,MAAM,IAAI,CAAC;CACvB;AAED,QAAA,MAAM,aAAa;+CAA8C,kBAAkB;;CAwClF,CAAC;AAIF,OAAO,EAAE,aAAa,EAAE,CAAC;AACzB,YAAY,EAAE,kBAAkB,EAAE,CAAC"}
|
|
@@ -7,7 +7,7 @@ import { Button } from './retro/Button';
|
|
|
7
7
|
import { Loader } from './retro/Loader';
|
|
8
8
|
const NpmPluginCard = ({ plugin, installing, error, onInstall }) => {
|
|
9
9
|
const displayName = extractShortName(plugin.name);
|
|
10
|
-
return (_jsxs("div", { className: "space-y-2 rounded border-2 border-border bg-card p-3 shadow-md transition-all hover:shadow-sm", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(PluginIcon, { pluginName: plugin.name, displayName: displayName, tabState: "closed", size: 28 }), _jsxs("div", { className: "flex min-w-0 flex-1 flex-col", children: [_jsxs("div", { className: "flex flex-wrap items-center gap-1", children: [_jsx("
|
|
10
|
+
return (_jsxs("div", { className: "space-y-2 rounded border-2 border-border bg-card p-3 shadow-md transition-all hover:shadow-sm", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(PluginIcon, { pluginName: plugin.name, displayName: displayName, tabState: "closed", size: 28 }), _jsxs("div", { className: "flex min-w-0 flex-1 flex-col", children: [_jsxs("div", { className: "flex flex-wrap items-center gap-1", children: [_jsx("a", { href: `https://www.npmjs.com/package/${plugin.name}`, target: "_blank", rel: "noopener noreferrer", className: "truncate font-head text-foreground text-sm hover:underline", onClick: e => e.stopPropagation(), children: displayName }), _jsx(Badge, { variant: "default", size: "sm", children: plugin.version })] }), _jsx("span", { className: "truncate font-sans text-muted-foreground text-xs", children: plugin.author })] }), _jsx(Button, { size: "sm", variant: "default", disabled: installing, onClick: onInstall, className: "shrink-0", children: installing ? _jsx(Loader, { size: "sm" }) : 'Install' })] }), _jsx("p", { className: "line-clamp-2 text-muted-foreground text-xs", children: plugin.description }), error && (_jsx(Alert, { status: "error", className: "px-3 py-2 text-xs", children: error }))] }));
|
|
11
11
|
};
|
|
12
12
|
NpmPluginCard.displayName = 'NpmPluginCard';
|
|
13
13
|
export { NpmPluginCard };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NpmPluginCard.js","sourceRoot":"","sources":["../../../src/side-panel/components/NpmPluginCard.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtC,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AASxC,MAAM,aAAa,GAAG,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAsB,EAAE,EAAE;IACrF,MAAM,WAAW,GAAG,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAElD,OAAO,CACL,eAAK,SAAS,EAAC,+FAA+F,aAE5G,eAAK,SAAS,EAAC,yBAAyB,aACtC,KAAC,UAAU,IAAC,UAAU,EAAE,MAAM,CAAC,IAAI,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAC,QAAQ,EAAC,IAAI,EAAE,EAAE,GAAI,EAC7F,eAAK,SAAS,EAAC,8BAA8B,aAC3C,eAAK,SAAS,EAAC,mCAAmC,aAChD,
|
|
1
|
+
{"version":3,"file":"NpmPluginCard.js","sourceRoot":"","sources":["../../../src/side-panel/components/NpmPluginCard.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtC,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AASxC,MAAM,aAAa,GAAG,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAsB,EAAE,EAAE;IACrF,MAAM,WAAW,GAAG,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAElD,OAAO,CACL,eAAK,SAAS,EAAC,+FAA+F,aAE5G,eAAK,SAAS,EAAC,yBAAyB,aACtC,KAAC,UAAU,IAAC,UAAU,EAAE,MAAM,CAAC,IAAI,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAC,QAAQ,EAAC,IAAI,EAAE,EAAE,GAAI,EAC7F,eAAK,SAAS,EAAC,8BAA8B,aAC3C,eAAK,SAAS,EAAC,mCAAmC,aAChD,YACE,IAAI,EAAE,iCAAiC,MAAM,CAAC,IAAI,EAAE,EACpD,MAAM,EAAC,QAAQ,EACf,GAAG,EAAC,qBAAqB,EACzB,SAAS,EAAC,4DAA4D,EACtE,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,YAChC,WAAW,GACV,EACJ,KAAC,KAAK,IAAC,OAAO,EAAC,SAAS,EAAC,IAAI,EAAC,IAAI,YAC/B,MAAM,CAAC,OAAO,GACT,IACJ,EACN,eAAM,SAAS,EAAC,kDAAkD,YAAE,MAAM,CAAC,MAAM,GAAQ,IACrF,EACN,KAAC,MAAM,IAAC,IAAI,EAAC,IAAI,EAAC,OAAO,EAAC,SAAS,EAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAC,UAAU,YAC/F,UAAU,CAAC,CAAC,CAAC,KAAC,MAAM,IAAC,IAAI,EAAC,IAAI,GAAG,CAAC,CAAC,CAAC,SAAS,GACvC,IACL,EAGN,YAAG,SAAS,EAAC,4CAA4C,YAAE,MAAM,CAAC,WAAW,GAAK,EAGjF,KAAK,IAAI,CACR,KAAC,KAAK,IAAC,MAAM,EAAC,OAAO,EAAC,SAAS,EAAC,mBAAmB,YAChD,KAAK,GACA,CACT,IACG,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,aAAa,CAAC,WAAW,GAAG,eAAe,CAAC;AAE5C,OAAO,EAAE,aAAa,EAAE,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { Dispatch, SetStateAction } from 'react';
|
|
2
2
|
import type { PluginState } from '../bridge.js';
|
|
3
|
-
declare const PluginCard: ({ plugin, activeTools, setPlugins, toolFilter, onUpdate, onRemove, updatingPlugin, removingPlugin, actionError,
|
|
3
|
+
declare const PluginCard: ({ plugin, activeTools, setPlugins, toolFilter, onUpdate, onRemove, updatingPlugin, removingPlugin, actionError, transitionClass, }: {
|
|
4
4
|
plugin: PluginState;
|
|
5
5
|
activeTools: Set<string>;
|
|
6
6
|
setPlugins: Dispatch<SetStateAction<PluginState[]>>;
|
|
@@ -10,7 +10,7 @@ declare const PluginCard: ({ plugin, activeTools, setPlugins, toolFilter, onUpda
|
|
|
10
10
|
updatingPlugin?: boolean;
|
|
11
11
|
removingPlugin?: boolean;
|
|
12
12
|
actionError?: string | null;
|
|
13
|
-
|
|
13
|
+
transitionClass?: string;
|
|
14
14
|
}) => import("react/jsx-runtime").JSX.Element;
|
|
15
15
|
export { PluginCard };
|
|
16
16
|
//# sourceMappingURL=PluginCard.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PluginCard.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/PluginCard.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAEtD,OAAO,KAAK,EAAE,WAAW,EAAe,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"PluginCard.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/PluginCard.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAEtD,OAAO,KAAK,EAAE,WAAW,EAAe,MAAM,cAAc,CAAC;AAc7D,QAAA,MAAM,UAAU,GAAI,oIAWjB;IACD,MAAM,EAAE,WAAW,CAAC;IACpB,WAAW,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IACzB,UAAU,EAAE,QAAQ,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IACpD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,4CAqPA,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import * as AccordionPrimitive from '@radix-ui/react-accordion';
|
|
3
|
-
import { ChevronDown } from 'lucide-react';
|
|
3
|
+
import { ChevronDown, ShieldQuestionMark } from 'lucide-react';
|
|
4
4
|
import { useEffect, useRef, useState } from 'react';
|
|
5
5
|
import { matchesTool, setPluginPermission, setToolPermission } from '../bridge.js';
|
|
6
6
|
import { ERROR_DISPLAY_DURATION_MS } from '../constants.js';
|
|
@@ -9,10 +9,15 @@ import { PluginMenu } from './PluginMenu.js';
|
|
|
9
9
|
import { Accordion } from './retro/Accordion.js';
|
|
10
10
|
import { Alert } from './retro/Alert.js';
|
|
11
11
|
import { Badge } from './retro/Badge.js';
|
|
12
|
+
import { Button } from './retro/Button.js';
|
|
13
|
+
import { Dialog } from './retro/Dialog.js';
|
|
12
14
|
import { Tooltip } from './retro/Tooltip.js';
|
|
13
15
|
import { PermissionSelect, ToolRow } from './ToolRow.js';
|
|
14
|
-
|
|
16
|
+
import { groupTools } from './tool-groups.js';
|
|
17
|
+
const PluginCard = ({ plugin, activeTools, setPlugins, toolFilter, onUpdate, onRemove, updatingPlugin, removingPlugin, actionError, transitionClass, }) => {
|
|
15
18
|
const [toggleError, setToggleError] = useState(null);
|
|
19
|
+
/** Pending unreviewed permission change awaiting user confirmation. */
|
|
20
|
+
const [pendingChange, setPendingChange] = useState(null);
|
|
16
21
|
const errorTimerRef = useRef(undefined);
|
|
17
22
|
const toggleCounter = useRef(0);
|
|
18
23
|
const preToggleRef = useRef([]);
|
|
@@ -25,18 +30,41 @@ const PluginCard = ({ plugin, activeTools, setPlugins, toolFilter, onUpdate, onR
|
|
|
25
30
|
const pluginTools = plugin.tools ?? [];
|
|
26
31
|
const updatePluginTools = (updater) => setPlugins(prev => prev.map(p => (p.name === plugin.name ? { ...p, tools: updater(p.tools ?? []) } : p)));
|
|
27
32
|
const prePluginPermRef = useRef('off');
|
|
28
|
-
const
|
|
33
|
+
const applyPluginPermission = (newPermission, reviewedVersion) => {
|
|
29
34
|
const myVersion = ++toggleCounter.current;
|
|
30
35
|
prePluginPermRef.current = plugin.permission;
|
|
31
|
-
setPlugins(prev => prev.map(p =>
|
|
32
|
-
|
|
36
|
+
setPlugins(prev => prev.map(p => p.name === plugin.name
|
|
37
|
+
? { ...p, permission: newPermission, ...(reviewedVersion ? { reviewed: true } : {}) }
|
|
38
|
+
: p));
|
|
39
|
+
void setPluginPermission(plugin.name, newPermission, reviewedVersion).catch(() => {
|
|
33
40
|
if (toggleCounter.current === myVersion) {
|
|
34
41
|
setPlugins(prev => prev.map(p => (p.name === plugin.name ? { ...p, permission: prePluginPermRef.current } : p)));
|
|
35
42
|
}
|
|
36
43
|
showToggleError('Failed to update plugin permission');
|
|
37
44
|
});
|
|
38
45
|
};
|
|
39
|
-
const
|
|
46
|
+
const handlePluginPermissionChange = (newPermission) => {
|
|
47
|
+
if (!plugin.reviewed && plugin.permission === 'off' && newPermission !== 'off') {
|
|
48
|
+
setPendingChange({ permission: newPermission });
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
applyPluginPermission(newPermission);
|
|
52
|
+
};
|
|
53
|
+
const handleEnableAnyway = () => {
|
|
54
|
+
if (!pendingChange)
|
|
55
|
+
return;
|
|
56
|
+
if (pendingChange.tool) {
|
|
57
|
+
// Tool-level: mark plugin reviewed and apply the tool permission change
|
|
58
|
+
applyPluginPermission(plugin.permission, plugin.version);
|
|
59
|
+
applyToolPermission(pendingChange.tool, pendingChange.permission);
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
// Plugin-level: set permission and mark reviewed
|
|
63
|
+
applyPluginPermission(pendingChange.permission, plugin.version);
|
|
64
|
+
}
|
|
65
|
+
setPendingChange(null);
|
|
66
|
+
};
|
|
67
|
+
const applyToolPermission = (toolName, newPermission) => {
|
|
40
68
|
const myVersion = ++toggleCounter.current;
|
|
41
69
|
updatePluginTools(prev => {
|
|
42
70
|
preToggleRef.current = prev;
|
|
@@ -49,36 +77,30 @@ const PluginCard = ({ plugin, activeTools, setPlugins, toolFilter, onUpdate, onR
|
|
|
49
77
|
showToggleError(`Failed to update ${toolName}`);
|
|
50
78
|
});
|
|
51
79
|
};
|
|
80
|
+
const handleToolPermissionChange = (toolName, newPermission) => {
|
|
81
|
+
if (!plugin.reviewed && newPermission !== 'off') {
|
|
82
|
+
const currentToolPerm = pluginTools.find(t => t.name === toolName)?.permission ?? 'off';
|
|
83
|
+
if (currentToolPerm === 'off') {
|
|
84
|
+
setPendingChange({ permission: newPermission, tool: toolName });
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
applyToolPermission(toolName, newPermission);
|
|
89
|
+
};
|
|
52
90
|
const filterLower = toolFilter?.toLowerCase() ?? '';
|
|
53
91
|
const visibleTools = filterLower ? pluginTools.filter(t => matchesTool(t, filterLower)) : pluginTools;
|
|
54
92
|
const hasActiveTool = pluginTools.some(t => activeTools.has(`${plugin.name}:${t.name}`));
|
|
55
|
-
|
|
56
|
-
const
|
|
57
|
-
const
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
}
|
|
67
|
-
bucket.push(tool);
|
|
68
|
-
}
|
|
69
|
-
// Move 'Other' to the end if it exists
|
|
70
|
-
const otherBucket = groupMap.get('Other');
|
|
71
|
-
groupMap.delete('Other');
|
|
72
|
-
for (const [name, tools] of groupMap) {
|
|
73
|
-
toolGroups.push({ name, tools });
|
|
74
|
-
}
|
|
75
|
-
if (otherBucket) {
|
|
76
|
-
toolGroups.push({ name: 'Other', tools: otherBucket });
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
return (_jsxs(Accordion.Item, { value: plugin.name, className: removingPlugin ? 'pointer-events-none opacity-60 transition-opacity' : undefined, children: [_jsxs(AccordionPrimitive.Header, { className: "flex", children: [_jsxs(AccordionPrimitive.Trigger, { className: "flex min-w-0 flex-1 cursor-pointer items-center gap-2 px-3 py-2 focus:outline-hidden [&[data-state=open]>svg]:rotate-180", children: [_jsxs(Tooltip, { children: [_jsx(Tooltip.Trigger, { asChild: true, children: _jsx("div", { children: _jsx(PluginIcon, { pluginName: plugin.name, displayName: plugin.displayName, tabState: plugin.tabState, size: 32, iconSvg: plugin.iconSvg, iconInactiveSvg: plugin.iconInactiveSvg, iconDarkSvg: plugin.iconDarkSvg, iconDarkInactiveSvg: plugin.iconDarkInactiveSvg, active: hasActiveTool }) }) }), _jsxs(Tooltip.Content, { children: ["v", plugin.version] })] }), _jsxs("div", { className: "flex min-w-0 flex-1 items-center gap-1.5 truncate font-head text-foreground text-sm", children: [plugin.displayName, plugin.source === 'local' && (_jsx(Badge, { variant: "default", size: "sm", className: "align-middle", children: "DEV" })), !plugin.sdkVersion && (_jsxs(Tooltip, { children: [_jsx(Tooltip.Trigger, { asChild: true, children: _jsx(Badge, { variant: "outline", size: "sm", className: "border-accent bg-accent/10 align-middle text-accent-foreground", children: "SDK" }) }), _jsx(Tooltip.Content, { children: "SDK version mismatch \u2014 rebuild plugin" })] }))] }), _jsx(ChevronDown, { className: "h-4 w-4 shrink-0 transition-transform duration-200" })] }), _jsx(PluginMenu, { plugin: plugin, onUpdate: onUpdate ?? (() => undefined), onRemove: onRemove ?? (() => undefined), updating: updatingPlugin ?? false, removing: removingPlugin ?? false, className: "flex shrink-0 items-center px-1" }), _jsx("div", { className: "flex shrink-0 items-center px-3", children: _jsx(PermissionSelect, { value: plugin.permission, onValueChange: handlePluginPermissionChange, disabled: skipPermissions ?? false, ariaLabel: `Permission for ${plugin.name} plugin` }) })] }), toggleError && (_jsx(Alert, { status: "error", className: "mx-3 mb-1 px-2 py-1 text-xs", children: toggleError })), actionError && (_jsx(Alert, { status: "error", className: "mx-3 mb-1 px-2 py-1 text-xs", children: actionError })), _jsxs(Accordion.Content, { className: "border-border border-t", children: [toolFilter && (_jsxs("div", { className: "mb-1 px-3 pt-2 text-muted-foreground text-xs", children: [visibleTools.length, " of ", pluginTools.length, " tools"] })), hasAnyGroup
|
|
80
|
-
? toolGroups.map(group => (_jsxs("div", { children: [_jsx("div", { className: "border-border border-b bg-muted/20 px-3 py-1", children: _jsx("span", { className: "font-head text-muted-foreground text-xs uppercase tracking-wider", children: group.name }) }), group.tools.map(tool => (_jsx(ToolRow, { name: tool.name, displayName: tool.displayName, description: tool.description, summary: tool.summary, icon: tool.icon, permission: tool.permission, active: activeTools.has(`${plugin.name}:${tool.name}`), disabled: skipPermissions, onPermissionChange: handleToolPermissionChange }, tool.name)))] }, group.name)))
|
|
81
|
-
: visibleTools.map(tool => (_jsx(ToolRow, { name: tool.name, displayName: tool.displayName, description: tool.description, summary: tool.summary, icon: tool.icon, permission: tool.permission, active: activeTools.has(`${plugin.name}:${tool.name}`), disabled: skipPermissions, onPermissionChange: handleToolPermissionChange }, tool.name)))] })] }));
|
|
93
|
+
const toolGroups = groupTools(visibleTools);
|
|
94
|
+
const inactive = plugin.tabState !== 'ready';
|
|
95
|
+
const renderToolList = (tools) => tools.map(tool => (_jsx(ToolRow, { name: tool.name, displayName: tool.displayName, description: tool.description, summary: tool.summary, icon: tool.icon, permission: tool.permission, active: activeTools.has(`${plugin.name}:${tool.name}`), muted: inactive, onPermissionChange: handleToolPermissionChange }, tool.name)));
|
|
96
|
+
return (_jsxs(Accordion.Item, { value: plugin.name, className: transitionClass ??
|
|
97
|
+
(removingPlugin
|
|
98
|
+
? 'pointer-events-none opacity-60 transition-opacity'
|
|
99
|
+
: inactive
|
|
100
|
+
? 'opacity-70 transition-opacity'
|
|
101
|
+
: undefined), children: [_jsxs(AccordionPrimitive.Header, { className: "flex", children: [_jsxs(AccordionPrimitive.Trigger, { className: "focus-ring flex min-w-0 flex-1 cursor-pointer items-center gap-2 px-3 py-2 [&[data-state=open]>svg]:rotate-180", children: [_jsxs(Tooltip, { children: [_jsx(Tooltip.Trigger, { asChild: true, children: _jsx("div", { children: _jsx(PluginIcon, { pluginName: plugin.name, displayName: plugin.displayName, tabState: plugin.tabState, size: 32, iconSvg: plugin.iconSvg, iconInactiveSvg: plugin.iconInactiveSvg, iconDarkSvg: plugin.iconDarkSvg, iconDarkInactiveSvg: plugin.iconDarkInactiveSvg, active: hasActiveTool }) }) }), _jsxs(Tooltip.Content, { children: ["v", plugin.version] })] }), _jsxs("div", { className: `flex min-w-0 flex-1 items-center gap-1.5 truncate font-head text-sm ${inactive ? 'text-muted-foreground' : 'text-foreground'}`, children: [plugin.displayName, plugin.source === 'local' && (_jsx(Badge, { variant: "default", size: "sm", className: "align-middle", children: "DEV" })), !plugin.reviewed && (_jsxs(Tooltip, { children: [_jsx(Tooltip.Trigger, { asChild: true, children: _jsx(ShieldQuestionMark, { className: "inline-block h-3.5 w-3.5 align-middle text-muted-foreground" }) }), _jsx(Tooltip.Content, { children: "This plugin version has not been reviewed" })] }))] }), _jsx(ChevronDown, { className: `h-4 w-4 shrink-0 transition-transform duration-200 ${inactive ? 'text-muted-foreground' : ''}` })] }), _jsx(PluginMenu, { plugin: plugin, onUpdate: onUpdate ?? (() => undefined), onRemove: onRemove ?? (() => undefined), updating: updatingPlugin ?? false, removing: removingPlugin ?? false, muted: inactive, className: "flex shrink-0 items-center px-1" }), _jsx("div", { className: "flex shrink-0 items-center px-3", children: _jsx(PermissionSelect, { value: plugin.permission, onValueChange: handlePluginPermissionChange, disabled: false, muted: inactive, ariaLabel: `Permission for ${plugin.name} plugin` }) })] }), toggleError && (_jsx(Alert, { status: "error", className: "mx-3 mb-1 px-2 py-1 text-xs", children: toggleError })), actionError && (_jsx(Alert, { status: "error", className: "mx-3 mb-1 px-2 py-1 text-xs", children: actionError })), _jsxs(Accordion.Content, { className: "border-border border-t", children: [toolFilter && (_jsxs("div", { className: "mb-1 px-3 pt-2 text-muted-foreground text-xs", children: [visibleTools.length, " of ", pluginTools.length, " tools"] })), toolGroups !== null
|
|
102
|
+
? toolGroups.map(group => (_jsxs("div", { className: "[&:not(:first-child)]:mt-2", children: [_jsx("div", { className: "border-border border-b border-l-2 border-l-primary bg-muted/30 px-3 py-1", children: _jsx("span", { className: "font-head text-muted-foreground text-xs uppercase tracking-wider", children: group.name }) }), renderToolList(group.tools)] }, group.name)))
|
|
103
|
+
: renderToolList(visibleTools)] }), _jsx(Dialog, { open: pendingChange !== null, onOpenChange: open => !open && setPendingChange(null), children: _jsxs(Dialog.Content, { onInteractOutside: (e) => e.preventDefault(), children: [_jsx(Dialog.Header, { children: "Unreviewed Plugin" }), _jsxs(Dialog.Body, { children: [_jsxs("p", { className: "font-mono text-foreground text-sm", children: [plugin.displayName, " v", plugin.version] }), _jsxs("p", { className: "mt-2 text-foreground text-sm", children: ["This plugin version has not been reviewed. You can ask your AI agent to review the adapter code by saying \u201Creview the ", plugin.name, " plugin\u201D in your chat."] }), _jsx("p", { className: "mt-2 text-muted-foreground text-xs", children: "You can also enable it now without review." })] }), _jsxs(Dialog.Footer, { children: [_jsx(Dialog.Close, { asChild: true, children: _jsx(Button, { size: "sm", variant: "outline", children: "Cancel" }) }), _jsx(Button, { size: "sm", onClick: handleEnableAnyway, children: "Enable Anyway" })] })] }) })] }));
|
|
82
104
|
};
|
|
83
105
|
export { PluginCard };
|
|
84
106
|
//# sourceMappingURL=PluginCard.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PluginCard.js","sourceRoot":"","sources":["../../../src/side-panel/components/PluginCard.tsx"],"names":[],"mappings":";AAGA,OAAO,KAAK,kBAAkB,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"PluginCard.js","sourceRoot":"","sources":["../../../src/side-panel/components/PluginCard.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import type
|
|
1
|
+
import { type Dispatch, type SetStateAction } from 'react';
|
|
2
2
|
import type { FailedPluginState, PluginState } from '../bridge.js';
|
|
3
|
-
declare const PluginList: ({ plugins, failedPlugins, activeTools, setPlugins, toolFilter, onUpdate, onRemove, removingPlugins, pluginErrors,
|
|
3
|
+
declare const PluginList: ({ plugins, failedPlugins, activeTools, setPlugins, toolFilter, onUpdate, onRemove, removingPlugins, pluginErrors, }: {
|
|
4
4
|
plugins: PluginState[];
|
|
5
5
|
failedPlugins: FailedPluginState[];
|
|
6
6
|
activeTools: Set<string>;
|
|
@@ -10,7 +10,6 @@ declare const PluginList: ({ plugins, failedPlugins, activeTools, setPlugins, to
|
|
|
10
10
|
onRemove?: (pluginName: string) => void;
|
|
11
11
|
removingPlugins?: Set<string>;
|
|
12
12
|
pluginErrors?: Map<string, string>;
|
|
13
|
-
|
|
14
|
-
}) => import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
}) => import("react/jsx-runtime").JSX.Element | null;
|
|
15
14
|
export { PluginList };
|
|
16
15
|
//# sourceMappingURL=PluginList.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PluginList.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/PluginList.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PluginList.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/PluginList.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,QAAQ,EAAE,KAAK,cAAc,EAA4C,MAAM,OAAO,CAAC;AACrG,OAAO,KAAK,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AA+EnE,QAAA,MAAM,UAAU,GAAI,qHAUjB;IACD,OAAO,EAAE,WAAW,EAAE,CAAC;IACvB,aAAa,EAAE,iBAAiB,EAAE,CAAC;IACnC,WAAW,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IACzB,UAAU,EAAE,QAAQ,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IACpD,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,QAAQ,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,eAAe,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAC9B,YAAY,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACpC,mDAiKA,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
|
|
@@ -1,19 +1,151 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useCallback, useEffect, useRef, useState } from 'react';
|
|
2
3
|
import { matchesTool } from '../bridge.js';
|
|
4
|
+
import { buildStateSnapshot, collapseTransitioningItems, detectGroupChanges, FADE_IN_MS, getTransitionClass, groupPlugins, } from '../group-transitions.js';
|
|
3
5
|
import { FailedPluginCard } from './FailedPluginCard.js';
|
|
4
6
|
import { PluginCard } from './PluginCard.js';
|
|
5
7
|
import { Accordion } from './retro/Accordion.js';
|
|
6
|
-
|
|
8
|
+
import { Empty } from './retro/Empty.js';
|
|
9
|
+
const ACCORDION_STORAGE_KEY = 'accordionState';
|
|
10
|
+
/**
|
|
11
|
+
* React hook that tracks which plugins are currently animating after a group change.
|
|
12
|
+
* Uses per-plugin timers to clear the animation class after FADE_IN_MS.
|
|
13
|
+
*/
|
|
14
|
+
function useGroupTransitions(plugins, isFiltering) {
|
|
15
|
+
const prevStates = useRef(new Map());
|
|
16
|
+
const [animating, setAnimating] = useState(new Set());
|
|
17
|
+
const clearTimers = useRef(new Map());
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
if (isFiltering) {
|
|
20
|
+
prevStates.current = buildStateSnapshot(plugins);
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const changed = detectGroupChanges(prevStates.current, plugins);
|
|
24
|
+
prevStates.current = buildStateSnapshot(plugins);
|
|
25
|
+
if (changed.size === 0)
|
|
26
|
+
return;
|
|
27
|
+
setAnimating(prev => {
|
|
28
|
+
const next = new Set(prev);
|
|
29
|
+
for (const name of changed)
|
|
30
|
+
next.add(name);
|
|
31
|
+
return next;
|
|
32
|
+
});
|
|
33
|
+
// Per-plugin timer so rapid successive transitions don't cancel each other
|
|
34
|
+
for (const name of changed) {
|
|
35
|
+
const existing = clearTimers.current.get(name);
|
|
36
|
+
if (existing)
|
|
37
|
+
clearTimeout(existing);
|
|
38
|
+
clearTimers.current.set(name, setTimeout(() => {
|
|
39
|
+
clearTimers.current.delete(name);
|
|
40
|
+
setAnimating(prev => {
|
|
41
|
+
if (!prev.has(name))
|
|
42
|
+
return prev;
|
|
43
|
+
const next = new Set(prev);
|
|
44
|
+
next.delete(name);
|
|
45
|
+
return next;
|
|
46
|
+
});
|
|
47
|
+
}, FADE_IN_MS));
|
|
48
|
+
}
|
|
49
|
+
}, [plugins, isFiltering]);
|
|
50
|
+
// Cleanup all timers on unmount
|
|
51
|
+
useEffect(() => () => {
|
|
52
|
+
for (const timer of clearTimers.current.values())
|
|
53
|
+
clearTimeout(timer);
|
|
54
|
+
}, []);
|
|
55
|
+
const resolveTransitionClass = useCallback((pluginName, isReadyGroup) => getTransitionClass(pluginName, isReadyGroup, animating), [animating]);
|
|
56
|
+
return { animating, resolveTransitionClass };
|
|
57
|
+
}
|
|
58
|
+
const PluginList = ({ plugins, failedPlugins, activeTools, setPlugins, toolFilter, onUpdate, onRemove, removingPlugins, pluginErrors, }) => {
|
|
7
59
|
const filterLower = toolFilter.toLowerCase();
|
|
8
60
|
const visiblePlugins = filterLower
|
|
9
61
|
? plugins.filter(p => (p.tools ?? []).some(t => matchesTool(t, filterLower)))
|
|
10
62
|
: plugins;
|
|
11
63
|
// Hide failed plugins when filtering tools
|
|
12
64
|
const visibleFailed = filterLower ? [] : failedPlugins;
|
|
65
|
+
const { animating, resolveTransitionClass } = useGroupTransitions(plugins, !!filterLower);
|
|
66
|
+
// Controlled accordion state — collapse cards when they change groups.
|
|
67
|
+
// Hydrated from chrome.storage.session before first render to prevent
|
|
68
|
+
// a collapsed→expanded flash (the accordion animates height changes).
|
|
69
|
+
const [accordionHydrated, setAccordionHydrated] = useState(false);
|
|
70
|
+
const [openReady, setOpenReady] = useState([]);
|
|
71
|
+
const [openNotReady, setOpenNotReady] = useState([]);
|
|
72
|
+
useEffect(() => {
|
|
73
|
+
chrome.storage.session.get(ACCORDION_STORAGE_KEY).then(result => {
|
|
74
|
+
const stored = result[ACCORDION_STORAGE_KEY];
|
|
75
|
+
if (stored) {
|
|
76
|
+
if (Array.isArray(stored.openReady))
|
|
77
|
+
setOpenReady(stored.openReady);
|
|
78
|
+
if (Array.isArray(stored.openNotReady))
|
|
79
|
+
setOpenNotReady(stored.openNotReady);
|
|
80
|
+
}
|
|
81
|
+
setAccordionHydrated(true);
|
|
82
|
+
}, () => {
|
|
83
|
+
setAccordionHydrated(true);
|
|
84
|
+
});
|
|
85
|
+
}, []);
|
|
86
|
+
// Persist accordion state to chrome.storage.session on every change.
|
|
87
|
+
// Writes immediately (no debounce) so state is flushed before the page
|
|
88
|
+
// can close — chrome.storage.session.set() is async and cannot reliably
|
|
89
|
+
// complete during unmount/beforeunload.
|
|
90
|
+
useEffect(() => {
|
|
91
|
+
if (filterLower)
|
|
92
|
+
return;
|
|
93
|
+
chrome.storage.session.set({ [ACCORDION_STORAGE_KEY]: { openReady, openNotReady } }).catch(() => { });
|
|
94
|
+
}, [openReady, openNotReady, filterLower]);
|
|
95
|
+
useEffect(() => {
|
|
96
|
+
if (animating.size === 0)
|
|
97
|
+
return;
|
|
98
|
+
setOpenReady(prev => collapseTransitioningItems(prev, animating));
|
|
99
|
+
setOpenNotReady(prev => collapseTransitioningItems(prev, animating));
|
|
100
|
+
}, [animating]);
|
|
101
|
+
// Group plugins by readiness (only when not filtering)
|
|
102
|
+
const { ready: readyPlugins, notReady: notReadyPlugins } = filterLower
|
|
103
|
+
? { ready: [], notReady: [] }
|
|
104
|
+
: groupPlugins(visiblePlugins);
|
|
105
|
+
const hasNotReady = notReadyPlugins.length > 0;
|
|
106
|
+
// Track whether the not-ready section was previously visible for label animation
|
|
107
|
+
const prevHadNotReady = useRef(false);
|
|
108
|
+
const [labelVisible, setLabelVisible] = useState(false);
|
|
109
|
+
const [labelMounted, setLabelMounted] = useState(false);
|
|
110
|
+
useEffect(() => {
|
|
111
|
+
let unmountTimer;
|
|
112
|
+
if (filterLower) {
|
|
113
|
+
setLabelMounted(false);
|
|
114
|
+
setLabelVisible(false);
|
|
115
|
+
prevHadNotReady.current = false;
|
|
116
|
+
}
|
|
117
|
+
else if (hasNotReady && !prevHadNotReady.current) {
|
|
118
|
+
setLabelMounted(true);
|
|
119
|
+
requestAnimationFrame(() => {
|
|
120
|
+
requestAnimationFrame(() => {
|
|
121
|
+
setLabelVisible(true);
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
prevHadNotReady.current = hasNotReady;
|
|
125
|
+
}
|
|
126
|
+
else if (!hasNotReady && prevHadNotReady.current) {
|
|
127
|
+
setLabelVisible(false);
|
|
128
|
+
unmountTimer = setTimeout(() => setLabelMounted(false), FADE_IN_MS);
|
|
129
|
+
prevHadNotReady.current = hasNotReady;
|
|
130
|
+
}
|
|
131
|
+
else if (hasNotReady) {
|
|
132
|
+
setLabelMounted(true);
|
|
133
|
+
setLabelVisible(true);
|
|
134
|
+
prevHadNotReady.current = hasNotReady;
|
|
135
|
+
}
|
|
136
|
+
return () => clearTimeout(unmountTimer);
|
|
137
|
+
}, [hasNotReady, filterLower]);
|
|
138
|
+
// Defer rendering until accordion state is hydrated from storage.
|
|
139
|
+
// Without this gate, the first render uses empty arrays (all collapsed),
|
|
140
|
+
// then the storage read triggers a re-render with the saved state,
|
|
141
|
+
// causing a visible expand animation.
|
|
142
|
+
if (!accordionHydrated)
|
|
143
|
+
return null;
|
|
13
144
|
if (filterLower && visiblePlugins.length === 0) {
|
|
14
|
-
return (
|
|
145
|
+
return (_jsx(Empty, { className: "border-muted", children: _jsxs(Empty.Content, { children: [_jsx(Empty.Icon, { className: "h-10 w-10 text-muted-foreground" }), _jsxs(Empty.Title, { className: "text-base", children: ["No tools matching \u201C", toolFilter, "\u201D"] }), _jsx(Empty.Separator, {}), _jsx(Empty.Description, { className: "text-xs", children: "Try searching by plugin name, tool name, or description." })] }) }));
|
|
15
146
|
}
|
|
16
|
-
|
|
147
|
+
const renderCard = (plugin, isReadyGroup) => (_jsx(PluginCard, { plugin: plugin, activeTools: activeTools, setPlugins: setPlugins, toolFilter: toolFilter, onUpdate: onUpdate ? () => onUpdate(plugin.name) : undefined, onRemove: onRemove ? () => onRemove(plugin.name) : undefined, removingPlugin: removingPlugins?.has(plugin.name), actionError: pluginErrors?.get(plugin.name) ?? null, transitionClass: resolveTransitionClass(plugin.name, isReadyGroup) }, plugin.name));
|
|
148
|
+
return (_jsxs(_Fragment, { children: [visibleFailed.length > 0 && (_jsx("div", { className: "mb-3 space-y-2", children: visibleFailed.map(fp => (_jsx(FailedPluginCard, { plugin: fp }, fp.specifier))) })), filterLower ? (_jsx(Accordion, { type: "multiple", className: "space-y-2", children: visiblePlugins.map(p => renderCard(p, true)) })) : (_jsxs(_Fragment, { children: [readyPlugins.length > 0 && (_jsx(Accordion, { type: "multiple", value: openReady, onValueChange: setOpenReady, className: "space-y-2", children: readyPlugins.map(p => renderCard(p, true)) })), labelMounted && (_jsx("div", { className: `px-3 pt-3 pb-1 font-mono text-[10px] text-muted-foreground uppercase tracking-widest transition-opacity duration-200 ${labelVisible ? 'opacity-100' : 'opacity-0'}`, children: "NOT CONNECTED" })), notReadyPlugins.length > 0 && (_jsx(Accordion, { type: "multiple", value: openNotReady, onValueChange: setOpenNotReady, className: "space-y-2", children: notReadyPlugins.map(p => renderCard(p, false)) }))] }))] }));
|
|
17
149
|
};
|
|
18
150
|
export { PluginList };
|
|
19
151
|
//# sourceMappingURL=PluginList.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PluginList.js","sourceRoot":"","sources":["../../../src/side-panel/components/PluginList.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"PluginList.js","sourceRoot":"","sources":["../../../src/side-panel/components/PluginList.tsx"],"names":[],"mappings":"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"}
|
|
@@ -5,10 +5,12 @@ interface PluginMenuProps {
|
|
|
5
5
|
onRemove: () => void;
|
|
6
6
|
updating: boolean;
|
|
7
7
|
removing: boolean;
|
|
8
|
+
/** Use muted icon color (for inactive/disconnected plugins). */
|
|
9
|
+
muted?: boolean;
|
|
8
10
|
className?: string;
|
|
9
11
|
}
|
|
10
12
|
declare const PluginMenu: {
|
|
11
|
-
({ plugin, onUpdate, onRemove, updating, removing, className }: PluginMenuProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
({ plugin, onUpdate, onRemove, updating, removing, muted, className }: PluginMenuProps): import("react/jsx-runtime").JSX.Element;
|
|
12
14
|
displayName: string;
|
|
13
15
|
};
|
|
14
16
|
export { PluginMenu };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PluginMenu.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/PluginMenu.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAM7C,UAAU,eAAe;IACvB,MAAM,EAAE,WAAW,CAAC;IACpB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,QAAA,MAAM,UAAU;
|
|
1
|
+
{"version":3,"file":"PluginMenu.d.ts","sourceRoot":"","sources":["../../../src/side-panel/components/PluginMenu.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAM7C,UAAU,eAAe;IACvB,MAAM,EAAE,WAAW,CAAC;IACpB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,EAAE,OAAO,CAAC;IAClB,gEAAgE;IAChE,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,QAAA,MAAM,UAAU;2EAA0E,eAAe;;CAoFxG,CAAC;AAIF,OAAO,EAAE,UAAU,EAAE,CAAC;AACtB,YAAY,EAAE,eAAe,EAAE,CAAC"}
|