skybridge 0.0.0-dev.fc2f516 → 0.0.0-dev.fcc9898

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 (164) hide show
  1. package/LICENSE +21 -674
  2. package/dist/src/server/devtoolsStaticServer.d.ts +19 -0
  3. package/dist/src/server/devtoolsStaticServer.js +48 -0
  4. package/dist/src/server/devtoolsStaticServer.js.map +1 -0
  5. package/dist/src/server/index.d.ts +3 -2
  6. package/dist/src/server/index.js +1 -0
  7. package/dist/src/server/index.js.map +1 -1
  8. package/dist/src/server/inferUtilityTypes.d.ts +10 -0
  9. package/dist/src/server/server.d.ts +43 -17
  10. package/dist/src/server/server.js +54 -34
  11. package/dist/src/server/server.js.map +1 -1
  12. package/dist/src/server/templateHelper.d.ts +3 -0
  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 +4 -3
  16. package/dist/src/server/templates/production.hbs +1 -0
  17. package/dist/src/server/widgetsDevServer.js +2 -3
  18. package/dist/src/server/widgetsDevServer.js.map +1 -1
  19. package/dist/src/test/utils.d.ts +54 -8
  20. package/dist/src/test/utils.js +86 -8
  21. package/dist/src/test/utils.js.map +1 -1
  22. package/dist/src/test/widget.test.js +82 -29
  23. package/dist/src/test/widget.test.js.map +1 -1
  24. package/dist/src/web/bridges/adaptors/apps-sdk-adaptor.d.ts +13 -0
  25. package/dist/src/web/bridges/adaptors/apps-sdk-adaptor.js +33 -0
  26. package/dist/src/web/bridges/adaptors/apps-sdk-adaptor.js.map +1 -0
  27. package/dist/src/web/bridges/adaptors/mcp-app-adaptor.d.ts +16 -0
  28. package/dist/src/web/bridges/adaptors/mcp-app-adaptor.js +115 -0
  29. package/dist/src/web/bridges/adaptors/mcp-app-adaptor.js.map +1 -0
  30. package/dist/src/web/bridges/apps-sdk-bridge.d.ts +10 -0
  31. package/dist/src/web/bridges/apps-sdk-bridge.js +46 -0
  32. package/dist/src/web/bridges/apps-sdk-bridge.js.map +1 -0
  33. package/dist/src/web/bridges/hooks/use-adaptor.d.ts +2 -0
  34. package/dist/src/web/bridges/hooks/use-adaptor.js +8 -0
  35. package/dist/src/web/bridges/hooks/use-adaptor.js.map +1 -0
  36. package/dist/src/web/bridges/hooks/use-apps-sdk-bridge.d.ts +2 -0
  37. package/dist/src/web/bridges/hooks/use-apps-sdk-bridge.js +7 -0
  38. package/dist/src/web/bridges/hooks/use-apps-sdk-bridge.js.map +1 -0
  39. package/dist/src/web/bridges/hooks/use-bridge.d.ts +2 -0
  40. package/dist/src/web/bridges/hooks/use-bridge.js +8 -0
  41. package/dist/src/web/bridges/hooks/use-bridge.js.map +1 -0
  42. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.d.ts +5 -0
  43. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.js +7 -0
  44. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.js.map +1 -0
  45. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.test.js +41 -0
  46. package/dist/src/web/bridges/hooks/use-mcp-app-bridge.test.js.map +1 -0
  47. package/dist/src/web/bridges/index.d.ts +4 -0
  48. package/dist/src/web/bridges/index.js +5 -0
  49. package/dist/src/web/bridges/index.js.map +1 -0
  50. package/dist/src/web/bridges/mcp-app-bridge.d.ts +38 -0
  51. package/dist/src/web/bridges/mcp-app-bridge.js +162 -0
  52. package/dist/src/web/bridges/mcp-app-bridge.js.map +1 -0
  53. package/dist/src/web/bridges/types.d.ts +57 -0
  54. package/dist/src/web/bridges/types.js +2 -0
  55. package/dist/src/web/bridges/types.js.map +1 -0
  56. package/dist/src/web/create-store.d.ts +3 -0
  57. package/dist/src/web/create-store.js +25 -0
  58. package/dist/src/web/create-store.js.map +1 -0
  59. package/dist/src/web/create-store.test.js +70 -0
  60. package/dist/src/web/create-store.test.js.map +1 -0
  61. package/dist/src/web/data-llm.d.ts +1 -0
  62. package/dist/src/web/data-llm.js +8 -5
  63. package/dist/src/web/data-llm.js.map +1 -1
  64. package/dist/src/web/data-llm.test.js.map +1 -1
  65. package/dist/src/web/generate-helpers.d.ts +11 -11
  66. package/dist/src/web/generate-helpers.js +6 -4
  67. package/dist/src/web/generate-helpers.js.map +1 -1
  68. package/dist/src/web/generate-helpers.test-d.js +62 -4
  69. package/dist/src/web/generate-helpers.test-d.js.map +1 -1
  70. package/dist/src/web/generate-helpers.test.js +1 -1
  71. package/dist/src/web/generate-helpers.test.js.map +1 -1
  72. package/dist/src/web/helpers/state.d.ts +7 -0
  73. package/dist/src/web/helpers/state.js +40 -0
  74. package/dist/src/web/helpers/state.js.map +1 -0
  75. package/dist/src/web/helpers/state.test.js +53 -0
  76. package/dist/src/web/helpers/state.test.js.map +1 -0
  77. package/dist/src/web/hooks/index.d.ts +4 -5
  78. package/dist/src/web/hooks/index.js +3 -4
  79. package/dist/src/web/hooks/index.js.map +1 -1
  80. package/dist/src/web/hooks/test/utils.d.ts +10 -0
  81. package/dist/src/web/hooks/test/utils.js +40 -0
  82. package/dist/src/web/hooks/test/utils.js.map +1 -0
  83. package/dist/src/web/hooks/use-call-tool.d.ts +1 -1
  84. package/dist/src/web/hooks/use-call-tool.js +12 -4
  85. package/dist/src/web/hooks/use-call-tool.js.map +1 -1
  86. package/dist/src/web/hooks/use-call-tool.test-d.js +1 -1
  87. package/dist/src/web/hooks/use-call-tool.test-d.js.map +1 -1
  88. package/dist/src/web/hooks/use-call-tool.test.js +35 -15
  89. package/dist/src/web/hooks/use-call-tool.test.js.map +1 -1
  90. package/dist/src/web/hooks/use-display-mode.d.ts +1 -1
  91. package/dist/src/web/hooks/use-display-mode.js +6 -3
  92. package/dist/src/web/hooks/use-display-mode.js.map +1 -1
  93. package/dist/src/web/hooks/use-display-mode.test.js +3 -2
  94. package/dist/src/web/hooks/use-display-mode.test.js.map +1 -1
  95. package/dist/src/web/hooks/use-files.test.js +1 -1
  96. package/dist/src/web/hooks/use-files.test.js.map +1 -1
  97. package/dist/src/web/hooks/use-layout.d.ts +22 -0
  98. package/dist/src/web/hooks/use-layout.js +23 -0
  99. package/dist/src/web/hooks/use-layout.js.map +1 -0
  100. package/dist/src/web/hooks/use-layout.test.d.ts +1 -0
  101. package/dist/src/web/hooks/use-layout.test.js +95 -0
  102. package/dist/src/web/hooks/use-layout.test.js.map +1 -0
  103. package/dist/src/web/hooks/use-open-external.js +5 -3
  104. package/dist/src/web/hooks/use-open-external.js.map +1 -1
  105. package/dist/src/web/hooks/use-open-external.test.js +43 -17
  106. package/dist/src/web/hooks/use-open-external.test.js.map +1 -1
  107. package/dist/src/web/hooks/use-openai-global.d.ts +3 -2
  108. package/dist/src/web/hooks/use-openai-global.js +3 -20
  109. package/dist/src/web/hooks/use-openai-global.js.map +1 -1
  110. package/dist/src/web/hooks/use-request-modal.d.ts +6 -3
  111. package/dist/src/web/hooks/use-request-modal.js +6 -1
  112. package/dist/src/web/hooks/use-request-modal.js.map +1 -1
  113. package/dist/src/web/hooks/use-request-modal.test.js +37 -4
  114. package/dist/src/web/hooks/use-request-modal.test.js.map +1 -1
  115. package/dist/src/web/hooks/use-send-follow-up-message.js +3 -6
  116. package/dist/src/web/hooks/use-send-follow-up-message.js.map +1 -1
  117. package/dist/src/web/hooks/use-tool-info.d.ts +13 -2
  118. package/dist/src/web/hooks/use-tool-info.js +15 -11
  119. package/dist/src/web/hooks/use-tool-info.js.map +1 -1
  120. package/dist/src/web/hooks/use-tool-info.test-d.js +40 -5
  121. package/dist/src/web/hooks/use-tool-info.test-d.js.map +1 -1
  122. package/dist/src/web/hooks/use-tool-info.test.js +119 -48
  123. package/dist/src/web/hooks/use-tool-info.test.js.map +1 -1
  124. package/dist/src/web/hooks/use-user.d.ts +18 -0
  125. package/dist/src/web/hooks/use-user.js +19 -0
  126. package/dist/src/web/hooks/use-user.js.map +1 -0
  127. package/dist/src/web/hooks/use-user.test.d.ts +1 -0
  128. package/dist/src/web/hooks/use-user.test.js +93 -0
  129. package/dist/src/web/hooks/use-user.test.js.map +1 -0
  130. package/dist/src/web/hooks/use-widget-state.js +5 -27
  131. package/dist/src/web/hooks/use-widget-state.js.map +1 -1
  132. package/dist/src/web/hooks/use-widget-state.test.js +3 -2
  133. package/dist/src/web/hooks/use-widget-state.test.js.map +1 -1
  134. package/dist/src/web/index.d.ts +5 -3
  135. package/dist/src/web/index.js +5 -3
  136. package/dist/src/web/index.js.map +1 -1
  137. package/dist/src/web/plugin/plugin.js +10 -4
  138. package/dist/src/web/plugin/plugin.js.map +1 -1
  139. package/dist/src/web/plugin/transform-data-llm.js +6 -3
  140. package/dist/src/web/plugin/transform-data-llm.js.map +1 -1
  141. package/dist/src/web/proxy.js +6 -1
  142. package/dist/src/web/proxy.js.map +1 -1
  143. package/dist/src/web/types.d.ts +30 -14
  144. package/dist/src/web/types.js.map +1 -1
  145. package/package.json +33 -26
  146. package/README.md +0 -371
  147. package/dist/src/web/hooks/use-locale.d.ts +0 -1
  148. package/dist/src/web/hooks/use-locale.js +0 -5
  149. package/dist/src/web/hooks/use-locale.js.map +0 -1
  150. package/dist/src/web/hooks/use-locale.test.js +0 -21
  151. package/dist/src/web/hooks/use-locale.test.js.map +0 -1
  152. package/dist/src/web/hooks/use-theme.d.ts +0 -1
  153. package/dist/src/web/hooks/use-theme.js +0 -5
  154. package/dist/src/web/hooks/use-theme.js.map +0 -1
  155. package/dist/src/web/hooks/use-theme.test.js +0 -26
  156. package/dist/src/web/hooks/use-theme.test.js.map +0 -1
  157. package/dist/src/web/hooks/use-user-agent.d.ts +0 -1
  158. package/dist/src/web/hooks/use-user-agent.js +0 -5
  159. package/dist/src/web/hooks/use-user-agent.js.map +0 -1
  160. package/dist/src/web/hooks/use-user-agent.test.js +0 -31
  161. package/dist/src/web/hooks/use-user-agent.test.js.map +0 -1
  162. /package/dist/src/web/{hooks/use-locale.test.d.ts → bridges/hooks/use-mcp-app-bridge.test.d.ts} +0 -0
  163. /package/dist/src/web/{hooks/use-theme.test.d.ts → create-store.test.d.ts} +0 -0
  164. /package/dist/src/web/{hooks/use-user-agent.test.d.ts → helpers/state.test.d.ts} +0 -0
@@ -1,11 +1,8 @@
1
1
  import { useCallback } from "react";
2
+ import { useAdaptor } from "../bridges/index.js";
2
3
  export function useSendFollowUpMessage() {
3
- const sendFollowUpMessage = useCallback(async (prompt) => {
4
- if (!window.openai?.sendFollowUpMessage) {
5
- throw new Error("window.openai.sendFollowUpMessage is not available");
6
- }
7
- return window.openai.sendFollowUpMessage({ prompt });
8
- }, []);
4
+ const adaptor = useAdaptor();
5
+ const sendFollowUpMessage = useCallback((prompt) => adaptor.sendFollowUpMessage(prompt), [adaptor]);
9
6
  return sendFollowUpMessage;
10
7
  }
11
8
  //# sourceMappingURL=use-send-follow-up-message.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-send-follow-up-message.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-send-follow-up-message.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAEpC,MAAM,UAAU,sBAAsB;IACpC,MAAM,mBAAmB,GAAG,WAAW,CACrC,KAAK,EAAE,MAAc,EAAiB,EAAE;QACtC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,mBAAmB,EAAE,CAAC;YACxC,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACxE,CAAC;QACD,OAAO,MAAM,CAAC,MAAM,CAAC,mBAAmB,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IACvD,CAAC,EACD,EAAE,CACH,CAAC;IAEF,OAAO,mBAAmB,CAAC;AAC7B,CAAC"}
1
+ {"version":3,"file":"use-send-follow-up-message.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-send-follow-up-message.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,MAAM,UAAU,sBAAsB;IACpC,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAC7B,MAAM,mBAAmB,GAAG,WAAW,CACrC,CAAC,MAAc,EAAE,EAAE,CAAC,OAAO,CAAC,mBAAmB,CAAC,MAAM,CAAC,EACvD,CAAC,OAAO,CAAC,CACV,CAAC;IAEF,OAAO,mBAAmB,CAAC;AAC7B,CAAC"}
@@ -1,6 +1,16 @@
1
1
  import type { UnknownObject } from "../types.js";
2
+ export type ToolIdleState = {
3
+ status: "idle";
4
+ isIdle: true;
5
+ isPending: false;
6
+ isSuccess: false;
7
+ input: undefined;
8
+ output: undefined;
9
+ responseMetadata: undefined;
10
+ };
2
11
  export type ToolPendingState<ToolInput extends UnknownObject> = {
3
12
  status: "pending";
13
+ isIdle: false;
4
14
  isPending: true;
5
15
  isSuccess: false;
6
16
  input: ToolInput;
@@ -9,17 +19,18 @@ export type ToolPendingState<ToolInput extends UnknownObject> = {
9
19
  };
10
20
  export type ToolSuccessState<ToolInput extends UnknownObject, ToolOutput extends UnknownObject, ToolResponseMetadata extends UnknownObject> = {
11
21
  status: "success";
22
+ isIdle: false;
12
23
  isPending: false;
13
24
  isSuccess: true;
14
25
  input: ToolInput;
15
26
  output: ToolOutput;
16
27
  responseMetadata: ToolResponseMetadata;
17
28
  };
18
- export type ToolState<ToolInput extends UnknownObject, ToolOutput extends UnknownObject, ToolResponseMetadata extends UnknownObject> = ToolPendingState<ToolInput> | ToolSuccessState<ToolInput, ToolOutput, ToolResponseMetadata>;
29
+ export type ToolState<ToolInput extends UnknownObject, ToolOutput extends UnknownObject, ToolResponseMetadata extends UnknownObject> = ToolIdleState | ToolPendingState<ToolInput> | ToolSuccessState<ToolInput, ToolOutput, ToolResponseMetadata>;
19
30
  type ToolSignature = {
20
31
  input: UnknownObject;
21
32
  output: UnknownObject;
22
33
  responseMetadata: UnknownObject;
23
34
  };
24
- export declare function useToolInfo<TS extends Partial<ToolSignature> = {}>(): ToolState<UnknownObject & TS["input"], UnknownObject & TS["output"], UnknownObject & TS["responseMetadata"]>;
35
+ export declare function useToolInfo<TS extends Partial<ToolSignature> = Record<string, never>>(): ToolState<UnknownObject & TS["input"], UnknownObject & TS["output"], UnknownObject & TS["responseMetadata"]>;
25
36
  export {};
@@ -1,18 +1,22 @@
1
- import { useOpenAiGlobal } from "./use-openai-global.js";
2
- import { useEffect, useState } from "react";
1
+ import { useBridge } from "../bridges/index.js";
2
+ function deriveStatus(input, output, responseMetadata) {
3
+ if (input === null) {
4
+ return "idle";
5
+ }
6
+ if (output === null && responseMetadata === null) {
7
+ return "pending";
8
+ }
9
+ return "success";
10
+ }
3
11
  export function useToolInfo() {
4
- const [status, setStatus] = useState("pending");
5
- const input = useOpenAiGlobal("toolInput");
6
- const output = useOpenAiGlobal("toolOutput") ?? undefined;
7
- const responseMetadata = useOpenAiGlobal("toolResponseMetadata") ?? undefined;
8
- useEffect(() => {
9
- setStatus(output === undefined && responseMetadata === undefined
10
- ? "pending"
11
- : "success");
12
- }, [output, responseMetadata]);
12
+ const input = useBridge("toolInput");
13
+ const output = useBridge("toolOutput");
14
+ const responseMetadata = useBridge("toolResponseMetadata");
15
+ const status = deriveStatus(input, output, responseMetadata);
13
16
  return {
14
17
  input,
15
18
  status,
19
+ isIdle: status === "idle",
16
20
  isPending: status === "pending",
17
21
  isSuccess: status === "success",
18
22
  output,
@@ -1 +1 @@
1
- {"version":3,"file":"use-tool-info.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-tool-info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAuC5C,MAAM,UAAU,WAAW;IACzB,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAwB,SAAS,CAAC,CAAC;IACvE,MAAM,KAAK,GAAG,eAAe,CAAC,WAAW,CAAE,CAAC;IAC5C,MAAM,MAAM,GAAG,eAAe,CAAC,YAAY,CAAC,IAAI,SAAS,CAAC;IAC1D,MAAM,gBAAgB,GAAG,eAAe,CAAC,sBAAsB,CAAC,IAAI,SAAS,CAAC;IAE9E,SAAS,CAAC,GAAG,EAAE;QACb,SAAS,CACP,MAAM,KAAK,SAAS,IAAI,gBAAgB,KAAK,SAAS;YACpD,CAAC,CAAC,SAAS;YACX,CAAC,CAAC,SAAS,CACd,CAAC;IACJ,CAAC,EAAE,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC,CAAC;IAM/B,OAAO;QACL,KAAK;QACL,MAAM;QACN,SAAS,EAAE,MAAM,KAAK,SAAS;QAC/B,SAAS,EAAE,MAAM,KAAK,SAAS;QAC/B,MAAM;QACN,gBAAgB;KACqB,CAAC;AAC1C,CAAC"}
1
+ {"version":3,"file":"use-tool-info.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-tool-info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAoDhD,SAAS,YAAY,CACnB,KAAqC,EACrC,MAAsC,EACtC,gBAAgD;IAEhD,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;QACnB,OAAO,MAAM,CAAC;IAChB,CAAC;IACD,IAAI,MAAM,KAAK,IAAI,IAAI,gBAAgB,KAAK,IAAI,EAAE,CAAC;QACjD,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,WAAW;IAGzB,MAAM,KAAK,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;IACrC,MAAM,MAAM,GAAG,SAAS,CAAC,YAAY,CAAC,CAAC;IACvC,MAAM,gBAAgB,GAAG,SAAS,CAAC,sBAAsB,CAAC,CAAC;IAE3D,MAAM,MAAM,GAAG,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,gBAAgB,CAAC,CAAC;IAM7D,OAAO;QACL,KAAK;QACL,MAAM;QACN,MAAM,EAAE,MAAM,KAAK,MAAM;QACzB,SAAS,EAAE,MAAM,KAAK,SAAS;QAC/B,SAAS,EAAE,MAAM,KAAK,SAAS;QAC/B,MAAM;QACN,gBAAgB;KACqB,CAAC;AAC1C,CAAC"}
@@ -1,5 +1,4 @@
1
1
  import { expectTypeOf, test } from "vitest";
2
- import { renderHook } from "@testing-library/react";
3
2
  import { useToolInfo } from "./use-tool-info.js";
4
3
  test("useToolInfo - TypeScript typing", () => {
5
4
  test("should have correct types when no generic parameter is provided", () => {
@@ -7,27 +6,46 @@ test("useToolInfo - TypeScript typing", () => {
7
6
  expectTypeOf(result.status);
8
7
  expectTypeOf(result.isPending);
9
8
  expectTypeOf(result.isSuccess);
9
+ expectTypeOf(result.isIdle);
10
10
  expectTypeOf(result.input);
11
11
  });
12
12
  test("should correctly type input, output, and responseMetadata with explicit ToolSignature", () => {
13
13
  const result = useToolInfo();
14
- expectTypeOf(result.input);
14
+ // When idle, input should be undefined
15
+ if (result.status === "idle") {
16
+ expectTypeOf(result.input);
17
+ expectTypeOf(result.output);
18
+ expectTypeOf(result.responseMetadata);
19
+ }
15
20
  // When pending, output and responseMetadata should be undefined
16
21
  if (result.status === "pending") {
22
+ expectTypeOf(result.input);
17
23
  expectTypeOf(result.output);
18
24
  expectTypeOf(result.responseMetadata);
19
25
  }
20
26
  // When success, output and responseMetadata should be defined
21
27
  if (result.status === "success") {
28
+ expectTypeOf(result.input);
22
29
  expectTypeOf(result.output);
23
30
  expectTypeOf(result.responseMetadata);
24
31
  }
25
32
  });
26
33
  test("should correctly narrow types based on status discriminated union", () => {
27
34
  const result = useToolInfo();
28
- // Test type narrowing
35
+ // Test type narrowing for idle
36
+ if (result.isIdle) {
37
+ expectTypeOf(result.status);
38
+ expectTypeOf(result.isIdle);
39
+ expectTypeOf(result.isPending);
40
+ expectTypeOf(result.isSuccess);
41
+ expectTypeOf(result.input);
42
+ expectTypeOf(result.output);
43
+ expectTypeOf(result.responseMetadata);
44
+ }
45
+ // Test type narrowing for pending
29
46
  if (result.isPending) {
30
47
  expectTypeOf(result.status);
48
+ expectTypeOf(result.isIdle);
31
49
  expectTypeOf(result.isPending);
32
50
  expectTypeOf(result.isSuccess);
33
51
  expectTypeOf(result.output);
@@ -35,13 +53,23 @@ test("useToolInfo - TypeScript typing", () => {
35
53
  }
36
54
  if (result.isSuccess) {
37
55
  expectTypeOf(result.status);
56
+ expectTypeOf(result.isIdle);
38
57
  expectTypeOf(result.isPending);
39
58
  expectTypeOf(result.isSuccess);
40
59
  expectTypeOf(result.output);
41
60
  expectTypeOf(result.responseMetadata);
42
61
  }
62
+ if (result.status === "idle") {
63
+ expectTypeOf(result.isIdle);
64
+ expectTypeOf(result.isPending);
65
+ expectTypeOf(result.isSuccess);
66
+ expectTypeOf(result.input);
67
+ expectTypeOf(result.output);
68
+ expectTypeOf(result.responseMetadata);
69
+ }
43
70
  if (result.status === "pending") {
44
71
  expectTypeOf(result.input);
72
+ expectTypeOf(result.isIdle);
45
73
  expectTypeOf(result.isPending);
46
74
  expectTypeOf(result.isSuccess);
47
75
  expectTypeOf(result.output);
@@ -49,6 +77,7 @@ test("useToolInfo - TypeScript typing", () => {
49
77
  }
50
78
  if (result.status === "success") {
51
79
  expectTypeOf(result.input);
80
+ expectTypeOf(result.isIdle);
52
81
  expectTypeOf(result.isPending);
53
82
  expectTypeOf(result.isSuccess);
54
83
  expectTypeOf(result.output);
@@ -57,7 +86,10 @@ test("useToolInfo - TypeScript typing", () => {
57
86
  });
58
87
  test("should handle partial ToolSignature with only input specified", () => {
59
88
  const result = useToolInfo();
60
- expectTypeOf(result.input);
89
+ // Input can be TestInput or undefined (when idle)
90
+ if (result.status === "pending" || result.status === "success") {
91
+ expectTypeOf(result.input);
92
+ }
61
93
  if (result.status === "success") {
62
94
  expectTypeOf(result.output);
63
95
  expectTypeOf(result.responseMetadata);
@@ -65,7 +97,10 @@ test("useToolInfo - TypeScript typing", () => {
65
97
  });
66
98
  test("should handle ToolSignature with only output specified", () => {
67
99
  const result = useToolInfo();
68
- expectTypeOf(result.input);
100
+ // Input can be Record<string, unknown> or undefined (when idle)
101
+ if (result.status === "pending" || result.status === "success") {
102
+ expectTypeOf(result.input);
103
+ }
69
104
  if (result.status === "success") {
70
105
  expectTypeOf(result.output);
71
106
  }
@@ -1 +1 @@
1
- {"version":3,"file":"use-tool-info.test-d.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-tool-info.test-d.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"use-tool-info.test-d.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-tool-info.test-d.ts"],"names":[],"mappings":"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"}
@@ -1,57 +1,128 @@
1
- import { fireEvent, renderHook, waitFor, act } from "@testing-library/react";
1
+ import { act, fireEvent, renderHook, waitFor } from "@testing-library/react";
2
2
  import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
3
- import { useToolInfo } from "./use-tool-info.js";
3
+ import { McpAppAdaptor } from "../bridges/adaptors/mcp-app-adaptor.js";
4
+ import { McpAppBridge } from "../bridges/mcp-app-bridge.js";
4
5
  import { SET_GLOBALS_EVENT_TYPE, SetGlobalsEvent, } from "../types.js";
6
+ import { fireToolInputNotification, fireToolResultNotification, getMcpAppHostPostMessageMock, } from "./test/utils.js";
7
+ import { useToolInfo } from "./use-tool-info.js";
5
8
  describe("useToolInfo", () => {
6
- let OpenaiMock;
7
- beforeEach(() => {
8
- OpenaiMock = {
9
- toolInput: { name: "pokemon", args: { name: "pikachu" } },
10
- toolOutput: null,
11
- toolResponseMetadata: null,
12
- };
13
- vi.stubGlobal("openai", OpenaiMock);
14
- });
15
- afterEach(() => {
16
- vi.unstubAllGlobals();
17
- vi.resetAllMocks();
18
- });
19
- it("should return toolInput on initial mount window.openai", () => {
20
- const { result } = renderHook(() => useToolInfo());
21
- expect(result.current).toMatchObject({
22
- input: { name: "pokemon", args: { name: "pikachu" } },
23
- status: "pending",
24
- isPending: true,
25
- isSuccess: false,
9
+ describe("apps-sdk host", () => {
10
+ let OpenaiMock;
11
+ beforeEach(() => {
12
+ OpenaiMock = {
13
+ toolInput: { name: "pokemon", args: { name: "pikachu" } },
14
+ toolOutput: null,
15
+ toolResponseMetadata: null,
16
+ };
17
+ vi.stubGlobal("openai", OpenaiMock);
18
+ vi.stubGlobal("skybridge", { hostType: "apps-sdk" });
26
19
  });
27
- });
28
- it("should eventually return tool output and response metadata once tool call completes", async () => {
29
- const toolOutput = {
30
- name: "pikachu",
31
- color: "yellow",
32
- description: "When several of these POKéMON gather, their\felectricity could build and cause lightning storms.",
33
- };
34
- const toolResponseMetadata = { id: 12 };
35
- const { result } = renderHook(() => useToolInfo());
36
- act(() => {
37
- OpenaiMock.toolOutput = toolOutput;
38
- OpenaiMock.toolResponseMetadata = toolResponseMetadata;
39
- fireEvent(window, new SetGlobalsEvent(SET_GLOBALS_EVENT_TYPE, {
40
- detail: {
41
- globals: {
42
- toolOutput,
43
- toolResponseMetadata,
44
- },
45
- },
46
- }));
20
+ afterEach(() => {
21
+ vi.unstubAllGlobals();
22
+ vi.resetAllMocks();
47
23
  });
48
- await waitFor(() => {
24
+ it("should return toolInput on initial mount window.openai", () => {
25
+ const { result } = renderHook(() => useToolInfo());
49
26
  expect(result.current).toMatchObject({
50
- status: "success",
51
- isPending: false,
52
- isSuccess: true,
53
- output: toolOutput,
54
- responseMetadata: toolResponseMetadata,
27
+ input: { name: "pokemon", args: { name: "pikachu" } },
28
+ status: "pending",
29
+ isIdle: false,
30
+ isPending: true,
31
+ isSuccess: false,
32
+ });
33
+ });
34
+ it("should eventually return tool output and response metadata once tool call completes", async () => {
35
+ const toolOutput = {
36
+ name: "pikachu",
37
+ color: "yellow",
38
+ description: "When several of these POKéMON gather, their\felectricity could build and cause lightning storms.",
39
+ };
40
+ const toolResponseMetadata = { id: 12 };
41
+ const { result } = renderHook(() => useToolInfo());
42
+ act(() => {
43
+ OpenaiMock.toolOutput = toolOutput;
44
+ OpenaiMock.toolResponseMetadata = toolResponseMetadata;
45
+ fireEvent(window, new SetGlobalsEvent(SET_GLOBALS_EVENT_TYPE, {
46
+ detail: {
47
+ globals: {
48
+ toolOutput,
49
+ toolResponseMetadata,
50
+ },
51
+ },
52
+ }));
53
+ });
54
+ await waitFor(() => {
55
+ expect(result.current).toMatchObject({
56
+ status: "success",
57
+ isIdle: false,
58
+ isPending: false,
59
+ isSuccess: true,
60
+ output: toolOutput,
61
+ responseMetadata: toolResponseMetadata,
62
+ });
63
+ });
64
+ });
65
+ });
66
+ describe("mcp-app host", () => {
67
+ beforeEach(() => {
68
+ vi.stubGlobal("parent", { postMessage: getMcpAppHostPostMessageMock() });
69
+ vi.stubGlobal("skybridge", { hostType: "mcp-app" });
70
+ });
71
+ afterEach(() => {
72
+ vi.unstubAllGlobals();
73
+ vi.resetAllMocks();
74
+ McpAppBridge.resetInstance();
75
+ McpAppAdaptor.resetInstance();
76
+ });
77
+ it("should return idle state initially when tool input is not yet set", async () => {
78
+ const { result } = renderHook(() => useToolInfo());
79
+ await waitFor(() => {
80
+ expect(result.current).toMatchObject({
81
+ status: "idle",
82
+ isIdle: true,
83
+ isPending: false,
84
+ isSuccess: false,
85
+ input: null,
86
+ output: null,
87
+ responseMetadata: null,
88
+ });
89
+ });
90
+ });
91
+ it("should return pending state with tool input from tool-input notification", async () => {
92
+ const { result } = renderHook(() => useToolInfo());
93
+ act(() => {
94
+ fireToolInputNotification({ name: "pokemon", query: "pikachu" });
95
+ });
96
+ await waitFor(() => {
97
+ expect(result.current).toMatchObject({
98
+ status: "pending",
99
+ isIdle: false,
100
+ isPending: true,
101
+ isSuccess: false,
102
+ input: { name: "pokemon", query: "pikachu" },
103
+ });
104
+ });
105
+ });
106
+ it("should return success state with output from tool-result notification", async () => {
107
+ const { result } = renderHook(() => useToolInfo());
108
+ act(() => {
109
+ fireToolInputNotification({ name: "pokemon", query: "pikachu" });
110
+ fireToolResultNotification({
111
+ content: [{ type: "text", text: "Pikachu data" }],
112
+ structuredContent: { name: "pikachu", color: "yellow" },
113
+ _meta: { requestId: "123" },
114
+ });
115
+ });
116
+ await waitFor(() => {
117
+ expect(result.current).toMatchObject({
118
+ status: "success",
119
+ isIdle: false,
120
+ isPending: false,
121
+ isSuccess: true,
122
+ input: { name: "pokemon", query: "pikachu" },
123
+ output: { name: "pikachu", color: "yellow" },
124
+ responseMetadata: { requestId: "123" },
125
+ });
55
126
  });
56
127
  });
57
128
  });
@@ -1 +1 @@
1
- {"version":3,"file":"use-tool-info.test.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-tool-info.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EACL,sBAAsB,EACtB,eAAe,GAEhB,MAAM,aAAa,CAAC;AAErB,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,IAAI,UAGH,CAAC;IAEF,UAAU,CAAC,GAAG,EAAE;QACd,UAAU,GAAG;YACX,SAAS,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE;YACzD,UAAU,EAAE,IAAI;YAChB,oBAAoB,EAAE,IAAI;SAC3B,CAAC;QACF,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,EAAE,CAAC,gBAAgB,EAAE,CAAC;QACtB,EAAE,CAAC,aAAa,EAAE,CAAC;IACrB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wDAAwD,EAAE,GAAG,EAAE;QAChE,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;QAEnD,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC;YACnC,KAAK,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE;YACrD,MAAM,EAAE,SAAS;YACjB,SAAS,EAAE,IAAI;YACf,SAAS,EAAE,KAAK;SACjB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qFAAqF,EAAE,KAAK,IAAI,EAAE;QACnG,MAAM,UAAU,GAAG;YACjB,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,QAAQ;YACf,WAAW,EACT,kGAAkG;SACrG,CAAC;QACF,MAAM,oBAAoB,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;QACxC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;QAEnD,GAAG,CAAC,GAAG,EAAE;YACP,UAAU,CAAC,UAAU,GAAG,UAAU,CAAC;YACnC,UAAU,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;YACvD,SAAS,CACP,MAAM,EACN,IAAI,eAAe,CAAC,sBAAsB,EAAE;gBAC1C,MAAM,EAAE;oBACN,OAAO,EAAE;wBACP,UAAU;wBACV,oBAAoB;qBACrB;iBACF;aACF,CAAC,CACH,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,MAAM,OAAO,CAAC,GAAG,EAAE;YACjB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC;gBACnC,MAAM,EAAE,SAAS;gBACjB,SAAS,EAAE,KAAK;gBAChB,SAAS,EAAE,IAAI;gBACf,MAAM,EAAE,UAAU;gBAClB,gBAAgB,EAAE,oBAAoB;aACvC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"use-tool-info.test.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-tool-info.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAEL,sBAAsB,EACtB,eAAe,GAChB,MAAM,aAAa,CAAC;AACrB,OAAO,EACL,yBAAyB,EACzB,0BAA0B,EAC1B,4BAA4B,GAC7B,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;QAC7B,IAAI,UAGH,CAAC;QAEF,UAAU,CAAC,GAAG,EAAE;YACd,UAAU,GAAG;gBACX,SAAS,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE;gBACzD,UAAU,EAAE,IAAI;gBAChB,oBAAoB,EAAE,IAAI;aAC3B,CAAC;YACF,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YACpC,EAAE,CAAC,UAAU,CAAC,WAAW,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,GAAG,EAAE;YACb,EAAE,CAAC,gBAAgB,EAAE,CAAC;YACtB,EAAE,CAAC,aAAa,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wDAAwD,EAAE,GAAG,EAAE;YAChE,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;YAEnD,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC;gBACnC,KAAK,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE;gBACrD,MAAM,EAAE,SAAS;gBACjB,MAAM,EAAE,KAAK;gBACb,SAAS,EAAE,IAAI;gBACf,SAAS,EAAE,KAAK;aACjB,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qFAAqF,EAAE,KAAK,IAAI,EAAE;YACnG,MAAM,UAAU,GAAG;gBACjB,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE,QAAQ;gBACf,WAAW,EACT,kGAAkG;aACrG,CAAC;YACF,MAAM,oBAAoB,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;YACxC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;YAEnD,GAAG,CAAC,GAAG,EAAE;gBACP,UAAU,CAAC,UAAU,GAAG,UAAU,CAAC;gBACnC,UAAU,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;gBACvD,SAAS,CACP,MAAM,EACN,IAAI,eAAe,CAAC,sBAAsB,EAAE;oBAC1C,MAAM,EAAE;wBACN,OAAO,EAAE;4BACP,UAAU;4BACV,oBAAoB;yBACrB;qBACF;iBACF,CAAC,CACH,CAAC;YACJ,CAAC,CAAC,CAAC;YAEH,MAAM,OAAO,CAAC,GAAG,EAAE;gBACjB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC;oBACnC,MAAM,EAAE,SAAS;oBACjB,MAAM,EAAE,KAAK;oBACb,SAAS,EAAE,KAAK;oBAChB,SAAS,EAAE,IAAI;oBACf,MAAM,EAAE,UAAU;oBAClB,gBAAgB,EAAE,oBAAoB;iBACvC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;QAC5B,UAAU,CAAC,GAAG,EAAE;YACd,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,EAAE,WAAW,EAAE,4BAA4B,EAAE,EAAE,CAAC,CAAC;YACzE,EAAE,CAAC,UAAU,CAAC,WAAW,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,GAAG,EAAE;YACb,EAAE,CAAC,gBAAgB,EAAE,CAAC;YACtB,EAAE,CAAC,aAAa,EAAE,CAAC;YACnB,YAAY,CAAC,aAAa,EAAE,CAAC;YAC7B,aAAa,CAAC,aAAa,EAAE,CAAC;QAChC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mEAAmE,EAAE,KAAK,IAAI,EAAE;YACjF,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;YAEnD,MAAM,OAAO,CAAC,GAAG,EAAE;gBACjB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC;oBACnC,MAAM,EAAE,MAAM;oBACd,MAAM,EAAE,IAAI;oBACZ,SAAS,EAAE,KAAK;oBAChB,SAAS,EAAE,KAAK;oBAChB,KAAK,EAAE,IAAI;oBACX,MAAM,EAAE,IAAI;oBACZ,gBAAgB,EAAE,IAAI;iBACvB,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0EAA0E,EAAE,KAAK,IAAI,EAAE;YACxF,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;YAEnD,GAAG,CAAC,GAAG,EAAE;gBACP,yBAAyB,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;YACnE,CAAC,CAAC,CAAC;YAEH,MAAM,OAAO,CAAC,GAAG,EAAE;gBACjB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC;oBACnC,MAAM,EAAE,SAAS;oBACjB,MAAM,EAAE,KAAK;oBACb,SAAS,EAAE,IAAI;oBACf,SAAS,EAAE,KAAK;oBAChB,KAAK,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;iBAC7C,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uEAAuE,EAAE,KAAK,IAAI,EAAE;YACrF,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;YAEnD,GAAG,CAAC,GAAG,EAAE;gBACP,yBAAyB,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;gBACjE,0BAA0B,CAAC;oBACzB,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,cAAc,EAAE,CAAC;oBACjD,iBAAiB,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE;oBACvD,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;iBAC5B,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,MAAM,OAAO,CAAC,GAAG,EAAE;gBACjB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC;oBACnC,MAAM,EAAE,SAAS;oBACjB,MAAM,EAAE,KAAK;oBACb,SAAS,EAAE,KAAK;oBAChB,SAAS,EAAE,IAAI;oBACf,KAAK,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE;oBAC5C,MAAM,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE;oBAC5C,gBAAgB,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;iBACvC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,18 @@
1
+ import type { UserAgent } from "../types.js";
2
+ export type UserState = {
3
+ locale: string;
4
+ userAgent: UserAgent;
5
+ };
6
+ /**
7
+ * Hook for accessing session-stable user information.
8
+ * These values are set once at initialization and do not change during the session.
9
+ *
10
+ * @example
11
+ * ```tsx
12
+ * const { locale, userAgent } = useUser();
13
+ *
14
+ * // Access device type
15
+ * const isMobile = userAgent.device.type === "mobile";
16
+ * ```
17
+ */
18
+ export declare function useUser(): UserState;
@@ -0,0 +1,19 @@
1
+ import { useBridge } from "../bridges/index.js";
2
+ /**
3
+ * Hook for accessing session-stable user information.
4
+ * These values are set once at initialization and do not change during the session.
5
+ *
6
+ * @example
7
+ * ```tsx
8
+ * const { locale, userAgent } = useUser();
9
+ *
10
+ * // Access device type
11
+ * const isMobile = userAgent.device.type === "mobile";
12
+ * ```
13
+ */
14
+ export function useUser() {
15
+ const locale = useBridge("locale");
16
+ const userAgent = useBridge("userAgent");
17
+ return { locale, userAgent };
18
+ }
19
+ //# sourceMappingURL=use-user.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-user.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-user.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAQhD;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,OAAO;IACrB,MAAM,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;IACnC,MAAM,SAAS,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;IAEzC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;AAC/B,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,93 @@
1
+ import { renderHook, waitFor } from "@testing-library/react";
2
+ import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
3
+ import { McpAppAdaptor } from "../bridges/adaptors/mcp-app-adaptor.js";
4
+ import { McpAppBridge } from "../bridges/mcp-app-bridge.js";
5
+ import { getMcpAppHostPostMessageMock } from "./test/utils.js";
6
+ import { useUser } from "./use-user.js";
7
+ describe("useUser", () => {
8
+ describe("apps-sdk host type", () => {
9
+ let OpenaiMock;
10
+ beforeEach(() => {
11
+ OpenaiMock = {
12
+ locale: "en-US",
13
+ userAgent: {
14
+ device: { type: "desktop" },
15
+ capabilities: { hover: true, touch: false },
16
+ },
17
+ };
18
+ vi.stubGlobal("openai", OpenaiMock);
19
+ vi.stubGlobal("skybridge", { hostType: "apps-sdk" });
20
+ });
21
+ afterEach(() => {
22
+ vi.unstubAllGlobals();
23
+ vi.resetAllMocks();
24
+ });
25
+ it("should return locale and userAgent from window.openai", () => {
26
+ const { result } = renderHook(() => useUser());
27
+ expect(result.current.locale).toBe("en-US");
28
+ expect(result.current.userAgent).toEqual({
29
+ device: { type: "desktop" },
30
+ capabilities: { hover: true, touch: false },
31
+ });
32
+ });
33
+ it("should return mobile userAgent when set to mobile", () => {
34
+ OpenaiMock.userAgent = {
35
+ device: { type: "mobile" },
36
+ capabilities: { hover: false, touch: true },
37
+ };
38
+ const { result } = renderHook(() => useUser());
39
+ expect(result.current.userAgent.device.type).toBe("mobile");
40
+ expect(result.current.userAgent.capabilities.touch).toBe(true);
41
+ });
42
+ it("should return different locale when set", () => {
43
+ OpenaiMock.locale = "es-ES";
44
+ const { result } = renderHook(() => useUser());
45
+ expect(result.current.locale).toBe("es-ES");
46
+ });
47
+ });
48
+ describe("mcp-app host type", () => {
49
+ beforeEach(() => {
50
+ vi.stubGlobal("skybridge", { hostType: "mcp-app" });
51
+ });
52
+ afterEach(() => {
53
+ vi.unstubAllGlobals();
54
+ vi.resetAllMocks();
55
+ McpAppBridge.resetInstance();
56
+ McpAppAdaptor.resetInstance();
57
+ });
58
+ it("should return locale and userAgent from mcp host context", async () => {
59
+ vi.stubGlobal("parent", {
60
+ postMessage: getMcpAppHostPostMessageMock({
61
+ locale: "fr-FR",
62
+ platform: "web",
63
+ deviceCapabilities: { hover: true, touch: false },
64
+ }),
65
+ });
66
+ const { result } = renderHook(() => useUser());
67
+ await waitFor(() => {
68
+ expect(result.current.locale).toBe("fr-FR");
69
+ expect(result.current.userAgent).toEqual({
70
+ device: { type: "desktop" },
71
+ capabilities: { hover: true, touch: false },
72
+ });
73
+ });
74
+ });
75
+ it("should maintain userAgent referential stability when data has not changed", async () => {
76
+ vi.stubGlobal("parent", {
77
+ postMessage: getMcpAppHostPostMessageMock({
78
+ locale: "en-US",
79
+ platform: "web",
80
+ deviceCapabilities: { hover: true, touch: false },
81
+ }),
82
+ });
83
+ const { result, rerender } = renderHook(() => useUser());
84
+ await waitFor(() => {
85
+ expect(result.current.userAgent).toBeDefined();
86
+ });
87
+ const initialUserAgent = result.current.userAgent;
88
+ rerender();
89
+ expect(result.current.userAgent).toBe(initialUserAgent);
90
+ });
91
+ });
92
+ });
93
+ //# sourceMappingURL=use-user.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-user.test.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-user.test.ts"],"names":[],"mappings":"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"}
@@ -1,37 +1,15 @@
1
1
  import { useCallback, useEffect, useState } from "react";
2
- import { useOpenAiGlobal } from "./use-openai-global.js";
3
- const WIDGET_CONTEXT_KEY = "__widget_context";
4
- function filterWidgetContext(state) {
5
- if (state === null) {
6
- return null;
7
- }
8
- const { [WIDGET_CONTEXT_KEY]: _, ...filteredState } = state;
9
- return filteredState;
10
- }
11
- function preserveWidgetContext(newState) {
12
- if (newState === null) {
13
- return null;
14
- }
15
- const currentWindowState = window.openai?.widgetState;
16
- if (currentWindowState !== null &&
17
- currentWindowState !== undefined &&
18
- WIDGET_CONTEXT_KEY in currentWindowState) {
19
- return {
20
- ...newState,
21
- [WIDGET_CONTEXT_KEY]: currentWindowState[WIDGET_CONTEXT_KEY],
22
- };
23
- }
24
- return newState;
25
- }
2
+ import { useAppsSdkBridge } from "../bridges/index.js";
3
+ import { filterWidgetContext, injectWidgetContext } from "../helpers/state.js";
26
4
  export function useWidgetState(defaultState) {
27
- const widgetStateFromWindow = useOpenAiGlobal("widgetState");
5
+ const widgetStateFromWindow = useAppsSdkBridge("widgetState");
28
6
  const [widgetState, _setWidgetState] = useState(() => {
29
7
  if (widgetStateFromWindow !== null) {
30
8
  return filterWidgetContext(widgetStateFromWindow);
31
9
  }
32
10
  return typeof defaultState === "function"
33
11
  ? defaultState()
34
- : defaultState ?? null;
12
+ : (defaultState ?? null);
35
13
  });
36
14
  useEffect(() => {
37
15
  // Fixes openai implementation bug
@@ -42,7 +20,7 @@ export function useWidgetState(defaultState) {
42
20
  const setWidgetState = useCallback((state) => {
43
21
  _setWidgetState((prevState) => {
44
22
  const newState = typeof state === "function" ? state(prevState) : state;
45
- const stateToSet = preserveWidgetContext(newState);
23
+ const stateToSet = injectWidgetContext(newState);
46
24
  if (stateToSet !== null) {
47
25
  window.openai.setWidgetState(stateToSet);
48
26
  }
@@ -1 +1 @@
1
- {"version":3,"file":"use-widget-state.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-widget-state.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAuB,MAAM,OAAO,CAAC;AAE9E,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,MAAM,kBAAkB,GAAG,kBAA2B,CAAC;AAEvD,SAAS,mBAAmB,CAC1B,KAAgB;IAEhB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;QACnB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,EAAE,CAAC,kBAAkB,CAAC,EAAE,CAAC,EAAE,GAAG,aAAa,EAAE,GAAG,KAErD,CAAC;IAEF,OAAO,aAAkB,CAAC;AAC5B,CAAC;AAED,SAAS,qBAAqB,CAC5B,QAAkB;IAElB,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;QACtB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,kBAAkB,GAAG,MAAM,CAAC,MAAM,EAAE,WAG7B,CAAC;IAEd,IACE,kBAAkB,KAAK,IAAI;QAC3B,kBAAkB,KAAK,SAAS;QAChC,kBAAkB,IAAI,kBAAkB,EACxC,CAAC;QACD,OAAO;YACL,GAAG,QAAQ;YACX,CAAC,kBAAkB,CAAC,EAAE,kBAAkB,CAAC,kBAAkB,CAAC;SACxD,CAAC;IACT,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAQD,MAAM,UAAU,cAAc,CAC5B,YAA0C;IAE1C,MAAM,qBAAqB,GAAG,eAAe,CAAC,aAAa,CAAa,CAAC;IAEzE,MAAM,CAAC,WAAW,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAW,GAAG,EAAE;QAC7D,IAAI,qBAAqB,KAAK,IAAI,EAAE,CAAC;YACnC,OAAO,mBAAmB,CAAC,qBAAqB,CAAC,CAAC;QACpD,CAAC;QAED,OAAO,OAAO,YAAY,KAAK,UAAU;YACvC,CAAC,CAAC,YAAY,EAAE;YAChB,CAAC,CAAC,YAAY,IAAI,IAAI,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,kCAAkC;QAClC,IAAI,qBAAqB,KAAK,IAAI,EAAE,CAAC;YACnC,eAAe,CAAC,mBAAmB,CAAC,qBAAqB,CAAC,CAAC,CAAC;QAC9D,CAAC;IACH,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC;IAE5B,MAAM,cAAc,GAAG,WAAW,CAAC,CAAC,KAA+B,EAAE,EAAE;QACrE,eAAe,CAAC,CAAC,SAAS,EAAE,EAAE;YAC5B,MAAM,QAAQ,GAAG,OAAO,KAAK,KAAK,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YACxE,MAAM,UAAU,GAAG,qBAAqB,CAAC,QAAQ,CAAC,CAAC;YAEnD,IAAI,UAAU,KAAK,IAAI,EAAE,CAAC;gBACxB,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;YAC3C,CAAC;YAED,OAAO,mBAAmB,CAAC,UAAU,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CAAC,WAAW,EAAE,cAAc,CAAU,CAAC;AAChD,CAAC"}
1
+ {"version":3,"file":"use-widget-state.js","sourceRoot":"","sources":["../../../../src/web/hooks/use-widget-state.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuB,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC9E,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAS/E,MAAM,UAAU,cAAc,CAC5B,YAA0C;IAE1C,MAAM,qBAAqB,GAAG,gBAAgB,CAAC,aAAa,CAAa,CAAC;IAE1E,MAAM,CAAC,WAAW,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAW,GAAG,EAAE;QAC7D,IAAI,qBAAqB,KAAK,IAAI,EAAE,CAAC;YACnC,OAAO,mBAAmB,CAAC,qBAAqB,CAAC,CAAC;QACpD,CAAC;QAED,OAAO,OAAO,YAAY,KAAK,UAAU;YACvC,CAAC,CAAC,YAAY,EAAE;YAChB,CAAC,CAAC,CAAC,YAAY,IAAI,IAAI,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,kCAAkC;QAClC,IAAI,qBAAqB,KAAK,IAAI,EAAE,CAAC;YACnC,eAAe,CAAC,mBAAmB,CAAC,qBAAqB,CAAC,CAAC,CAAC;QAC9D,CAAC;IACH,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC;IAE5B,MAAM,cAAc,GAAG,WAAW,CAAC,CAAC,KAA+B,EAAE,EAAE;QACrE,eAAe,CAAC,CAAC,SAAS,EAAE,EAAE;YAC5B,MAAM,QAAQ,GAAG,OAAO,KAAK,KAAK,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YACxE,MAAM,UAAU,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;YAEjD,IAAI,UAAU,KAAK,IAAI,EAAE,CAAC;gBACxB,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;YAC3C,CAAC;YAED,OAAO,mBAAmB,CAAC,UAAU,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CAAC,WAAW,EAAE,cAAc,CAAU,CAAC;AAChD,CAAC"}