skybridge 0.0.0-dev.e4c9359 → 0.0.0-dev.e508ce2

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 (359) hide show
  1. package/LICENSE +21 -674
  2. package/README.md +86 -264
  3. package/bin/run.js +5 -0
  4. package/dist/cli/detect-port.d.ts +18 -0
  5. package/dist/cli/detect-port.js +61 -0
  6. package/dist/cli/detect-port.js.map +1 -0
  7. package/dist/cli/header.d.ts +4 -0
  8. package/dist/cli/header.js +6 -0
  9. package/dist/cli/header.js.map +1 -0
  10. package/dist/cli/run-command.d.ts +2 -0
  11. package/dist/cli/run-command.js +43 -0
  12. package/dist/cli/run-command.js.map +1 -0
  13. package/dist/cli/telemetry.d.ts +7 -0
  14. package/dist/cli/telemetry.js +123 -0
  15. package/dist/cli/telemetry.js.map +1 -0
  16. package/dist/cli/use-execute-steps.d.ts +11 -0
  17. package/dist/cli/use-execute-steps.js +36 -0
  18. package/dist/cli/use-execute-steps.js.map +1 -0
  19. package/dist/cli/use-nodemon.d.ts +7 -0
  20. package/dist/cli/use-nodemon.js +76 -0
  21. package/dist/cli/use-nodemon.js.map +1 -0
  22. package/dist/cli/use-typescript-check.d.ts +8 -0
  23. package/dist/cli/use-typescript-check.js +59 -0
  24. package/dist/cli/use-typescript-check.js.map +1 -0
  25. package/dist/commands/build.d.ts +9 -0
  26. package/dist/commands/build.js +46 -0
  27. package/dist/commands/build.js.map +1 -0
  28. package/dist/commands/dev.d.ts +10 -0
  29. package/dist/commands/dev.js +42 -0
  30. package/dist/commands/dev.js.map +1 -0
  31. package/dist/commands/start.d.ts +9 -0
  32. package/dist/commands/start.js +52 -0
  33. package/dist/commands/start.js.map +1 -0
  34. package/dist/commands/telemetry/disable.d.ts +5 -0
  35. package/dist/commands/telemetry/disable.js +14 -0
  36. package/dist/commands/telemetry/disable.js.map +1 -0
  37. package/dist/commands/telemetry/enable.d.ts +5 -0
  38. package/dist/commands/telemetry/enable.js +14 -0
  39. package/dist/commands/telemetry/enable.js.map +1 -0
  40. package/dist/commands/telemetry/status.d.ts +5 -0
  41. package/dist/commands/telemetry/status.js +14 -0
  42. package/dist/commands/telemetry/status.js.map +1 -0
  43. package/dist/server/asset-base-url-transform-plugin.d.ts +11 -0
  44. package/dist/server/asset-base-url-transform-plugin.js +34 -0
  45. package/dist/server/asset-base-url-transform-plugin.js.map +1 -0
  46. package/dist/server/asset-base-url-transform-plugin.test.js +56 -0
  47. package/dist/server/asset-base-url-transform-plugin.test.js.map +1 -0
  48. package/dist/server/const.d.ts +1 -0
  49. package/dist/server/const.js +2 -0
  50. package/dist/server/const.js.map +1 -0
  51. package/dist/server/express.d.ts +9 -0
  52. package/dist/server/express.js +72 -0
  53. package/dist/server/express.js.map +1 -0
  54. package/dist/server/express.test.js +74 -0
  55. package/dist/server/express.test.js.map +1 -0
  56. package/dist/server/index.d.ts +5 -0
  57. package/dist/server/index.js.map +1 -0
  58. package/dist/server/inferUtilityTypes.d.ts +64 -0
  59. package/dist/server/inferUtilityTypes.js.map +1 -0
  60. package/dist/server/middleware.d.ts +96 -0
  61. package/dist/server/middleware.js +93 -0
  62. package/dist/server/middleware.js.map +1 -0
  63. package/dist/server/middleware.test-d.js +52 -0
  64. package/dist/server/middleware.test-d.js.map +1 -0
  65. package/dist/server/middleware.test.js +383 -0
  66. package/dist/server/middleware.test.js.map +1 -0
  67. package/dist/server/server.d.ts +139 -0
  68. package/dist/server/server.js +259 -0
  69. package/dist/server/server.js.map +1 -0
  70. package/dist/{src/server → server}/templateHelper.d.ts +4 -0
  71. package/dist/{src/server → server}/templateHelper.js +5 -4
  72. package/dist/server/templateHelper.js.map +1 -0
  73. package/dist/server/templates/development.hbs +67 -0
  74. package/dist/{src/server → server}/templates/production.hbs +1 -1
  75. package/dist/{src/server → server}/widgetsDevServer.d.ts +2 -2
  76. package/dist/server/widgetsDevServer.js +63 -0
  77. package/dist/server/widgetsDevServer.js.map +1 -0
  78. package/dist/{src/test → test}/utils.d.ts +54 -8
  79. package/dist/{src/test → test}/utils.js +86 -8
  80. package/dist/test/utils.js.map +1 -0
  81. package/dist/test/widget.test.js +261 -0
  82. package/dist/test/widget.test.js.map +1 -0
  83. package/dist/web/bridges/apps-sdk/adaptor.d.ts +22 -0
  84. package/dist/web/bridges/apps-sdk/adaptor.js +75 -0
  85. package/dist/web/bridges/apps-sdk/adaptor.js.map +1 -0
  86. package/dist/web/bridges/apps-sdk/bridge.d.ts +10 -0
  87. package/dist/web/bridges/apps-sdk/bridge.js +46 -0
  88. package/dist/web/bridges/apps-sdk/bridge.js.map +1 -0
  89. package/dist/web/bridges/apps-sdk/index.d.ts +5 -0
  90. package/dist/web/bridges/apps-sdk/index.js +5 -0
  91. package/dist/web/bridges/apps-sdk/index.js.map +1 -0
  92. package/dist/{src/web → web/bridges/apps-sdk}/types.d.ts +37 -39
  93. package/dist/web/bridges/apps-sdk/types.js.map +1 -0
  94. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.d.ts +2 -0
  95. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.js +7 -0
  96. package/dist/web/bridges/apps-sdk/use-apps-sdk-context.js.map +1 -0
  97. package/dist/web/bridges/get-adaptor.d.ts +2 -0
  98. package/dist/web/bridges/get-adaptor.js +8 -0
  99. package/dist/web/bridges/get-adaptor.js.map +1 -0
  100. package/dist/web/bridges/index.d.ts +5 -0
  101. package/dist/web/bridges/index.js +6 -0
  102. package/dist/web/bridges/index.js.map +1 -0
  103. package/dist/web/bridges/mcp-app/adaptor.d.ts +36 -0
  104. package/dist/web/bridges/mcp-app/adaptor.js +190 -0
  105. package/dist/web/bridges/mcp-app/adaptor.js.map +1 -0
  106. package/dist/web/bridges/mcp-app/bridge.d.ts +43 -0
  107. package/dist/web/bridges/mcp-app/bridge.js +260 -0
  108. package/dist/web/bridges/mcp-app/bridge.js.map +1 -0
  109. package/dist/web/bridges/mcp-app/index.d.ts +4 -0
  110. package/dist/web/bridges/mcp-app/index.js +4 -0
  111. package/dist/web/bridges/mcp-app/index.js.map +1 -0
  112. package/dist/web/bridges/mcp-app/types.d.ts +8 -0
  113. package/dist/web/bridges/mcp-app/types.js +2 -0
  114. package/dist/web/bridges/mcp-app/types.js.map +1 -0
  115. package/dist/web/bridges/mcp-app/use-mcp-app-context.d.ts +5 -0
  116. package/dist/web/bridges/mcp-app/use-mcp-app-context.js +7 -0
  117. package/dist/web/bridges/mcp-app/use-mcp-app-context.js.map +1 -0
  118. package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js +66 -0
  119. package/dist/web/bridges/mcp-app/use-mcp-app-context.test.js.map +1 -0
  120. package/dist/web/bridges/types.d.ts +102 -0
  121. package/dist/web/bridges/types.js +2 -0
  122. package/dist/web/bridges/types.js.map +1 -0
  123. package/dist/web/bridges/use-host-context.d.ts +2 -0
  124. package/dist/web/bridges/use-host-context.js +8 -0
  125. package/dist/web/bridges/use-host-context.js.map +1 -0
  126. package/dist/web/components/modal-provider.d.ts +4 -0
  127. package/dist/web/components/modal-provider.js +47 -0
  128. package/dist/web/components/modal-provider.js.map +1 -0
  129. package/dist/web/create-store.d.ts +3 -0
  130. package/dist/web/create-store.js +24 -0
  131. package/dist/web/create-store.js.map +1 -0
  132. package/dist/web/create-store.test.js +129 -0
  133. package/dist/web/create-store.test.js.map +1 -0
  134. package/dist/web/data-llm.d.ts +14 -0
  135. package/dist/web/data-llm.js +72 -0
  136. package/dist/web/data-llm.js.map +1 -0
  137. package/dist/web/data-llm.test.js +141 -0
  138. package/dist/web/data-llm.test.js.map +1 -0
  139. package/dist/{src/web/typed-hooks.d.ts → web/generate-helpers.d.ts} +25 -21
  140. package/dist/{src/web/typed-hooks.js → web/generate-helpers.js} +15 -11
  141. package/dist/web/generate-helpers.js.map +1 -0
  142. package/dist/web/generate-helpers.test-d.js +209 -0
  143. package/dist/web/generate-helpers.test-d.js.map +1 -0
  144. package/dist/{src/web/typed-hooks.test.js → web/generate-helpers.test.js} +5 -5
  145. package/dist/web/generate-helpers.test.js.map +1 -0
  146. package/dist/web/helpers/state.d.ts +7 -0
  147. package/dist/web/helpers/state.js +45 -0
  148. package/dist/web/helpers/state.js.map +1 -0
  149. package/dist/web/helpers/state.test.js +53 -0
  150. package/dist/web/helpers/state.test.js.map +1 -0
  151. package/dist/web/hooks/index.d.ts +11 -0
  152. package/dist/{src/web/hooks/index.d.ts → web/hooks/index.js} +5 -7
  153. package/dist/web/hooks/index.js.map +1 -0
  154. package/dist/web/hooks/test/utils.d.ts +16 -0
  155. package/dist/web/hooks/test/utils.js +60 -0
  156. package/dist/web/hooks/test/utils.js.map +1 -0
  157. package/dist/{src/web → web}/hooks/use-call-tool.d.ts +22 -20
  158. package/dist/{src/web → web}/hooks/use-call-tool.js +19 -19
  159. package/dist/web/hooks/use-call-tool.js.map +1 -0
  160. package/dist/web/hooks/use-call-tool.test-d.js +104 -0
  161. package/dist/web/hooks/use-call-tool.test-d.js.map +1 -0
  162. package/dist/{src/web → web}/hooks/use-call-tool.test.js +40 -13
  163. package/dist/web/hooks/use-call-tool.test.js.map +1 -0
  164. package/dist/web/hooks/use-display-mode.d.ts +4 -0
  165. package/dist/web/hooks/use-display-mode.js +9 -0
  166. package/dist/web/hooks/use-display-mode.js.map +1 -0
  167. package/dist/web/hooks/use-display-mode.test-d.js +8 -0
  168. package/dist/web/hooks/use-display-mode.test-d.js.map +1 -0
  169. package/dist/web/hooks/use-display-mode.test.d.ts +1 -0
  170. package/dist/{src/web → web}/hooks/use-display-mode.test.js +3 -2
  171. package/dist/web/hooks/use-display-mode.test.js.map +1 -0
  172. package/dist/web/hooks/use-files.d.ts +6 -0
  173. package/dist/web/hooks/use-files.js +9 -0
  174. package/dist/web/hooks/use-files.js.map +1 -0
  175. package/dist/web/hooks/use-files.test.d.ts +1 -0
  176. package/dist/{src/web → web}/hooks/use-files.test.js +11 -6
  177. package/dist/web/hooks/use-files.test.js.map +1 -0
  178. package/dist/web/hooks/use-layout.d.ts +22 -0
  179. package/dist/web/hooks/use-layout.js +23 -0
  180. package/dist/web/hooks/use-layout.js.map +1 -0
  181. package/dist/web/hooks/use-layout.test.d.ts +1 -0
  182. package/dist/web/hooks/use-layout.test.js +96 -0
  183. package/dist/web/hooks/use-layout.test.js.map +1 -0
  184. package/dist/web/hooks/use-open-external.d.ts +3 -0
  185. package/dist/web/hooks/use-open-external.js +8 -0
  186. package/dist/web/hooks/use-open-external.js.map +1 -0
  187. package/dist/web/hooks/use-open-external.test.d.ts +1 -0
  188. package/dist/web/hooks/use-open-external.test.js +60 -0
  189. package/dist/web/hooks/use-open-external.test.js.map +1 -0
  190. package/dist/web/hooks/use-request-modal.d.ts +9 -0
  191. package/dist/web/hooks/use-request-modal.js +16 -0
  192. package/dist/web/hooks/use-request-modal.js.map +1 -0
  193. package/dist/web/hooks/use-request-modal.test.d.ts +1 -0
  194. package/dist/web/hooks/use-request-modal.test.js +57 -0
  195. package/dist/web/hooks/use-request-modal.test.js.map +1 -0
  196. package/dist/web/hooks/use-send-follow-up-message.js +8 -0
  197. package/dist/web/hooks/use-send-follow-up-message.js.map +1 -0
  198. package/dist/web/hooks/use-set-open-in-app-url.d.ts +1 -0
  199. package/dist/web/hooks/use-set-open-in-app-url.js +8 -0
  200. package/dist/web/hooks/use-set-open-in-app-url.js.map +1 -0
  201. package/dist/web/hooks/use-set-open-in-app-url.test.d.ts +1 -0
  202. package/dist/web/hooks/use-set-open-in-app-url.test.js +43 -0
  203. package/dist/web/hooks/use-set-open-in-app-url.test.js.map +1 -0
  204. package/dist/{src/web → web}/hooks/use-tool-info.d.ts +13 -2
  205. package/dist/web/hooks/use-tool-info.js +26 -0
  206. package/dist/web/hooks/use-tool-info.js.map +1 -0
  207. package/dist/web/hooks/use-tool-info.test-d.d.ts +1 -0
  208. package/dist/{src/web → web}/hooks/use-tool-info.test-d.js +40 -5
  209. package/dist/web/hooks/use-tool-info.test-d.js.map +1 -0
  210. package/dist/web/hooks/use-tool-info.test.d.ts +1 -0
  211. package/dist/web/hooks/use-tool-info.test.js +130 -0
  212. package/dist/web/hooks/use-tool-info.test.js.map +1 -0
  213. package/dist/web/hooks/use-user.d.ts +18 -0
  214. package/dist/web/hooks/use-user.js +19 -0
  215. package/dist/web/hooks/use-user.js.map +1 -0
  216. package/dist/web/hooks/use-user.test.d.ts +1 -0
  217. package/dist/web/hooks/use-user.test.js +94 -0
  218. package/dist/web/hooks/use-user.test.js.map +1 -0
  219. package/dist/web/hooks/use-widget-state.js +32 -0
  220. package/dist/web/hooks/use-widget-state.js.map +1 -0
  221. package/dist/web/hooks/use-widget-state.test.d.ts +1 -0
  222. package/dist/{src/web → web}/hooks/use-widget-state.test.js +12 -8
  223. package/dist/web/hooks/use-widget-state.test.js.map +1 -0
  224. package/dist/web/index.d.ts +8 -0
  225. package/dist/web/index.js +9 -0
  226. package/dist/web/index.js.map +1 -0
  227. package/dist/{src/web → web}/mount-widget.js +9 -1
  228. package/dist/web/mount-widget.js.map +1 -0
  229. package/dist/web/plugin/data-llm.test.d.ts +1 -0
  230. package/dist/web/plugin/data-llm.test.js +81 -0
  231. package/dist/web/plugin/data-llm.test.js.map +1 -0
  232. package/dist/web/plugin/plugin.js +54 -0
  233. package/dist/web/plugin/plugin.js.map +1 -0
  234. package/dist/web/plugin/transform-data-llm.d.ts +12 -0
  235. package/dist/web/plugin/transform-data-llm.js +96 -0
  236. package/dist/web/plugin/transform-data-llm.js.map +1 -0
  237. package/dist/web/plugin/transform-data-llm.test.d.ts +1 -0
  238. package/dist/web/plugin/transform-data-llm.test.js +81 -0
  239. package/dist/web/plugin/transform-data-llm.test.js.map +1 -0
  240. package/dist/web/plugin/validate-widget.d.ts +5 -0
  241. package/dist/web/plugin/validate-widget.js +27 -0
  242. package/dist/web/plugin/validate-widget.js.map +1 -0
  243. package/dist/web/plugin/validate-widget.test.d.ts +1 -0
  244. package/dist/web/plugin/validate-widget.test.js +42 -0
  245. package/dist/web/plugin/validate-widget.test.js.map +1 -0
  246. package/dist/{src/web → web}/proxy.js +6 -2
  247. package/dist/web/proxy.js.map +1 -0
  248. package/dist/web/types.d.ts +16 -0
  249. package/dist/web/types.js +2 -0
  250. package/dist/web/types.js.map +1 -0
  251. package/package.json +69 -34
  252. package/tsconfig.base.json +28 -0
  253. package/dist/src/server/index.d.ts +0 -4
  254. package/dist/src/server/index.js.map +0 -1
  255. package/dist/src/server/inferUtilityTypes.d.ts +0 -48
  256. package/dist/src/server/inferUtilityTypes.js.map +0 -1
  257. package/dist/src/server/server.d.ts +0 -35
  258. package/dist/src/server/server.js +0 -62
  259. package/dist/src/server/server.js.map +0 -1
  260. package/dist/src/server/templateHelper.js.map +0 -1
  261. package/dist/src/server/templates/development.hbs +0 -12
  262. package/dist/src/server/widgetsDevServer.js +0 -39
  263. package/dist/src/server/widgetsDevServer.js.map +0 -1
  264. package/dist/src/test/utils.js.map +0 -1
  265. package/dist/src/test/widget.test.js +0 -90
  266. package/dist/src/test/widget.test.js.map +0 -1
  267. package/dist/src/web/hooks/index.js +0 -15
  268. package/dist/src/web/hooks/index.js.map +0 -1
  269. package/dist/src/web/hooks/use-call-tool.js.map +0 -1
  270. package/dist/src/web/hooks/use-call-tool.test.js.map +0 -1
  271. package/dist/src/web/hooks/use-display-mode.d.ts +0 -4
  272. package/dist/src/web/hooks/use-display-mode.js +0 -7
  273. package/dist/src/web/hooks/use-display-mode.js.map +0 -1
  274. package/dist/src/web/hooks/use-display-mode.test.js.map +0 -1
  275. package/dist/src/web/hooks/use-files.d.ts +0 -10
  276. package/dist/src/web/hooks/use-files.js +0 -7
  277. package/dist/src/web/hooks/use-files.js.map +0 -1
  278. package/dist/src/web/hooks/use-files.test.js.map +0 -1
  279. package/dist/src/web/hooks/use-locale.d.ts +0 -1
  280. package/dist/src/web/hooks/use-locale.js +0 -5
  281. package/dist/src/web/hooks/use-locale.js.map +0 -1
  282. package/dist/src/web/hooks/use-locale.test.js +0 -21
  283. package/dist/src/web/hooks/use-locale.test.js.map +0 -1
  284. package/dist/src/web/hooks/use-open-external.d.ts +0 -1
  285. package/dist/src/web/hooks/use-open-external.js +0 -6
  286. package/dist/src/web/hooks/use-open-external.js.map +0 -1
  287. package/dist/src/web/hooks/use-open-external.test.js +0 -24
  288. package/dist/src/web/hooks/use-open-external.test.js.map +0 -1
  289. package/dist/src/web/hooks/use-openai-global.d.ts +0 -2
  290. package/dist/src/web/hooks/use-openai-global.js +0 -23
  291. package/dist/src/web/hooks/use-openai-global.js.map +0 -1
  292. package/dist/src/web/hooks/use-request-modal.d.ts +0 -6
  293. package/dist/src/web/hooks/use-request-modal.js +0 -9
  294. package/dist/src/web/hooks/use-request-modal.js.map +0 -1
  295. package/dist/src/web/hooks/use-request-modal.test.js +0 -24
  296. package/dist/src/web/hooks/use-request-modal.test.js.map +0 -1
  297. package/dist/src/web/hooks/use-send-follow-up-message.js +0 -11
  298. package/dist/src/web/hooks/use-send-follow-up-message.js.map +0 -1
  299. package/dist/src/web/hooks/use-theme.d.ts +0 -1
  300. package/dist/src/web/hooks/use-theme.js +0 -5
  301. package/dist/src/web/hooks/use-theme.js.map +0 -1
  302. package/dist/src/web/hooks/use-theme.test.js +0 -26
  303. package/dist/src/web/hooks/use-theme.test.js.map +0 -1
  304. package/dist/src/web/hooks/use-tool-info.js +0 -22
  305. package/dist/src/web/hooks/use-tool-info.js.map +0 -1
  306. package/dist/src/web/hooks/use-tool-info.test-d.js.map +0 -1
  307. package/dist/src/web/hooks/use-tool-info.test.js +0 -59
  308. package/dist/src/web/hooks/use-tool-info.test.js.map +0 -1
  309. package/dist/src/web/hooks/use-tool-output.d.ts +0 -4
  310. package/dist/src/web/hooks/use-tool-output.js +0 -9
  311. package/dist/src/web/hooks/use-tool-output.js.map +0 -1
  312. package/dist/src/web/hooks/use-tool-response-metadata.d.ts +0 -4
  313. package/dist/src/web/hooks/use-tool-response-metadata.js +0 -8
  314. package/dist/src/web/hooks/use-tool-response-metadata.js.map +0 -1
  315. package/dist/src/web/hooks/use-user-agent.d.ts +0 -1
  316. package/dist/src/web/hooks/use-user-agent.js +0 -5
  317. package/dist/src/web/hooks/use-user-agent.js.map +0 -1
  318. package/dist/src/web/hooks/use-user-agent.test.js +0 -31
  319. package/dist/src/web/hooks/use-user-agent.test.js.map +0 -1
  320. package/dist/src/web/hooks/use-widget-state.js +0 -30
  321. package/dist/src/web/hooks/use-widget-state.js.map +0 -1
  322. package/dist/src/web/hooks/use-widget-state.test.js.map +0 -1
  323. package/dist/src/web/index.d.ts +0 -5
  324. package/dist/src/web/index.js +0 -6
  325. package/dist/src/web/index.js.map +0 -1
  326. package/dist/src/web/mount-widget.js.map +0 -1
  327. package/dist/src/web/plugin.js +0 -28
  328. package/dist/src/web/plugin.js.map +0 -1
  329. package/dist/src/web/proxy.js.map +0 -1
  330. package/dist/src/web/typed-hooks.js.map +0 -1
  331. package/dist/src/web/typed-hooks.test-d.js +0 -90
  332. package/dist/src/web/typed-hooks.test-d.js.map +0 -1
  333. package/dist/src/web/typed-hooks.test.js.map +0 -1
  334. package/dist/src/web/types.js.map +0 -1
  335. package/dist/vitest.config.d.ts +0 -2
  336. package/dist/vitest.config.js +0 -8
  337. package/dist/vitest.config.js.map +0 -1
  338. /package/dist/{src/test/widget.test.d.ts → server/asset-base-url-transform-plugin.test.d.ts} +0 -0
  339. /package/dist/{src/web/hooks/use-call-tool.test.d.ts → server/express.test.d.ts} +0 -0
  340. /package/dist/{src/server → server}/index.js +0 -0
  341. /package/dist/{src/server → server}/inferUtilityTypes.js +0 -0
  342. /package/dist/{src/web/hooks/use-display-mode.test.d.ts → server/middleware.test-d.d.ts} +0 -0
  343. /package/dist/{src/web/hooks/use-files.test.d.ts → server/middleware.test.d.ts} +0 -0
  344. /package/dist/{src/web/hooks/use-locale.test.d.ts → test/widget.test.d.ts} +0 -0
  345. /package/dist/{src/web → web/bridges/apps-sdk}/types.js +0 -0
  346. /package/dist/{src/web/hooks/use-open-external.test.d.ts → web/bridges/mcp-app/use-mcp-app-context.test.d.ts} +0 -0
  347. /package/dist/{src/web/hooks/use-request-modal.test.d.ts → web/create-store.test.d.ts} +0 -0
  348. /package/dist/{src/web/hooks/use-theme.test.d.ts → web/data-llm.test.d.ts} +0 -0
  349. /package/dist/{src/web/hooks/use-tool-info.test-d.d.ts → web/generate-helpers.test-d.d.ts} +0 -0
  350. /package/dist/{src/web/hooks/use-tool-info.test.d.ts → web/generate-helpers.test.d.ts} +0 -0
  351. /package/dist/{src/web/hooks/use-user-agent.test.d.ts → web/helpers/state.test.d.ts} +0 -0
  352. /package/dist/{src/web/hooks/use-widget-state.test.d.ts → web/hooks/use-call-tool.test-d.d.ts} +0 -0
  353. /package/dist/{src/web/typed-hooks.test-d.d.ts → web/hooks/use-call-tool.test.d.ts} +0 -0
  354. /package/dist/{src/web/typed-hooks.test.d.ts → web/hooks/use-display-mode.test-d.d.ts} +0 -0
  355. /package/dist/{src/web → web}/hooks/use-send-follow-up-message.d.ts +0 -0
  356. /package/dist/{src/web → web}/hooks/use-widget-state.d.ts +0 -0
  357. /package/dist/{src/web → web}/mount-widget.d.ts +0 -0
  358. /package/dist/{src/web → web/plugin}/plugin.d.ts +0 -0
  359. /package/dist/{src/web → web}/proxy.d.ts +0 -0
package/README.md CHANGED
@@ -1,323 +1,145 @@
1
1
  <div align="center">
2
2
 
3
- # Skybridge
4
-
5
- **Skybridge is the TypeScript framework for building ChatGPT apps**
6
-
7
- [![By Alpic](https://img.shields.io/badge/Made%20by%20Alpic-f6ffed?logo=alpic)](https://alpic.ai)
3
+ <img alt="Skybridge" src="https://raw.githubusercontent.com/alpic-ai/skybridge/main/docs/images/github-banner.png" width="100%">
8
4
 
9
- ![NPM Downloads](https://img.shields.io/npm/dm/skybridge?color=e90060)
10
- ![NPM Version](https://img.shields.io/npm/v/skybridge?color=e90060)
11
- ![GitHub License](https://img.shields.io/github/license/alpic-ai/skybridge?color=e90060)
12
-
13
- </div>
5
+ <br />
14
6
 
15
- Skybridge comes with 2 packages:
7
+ # Skybridge
16
8
 
17
- - `skybridge/server`: A drop-in replacement of the `@modelcontextprotocol/sdk` official `McpServer` class with extra features for widget development.
18
- - `skybridge/web`: A react library with hooks and components to build widgets on the underlying _OpenAI iFrame skybridge_ runtime.
9
+ **Build ChatGPT & MCP Apps. The Modern TypeScript Way.**
19
10
 
20
- ## Quick start
11
+ The fullstack TypeScript framework for AI-embedded widgets.<br />
12
+ **Type-safe. React-powered. Platform-agnostic.**
21
13
 
22
- To get started in less than a minute, you can [create a new repository](https://github.com/new?template_name=apps-sdk-template&template_owner=alpic-ai) using our [ChatGPT SDK template](https://github.com/alpic-ai/apps-sdk-template). This template includes a basic setup for both the server and the widgets.
14
+ <br />
23
15
 
24
- ## Installation
16
+ [![NPM Version](https://img.shields.io/npm/v/skybridge?color=e90060&style=for-the-badge)](https://www.npmjs.com/package/skybridge)
17
+ [![NPM Downloads](https://img.shields.io/npm/dm/skybridge?color=e90060&style=for-the-badge)](https://www.npmjs.com/package/skybridge)
18
+ [![GitHub License](https://img.shields.io/github/license/alpic-ai/skybridge?color=e90060&style=for-the-badge)](https://github.com/alpic-ai/skybridge/blob/main/LICENSE)
25
19
 
26
- ```bash
27
- pnpm add skybridge
28
- ```
20
+ <br />
29
21
 
30
- ## Concepts
22
+ [Documentation](https://docs.skybridge.tech) · [Quick Start](https://docs.skybridge.tech/quickstart/create-new-app) · [Showcase](https://docs.skybridge.tech/showcase)
31
23
 
32
- ### Widgets
24
+ </div>
33
25
 
34
- > A widget is a UI component that turns structured tool results into a human-friendly UI. Those are built using React components. They are rendered inside an iframe inline with the conversation on ChatGPT.
26
+ <br />
35
27
 
36
- Each widget in your app must have a unique name. The name is used to bridge the tool invocation result with the widget React component.
28
+ ## Why Skybridge?
37
29
 
38
- For example, in order to register a new widget named `pokemon` on your ChatGPT app. You should have the following file structure and file contents:
30
+ ChatGPT Apps and MCP Apps let you embed **rich, interactive UIs** directly in AI conversations. But the raw SDKs are low-level—no hooks, no type safety, no dev tools, and no HMR.
39
31
 
40
- _Project structure_
32
+ **Skybridge fixes that.**
41
33
 
42
- ```
43
- server/
44
- └── src/
45
- └── index.ts // Register the widget with McpServer.widget()
46
- web/
47
- └── src/
48
- └── widgets/
49
- └── pokemon.tsx // Use the same widget name as the file name
50
- ```
34
+ | | |
35
+ |:--|:--|
36
+ | 👨‍💻 **Full Dev Environment** — HMR, debug traces, and local devtools. No more refresh loops. | ✅ **End-to-End Type Safety** — tRPC-style inference from server to widget. Autocomplete everywhere. |
37
+ | 🔄 **Widget-to-Model Sync** — Keep the model aware of UI state with `data-llm`. Dual surfaces, one source of truth. | ⚒️ **React Query-style Hooks** — `isPending`, `isError`, callbacks. State management you already know. |
38
+ | 🌐 **Platform Agnostic** — Write once, run anywhere. Works with ChatGPT (Apps SDK) and MCP-compatible clients. | 📦 **Showcase Examples** — Production-ready examples to learn from and build upon. |
51
39
 
52
- _server/src/index.ts_
40
+ <br />
53
41
 
54
- ```ts
55
- import { McpServer } from "skybridge/server";
42
+ ## 🚀 Get Started
56
43
 
57
- const server = new McpServer();
44
+ **Create a new app:**
58
45
 
59
- server.widget(
60
- "pokemon"
61
- // Remaining arguments...
62
- );
46
+ ```bash
47
+ npm create skybridge@latest
63
48
  ```
64
49
 
65
- _web/src/widgets/pokemon.tsx_
50
+ **Or add to an existing project:**
66
51
 
67
- ```ts
68
- import { mountWidget } from "skybridge/web";
69
-
70
- const Pokemon: React.FunctionComponent = () => {
71
- // Your React component code goes here...
72
- };
73
-
74
- mountWidget(<Pokemon />);
52
+ ```bash
53
+ npm i skybridge
54
+ yarn add skybridge
55
+ pnpm add skybridge
56
+ bun add skybridge
57
+ deno add skybridge
75
58
  ```
76
59
 
77
- ## Packages
78
-
79
- ### skybridge/server
80
-
81
- The `skybridge/server` package is a drop-in replacement of the `@modelcontextprotocol/sdk` official `McpServer` class with extra features for widget development. If you're already using the `@modelcontextprotocol/sdk`, you can simply replace your `McpServer` import with `skybridge/server` and you're good to go.
82
-
83
- ### skybridge/web
84
-
85
- The `skybridge/web` package is a react library with hooks and components to build widgets on the underlying _OpenAI iFrame skybridge_ runtime.
86
-
87
- **Vite plugin**
60
+ <div align="center">
88
61
 
89
- The `skybridge/web` package comes with a Vite plugin that allows you to build your widgets as regular Vite apps.
62
+ **👉 [Read the Docs](https://docs.skybridge.tech) 👈**
90
63
 
91
- ```ts
92
- import { defineConfig } from "vite";
93
- import { skybridge } from "skybridge/web";
64
+ </div>
94
65
 
95
- export default defineConfig({
96
- plugins: [skybridge()],
97
- });
98
- ```
66
+ <br />
99
67
 
100
- **Typed Hooks**
68
+ ## 📦 Architecture
101
69
 
102
- Skybridge provides fully typed hooks that give you autocomplete for tool names and type inference for inputs/outputs - similar to tRPC. This is opt-in and requires exporting your server type.
70
+ Skybridge is a fullstack framework with unified server and client modules:
103
71
 
104
- > **Tip:** For the best TypeScript experience, use typed hooks throughout your application. They provide autocomplete, type safety, and better IDE support.
72
+ - **`skybridge/server`** Define tools and widgets with full type inference. Extends the MCP SDK.
73
+ - **`skybridge/web`** — React hooks that consume your server types. Works with Apps SDK (ChatGPT) and MCP Apps.
74
+ - **Dev Environment** — Vite plugin with HMR, DevTools emulator, and optimized builds.
105
75
 
106
- _Server setup (server/src/index.ts)_
76
+ ### Server
107
77
 
108
78
  ```ts
109
79
  import { McpServer } from "skybridge/server";
110
- import { z } from "zod";
111
-
112
- const server = new McpServer({ name: "my-app", version: "1.0" }, {})
113
- .widget("search-voyage", {}, {
114
- description: "Search for trips",
115
- inputSchema: {
116
- destination: z.string(),
117
- departureDate: z.string().optional(),
118
- },
119
- outputSchema: {
120
- results: z.array(z.object({ id: z.string(), name: z.string() })),
121
- totalCount: z.number(),
122
- },
123
- }, async ({ destination }) => {
124
- // Your tool logic here...
125
- return { content: [{ type: "text", text: `Found trips to ${destination}` }] };
126
- })
127
- .widget("get-details", {}, {
128
- inputSchema: { tripId: z.string() },
129
- }, async ({ tripId }) => {
130
- return { content: [{ type: "text", text: `Details for ${tripId}` }] };
131
- });
132
-
133
- // Export the server type for the client
134
- export type AppType = typeof server;
135
- ```
136
-
137
- _One-time setup (web/src/skybridge.ts)_
138
-
139
- Create typed hooks once and export them for use across your app. This file acts as a bridge between your server types and your widgets:
140
-
141
- ```ts
142
- import type { AppType } from "../server"; // type-only import
143
- import { createTypedHooks } from "skybridge/web";
144
80
 
145
- export const { useCallTool, useToolInfo } = createTypedHooks<AppType>();
81
+ server.registerWidget("flights", {}, {
82
+ inputSchema: { destination: z.string() },
83
+ }, async ({ destination }) => {
84
+ const flights = await searchFlights(destination);
85
+ return { structuredContent: { flights } };
86
+ });
146
87
  ```
147
88
 
148
- _Usage in widgets (web/src/widgets/search.tsx)_
89
+ ### Widget
149
90
 
150
91
  ```tsx
151
- import { useCallTool, useToolInfo } from "../skybridge"; // import typed hooks
152
-
153
- export function SearchWidget() {
154
- const { callTool, data, isPending } = useCallTool("search-voyage");
155
- // ^ autocomplete for tool names
156
- const toolInfo = useToolInfo<"search-voyage">();
157
- // ^ autocomplete for widget names
158
-
159
- const handleSearch = () => {
160
- callTool({ destination: "Spain" });
161
- // ^ autocomplete for input fields
162
- };
163
-
164
- return (
165
- <div>
166
- <button onClick={handleSearch} disabled={isPending}>
167
- Search
168
- </button>
169
- {toolInfo.isSuccess && (
170
- <div>Found {toolInfo.output.totalCount} results</div>
171
- // ^ typed output
172
- )}
173
- </div>
174
- );
175
- }
176
- ```
177
-
178
- **Hooks**
179
-
180
- The `skybridge/web` package comes with a set of hooks to help you build your widgets :
181
-
182
- - `useOpenAiGlobal`: A generic hook to get any global data from the OpenAI iFrame skybridge runtime (in `window.openai`).
183
- - `useToolOutput`: A hook to get the initial tool `structuredContent` returned when rendering the widget for the first time. The data inside this hook is not updated when the tool is called again.
184
- - `useToolResponseMetadata`: A hook to get the initial tool `meta` returned when rendering the widget for the first time. The data inside this hook is not updated when the tool is called again.
185
- - `useToolInfo`: A hook to get the tool input, output, and response metadata with type inference. Provides a discriminated union based on status (pending/success).
186
- - `useCallTool`: A @tanstack/react-query inspired hook to send make additional tool calls inside a widget.
187
- - `createTypedHooks`: A factory that creates typed versions of `useCallTool` and `useToolInfo` with full type inference from your server type.
188
-
189
- _useOpenAiGlobal_
190
-
191
- ```ts
192
- import { useOpenAiGlobal } from "skybridge/web";
193
-
194
- const theme = useOpenAiGlobal("theme");
195
- ```
196
-
197
- _useToolOutput_
198
-
199
- ```ts
200
- import { useToolOutput } from "skybridge/web";
201
-
202
- const toolOutput = useToolOutput();
203
- ```
204
-
205
- _useToolResponseMetadata_
206
-
207
- ```ts
208
- import { useToolResponseMetadata } from "skybridge/web";
209
-
210
- const toolResponseMetadata = useToolResponseMetadata();
211
- ```
212
-
213
- _useToolInfo_
214
-
215
- ```ts
216
92
  import { useToolInfo } from "skybridge/web";
217
93
 
218
- const toolInfo = useToolInfo<{
219
- input: { query: string };
220
- output: { results: string[] };
221
- responseMetadata: { id: number };
222
- }>();
94
+ function FlightsWidget() {
95
+ const { output } = useToolInfo();
223
96
 
224
- // toolInfo.input is typed based on the input type
225
- // toolInfo.output is typed based on the output type (undefined when pending)
226
- // toolInfo.status narrows correctly: "pending" | "success"
227
-
228
- if (toolInfo.isPending) {
229
- // toolInfo.output is undefined here
230
- console.log(toolInfo.input.query);
231
- }
232
-
233
- if (toolInfo.isSuccess) {
234
- // toolInfo.output is typed here
235
- console.log(toolInfo.output.results);
97
+ return output.structuredContent.flights.map(flight =>
98
+ <FlightCard key={flight.id} flight={flight} />
99
+ );
236
100
  }
237
101
  ```
238
102
 
239
- _useToolInfo_ with typed hooks (recommended)
103
+ <br />
240
104
 
241
- ```tsx
242
- import { useToolInfo } from "../skybridge"; // import typed hooks
105
+ ## 🎯 Features at a Glance
243
106
 
244
- export function SearchWidget() {
245
- const toolInfo = useToolInfo<"search-voyage">();
246
- // ^ autocomplete for widget names
247
- // toolInfo.input is typed as { destination: string; departureDate?: string; ... }
248
- // toolInfo.output is typed as { results: Array<...>; totalCount: number; } | undefined
107
+ - **Live Reload** — Vite HMR. See changes instantly without reinstalling.
108
+ - **Typed Hooks** — Full autocomplete for tools, inputs, outputs.
109
+ - **Widget Tool Calls** — Trigger server actions from UI.
110
+ - **Dual Surface Sync** Keep model aware of what users see with `data-llm`.
111
+ - **React Query-style API** `isPending`, `isError`, callbacks.
112
+ - **Platform Agnostic** — Works with ChatGPT (Apps SDK) and MCP Apps clients (Goose, VSCode, etc.).
113
+ - **MCP Compatible** — Extends the official SDK. Works with any MCP client.
249
114
 
250
- if (toolInfo.isSuccess) {
251
- return <div>Found {toolInfo.output.totalCount} results</div>;
252
- }
115
+ <br />
253
116
 
254
- return <div>Searching for {toolInfo.input.destination}...</div>;
255
- }
256
- ```
117
+ ## 📖 Showcase
257
118
 
258
- _useCallTool_ in synchronous mode
119
+ Explore production-ready examples:
259
120
 
260
- ```ts
261
- import { useCallTool } from "skybridge/web";
262
-
263
- export const TestTool: React.FunctionComponent = () => {
264
- const { callTool, isPending } = useCallTool("myToolName");
265
-
266
- return (
267
- <div>
268
- <button
269
- disabled={isPending}
270
- onClick={() => {
271
- callTool({ input: "test input" }, {
272
- onSuccess: (data) => {
273
- alert("Tool returned: " + data);
274
- },
275
- });
276
- >
277
- Call Tool inside a widget
278
- </button>
279
- </div>
280
- );
281
- };
282
- ```
121
+ | Example | Description | Demo | Code |
122
+ |------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------|
123
+ | **Capitals Explorer** | Interactive world map with geolocation and Wikipedia integration | [Try Demo](https://capitals.skybridge.tech/try) | [View Code](https://github.com/alpic-ai/skybridge/tree/main/examples/capitals) |
124
+ | **Ecommerce Carousel** | Product carousel with cart, localization, and modals | [Try Demo](https://ecommerce.skybridge.tech/try) | [View Code](https://github.com/alpic-ai/skybridge/tree/main/examples/ecom-carousel) |
125
+ | **Everything** | Comprehensive playground showcasing all hooks and features | [Try Demo](https://everything.skybridge.tech/try) | [View Code](https://github.com/alpic-ai/skybridge/tree/main/examples/everything) |
126
+ | **Productivity** | Data visualization dashboard demonstrating Skybridge capabilities for MCP Apps | [Try Demo](https://productivity.skybridge.tech/try) | [View Code](https://github.com/alpic-ai/skybridge/tree/main/examples/productivity) |
127
+ | **Manifest Starter** | Starter app with Manifest UI agentic components out-of-the-box | [Try Demo](https://manifest-ui.skybridge.tech/try) | [View Code](https://github.com/alpic-ai/skybridge/tree/main/examples/manifest-ui) |
283
128
 
284
- _useCallTool_ in asynchronous mode
129
+ See all examples in the [Showcase](https://docs.skybridge.tech/showcase) or browse the [examples/](examples/) directory.
285
130
 
286
- ```ts
287
- import { useCallTool } from "skybridge/web";
288
-
289
- export const TestTool: React.FunctionComponent = () => {
290
- const { callToolAsync, isPending } = useCallTool("myToolName");
291
-
292
- return (
293
- <div>
294
- <button
295
- disabled={isPending}
296
- onClick={async () => {
297
- const data = await callToolAsync({ input: "test input" });
298
- alert("Tool returned: " + data);
299
- }}
300
- >
301
- Call Tool inside a widget
302
- </button>
303
- </div>
304
- );
305
- };
306
- ```
131
+ <br />
307
132
 
308
- ## Migrate your existing MCP server to a ChatGPT app
133
+ <div align="center">
309
134
 
310
- If you're already using the `@modelcontextprotocol/sdk` to build a MCP server, you can migrate to a ChatGPT app by following these steps:
135
+ [![GitHub Discussions](https://img.shields.io/badge/Discussions-Ask%20Questions-blue?style=flat-square&logo=github)](https://github.com/alpic-ai/skybridge/discussions)
136
+ [![GitHub Issues](https://img.shields.io/badge/Issues-Report%20Bugs-red?style=flat-square&logo=github)](https://github.com/alpic-ai/skybridge/issues)
137
+ [![Discord](https://img.shields.io/badge/Discord-Chat-5865F2?style=flat-square&logo=discord&logoColor=white)](https://discord.com/invite/gNAazGueab)
311
138
 
312
- 1. Replace your `McpServer` import from `@modelcontextprotocol/sdk` with the same import from `skybridge/server`
313
- 2. Create a new vite project in a folder named `web` and install the `skybridge` package
314
- 3. Replace the `vite.config.ts` file with the following:
139
+ See [CONTRIBUTING.md](CONTRIBUTING.md) for setup instructions
315
140
 
316
- ```ts
317
- import { defineConfig } from "vite";
318
- import { skybridge } from "skybridge/web";
141
+ <br />
319
142
 
320
- export default defineConfig({
321
- plugins: [skybridge()],
322
- });
323
- ```
143
+ **[MIT License](LICENSE)** · Made with ❤️ by **[Alpic](https://alpic.ai)**
144
+
145
+ </div>
package/bin/run.js ADDED
@@ -0,0 +1,5 @@
1
+ #!/usr/bin/env node
2
+
3
+ import { execute } from "@oclif/core";
4
+
5
+ await execute({ dir: import.meta.url });
@@ -0,0 +1,18 @@
1
+ export declare function resolvePort(flagPort?: number): Promise<{
2
+ port: number;
3
+ fallback: boolean;
4
+ envWarning?: undefined;
5
+ } | {
6
+ port: number;
7
+ fallback: boolean;
8
+ envWarning: string;
9
+ }>;
10
+ /**
11
+ * Returns the given port if available, otherwise lets the OS
12
+ * pick a free port via `listen(0)`.
13
+ *
14
+ * @param host - Bind address for the check. Pass `"localhost"` for
15
+ * services that bind to 127.0.0.1 (e.g. Vite HMR). Omit for
16
+ * services that bind to all interfaces (e.g. the HTTP server).
17
+ */
18
+ export declare function detectAvailablePort(startPort: number, host?: string): Promise<number>;
@@ -0,0 +1,61 @@
1
+ import net from "node:net";
2
+ const DEFAULT_PORT = 3000;
3
+ export async function resolvePort(flagPort) {
4
+ if (flagPort && flagPort > 1) {
5
+ return { port: flagPort, fallback: false };
6
+ }
7
+ const rawEnv = process.env.PORT;
8
+ if (rawEnv) {
9
+ const parsed = Number(rawEnv);
10
+ if (Number.isInteger(parsed) && parsed > 0) {
11
+ return { port: parsed, fallback: false };
12
+ }
13
+ return {
14
+ port: await detectAvailablePort(DEFAULT_PORT),
15
+ fallback: false,
16
+ envWarning: `Invalid PORT="${rawEnv}", ignoring and using default`,
17
+ };
18
+ }
19
+ const port = await detectAvailablePort(DEFAULT_PORT);
20
+ return { port, fallback: port !== DEFAULT_PORT };
21
+ }
22
+ /**
23
+ * Returns the given port if available, otherwise lets the OS
24
+ * pick a free port via `listen(0)`.
25
+ *
26
+ * @param host - Bind address for the check. Pass `"localhost"` for
27
+ * services that bind to 127.0.0.1 (e.g. Vite HMR). Omit for
28
+ * services that bind to all interfaces (e.g. the HTTP server).
29
+ */
30
+ export async function detectAvailablePort(startPort, host) {
31
+ const available = await isPortAvailable(startPort, host);
32
+ if (available) {
33
+ return startPort;
34
+ }
35
+ return new Promise((resolve, reject) => {
36
+ const server = net.createServer();
37
+ server.once("error", reject);
38
+ server.once("listening", () => {
39
+ const addr = server.address();
40
+ if (addr && typeof addr === "object") {
41
+ const { port } = addr;
42
+ server.close(() => resolve(port));
43
+ }
44
+ else {
45
+ server.close(() => reject(new Error("Failed to detect available port")));
46
+ }
47
+ });
48
+ server.listen(0, host);
49
+ });
50
+ }
51
+ function isPortAvailable(port, host) {
52
+ return new Promise((resolve) => {
53
+ const server = net.createServer();
54
+ server.once("error", () => resolve(false));
55
+ server.once("listening", () => {
56
+ server.close(() => resolve(true));
57
+ });
58
+ server.listen(port, host);
59
+ });
60
+ }
61
+ //# sourceMappingURL=detect-port.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"detect-port.js","sourceRoot":"","sources":["../../src/cli/detect-port.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,UAAU,CAAC;AAE3B,MAAM,YAAY,GAAG,IAAI,CAAC;AAE1B,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,QAAiB;IACjD,IAAI,QAAQ,IAAI,QAAQ,GAAG,CAAC,EAAE,CAAC;QAC7B,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC7C,CAAC;IAED,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;IAChC,IAAI,MAAM,EAAE,CAAC;QACX,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QAC9B,IAAI,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3C,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC3C,CAAC;QACD,OAAO;YACL,IAAI,EAAE,MAAM,mBAAmB,CAAC,YAAY,CAAC;YAC7C,QAAQ,EAAE,KAAK;YACf,UAAU,EAAE,iBAAiB,MAAM,+BAA+B;SACnE,CAAC;IACJ,CAAC;IAED,MAAM,IAAI,GAAG,MAAM,mBAAmB,CAAC,YAAY,CAAC,CAAC;IACrD,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,KAAK,YAAY,EAAE,CAAC;AACnD,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,CAAC,KAAK,UAAU,mBAAmB,CACvC,SAAiB,EACjB,IAAa;IAEb,MAAM,SAAS,GAAG,MAAM,eAAe,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IACzD,IAAI,SAAS,EAAE,CAAC;QACd,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,MAAM,GAAG,GAAG,CAAC,YAAY,EAAE,CAAC;QAElC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAC7B,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE;YAC5B,MAAM,IAAI,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC;YAC9B,IAAI,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;gBACrC,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC;gBACtB,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;YACpC,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAChB,MAAM,CAAC,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC,CACrD,CAAC;YACJ,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;IACzB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,eAAe,CAAC,IAAY,EAAE,IAAa;IAClD,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,MAAM,MAAM,GAAG,GAAG,CAAC,YAAY,EAAE,CAAC;QAElC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3C,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE;YAC5B,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,4 @@
1
+ export declare const Header: ({ version, children, }: {
2
+ version: string;
3
+ children?: React.ReactNode;
4
+ }) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,6 @@
1
+ import { jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Text } from "ink";
3
+ export const Header = ({ version, children, }) => {
4
+ return (_jsxs(Box, { marginBottom: 1, children: [_jsxs(Text, { color: "cyan", bold: true, children: ["\u26F0", " ", "Welcome to Skybridge"] }), _jsxs(Text, { color: "cyan", children: [" v", version] }), children] }));
5
+ };
6
+ //# sourceMappingURL=header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"header.js","sourceRoot":"","sources":["../../src/cli/header.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAEhC,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,EACrB,OAAO,EACP,QAAQ,GAIT,EAAE,EAAE;IACH,OAAO,CACL,MAAC,GAAG,IAAC,YAAY,EAAE,CAAC,aAClB,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,EAAC,IAAI,6BACnB,IAAI,4BACD,EACP,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,mBAAI,OAAO,IAAQ,EACpC,QAAQ,IACL,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ import { type SpawnOptions } from "node:child_process";
2
+ export declare function runCommand(command: string, options?: SpawnOptions): Promise<void>;
@@ -0,0 +1,43 @@
1
+ import { spawn } from "node:child_process";
2
+ export function runCommand(command, options = {
3
+ stdio: ["ignore", "inherit", "inherit"],
4
+ }) {
5
+ return new Promise((resolve, reject) => {
6
+ const stdoutChunks = [];
7
+ const stderrChunks = [];
8
+ const proc = spawn(command, {
9
+ ...options,
10
+ shell: true,
11
+ });
12
+ if (proc.stdout) {
13
+ proc.stdout.on("data", (chunk) => {
14
+ stdoutChunks.push(chunk);
15
+ });
16
+ }
17
+ if (proc.stderr) {
18
+ proc.stderr.on("data", (chunk) => {
19
+ stderrChunks.push(chunk);
20
+ });
21
+ }
22
+ proc.on("close", (code) => {
23
+ if (code === 0) {
24
+ resolve();
25
+ }
26
+ else {
27
+ const stdoutOutput = Buffer.concat(stdoutChunks).toString();
28
+ const stderrOutput = Buffer.concat(stderrChunks).toString();
29
+ const allOutput = [stdoutOutput, stderrOutput]
30
+ .filter((output) => output.trim())
31
+ .join("\n");
32
+ const errorMessage = allOutput
33
+ ? `Command failed with exit code ${code}\n${allOutput}`
34
+ : `Command failed with exit code ${code}`;
35
+ reject(new Error(errorMessage));
36
+ }
37
+ });
38
+ proc.on("error", (error) => {
39
+ reject(error);
40
+ });
41
+ });
42
+ }
43
+ //# sourceMappingURL=run-command.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"run-command.js","sourceRoot":"","sources":["../../src/cli/run-command.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAE9D,MAAM,UAAU,UAAU,CACxB,OAAe,EACf,UAAwB;IACtB,KAAK,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,CAAC;CACxC;IAED,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,YAAY,GAAa,EAAE,CAAC;QAClC,MAAM,YAAY,GAAa,EAAE,CAAC;QAElC,MAAM,IAAI,GAAG,KAAK,CAAC,OAAO,EAAE;YAC1B,GAAG,OAAO;YACV,KAAK,EAAE,IAAI;SACZ,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE;gBAC/B,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3B,CAAC,CAAC,CAAC;QACL,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE;gBAC/B,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3B,CAAC,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;YACxB,IAAI,IAAI,KAAK,CAAC,EAAE,CAAC;gBACf,OAAO,EAAE,CAAC;YACZ,CAAC;iBAAM,CAAC;gBACN,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAC;gBAC5D,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAC;gBAC5D,MAAM,SAAS,GAAG,CAAC,YAAY,EAAE,YAAY,CAAC;qBAC3C,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;qBACjC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACd,MAAM,YAAY,GAAG,SAAS;oBAC5B,CAAC,CAAC,iCAAiC,IAAI,KAAK,SAAS,EAAE;oBACvD,CAAC,CAAC,iCAAiC,IAAI,EAAE,CAAC;gBAC5C,MAAM,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC;YAClC,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;YACzB,MAAM,CAAC,KAAK,CAAC,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { Hook } from "@oclif/core";
2
+ export declare function isEnabled(): boolean;
3
+ export declare function isDebugMode(): boolean;
4
+ export declare function setEnabled(enabled: boolean): void;
5
+ export declare function getMachineId(): string;
6
+ declare const hook: Hook<"finally">;
7
+ export default hook;