skybridge 0.0.0-dev.d8b52a9 → 0.0.0-dev.da10bf6

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.
Files changed (126) hide show
  1. package/LICENSE +21 -674
  2. package/README.md +70 -270
  3. package/dist/src/server/devtoolsStaticServer.d.ts +15 -0
  4. package/dist/src/server/devtoolsStaticServer.js +38 -0
  5. package/dist/src/server/devtoolsStaticServer.js.map +1 -0
  6. package/dist/src/server/index.d.ts +3 -2
  7. package/dist/src/server/index.js +1 -0
  8. package/dist/src/server/index.js.map +1 -1
  9. package/dist/src/server/inferUtilityTypes.d.ts +38 -18
  10. package/dist/src/server/server.d.ts +56 -11
  11. package/dist/src/server/server.js +19 -6
  12. package/dist/src/server/server.js.map +1 -1
  13. package/dist/src/server/templateHelper.js +5 -4
  14. package/dist/src/server/templateHelper.js.map +1 -1
  15. package/dist/src/server/templates/development.hbs +2 -2
  16. package/dist/src/server/widgetsDevServer.js +3 -3
  17. package/dist/src/server/widgetsDevServer.js.map +1 -1
  18. package/dist/src/test/utils.d.ts +97 -1
  19. package/dist/src/test/utils.js +181 -2
  20. package/dist/src/test/utils.js.map +1 -1
  21. package/dist/src/test/widget.test.js +43 -21
  22. package/dist/src/test/widget.test.js.map +1 -1
  23. package/dist/src/web/create-store.d.ts +3 -0
  24. package/dist/src/web/create-store.js +25 -0
  25. package/dist/src/web/create-store.js.map +1 -0
  26. package/dist/src/web/create-store.test.js +70 -0
  27. package/dist/src/web/create-store.test.js.map +1 -0
  28. package/dist/src/web/data-llm.d.ts +14 -0
  29. package/dist/src/web/data-llm.js +68 -0
  30. package/dist/src/web/data-llm.js.map +1 -0
  31. package/dist/src/web/data-llm.test.js +76 -0
  32. package/dist/src/web/data-llm.test.js.map +1 -0
  33. package/dist/src/web/{typed-hooks.d.ts → generate-helpers.d.ts} +26 -18
  34. package/dist/src/web/{typed-hooks.js → generate-helpers.js} +14 -14
  35. package/dist/src/web/generate-helpers.js.map +1 -0
  36. package/dist/src/web/generate-helpers.test-d.d.ts +1 -0
  37. package/dist/src/web/generate-helpers.test-d.js +180 -0
  38. package/dist/src/web/generate-helpers.test-d.js.map +1 -0
  39. package/dist/src/web/generate-helpers.test.d.ts +1 -0
  40. package/dist/src/web/generate-helpers.test.js +17 -0
  41. package/dist/src/web/generate-helpers.test.js.map +1 -0
  42. package/dist/src/web/helpers/state.d.ts +7 -0
  43. package/dist/src/web/helpers/state.js +40 -0
  44. package/dist/src/web/helpers/state.js.map +1 -0
  45. package/dist/src/web/helpers/state.test.d.ts +1 -0
  46. package/dist/src/web/helpers/state.test.js +53 -0
  47. package/dist/src/web/helpers/state.test.js.map +1 -0
  48. package/dist/src/web/hooks/index.d.ts +2 -4
  49. package/dist/src/web/hooks/index.js +2 -4
  50. package/dist/src/web/hooks/index.js.map +1 -1
  51. package/dist/src/web/hooks/use-call-tool.d.ts +58 -20
  52. package/dist/src/web/hooks/use-call-tool.js +7 -15
  53. package/dist/src/web/hooks/use-call-tool.js.map +1 -1
  54. package/dist/src/web/hooks/use-call-tool.test-d.d.ts +1 -0
  55. package/dist/src/web/hooks/use-call-tool.test-d.js +104 -0
  56. package/dist/src/web/hooks/use-call-tool.test-d.js.map +1 -0
  57. package/dist/src/web/hooks/use-call-tool.test.js +14 -12
  58. package/dist/src/web/hooks/use-call-tool.test.js.map +1 -1
  59. package/dist/src/web/hooks/use-display-mode.js.map +1 -1
  60. package/dist/src/web/hooks/use-display-mode.test.js +2 -2
  61. package/dist/src/web/hooks/use-display-mode.test.js.map +1 -1
  62. package/dist/src/web/hooks/use-files.test.js +1 -1
  63. package/dist/src/web/hooks/use-files.test.js.map +1 -1
  64. package/dist/src/web/hooks/use-locale.js.map +1 -1
  65. package/dist/src/web/hooks/use-locale.test.js +2 -2
  66. package/dist/src/web/hooks/use-locale.test.js.map +1 -1
  67. package/dist/src/web/hooks/use-open-external.test.js +2 -2
  68. package/dist/src/web/hooks/use-open-external.test.js.map +1 -1
  69. package/dist/src/web/hooks/use-openai-global.d.ts +2 -2
  70. package/dist/src/web/hooks/use-openai-global.js +7 -5
  71. package/dist/src/web/hooks/use-openai-global.js.map +1 -1
  72. package/dist/src/web/hooks/use-request-modal.test.js +2 -2
  73. package/dist/src/web/hooks/use-request-modal.test.js.map +1 -1
  74. package/dist/src/web/hooks/use-theme.js.map +1 -1
  75. package/dist/src/web/hooks/use-theme.test.js +2 -2
  76. package/dist/src/web/hooks/use-theme.test.js.map +1 -1
  77. package/dist/src/web/hooks/use-tool-info.d.ts +2 -2
  78. package/dist/src/web/hooks/use-tool-info.js +4 -6
  79. package/dist/src/web/hooks/use-tool-info.js.map +1 -1
  80. package/dist/src/web/hooks/use-tool-info.test-d.js +0 -1
  81. package/dist/src/web/hooks/use-tool-info.test-d.js.map +1 -1
  82. package/dist/src/web/hooks/use-tool-info.test.js +2 -2
  83. package/dist/src/web/hooks/use-tool-info.test.js.map +1 -1
  84. package/dist/src/web/hooks/use-user-agent.js.map +1 -1
  85. package/dist/src/web/hooks/use-user-agent.test.js +2 -2
  86. package/dist/src/web/hooks/use-user-agent.test.js.map +1 -1
  87. package/dist/src/web/hooks/use-widget-state.js +9 -7
  88. package/dist/src/web/hooks/use-widget-state.js.map +1 -1
  89. package/dist/src/web/hooks/use-widget-state.test.js +2 -2
  90. package/dist/src/web/hooks/use-widget-state.test.js.map +1 -1
  91. package/dist/src/web/index.d.ts +6 -4
  92. package/dist/src/web/index.js +6 -4
  93. package/dist/src/web/index.js.map +1 -1
  94. package/dist/src/web/plugin/data-llm.test.d.ts +1 -0
  95. package/dist/src/web/plugin/data-llm.test.js +81 -0
  96. package/dist/src/web/plugin/data-llm.test.js.map +1 -0
  97. package/dist/src/web/plugin/plugin.js +39 -0
  98. package/dist/src/web/plugin/plugin.js.map +1 -0
  99. package/dist/src/web/plugin/transform-data-llm.d.ts +12 -0
  100. package/dist/src/web/plugin/transform-data-llm.js +93 -0
  101. package/dist/src/web/plugin/transform-data-llm.js.map +1 -0
  102. package/dist/src/web/plugin/transform-data-llm.test.d.ts +1 -0
  103. package/dist/src/web/plugin/transform-data-llm.test.js +81 -0
  104. package/dist/src/web/plugin/transform-data-llm.test.js.map +1 -0
  105. package/dist/src/web/proxy.js +1 -1
  106. package/dist/src/web/proxy.js.map +1 -1
  107. package/dist/src/web/types.d.ts +18 -4
  108. package/dist/src/web/types.js +1 -0
  109. package/dist/src/web/types.js.map +1 -1
  110. package/package.json +14 -6
  111. package/dist/src/web/hooks/use-tool-output.d.ts +0 -4
  112. package/dist/src/web/hooks/use-tool-output.js +0 -9
  113. package/dist/src/web/hooks/use-tool-output.js.map +0 -1
  114. package/dist/src/web/hooks/use-tool-response-metadata.d.ts +0 -4
  115. package/dist/src/web/hooks/use-tool-response-metadata.js +0 -8
  116. package/dist/src/web/hooks/use-tool-response-metadata.js.map +0 -1
  117. package/dist/src/web/plugin.js +0 -28
  118. package/dist/src/web/plugin.js.map +0 -1
  119. package/dist/src/web/typed-hooks.js.map +0 -1
  120. package/dist/src/web/typed-hooks.test-d.js +0 -72
  121. package/dist/src/web/typed-hooks.test-d.js.map +0 -1
  122. package/dist/src/web/typed-hooks.test.js +0 -10
  123. package/dist/src/web/typed-hooks.test.js.map +0 -1
  124. /package/dist/src/web/{typed-hooks.test-d.d.ts → create-store.test.d.ts} +0 -0
  125. /package/dist/src/web/{typed-hooks.test.d.ts → data-llm.test.d.ts} +0 -0
  126. /package/dist/src/web/{plugin.d.ts → plugin/plugin.d.ts} +0 -0
@@ -0,0 +1,70 @@
1
+ import { afterEach, beforeEach, describe, expect, it, vi, } from "vitest";
2
+ import { createStore } from "./create-store.js";
3
+ import { WIDGET_CONTEXT_KEY } from "./data-llm.js";
4
+ describe("createStore", () => {
5
+ let OpenaiMock;
6
+ beforeEach(() => {
7
+ OpenaiMock = {
8
+ widgetState: null,
9
+ setWidgetState: vi.fn().mockResolvedValue(undefined),
10
+ };
11
+ vi.stubGlobal("openai", OpenaiMock);
12
+ });
13
+ afterEach(() => {
14
+ vi.unstubAllGlobals();
15
+ vi.resetAllMocks();
16
+ });
17
+ it("should create a store without default state", () => {
18
+ const storeCreator = () => ({
19
+ count: 0,
20
+ });
21
+ const store = createStore(storeCreator);
22
+ expect(store.getState()).toEqual({ count: 0 });
23
+ });
24
+ it("should create a store with default state", () => {
25
+ const storeCreator = () => ({
26
+ count: 0,
27
+ name: "initial",
28
+ });
29
+ const defaultState = { count: 5, name: "default" };
30
+ const store = createStore(storeCreator, defaultState);
31
+ expect(store.getState()).toEqual({ count: 5, name: "default" });
32
+ });
33
+ it("should initialize from window.openai.widgetState when available", () => {
34
+ const storeCreator = () => ({
35
+ count: 0,
36
+ name: "initial",
37
+ });
38
+ const windowState = { count: 20, name: "window" };
39
+ OpenaiMock.widgetState = windowState;
40
+ const store = createStore(storeCreator);
41
+ expect(store.getState()).toEqual({ count: 20, name: "window" });
42
+ });
43
+ it("should persist state changes to window.openai.setWidgetState", async () => {
44
+ const storeCreator = (set) => ({
45
+ count: 0,
46
+ increment: () => set((state) => ({ count: state.count + 1 })),
47
+ });
48
+ const store = createStore(storeCreator);
49
+ store.getState().increment();
50
+ await vi.waitFor(() => {
51
+ expect(OpenaiMock.setWidgetState).toHaveBeenCalled();
52
+ });
53
+ const callArgs = OpenaiMock.setWidgetState.mock.calls[0]?.[0];
54
+ expect(callArgs).toEqual({ count: 1 });
55
+ });
56
+ it("should filter widget context from initial state", () => {
57
+ const storeCreator = () => ({
58
+ count: 0,
59
+ });
60
+ const windowState = {
61
+ count: 5,
62
+ [WIDGET_CONTEXT_KEY]: "context-value",
63
+ };
64
+ OpenaiMock.widgetState = windowState;
65
+ const store = createStore(storeCreator);
66
+ expect(store.getState()).toEqual({ count: 5 });
67
+ expect(store.getState()[WIDGET_CONTEXT_KEY]).toBeUndefined();
68
+ });
69
+ });
70
+ //# sourceMappingURL=create-store.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-store.test.js","sourceRoot":"","sources":["../../../src/web/create-store.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import { type ReactNode } from "react";
2
+ export type DataLLMContent = string;
3
+ export interface DataLLMNode {
4
+ id: string;
5
+ parentId: string | null;
6
+ content: string | null;
7
+ }
8
+ export declare const WIDGET_CONTEXT_KEY: "__widget_context";
9
+ interface DataLLMProps {
10
+ content: DataLLMContent | null | undefined;
11
+ children?: ReactNode;
12
+ }
13
+ export declare function DataLLM({ content, children }: DataLLMProps): import("react/jsx-runtime").JSX.Element;
14
+ export {};
@@ -0,0 +1,68 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { createContext, useContext, useEffect, useId, } from "react";
3
+ export const WIDGET_CONTEXT_KEY = "__widget_context";
4
+ const nodes = new Map();
5
+ function setNode(node) {
6
+ nodes.set(node.id, node);
7
+ onChange();
8
+ }
9
+ function removeNode(id) {
10
+ nodes.delete(id);
11
+ onChange();
12
+ }
13
+ function onChange() {
14
+ const description = getLLMDescriptionString();
15
+ window.openai.setWidgetState({
16
+ ...window.openai.widgetState,
17
+ [WIDGET_CONTEXT_KEY]: description,
18
+ });
19
+ }
20
+ const ParentIdContext = createContext(null);
21
+ export function DataLLM({ content, children }) {
22
+ const parentId = useContext(ParentIdContext);
23
+ const id = useId();
24
+ useEffect(() => {
25
+ if (content) {
26
+ setNode({
27
+ id,
28
+ parentId,
29
+ content,
30
+ });
31
+ }
32
+ else {
33
+ removeNode(id);
34
+ }
35
+ return () => {
36
+ removeNode(id);
37
+ };
38
+ }, [id, parentId, content]);
39
+ return (_jsx(ParentIdContext.Provider, { value: id, children: children }));
40
+ }
41
+ function getLLMDescriptionString() {
42
+ const byParent = new Map();
43
+ for (const node of Array.from(nodes.values())) {
44
+ const key = node.parentId ?? null;
45
+ if (!byParent.has(key))
46
+ byParent.set(key, []);
47
+ byParent.get(key)?.push(node);
48
+ }
49
+ for (const list of byParent.values()) {
50
+ list.sort((a, b) => a.id.localeCompare(b.id));
51
+ }
52
+ const lines = [];
53
+ function traverseTree(parentId, depth) {
54
+ const children = byParent.get(parentId);
55
+ if (!children)
56
+ return;
57
+ for (const child of children) {
58
+ if (child.content?.trim()) {
59
+ const indent = " ".repeat(depth);
60
+ lines.push(`${indent}- ${child.content.trim()}`);
61
+ }
62
+ traverseTree(child.id, depth + 1);
63
+ }
64
+ }
65
+ traverseTree(null, 0);
66
+ return lines.join("\n");
67
+ }
68
+ //# sourceMappingURL=data-llm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-llm.js","sourceRoot":"","sources":["../../../src/web/data-llm.tsx"],"names":[],"mappings":";AAAA,OAAO,EACL,aAAa,EAEb,UAAU,EACV,SAAS,EACT,KAAK,GACN,MAAM,OAAO,CAAC;AAUf,MAAM,CAAC,MAAM,kBAAkB,GAAG,kBAA2B,CAAC;AAE9D,MAAM,KAAK,GAAG,IAAI,GAAG,EAAuB,CAAC;AAE7C,SAAS,OAAO,CAAC,IAAiB;IAChC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACzB,QAAQ,EAAE,CAAC;AACb,CAAC;AAED,SAAS,UAAU,CAAC,EAAU;IAC5B,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACjB,QAAQ,EAAE,CAAC;AACb,CAAC;AAED,SAAS,QAAQ;IACf,MAAM,WAAW,GAAG,uBAAuB,EAAE,CAAC;IAC9C,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC;QAC3B,GAAG,MAAM,CAAC,MAAM,CAAC,WAAW;QAC5B,CAAC,kBAAkB,CAAC,EAAE,WAAW;KAClC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,eAAe,GAAG,aAAa,CAAgB,IAAI,CAAC,CAAC;AAO3D,MAAM,UAAU,OAAO,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAgB;IACzD,MAAM,QAAQ,GAAG,UAAU,CAAC,eAAe,CAAC,CAAC;IAC7C,MAAM,EAAE,GAAG,KAAK,EAAE,CAAC;IAEnB,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC;gBACN,EAAE;gBACF,QAAQ;gBACR,OAAO;aACR,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,UAAU,CAAC,EAAE,CAAC,CAAC;QACjB,CAAC;QAED,OAAO,GAAG,EAAE;YACV,UAAU,CAAC,EAAE,CAAC,CAAC;QACjB,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;IAE5B,OAAO,CACL,KAAC,eAAe,CAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,YAAG,QAAQ,GAA4B,CAC3E,CAAC;AACJ,CAAC;AAED,SAAS,uBAAuB;IAC9B,MAAM,QAAQ,GAAG,IAAI,GAAG,EAAgC,CAAC;IACzD,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC;QAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC;QAClC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC;YAAE,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAC9C,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC;QACrC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAChD,CAAC;IAED,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,SAAS,YAAY,CAAC,QAAuB,EAAE,KAAa;QAC1D,MAAM,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACxC,IAAI,CAAC,QAAQ;YAAE,OAAO;QAEtB,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,IAAI,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CAAC;gBAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAClC,KAAK,CAAC,IAAI,CAAC,GAAG,MAAM,KAAK,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YACnD,CAAC;YACD,YAAY,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;IAED,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAEtB,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC"}
@@ -0,0 +1,76 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { render } from "@testing-library/react";
3
+ import { afterEach, beforeEach, describe, expect, it, vi, } from "vitest";
4
+ import { DataLLM } from "./data-llm.js";
5
+ describe("DataLLM", () => {
6
+ let OpenaiMock;
7
+ beforeEach(() => {
8
+ OpenaiMock = {
9
+ widgetState: {},
10
+ setWidgetState: vi.fn(),
11
+ };
12
+ // Use Object.defineProperty to ensure it persists
13
+ Object.defineProperty(globalThis, "openai", {
14
+ value: OpenaiMock,
15
+ writable: true,
16
+ configurable: true,
17
+ });
18
+ // Also set on window for browser-like environment
19
+ if (typeof window !== "undefined") {
20
+ Object.defineProperty(window, "openai", {
21
+ value: OpenaiMock,
22
+ writable: true,
23
+ configurable: true,
24
+ });
25
+ }
26
+ vi.stubGlobal("openai", OpenaiMock);
27
+ });
28
+ afterEach(() => {
29
+ vi.resetAllMocks();
30
+ // Keep the mock available for React cleanup, but reset it
31
+ if (typeof window !== "undefined" && window.openai) {
32
+ window.openai.setWidgetState = vi.fn();
33
+ window.openai.widgetState = {};
34
+ }
35
+ });
36
+ it("should register a node with content and call setWidgetState", () => {
37
+ render(_jsx(DataLLM, { content: "Test content", children: _jsx("div", { children: "Child" }) }));
38
+ expect(OpenaiMock.setWidgetState).toHaveBeenCalled();
39
+ const callArgs = OpenaiMock.setWidgetState.mock.calls[0]?.[0];
40
+ expect(callArgs).toHaveProperty("__widget_context");
41
+ expect(callArgs?.__widget_context).toContain("- Test content");
42
+ });
43
+ it("should preserve existing widgetState when updating context", () => {
44
+ OpenaiMock.widgetState = { existingKey: "existingValue" };
45
+ render(_jsx(DataLLM, { content: "Test content", children: _jsx("div", { children: "Child" }) }));
46
+ const callArgs = OpenaiMock.setWidgetState.mock.calls[0]?.[0];
47
+ expect(callArgs).toHaveProperty("existingKey", "existingValue");
48
+ expect(callArgs).toHaveProperty("__widget_context");
49
+ });
50
+ it("should handle deeply nested DataLLM components", () => {
51
+ render(_jsxs(DataLLM, { content: "Level 1", children: [_jsx(DataLLM, { content: "Level 2A" }), _jsx(DataLLM, { content: "Level 2B", children: _jsx(DataLLM, { content: "Level 3", children: _jsx("div", { children: "Content" }) }) })] }));
52
+ const callArgs = OpenaiMock.setWidgetState.mock.calls[OpenaiMock.setWidgetState.mock.calls.length - 1]?.[0];
53
+ const context = callArgs?.__widget_context;
54
+ expect(context).toContain("- Level 1");
55
+ expect(context).toContain(" - Level 2A");
56
+ expect(context).toContain(" - Level 2B");
57
+ expect(context).toContain(" - Level 3");
58
+ });
59
+ it("should update context when content changes", () => {
60
+ const { rerender } = render(_jsx(DataLLM, { content: "Initial content", children: _jsx("div", { children: "Child" }) }));
61
+ const initialCalls = OpenaiMock.setWidgetState.mock.calls.length;
62
+ rerender(_jsx(DataLLM, { content: "Updated content", children: _jsx("div", { children: "Child" }) }));
63
+ expect(OpenaiMock.setWidgetState.mock.calls.length).toBeGreaterThan(initialCalls);
64
+ const lastCallArgs = OpenaiMock.setWidgetState.mock.calls[OpenaiMock.setWidgetState.mock.calls.length - 1]?.[0];
65
+ expect(lastCallArgs?.__widget_context).toContain("- Updated content");
66
+ });
67
+ it("should remove node and update context when component unmounts", () => {
68
+ const { unmount } = render(_jsx(DataLLM, { content: "Content to remove", children: _jsx("div", { children: "Child" }) }));
69
+ const callsBeforeUnmount = OpenaiMock.setWidgetState.mock.calls.length;
70
+ unmount();
71
+ expect(OpenaiMock.setWidgetState.mock.calls.length).toBeGreaterThan(callsBeforeUnmount);
72
+ const lastCallArgs = OpenaiMock.setWidgetState.mock.calls[OpenaiMock.setWidgetState.mock.calls.length - 1]?.[0];
73
+ expect(lastCallArgs?.__widget_context).not.toContain("Content to remove");
74
+ });
75
+ });
76
+ //# sourceMappingURL=data-llm.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-llm.test.js","sourceRoot":"","sources":["../../../src/web/data-llm.test.tsx"],"names":[],"mappings":"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"}
@@ -1,11 +1,15 @@
1
- import { useCallTool } from "./hooks/use-call-tool.js";
2
- import type { ToolPendingState, ToolSuccessState } from "./hooks/use-tool-info.js";
3
- import type { McpServer, InferWidgets, AnyWidgetRegistry, WidgetInput, WidgetOutput } from "../server/index.js";
4
- import type { CallToolArgs, UnknownObject } from "./types.js";
5
- type TypedCallToolReturn<TInput, TOutput> = ReturnType<typeof useCallTool<TInput & CallToolArgs, {
6
- structuredContent: TOutput & UnknownObject;
7
- }>>;
8
- type TypedToolInfoReturn<TInput extends UnknownObject, TOutput extends UnknownObject, TResponseMetadata extends UnknownObject> = ToolPendingState<TInput> | ToolSuccessState<TInput, TOutput, TResponseMetadata>;
1
+ import type { InferTools, ToolInput, ToolOutput, ToolResponseMetadata } from "../server/index.js";
2
+ import { type CallToolAsyncFn, type CallToolFn, type CallToolState } from "./hooks/use-call-tool.js";
3
+ import { type ToolState } from "./hooks/use-tool-info.js";
4
+ import type { CallToolResponse, Objectify, Prettify } from "./types.js";
5
+ type TypedCallToolResponse<TOutput> = CallToolResponse & {
6
+ structuredContent: TOutput;
7
+ };
8
+ type TypedCallToolReturn<TInput, TOutput> = Prettify<CallToolState<TypedCallToolResponse<TOutput>> & {
9
+ callTool: CallToolFn<TInput, TypedCallToolResponse<TOutput>>;
10
+ callToolAsync: CallToolAsyncFn<TInput, TypedCallToolResponse<TOutput>>;
11
+ }>;
12
+ type TypedToolInfoReturn<TInput, TOutput, TResponseMetadata> = ToolState<Objectify<TInput>, Objectify<TOutput>, Objectify<TResponseMetadata>>;
9
13
  /**
10
14
  * Creates typed versions of skybridge hooks with full type inference
11
15
  * for tool names, inputs, and outputs.
@@ -13,7 +17,9 @@ type TypedToolInfoReturn<TInput extends UnknownObject, TOutput extends UnknownOb
13
17
  * This is the recommended way to use skybridge hooks in your widgets.
14
18
  * Set this up once in a dedicated file and export the typed hooks for use across your app.
15
19
  *
16
- * @typeParam T - The type of your McpServer instance. Use `typeof server`.
20
+ * @typeParam ServerType - The type of your McpServer instance (use `typeof server`).
21
+ * Must be a server instance created with method chaining.
22
+ * TypeScript will validate that tools can be inferred from this type.
17
23
  *
18
24
  * @example
19
25
  * ```typescript
@@ -33,9 +39,9 @@ type TypedToolInfoReturn<TInput extends UnknownObject, TOutput extends UnknownOb
33
39
  * ```typescript
34
40
  * // web/src/skybridge.ts (one-time setup)
35
41
  * import type { AppType } from "../server";
36
- * import { createTypedHooks } from "skybridge/web";
42
+ * import { generateHelpers } from "skybridge/web";
37
43
  *
38
- * export const { useCallTool, useToolInfo } = createTypedHooks<AppType>();
44
+ * export const { useCallTool, useToolInfo } = generateHelpers<AppType>();
39
45
  * ```
40
46
  *
41
47
  * @example
@@ -52,11 +58,11 @@ type TypedToolInfoReturn<TInput extends UnknownObject, TOutput extends UnknownOb
52
58
  * const toolInfo = useToolInfo<"search-voyage">();
53
59
  * // ^ autocomplete for widget names
54
60
  * // toolInfo.input is typed based on widget input schema
55
- * // toolInfo.output is typed based on widget output schema
61
+ * // toolInfo.output.structuredContent is typed based on widget output schema
56
62
  * }
57
63
  * ```
58
64
  */
59
- export declare function createTypedHooks<T extends McpServer<AnyWidgetRegistry>>(): {
65
+ export declare function generateHelpers<ServerType = never>(): {
60
66
  /**
61
67
  * Typed version of `useCallTool` that provides autocomplete for tool names
62
68
  * and type inference for inputs and outputs.
@@ -76,7 +82,7 @@ export declare function createTypedHooks<T extends McpServer<AnyWidgetRegistry>>
76
82
  * }
77
83
  * ```
78
84
  */
79
- useCallTool: <K extends keyof InferWidgets<T> & string>(name: K) => TypedCallToolReturn<InferWidgets<T>[K]["input"], InferWidgets<T>[K]["output"]>;
85
+ useCallTool: <ToolName extends keyof InferTools<ServerType> & string>(name: ToolName) => TypedCallToolReturn<ToolInput<ServerType, ToolName>, ToolOutput<ServerType, ToolName>>;
80
86
  /**
81
87
  * Typed version of `useToolInfo` that provides autocomplete for widget names
82
88
  * and type inference for inputs, outputs, and responseMetadata.
@@ -88,20 +94,22 @@ export declare function createTypedHooks<T extends McpServer<AnyWidgetRegistry>>
88
94
  * ```typescript
89
95
  * const toolInfo = useToolInfo<"search-voyage">();
90
96
  * // toolInfo.input is typed as { destination: string; ... }
91
- * // toolInfo.output is typed as { results: Array<...>; ... } | undefined
97
+ * // toolInfo.output is typed as { results: Array<...>; ... }
98
+ * // toolInfo.responseMetadata is typed based on _meta in callback return
92
99
  * // toolInfo.status narrows correctly: "pending" | "success"
93
100
  *
94
101
  * if (toolInfo.isPending) {
95
- * // TypeScript knows output is undefined here
102
+ * // TypeScript knows output and responseMetadata are undefined here
96
103
  * console.log(toolInfo.input.destination);
97
104
  * }
98
105
  *
99
106
  * if (toolInfo.isSuccess) {
100
- * // TypeScript knows output is defined here
107
+ * // TypeScript knows output and responseMetadata are defined here
101
108
  * console.log(toolInfo.output.results);
109
+ * console.log(toolInfo.responseMetadata);
102
110
  * }
103
111
  * ```
104
112
  */
105
- useToolInfo: <K extends keyof InferWidgets<T> & string>() => TypedToolInfoReturn<WidgetInput<T, K> & UnknownObject, WidgetOutput<T, K> & UnknownObject, UnknownObject>;
113
+ useToolInfo: <ToolName extends keyof InferTools<ServerType> & string>() => TypedToolInfoReturn<ToolInput<ServerType, ToolName>, ToolOutput<ServerType, ToolName>, ToolResponseMetadata<ServerType, ToolName>>;
106
114
  };
107
115
  export {};
@@ -1,4 +1,4 @@
1
- import { useCallTool } from "./hooks/use-call-tool.js";
1
+ import { useCallTool, } from "./hooks/use-call-tool.js";
2
2
  import { useToolInfo } from "./hooks/use-tool-info.js";
3
3
  /**
4
4
  * Creates typed versions of skybridge hooks with full type inference
@@ -7,7 +7,9 @@ import { useToolInfo } from "./hooks/use-tool-info.js";
7
7
  * This is the recommended way to use skybridge hooks in your widgets.
8
8
  * Set this up once in a dedicated file and export the typed hooks for use across your app.
9
9
  *
10
- * @typeParam T - The type of your McpServer instance. Use `typeof server`.
10
+ * @typeParam ServerType - The type of your McpServer instance (use `typeof server`).
11
+ * Must be a server instance created with method chaining.
12
+ * TypeScript will validate that tools can be inferred from this type.
11
13
  *
12
14
  * @example
13
15
  * ```typescript
@@ -27,9 +29,9 @@ import { useToolInfo } from "./hooks/use-tool-info.js";
27
29
  * ```typescript
28
30
  * // web/src/skybridge.ts (one-time setup)
29
31
  * import type { AppType } from "../server";
30
- * import { createTypedHooks } from "skybridge/web";
32
+ * import { generateHelpers } from "skybridge/web";
31
33
  *
32
- * export const { useCallTool, useToolInfo } = createTypedHooks<AppType>();
34
+ * export const { useCallTool, useToolInfo } = generateHelpers<AppType>();
33
35
  * ```
34
36
  *
35
37
  * @example
@@ -46,11 +48,11 @@ import { useToolInfo } from "./hooks/use-tool-info.js";
46
48
  * const toolInfo = useToolInfo<"search-voyage">();
47
49
  * // ^ autocomplete for widget names
48
50
  * // toolInfo.input is typed based on widget input schema
49
- * // toolInfo.output is typed based on widget output schema
51
+ * // toolInfo.output.structuredContent is typed based on widget output schema
50
52
  * }
51
53
  * ```
52
54
  */
53
- export function createTypedHooks() {
55
+ export function generateHelpers() {
54
56
  return {
55
57
  /**
56
58
  * Typed version of `useCallTool` that provides autocomplete for tool names
@@ -72,8 +74,6 @@ export function createTypedHooks() {
72
74
  * ```
73
75
  */
74
76
  useCallTool: (name) => {
75
- // Type assertion is safe here because the runtime types are compatible.
76
- // The underlying hook accepts broader types, but we expose narrower, more specific types.
77
77
  return useCallTool(name);
78
78
  },
79
79
  /**
@@ -87,25 +87,25 @@ export function createTypedHooks() {
87
87
  * ```typescript
88
88
  * const toolInfo = useToolInfo<"search-voyage">();
89
89
  * // toolInfo.input is typed as { destination: string; ... }
90
- * // toolInfo.output is typed as { results: Array<...>; ... } | undefined
90
+ * // toolInfo.output is typed as { results: Array<...>; ... }
91
+ * // toolInfo.responseMetadata is typed based on _meta in callback return
91
92
  * // toolInfo.status narrows correctly: "pending" | "success"
92
93
  *
93
94
  * if (toolInfo.isPending) {
94
- * // TypeScript knows output is undefined here
95
+ * // TypeScript knows output and responseMetadata are undefined here
95
96
  * console.log(toolInfo.input.destination);
96
97
  * }
97
98
  *
98
99
  * if (toolInfo.isSuccess) {
99
- * // TypeScript knows output is defined here
100
+ * // TypeScript knows output and responseMetadata are defined here
100
101
  * console.log(toolInfo.output.results);
102
+ * console.log(toolInfo.responseMetadata);
101
103
  * }
102
104
  * ```
103
105
  */
104
106
  useToolInfo: () => {
105
- // Type assertion is safe here because the runtime types are compatible.
106
- // The underlying hook accepts broader types, but we expose narrower, more specific types.
107
107
  return useToolInfo();
108
108
  },
109
109
  };
110
110
  }
111
- //# sourceMappingURL=typed-hooks.js.map
111
+ //# sourceMappingURL=generate-helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-helpers.js","sourceRoot":"","sources":["../../../src/web/generate-helpers.ts"],"names":[],"mappings":"AAMA,OAAO,EAIL,WAAW,GACZ,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAkB,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAoBvE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmDG;AACH,MAAM,UAAU,eAAe;IAI7B,OAAO;QACL;;;;;;;;;;;;;;;;;;WAkBG;QACH,WAAW,EAAE,CACX,IAAc,EAId,EAAE;YACF,OAAO,WAAW,CAAC,IAAI,CAGtB,CAAC;QACJ,CAAC;QAED;;;;;;;;;;;;;;;;;;;;;;;;;;WA0BG;QACH,WAAW,EAAE,GAIX,EAAE;YACF,OAAO,WAAW,EAIjB,CAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,180 @@
1
+ import { expectTypeOf, test } from "vitest";
2
+ import { createTestServer } from "../test/utils.js";
3
+ import { generateHelpers } from "./generate-helpers.js";
4
+ const server = createTestServer();
5
+ test("InferTools extracts the tool registry type (widgets + registerTool)", () => {
6
+ expectTypeOf().toHaveProperty("search-voyage");
7
+ expectTypeOf().toHaveProperty("get-trip-details");
8
+ expectTypeOf().toHaveProperty("no-input-widget");
9
+ expectTypeOf().toHaveProperty("calculate-price");
10
+ expectTypeOf().toHaveProperty("inferred-output-widget");
11
+ expectTypeOf().toHaveProperty("inferred-tool");
12
+ expectTypeOf().toHaveProperty("widget-with-metadata");
13
+ expectTypeOf().toHaveProperty("tool-with-metadata");
14
+ expectTypeOf().toHaveProperty("widget-with-mixed-returns");
15
+ });
16
+ test("ToolNames returns a union of tool name literals (widgets + registerTool)", () => {
17
+ expectTypeOf().toEqualTypeOf();
18
+ });
19
+ test("ToolInput extracts the correct input type from Zod schema", () => {
20
+ expectTypeOf().toEqualTypeOf();
21
+ expectTypeOf().toEqualTypeOf();
22
+ expectTypeOf().toEqualTypeOf();
23
+ });
24
+ test("ToolOutput extracts the correct output type from callback's structuredContent", () => {
25
+ expectTypeOf().toEqualTypeOf();
26
+ expectTypeOf().toEqualTypeOf();
27
+ expectTypeOf().toEqualTypeOf();
28
+ expectTypeOf().toEqualTypeOf();
29
+ });
30
+ test("ToolOutput extracts the correct output type from callback (inferred)", () => {
31
+ expectTypeOf().toEqualTypeOf();
32
+ expectTypeOf().toEqualTypeOf();
33
+ });
34
+ test("generateHelpers provides autocomplete for tool names (widgets + registerTool)", () => {
35
+ const { useCallTool } = generateHelpers();
36
+ useCallTool("search-voyage");
37
+ useCallTool("get-trip-details");
38
+ useCallTool("no-input-widget");
39
+ useCallTool("calculate-price");
40
+ useCallTool("inferred-output-widget");
41
+ useCallTool("inferred-tool");
42
+ useCallTool("widget-with-metadata");
43
+ useCallTool("tool-with-metadata");
44
+ useCallTool("widget-with-mixed-returns");
45
+ // @ts-expect-error - "invalid-name" is not a valid tool name
46
+ useCallTool("invalid-name");
47
+ });
48
+ test("useCallTool returns correctly typed callTool function", () => {
49
+ const { useCallTool } = generateHelpers();
50
+ const { callTool } = useCallTool("search-voyage");
51
+ callTool({ destination: "Spain" });
52
+ callTool({ destination: "France", departureDate: "2024-06-01" });
53
+ callTool({ destination: "Italy", maxPrice: 1000 });
54
+ const { callTool: calculateTool } = useCallTool("calculate-price");
55
+ calculateTool({ tripId: "123", passengers: 2 });
56
+ });
57
+ test("callTool can be called without args for tools with no required inputs", () => {
58
+ const { useCallTool } = generateHelpers();
59
+ const { callTool, callToolAsync } = useCallTool("no-input-widget");
60
+ callTool();
61
+ callTool({});
62
+ callToolAsync();
63
+ callToolAsync({});
64
+ });
65
+ test("callTool requires args for tools with required inputs", () => {
66
+ const { useCallTool } = generateHelpers();
67
+ const { callTool } = useCallTool("search-voyage");
68
+ // @ts-expect-error - "destination" is required
69
+ callTool();
70
+ // @ts-expect-error - "destination" is required
71
+ callTool({});
72
+ // This should work
73
+ callTool({ destination: "Spain" });
74
+ });
75
+ test("callTool supports sideEffects for tools with required inputs", () => {
76
+ const { useCallTool } = generateHelpers();
77
+ const { callTool } = useCallTool("search-voyage");
78
+ callTool({ destination: "Spain" }, {
79
+ onSuccess: (response, args) => {
80
+ expectTypeOf(response.structuredContent.results).toBeArray();
81
+ expectTypeOf(args.destination).toBeString();
82
+ },
83
+ onError: (error, args) => {
84
+ expectTypeOf(error).toBeUnknown();
85
+ expectTypeOf(args.destination).toBeString();
86
+ },
87
+ onSettled: (response, error, args) => {
88
+ if (response) {
89
+ expectTypeOf(response.structuredContent.totalCount).toBeNumber();
90
+ }
91
+ expectTypeOf(error).toBeUnknown();
92
+ expectTypeOf(args.destination).toBeString();
93
+ },
94
+ });
95
+ });
96
+ test("callTool supports sideEffects for tools with no required inputs", () => {
97
+ const { useCallTool } = generateHelpers();
98
+ const { callTool } = useCallTool("no-input-widget");
99
+ callTool({
100
+ onSuccess: (response) => {
101
+ expectTypeOf(response).toHaveProperty("structuredContent");
102
+ },
103
+ });
104
+ callTool({}, {
105
+ onSuccess: (response) => {
106
+ expectTypeOf(response).toHaveProperty("structuredContent");
107
+ },
108
+ });
109
+ });
110
+ test("callToolAsync returns correctly typed promise", () => {
111
+ const { useCallTool } = generateHelpers();
112
+ const { callToolAsync: searchAsync } = useCallTool("search-voyage");
113
+ const searchPromise = searchAsync({ destination: "Spain" });
114
+ expectTypeOf(searchPromise).resolves.toHaveProperty("structuredContent");
115
+ const { callToolAsync: noInputAsync } = useCallTool("no-input-widget");
116
+ const noInputPromise = noInputAsync();
117
+ expectTypeOf(noInputPromise).resolves.toHaveProperty("structuredContent");
118
+ });
119
+ test("useCallTool returns correctly typed data", () => {
120
+ const { useCallTool } = generateHelpers();
121
+ const { data } = useCallTool("search-voyage");
122
+ if (data) {
123
+ expectTypeOf(data.structuredContent).toExtend();
124
+ expectTypeOf(data.structuredContent.results).toBeArray();
125
+ expectTypeOf(data.structuredContent.totalCount).toBeNumber();
126
+ }
127
+ });
128
+ test("useCallTool returns correctly typed data for callback-inferred outputs", () => {
129
+ const { useCallTool } = generateHelpers();
130
+ const { data: widgetData } = useCallTool("inferred-output-widget");
131
+ if (widgetData) {
132
+ expectTypeOf(widgetData.structuredContent).toExtend();
133
+ }
134
+ const { data: toolData } = useCallTool("inferred-tool");
135
+ if (toolData) {
136
+ expectTypeOf(toolData.structuredContent).toExtend();
137
+ }
138
+ });
139
+ test("generateHelpers provides autocomplete for tool names in useToolInfo (widgets + registerTool)", () => {
140
+ const { useToolInfo } = generateHelpers();
141
+ useToolInfo();
142
+ useToolInfo();
143
+ useToolInfo();
144
+ useToolInfo();
145
+ useToolInfo();
146
+ useToolInfo();
147
+ useToolInfo();
148
+ useToolInfo();
149
+ useToolInfo();
150
+ // @ts-expect-error - "invalid-name" is not a valid tool name
151
+ useToolInfo();
152
+ });
153
+ test("useToolInfo infers input and output types", () => {
154
+ const { useToolInfo } = generateHelpers();
155
+ const toolInfo = useToolInfo();
156
+ expectTypeOf(toolInfo.input).toExtend();
157
+ if (toolInfo.status === "success") {
158
+ expectTypeOf(toolInfo.output).toExtend();
159
+ expectTypeOf(toolInfo.output.results).toBeArray();
160
+ expectTypeOf(toolInfo.output.totalCount).toBeNumber();
161
+ }
162
+ });
163
+ test("ToolResponseMetadata extracts _meta type from callback", () => {
164
+ expectTypeOf().toEqualTypeOf();
165
+ expectTypeOf().toEqualTypeOf();
166
+ expectTypeOf().toBeUnknown();
167
+ });
168
+ test("useToolInfo infers responseMetadata type from generateHelpers", () => {
169
+ const { useToolInfo } = generateHelpers();
170
+ const toolInfo = useToolInfo();
171
+ if (toolInfo.isSuccess) {
172
+ expectTypeOf(toolInfo.responseMetadata.requestId).toBeString();
173
+ expectTypeOf(toolInfo.responseMetadata.timestamp).toBeNumber();
174
+ expectTypeOf(toolInfo.responseMetadata.cached).toBeBoolean();
175
+ }
176
+ });
177
+ test("ToolResponseMetadata extracts _meta from mixed return paths", () => {
178
+ expectTypeOf().toEqualTypeOf();
179
+ });
180
+ //# sourceMappingURL=generate-helpers.test-d.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-helpers.test-d.js","sourceRoot":"","sources":["../../../src/web/generate-helpers.test-d.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};