skybridge 0.0.0-dev.6f1dfd8 → 0.0.0-dev.6f5ad0d

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 (74) hide show
  1. package/README.md +144 -0
  2. package/bin/run.js +0 -4
  3. package/dist/cli/telemetry.d.ts +7 -0
  4. package/dist/cli/telemetry.js +123 -0
  5. package/dist/cli/telemetry.js.map +1 -0
  6. package/dist/cli/use-execute-steps.d.ts +1 -1
  7. package/dist/cli/use-nodemon.d.ts +6 -0
  8. package/dist/cli/use-nodemon.js +61 -0
  9. package/dist/cli/use-nodemon.js.map +1 -0
  10. package/dist/cli/use-typescript-check.d.ts +8 -0
  11. package/dist/cli/use-typescript-check.js +59 -0
  12. package/dist/cli/use-typescript-check.js.map +1 -0
  13. package/dist/commands/dev.d.ts +3 -1
  14. package/dist/commands/dev.js +20 -9
  15. package/dist/commands/dev.js.map +1 -1
  16. package/dist/commands/telemetry/disable.d.ts +5 -0
  17. package/dist/commands/telemetry/disable.js +14 -0
  18. package/dist/commands/telemetry/disable.js.map +1 -0
  19. package/dist/commands/telemetry/enable.d.ts +5 -0
  20. package/dist/commands/telemetry/enable.js +14 -0
  21. package/dist/commands/telemetry/enable.js.map +1 -0
  22. package/dist/commands/telemetry/status.d.ts +5 -0
  23. package/dist/commands/telemetry/status.js +14 -0
  24. package/dist/commands/telemetry/status.js.map +1 -0
  25. package/dist/server/asset-base-url-transform-plugin.d.ts +11 -0
  26. package/dist/server/asset-base-url-transform-plugin.js +34 -0
  27. package/dist/server/asset-base-url-transform-plugin.js.map +1 -0
  28. package/dist/server/asset-base-url-transform-plugin.test.d.ts +1 -0
  29. package/dist/server/asset-base-url-transform-plugin.test.js +56 -0
  30. package/dist/server/asset-base-url-transform-plugin.test.js.map +1 -0
  31. package/dist/server/server.js +2 -1
  32. package/dist/server/server.js.map +1 -1
  33. package/dist/server/templates/development.hbs +1 -2
  34. package/dist/server/templates/production.hbs +1 -2
  35. package/dist/server/widgetsDevServer.js +4 -0
  36. package/dist/server/widgetsDevServer.js.map +1 -1
  37. package/dist/test/widget.test.js +2 -2
  38. package/dist/test/widget.test.js.map +1 -1
  39. package/dist/web/bridges/apps-sdk/adaptor.d.ts +9 -1
  40. package/dist/web/bridges/apps-sdk/adaptor.js +25 -0
  41. package/dist/web/bridges/apps-sdk/adaptor.js.map +1 -1
  42. package/dist/web/bridges/apps-sdk/index.d.ts +1 -1
  43. package/dist/web/bridges/apps-sdk/index.js.map +1 -1
  44. package/dist/web/bridges/apps-sdk/types.d.ts +8 -14
  45. package/dist/web/bridges/apps-sdk/types.js.map +1 -1
  46. package/dist/web/bridges/mcp-app/adaptor.d.ts +18 -1
  47. package/dist/web/bridges/mcp-app/adaptor.js +40 -0
  48. package/dist/web/bridges/mcp-app/adaptor.js.map +1 -1
  49. package/dist/web/bridges/types.d.ts +24 -0
  50. package/dist/web/components/modal-provider.d.ts +4 -0
  51. package/dist/web/components/modal-provider.js +47 -0
  52. package/dist/web/components/modal-provider.js.map +1 -0
  53. package/dist/web/hooks/index.d.ts +1 -0
  54. package/dist/web/hooks/index.js +1 -0
  55. package/dist/web/hooks/index.js.map +1 -1
  56. package/dist/web/hooks/use-files.d.ts +2 -6
  57. package/dist/web/hooks/use-files.js +4 -2
  58. package/dist/web/hooks/use-files.js.map +1 -1
  59. package/dist/web/hooks/use-files.test.js +1 -0
  60. package/dist/web/hooks/use-files.test.js.map +1 -1
  61. package/dist/web/hooks/use-request-modal.d.ts +2 -2
  62. package/dist/web/hooks/use-request-modal.js +9 -7
  63. package/dist/web/hooks/use-request-modal.js.map +1 -1
  64. package/dist/web/hooks/use-set-open-in-app-url.d.ts +1 -0
  65. package/dist/web/hooks/use-set-open-in-app-url.js +8 -0
  66. package/dist/web/hooks/use-set-open-in-app-url.js.map +1 -0
  67. package/dist/web/hooks/use-set-open-in-app-url.test.d.ts +1 -0
  68. package/dist/web/hooks/use-set-open-in-app-url.test.js +49 -0
  69. package/dist/web/hooks/use-set-open-in-app-url.test.js.map +1 -0
  70. package/dist/web/mount-widget.js +9 -1
  71. package/dist/web/mount-widget.js.map +1 -1
  72. package/dist/web/plugin/plugin.js +7 -0
  73. package/dist/web/plugin/plugin.js.map +1 -1
  74. package/package.json +17 -10
@@ -5,6 +5,7 @@ export { useLayout } from "./use-layout.js";
5
5
  export { useOpenExternal } from "./use-open-external.js";
6
6
  export { useRequestModal } from "./use-request-modal.js";
7
7
  export { useSendFollowUpMessage } from "./use-send-follow-up-message.js";
8
+ export { useSetOpenInAppUrl } from "./use-set-open-in-app-url.js";
8
9
  export { useToolInfo } from "./use-tool-info.js";
9
10
  export { useUser } from "./use-user.js";
10
11
  export { useWidgetState } from "./use-widget-state.js";
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/web/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAKL,WAAW,GACZ,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAoB,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAkB,OAAO,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/web/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAKL,WAAW,GACZ,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAoB,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AACzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAkB,OAAO,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC"}
@@ -1,10 +1,6 @@
1
1
  export declare function useFiles(): {
2
- upload: (file: File) => Promise<{
3
- fileId: string;
4
- }>;
5
- getDownloadUrl: (file: {
6
- fileId: string;
7
- }) => Promise<{
2
+ upload: (file: File) => Promise<import("../index.js").FileMetadata>;
3
+ getDownloadUrl: (file: import("../index.js").FileMetadata) => Promise<{
8
4
  downloadUrl: string;
9
5
  }>;
10
6
  };
@@ -1,7 +1,9 @@
1
+ import { getAdaptor } from "../bridges/index.js";
1
2
  export function useFiles() {
3
+ const adaptor = getAdaptor();
2
4
  return {
3
- upload: window.openai.uploadFile,
4
- getDownloadUrl: window.openai.getFileDownloadUrl,
5
+ upload: adaptor.uploadFile,
6
+ getDownloadUrl: adaptor.getFileDownloadUrl,
5
7
  };
6
8
  }
7
9
  //# sourceMappingURL=use-files.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-files.js","sourceRoot":"","sources":["../../../src/web/hooks/use-files.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,QAAQ;IACtB,OAAO;QACL,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,UAAU;QAChC,cAAc,EAAE,MAAM,CAAC,MAAM,CAAC,kBAAkB;KACjD,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"use-files.js","sourceRoot":"","sources":["../../../src/web/hooks/use-files.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,MAAM,UAAU,QAAQ;IACtB,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAC7B,OAAO;QACL,MAAM,EAAE,OAAO,CAAC,UAAU;QAC1B,cAAc,EAAE,OAAO,CAAC,kBAAkB;KAC3C,CAAC;AACJ,CAAC"}
@@ -7,6 +7,7 @@ describe("useFiles", () => {
7
7
  getFileDownloadUrl: vi.fn(),
8
8
  };
9
9
  beforeEach(() => {
10
+ vi.stubGlobal("skybridge", { hostType: "apps-sdk" });
10
11
  vi.stubGlobal("openai", OpenaiMock);
11
12
  });
12
13
  afterEach(() => {
@@ -1 +1 @@
1
- {"version":3,"file":"use-files.test.js","sourceRoot":"","sources":["../../../src/web/hooks/use-files.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACxB,MAAM,UAAU,GAAG;QACjB,UAAU,EAAE,EAAE,CAAC,EAAE,EAAE;QACnB,kBAAkB,EAAE,EAAE,CAAC,EAAE,EAAE;KAC5B,CAAC;IAEF,UAAU,CAAC,GAAG,EAAE;QACd,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,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IAE3C,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;QAEhD,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACjC,MAAM,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,MAAM,GAAG,KAAK,CAAC;QACrB,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;QAEhD,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QAC1C,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC,oBAAoB,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IACzE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"use-files.test.js","sourceRoot":"","sources":["../../../src/web/hooks/use-files.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACxB,MAAM,UAAU,GAAG;QACjB,UAAU,EAAE,EAAE,CAAC,EAAE,EAAE;QACnB,kBAAkB,EAAE,EAAE,CAAC,EAAE,EAAE;KAC5B,CAAC;IAEF,UAAU,CAAC,GAAG,EAAE;QACd,EAAE,CAAC,UAAU,CAAC,WAAW,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,CAAC,CAAC;QACrD,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,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IAE3C,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;QAEhD,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACjC,MAAM,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,MAAM,GAAG,KAAK,CAAC;QACrB,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;QAEhD,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QAC1C,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC,oBAAoB,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IACzE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,9 +1,9 @@
1
- import { type RequestModalOptions } from "../bridges/apps-sdk/index.js";
1
+ import { type RequestModalOptions } from "../bridges/index.js";
2
2
  /**
3
3
  * Triggers a modal containing the widget rendered in display mode "modal"
4
4
  */
5
5
  export declare function useRequestModal(): {
6
6
  isOpen: boolean;
7
- open: (options: RequestModalOptions) => void;
8
7
  params: Record<string, unknown> | undefined;
8
+ open: (opts: RequestModalOptions) => void;
9
9
  };
@@ -1,14 +1,16 @@
1
- import { useAppsSdkContext, } from "../bridges/apps-sdk/index.js";
1
+ import { useCallback } from "react";
2
+ import { getAdaptor, useHostContext, } from "../bridges/index.js";
2
3
  /**
3
4
  * Triggers a modal containing the widget rendered in display mode "modal"
4
5
  */
5
6
  export function useRequestModal() {
6
- const view = useAppsSdkContext("view");
7
- const isOpen = view?.mode === "modal";
8
- const params = view?.params;
9
- const open = (options) => {
10
- window.openai.requestModal(options);
7
+ const adaptor = getAdaptor();
8
+ const view = useHostContext("view");
9
+ const open = useCallback((opts) => adaptor.openModal(opts), [adaptor]);
10
+ return {
11
+ isOpen: view.mode === "modal",
12
+ params: view.params,
13
+ open,
11
14
  };
12
- return { isOpen, open, params };
13
15
  }
14
16
  //# sourceMappingURL=use-request-modal.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-request-modal.js","sourceRoot":"","sources":["../../../src/web/hooks/use-request-modal.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,GAClB,MAAM,8BAA8B,CAAC;AAEtC;;GAEG;AACH,MAAM,UAAU,eAAe;IAC7B,MAAM,IAAI,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC;IACvC,MAAM,MAAM,GAAG,IAAI,EAAE,IAAI,KAAK,OAAO,CAAC;IACtC,MAAM,MAAM,GAAG,IAAI,EAAE,MAAM,CAAC;IAE5B,MAAM,IAAI,GAAG,CAAC,OAA4B,EAAE,EAAE;QAC5C,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC,CAAC;IAEF,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;AAClC,CAAC"}
1
+ {"version":3,"file":"use-request-modal.js","sourceRoot":"","sources":["../../../src/web/hooks/use-request-modal.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EACL,UAAU,EAEV,cAAc,GACf,MAAM,qBAAqB,CAAC;AAE7B;;GAEG;AACH,MAAM,UAAU,eAAe;IAC7B,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAC7B,MAAM,IAAI,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IACpC,MAAM,IAAI,GAAG,WAAW,CACtB,CAAC,IAAyB,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,EACtD,CAAC,OAAO,CAAC,CACV,CAAC;IACF,OAAO;QACL,MAAM,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO;QAC7B,MAAM,EAAE,IAAI,CAAC,MAAM;QACnB,IAAI;KACL,CAAC;AACJ,CAAC"}
@@ -0,0 +1 @@
1
+ export declare function useSetOpenInAppUrl(): (href: string) => Promise<void>;
@@ -0,0 +1,8 @@
1
+ import { useCallback } from "react";
2
+ import { getAdaptor } from "../bridges/index.js";
3
+ export function useSetOpenInAppUrl() {
4
+ const adaptor = getAdaptor();
5
+ const setOpenInAppUrl = useCallback((href) => adaptor.setOpenInAppUrl(href), [adaptor]);
6
+ return setOpenInAppUrl;
7
+ }
8
+ //# sourceMappingURL=use-set-open-in-app-url.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-set-open-in-app-url.js","sourceRoot":"","sources":["../../../src/web/hooks/use-set-open-in-app-url.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,MAAM,UAAU,kBAAkB;IAChC,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAC7B,MAAM,eAAe,GAAG,WAAW,CACjC,CAAC,IAAY,EAAE,EAAE,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,EAC/C,CAAC,OAAO,CAAC,CACV,CAAC;IAEF,OAAO,eAAe,CAAC;AACzB,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,49 @@
1
+ import { renderHook } from "@testing-library/react";
2
+ import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
3
+ import { AppsSdkAdaptor } from "../bridges/apps-sdk/adaptor.js";
4
+ import { useSetOpenInAppUrl } from "./use-set-open-in-app-url.js";
5
+ describe("useSetOpenInAppUrl", () => {
6
+ describe("apps-sdk host", () => {
7
+ let setOpenInAppUrlMock;
8
+ beforeEach(() => {
9
+ setOpenInAppUrlMock = vi.fn().mockResolvedValue(undefined);
10
+ vi.stubGlobal("openai", {
11
+ setOpenInAppUrl: setOpenInAppUrlMock,
12
+ });
13
+ vi.stubGlobal("skybridge", {
14
+ hostType: "apps-sdk",
15
+ serverUrl: "https://example.com",
16
+ });
17
+ });
18
+ afterEach(() => {
19
+ vi.unstubAllGlobals();
20
+ vi.resetAllMocks();
21
+ AppsSdkAdaptor.resetInstance();
22
+ });
23
+ it("should return a function that calls window.openai.setOpenInAppUrl with the href", async () => {
24
+ const { result } = renderHook(() => useSetOpenInAppUrl());
25
+ const href = "https://example.com/path";
26
+ await result.current(href);
27
+ expect(setOpenInAppUrlMock).toHaveBeenCalledTimes(1);
28
+ expect(setOpenInAppUrlMock).toHaveBeenCalledWith({ href });
29
+ });
30
+ it("should throw an error when href is empty", () => {
31
+ const { result } = renderHook(() => useSetOpenInAppUrl());
32
+ expect(() => result.current("")).toThrow("The href parameter is required.");
33
+ });
34
+ it("should throw an error when serverUrl is not set", () => {
35
+ vi.stubGlobal("skybridge", {
36
+ hostType: "apps-sdk",
37
+ serverUrl: undefined,
38
+ });
39
+ AppsSdkAdaptor.resetInstance();
40
+ const { result } = renderHook(() => useSetOpenInAppUrl());
41
+ expect(() => result.current("https://example.com/path")).toThrow("The widgetDomain property has not been set on the widget resource meta object.");
42
+ });
43
+ it("should throw an error when href origin differs from serverUrl origin", () => {
44
+ const { result } = renderHook(() => useSetOpenInAppUrl());
45
+ expect(() => result.current("https://different-domain.com/path")).toThrow("Provided href is not compatible with widget domain: origin differs");
46
+ });
47
+ });
48
+ });
49
+ //# sourceMappingURL=use-set-open-in-app-url.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-set-open-in-app-url.test.js","sourceRoot":"","sources":["../../../src/web/hooks/use-set-open-in-app-url.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAElE,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;QAC7B,IAAI,mBAA6C,CAAC;QAElD,UAAU,CAAC,GAAG,EAAE;YACd,mBAAmB,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC3D,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE;gBACtB,eAAe,EAAE,mBAAmB;aACrC,CAAC,CAAC;YACH,EAAE,CAAC,UAAU,CAAC,WAAW,EAAE;gBACzB,QAAQ,EAAE,UAAU;gBACpB,SAAS,EAAE,qBAAqB;aACjC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,GAAG,EAAE;YACb,EAAE,CAAC,gBAAgB,EAAE,CAAC;YACtB,EAAE,CAAC,aAAa,EAAE,CAAC;YACnB,cAAc,CAAC,aAAa,EAAE,CAAC;QACjC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iFAAiF,EAAE,KAAK,IAAI,EAAE;YAC/F,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC,CAAC;YAE1D,MAAM,IAAI,GAAG,0BAA0B,CAAC;YACxC,MAAM,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAE3B,MAAM,CAAC,mBAAmB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;YACrD,MAAM,CAAC,mBAAmB,CAAC,CAAC,oBAAoB,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC,CAAC;YAE1D,MAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CACtC,iCAAiC,CAClC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;YACzD,EAAE,CAAC,UAAU,CAAC,WAAW,EAAE;gBACzB,QAAQ,EAAE,UAAU;gBACpB,SAAS,EAAE,SAAS;aACrB,CAAC,CAAC;YACH,cAAc,CAAC,aAAa,EAAE,CAAC;YAE/B,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC,CAAC;YAE1D,MAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC,CAAC,OAAO,CAC9D,gFAAgF,CACjF,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sEAAsE,EAAE,GAAG,EAAE;YAC9E,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC,CAAC;YAE1D,MAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,mCAAmC,CAAC,CAAC,CAAC,OAAO,CACvE,oEAAoE,CACrE,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -14,6 +14,14 @@ export const mountWidget = (component) => {
14
14
  if (import.meta.env.DEV) {
15
15
  installOpenAILoggingProxy();
16
16
  }
17
- rootInstance.render(createElement(StrictMode, null, component));
17
+ const hostType = window.skybridge?.hostType;
18
+ (async () => {
19
+ let app = component;
20
+ if (hostType === "mcp-app") {
21
+ const { ModalProvider } = await import("./components/modal-provider.js");
22
+ app = createElement(ModalProvider, null, component);
23
+ }
24
+ rootInstance.render(createElement(StrictMode, null, app));
25
+ })();
18
26
  };
19
27
  //# sourceMappingURL=mount-widget.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"mount-widget.js","sourceRoot":"","sources":["../../src/web/mount-widget.ts"],"names":[],"mappings":"AAAA,qCAAqC;AAErC,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAClD,OAAO,EAAE,UAAU,EAAa,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,yBAAyB,EAAE,MAAM,YAAY,CAAC;AAEvD,IAAI,YAAY,GAAgB,IAAI,CAAC;AAErC,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,SAA0B,EAAE,EAAE;IACxD,MAAM,WAAW,GAAG,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;IACpD,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;IAC5C,CAAC;IAED,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,YAAY,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;QACxB,yBAAyB,EAAE,CAAC;IAC9B,CAAC;IAED,YAAY,CAAC,MAAM,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC;AAClE,CAAC,CAAC"}
1
+ {"version":3,"file":"mount-widget.js","sourceRoot":"","sources":["../../src/web/mount-widget.ts"],"names":[],"mappings":"AAAA,qCAAqC;AAErC,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAClD,OAAO,EAAE,UAAU,EAAa,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,yBAAyB,EAAE,MAAM,YAAY,CAAC;AAEvD,IAAI,YAAY,GAAgB,IAAI,CAAC;AAErC,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,SAA0B,EAAE,EAAE;IACxD,MAAM,WAAW,GAAG,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;IACpD,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;IAC5C,CAAC;IAED,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,YAAY,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;QACxB,yBAAyB,EAAE,CAAC;IAC9B,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,CAAC,SAAS,EAAE,QAAQ,CAAC;IAE5C,CAAC,KAAK,IAAI,EAAE;QACV,IAAI,GAAG,GAAG,SAAS,CAAC;QACpB,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;YAC3B,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,MAAM,CAAC,gCAAgC,CAAC,CAAC;YACzE,GAAG,GAAG,aAAa,CAAC,aAAa,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC;QACtD,CAAC;QACD,YAAY,CAAC,MAAM,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;IAC5D,CAAC,CAAC,EAAE,CAAC;AACP,CAAC,CAAC"}
@@ -28,6 +28,13 @@ export function skybridge() {
28
28
  input,
29
29
  },
30
30
  },
31
+ experimental: {
32
+ renderBuiltUrl: (filename) => {
33
+ return {
34
+ runtime: `window.skybridge.serverUrl + "/assets/${filename}"`,
35
+ };
36
+ },
37
+ },
31
38
  };
32
39
  },
33
40
  enforce: "pre",
@@ -1 +1 @@
1
- {"version":3,"file":"plugin.js","sourceRoot":"","sources":["../../../src/web/plugin/plugin.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAExE,MAAM,UAAU,SAAS;IACvB,OAAO;QACL,IAAI,EAAE,WAAW;QAEjB,KAAK,CAAC,MAAM,CAAC,MAAM;YACjB,4EAA4E;YAC5E,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,SAAS,CAAC,CAAC;YAC7C,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,CAAC;YAE9C,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;YACjD,MAAM,iBAAiB,GAAG,OAAO,CAC/B,WAAW,EACX,oCAAoC,CACrC,CAAC;YACF,MAAM,gBAAgB,GAAG,OAAO,CAAC,WAAW,EAAE,yBAAyB,CAAC,CAAC;YAEzE,MAAM,WAAW,GAAG,QAAQ,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC;gBAC5D,IAAI,CAAC,KAAK,CAAC,6BAA6B,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC9C,IAAI;aACL,CAAC,CAAC;YACH,MAAM,UAAU,GAAG,QAAQ,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC;gBAC1D,IAAI,CAAC,KAAK,CAAC,oCAAoC,CAAC,EAAE,CAAC,CAAC,CAAC;gBACrD,IAAI;aACL,CAAC,CAAC;YACH,MAAM,KAAK,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC,GAAG,WAAW,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC;YAElE,OAAO;gBACL,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE;oBACL,QAAQ,EAAE,IAAI;oBACd,MAAM,EAAE,IAAI;oBACZ,YAAY,EAAE,KAAK;oBACnB,aAAa,EAAE;wBACb,KAAK;qBACN;iBACF;aACF,CAAC;QACJ,CAAC;QACD,OAAO,EAAE,KAAK;QACd,KAAK,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE;YACtB,OAAO,MAAM,gBAAgB,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAC1C,CAAC;KACF,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"plugin.js","sourceRoot":"","sources":["../../../src/web/plugin/plugin.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAExE,MAAM,UAAU,SAAS;IACvB,OAAO;QACL,IAAI,EAAE,WAAW;QAEjB,KAAK,CAAC,MAAM,CAAC,MAAM;YACjB,4EAA4E;YAC5E,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,SAAS,CAAC,CAAC;YAC7C,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,CAAC;YAE9C,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;YACjD,MAAM,iBAAiB,GAAG,OAAO,CAC/B,WAAW,EACX,oCAAoC,CACrC,CAAC;YACF,MAAM,gBAAgB,GAAG,OAAO,CAAC,WAAW,EAAE,yBAAyB,CAAC,CAAC;YAEzE,MAAM,WAAW,GAAG,QAAQ,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC;gBAC5D,IAAI,CAAC,KAAK,CAAC,6BAA6B,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC9C,IAAI;aACL,CAAC,CAAC;YACH,MAAM,UAAU,GAAG,QAAQ,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC;gBAC1D,IAAI,CAAC,KAAK,CAAC,oCAAoC,CAAC,EAAE,CAAC,CAAC,CAAC;gBACrD,IAAI;aACL,CAAC,CAAC;YACH,MAAM,KAAK,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC,GAAG,WAAW,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC;YAElE,OAAO;gBACL,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE;oBACL,QAAQ,EAAE,IAAI;oBACd,MAAM,EAAE,IAAI;oBACZ,YAAY,EAAE,KAAK;oBACnB,aAAa,EAAE;wBACb,KAAK;qBACN;iBACF;gBACD,YAAY,EAAE;oBACZ,cAAc,EAAE,CAAC,QAAQ,EAAE,EAAE;wBAC3B,OAAO;4BACL,OAAO,EAAE,yCAAyC,QAAQ,GAAG;yBAC9D,CAAC;oBACJ,CAAC;iBACF;aACF,CAAC;QACJ,CAAC;QACD,OAAO,EAAE,KAAK;QACd,KAAK,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE;YACtB,OAAO,MAAM,gBAAgB,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAC1C,CAAC;KACF,CAAC;AACJ,CAAC"}
package/package.json CHANGED
@@ -1,14 +1,15 @@
1
1
  {
2
2
  "name": "skybridge",
3
- "version": "0.0.0-dev.6f1dfd8",
4
- "description": "Skybridge is a framework for building ChatGPT apps",
3
+ "version": "0.0.0-dev.6f5ad0d",
4
+ "description": "Skybridge is a framework for building ChatGPT and MCP Apps",
5
5
  "repository": {
6
6
  "type": "git",
7
7
  "url": "https://github.com/alpic-ai/skybridge.git"
8
8
  },
9
9
  "type": "module",
10
10
  "files": [
11
- "dist"
11
+ "dist",
12
+ "README.md"
12
13
  ],
13
14
  "exports": {
14
15
  "./server": {
@@ -30,34 +31,37 @@
30
31
  "license": "ISC",
31
32
  "peerDependencies": {
32
33
  "@modelcontextprotocol/sdk": ">=1.0.0",
34
+ "nodemon": ">=3.0.0",
33
35
  "react": ">=18.0.0",
34
36
  "react-dom": ">=18.0.0"
35
37
  },
36
38
  "dependencies": {
37
39
  "@babel/core": "^7.28.6",
38
40
  "@oclif/core": "^4.8.0",
41
+ "ci-info": "^4.3.1",
39
42
  "cors": "^2.8.5",
40
43
  "dequal": "^2.0.3",
41
- "es-toolkit": "^1.43.0",
44
+ "es-toolkit": "^1.44.0",
42
45
  "express": "^5.2.1",
43
46
  "handlebars": "^4.7.8",
44
47
  "ink": "^6.6.0",
48
+ "posthog-node": "^5.24.1",
45
49
  "superjson": "^2.2.6",
46
50
  "vite": "^7.3.1",
47
51
  "zustand": "^5.0.10"
48
52
  },
49
53
  "devDependencies": {
50
- "@modelcontextprotocol/ext-apps": "^0.4.0",
51
- "@modelcontextprotocol/sdk": "^1.25.2",
54
+ "@modelcontextprotocol/ext-apps": "^0.4.1",
55
+ "@modelcontextprotocol/sdk": "^1.25.3",
52
56
  "@testing-library/dom": "^10.4.1",
53
- "@testing-library/react": "^16.3.1",
57
+ "@testing-library/react": "^16.3.2",
54
58
  "@total-typescript/tsconfig": "^1.0.4",
55
59
  "@types/babel__core": "^7.20.5",
56
60
  "@types/cors": "^2.8.19",
57
61
  "@types/express": "^5.0.6",
58
62
  "@types/jsdom": "^27.0.0",
59
- "@types/node": "^24.10.8",
60
- "@types/react": "^19.2.8",
63
+ "@types/node": "^24.10.9",
64
+ "@types/react": "^19.2.9",
61
65
  "@types/react-dom": "^19.2.3",
62
66
  "@vitest/ui": "^4.0.17",
63
67
  "jsdom": "^27.4.0",
@@ -75,7 +79,10 @@
75
79
  "bin": "skybridge",
76
80
  "commands": "./dist/commands",
77
81
  "dirname": "skybridge",
78
- "topicSeparator": " "
82
+ "topicSeparator": " ",
83
+ "hooks": {
84
+ "finally": "./dist/cli/telemetry"
85
+ }
79
86
  },
80
87
  "scripts": {
81
88
  "build": "shx rm -rf dist && tsc && pnpm run build:templates",