skybridge 0.0.0-dev.aa3a8de → 0.0.0-dev.aa4c7a4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/run.js +5 -0
- package/dist/cli/header.d.ts +4 -0
- package/dist/cli/header.js +6 -0
- package/dist/cli/header.js.map +1 -0
- package/dist/cli/run-command.d.ts +2 -0
- package/dist/cli/run-command.js +43 -0
- package/dist/cli/run-command.js.map +1 -0
- package/dist/cli/use-execute-steps.d.ts +10 -0
- package/dist/cli/use-execute-steps.js +31 -0
- package/dist/cli/use-execute-steps.js.map +1 -0
- package/dist/commands/build.d.ts +9 -0
- package/dist/commands/build.js +44 -0
- package/dist/commands/build.js.map +1 -0
- package/dist/commands/dev.d.ts +9 -0
- package/dist/commands/dev.js +32 -0
- package/dist/commands/dev.js.map +1 -0
- package/dist/commands/start.d.ts +7 -0
- package/dist/commands/start.js +33 -0
- package/dist/commands/start.js.map +1 -0
- package/dist/commands/telemetry/disable.d.ts +5 -0
- package/dist/commands/telemetry/disable.js +14 -0
- package/dist/commands/telemetry/disable.js.map +1 -0
- package/dist/commands/telemetry/enable.d.ts +5 -0
- package/dist/commands/telemetry/enable.js +14 -0
- package/dist/commands/telemetry/enable.js.map +1 -0
- package/dist/commands/telemetry/status.d.ts +5 -0
- package/dist/commands/telemetry/status.js +14 -0
- package/dist/commands/telemetry/status.js.map +1 -0
- package/dist/hooks/telemetry.d.ts +7 -0
- package/dist/hooks/telemetry.js +124 -0
- package/dist/hooks/telemetry.js.map +1 -0
- package/dist/{src/server → server}/index.d.ts +0 -1
- package/dist/{src/server → server}/index.js +0 -1
- package/dist/server/index.js.map +1 -0
- package/dist/server/inferUtilityTypes.js.map +1 -0
- package/dist/{src/server → server}/server.d.ts +26 -1
- package/dist/server/server.js +139 -0
- package/dist/server/server.js.map +1 -0
- package/dist/server/templateHelper.js.map +1 -0
- package/dist/server/templates/development.hbs +66 -0
- package/dist/{src/server → server}/widgetsDevServer.d.ts +2 -2
- package/dist/{src/server → server}/widgetsDevServer.js +11 -3
- package/dist/server/widgetsDevServer.js.map +1 -0
- package/dist/test/utils.js.map +1 -0
- package/dist/{src/test → test}/widget.test.js +121 -12
- package/dist/test/widget.test.js.map +1 -0
- package/dist/web/bridges/apps-sdk/adaptor.d.ts +21 -0
- package/dist/{src/web/bridges/adaptors/apps-sdk-adaptor.js → web/bridges/apps-sdk/adaptor.js} +21 -3
- package/dist/web/bridges/apps-sdk/adaptor.js.map +1 -0
- package/dist/web/bridges/apps-sdk/bridge.d.ts +10 -0
- package/dist/{src/web/bridges/apps-sdk-bridge.js → web/bridges/apps-sdk/bridge.js} +2 -2
- package/dist/web/bridges/apps-sdk/bridge.js.map +1 -0
- package/dist/web/bridges/apps-sdk/index.d.ts +5 -0
- package/dist/web/bridges/apps-sdk/index.js +5 -0
- package/dist/web/bridges/apps-sdk/index.js.map +1 -0
- package/dist/{src/web → web/bridges/apps-sdk}/types.d.ts +15 -56
- package/dist/{src/web → web/bridges/apps-sdk}/types.js +0 -1
- package/dist/web/bridges/apps-sdk/types.js.map +1 -0
- package/dist/web/bridges/apps-sdk/use-apps-sdk-context.d.ts +2 -0
- package/dist/{src/web/bridges/hooks/use-apps-sdk-bridge.js → web/bridges/apps-sdk/use-apps-sdk-context.js} +3 -3
- package/dist/web/bridges/apps-sdk/use-apps-sdk-context.js.map +1 -0
- package/dist/web/bridges/get-adaptor.d.ts +2 -0
- package/dist/web/bridges/get-adaptor.js +8 -0
- package/dist/web/bridges/get-adaptor.js.map +1 -0
- package/dist/web/bridges/index.d.ts +5 -0
- package/dist/web/bridges/index.js +6 -0
- package/dist/web/bridges/index.js.map +1 -0
- package/dist/web/bridges/mcp-app/adaptor.d.ts +35 -0
- package/dist/web/bridges/mcp-app/adaptor.js +182 -0
- package/dist/web/bridges/mcp-app/adaptor.js.map +1 -0
- package/dist/web/bridges/mcp-app/bridge.d.ts +43 -0
- package/dist/{src/web/bridges/mcp-app-bridge.js → web/bridges/mcp-app/bridge.js} +109 -16
- package/dist/web/bridges/mcp-app/bridge.js.map +1 -0
- package/dist/web/bridges/mcp-app/index.d.ts +4 -0
- package/dist/web/bridges/mcp-app/index.js +4 -0
- package/dist/web/bridges/mcp-app/index.js.map +1 -0
- package/dist/web/bridges/mcp-app/types.d.ts +8 -0
- package/dist/web/bridges/mcp-app/types.js.map +1 -0
- package/dist/web/bridges/mcp-app/use-mcp-app-context.d.ts +5 -0
- package/dist/{src/web/bridges/hooks/use-mcp-app-bridge.js → web/bridges/mcp-app/use-mcp-app-context.js} +3 -3
- package/dist/web/bridges/mcp-app/use-mcp-app-context.js.map +1 -0
- package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js +66 -0
- package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js.map +1 -0
- package/dist/web/bridges/types.d.ts +96 -0
- package/dist/web/bridges/types.js +2 -0
- package/dist/{src/web → web}/bridges/types.js.map +1 -1
- package/dist/web/bridges/use-host-context.d.ts +2 -0
- package/dist/web/bridges/use-host-context.js +8 -0
- package/dist/web/bridges/use-host-context.js.map +1 -0
- package/dist/web/components/modal-provider.d.ts +4 -0
- package/dist/web/components/modal-provider.js +47 -0
- package/dist/web/components/modal-provider.js.map +1 -0
- package/dist/{src/web → web}/create-store.js +6 -7
- package/dist/web/create-store.js.map +1 -0
- package/dist/web/create-store.test.js +126 -0
- package/dist/web/create-store.test.js.map +1 -0
- package/dist/{src/web → web}/data-llm.js +5 -3
- package/dist/web/data-llm.js.map +1 -0
- package/dist/web/data-llm.test.js +139 -0
- package/dist/web/data-llm.test.js.map +1 -0
- package/dist/{src/web → web}/generate-helpers.d.ts +3 -2
- package/dist/{src/web → web}/generate-helpers.js +1 -1
- package/dist/web/generate-helpers.js.map +1 -0
- package/dist/web/generate-helpers.test-d.js.map +1 -0
- package/dist/web/generate-helpers.test.js.map +1 -0
- package/dist/{src/web → web}/helpers/state.js +13 -8
- package/dist/web/helpers/state.js.map +1 -0
- package/dist/web/helpers/state.test.js.map +1 -0
- package/dist/{src/web → web}/hooks/index.d.ts +0 -1
- package/dist/{src/web → web}/hooks/index.js +0 -1
- package/dist/web/hooks/index.js.map +1 -0
- package/dist/{src/web → web}/hooks/test/utils.d.ts +8 -2
- package/dist/web/hooks/test/utils.js +60 -0
- package/dist/web/hooks/test/utils.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-call-tool.d.ts +2 -1
- package/dist/{src/web → web}/hooks/use-call-tool.js +2 -2
- package/dist/web/hooks/use-call-tool.js.map +1 -0
- package/dist/web/hooks/use-call-tool.test-d.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-call-tool.test.js +0 -1
- package/dist/web/hooks/use-call-tool.test.js.map +1 -0
- package/dist/web/hooks/use-display-mode.js +9 -0
- package/dist/web/hooks/use-display-mode.js.map +1 -0
- package/dist/web/hooks/use-display-mode.test.js.map +1 -0
- package/dist/web/hooks/use-files.d.ts +6 -0
- package/dist/web/hooks/use-files.js +9 -0
- package/dist/web/hooks/use-files.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-files.test.js +5 -4
- package/dist/web/hooks/use-files.test.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-layout.d.ts +2 -2
- package/dist/{src/web → web}/hooks/use-layout.js +4 -4
- package/dist/web/hooks/use-layout.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-layout.test.js +6 -5
- package/dist/web/hooks/use-layout.test.js.map +1 -0
- package/dist/web/hooks/use-open-external.js +8 -0
- package/dist/web/hooks/use-open-external.js.map +1 -0
- package/dist/web/hooks/use-open-external.test.js +50 -0
- package/dist/web/hooks/use-open-external.test.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-request-modal.d.ts +2 -2
- package/dist/web/hooks/use-request-modal.js +16 -0
- package/dist/web/hooks/use-request-modal.js.map +1 -0
- package/dist/web/hooks/use-request-modal.test.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-send-follow-up-message.js +2 -2
- package/dist/web/hooks/use-send-follow-up-message.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-tool-info.js +4 -4
- package/dist/web/hooks/use-tool-info.js.map +1 -0
- package/dist/web/hooks/use-tool-info.test-d.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-tool-info.test.js +4 -4
- package/dist/web/hooks/use-tool-info.test.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-user.d.ts +1 -1
- package/dist/{src/web → web}/hooks/use-user.js +3 -3
- package/dist/web/hooks/use-user.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-user.test.js +4 -3
- package/dist/web/hooks/use-user.test.js.map +1 -0
- package/dist/{src/web → web}/hooks/use-widget-state.js +10 -10
- package/dist/web/hooks/use-widget-state.js.map +1 -0
- package/dist/web/hooks/use-widget-state.test.js.map +1 -0
- package/dist/web/index.js.map +1 -0
- package/dist/{src/web → web}/mount-widget.js +9 -1
- package/dist/web/mount-widget.js.map +1 -0
- package/dist/web/plugin/data-llm.test.js.map +1 -0
- package/dist/web/plugin/plugin.js.map +1 -0
- package/dist/web/plugin/transform-data-llm.js.map +1 -0
- package/dist/web/plugin/transform-data-llm.test.js.map +1 -0
- package/dist/web/proxy.js.map +1 -0
- package/dist/web/types.d.ts +16 -0
- package/dist/web/types.js +2 -0
- package/dist/web/types.js.map +1 -0
- package/package.json +46 -26
- package/dist/src/server/devtoolsStaticServer.d.ts +0 -15
- package/dist/src/server/devtoolsStaticServer.js +0 -38
- package/dist/src/server/devtoolsStaticServer.js.map +0 -1
- package/dist/src/server/index.js.map +0 -1
- package/dist/src/server/inferUtilityTypes.js.map +0 -1
- package/dist/src/server/server.js +0 -82
- package/dist/src/server/server.js.map +0 -1
- package/dist/src/server/templateHelper.js.map +0 -1
- package/dist/src/server/templates/development.hbs +0 -13
- package/dist/src/server/widgetsDevServer.js.map +0 -1
- package/dist/src/test/utils.js.map +0 -1
- package/dist/src/test/widget.test.js.map +0 -1
- package/dist/src/web/bridges/adaptors/apps-sdk-adaptor.d.ts +0 -12
- package/dist/src/web/bridges/adaptors/apps-sdk-adaptor.js.map +0 -1
- package/dist/src/web/bridges/adaptors/mcp-app-adaptor.d.ts +0 -15
- package/dist/src/web/bridges/adaptors/mcp-app-adaptor.js +0 -108
- package/dist/src/web/bridges/adaptors/mcp-app-adaptor.js.map +0 -1
- package/dist/src/web/bridges/apps-sdk-bridge.d.ts +0 -10
- package/dist/src/web/bridges/apps-sdk-bridge.js.map +0 -1
- package/dist/src/web/bridges/hooks/use-adaptor.d.ts +0 -2
- package/dist/src/web/bridges/hooks/use-adaptor.js +0 -8
- package/dist/src/web/bridges/hooks/use-adaptor.js.map +0 -1
- package/dist/src/web/bridges/hooks/use-apps-sdk-bridge.d.ts +0 -2
- package/dist/src/web/bridges/hooks/use-apps-sdk-bridge.js.map +0 -1
- package/dist/src/web/bridges/hooks/use-bridge.d.ts +0 -2
- package/dist/src/web/bridges/hooks/use-bridge.js +0 -8
- package/dist/src/web/bridges/hooks/use-bridge.js.map +0 -1
- package/dist/src/web/bridges/hooks/use-mcp-app-bridge.d.ts +0 -5
- package/dist/src/web/bridges/hooks/use-mcp-app-bridge.js.map +0 -1
- package/dist/src/web/bridges/hooks/use-mcp-app-bridge.test.js +0 -41
- package/dist/src/web/bridges/hooks/use-mcp-app-bridge.test.js.map +0 -1
- package/dist/src/web/bridges/index.d.ts +0 -4
- package/dist/src/web/bridges/index.js +0 -5
- package/dist/src/web/bridges/index.js.map +0 -1
- package/dist/src/web/bridges/mcp-app-bridge.d.ts +0 -38
- package/dist/src/web/bridges/mcp-app-bridge.js.map +0 -1
- package/dist/src/web/bridges/types.d.ts +0 -56
- package/dist/src/web/create-store.js.map +0 -1
- package/dist/src/web/create-store.test.js +0 -70
- package/dist/src/web/create-store.test.js.map +0 -1
- package/dist/src/web/data-llm.js.map +0 -1
- package/dist/src/web/data-llm.test.js +0 -76
- package/dist/src/web/data-llm.test.js.map +0 -1
- package/dist/src/web/generate-helpers.js.map +0 -1
- package/dist/src/web/generate-helpers.test-d.js.map +0 -1
- package/dist/src/web/generate-helpers.test.js.map +0 -1
- package/dist/src/web/helpers/state.js.map +0 -1
- package/dist/src/web/helpers/state.test.js.map +0 -1
- package/dist/src/web/hooks/index.js.map +0 -1
- package/dist/src/web/hooks/test/utils.js +0 -40
- package/dist/src/web/hooks/test/utils.js.map +0 -1
- package/dist/src/web/hooks/use-call-tool.js.map +0 -1
- package/dist/src/web/hooks/use-call-tool.test-d.js.map +0 -1
- package/dist/src/web/hooks/use-call-tool.test.js.map +0 -1
- package/dist/src/web/hooks/use-display-mode.js +0 -10
- package/dist/src/web/hooks/use-display-mode.js.map +0 -1
- package/dist/src/web/hooks/use-display-mode.test.js.map +0 -1
- package/dist/src/web/hooks/use-files.d.ts +0 -10
- package/dist/src/web/hooks/use-files.js +0 -7
- package/dist/src/web/hooks/use-files.js.map +0 -1
- package/dist/src/web/hooks/use-files.test.js.map +0 -1
- package/dist/src/web/hooks/use-layout.js.map +0 -1
- package/dist/src/web/hooks/use-layout.test.js.map +0 -1
- package/dist/src/web/hooks/use-open-external.js +0 -6
- package/dist/src/web/hooks/use-open-external.js.map +0 -1
- package/dist/src/web/hooks/use-open-external.test.js +0 -24
- package/dist/src/web/hooks/use-open-external.test.js.map +0 -1
- package/dist/src/web/hooks/use-openai-global.d.ts +0 -3
- package/dist/src/web/hooks/use-openai-global.js +0 -6
- package/dist/src/web/hooks/use-openai-global.js.map +0 -1
- package/dist/src/web/hooks/use-request-modal.js +0 -14
- package/dist/src/web/hooks/use-request-modal.js.map +0 -1
- package/dist/src/web/hooks/use-request-modal.test.js.map +0 -1
- package/dist/src/web/hooks/use-send-follow-up-message.js.map +0 -1
- package/dist/src/web/hooks/use-tool-info.js.map +0 -1
- package/dist/src/web/hooks/use-tool-info.test-d.js.map +0 -1
- package/dist/src/web/hooks/use-tool-info.test.js.map +0 -1
- package/dist/src/web/hooks/use-user.js.map +0 -1
- package/dist/src/web/hooks/use-user.test.js.map +0 -1
- package/dist/src/web/hooks/use-widget-state.js.map +0 -1
- package/dist/src/web/hooks/use-widget-state.test.js.map +0 -1
- package/dist/src/web/index.js.map +0 -1
- package/dist/src/web/mount-widget.js.map +0 -1
- package/dist/src/web/plugin/data-llm.test.js.map +0 -1
- package/dist/src/web/plugin/plugin.js.map +0 -1
- package/dist/src/web/plugin/transform-data-llm.js.map +0 -1
- package/dist/src/web/plugin/transform-data-llm.test.js.map +0 -1
- package/dist/src/web/proxy.js.map +0 -1
- package/dist/src/web/types.js.map +0 -1
- package/dist/vitest.config.d.ts +0 -2
- package/dist/vitest.config.js +0 -8
- package/dist/vitest.config.js.map +0 -1
- /package/dist/{src/server → server}/inferUtilityTypes.d.ts +0 -0
- /package/dist/{src/server → server}/inferUtilityTypes.js +0 -0
- /package/dist/{src/server → server}/templateHelper.d.ts +0 -0
- /package/dist/{src/server → server}/templateHelper.js +0 -0
- /package/dist/{src/server → server}/templates/production.hbs +0 -0
- /package/dist/{src/test → test}/utils.d.ts +0 -0
- /package/dist/{src/test → test}/utils.js +0 -0
- /package/dist/{src/test → test}/widget.test.d.ts +0 -0
- /package/dist/{src/web/bridges → web/bridges/mcp-app}/types.js +0 -0
- /package/dist/{src/web/bridges/hooks/use-mcp-app-bridge.test.d.ts → web/bridges/mcp-app/use-mcp-app-context.test.d.ts} +0 -0
- /package/dist/{src/web → web}/create-store.d.ts +0 -0
- /package/dist/{src/web → web}/create-store.test.d.ts +0 -0
- /package/dist/{src/web → web}/data-llm.d.ts +0 -0
- /package/dist/{src/web → web}/data-llm.test.d.ts +0 -0
- /package/dist/{src/web → web}/generate-helpers.test-d.d.ts +0 -0
- /package/dist/{src/web → web}/generate-helpers.test-d.js +0 -0
- /package/dist/{src/web → web}/generate-helpers.test.d.ts +0 -0
- /package/dist/{src/web → web}/generate-helpers.test.js +0 -0
- /package/dist/{src/web → web}/helpers/state.d.ts +0 -0
- /package/dist/{src/web → web}/helpers/state.test.d.ts +0 -0
- /package/dist/{src/web → web}/helpers/state.test.js +0 -0
- /package/dist/{src/web → web}/hooks/use-call-tool.test-d.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-call-tool.test-d.js +0 -0
- /package/dist/{src/web → web}/hooks/use-call-tool.test.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-display-mode.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-display-mode.test.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-display-mode.test.js +0 -0
- /package/dist/{src/web → web}/hooks/use-files.test.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-layout.test.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-open-external.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-open-external.test.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-request-modal.test.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-request-modal.test.js +0 -0
- /package/dist/{src/web → web}/hooks/use-send-follow-up-message.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-tool-info.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-tool-info.test-d.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-tool-info.test-d.js +0 -0
- /package/dist/{src/web → web}/hooks/use-tool-info.test.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-user.test.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-widget-state.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-widget-state.test.d.ts +0 -0
- /package/dist/{src/web → web}/hooks/use-widget-state.test.js +0 -0
- /package/dist/{src/web → web}/index.d.ts +0 -0
- /package/dist/{src/web → web}/index.js +0 -0
- /package/dist/{src/web → web}/mount-widget.d.ts +0 -0
- /package/dist/{src/web → web}/plugin/data-llm.test.d.ts +0 -0
- /package/dist/{src/web → web}/plugin/data-llm.test.js +0 -0
- /package/dist/{src/web → web}/plugin/plugin.d.ts +0 -0
- /package/dist/{src/web → web}/plugin/plugin.js +0 -0
- /package/dist/{src/web → web}/plugin/transform-data-llm.d.ts +0 -0
- /package/dist/{src/web → web}/plugin/transform-data-llm.js +0 -0
- /package/dist/{src/web → web}/plugin/transform-data-llm.test.d.ts +0 -0
- /package/dist/{src/web → web}/plugin/transform-data-llm.test.js +0 -0
- /package/dist/{src/web → web}/proxy.d.ts +0 -0
- /package/dist/{src/web → web}/proxy.js +0 -0
|
@@ -1,24 +1,7 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import type {
|
|
3
|
-
|
|
4
|
-
declare module "react" {
|
|
5
|
-
interface HTMLAttributes<T> {
|
|
6
|
-
"data-llm"?: string;
|
|
7
|
-
}
|
|
8
|
-
}
|
|
9
|
-
export type UnknownObject = Record<string, unknown>;
|
|
10
|
-
export type Prettify<T> = {
|
|
11
|
-
[K in keyof T]: T[K];
|
|
12
|
-
} & {};
|
|
13
|
-
export type Objectify<T> = T & UnknownObject;
|
|
14
|
-
type RequiredKeys<T> = {
|
|
15
|
-
[K in keyof T]-?: Record<string, never> extends Pick<T, K> ? never : K;
|
|
16
|
-
}[keyof T];
|
|
17
|
-
export type HasRequiredKeys<T> = RequiredKeys<T> extends never ? false : true;
|
|
1
|
+
import type { UnknownObject } from "../../types.js";
|
|
2
|
+
import type { CallToolArgs, CallToolResponse, FileMetadata, RequestModalOptions } from "../types.js";
|
|
3
|
+
type DisplayMode = "pip" | "inline" | "fullscreen" | "modal";
|
|
18
4
|
type WidgetState = UnknownObject;
|
|
19
|
-
type FileMetadata = {
|
|
20
|
-
fileId: string;
|
|
21
|
-
};
|
|
22
5
|
export declare const TOOL_RESPONSE_EVENT_TYPE = "openai:tool_response";
|
|
23
6
|
export declare class ToolResponseEvent extends CustomEvent<{
|
|
24
7
|
tool: {
|
|
@@ -30,21 +13,17 @@ export declare class ToolResponseEvent extends CustomEvent<{
|
|
|
30
13
|
}
|
|
31
14
|
declare global {
|
|
32
15
|
interface Window {
|
|
33
|
-
|
|
34
|
-
openai: OpenAiMethods<WidgetState> & OpenAiProperties;
|
|
16
|
+
openai: AppsSdkMethods<WidgetState> & AppsSdkContext;
|
|
35
17
|
}
|
|
36
18
|
interface WindowEventMap {
|
|
37
19
|
[SET_GLOBALS_EVENT_TYPE]: SetGlobalsEvent;
|
|
38
20
|
}
|
|
39
21
|
}
|
|
40
|
-
export type
|
|
41
|
-
hostType: WidgetHostType;
|
|
42
|
-
};
|
|
43
|
-
export type OpenAiProperties<ToolInput extends UnknownObject = Record<never, unknown>, ToolOutput extends UnknownObject = UnknownObject, ToolResponseMetadata extends UnknownObject = UnknownObject, WidgetState extends UnknownObject = UnknownObject> = {
|
|
22
|
+
export type AppsSdkContext<ToolInput extends UnknownObject = Record<never, unknown>, ToolOutput extends UnknownObject = UnknownObject, ToolResponseMetadata extends UnknownObject = UnknownObject, WidgetState extends UnknownObject = UnknownObject> = {
|
|
44
23
|
theme: Theme;
|
|
45
24
|
userAgent: UserAgent;
|
|
46
25
|
locale: string;
|
|
47
|
-
maxHeight: number;
|
|
26
|
+
maxHeight: number | undefined;
|
|
48
27
|
displayMode: DisplayMode;
|
|
49
28
|
safeArea: SafeArea;
|
|
50
29
|
view: View;
|
|
@@ -55,25 +34,7 @@ export type OpenAiProperties<ToolInput extends UnknownObject = Record<never, unk
|
|
|
55
34
|
toolResponseMetadata: ToolResponseMetadata | null;
|
|
56
35
|
widgetState: WidgetState | null;
|
|
57
36
|
};
|
|
58
|
-
export type
|
|
59
|
-
export type CallToolResponse = {
|
|
60
|
-
content: CallToolResult["content"];
|
|
61
|
-
structuredContent: Record<string, unknown>;
|
|
62
|
-
isError: boolean;
|
|
63
|
-
result: string;
|
|
64
|
-
meta: Record<string, unknown>;
|
|
65
|
-
};
|
|
66
|
-
export type RequestModalOptions = {
|
|
67
|
-
title?: string;
|
|
68
|
-
params?: Record<string, unknown>;
|
|
69
|
-
anchor?: {
|
|
70
|
-
top?: number;
|
|
71
|
-
left?: number;
|
|
72
|
-
width?: number;
|
|
73
|
-
height?: number;
|
|
74
|
-
};
|
|
75
|
-
};
|
|
76
|
-
export type OpenAiMethods<WidgetState extends UnknownObject = UnknownObject> = {
|
|
37
|
+
export type AppsSdkMethods<WidgetState extends UnknownObject = UnknownObject> = {
|
|
77
38
|
/** Calls a tool on your MCP. Returns the full response. */
|
|
78
39
|
callTool: <ToolArgs extends CallToolArgs = null, ToolResponse extends CallToolResponse = CallToolResponse>(name: string, args: ToolArgs) => Promise<ToolResponse>;
|
|
79
40
|
/** Triggers a followup turn in the ChatGPT conversation */
|
|
@@ -110,34 +71,32 @@ export type OpenAiMethods<WidgetState extends UnknownObject = UnknownObject> = {
|
|
|
110
71
|
* Downloads a file from the host that was previously uploaded.
|
|
111
72
|
* Only files uploaded by the same connector instance can be downloaded.
|
|
112
73
|
*/
|
|
113
|
-
|
|
74
|
+
getFileDownloadUrl: (file: FileMetadata) => Promise<{
|
|
114
75
|
downloadUrl: string;
|
|
115
76
|
}>;
|
|
116
77
|
};
|
|
117
78
|
export declare const SET_GLOBALS_EVENT_TYPE = "openai:set_globals";
|
|
118
79
|
export declare class SetGlobalsEvent extends CustomEvent<{
|
|
119
|
-
globals: Partial<
|
|
80
|
+
globals: Partial<AppsSdkContext>;
|
|
120
81
|
}> {
|
|
121
82
|
readonly type = "openai:set_globals";
|
|
122
83
|
}
|
|
123
|
-
|
|
124
|
-
export type DisplayMode = "pip" | "inline" | "fullscreen" | "modal";
|
|
125
|
-
export type View = {
|
|
84
|
+
type View = {
|
|
126
85
|
mode: DisplayMode;
|
|
127
86
|
params?: Record<string, unknown>;
|
|
128
87
|
};
|
|
129
|
-
|
|
130
|
-
|
|
88
|
+
type Theme = "light" | "dark";
|
|
89
|
+
type SafeAreaInsets = {
|
|
131
90
|
top: number;
|
|
132
91
|
bottom: number;
|
|
133
92
|
left: number;
|
|
134
93
|
right: number;
|
|
135
94
|
};
|
|
136
|
-
|
|
95
|
+
type SafeArea = {
|
|
137
96
|
insets: SafeAreaInsets;
|
|
138
97
|
};
|
|
139
|
-
|
|
140
|
-
|
|
98
|
+
type DeviceType = "mobile" | "tablet" | "desktop" | "unknown";
|
|
99
|
+
type UserAgent = {
|
|
141
100
|
device: {
|
|
142
101
|
type: DeviceType;
|
|
143
102
|
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/web/bridges/apps-sdk/types.ts"],"names":[],"mappings":"AAYA,MAAM,CAAC,MAAM,wBAAwB,GAAG,sBAAsB,CAAC;AAC/D,MAAM,OAAO,iBAAkB,SAAQ,WAErC;IACkB,IAAI,GAAG,wBAAwB,CAAC;CACnD;AAqFD,sDAAsD;AACtD,MAAM,CAAC,MAAM,sBAAsB,GAAG,oBAAoB,CAAC;AAC3D,MAAM,OAAO,eAAgB,SAAQ,WAEnC;IACkB,IAAI,GAAG,sBAAsB,CAAC;CACjD"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { useSyncExternalStore } from "react";
|
|
2
|
-
import { AppsSdkBridge } from "
|
|
3
|
-
export function
|
|
2
|
+
import { AppsSdkBridge } from "./bridge.js";
|
|
3
|
+
export function useAppsSdkContext(key) {
|
|
4
4
|
const bridge = AppsSdkBridge.getInstance();
|
|
5
5
|
return useSyncExternalStore(bridge.subscribe(key), () => bridge.getSnapshot(key));
|
|
6
6
|
}
|
|
7
|
-
//# sourceMappingURL=use-apps-sdk-
|
|
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,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 @@
|
|
|
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,35 @@
|
|
|
1
|
+
import type { McpUiRequestDisplayModeResult } from "@modelcontextprotocol/ext-apps";
|
|
2
|
+
import type { Adaptor, CallToolResponse, DisplayMode, HostContext, HostContextStore, RequestModalOptions, 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 _viewState;
|
|
9
|
+
private viewListeners;
|
|
10
|
+
private constructor();
|
|
11
|
+
static getInstance(): McpAppAdaptor;
|
|
12
|
+
static resetInstance(): void;
|
|
13
|
+
getHostContextStore<K extends keyof HostContext>(key: K): HostContextStore<K>;
|
|
14
|
+
callTool: <ToolArgs extends Record<string, unknown> | null = null, ToolResponse extends CallToolResponse = CallToolResponse>(name: string, args: ToolArgs) => Promise<ToolResponse>;
|
|
15
|
+
requestDisplayMode: (mode: DisplayMode) => Promise<McpUiRequestDisplayModeResult>;
|
|
16
|
+
sendFollowUpMessage: (prompt: string) => Promise<void>;
|
|
17
|
+
openExternal(href: string): void;
|
|
18
|
+
private initializeStores;
|
|
19
|
+
setWidgetState: (stateOrUpdater: SetWidgetStateAction) => Promise<void>;
|
|
20
|
+
/**
|
|
21
|
+
* @throws File upload is not supported in MCP App.
|
|
22
|
+
*/
|
|
23
|
+
uploadFile(): Promise<{
|
|
24
|
+
fileId: string;
|
|
25
|
+
}>;
|
|
26
|
+
/**
|
|
27
|
+
* @throws File download is not supported in MCP App.
|
|
28
|
+
*/
|
|
29
|
+
getFileDownloadUrl(): Promise<{
|
|
30
|
+
downloadUrl: string;
|
|
31
|
+
}>;
|
|
32
|
+
openModal(options: RequestModalOptions): void;
|
|
33
|
+
closeModal(): void;
|
|
34
|
+
private createHostContextStore;
|
|
35
|
+
}
|
|
@@ -0,0 +1,182 @@
|
|
|
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
|
+
_viewState = {
|
|
9
|
+
mode: "inline",
|
|
10
|
+
};
|
|
11
|
+
viewListeners = new Set();
|
|
12
|
+
constructor() {
|
|
13
|
+
this.stores = this.initializeStores();
|
|
14
|
+
}
|
|
15
|
+
static getInstance() {
|
|
16
|
+
if (!McpAppAdaptor.instance) {
|
|
17
|
+
McpAppAdaptor.instance = new McpAppAdaptor();
|
|
18
|
+
}
|
|
19
|
+
return McpAppAdaptor.instance;
|
|
20
|
+
}
|
|
21
|
+
static resetInstance() {
|
|
22
|
+
McpAppAdaptor.instance = null;
|
|
23
|
+
}
|
|
24
|
+
getHostContextStore(key) {
|
|
25
|
+
return this.stores[key];
|
|
26
|
+
}
|
|
27
|
+
callTool = async (name, args) => {
|
|
28
|
+
const bridge = McpAppBridge.getInstance();
|
|
29
|
+
const response = await bridge.request({
|
|
30
|
+
method: "tools/call",
|
|
31
|
+
params: {
|
|
32
|
+
name,
|
|
33
|
+
arguments: args ?? undefined,
|
|
34
|
+
},
|
|
35
|
+
});
|
|
36
|
+
const result = response.content
|
|
37
|
+
.filter((content) => content.type === "text")
|
|
38
|
+
.map(({ text }) => text)
|
|
39
|
+
.join("\n");
|
|
40
|
+
return {
|
|
41
|
+
content: response.content,
|
|
42
|
+
structuredContent: response.structuredContent ?? {},
|
|
43
|
+
isError: response.isError ?? false,
|
|
44
|
+
result,
|
|
45
|
+
meta: response._meta ?? {},
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
requestDisplayMode = (mode) => {
|
|
49
|
+
const bridge = McpAppBridge.getInstance();
|
|
50
|
+
if (mode !== "modal") {
|
|
51
|
+
return bridge.request({
|
|
52
|
+
method: "ui/request-display-mode",
|
|
53
|
+
params: { mode },
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
throw new Error("Modal display mode is not accessible in MCP App.");
|
|
57
|
+
};
|
|
58
|
+
sendFollowUpMessage = async (prompt) => {
|
|
59
|
+
const bridge = McpAppBridge.getInstance();
|
|
60
|
+
await bridge.request({
|
|
61
|
+
method: "ui/message",
|
|
62
|
+
params: {
|
|
63
|
+
role: "user",
|
|
64
|
+
content: [
|
|
65
|
+
{
|
|
66
|
+
type: "text",
|
|
67
|
+
text: prompt,
|
|
68
|
+
},
|
|
69
|
+
],
|
|
70
|
+
},
|
|
71
|
+
});
|
|
72
|
+
};
|
|
73
|
+
openExternal(href) {
|
|
74
|
+
const bridge = McpAppBridge.getInstance();
|
|
75
|
+
bridge.request({
|
|
76
|
+
method: "ui/open-link",
|
|
77
|
+
params: { url: href },
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
initializeStores() {
|
|
81
|
+
return {
|
|
82
|
+
theme: this.createHostContextStore(["theme"], ({ theme }) => theme ?? "light"),
|
|
83
|
+
locale: this.createHostContextStore(["locale"], ({ locale }) => locale ?? "en-US"),
|
|
84
|
+
safeArea: this.createHostContextStore(["safeAreaInsets"], ({ safeAreaInsets }) => ({
|
|
85
|
+
insets: safeAreaInsets ?? { top: 0, right: 0, bottom: 0, left: 0 },
|
|
86
|
+
})),
|
|
87
|
+
displayMode: this.createHostContextStore(["displayMode"], ({ displayMode }) => displayMode ?? "inline"),
|
|
88
|
+
maxHeight: this.createHostContextStore(["containerDimensions"], ({ containerDimensions }) => {
|
|
89
|
+
if (containerDimensions && "maxHeight" in containerDimensions) {
|
|
90
|
+
return containerDimensions.maxHeight;
|
|
91
|
+
}
|
|
92
|
+
return undefined;
|
|
93
|
+
}),
|
|
94
|
+
userAgent: this.createHostContextStore(["platform", "deviceCapabilities"], ({ platform, deviceCapabilities }) => ({
|
|
95
|
+
device: {
|
|
96
|
+
type: platform === "web" ? "desktop" : (platform ?? "unknown"),
|
|
97
|
+
},
|
|
98
|
+
capabilities: {
|
|
99
|
+
hover: true,
|
|
100
|
+
touch: true,
|
|
101
|
+
...deviceCapabilities,
|
|
102
|
+
},
|
|
103
|
+
})),
|
|
104
|
+
toolInput: this.createHostContextStore(["toolInput"], ({ toolInput }) => toolInput ?? null),
|
|
105
|
+
toolOutput: this.createHostContextStore(["toolResult"], ({ toolResult }) => toolResult?.structuredContent ?? null),
|
|
106
|
+
toolResponseMetadata: this.createHostContextStore(["toolResult"], ({ toolResult }) => toolResult?._meta ?? null),
|
|
107
|
+
view: {
|
|
108
|
+
subscribe: (onChange) => {
|
|
109
|
+
this.viewListeners.add(onChange);
|
|
110
|
+
return () => {
|
|
111
|
+
this.viewListeners.delete(onChange);
|
|
112
|
+
};
|
|
113
|
+
},
|
|
114
|
+
getSnapshot: () => this._viewState,
|
|
115
|
+
},
|
|
116
|
+
widgetState: {
|
|
117
|
+
subscribe: (onChange) => {
|
|
118
|
+
this.widgetStateListeners.add(onChange);
|
|
119
|
+
return () => {
|
|
120
|
+
this.widgetStateListeners.delete(onChange);
|
|
121
|
+
};
|
|
122
|
+
},
|
|
123
|
+
getSnapshot: () => this._widgetState,
|
|
124
|
+
},
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
setWidgetState = async (stateOrUpdater) => {
|
|
128
|
+
const newState = typeof stateOrUpdater === "function"
|
|
129
|
+
? stateOrUpdater(this._widgetState)
|
|
130
|
+
: stateOrUpdater;
|
|
131
|
+
const bridge = McpAppBridge.getInstance();
|
|
132
|
+
await bridge.request({
|
|
133
|
+
method: "ui/update-model-context",
|
|
134
|
+
params: { structuredContent: newState },
|
|
135
|
+
});
|
|
136
|
+
this._widgetState = newState;
|
|
137
|
+
this.widgetStateListeners.forEach((listener) => {
|
|
138
|
+
listener();
|
|
139
|
+
});
|
|
140
|
+
};
|
|
141
|
+
/**
|
|
142
|
+
* @throws File upload is not supported in MCP App.
|
|
143
|
+
*/
|
|
144
|
+
uploadFile() {
|
|
145
|
+
throw new Error("File upload is not supported in MCP App.");
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* @throws File download is not supported in MCP App.
|
|
149
|
+
*/
|
|
150
|
+
getFileDownloadUrl() {
|
|
151
|
+
throw new Error("File download is not supported in MCP App.");
|
|
152
|
+
}
|
|
153
|
+
openModal(options) {
|
|
154
|
+
this._viewState = { mode: "modal", params: options.params };
|
|
155
|
+
this.viewListeners.forEach((listener) => {
|
|
156
|
+
listener();
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
closeModal() {
|
|
160
|
+
this._viewState = { mode: "inline" };
|
|
161
|
+
this.viewListeners.forEach((listener) => {
|
|
162
|
+
listener();
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
createHostContextStore(keys, computeSnapshot) {
|
|
166
|
+
const bridge = McpAppBridge.getInstance();
|
|
167
|
+
let cachedValue;
|
|
168
|
+
return {
|
|
169
|
+
subscribe: bridge.subscribe(keys),
|
|
170
|
+
getSnapshot: () => {
|
|
171
|
+
const context = Object.fromEntries(keys.map((k) => [k, bridge.getSnapshot(k)]));
|
|
172
|
+
const newValue = computeSnapshot(context);
|
|
173
|
+
if (cachedValue !== undefined && dequal(cachedValue, newValue)) {
|
|
174
|
+
return cachedValue;
|
|
175
|
+
}
|
|
176
|
+
cachedValue = newValue;
|
|
177
|
+
return newValue;
|
|
178
|
+
},
|
|
179
|
+
};
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
//# sourceMappingURL=adaptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adaptor.js","sourceRoot":"","sources":["../../../../src/web/bridges/mcp-app/adaptor.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAUrC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAO3C,MAAM,OAAO,aAAa;IAChB,MAAM,CAAC,QAAQ,GAAyB,IAAI,CAAC;IAC7C,MAAM,CAEZ;IACM,YAAY,GAA+B,IAAI,CAAC;IAChD,oBAAoB,GAAG,IAAI,GAAG,EAAc,CAAC;IAE7C,UAAU,GAAwB;QACxC,IAAI,EAAE,QAAQ;KACf,CAAC;IACM,aAAa,GAAG,IAAI,GAAG,EAAc,CAAC;IAE9C;QACE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;IACxC,CAAC;IAEM,MAAM,CAAC,WAAW;QACvB,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;YAC5B,aAAa,CAAC,QAAQ,GAAG,IAAI,aAAa,EAAE,CAAC;QAC/C,CAAC;QACD,OAAO,aAAa,CAAC,QAAQ,CAAC;IAChC,CAAC;IAEM,MAAM,CAAC,aAAa;QACzB,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;IAChC,CAAC;IAEM,mBAAmB,CACxB,GAAM;QAEN,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAEM,QAAQ,GAAG,KAAK,EAIrB,IAAY,EACZ,IAAc,EACS,EAAE;QACzB,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,EAAE,CAAC;QAC1C,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,OAAO,CAAkC;YACrE,MAAM,EAAE,YAAY;YACpB,MAAM,EAAE;gBACN,IAAI;gBACJ,SAAS,EAAE,IAAI,IAAI,SAAS;aAC7B;SACF,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,QAAQ,CAAC,OAAO;aAC5B,MAAM,CACL,CAAC,OAAO,EAA6C,EAAE,CACrD,OAAO,CAAC,IAAI,KAAK,MAAM,CAC1B;aACA,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC;aACvB,IAAI,CAAC,IAAI,CAAC,CAAC;QAEd,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,OAAO;YACzB,iBAAiB,EAAE,QAAQ,CAAC,iBAAiB,IAAI,EAAE;YACnD,OAAO,EAAE,QAAQ,CAAC,OAAO,IAAI,KAAK;YAClC,MAAM;YACN,IAAI,EAAE,QAAQ,CAAC,KAAK,IAAI,EAAE;SACX,CAAC;IACpB,CAAC,CAAC;IAEK,kBAAkB,GAAG,CAAC,IAAiB,EAAE,EAAE;QAChD,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,EAAE,CAAC;QAC1C,IAAI,IAAI,KAAK,OAAO,EAAE,CAAC;YACrB,OAAO,MAAM,CAAC,OAAO,CAGnB;gBACA,MAAM,EAAE,yBAAyB;gBACjC,MAAM,EAAE,EAAE,IAAI,EAAE;aACjB,CAAC,CAAC;QACL,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;IACtE,CAAC,CAAC;IAEK,mBAAmB,GAAG,KAAK,EAAE,MAAc,EAAE,EAAE;QACpD,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,EAAE,CAAC;QAC1C,MAAM,MAAM,CAAC,OAAO,CAA0C;YAC5D,MAAM,EAAE,YAAY;YACpB,MAAM,EAAE;gBACN,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE;oBACP;wBACE,IAAI,EAAE,MAAM;wBACZ,IAAI,EAAE,MAAM;qBACb;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC;IAEK,YAAY,CAAC,IAAY;QAC9B,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,EAAE,CAAC;QAC1C,MAAM,CAAC,OAAO,CAA4C;YACxD,MAAM,EAAE,cAAc;YACtB,MAAM,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE;SACtB,CAAC,CAAC;IACL,CAAC;IAEO,gBAAgB;QAGtB,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,sBAAsB,CAChC,CAAC,OAAO,CAAC,EACT,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,IAAI,OAAO,CAChC;YACD,MAAM,EAAE,IAAI,CAAC,sBAAsB,CACjC,CAAC,QAAQ,CAAC,EACV,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,IAAI,OAAO,CAClC;YACD,QAAQ,EAAE,IAAI,CAAC,sBAAsB,CACnC,CAAC,gBAAgB,CAAC,EAClB,CAAC,EAAE,cAAc,EAAE,EAAE,EAAE,CAAC,CAAC;gBACvB,MAAM,EAAE,cAAc,IAAI,EAAE,GAAG,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;aACnE,CAAC,CACH;YACD,WAAW,EAAE,IAAI,CAAC,sBAAsB,CACtC,CAAC,aAAa,CAAC,EACf,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,WAAW,IAAI,QAAQ,CAC7C;YACD,SAAS,EAAE,IAAI,CAAC,sBAAsB,CACpC,CAAC,qBAAqB,CAAC,EACvB,CAAC,EAAE,mBAAmB,EAAE,EAAE,EAAE;gBAC1B,IAAI,mBAAmB,IAAI,WAAW,IAAI,mBAAmB,EAAE,CAAC;oBAC9D,OAAO,mBAAmB,CAAC,SAAS,CAAC;gBACvC,CAAC;gBAED,OAAO,SAAS,CAAC;YACnB,CAAC,CACF;YACD,SAAS,EAAE,IAAI,CAAC,sBAAsB,CACpC,CAAC,UAAU,EAAE,oBAAoB,CAAC,EAClC,CAAC,EAAE,QAAQ,EAAE,kBAAkB,EAAE,EAAE,EAAE,CAAC,CAAC;gBACrC,MAAM,EAAE;oBACN,IAAI,EAAE,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,IAAI,SAAS,CAAC;iBAC/D;gBACD,YAAY,EAAE;oBACZ,KAAK,EAAE,IAAI;oBACX,KAAK,EAAE,IAAI;oBACX,GAAG,kBAAkB;iBACtB;aACF,CAAC,CACH;YACD,SAAS,EAAE,IAAI,CAAC,sBAAsB,CACpC,CAAC,WAAW,CAAC,EACb,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,SAAS,IAAI,IAAI,CACrC;YACD,UAAU,EAAE,IAAI,CAAC,sBAAsB,CACrC,CAAC,YAAY,CAAC,EACd,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,UAAU,EAAE,iBAAiB,IAAI,IAAI,CAC1D;YACD,oBAAoB,EAAE,IAAI,CAAC,sBAAsB,CAC/C,CAAC,YAAY,CAAC,EACd,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,UAAU,EAAE,KAAK,IAAI,IAAI,CAC9C;YACD,IAAI,EAAE;gBACJ,SAAS,EAAE,CAAC,QAAoB,EAAE,EAAE;oBAClC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;oBACjC,OAAO,GAAG,EAAE;wBACV,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;oBACtC,CAAC,CAAC;gBACJ,CAAC;gBACD,WAAW,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU;aACnC;YACD,WAAW,EAAE;gBACX,SAAS,EAAE,CAAC,QAAoB,EAAE,EAAE;oBAClC,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;oBACxC,OAAO,GAAG,EAAE;wBACV,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;oBAC7C,CAAC,CAAC;gBACJ,CAAC;gBACD,WAAW,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY;aACrC;SACF,CAAC;IACJ,CAAC;IAEM,cAAc,GAAG,KAAK,EAC3B,cAAoC,EACrB,EAAE;QACjB,MAAM,QAAQ,GACZ,OAAO,cAAc,KAAK,UAAU;YAClC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC;YACnC,CAAC,CAAC,cAAc,CAAC;QAErB,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,EAAE,CAAC;QAC1C,MAAM,MAAM,CAAC,OAAO,CAA0C;YAC5D,MAAM,EAAE,yBAAyB;YACjC,MAAM,EAAE,EAAE,iBAAiB,EAAE,QAAQ,EAAE;SACxC,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;QAC7B,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YAC7C,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;IAEF;;OAEG;IACI,UAAU;QACf,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;IAC9D,CAAC;IAED;;OAEG;IACI,kBAAkB;QACvB,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;IAChE,CAAC;IAEM,SAAS,CAAC,OAA4B;QAC3C,IAAI,CAAC,UAAU,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC;QAC5D,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YACtC,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,UAAU,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;QACrC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YACtC,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,sBAAsB,CAG5B,IAAU,EAAE,eAAkD;QAC9D,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,EAAE,CAAC;QAC1C,IAAI,WAA0B,CAAC;QAE/B,OAAO;YACL,SAAS,EAAE,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC;YACjC,WAAW,EAAE,GAAG,EAAE;gBAChB,MAAM,OAAO,GAAG,MAAM,CAAC,WAAW,CAChC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CACvB,CAAC;gBACvB,MAAM,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;gBAE1C,IAAI,WAAW,KAAK,SAAS,IAAI,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,EAAE,CAAC;oBAC/D,OAAO,WAAW,CAAC;gBACrB,CAAC;gBAED,WAAW,GAAG,QAAQ,CAAC;gBACvB,OAAO,QAAQ,CAAC;YAClB,CAAC;SACF,CAAC;IACJ,CAAC"}
|
|
@@ -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 {};
|
|
@@ -1,4 +1,12 @@
|
|
|
1
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 = {}));
|
|
2
10
|
export class McpAppBridge {
|
|
3
11
|
static instance = null;
|
|
4
12
|
context = {
|
|
@@ -12,6 +20,7 @@ export class McpAppBridge {
|
|
|
12
20
|
initialized;
|
|
13
21
|
appInitializationOptions;
|
|
14
22
|
requestTimeout;
|
|
23
|
+
cleanupSizeObserver = null;
|
|
15
24
|
constructor(options, requestTimeout = 10_000) {
|
|
16
25
|
this.requestTimeout = requestTimeout;
|
|
17
26
|
this.initialized = false;
|
|
@@ -20,6 +29,7 @@ export class McpAppBridge {
|
|
|
20
29
|
appCapabilities: {},
|
|
21
30
|
protocolVersion: LATEST_PROTOCOL_VERSION,
|
|
22
31
|
};
|
|
32
|
+
this.init();
|
|
23
33
|
}
|
|
24
34
|
static getInstance(options, requestTimeout) {
|
|
25
35
|
if (window.skybridge.hostType !== "mcp-app") {
|
|
@@ -42,7 +52,6 @@ export class McpAppBridge {
|
|
|
42
52
|
for (const key of keys) {
|
|
43
53
|
this.listeners.set(key, new Set([...(this.listeners.get(key) || []), onChange]));
|
|
44
54
|
}
|
|
45
|
-
this.init();
|
|
46
55
|
return () => {
|
|
47
56
|
for (const key of keys) {
|
|
48
57
|
this.listeners.get(key)?.delete(onChange);
|
|
@@ -60,6 +69,8 @@ export class McpAppBridge {
|
|
|
60
69
|
});
|
|
61
70
|
this.pendingRequests.clear();
|
|
62
71
|
this.listeners.clear();
|
|
72
|
+
this.cleanupSizeObserver?.();
|
|
73
|
+
this.cleanupSizeObserver = null;
|
|
63
74
|
};
|
|
64
75
|
static resetInstance() {
|
|
65
76
|
if (McpAppBridge.instance) {
|
|
@@ -109,39 +120,70 @@ export class McpAppBridge {
|
|
|
109
120
|
return;
|
|
110
121
|
}
|
|
111
122
|
if ("id" in data) {
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
this.pendingRequests.delete(data.id);
|
|
116
|
-
if ("error" in data) {
|
|
117
|
-
request.reject(new Error(data.error.message));
|
|
118
|
-
return;
|
|
119
|
-
}
|
|
120
|
-
request.resolve(data.result);
|
|
123
|
+
if ("method" in data) {
|
|
124
|
+
this.handleRequest(data);
|
|
125
|
+
return;
|
|
121
126
|
}
|
|
127
|
+
this.handleResponse(data);
|
|
122
128
|
return;
|
|
123
129
|
}
|
|
124
|
-
|
|
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) {
|
|
125
146
|
case "ui/notifications/host-context-changed":
|
|
126
|
-
this.updateContext(
|
|
147
|
+
this.updateContext(notification.params);
|
|
127
148
|
return;
|
|
128
149
|
case "ui/notifications/tool-input":
|
|
129
150
|
this.updateContext({
|
|
130
|
-
toolInput:
|
|
151
|
+
toolInput: notification.params.arguments ?? {},
|
|
131
152
|
});
|
|
132
153
|
return;
|
|
133
154
|
case "ui/notifications/tool-result":
|
|
134
155
|
this.updateContext({
|
|
135
|
-
toolResult:
|
|
156
|
+
toolResult: notification.params,
|
|
136
157
|
});
|
|
137
158
|
return;
|
|
138
159
|
case "ui/notifications/tool-cancelled":
|
|
139
160
|
this.updateContext({
|
|
140
|
-
toolCancelled:
|
|
161
|
+
toolCancelled: notification.params,
|
|
141
162
|
});
|
|
142
163
|
return;
|
|
143
164
|
}
|
|
144
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
|
+
};
|
|
145
187
|
async connect() {
|
|
146
188
|
try {
|
|
147
189
|
const result = await this.request({
|
|
@@ -150,6 +192,7 @@ export class McpAppBridge {
|
|
|
150
192
|
});
|
|
151
193
|
this.updateContext(result.hostContext);
|
|
152
194
|
this.notify({ method: "ui/notifications/initialized" });
|
|
195
|
+
this.cleanupSizeObserver = this.setupSizeChangedNotifications();
|
|
153
196
|
}
|
|
154
197
|
catch (err) {
|
|
155
198
|
console.error(err);
|
|
@@ -158,5 +201,55 @@ export class McpAppBridge {
|
|
|
158
201
|
notify(notification) {
|
|
159
202
|
window.parent.postMessage({ jsonrpc: "2.0", ...notification }, "*");
|
|
160
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
|
+
}
|
|
161
254
|
}
|
|
162
|
-
//# sourceMappingURL=
|
|
255
|
+
//# sourceMappingURL=bridge.js.map
|