zudoku 0.3.0-dev.4 → 0.3.0-dev.41

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 (474) hide show
  1. package/dist/app/App.d.ts +1 -2
  2. package/dist/app/App.js +1 -28
  3. package/dist/app/App.js.map +1 -1
  4. package/dist/app/demo.d.ts +2 -0
  5. package/dist/app/demo.js +27 -0
  6. package/dist/app/demo.js.map +1 -0
  7. package/dist/app/entry.client.d.ts +2 -0
  8. package/dist/app/entry.client.js +35 -0
  9. package/dist/app/entry.client.js.map +1 -0
  10. package/dist/app/entry.server.d.ts +12 -0
  11. package/dist/app/entry.server.js +104 -0
  12. package/dist/app/entry.server.js.map +1 -0
  13. package/dist/app/main.d.ts +6 -1
  14. package/dist/app/main.js +54 -12
  15. package/dist/app/main.js.map +1 -1
  16. package/dist/app/standalone.d.ts +2 -0
  17. package/dist/app/standalone.js +32 -0
  18. package/dist/app/standalone.js.map +1 -0
  19. package/dist/app/tailwind.d.ts +1 -1
  20. package/dist/app/tailwind.js +0 -4
  21. package/dist/app/tailwind.js.map +1 -1
  22. package/dist/app/zudoku-manifest.d.ts +1 -0
  23. package/dist/app/zudoku-manifest.js +20 -0
  24. package/dist/app/zudoku-manifest.js.map +1 -0
  25. package/dist/cli/cmds/dev.js +5 -0
  26. package/dist/cli/cmds/dev.js.map +1 -1
  27. package/dist/cli/dev/handler.d.ts +1 -0
  28. package/dist/cli/dev/handler.js +3 -1
  29. package/dist/cli/dev/handler.js.map +1 -1
  30. package/dist/config/config.d.ts +15 -16
  31. package/dist/internal.d.ts +1 -0
  32. package/dist/internal.js +2 -0
  33. package/dist/internal.js.map +1 -0
  34. package/dist/lib/authentication/Callback.js +1 -1
  35. package/dist/lib/authentication/Callback.js.map +1 -1
  36. package/dist/lib/authentication/authentication.d.ts +2 -2
  37. package/dist/lib/authentication/hook.d.ts +1 -0
  38. package/dist/lib/authentication/hook.js +1 -0
  39. package/dist/lib/authentication/hook.js.map +1 -1
  40. package/dist/lib/authentication/providers/auth0.js +1 -0
  41. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  42. package/dist/lib/authentication/providers/clerk.js +4 -0
  43. package/dist/lib/authentication/providers/clerk.js.map +1 -1
  44. package/dist/lib/authentication/providers/openid.d.ts +1 -1
  45. package/dist/lib/authentication/providers/openid.js +2 -0
  46. package/dist/lib/authentication/providers/openid.js.map +1 -1
  47. package/dist/lib/authentication/state.d.ts +1 -0
  48. package/dist/lib/authentication/state.js +1 -0
  49. package/dist/lib/authentication/state.js.map +1 -1
  50. package/dist/lib/components/Bootstrap.d.ts +12 -0
  51. package/dist/lib/components/Bootstrap.js +9 -0
  52. package/dist/lib/components/Bootstrap.js.map +1 -0
  53. package/dist/lib/components/DevPortal.d.ts +4 -19
  54. package/dist/lib/components/DevPortal.js +17 -12
  55. package/dist/lib/components/DevPortal.js.map +1 -1
  56. package/dist/lib/components/ErrorPage.d.ts +6 -0
  57. package/dist/lib/components/ErrorPage.js +9 -0
  58. package/dist/lib/components/ErrorPage.js.map +1 -0
  59. package/dist/lib/components/Header.js +3 -3
  60. package/dist/lib/components/Header.js.map +1 -1
  61. package/dist/lib/components/Heading.d.ts +9 -4
  62. package/dist/lib/components/Heading.js +17 -2
  63. package/dist/lib/components/Heading.js.map +1 -1
  64. package/dist/lib/components/InlineCode.d.ts +5 -0
  65. package/dist/lib/components/InlineCode.js +4 -0
  66. package/dist/lib/components/InlineCode.js.map +1 -0
  67. package/dist/lib/components/Layout.js +3 -2
  68. package/dist/lib/components/Layout.js.map +1 -1
  69. package/dist/lib/components/NotFoundPage.d.ts +1 -0
  70. package/dist/lib/components/NotFoundPage.js +12 -0
  71. package/dist/lib/components/NotFoundPage.js.map +1 -0
  72. package/dist/lib/components/SyntaxHighlight.d.ts +3 -2
  73. package/dist/lib/components/SyntaxHighlight.js +21 -19
  74. package/dist/lib/components/SyntaxHighlight.js.map +1 -1
  75. package/dist/lib/components/TopNavigation.d.ts +1 -1
  76. package/dist/lib/components/TopNavigation.js +4 -0
  77. package/dist/lib/components/TopNavigation.js.map +1 -1
  78. package/dist/lib/components/context/DevPortalProvider.d.ts +1 -1
  79. package/dist/lib/components/context/DevPortalProvider.js +2 -2
  80. package/dist/lib/components/context/DevPortalProvider.js.map +1 -1
  81. package/dist/lib/components/index.d.ts +28 -3
  82. package/dist/lib/components/index.js +17 -3
  83. package/dist/lib/components/index.js.map +1 -1
  84. package/dist/lib/core/DevPortalContext.d.ts +33 -3
  85. package/dist/lib/core/DevPortalContext.js +8 -5
  86. package/dist/lib/core/DevPortalContext.js.map +1 -1
  87. package/dist/lib/core/plugins.d.ts +7 -4
  88. package/dist/lib/core/plugins.js +1 -0
  89. package/dist/lib/core/plugins.js.map +1 -1
  90. package/dist/lib/errors/ErrorAlert.d.ts +3 -0
  91. package/dist/lib/errors/ErrorAlert.js +8 -0
  92. package/dist/lib/errors/ErrorAlert.js.map +1 -0
  93. package/dist/lib/errors/RouterError.d.ts +1 -0
  94. package/dist/lib/errors/RouterError.js +12 -0
  95. package/dist/lib/errors/RouterError.js.map +1 -0
  96. package/dist/lib/errors/ServerError.d.ts +3 -0
  97. package/dist/lib/errors/ServerError.js +6 -0
  98. package/dist/lib/errors/ServerError.js.map +1 -0
  99. package/dist/lib/errors/TopLevelError.d.ts +2 -0
  100. package/dist/lib/errors/TopLevelError.js +7 -0
  101. package/dist/lib/errors/TopLevelError.js.map +1 -0
  102. package/dist/lib/oas/graphql/index.js +1 -1
  103. package/dist/lib/oas/graphql/index.js.map +1 -1
  104. package/dist/lib/oas/parser/index.d.ts +1 -1
  105. package/dist/lib/oas/parser/index.js +38 -12
  106. package/dist/lib/oas/parser/index.js.map +1 -1
  107. package/dist/lib/plugins/api-keys/CreateApiKey.d.ts +4 -0
  108. package/dist/lib/plugins/{api-key → api-keys}/CreateApiKey.js +1 -1
  109. package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -0
  110. package/dist/lib/plugins/api-keys/SettingsApiKeys.d.ts +4 -0
  111. package/dist/lib/plugins/api-keys/SettingsApiKeys.js +38 -0
  112. package/dist/lib/plugins/api-keys/SettingsApiKeys.js.map +1 -0
  113. package/dist/lib/plugins/{api-key → api-keys}/index.js +32 -9
  114. package/dist/lib/plugins/api-keys/index.js.map +1 -0
  115. package/dist/lib/plugins/markdown/MdxPage.d.ts +3 -2
  116. package/dist/lib/plugins/markdown/MdxPage.js +7 -6
  117. package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
  118. package/dist/lib/plugins/markdown/Toc.js +1 -1
  119. package/dist/lib/plugins/markdown/Toc.js.map +1 -1
  120. package/dist/lib/plugins/markdown/generateRoutes.d.ts +3 -3
  121. package/dist/lib/plugins/markdown/generateRoutes.js +4 -4
  122. package/dist/lib/plugins/markdown/generateRoutes.js.map +1 -1
  123. package/dist/lib/plugins/markdown/index.d.ts +4 -1
  124. package/dist/lib/plugins/markdown/index.js +3 -7
  125. package/dist/lib/plugins/markdown/index.js.map +1 -1
  126. package/dist/lib/plugins/openapi/OperationList.js +16 -5
  127. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  128. package/dist/lib/plugins/openapi/OperationListItem.js +10 -5
  129. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  130. package/dist/lib/plugins/openapi/ParameterList.js +1 -1
  131. package/dist/lib/plugins/openapi/ParameterList.js.map +1 -1
  132. package/dist/lib/plugins/openapi/ParameterListItem.js +1 -1
  133. package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
  134. package/dist/lib/plugins/openapi/{MakeRequest.d.ts → PlaygroundDialogWrapper.d.ts} +1 -1
  135. package/dist/lib/plugins/openapi/{MakeRequest.js → PlaygroundDialogWrapper.js} +5 -5
  136. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js.map +1 -0
  137. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js +1 -9
  138. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
  139. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js +1 -1
  140. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
  141. package/dist/lib/plugins/openapi/Route.d.ts +6 -0
  142. package/dist/lib/plugins/openapi/Route.js +8 -0
  143. package/dist/lib/plugins/openapi/Route.js.map +1 -0
  144. package/dist/lib/plugins/openapi/SchemaListView.js +6 -27
  145. package/dist/lib/plugins/openapi/SchemaListView.js.map +1 -1
  146. package/dist/lib/plugins/openapi/SchemaListViewItem.d.ts +7 -0
  147. package/dist/lib/plugins/openapi/SchemaListViewItem.js +16 -0
  148. package/dist/lib/plugins/openapi/SchemaListViewItem.js.map +1 -0
  149. package/dist/lib/plugins/openapi/SchemaListViewItemGroup.d.ts +8 -0
  150. package/dist/lib/plugins/openapi/SchemaListViewItemGroup.js +17 -0
  151. package/dist/lib/plugins/openapi/SchemaListViewItemGroup.js.map +1 -0
  152. package/dist/lib/plugins/openapi/Sidecar.js +10 -8
  153. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  154. package/dist/lib/plugins/openapi/{Select.d.ts → SimpleSelect.d.ts} +3 -2
  155. package/dist/lib/plugins/openapi/SimpleSelect.js +5 -0
  156. package/dist/lib/plugins/openapi/SimpleSelect.js.map +1 -0
  157. package/dist/lib/plugins/openapi/client/createMemoryClient.d.ts +12 -0
  158. package/dist/lib/plugins/openapi/client/createMemoryClient.js +46 -0
  159. package/dist/lib/plugins/openapi/client/createMemoryClient.js.map +1 -0
  160. package/dist/lib/plugins/openapi/client/createServer.d.ts +4 -0
  161. package/dist/lib/plugins/openapi/client/createServer.js +30 -0
  162. package/dist/lib/plugins/openapi/client/createServer.js.map +1 -0
  163. package/dist/lib/plugins/openapi/client/createWorkerClient.d.ts +10 -0
  164. package/dist/lib/plugins/openapi/{worker/createSharedWorkerClient.js → client/createWorkerClient.js} +15 -2
  165. package/dist/lib/plugins/openapi/client/createWorkerClient.js.map +1 -0
  166. package/dist/lib/plugins/openapi/client/interfaces.d.ts +4 -0
  167. package/dist/lib/plugins/openapi/client/interfaces.js +2 -0
  168. package/dist/lib/plugins/openapi/client/interfaces.js.map +1 -0
  169. package/dist/lib/plugins/openapi/{worker → client}/worker.js +2 -2
  170. package/dist/lib/plugins/openapi/client/worker.js.map +1 -0
  171. package/dist/lib/plugins/openapi/context.d.ts +5 -0
  172. package/dist/lib/plugins/openapi/context.js +11 -0
  173. package/dist/lib/plugins/openapi/context.js.map +1 -0
  174. package/dist/lib/plugins/openapi/index.d.ts +4 -18
  175. package/dist/lib/plugins/openapi/index.js +35 -20
  176. package/dist/lib/plugins/openapi/index.js.map +1 -1
  177. package/dist/lib/plugins/openapi/interfaces.d.ts +15 -0
  178. package/dist/lib/plugins/openapi/interfaces.js +2 -0
  179. package/dist/lib/plugins/openapi/interfaces.js.map +1 -0
  180. package/dist/lib/plugins/openapi/playground/Headers.d.ts +2 -3
  181. package/dist/lib/plugins/openapi/playground/Headers.js +16 -6
  182. package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
  183. package/dist/lib/plugins/openapi/playground/PathParams.d.ts +1 -1
  184. package/dist/lib/plugins/openapi/playground/Playground.d.ts +4 -3
  185. package/dist/lib/plugins/openapi/playground/Playground.js +8 -12
  186. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  187. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.d.ts +3 -0
  188. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +10 -0
  189. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -0
  190. package/dist/lib/plugins/openapi/playground/QueryParams.d.ts +1 -1
  191. package/dist/lib/plugins/openapi/playground/QueryParams.js +2 -1
  192. package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
  193. package/dist/lib/plugins/openapi/playground/createUrl.d.ts +1 -1
  194. package/dist/lib/plugins/openapi/util/prose.d.ts +1 -0
  195. package/dist/lib/plugins/openapi/util/prose.js +4 -0
  196. package/dist/lib/plugins/openapi/util/prose.js.map +1 -0
  197. package/dist/lib/plugins/openapi-worker.d.ts +1 -1
  198. package/dist/lib/plugins/openapi-worker.js +1 -1
  199. package/dist/lib/plugins/openapi-worker.js.map +1 -1
  200. package/dist/lib/plugins/redirect/index.js +2 -3
  201. package/dist/lib/plugins/redirect/index.js.map +1 -1
  202. package/dist/lib/ui/Callout.js +2 -2
  203. package/dist/lib/ui/Callout.js.map +1 -1
  204. package/dist/lib/ui/button-variants.d.ts +2 -2
  205. package/dist/lib/util/MdxComponents.js +2 -2
  206. package/dist/lib/util/MdxComponents.js.map +1 -1
  207. package/dist/lib/util/groupBy.d.ts +1 -6
  208. package/dist/lib/util/groupBy.js +10 -8
  209. package/dist/lib/util/groupBy.js.map +1 -1
  210. package/dist/lib/util/logInit.d.ts +1 -0
  211. package/dist/lib/util/logInit.js +9 -0
  212. package/dist/lib/util/logInit.js.map +1 -0
  213. package/dist/lib/util/objectEntries.d.ts +4 -0
  214. package/dist/lib/util/objectEntries.js +2 -0
  215. package/dist/lib/util/objectEntries.js.map +1 -0
  216. package/dist/lib/util/renderIf.d.ts +1 -0
  217. package/dist/lib/util/renderIf.js +2 -0
  218. package/dist/lib/util/renderIf.js.map +1 -0
  219. package/dist/vite/build.js +27 -8
  220. package/dist/vite/build.js.map +1 -1
  221. package/dist/vite/config.d.ts +13 -9
  222. package/dist/vite/config.js +98 -57
  223. package/dist/vite/config.js.map +1 -1
  224. package/dist/vite/config.test.js +7 -4
  225. package/dist/vite/config.test.js.map +1 -1
  226. package/dist/vite/dev-server.d.ts +2 -1
  227. package/dist/vite/dev-server.js +43 -15
  228. package/dist/vite/dev-server.js.map +1 -1
  229. package/dist/vite/html.js +5 -5
  230. package/dist/vite/html.js.map +1 -1
  231. package/dist/vite/plugin-api-keys.js +7 -8
  232. package/dist/vite/plugin-api-keys.js.map +1 -1
  233. package/dist/vite/plugin-api.js +8 -19
  234. package/dist/vite/plugin-api.js.map +1 -1
  235. package/dist/vite/plugin-auth.js +5 -6
  236. package/dist/vite/plugin-auth.js.map +1 -1
  237. package/dist/vite/plugin-component.js +3 -2
  238. package/dist/vite/plugin-component.js.map +1 -1
  239. package/dist/vite/plugin-config.d.ts +0 -1
  240. package/dist/vite/plugin-config.js +13 -7
  241. package/dist/vite/plugin-config.js.map +1 -1
  242. package/dist/vite/plugin-custom-css.d.ts +6 -0
  243. package/dist/vite/plugin-custom-css.js +55 -0
  244. package/dist/vite/plugin-custom-css.js.map +1 -0
  245. package/dist/vite/plugin-docs.js +14 -4
  246. package/dist/vite/plugin-docs.js.map +1 -1
  247. package/dist/vite/plugin-docs.test.js +1 -1
  248. package/dist/vite/plugin-docs.test.js.map +1 -1
  249. package/dist/vite/plugin-html.js +1 -9
  250. package/dist/vite/plugin-html.js.map +1 -1
  251. package/dist/vite/plugin-mdx.d.ts +3 -1
  252. package/dist/vite/plugin-mdx.js +4 -4
  253. package/dist/vite/plugin-mdx.js.map +1 -1
  254. package/dist/vite/plugin-redirect.js +9 -9
  255. package/dist/vite/plugin-redirect.js.map +1 -1
  256. package/dist/vite/plugin.js +3 -3
  257. package/dist/vite/plugin.js.map +1 -1
  258. package/dist/vite/prerender.d.ts +17 -0
  259. package/dist/vite/prerender.js +55 -0
  260. package/dist/vite/prerender.js.map +1 -0
  261. package/lib/AnchorLink-DCdBbdqo.js +705 -0
  262. package/lib/AnchorLink-DCdBbdqo.js.map +1 -0
  263. package/lib/DevPortalProvider-C-O1s7mm.js +1081 -0
  264. package/lib/DevPortalProvider-C-O1s7mm.js.map +1 -0
  265. package/lib/Markdown-CGZJUYcj.js +15028 -0
  266. package/lib/Markdown-CGZJUYcj.js.map +1 -0
  267. package/lib/MdxPage-BZLuBOqR.js +190 -0
  268. package/lib/MdxPage-BZLuBOqR.js.map +1 -0
  269. package/lib/OperationList-BEpN70_E.js +5562 -0
  270. package/lib/OperationList-BEpN70_E.js.map +1 -0
  271. package/lib/Route-WiMUalLG.js +13 -0
  272. package/lib/Route-WiMUalLG.js.map +1 -0
  273. package/lib/Select-BQ9-3iTJ.js +4571 -0
  274. package/lib/Select-BQ9-3iTJ.js.map +1 -0
  275. package/lib/Spinner-C1L_TK5f.js +182 -0
  276. package/lib/Spinner-C1L_TK5f.js.map +1 -0
  277. package/lib/_commonjsHelpers-BkfeUUK-.js +1 -0
  278. package/lib/_commonjsHelpers-BkfeUUK-.js.map +1 -0
  279. package/lib/assets/index-BPdJm2ty.js +1 -0
  280. package/lib/assets/index-BPdJm2ty.js.map +1 -0
  281. package/lib/assets/{worker-BCcpCNJ7.js → worker-BjPv-hjP.js} +10742 -10318
  282. package/lib/assets/worker-BjPv-hjP.js.map +1 -0
  283. package/lib/context-_fYfJFgk.js +14 -0
  284. package/lib/context-_fYfJFgk.js.map +1 -0
  285. package/lib/createWorkerClient-TWecYOlx.js +16698 -0
  286. package/lib/createWorkerClient-TWecYOlx.js.map +1 -0
  287. package/lib/hook-SM2dMVmI.js +77 -0
  288. package/lib/hook-SM2dMVmI.js.map +1 -0
  289. package/lib/index-CtLNbq0d.js +412 -0
  290. package/lib/index-CtLNbq0d.js.map +1 -0
  291. package/lib/index-PvQa9XLl.js +724 -0
  292. package/lib/index-PvQa9XLl.js.map +1 -0
  293. package/lib/index-pI9JkN46.js +4765 -0
  294. package/lib/index-pI9JkN46.js.map +1 -0
  295. package/lib/jsx-runtime-DLtUZ5Ve.js +1526 -0
  296. package/lib/jsx-runtime-DLtUZ5Ve.js.map +1 -0
  297. package/lib/prism-bash.min-DadFsM4Z.js +1 -0
  298. package/lib/prism-bash.min-DadFsM4Z.js.map +1 -0
  299. package/lib/prism-csharp.min-Yizuc34Y.js +35 -0
  300. package/lib/prism-csharp.min-Yizuc34Y.js.map +1 -0
  301. package/lib/prism-java.min-d5iT_mOd.js +1 -0
  302. package/lib/prism-java.min-d5iT_mOd.js.map +1 -0
  303. package/lib/prism-json.min-B1GJqK1k.js +1 -0
  304. package/lib/prism-json.min-B1GJqK1k.js.map +1 -0
  305. package/lib/prism-markup-templating-DZrrEs0A.js +1 -0
  306. package/lib/prism-markup-templating-DZrrEs0A.js.map +1 -0
  307. package/lib/prism-objectivec.min-BXSWqpJJ.js +2 -0
  308. package/lib/prism-objectivec.min-BXSWqpJJ.js.map +1 -0
  309. package/lib/prism-php.min-o7FpoMP_.js +1 -0
  310. package/lib/prism-php.min-o7FpoMP_.js.map +1 -0
  311. package/lib/prism-ruby.min-C7LwcKyz.js +1 -0
  312. package/lib/prism-ruby.min-C7LwcKyz.js.map +1 -0
  313. package/lib/router-BkOLuJlq.js +2973 -0
  314. package/lib/router-BkOLuJlq.js.map +1 -0
  315. package/lib/slugify-DbLhpSPt.js +28 -0
  316. package/lib/slugify-DbLhpSPt.js.map +1 -0
  317. package/lib/{state-oycsxkHz.js → state-Ds_OxRHP.js} +20 -18
  318. package/lib/state-Ds_OxRHP.js.map +1 -0
  319. package/lib/util-Cgie7wjb.js +41 -0
  320. package/lib/util-Cgie7wjb.js.map +1 -0
  321. package/lib/zudoku.auth-auth0.js +3 -1
  322. package/lib/zudoku.auth-auth0.js.map +1 -0
  323. package/lib/zudoku.auth-clerk.js +11 -8
  324. package/lib/zudoku.auth-clerk.js.map +1 -0
  325. package/lib/zudoku.auth-openid.js +5 -2
  326. package/lib/zudoku.auth-openid.js.map +1 -0
  327. package/lib/zudoku.components.js +800 -464
  328. package/lib/zudoku.components.js.map +1 -0
  329. package/lib/zudoku.openapi-worker.js +3 -223
  330. package/lib/zudoku.openapi-worker.js.map +1 -0
  331. package/lib/zudoku.plugin-api-keys.js +287 -0
  332. package/lib/zudoku.plugin-api-keys.js.map +1 -0
  333. package/lib/zudoku.plugin-markdown.js +49 -0
  334. package/lib/zudoku.plugin-markdown.js.map +1 -0
  335. package/lib/zudoku.plugin-openapi.js +9 -0
  336. package/lib/zudoku.plugin-openapi.js.map +1 -0
  337. package/lib/zudoku.plugin-redirect.js +11 -0
  338. package/lib/zudoku.plugin-redirect.js.map +1 -0
  339. package/package.json +33 -15
  340. package/src/app/App.tsx +0 -40
  341. package/src/app/demo-cdn.html +26 -0
  342. package/src/app/demo.html +18 -0
  343. package/src/app/demo.tsx +40 -0
  344. package/src/app/entry.client.tsx +47 -0
  345. package/src/app/entry.server.tsx +158 -0
  346. package/src/app/main.css +74 -0
  347. package/src/app/main.tsx +71 -15
  348. package/src/app/standalone.html +20 -0
  349. package/src/app/standalone.tsx +46 -0
  350. package/src/app/tailwind.ts +2 -6
  351. package/src/app/zudoku-manifest.ts +22 -0
  352. package/src/lib/authentication/Callback.tsx +1 -1
  353. package/src/lib/authentication/authentication.ts +2 -5
  354. package/src/lib/authentication/hook.ts +1 -0
  355. package/src/lib/authentication/providers/auth0.tsx +1 -0
  356. package/src/lib/authentication/providers/clerk.tsx +3 -0
  357. package/src/lib/authentication/providers/openid.tsx +3 -1
  358. package/src/lib/authentication/state.ts +2 -0
  359. package/src/lib/components/Bootstrap.tsx +37 -0
  360. package/src/lib/components/DevPortal.tsx +41 -56
  361. package/src/lib/components/ErrorPage.tsx +28 -0
  362. package/src/lib/components/Header.tsx +7 -7
  363. package/src/lib/components/Heading.tsx +26 -7
  364. package/src/lib/components/InlineCode.tsx +19 -0
  365. package/src/lib/components/Layout.tsx +9 -7
  366. package/src/lib/components/NotFoundPage.tsx +39 -0
  367. package/src/lib/components/SyntaxHighlight.tsx +27 -19
  368. package/src/lib/components/TopNavigation.tsx +5 -0
  369. package/src/lib/components/context/DevPortalProvider.ts +2 -2
  370. package/src/lib/components/index.ts +21 -3
  371. package/src/lib/core/DevPortalContext.ts +42 -13
  372. package/src/lib/core/plugins.ts +10 -5
  373. package/src/lib/errors/ErrorAlert.tsx +21 -0
  374. package/src/lib/errors/RouterError.tsx +13 -0
  375. package/src/lib/errors/ServerError.tsx +5 -0
  376. package/src/lib/errors/TopLevelError.tsx +8 -0
  377. package/src/lib/oas/graphql/index.ts +2 -2
  378. package/src/lib/oas/parser/index.ts +41 -20
  379. package/src/lib/plugins/{api-key → api-keys}/CreateApiKey.tsx +2 -8
  380. package/src/lib/plugins/{api-key → api-keys}/SettingsApiKeys.tsx +21 -14
  381. package/src/lib/plugins/{api-key → api-keys}/index.tsx +43 -9
  382. package/src/lib/plugins/markdown/MdxPage.tsx +52 -35
  383. package/src/lib/plugins/markdown/Toc.tsx +1 -1
  384. package/src/lib/plugins/markdown/generateRoutes.tsx +16 -6
  385. package/src/lib/plugins/markdown/index.tsx +10 -7
  386. package/src/lib/plugins/openapi/OperationList.tsx +40 -4
  387. package/src/lib/plugins/openapi/OperationListItem.tsx +69 -42
  388. package/src/lib/plugins/openapi/ParameterList.tsx +1 -1
  389. package/src/lib/plugins/openapi/ParameterListItem.tsx +3 -4
  390. package/src/lib/plugins/openapi/{MakeRequest.tsx → PlaygroundDialogWrapper.tsx} +4 -4
  391. package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +2 -16
  392. package/src/lib/plugins/openapi/ResponsesSidecarBox.tsx +3 -1
  393. package/src/lib/plugins/openapi/Route.tsx +21 -0
  394. package/src/lib/plugins/openapi/SchemaListView.tsx +23 -192
  395. package/src/lib/plugins/openapi/SchemaListViewItem.tsx +110 -0
  396. package/src/lib/plugins/openapi/SchemaListViewItemGroup.tsx +63 -0
  397. package/src/lib/plugins/openapi/Sidecar.tsx +15 -10
  398. package/src/lib/plugins/openapi/{Select.tsx → SimpleSelect.tsx} +6 -3
  399. package/src/lib/plugins/openapi/client/createMemoryClient.ts +56 -0
  400. package/src/lib/plugins/openapi/client/createServer.ts +33 -0
  401. package/src/lib/plugins/openapi/{worker/createSharedWorkerClient.ts → client/createWorkerClient.ts} +21 -1
  402. package/src/lib/plugins/openapi/client/interfaces.ts +5 -0
  403. package/src/lib/plugins/openapi/{worker → client}/worker.ts +3 -3
  404. package/src/lib/plugins/openapi/context.tsx +16 -0
  405. package/src/lib/plugins/openapi/index.tsx +59 -52
  406. package/src/lib/plugins/openapi/interfaces.ts +9 -0
  407. package/src/lib/plugins/openapi/playground/Headers.tsx +60 -33
  408. package/src/lib/plugins/openapi/playground/PathParams.tsx +1 -1
  409. package/src/lib/plugins/openapi/playground/Playground.tsx +158 -193
  410. package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +34 -0
  411. package/src/lib/plugins/openapi/playground/QueryParams.tsx +7 -2
  412. package/src/lib/plugins/openapi/playground/createUrl.ts +1 -1
  413. package/src/lib/plugins/openapi/util/prose.ts +7 -0
  414. package/src/lib/plugins/openapi-worker.ts +1 -1
  415. package/src/lib/plugins/redirect/index.tsx +2 -2
  416. package/src/lib/ui/Callout.tsx +4 -4
  417. package/src/lib/util/MdxComponents.tsx +2 -12
  418. package/src/lib/util/groupBy.ts +7 -12
  419. package/src/lib/util/logInit.ts +9 -0
  420. package/src/lib/util/objectEntries.ts +5 -0
  421. package/src/lib/util/renderIf.ts +4 -0
  422. package/dist/lib/components/Link.d.ts +0 -1
  423. package/dist/lib/components/Link.js +0 -2
  424. package/dist/lib/components/Link.js.map +0 -1
  425. package/dist/lib/components/Router.d.ts +0 -4
  426. package/dist/lib/components/Router.js +0 -20
  427. package/dist/lib/components/Router.js.map +0 -1
  428. package/dist/lib/core/helmet.d.ts +0 -4
  429. package/dist/lib/core/helmet.js +0 -5
  430. package/dist/lib/core/helmet.js.map +0 -1
  431. package/dist/lib/core/icons.d.ts +0 -1
  432. package/dist/lib/core/icons.js +0 -2
  433. package/dist/lib/core/icons.js.map +0 -1
  434. package/dist/lib/core/router.d.ts +0 -1
  435. package/dist/lib/core/router.js +0 -2
  436. package/dist/lib/core/router.js.map +0 -1
  437. package/dist/lib/plugins/api-key/CreateApiKey.d.ts +0 -5
  438. package/dist/lib/plugins/api-key/CreateApiKey.js.map +0 -1
  439. package/dist/lib/plugins/api-key/SettingsApiKeys.d.ts +0 -5
  440. package/dist/lib/plugins/api-key/SettingsApiKeys.js +0 -38
  441. package/dist/lib/plugins/api-key/SettingsApiKeys.js.map +0 -1
  442. package/dist/lib/plugins/api-key/index.js.map +0 -1
  443. package/dist/lib/plugins/index.d.ts +0 -4
  444. package/dist/lib/plugins/index.js +0 -5
  445. package/dist/lib/plugins/index.js.map +0 -1
  446. package/dist/lib/plugins/openapi/MakeRequest.js.map +0 -1
  447. package/dist/lib/plugins/openapi/Select.js +0 -5
  448. package/dist/lib/plugins/openapi/Select.js.map +0 -1
  449. package/dist/lib/plugins/openapi/worker/createSharedWorkerClient.d.ts +0 -5
  450. package/dist/lib/plugins/openapi/worker/createSharedWorkerClient.js.map +0 -1
  451. package/dist/lib/plugins/openapi/worker/shared-worker.d.ts +0 -1
  452. package/dist/lib/plugins/openapi/worker/shared-worker.js +0 -6
  453. package/dist/lib/plugins/openapi/worker/shared-worker.js.map +0 -1
  454. package/dist/lib/plugins/openapi/worker/worker.js.map +0 -1
  455. package/dist/vite/common.d.ts +0 -1
  456. package/dist/vite/common.js +0 -5
  457. package/dist/vite/common.js.map +0 -1
  458. package/dist/vite/plugin-openapi-worker.d.ts +0 -4
  459. package/dist/vite/plugin-openapi-worker.js +0 -28
  460. package/dist/vite/plugin-openapi-worker.js.map +0 -1
  461. package/lib/Spinner-7LezPqGn.js +0 -8393
  462. package/lib/clerk-Wslx_mPo.js +0 -19685
  463. package/lib/index-DNx3xWa2.js +0 -3461
  464. package/lib/urql-DMlBWUKL.js +0 -1591
  465. package/lib/zudoku.plugins.js +0 -19863
  466. package/src/lib/components/Link.tsx +0 -1
  467. package/src/lib/components/Router.tsx +0 -28
  468. package/src/lib/core/helmet.ts +0 -5
  469. package/src/lib/core/icons.tsx +0 -1
  470. package/src/lib/core/router.tsx +0 -1
  471. package/src/lib/plugins/index.ts +0 -4
  472. package/src/lib/plugins/openapi/worker/shared-worker.ts +0 -5
  473. /package/dist/lib/plugins/{api-key → api-keys}/index.d.ts +0 -0
  474. /package/dist/lib/plugins/openapi/{worker → client}/worker.d.ts +0 -0
@@ -0,0 +1,63 @@
1
+ import * as Collapsible from "@radix-ui/react-collapsible";
2
+ import { useState } from "react";
3
+ import { SchemaObject } from "../../oas/parser/index.js";
4
+ import { cn } from "../../util/cn.js";
5
+ import { SchemaListViewItem } from "./SchemaListViewItem.js";
6
+
7
+ export const SchemaListViewItemGroup = ({
8
+ group,
9
+ properties,
10
+ nestingLevel,
11
+ required,
12
+ defaultOpen = false,
13
+ }: {
14
+ group: "optional" | "required" | "deprecated";
15
+ defaultOpen?: boolean;
16
+ properties: [string, SchemaObject][];
17
+ nestingLevel: number;
18
+ required: string[];
19
+ }) => {
20
+ const notCollapsible =
21
+ defaultOpen ||
22
+ group === "required" ||
23
+ properties.length === 1 ||
24
+ nestingLevel === 0;
25
+
26
+ const [open, setOpen] = useState(notCollapsible);
27
+
28
+ if (properties.length === 0) {
29
+ return;
30
+ }
31
+
32
+ return (
33
+ <Collapsible.Root
34
+ className="CollapsibleRoot"
35
+ open={open}
36
+ onOpenChange={setOpen}
37
+ >
38
+ {!open && (
39
+ <Collapsible.Trigger
40
+ className={cn(
41
+ "py-2 hover:bg-muted w-full",
42
+ group === "optional" && "font-semibold",
43
+ group === "deprecated" && "text-muted-foreground",
44
+ )}
45
+ >
46
+ {properties.length} {group} fields
47
+ </Collapsible.Trigger>
48
+ )}
49
+
50
+ <Collapsible.Content className="divide-y divide-border">
51
+ {properties.map(([propertyName, property]) => (
52
+ <SchemaListViewItem
53
+ key={propertyName}
54
+ property={property}
55
+ propertyName={propertyName}
56
+ nestingLevel={nestingLevel}
57
+ isRequired={required.includes(propertyName)}
58
+ />
59
+ ))}
60
+ </Collapsible.Content>
61
+ </Collapsible.Root>
62
+ );
63
+ };
@@ -1,16 +1,17 @@
1
1
  import { HTTPSnippet } from "@zudoku/httpsnippet";
2
- import { Fragment, useMemo, useState } from "react";
2
+ import { Fragment, useMemo } from "react";
3
+ import { useSearchParams } from "react-router-dom";
3
4
  import { SyntaxHighlight } from "../../components/SyntaxHighlight.js";
4
5
  import type { SchemaObject } from "../../oas/parser/index.js";
5
6
  import { cn } from "../../util/cn.js";
6
7
  import { ColorizedParam } from "./ColorizedParam.js";
7
- import { MakeRequest } from "./MakeRequest.js";
8
8
  import { MethodTextColorMap } from "./MethodBadge.js";
9
9
  import type { OperationListItemResult } from "./OperationList.js";
10
+ import { PlaygroundDialogWrapper } from "./PlaygroundDialogWrapper.js";
10
11
  import { RequestBodySidecarBox } from "./RequestBodySidecarBox.js";
11
12
  import { ResponsesSidecarBox } from "./ResponsesSidecarBox.js";
12
- import { Select } from "./Select.js";
13
13
  import * as SidecarBox from "./SidecarBox.js";
14
+ import { SimpleSelect } from "./SimpleSelect.js";
14
15
  import { generateSchemaExample } from "./util/generateSchemaExample.js";
15
16
 
16
17
  const getConverted = (snippet: HTTPSnippet, option: string) => {
@@ -64,7 +65,10 @@ export const Sidecar = ({
64
65
  }) => {
65
66
  const methodTextColor =
66
67
  MethodTextColorMap[operation.method as keyof typeof MethodTextColorMap];
67
- const [option, setOption] = useState("curl");
68
+
69
+ const [searchParams, setSearchParams] = useSearchParams();
70
+ const selectedLang = searchParams.get("lang") ?? "shell";
71
+
68
72
  const requestBodyContent = operation.requestBody?.content;
69
73
 
70
74
  const path = operation.path.split("/").map((part) => (
@@ -105,8 +109,8 @@ export const Sidecar = ({
105
109
  } as never, // 👈 never touch this
106
110
  );
107
111
 
108
- return getConverted(snippet, option);
109
- }, [option, operation.method, operation.path, requestBodyContent]);
112
+ return getConverted(snippet, selectedLang);
113
+ }, [selectedLang, operation.method, operation.path, requestBodyContent]);
110
114
 
111
115
  return (
112
116
  <aside className="flex flex-col overflow-hidden sticky top-[--scroll-padding] gap-4">
@@ -120,9 +124,10 @@ export const Sidecar = ({
120
124
  {path}
121
125
  </span>
122
126
  <div className="flex gap-2 items-center">
123
- <Select
127
+ <SimpleSelect
124
128
  className="self-start"
125
- onChange={(e) => setOption(e.target.value)}
129
+ value={selectedLang}
130
+ onChange={(e) => setSearchParams({ lang: e.target.value })}
126
131
  options={[
127
132
  { value: "shell", label: "cURL" },
128
133
  { value: "js", label: "Javascript" },
@@ -137,12 +142,12 @@ export const Sidecar = ({
137
142
  { value: "swift", label: "Swift" },
138
143
  ]}
139
144
  />
140
- <MakeRequest operation={operation} />
145
+ <PlaygroundDialogWrapper operation={operation} />
141
146
  </div>
142
147
  </SidecarBox.Head>
143
148
  <SidecarBox.Body>
144
149
  <SyntaxHighlight
145
- language={option}
150
+ language={selectedLang}
146
151
  noBackground
147
152
  className="text-xs"
148
153
  code={code}
@@ -1,13 +1,15 @@
1
+ import { ChevronsUpDownIcon } from "lucide-react";
1
2
  import type { ChangeEventHandler } from "react";
2
- import { ChevronsUpDownIcon } from "../../core/icons.js";
3
3
  import { cn } from "../../util/cn.js";
4
4
 
5
- export const Select = ({
5
+ export const SimpleSelect = ({
6
+ value,
6
7
  onChange,
7
8
  className,
8
9
  options,
9
10
  }: {
10
- onChange?: ChangeEventHandler<HTMLSelectElement>;
11
+ value: string;
12
+ onChange: ChangeEventHandler<HTMLSelectElement>;
11
13
  className?: string;
12
14
  options: {
13
15
  value: string;
@@ -20,6 +22,7 @@ export const Select = ({
20
22
  "row-start-1 col-start-1 border border-input text-foreground px-2 py-1 pe-6",
21
23
  "rounded-md appearance-none bg-zinc-50 hover:bg-white dark:bg-zinc-800 hover:dark:bg-zinc-800/75",
22
24
  )}
25
+ value={value}
23
26
  onChange={onChange}
24
27
  >
25
28
  {options.map((option) => (
@@ -0,0 +1,56 @@
1
+ /* eslint-disable no-console */
2
+ import {
3
+ cacheExchange,
4
+ Client,
5
+ fetchExchange,
6
+ mapExchange,
7
+ } from "../util/urql.js";
8
+ import { createServer } from "./createServer.js";
9
+ import { CreateClientFunction } from "./interfaces.js";
10
+
11
+ export type WorkerGraphQLMessage = { id: string; body: string };
12
+
13
+ const localServer = createServer();
14
+
15
+ /**
16
+ * Creates an in memory Client that does not use Workers. This allows
17
+ * developers to run the simple standalone version of zudoku using the CDN
18
+ * hosted scripts. Worker's cannot be loaded cross domain so in this case
19
+ * we sacrifice performance for making it work cross domain.
20
+ */
21
+ export const createClient: CreateClientFunction = () => {
22
+ return new Client({
23
+ url: "/__z/graphql",
24
+ // Custom fetch to send the GraphQL request to the worker and convert the response back to a `Response` object
25
+ fetch: async (req, init) => {
26
+ if (!init?.body) throw new Error("No body");
27
+ const response = await localServer.fetch(
28
+ new Request("http://localhost/__z/graphql", {
29
+ method: "POST",
30
+ body: init.body,
31
+ headers: {
32
+ "Content-Type": "application/json",
33
+ },
34
+ }),
35
+ );
36
+ return response;
37
+ // port.postMessage({
38
+ // id: e.data.id,
39
+ // body: await response.text(),
40
+ // } satisfies WorkerGraphQLMessage);
41
+ },
42
+ exchanges: [
43
+ cacheExchange,
44
+ mapExchange({
45
+ onError(error, operation) {
46
+ console.error(error);
47
+ console.groupCollapsed("Operation info");
48
+ console.log("body", operation.query.loc?.source.body.trim());
49
+ console.log("variables", operation.variables);
50
+ console.groupEnd();
51
+ },
52
+ }),
53
+ fetchExchange,
54
+ ],
55
+ });
56
+ };
@@ -0,0 +1,33 @@
1
+ import { useLogger } from "@envelop/core";
2
+ import { createGraphQLServer } from "../../../oas/graphql/index.js";
3
+
4
+ const map = new Map<string, number>();
5
+
6
+ /**
7
+ * Creates the GraphQL server
8
+ */
9
+ export const createServer = () =>
10
+ createGraphQLServer({
11
+ plugins: [
12
+ // eslint-disable-next-line react-hooks/rules-of-hooks
13
+ useLogger({
14
+ logFn: (eventName, { args }) => {
15
+ if (import.meta.env.PROD) return;
16
+
17
+ if (eventName.endsWith("-start")) {
18
+ map.set(`${eventName}-${args.operationName}`, performance.now());
19
+ } else if (eventName.endsWith("-end")) {
20
+ const startEvent = eventName.replace("-end", "-start");
21
+ const start = map.get(`${startEvent}-${args.operationName}`);
22
+ if (start) {
23
+ // eslint-disable-next-line no-console
24
+ console.log(
25
+ `${args.operationName} query took ${performance.now() - start}ms`,
26
+ );
27
+ map.delete(`${startEvent}-${args.operationName}`);
28
+ }
29
+ }
30
+ },
31
+ }),
32
+ ],
33
+ });
@@ -7,15 +7,35 @@ import {
7
7
  fetchExchange,
8
8
  mapExchange,
9
9
  } from "../util/urql.js";
10
+ import { createClient as createMemoryClient } from "./createMemoryClient.js";
11
+ import { CreateClientFunction } from "./interfaces.js";
10
12
 
11
13
  export type WorkerGraphQLMessage = { id: string; body: string };
12
14
 
13
15
  const ulid = monotonicFactory();
14
- export const createSharedWorkerClient = () => {
16
+
17
+ /**
18
+ * This loads the client from a worker and uses mess port to send requests
19
+ * and responses between the main thread and the worker.
20
+ */
21
+ export const createClient: CreateClientFunction = ({
22
+ useMemoryClient,
23
+ }: {
24
+ useMemoryClient: boolean;
25
+ }) => {
26
+ if (useMemoryClient || typeof SharedWorker === "undefined") {
27
+ return createMemoryClient({ useMemoryClient });
28
+ }
29
+ // NOTE: This URL needs to be inline with the SharedWorker otherwse
30
+ // vite build does not recognize the worker file as a module.
15
31
  const worker = new SharedWorker(new URL("./worker.ts", import.meta.url), {
16
32
  type: "module",
17
33
  });
18
34
 
35
+ worker.onerror = (e) => {
36
+ console.error(e);
37
+ };
38
+
19
39
  worker.port.start();
20
40
 
21
41
  const [waitFor, notify] = createWaitForNotify<string>();
@@ -0,0 +1,5 @@
1
+ import { Client } from "urql";
2
+
3
+ export type CreateClientFunction = (config: {
4
+ useMemoryClient: boolean;
5
+ }) => Client;
@@ -1,7 +1,7 @@
1
- import { createGraphQLServer } from "../../../oas/graphql/index.js";
2
- import { type WorkerGraphQLMessage } from "./createSharedWorkerClient.js";
1
+ import { createServer } from "./createServer.js";
2
+ import { type WorkerGraphQLMessage } from "./createWorkerClient.js";
3
3
 
4
- const localServer = createGraphQLServer();
4
+ const localServer = createServer();
5
5
 
6
6
  const worker = self as unknown as SharedWorkerGlobalScope;
7
7
 
@@ -0,0 +1,16 @@
1
+ import { createContext, useContext } from "react";
2
+ import { OasPluginConfig } from "./interfaces.js";
3
+
4
+ const OasContext = createContext<{ config: OasPluginConfig } | undefined>(
5
+ undefined,
6
+ );
7
+
8
+ export const OasConfigProvider = OasContext.Provider;
9
+
10
+ export const useOasConfig = () => {
11
+ const ctx = useContext(OasContext);
12
+ if (!ctx) {
13
+ throw new Error("useOasConfig must be used within a OasConfigProvider");
14
+ }
15
+ return ctx.config;
16
+ };
@@ -1,61 +1,20 @@
1
- import { createContext, useContext } from "react";
1
+ import { matchPath, useRouteError, type RouteObject } from "react-router-dom";
2
2
  import {
3
3
  type DevPortalPlugin,
4
4
  type PluginNavigationCategory,
5
5
  } from "../../core/plugins.js";
6
- import { Outlet, matchPath, type RouteObject } from "../../core/router.js";
7
6
  import { MethodBadge } from "./MethodBadge.js";
8
- import { OperationList } from "./OperationList.js";
9
7
  import { graphql } from "./graphql/index.js";
10
8
  import {
11
- Provider,
12
9
  Client as UrqlClient,
13
10
  cacheExchange,
14
11
  fetchExchange,
15
12
  } from "./util/urql.js";
16
13
 
17
- import { createSharedWorkerClient } from "virtual:zudoku-openapi-worker";
18
- import type { createSharedWorkerClient as createSharedWorkerClientType } from "./worker/createSharedWorkerClient.js";
19
-
20
- const OasContext = createContext<{ config: OasPluginConfig } | undefined>(
21
- undefined,
22
- );
23
-
24
- export const OasConfigProvider = OasContext.Provider;
25
-
26
- export const useOasConfig = () => {
27
- const ctx = useContext(OasContext);
28
- if (!ctx) {
29
- throw new Error("useOasConfig must be used within a OasConfigProvider");
30
- }
31
- return ctx.config;
32
- };
33
-
34
- type OasSource =
35
- | { type: "url"; input: string }
36
- | { type: "yaml"; input: string }
37
- | { type: "json"; input: object };
38
-
39
- export type OasPluginConfig = {
40
- server?: string;
41
- path?: string;
42
- } & OasSource;
43
-
44
- const OasContextProvider = ({
45
- config,
46
- client,
47
- }: {
48
- config: OasPluginConfig;
49
- client: typeof UrqlClient;
50
- }) => {
51
- return (
52
- <Provider value={client}>
53
- <OasConfigProvider value={{ config }}>
54
- <Outlet />
55
- </OasConfigProvider>
56
- </Provider>
57
- );
58
- };
14
+ import { ErrorPage } from "../../components/ErrorPage.js";
15
+ import { SyntaxHighlight } from "../../components/SyntaxHighlight.js";
16
+ import { createClient } from "./client/createWorkerClient.js";
17
+ import { OasPluginConfig } from "./interfaces.js";
59
18
 
60
19
  const GetCategoriesQuery = graphql(`
61
20
  query GetCategories($input: JSON!, $type: SchemaType!) {
@@ -77,7 +36,25 @@ const GetCategoriesQuery = graphql(`
77
36
  }
78
37
  `);
79
38
 
80
- export const openApiPlugin = (config: OasPluginConfig): DevPortalPlugin => {
39
+ const OpenApiErrorPage = () => {
40
+ const error = useRouteError();
41
+ const message =
42
+ error instanceof Error ? (
43
+ <SyntaxHighlight code={error.message} />
44
+ ) : (
45
+ "An unknown error occurred"
46
+ );
47
+
48
+ return (
49
+ <ErrorPage category="Error" title="An error occurred" message={message} />
50
+ );
51
+ };
52
+
53
+ type InternalOasPluginConfig = { inMemory?: boolean };
54
+
55
+ export const openApiPlugin = (
56
+ config: OasPluginConfig & InternalOasPluginConfig,
57
+ ): DevPortalPlugin => {
81
58
  const basePath = config.path ?? "/reference";
82
59
 
83
60
  const client = config.server
@@ -85,11 +62,25 @@ export const openApiPlugin = (config: OasPluginConfig): DevPortalPlugin => {
85
62
  url: config.server,
86
63
  exchanges: [cacheExchange, fetchExchange],
87
64
  })
88
- : (createSharedWorkerClient() as ReturnType<
89
- typeof createSharedWorkerClientType
90
- >);
65
+ : createClient({ useMemoryClient: config.inMemory ?? false });
91
66
 
92
67
  return {
68
+ getHead: () => {
69
+ if (config.type === "url") {
70
+ return (
71
+ <link
72
+ rel="preload"
73
+ href={config.input}
74
+ as="fetch"
75
+ crossOrigin="anonymous"
76
+ />
77
+ );
78
+ }
79
+
80
+ if (config.server) {
81
+ return <link rel="preconnect" href={config.server} />;
82
+ }
83
+ },
93
84
  getNavigation: async (path: string) => {
94
85
  if (!matchPath({ path: basePath, end: false }, path)) {
95
86
  return [];
@@ -135,11 +126,27 @@ export const openApiPlugin = (config: OasPluginConfig): DevPortalPlugin => {
135
126
  getRoutes: () =>
136
127
  [
137
128
  {
138
- element: <OasContextProvider config={config} client={client} />,
129
+ async lazy() {
130
+ const { OpenApiRoute } = await import("./Route.js");
131
+ return {
132
+ element: <OpenApiRoute client={client} config={config} />,
133
+ };
134
+ },
135
+ errorElement: <OpenApiErrorPage />,
139
136
  children: [
140
137
  {
141
138
  path: basePath,
142
- children: [{ index: true, element: <OperationList /> }],
139
+ children: [
140
+ {
141
+ index: true,
142
+ async lazy() {
143
+ const { OperationList } = await import(
144
+ "./OperationList.js"
145
+ );
146
+ return { element: <OperationList /> };
147
+ },
148
+ },
149
+ ],
143
150
  },
144
151
  ],
145
152
  },
@@ -0,0 +1,9 @@
1
+ type OasSource =
2
+ | { type: "url"; input: string }
3
+ | { type: "yaml"; input: string }
4
+ | { type: "json"; input: object };
5
+
6
+ export type OasPluginConfig = {
7
+ server?: string;
8
+ path?: string;
9
+ } & OasSource;
@@ -1,53 +1,80 @@
1
- import { XIcon } from "lucide-react";
2
- import { Control, useFieldArray, UseFormRegister } from "react-hook-form";
1
+ import { TriangleAlertIcon, XIcon } from "lucide-react";
2
+ import {
3
+ Control,
4
+ useFieldArray,
5
+ UseFormRegister,
6
+ useWatch,
7
+ } from "react-hook-form";
3
8
  import { Button } from "../../../ui/Button.js";
9
+ import { cn } from "../../../util/cn.js";
4
10
  import { InlineInput } from "./InlineInput.js";
5
- import type { Header, PlaygroundForm } from "./Playground.js";
11
+ import { NO_IDENTITY, type PlaygroundForm } from "./Playground.js";
6
12
 
7
13
  export const Headers = ({
8
14
  control,
9
15
  register,
10
- headers,
11
16
  }: {
12
17
  register: UseFormRegister<PlaygroundForm>;
13
18
  control: Control<PlaygroundForm>;
14
- headers: Header[];
15
19
  }) => {
16
20
  const { fields, append, remove } = useFieldArray<PlaygroundForm>({
17
21
  control,
18
22
  name: "headers",
19
23
  });
24
+ const selectedIdentity = useWatch({ name: "identity", control });
25
+ const liveHeaders = useWatch({ name: "headers", control });
26
+
27
+ const disableAuth = selectedIdentity !== NO_IDENTITY;
28
+
20
29
  return (
21
30
  <div className="grid grid-cols-[1fr_1fr_auto]">
22
- {fields.map((header, i) => (
23
- <div
24
- key={header.id}
25
- className="grid-cols-subgrid col-span-full grid items-center gap-x-2 has-[:focus]:bg-muted hover:bg-muted rounded overflow-hidden group"
26
- >
27
- <InlineInput
28
- {...register(`headers.${i}.name`)}
29
- placeholder="Name"
30
- className="peer"
31
- autoComplete="off"
32
- />
33
- <InlineInput
34
- placeholder={"Value"}
35
- className="peer"
36
- {...register(`headers.${i}.value`)}
37
- autoComplete="off"
38
- />
39
- <button
40
- className="hover:bg-black/5 p-1 rounded mr-2 text-muted-foreground invisible group-hover:visible peer-focus:visible"
41
- onClick={() => {
42
- remove(i);
43
- }}
44
- type="button"
31
+ {fields.map((header, i) => {
32
+ const isDisabledByAuth =
33
+ disableAuth && liveHeaders.at(i)?.name === "Authorization";
34
+
35
+ return (
36
+ <div
37
+ key={header.id}
38
+ className={cn(
39
+ "grid-cols-subgrid col-span-full grid items-center gap-x-2 has-[:focus]:bg-muted hover:bg-muted rounded overflow-hidden group",
40
+ isDisabledByAuth && "line-through",
41
+ )}
42
+ title={
43
+ isDisabledByAuth
44
+ ? "This header is disabled because authentication was selected"
45
+ : undefined
46
+ }
45
47
  >
46
- <XIcon size={16} />
47
- </button>
48
- <div className="col-span-full border-b border-border"></div>
49
- </div>
50
- ))}
48
+ <div className="flex gap-2 items-center">
49
+ <InlineInput
50
+ {...register(`headers.${i}.name`)}
51
+ placeholder="Name"
52
+ className="peer"
53
+ autoComplete="off"
54
+ />
55
+ {isDisabledByAuth && (
56
+ <TriangleAlertIcon size={16} className="text-amber-500" />
57
+ )}
58
+ </div>
59
+ <InlineInput
60
+ placeholder={"Value"}
61
+ className="peer"
62
+ {...register(`headers.${i}.value`)}
63
+ autoComplete="off"
64
+ />
65
+ <button
66
+ className="hover:bg-black/5 p-1 rounded mr-2 text-muted-foreground invisible group-hover:visible peer-focus:visible"
67
+ onClick={() => {
68
+ remove(i);
69
+ }}
70
+ type="button"
71
+ >
72
+ <XIcon size={16} />
73
+ </button>
74
+ <div className="col-span-full border-b border-border"></div>
75
+ </div>
76
+ );
77
+ })}
51
78
  <Button
52
79
  className="col-span-full mt-4"
53
80
  onClick={() => append({ name: "", value: "" })}
@@ -3,7 +3,7 @@ import { Control, useFieldArray, UseFormRegister } from "react-hook-form";
3
3
  import { cn } from "../../../util/cn.js";
4
4
  import { DATA_ATTR, usePastellizedColor } from "../ColorizedParam.js";
5
5
  import { InlineInput } from "./InlineInput.js";
6
- import { PlaygroundForm } from "./Playground.js";
6
+ import type { PlaygroundForm } from "./Playground.js";
7
7
 
8
8
  type ParameterValueProps = {
9
9
  part: string;