skybridge 0.0.0-dev.da10bf6 → 0.0.0-dev.dbd3f0e

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 (290) hide show
  1. package/bin/run.js +9 -0
  2. package/dist/cli/header.d.ts +4 -0
  3. package/dist/cli/header.js +6 -0
  4. package/dist/cli/header.js.map +1 -0
  5. package/dist/cli/run-command.d.ts +2 -0
  6. package/dist/cli/run-command.js +43 -0
  7. package/dist/cli/run-command.js.map +1 -0
  8. package/dist/cli/use-execute-steps.d.ts +10 -0
  9. package/dist/cli/use-execute-steps.js +31 -0
  10. package/dist/cli/use-execute-steps.js.map +1 -0
  11. package/dist/commands/build.d.ts +9 -0
  12. package/dist/commands/build.js +44 -0
  13. package/dist/commands/build.js.map +1 -0
  14. package/dist/commands/dev.d.ts +7 -0
  15. package/dist/commands/dev.js +20 -0
  16. package/dist/commands/dev.js.map +1 -0
  17. package/dist/commands/start.d.ts +7 -0
  18. package/dist/commands/start.js +33 -0
  19. package/dist/commands/start.js.map +1 -0
  20. package/dist/{src/server → server}/index.d.ts +1 -2
  21. package/dist/{src/server → server}/index.js +0 -1
  22. package/dist/server/index.js.map +1 -0
  23. package/dist/server/inferUtilityTypes.js.map +1 -0
  24. package/dist/{src/server → server}/server.d.ts +46 -11
  25. package/dist/server/server.js +138 -0
  26. package/dist/server/server.js.map +1 -0
  27. package/dist/{src/server → server}/templateHelper.d.ts +3 -0
  28. package/dist/server/templateHelper.js.map +1 -0
  29. package/dist/server/templates/development.hbs +66 -0
  30. package/dist/{src/server → server}/templates/production.hbs +1 -0
  31. package/dist/{src/server → server}/widgetsDevServer.d.ts +2 -2
  32. package/dist/{src/server → server}/widgetsDevServer.js +11 -3
  33. package/dist/server/widgetsDevServer.js.map +1 -0
  34. package/dist/{src/test → test}/utils.d.ts +11 -0
  35. package/dist/{src/test → test}/utils.js +20 -0
  36. package/dist/test/utils.js.map +1 -0
  37. package/dist/test/widget.test.js +255 -0
  38. package/dist/test/widget.test.js.map +1 -0
  39. package/dist/web/bridges/apps-sdk/adaptor.d.ts +14 -0
  40. package/dist/web/bridges/apps-sdk/adaptor.js +39 -0
  41. package/dist/web/bridges/apps-sdk/adaptor.js.map +1 -0
  42. package/dist/web/bridges/apps-sdk/bridge.d.ts +10 -0
  43. package/dist/web/bridges/apps-sdk/bridge.js +46 -0
  44. package/dist/web/bridges/apps-sdk/bridge.js.map +1 -0
  45. package/dist/web/bridges/apps-sdk/index.d.ts +5 -0
  46. package/dist/web/bridges/apps-sdk/index.js +5 -0
  47. package/dist/web/bridges/apps-sdk/index.js.map +1 -0
  48. package/dist/{src/web → web/bridges/apps-sdk}/types.d.ts +28 -40
  49. package/dist/{src/web → web/bridges/apps-sdk}/types.js +0 -1
  50. package/dist/web/bridges/apps-sdk/types.js.map +1 -0
  51. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.d.ts +2 -0
  52. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.js +7 -0
  53. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.js.map +1 -0
  54. package/dist/web/bridges/get-adaptor.d.ts +2 -0
  55. package/dist/web/bridges/get-adaptor.js +8 -0
  56. package/dist/web/bridges/get-adaptor.js.map +1 -0
  57. package/dist/web/bridges/index.d.ts +5 -0
  58. package/dist/web/bridges/index.js +6 -0
  59. package/dist/web/bridges/index.js.map +1 -0
  60. package/dist/web/bridges/mcp-app/adaptor.d.ts +19 -0
  61. package/dist/web/bridges/mcp-app/adaptor.js +145 -0
  62. package/dist/web/bridges/mcp-app/adaptor.js.map +1 -0
  63. package/dist/web/bridges/mcp-app/bridge.d.ts +43 -0
  64. package/dist/web/bridges/mcp-app/bridge.js +255 -0
  65. package/dist/web/bridges/mcp-app/bridge.js.map +1 -0
  66. package/dist/web/bridges/mcp-app/index.d.ts +4 -0
  67. package/dist/web/bridges/mcp-app/index.js +4 -0
  68. package/dist/web/bridges/mcp-app/index.js.map +1 -0
  69. package/dist/web/bridges/mcp-app/types.d.ts +8 -0
  70. package/dist/web/bridges/mcp-app/types.js +2 -0
  71. package/dist/web/bridges/mcp-app/types.js.map +1 -0
  72. package/dist/web/bridges/mcp-app/use-mcp-app-context.d.ts +5 -0
  73. package/dist/web/bridges/mcp-app/use-mcp-app-context.js +7 -0
  74. package/dist/web/bridges/mcp-app/use-mcp-app-context.js.map +1 -0
  75. package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js +60 -0
  76. package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js.map +1 -0
  77. package/dist/web/bridges/types.d.ts +74 -0
  78. package/dist/web/bridges/types.js +2 -0
  79. package/dist/web/bridges/types.js.map +1 -0
  80. package/dist/web/bridges/use-host-context.d.ts +2 -0
  81. package/dist/web/bridges/use-host-context.js +8 -0
  82. package/dist/web/bridges/use-host-context.js.map +1 -0
  83. package/dist/{src/web → web}/create-store.js +6 -7
  84. package/dist/web/create-store.js.map +1 -0
  85. package/dist/web/create-store.test.js +126 -0
  86. package/dist/web/create-store.test.js.map +1 -0
  87. package/dist/{src/web → web}/data-llm.js +9 -5
  88. package/dist/web/data-llm.js.map +1 -0
  89. package/dist/web/data-llm.test.js +139 -0
  90. package/dist/web/data-llm.test.js.map +1 -0
  91. package/dist/{src/web → web}/generate-helpers.d.ts +2 -1
  92. package/dist/web/generate-helpers.js.map +1 -0
  93. package/dist/{src/web → web}/generate-helpers.test-d.js +31 -2
  94. package/dist/web/generate-helpers.test-d.js.map +1 -0
  95. package/dist/web/generate-helpers.test.js.map +1 -0
  96. package/dist/{src/web → web}/helpers/state.js +13 -8
  97. package/dist/web/helpers/state.js.map +1 -0
  98. package/dist/web/helpers/state.test.js.map +1 -0
  99. package/dist/{src/web → web}/hooks/index.d.ts +2 -4
  100. package/dist/{src/web → web}/hooks/index.js +2 -4
  101. package/dist/web/hooks/index.js.map +1 -0
  102. package/dist/web/hooks/test/utils.d.ts +16 -0
  103. package/dist/web/hooks/test/utils.js +60 -0
  104. package/dist/web/hooks/test/utils.js.map +1 -0
  105. package/dist/{src/web → web}/hooks/use-call-tool.d.ts +2 -1
  106. package/dist/{src/web → web}/hooks/use-call-tool.js +12 -4
  107. package/dist/web/hooks/use-call-tool.js.map +1 -0
  108. package/dist/web/hooks/use-call-tool.test-d.js.map +1 -0
  109. package/dist/{src/web → web}/hooks/use-call-tool.test.js +26 -1
  110. package/dist/web/hooks/use-call-tool.test.js.map +1 -0
  111. package/dist/{src/web → web}/hooks/use-display-mode.d.ts +1 -1
  112. package/dist/web/hooks/use-display-mode.js +9 -0
  113. package/dist/web/hooks/use-display-mode.js.map +1 -0
  114. package/dist/{src/web → web}/hooks/use-display-mode.test.js +1 -0
  115. package/dist/web/hooks/use-display-mode.test.js.map +1 -0
  116. package/dist/{src/web → web}/hooks/use-files.d.ts +1 -1
  117. package/dist/web/hooks/use-files.js +7 -0
  118. package/dist/web/hooks/use-files.js.map +1 -0
  119. package/dist/{src/web → web}/hooks/use-files.test.js +4 -4
  120. package/dist/web/hooks/use-files.test.js.map +1 -0
  121. package/dist/web/hooks/use-layout.d.ts +22 -0
  122. package/dist/web/hooks/use-layout.js +23 -0
  123. package/dist/web/hooks/use-layout.js.map +1 -0
  124. package/dist/web/hooks/use-layout.test.js +96 -0
  125. package/dist/web/hooks/use-layout.test.js.map +1 -0
  126. package/dist/web/hooks/use-open-external.js +8 -0
  127. package/dist/web/hooks/use-open-external.js.map +1 -0
  128. package/dist/web/hooks/use-open-external.test.js +50 -0
  129. package/dist/web/hooks/use-open-external.test.js.map +1 -0
  130. package/dist/web/hooks/use-request-modal.d.ts +9 -0
  131. package/dist/web/hooks/use-request-modal.js +14 -0
  132. package/dist/web/hooks/use-request-modal.js.map +1 -0
  133. package/dist/web/hooks/use-request-modal.test.js +57 -0
  134. package/dist/web/hooks/use-request-modal.test.js.map +1 -0
  135. package/dist/web/hooks/use-send-follow-up-message.js +8 -0
  136. package/dist/web/hooks/use-send-follow-up-message.js.map +1 -0
  137. package/dist/{src/web → web}/hooks/use-tool-info.d.ts +12 -1
  138. package/dist/web/hooks/use-tool-info.js +26 -0
  139. package/dist/web/hooks/use-tool-info.js.map +1 -0
  140. package/dist/{src/web → web}/hooks/use-tool-info.test-d.js +40 -4
  141. package/dist/web/hooks/use-tool-info.test-d.js.map +1 -0
  142. package/dist/web/hooks/use-tool-info.test.js +130 -0
  143. package/dist/web/hooks/use-tool-info.test.js.map +1 -0
  144. package/dist/web/hooks/use-user.d.ts +18 -0
  145. package/dist/web/hooks/use-user.js +19 -0
  146. package/dist/web/hooks/use-user.js.map +1 -0
  147. package/dist/web/hooks/use-user.test.js +94 -0
  148. package/dist/web/hooks/use-user.test.js.map +1 -0
  149. package/dist/{src/web → web}/hooks/use-widget-state.js +10 -10
  150. package/dist/web/hooks/use-widget-state.js.map +1 -0
  151. package/dist/{src/web → web}/hooks/use-widget-state.test.js +1 -0
  152. package/dist/web/hooks/use-widget-state.test.js.map +1 -0
  153. package/dist/{src/web → web}/index.d.ts +1 -0
  154. package/dist/{src/web → web}/index.js +1 -0
  155. package/dist/web/index.js.map +1 -0
  156. package/dist/web/mount-widget.js.map +1 -0
  157. package/dist/web/plugin/data-llm.test.js.map +1 -0
  158. package/dist/web/plugin/plugin.js.map +1 -0
  159. package/dist/{src/web → web}/plugin/transform-data-llm.js +6 -3
  160. package/dist/web/plugin/transform-data-llm.js.map +1 -0
  161. package/dist/web/plugin/transform-data-llm.test.js.map +1 -0
  162. package/dist/{src/web → web}/proxy.js +5 -0
  163. package/dist/web/proxy.js.map +1 -0
  164. package/dist/web/types.d.ts +16 -0
  165. package/dist/web/types.js +2 -0
  166. package/dist/web/types.js.map +1 -0
  167. package/package.json +49 -33
  168. package/README.md +0 -123
  169. package/dist/src/server/devtoolsStaticServer.d.ts +0 -15
  170. package/dist/src/server/devtoolsStaticServer.js +0 -38
  171. package/dist/src/server/devtoolsStaticServer.js.map +0 -1
  172. package/dist/src/server/index.js.map +0 -1
  173. package/dist/src/server/inferUtilityTypes.js.map +0 -1
  174. package/dist/src/server/server.js +0 -71
  175. package/dist/src/server/server.js.map +0 -1
  176. package/dist/src/server/templateHelper.js.map +0 -1
  177. package/dist/src/server/templates/development.hbs +0 -12
  178. package/dist/src/server/widgetsDevServer.js.map +0 -1
  179. package/dist/src/test/utils.js.map +0 -1
  180. package/dist/src/test/widget.test.js +0 -112
  181. package/dist/src/test/widget.test.js.map +0 -1
  182. package/dist/src/web/create-store.js.map +0 -1
  183. package/dist/src/web/create-store.test.js +0 -70
  184. package/dist/src/web/create-store.test.js.map +0 -1
  185. package/dist/src/web/data-llm.js.map +0 -1
  186. package/dist/src/web/data-llm.test.js +0 -76
  187. package/dist/src/web/data-llm.test.js.map +0 -1
  188. package/dist/src/web/generate-helpers.js.map +0 -1
  189. package/dist/src/web/generate-helpers.test-d.js.map +0 -1
  190. package/dist/src/web/generate-helpers.test.js.map +0 -1
  191. package/dist/src/web/helpers/state.js.map +0 -1
  192. package/dist/src/web/helpers/state.test.js.map +0 -1
  193. package/dist/src/web/hooks/index.js.map +0 -1
  194. package/dist/src/web/hooks/use-call-tool.js.map +0 -1
  195. package/dist/src/web/hooks/use-call-tool.test-d.js.map +0 -1
  196. package/dist/src/web/hooks/use-call-tool.test.js.map +0 -1
  197. package/dist/src/web/hooks/use-display-mode.js +0 -7
  198. package/dist/src/web/hooks/use-display-mode.js.map +0 -1
  199. package/dist/src/web/hooks/use-display-mode.test.js.map +0 -1
  200. package/dist/src/web/hooks/use-files.js +0 -7
  201. package/dist/src/web/hooks/use-files.js.map +0 -1
  202. package/dist/src/web/hooks/use-files.test.js.map +0 -1
  203. package/dist/src/web/hooks/use-locale.d.ts +0 -1
  204. package/dist/src/web/hooks/use-locale.js +0 -5
  205. package/dist/src/web/hooks/use-locale.js.map +0 -1
  206. package/dist/src/web/hooks/use-locale.test.js +0 -21
  207. package/dist/src/web/hooks/use-locale.test.js.map +0 -1
  208. package/dist/src/web/hooks/use-open-external.js +0 -6
  209. package/dist/src/web/hooks/use-open-external.js.map +0 -1
  210. package/dist/src/web/hooks/use-open-external.test.js +0 -24
  211. package/dist/src/web/hooks/use-open-external.test.js.map +0 -1
  212. package/dist/src/web/hooks/use-openai-global.d.ts +0 -2
  213. package/dist/src/web/hooks/use-openai-global.js +0 -25
  214. package/dist/src/web/hooks/use-openai-global.js.map +0 -1
  215. package/dist/src/web/hooks/use-request-modal.d.ts +0 -6
  216. package/dist/src/web/hooks/use-request-modal.js +0 -9
  217. package/dist/src/web/hooks/use-request-modal.js.map +0 -1
  218. package/dist/src/web/hooks/use-request-modal.test.js +0 -24
  219. package/dist/src/web/hooks/use-request-modal.test.js.map +0 -1
  220. package/dist/src/web/hooks/use-send-follow-up-message.js +0 -11
  221. package/dist/src/web/hooks/use-send-follow-up-message.js.map +0 -1
  222. package/dist/src/web/hooks/use-theme.d.ts +0 -1
  223. package/dist/src/web/hooks/use-theme.js +0 -5
  224. package/dist/src/web/hooks/use-theme.js.map +0 -1
  225. package/dist/src/web/hooks/use-theme.test.js +0 -26
  226. package/dist/src/web/hooks/use-theme.test.js.map +0 -1
  227. package/dist/src/web/hooks/use-tool-info.js +0 -20
  228. package/dist/src/web/hooks/use-tool-info.js.map +0 -1
  229. package/dist/src/web/hooks/use-tool-info.test-d.js.map +0 -1
  230. package/dist/src/web/hooks/use-tool-info.test.js +0 -59
  231. package/dist/src/web/hooks/use-tool-info.test.js.map +0 -1
  232. package/dist/src/web/hooks/use-user-agent.d.ts +0 -1
  233. package/dist/src/web/hooks/use-user-agent.js +0 -5
  234. package/dist/src/web/hooks/use-user-agent.js.map +0 -1
  235. package/dist/src/web/hooks/use-user-agent.test.js +0 -31
  236. package/dist/src/web/hooks/use-user-agent.test.js.map +0 -1
  237. package/dist/src/web/hooks/use-widget-state.js.map +0 -1
  238. package/dist/src/web/hooks/use-widget-state.test.js.map +0 -1
  239. package/dist/src/web/index.js.map +0 -1
  240. package/dist/src/web/mount-widget.js.map +0 -1
  241. package/dist/src/web/plugin/data-llm.test.js.map +0 -1
  242. package/dist/src/web/plugin/plugin.js.map +0 -1
  243. package/dist/src/web/plugin/transform-data-llm.js.map +0 -1
  244. package/dist/src/web/plugin/transform-data-llm.test.js.map +0 -1
  245. package/dist/src/web/proxy.js.map +0 -1
  246. package/dist/src/web/types.js.map +0 -1
  247. package/dist/vitest.config.d.ts +0 -2
  248. package/dist/vitest.config.js +0 -8
  249. package/dist/vitest.config.js.map +0 -1
  250. /package/dist/{src/server → server}/inferUtilityTypes.d.ts +0 -0
  251. /package/dist/{src/server → server}/inferUtilityTypes.js +0 -0
  252. /package/dist/{src/server → server}/templateHelper.js +0 -0
  253. /package/dist/{src/test → test}/widget.test.d.ts +0 -0
  254. /package/dist/{src/web/create-store.test.d.ts → web/bridges/mcp-app/use-mcp-app-context.test.d.ts} +0 -0
  255. /package/dist/{src/web → web}/create-store.d.ts +0 -0
  256. /package/dist/{src/web/data-llm.test.d.ts → web/create-store.test.d.ts} +0 -0
  257. /package/dist/{src/web → web}/data-llm.d.ts +0 -0
  258. /package/dist/{src/web/plugin → web}/data-llm.test.d.ts +0 -0
  259. /package/dist/{src/web → web}/generate-helpers.js +0 -0
  260. /package/dist/{src/web → web}/generate-helpers.test-d.d.ts +0 -0
  261. /package/dist/{src/web → web}/generate-helpers.test.d.ts +0 -0
  262. /package/dist/{src/web → web}/generate-helpers.test.js +0 -0
  263. /package/dist/{src/web → web}/helpers/state.d.ts +0 -0
  264. /package/dist/{src/web → web}/helpers/state.test.d.ts +0 -0
  265. /package/dist/{src/web → web}/helpers/state.test.js +0 -0
  266. /package/dist/{src/web → web}/hooks/use-call-tool.test-d.d.ts +0 -0
  267. /package/dist/{src/web → web}/hooks/use-call-tool.test-d.js +0 -0
  268. /package/dist/{src/web → web}/hooks/use-call-tool.test.d.ts +0 -0
  269. /package/dist/{src/web → web}/hooks/use-display-mode.test.d.ts +0 -0
  270. /package/dist/{src/web → web}/hooks/use-files.test.d.ts +0 -0
  271. /package/dist/{src/web/hooks/use-locale.test.d.ts → web/hooks/use-layout.test.d.ts} +0 -0
  272. /package/dist/{src/web → web}/hooks/use-open-external.d.ts +0 -0
  273. /package/dist/{src/web → web}/hooks/use-open-external.test.d.ts +0 -0
  274. /package/dist/{src/web → web}/hooks/use-request-modal.test.d.ts +0 -0
  275. /package/dist/{src/web → web}/hooks/use-send-follow-up-message.d.ts +0 -0
  276. /package/dist/{src/web → web}/hooks/use-tool-info.test-d.d.ts +0 -0
  277. /package/dist/{src/web → web}/hooks/use-tool-info.test.d.ts +0 -0
  278. /package/dist/{src/web/hooks/use-theme.test.d.ts → web/hooks/use-user.test.d.ts} +0 -0
  279. /package/dist/{src/web → web}/hooks/use-widget-state.d.ts +0 -0
  280. /package/dist/{src/web → web}/hooks/use-widget-state.test.d.ts +0 -0
  281. /package/dist/{src/web → web}/mount-widget.d.ts +0 -0
  282. /package/dist/{src/web → web}/mount-widget.js +0 -0
  283. /package/dist/{src/web/hooks/use-user-agent.test.d.ts → web/plugin/data-llm.test.d.ts} +0 -0
  284. /package/dist/{src/web → web}/plugin/data-llm.test.js +0 -0
  285. /package/dist/{src/web → web}/plugin/plugin.d.ts +0 -0
  286. /package/dist/{src/web → web}/plugin/plugin.js +0 -0
  287. /package/dist/{src/web → web}/plugin/transform-data-llm.d.ts +0 -0
  288. /package/dist/{src/web → web}/plugin/transform-data-llm.test.d.ts +0 -0
  289. /package/dist/{src/web → web}/plugin/transform-data-llm.test.js +0 -0
  290. /package/dist/{src/web → web}/proxy.d.ts +0 -0
@@ -1,18 +1,6 @@
1
- import "react";
2
- declare module "react" {
3
- interface HTMLAttributes<T> {
4
- "data-llm"?: string;
5
- }
6
- }
7
- export type UnknownObject = Record<string, unknown>;
8
- export type Prettify<T> = {
9
- [K in keyof T]: T[K];
10
- } & {};
11
- export type Objectify<T> = T & UnknownObject;
12
- type RequiredKeys<T> = {
13
- [K in keyof T]-?: Record<string, never> extends Pick<T, K> ? never : K;
14
- }[keyof T];
15
- export type HasRequiredKeys<T> = RequiredKeys<T> extends never ? false : true;
1
+ import type { UnknownObject } from "../../types.js";
2
+ import type { CallToolArgs, CallToolResponse } from "../types.js";
3
+ type DisplayMode = "pip" | "inline" | "fullscreen" | "modal";
16
4
  type WidgetState = UnknownObject;
17
5
  type FileMetadata = {
18
6
  fileId: string;
@@ -28,19 +16,20 @@ export declare class ToolResponseEvent extends CustomEvent<{
28
16
  }
29
17
  declare global {
30
18
  interface Window {
31
- openai: OpenAiMethods<WidgetState> & OpenAiProperties;
19
+ openai: AppsSdkMethods<WidgetState> & AppsSdkContext;
32
20
  }
33
21
  interface WindowEventMap {
34
22
  [SET_GLOBALS_EVENT_TYPE]: SetGlobalsEvent;
35
23
  }
36
24
  }
37
- export type OpenAiProperties<ToolInput extends UnknownObject = Record<never, unknown>, ToolOutput extends UnknownObject = UnknownObject, ToolResponseMetadata extends UnknownObject = UnknownObject, WidgetState extends UnknownObject = UnknownObject> = {
25
+ export type AppsSdkContext<ToolInput extends UnknownObject = Record<never, unknown>, ToolOutput extends UnknownObject = UnknownObject, ToolResponseMetadata extends UnknownObject = UnknownObject, WidgetState extends UnknownObject = UnknownObject> = {
38
26
  theme: Theme;
39
27
  userAgent: UserAgent;
40
28
  locale: string;
41
29
  maxHeight: number;
42
30
  displayMode: DisplayMode;
43
31
  safeArea: SafeArea;
32
+ view: View;
44
33
  toolInput: ToolInput;
45
34
  toolOutput: ToolOutput | {
46
35
  text: string;
@@ -48,18 +37,17 @@ export type OpenAiProperties<ToolInput extends UnknownObject = Record<never, unk
48
37
  toolResponseMetadata: ToolResponseMetadata | null;
49
38
  widgetState: WidgetState | null;
50
39
  };
51
- export type CallToolArgs = Record<string, unknown> | null;
52
- export type CallToolResponse = {
53
- content: {
54
- type: "text";
55
- text: string;
56
- }[];
57
- structuredContent: Record<string, unknown>;
58
- isError: boolean;
59
- result: string;
60
- meta: Record<string, unknown>;
40
+ export type RequestModalOptions = {
41
+ title?: string;
42
+ params?: Record<string, unknown>;
43
+ anchor?: {
44
+ top?: number;
45
+ left?: number;
46
+ width?: number;
47
+ height?: number;
48
+ };
61
49
  };
62
- export type OpenAiMethods<WidgetState extends UnknownObject = UnknownObject> = {
50
+ export type AppsSdkMethods<WidgetState extends UnknownObject = UnknownObject> = {
63
51
  /** Calls a tool on your MCP. Returns the full response. */
64
52
  callTool: <ToolArgs extends CallToolArgs = null, ToolResponse extends CallToolResponse = CallToolResponse>(name: string, args: ToolArgs) => Promise<ToolResponse>;
65
53
  /** Triggers a followup turn in the ChatGPT conversation */
@@ -89,39 +77,39 @@ export type OpenAiMethods<WidgetState extends UnknownObject = UnknownObject> = {
89
77
  * Opens a modal portaled outside of the widget iFrame.
90
78
  * This ensures the modal is correctly displayed and not limited to the widget's area.
91
79
  */
92
- requestModal: (args: {
93
- title: string;
94
- }) => Promise<void>;
80
+ requestModal: (args: RequestModalOptions) => Promise<void>;
95
81
  /** Uploads a new file to the host */
96
82
  uploadFile: (file: File) => Promise<FileMetadata>;
97
83
  /**
98
84
  * Downloads a file from the host that was previously uploaded.
99
85
  * Only files uploaded by the same connector instance can be downloaded.
100
86
  */
101
- downloadFile: (file: FileMetadata) => Promise<{
87
+ getFileDownloadUrl: (file: FileMetadata) => Promise<{
102
88
  downloadUrl: string;
103
89
  }>;
104
90
  };
105
91
  export declare const SET_GLOBALS_EVENT_TYPE = "openai:set_globals";
106
92
  export declare class SetGlobalsEvent extends CustomEvent<{
107
- globals: Partial<OpenAiProperties>;
93
+ globals: Partial<AppsSdkContext>;
108
94
  }> {
109
95
  readonly type = "openai:set_globals";
110
96
  }
111
- export type CallTool = (name: string, args: Record<string, unknown>) => Promise<CallToolResponse>;
112
- export type DisplayMode = "pip" | "inline" | "fullscreen";
113
- export type Theme = "light" | "dark";
114
- export type SafeAreaInsets = {
97
+ type View = {
98
+ mode: DisplayMode;
99
+ params?: Record<string, unknown>;
100
+ };
101
+ type Theme = "light" | "dark";
102
+ type SafeAreaInsets = {
115
103
  top: number;
116
104
  bottom: number;
117
105
  left: number;
118
106
  right: number;
119
107
  };
120
- export type SafeArea = {
108
+ type SafeArea = {
121
109
  insets: SafeAreaInsets;
122
110
  };
123
- export type DeviceType = "mobile" | "tablet" | "desktop" | "unknown";
124
- export type UserAgent = {
111
+ type DeviceType = "mobile" | "tablet" | "desktop" | "unknown";
112
+ type UserAgent = {
125
113
  device: {
126
114
  type: DeviceType;
127
115
  };
@@ -1,4 +1,3 @@
1
- import "react";
2
1
  export const TOOL_RESPONSE_EVENT_TYPE = "openai:tool_response";
3
2
  export class ToolResponseEvent extends CustomEvent {
4
3
  type = TOOL_RESPONSE_EVENT_TYPE;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/web/bridges/apps-sdk/types.ts"],"names":[],"mappings":"AASA,MAAM,CAAC,MAAM,wBAAwB,GAAG,sBAAsB,CAAC;AAC/D,MAAM,OAAO,iBAAkB,SAAQ,WAErC;IACkB,IAAI,GAAG,wBAAwB,CAAC;CACnD;AA2FD,sDAAsD;AACtD,MAAM,CAAC,MAAM,sBAAsB,GAAG,oBAAoB,CAAC;AAC3D,MAAM,OAAO,eAAgB,SAAQ,WAEnC;IACkB,IAAI,GAAG,sBAAsB,CAAC;CACjD"}
@@ -0,0 +1,2 @@
1
+ import type { AppsSdkContext } from "./types.js";
2
+ export declare function useAppsSdkContext<K extends keyof AppsSdkContext>(key: K): AppsSdkContext[K];
@@ -0,0 +1,7 @@
1
+ import { useSyncExternalStore } from "react";
2
+ import { AppsSdkBridge } from "./bridge.js";
3
+ export function useAppsSdkContext(key) {
4
+ const bridge = AppsSdkBridge.getInstance();
5
+ return useSyncExternalStore(bridge.subscribe(key), () => bridge.getSnapshot(key));
6
+ }
7
+ //# sourceMappingURL=use-apps-sdk-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-apps-sdk-context.js","sourceRoot":"","sources":["../../../../src/web/bridges/apps-sdk/use-apps-sdk-context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAG5C,MAAM,UAAU,iBAAiB,CAC/B,GAAM;IAEN,MAAM,MAAM,GAAG,aAAa,CAAC,WAAW,EAAE,CAAC;IAC3C,OAAO,oBAAoB,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CACtD,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CACxB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,2 @@
1
+ import type { Adaptor } from "./types.js";
2
+ export declare const getAdaptor: () => Adaptor;
@@ -0,0 +1,8 @@
1
+ import { AppsSdkAdaptor } from "./apps-sdk/adaptor.js";
2
+ import { McpAppAdaptor } from "./mcp-app/adaptor.js";
3
+ export const getAdaptor = () => {
4
+ return window.skybridge.hostType === "apps-sdk"
5
+ ? AppsSdkAdaptor.getInstance()
6
+ : McpAppAdaptor.getInstance();
7
+ };
8
+ //# sourceMappingURL=get-adaptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-adaptor.js","sourceRoot":"","sources":["../../../src/web/bridges/get-adaptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGrD,MAAM,CAAC,MAAM,UAAU,GAAG,GAAY,EAAE;IACtC,OAAO,MAAM,CAAC,SAAS,CAAC,QAAQ,KAAK,UAAU;QAC7C,CAAC,CAAC,cAAc,CAAC,WAAW,EAAE;QAC9B,CAAC,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;AAClC,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export * from "./apps-sdk/index.js";
2
+ export { getAdaptor } from "./get-adaptor.js";
3
+ export * from "./mcp-app/index.js";
4
+ export * from "./types.js";
5
+ export { useHostContext } from "./use-host-context.js";
@@ -0,0 +1,6 @@
1
+ export * from "./apps-sdk/index.js";
2
+ export { getAdaptor } from "./get-adaptor.js";
3
+ export * from "./mcp-app/index.js";
4
+ export * from "./types.js";
5
+ export { useHostContext } from "./use-host-context.js";
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/web/bridges/index.tsx"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,cAAc,oBAAoB,CAAC;AACnC,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,19 @@
1
+ import type { McpUiRequestDisplayModeResult } from "@modelcontextprotocol/ext-apps";
2
+ import type { Adaptor, CallToolResponse, DisplayMode, HostContext, HostContextStore, SetWidgetStateAction } from "../types.js";
3
+ export declare class McpAppAdaptor implements Adaptor {
4
+ private static instance;
5
+ private stores;
6
+ private _widgetState;
7
+ private widgetStateListeners;
8
+ private constructor();
9
+ static getInstance(): McpAppAdaptor;
10
+ static resetInstance(): void;
11
+ getHostContextStore<K extends keyof HostContext>(key: K): HostContextStore<K>;
12
+ callTool: <ToolArgs extends Record<string, unknown> | null = null, ToolResponse extends CallToolResponse = CallToolResponse>(name: string, args: ToolArgs) => Promise<ToolResponse>;
13
+ requestDisplayMode: (mode: DisplayMode) => Promise<McpUiRequestDisplayModeResult>;
14
+ sendFollowUpMessage: (prompt: string) => Promise<void>;
15
+ openExternal(href: string): void;
16
+ private initializeStores;
17
+ setWidgetState: (stateOrUpdater: SetWidgetStateAction) => Promise<void>;
18
+ private createHostContextStore;
19
+ }
@@ -0,0 +1,145 @@
1
+ import { dequal } from "dequal/lite";
2
+ import { McpAppBridge } from "./bridge.js";
3
+ export class McpAppAdaptor {
4
+ static instance = null;
5
+ stores;
6
+ _widgetState = null;
7
+ widgetStateListeners = new Set();
8
+ constructor() {
9
+ this.stores = this.initializeStores();
10
+ }
11
+ static getInstance() {
12
+ if (!McpAppAdaptor.instance) {
13
+ McpAppAdaptor.instance = new McpAppAdaptor();
14
+ }
15
+ return McpAppAdaptor.instance;
16
+ }
17
+ static resetInstance() {
18
+ McpAppAdaptor.instance = null;
19
+ }
20
+ getHostContextStore(key) {
21
+ return this.stores[key];
22
+ }
23
+ callTool = async (name, args) => {
24
+ const bridge = McpAppBridge.getInstance();
25
+ const response = await bridge.request({
26
+ method: "tools/call",
27
+ params: {
28
+ name,
29
+ arguments: args ?? undefined,
30
+ },
31
+ });
32
+ const result = response.content
33
+ .filter((content) => content.type === "text")
34
+ .map(({ text }) => text)
35
+ .join("\n");
36
+ return {
37
+ content: response.content,
38
+ structuredContent: response.structuredContent ?? {},
39
+ isError: response.isError ?? false,
40
+ result,
41
+ meta: response._meta ?? {},
42
+ };
43
+ };
44
+ requestDisplayMode = (mode) => {
45
+ const bridge = McpAppBridge.getInstance();
46
+ if (mode !== "modal") {
47
+ return bridge.request({
48
+ method: "ui/request-display-mode",
49
+ params: { mode },
50
+ });
51
+ }
52
+ throw new Error("Modal display mode is not accessible in MCP App.");
53
+ };
54
+ sendFollowUpMessage = async (prompt) => {
55
+ const bridge = McpAppBridge.getInstance();
56
+ await bridge.request({
57
+ method: "ui/message",
58
+ params: {
59
+ role: "user",
60
+ content: [
61
+ {
62
+ type: "text",
63
+ text: prompt,
64
+ },
65
+ ],
66
+ },
67
+ });
68
+ };
69
+ openExternal(href) {
70
+ const bridge = McpAppBridge.getInstance();
71
+ bridge.request({
72
+ method: "ui/open-link",
73
+ params: { url: href },
74
+ });
75
+ }
76
+ initializeStores() {
77
+ return {
78
+ theme: this.createHostContextStore(["theme"], ({ theme }) => theme ?? "light"),
79
+ locale: this.createHostContextStore(["locale"], ({ locale }) => locale ?? "en-US"),
80
+ safeArea: this.createHostContextStore(["safeAreaInsets"], ({ safeAreaInsets }) => ({
81
+ insets: safeAreaInsets ?? { top: 0, right: 0, bottom: 0, left: 0 },
82
+ })),
83
+ displayMode: this.createHostContextStore(["displayMode"], ({ displayMode }) => displayMode ?? "inline"),
84
+ maxHeight: this.createHostContextStore(["containerDimensions"], ({ containerDimensions }) => {
85
+ if (containerDimensions && "maxHeight" in containerDimensions) {
86
+ return containerDimensions.maxHeight ?? window.innerHeight;
87
+ }
88
+ return window.innerHeight;
89
+ }),
90
+ userAgent: this.createHostContextStore(["platform", "deviceCapabilities"], ({ platform, deviceCapabilities }) => ({
91
+ device: {
92
+ type: platform === "web" ? "desktop" : (platform ?? "unknown"),
93
+ },
94
+ capabilities: {
95
+ hover: true,
96
+ touch: true,
97
+ ...deviceCapabilities,
98
+ },
99
+ })),
100
+ toolInput: this.createHostContextStore(["toolInput"], ({ toolInput }) => toolInput ?? null),
101
+ toolOutput: this.createHostContextStore(["toolResult"], ({ toolResult }) => toolResult?.structuredContent ?? null),
102
+ toolResponseMetadata: this.createHostContextStore(["toolResult"], ({ toolResult }) => toolResult?._meta ?? null),
103
+ widgetState: {
104
+ subscribe: (onChange) => {
105
+ this.widgetStateListeners.add(onChange);
106
+ return () => {
107
+ this.widgetStateListeners.delete(onChange);
108
+ };
109
+ },
110
+ getSnapshot: () => this._widgetState,
111
+ },
112
+ };
113
+ }
114
+ setWidgetState = async (stateOrUpdater) => {
115
+ const newState = typeof stateOrUpdater === "function"
116
+ ? stateOrUpdater(this._widgetState)
117
+ : stateOrUpdater;
118
+ const bridge = McpAppBridge.getInstance();
119
+ await bridge.request({
120
+ method: "ui/update-model-context",
121
+ params: { structuredContent: newState },
122
+ });
123
+ this._widgetState = newState;
124
+ this.widgetStateListeners.forEach((listener) => {
125
+ listener();
126
+ });
127
+ };
128
+ createHostContextStore(keys, computeSnapshot) {
129
+ const bridge = McpAppBridge.getInstance();
130
+ let cachedValue;
131
+ return {
132
+ subscribe: bridge.subscribe(keys),
133
+ getSnapshot: () => {
134
+ const context = Object.fromEntries(keys.map((k) => [k, bridge.getSnapshot(k)]));
135
+ const newValue = computeSnapshot(context);
136
+ if (cachedValue !== undefined && dequal(cachedValue, newValue)) {
137
+ return cachedValue;
138
+ }
139
+ cachedValue = newValue;
140
+ return newValue;
141
+ },
142
+ };
143
+ }
144
+ }
145
+ //# sourceMappingURL=adaptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"adaptor.js","sourceRoot":"","sources":["../../../../src/web/bridges/mcp-app/adaptor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ import type { McpUiHostContext, McpUiInitializeRequest } from "@modelcontextprotocol/ext-apps";
2
+ import type { Bridge, Subscribe } from "../types.js";
3
+ import type { McpAppContext, McpAppContextKey } from "./types.js";
4
+ type McpAppInitializationOptions = Pick<McpUiInitializeRequest["params"], "appInfo">;
5
+ export declare class McpAppBridge implements Bridge<McpUiHostContext> {
6
+ private static instance;
7
+ context: McpAppContext;
8
+ private listeners;
9
+ private pendingRequests;
10
+ private nextId;
11
+ private initialized;
12
+ private appInitializationOptions;
13
+ private requestTimeout;
14
+ private cleanupSizeObserver;
15
+ constructor(options: McpAppInitializationOptions, requestTimeout?: number);
16
+ static getInstance(options?: Partial<McpAppInitializationOptions>, requestTimeout?: number): McpAppBridge;
17
+ subscribe(key: McpAppContextKey): Subscribe;
18
+ subscribe(keys: readonly McpAppContextKey[]): Subscribe;
19
+ getSnapshot<K extends keyof McpAppContext>(key: K): McpAppContext[K];
20
+ cleanup: () => void;
21
+ static resetInstance(): void;
22
+ request<R extends {
23
+ method: string;
24
+ params?: unknown;
25
+ }, T>({ method, params, }: R): Promise<T>;
26
+ private emit;
27
+ private updateContext;
28
+ private init;
29
+ private handleMessage;
30
+ private handleResponse;
31
+ private handleNotification;
32
+ private handleRequest;
33
+ private connect;
34
+ private notify;
35
+ private sendSizeChanged;
36
+ /**
37
+ * Set up automatic size change notifications using ResizeObserver.
38
+ * Based on @modelcontextprotocol/ext-apps App.setupSizeChangedNotifications
39
+ * @see https://github.com/modelcontextprotocol/ext-apps/blob/main/src/app.ts#L940-L989
40
+ */
41
+ private setupSizeChangedNotifications;
42
+ }
43
+ export {};
@@ -0,0 +1,255 @@
1
+ const LATEST_PROTOCOL_VERSION = "2025-11-21";
2
+ var JsonRpcErrorCode;
3
+ (function (JsonRpcErrorCode) {
4
+ JsonRpcErrorCode[JsonRpcErrorCode["ParseError"] = -32700] = "ParseError";
5
+ JsonRpcErrorCode[JsonRpcErrorCode["InvalidRequest"] = -32600] = "InvalidRequest";
6
+ JsonRpcErrorCode[JsonRpcErrorCode["MethodNotFound"] = -32601] = "MethodNotFound";
7
+ JsonRpcErrorCode[JsonRpcErrorCode["InvalidParams"] = -32602] = "InvalidParams";
8
+ JsonRpcErrorCode[JsonRpcErrorCode["InternalError"] = -32603] = "InternalError";
9
+ })(JsonRpcErrorCode || (JsonRpcErrorCode = {}));
10
+ export class McpAppBridge {
11
+ static instance = null;
12
+ context = {
13
+ toolInput: null,
14
+ toolCancelled: null,
15
+ toolResult: null,
16
+ };
17
+ listeners = new Map();
18
+ pendingRequests = new Map();
19
+ nextId = 1;
20
+ initialized;
21
+ appInitializationOptions;
22
+ requestTimeout;
23
+ cleanupSizeObserver = null;
24
+ constructor(options, requestTimeout = 10_000) {
25
+ this.requestTimeout = requestTimeout;
26
+ this.initialized = false;
27
+ this.appInitializationOptions = {
28
+ appInfo: options.appInfo,
29
+ appCapabilities: {},
30
+ protocolVersion: LATEST_PROTOCOL_VERSION,
31
+ };
32
+ this.init();
33
+ }
34
+ static getInstance(options, requestTimeout) {
35
+ if (window.skybridge.hostType !== "mcp-app") {
36
+ throw new Error("MCP App Bridge can only be used in the mcp-app runtime");
37
+ }
38
+ if (McpAppBridge.instance && (options || requestTimeout)) {
39
+ console.warn("McpAppBridge.getInstance: options and requestTimeout ignored, instance already exists");
40
+ }
41
+ if (!McpAppBridge.instance) {
42
+ const defaultOptions = {
43
+ appInfo: { name: "skybridge-app", version: "0.0.1" },
44
+ };
45
+ McpAppBridge.instance = new McpAppBridge({ ...defaultOptions, ...options }, requestTimeout);
46
+ }
47
+ return McpAppBridge.instance;
48
+ }
49
+ subscribe(keyOrKeys) {
50
+ const keys = Array.isArray(keyOrKeys) ? keyOrKeys : [keyOrKeys];
51
+ return (onChange) => {
52
+ for (const key of keys) {
53
+ this.listeners.set(key, new Set([...(this.listeners.get(key) || []), onChange]));
54
+ }
55
+ return () => {
56
+ for (const key of keys) {
57
+ this.listeners.get(key)?.delete(onChange);
58
+ }
59
+ };
60
+ };
61
+ }
62
+ getSnapshot(key) {
63
+ return this.context[key];
64
+ }
65
+ cleanup = () => {
66
+ window.removeEventListener("message", this.handleMessage);
67
+ this.pendingRequests.forEach((request) => {
68
+ clearTimeout(request.timeout);
69
+ });
70
+ this.pendingRequests.clear();
71
+ this.listeners.clear();
72
+ this.cleanupSizeObserver?.();
73
+ this.cleanupSizeObserver = null;
74
+ };
75
+ static resetInstance() {
76
+ if (McpAppBridge.instance) {
77
+ McpAppBridge.instance.cleanup();
78
+ McpAppBridge.instance = null;
79
+ }
80
+ }
81
+ request({ method, params, }) {
82
+ const id = this.nextId++;
83
+ const { promise, resolve, reject } = Promise.withResolvers();
84
+ this.pendingRequests.set(id, {
85
+ resolve: resolve,
86
+ reject,
87
+ timeout: setTimeout(() => {
88
+ reject(new Error("Request timed out"));
89
+ this.pendingRequests.delete(id);
90
+ }, this.requestTimeout),
91
+ });
92
+ window.parent.postMessage({ jsonrpc: "2.0", id, method, params }, "*");
93
+ return promise;
94
+ }
95
+ emit(key) {
96
+ this.listeners.get(key)?.forEach((listener) => {
97
+ listener();
98
+ });
99
+ }
100
+ updateContext(context) {
101
+ this.context = { ...this.context, ...context };
102
+ for (const key of Object.keys(context)) {
103
+ this.emit(key);
104
+ }
105
+ }
106
+ init() {
107
+ if (this.initialized) {
108
+ return;
109
+ }
110
+ this.initialized = true;
111
+ if (typeof window === "undefined" || window.parent === window) {
112
+ return;
113
+ }
114
+ window.addEventListener("message", this.handleMessage);
115
+ this.connect();
116
+ }
117
+ handleMessage = (event) => {
118
+ const data = event.data;
119
+ if (data.jsonrpc !== "2.0") {
120
+ return;
121
+ }
122
+ if ("id" in data) {
123
+ if ("method" in data) {
124
+ this.handleRequest(data);
125
+ return;
126
+ }
127
+ this.handleResponse(data);
128
+ return;
129
+ }
130
+ this.handleNotification(data);
131
+ };
132
+ handleResponse(response) {
133
+ const request = this.pendingRequests.get(response.id);
134
+ if (request) {
135
+ clearTimeout(request.timeout);
136
+ this.pendingRequests.delete(response.id);
137
+ if ("error" in response) {
138
+ request.reject(new Error(response.error.message));
139
+ return;
140
+ }
141
+ request.resolve(response.result);
142
+ }
143
+ }
144
+ handleNotification = (notification) => {
145
+ switch (notification.method) {
146
+ case "ui/notifications/host-context-changed":
147
+ this.updateContext(notification.params);
148
+ return;
149
+ case "ui/notifications/tool-input":
150
+ this.updateContext({
151
+ toolInput: notification.params.arguments ?? {},
152
+ });
153
+ return;
154
+ case "ui/notifications/tool-result":
155
+ this.updateContext({
156
+ toolResult: notification.params,
157
+ });
158
+ return;
159
+ case "ui/notifications/tool-cancelled":
160
+ this.updateContext({
161
+ toolCancelled: notification.params,
162
+ });
163
+ return;
164
+ }
165
+ };
166
+ handleRequest = (request) => {
167
+ switch (request.method) {
168
+ case "ui/resource-teardown":
169
+ this.cleanup();
170
+ window.parent.postMessage({
171
+ jsonrpc: "2.0",
172
+ id: request.id,
173
+ result: {},
174
+ }, "*");
175
+ return;
176
+ default:
177
+ window.parent.postMessage({
178
+ jsonrpc: "2.0",
179
+ id: request.id,
180
+ error: {
181
+ code: JsonRpcErrorCode.MethodNotFound,
182
+ message: "Unsupported Request",
183
+ },
184
+ }, "*");
185
+ }
186
+ };
187
+ async connect() {
188
+ try {
189
+ const result = await this.request({
190
+ method: "ui/initialize",
191
+ params: this.appInitializationOptions,
192
+ });
193
+ this.updateContext(result.hostContext);
194
+ this.notify({ method: "ui/notifications/initialized" });
195
+ this.cleanupSizeObserver = this.setupSizeChangedNotifications();
196
+ }
197
+ catch (err) {
198
+ console.error(err);
199
+ }
200
+ }
201
+ notify(notification) {
202
+ window.parent.postMessage({ jsonrpc: "2.0", ...notification }, "*");
203
+ }
204
+ sendSizeChanged(params) {
205
+ this.notify({ method: "ui/notifications/size-changed", params });
206
+ }
207
+ /**
208
+ * Set up automatic size change notifications using ResizeObserver.
209
+ * Based on @modelcontextprotocol/ext-apps App.setupSizeChangedNotifications
210
+ * @see https://github.com/modelcontextprotocol/ext-apps/blob/main/src/app.ts#L940-L989
211
+ */
212
+ setupSizeChangedNotifications() {
213
+ let scheduled = false;
214
+ let lastWidth = 0;
215
+ let lastHeight = 0;
216
+ const sendBodySizeChanged = () => {
217
+ if (scheduled) {
218
+ return;
219
+ }
220
+ scheduled = true;
221
+ requestAnimationFrame(() => {
222
+ scheduled = false;
223
+ let width;
224
+ let height;
225
+ // In fullscreen mode, use viewport size since the widget should fill
226
+ // the entire available space provided by the host.
227
+ if (this.context.displayMode === "fullscreen") {
228
+ width = window.innerWidth;
229
+ height = window.innerHeight;
230
+ }
231
+ else {
232
+ // Use scrollWidth/scrollHeight to measure actual rendered content size.
233
+ // This works better than fit-content for viewport-based layouts (vw/vh)
234
+ // and fluid elements like maps that want to fill available space.
235
+ const body = document.body;
236
+ width = Math.ceil(body.scrollWidth);
237
+ height = Math.ceil(body.scrollHeight);
238
+ }
239
+ // Only send if size actually changed (prevents feedback loops from
240
+ // style changes)
241
+ if (width !== lastWidth || height !== lastHeight) {
242
+ lastWidth = width;
243
+ lastHeight = height;
244
+ this.sendSizeChanged({ width, height });
245
+ }
246
+ });
247
+ };
248
+ sendBodySizeChanged();
249
+ const resizeObserver = new ResizeObserver(sendBodySizeChanged);
250
+ resizeObserver.observe(document.documentElement);
251
+ resizeObserver.observe(document.body);
252
+ return () => resizeObserver.disconnect();
253
+ }
254
+ }
255
+ //# sourceMappingURL=bridge.js.map