zudoku 0.26.0 → 0.27.0

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 (300) hide show
  1. package/dist/app/main.d.ts +1 -1
  2. package/dist/app/main.js +19 -7
  3. package/dist/app/main.js.map +1 -1
  4. package/dist/config/config.d.ts +1 -0
  5. package/dist/config/validators/InputSidebarSchema.d.ts +2 -2
  6. package/dist/config/validators/common.d.ts +78 -0
  7. package/dist/config/validators/common.js +6 -0
  8. package/dist/config/validators/common.js.map +1 -1
  9. package/dist/config/validators/validate.d.ts +34 -0
  10. package/dist/lib/authentication/providers/auth0.js +1 -1
  11. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  12. package/dist/lib/authentication/providers/openid.d.ts +1 -1
  13. package/dist/lib/authentication/providers/openid.js +10 -6
  14. package/dist/lib/authentication/providers/openid.js.map +1 -1
  15. package/dist/lib/components/AnchorLink.js +5 -2
  16. package/dist/lib/components/AnchorLink.js.map +1 -1
  17. package/dist/lib/components/Autocomplete.d.ts +12 -0
  18. package/dist/lib/components/Autocomplete.js +47 -0
  19. package/dist/lib/components/Autocomplete.js.map +1 -0
  20. package/dist/lib/components/Header.js +4 -4
  21. package/dist/lib/components/Header.js.map +1 -1
  22. package/dist/lib/components/Heading.d.ts +1 -1
  23. package/dist/lib/components/Markdown.d.ts +2 -2
  24. package/dist/lib/components/Markdown.js +3 -1
  25. package/dist/lib/components/Markdown.js.map +1 -1
  26. package/dist/lib/components/StatusPage.d.ts +7 -0
  27. package/dist/lib/components/StatusPage.js +71 -0
  28. package/dist/lib/components/StatusPage.js.map +1 -0
  29. package/dist/lib/components/SyntaxHighlight.d.ts +2 -1
  30. package/dist/lib/components/SyntaxHighlight.js +2 -2
  31. package/dist/lib/components/SyntaxHighlight.js.map +1 -1
  32. package/dist/lib/components/ThemeSwitch.js +4 -4
  33. package/dist/lib/components/ThemeSwitch.js.map +1 -1
  34. package/dist/lib/components/cache.d.ts +6 -0
  35. package/dist/lib/components/cache.js +13 -0
  36. package/dist/lib/components/cache.js.map +1 -0
  37. package/dist/lib/components/context/ViewportAnchorContext.js +16 -4
  38. package/dist/lib/components/context/ViewportAnchorContext.js.map +1 -1
  39. package/dist/lib/components/context/ZudokuContext.js +2 -1
  40. package/dist/lib/components/context/ZudokuContext.js.map +1 -1
  41. package/dist/lib/components/index.d.ts +9 -2
  42. package/dist/lib/components/index.js +5 -2
  43. package/dist/lib/components/index.js.map +1 -1
  44. package/dist/lib/core/RouteGuard.d.ts +1 -0
  45. package/dist/lib/core/RouteGuard.js +28 -0
  46. package/dist/lib/core/RouteGuard.js.map +1 -0
  47. package/dist/lib/core/ZudokuContext.d.ts +4 -2
  48. package/dist/lib/core/ZudokuContext.js +9 -7
  49. package/dist/lib/core/ZudokuContext.js.map +1 -1
  50. package/dist/lib/oas/graphql/circular.d.ts +3 -0
  51. package/dist/lib/oas/graphql/circular.js +27 -0
  52. package/dist/lib/oas/graphql/circular.js.map +1 -0
  53. package/dist/lib/oas/graphql/index.js +5 -6
  54. package/dist/lib/oas/graphql/index.js.map +1 -1
  55. package/dist/lib/oas/parser/dereference/index.d.ts +0 -1
  56. package/dist/lib/oas/parser/dereference/index.js +1 -1
  57. package/dist/lib/oas/parser/dereference/index.js.map +1 -1
  58. package/dist/lib/plugins/markdown/MdxPage.js +8 -2
  59. package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
  60. package/dist/lib/plugins/openapi/OperationListItem.js +1 -1
  61. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  62. package/dist/lib/plugins/openapi/ParameterListItem.js +1 -1
  63. package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
  64. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.d.ts +3 -1
  65. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js +3 -2
  66. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js.map +1 -1
  67. package/dist/lib/plugins/openapi/Sidecar.js +3 -3
  68. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  69. package/dist/lib/plugins/openapi/index.js +4 -11
  70. package/dist/lib/plugins/openapi/index.js.map +1 -1
  71. package/dist/lib/plugins/openapi/interfaces.d.ts +7 -2
  72. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.d.ts +6 -0
  73. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +12 -0
  74. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -0
  75. package/dist/lib/plugins/openapi/playground/Headers.js +67 -4
  76. package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
  77. package/dist/lib/plugins/openapi/playground/ParamsGrid.d.ts +5 -0
  78. package/dist/lib/plugins/openapi/playground/ParamsGrid.js +4 -0
  79. package/dist/lib/plugins/openapi/playground/ParamsGrid.js.map +1 -0
  80. package/dist/lib/plugins/openapi/playground/PathParams.js +4 -12
  81. package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
  82. package/dist/lib/plugins/openapi/playground/Playground.d.ts +18 -1
  83. package/dist/lib/plugins/openapi/playground/Playground.js +53 -40
  84. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  85. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +1 -1
  86. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
  87. package/dist/lib/plugins/openapi/playground/QueryParams.js +21 -30
  88. package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
  89. package/dist/lib/plugins/openapi/playground/SubmitButton.d.ts +7 -0
  90. package/dist/lib/plugins/openapi/playground/SubmitButton.js +22 -0
  91. package/dist/lib/plugins/openapi/playground/SubmitButton.js.map +1 -0
  92. package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.d.ts +7 -0
  93. package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js +11 -0
  94. package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js.map +1 -0
  95. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.d.ts +8 -0
  96. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +95 -0
  97. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -0
  98. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.d.ts +7 -0
  99. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js +16 -0
  100. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js.map +1 -0
  101. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.d.ts +10 -0
  102. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.js +32 -0
  103. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.js.map +1 -0
  104. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.test.d.ts +1 -0
  105. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.test.js +56 -0
  106. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.test.js.map +1 -0
  107. package/dist/lib/plugins/openapi/post-processors/removeExtensions.d.ts +2 -1
  108. package/dist/lib/plugins/openapi/post-processors/removeExtensions.js +5 -3
  109. package/dist/lib/plugins/openapi/post-processors/removeExtensions.js.map +1 -1
  110. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js +49 -0
  111. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js.map +1 -1
  112. package/dist/lib/plugins/openapi/post-processors/removeParameters.d.ts +10 -0
  113. package/dist/lib/plugins/openapi/post-processors/removeParameters.js +66 -0
  114. package/dist/lib/plugins/openapi/post-processors/removeParameters.js.map +1 -0
  115. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.d.ts +1 -0
  116. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.js +131 -0
  117. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.js.map +1 -0
  118. package/dist/lib/plugins/openapi/schema/SchemaComponents.js +1 -1
  119. package/dist/lib/plugins/openapi/schema/SchemaComponents.js.map +1 -1
  120. package/dist/lib/ui/Command.d.ts +9 -1
  121. package/dist/lib/ui/Command.js +5 -1
  122. package/dist/lib/ui/Command.js.map +1 -1
  123. package/dist/lib/ui/Select.js +2 -2
  124. package/dist/lib/ui/Select.js.map +1 -1
  125. package/dist/lib/util/MdxComponents.js +2 -2
  126. package/dist/lib/util/MdxComponents.js.map +1 -1
  127. package/dist/lib/util/joinUrl.d.ts +1 -0
  128. package/dist/lib/util/joinUrl.js +40 -0
  129. package/dist/lib/util/joinUrl.js.map +1 -0
  130. package/dist/lib/util/useScrollToAnchor.d.ts +1 -0
  131. package/dist/lib/util/useScrollToAnchor.js +26 -15
  132. package/dist/lib/util/useScrollToAnchor.js.map +1 -1
  133. package/dist/vite/build.js +10 -10
  134. package/dist/vite/build.js.map +1 -1
  135. package/dist/vite/config.js +4 -1
  136. package/dist/vite/config.js.map +1 -1
  137. package/dist/vite/dev-server.js +4 -1
  138. package/dist/vite/dev-server.js.map +1 -1
  139. package/dist/vite/plugin-api.d.ts +1 -1
  140. package/dist/vite/plugin-api.js +31 -7
  141. package/dist/vite/plugin-api.js.map +1 -1
  142. package/dist/vite/plugin-auth.js +4 -1
  143. package/dist/vite/plugin-auth.js.map +1 -1
  144. package/dist/vite/plugin-mdx.js +9 -4
  145. package/dist/vite/plugin-mdx.js.map +1 -1
  146. package/dist/vite/prerender.d.ts +2 -2
  147. package/dist/vite/prerender.js +5 -4
  148. package/dist/vite/prerender.js.map +1 -1
  149. package/dist/zuplo/enrich-with-zuplo.d.ts +5 -0
  150. package/dist/zuplo/enrich-with-zuplo.js +184 -0
  151. package/dist/zuplo/enrich-with-zuplo.js.map +1 -0
  152. package/dist/zuplo/env.d.ts +1 -0
  153. package/dist/zuplo/env.js +3 -0
  154. package/dist/zuplo/env.js.map +1 -1
  155. package/dist/zuplo/policy-types.d.ts +33 -0
  156. package/dist/zuplo/policy-types.js +8 -0
  157. package/dist/zuplo/policy-types.js.map +1 -0
  158. package/dist/zuplo/with-zuplo-processors.d.ts +3 -0
  159. package/dist/zuplo/with-zuplo-processors.js +26 -0
  160. package/dist/zuplo/with-zuplo-processors.js.map +1 -0
  161. package/dist/zuplo/with-zuplo.d.ts +1 -1
  162. package/dist/zuplo/with-zuplo.js +7 -26
  163. package/dist/zuplo/with-zuplo.js.map +1 -1
  164. package/lib/{AuthenticationPlugin-DNXBcsVN.js → AuthenticationPlugin-CO_YCd2x.js} +3 -3
  165. package/lib/{AuthenticationPlugin-DNXBcsVN.js.map → AuthenticationPlugin-CO_YCd2x.js.map} +1 -1
  166. package/lib/{Markdown-BrfrjEk_.js → Markdown-B8o9Qz4q.js} +1197 -1186
  167. package/lib/{Markdown-BrfrjEk_.js.map → Markdown-B8o9Qz4q.js.map} +1 -1
  168. package/lib/{MdxPage-LNZLj_A5.js → MdxPage-BxRt3Ly7.js} +63 -58
  169. package/lib/MdxPage-BxRt3Ly7.js.map +1 -0
  170. package/lib/OperationList-DH-zIgtq.js +5160 -0
  171. package/lib/OperationList-DH-zIgtq.js.map +1 -0
  172. package/lib/{Route-Pzk6qwIk.js → Route-DJ0ZlVq1.js} +3 -3
  173. package/lib/{Route-Pzk6qwIk.js.map → Route-DJ0ZlVq1.js.map} +1 -1
  174. package/lib/{Select-DkOpAG0c.js → Select-B7UXR0SB.js} +61 -61
  175. package/lib/Select-B7UXR0SB.js.map +1 -0
  176. package/lib/{SlotletProvider-DPbx9KdU.js → SlotletProvider-CtIp8rP3.js} +4 -4
  177. package/lib/{SlotletProvider-DPbx9KdU.js.map → SlotletProvider-CtIp8rP3.js.map} +1 -1
  178. package/lib/{Button-oroWHXAy.js → Spinner-BlzrEEk1.js} +15 -12
  179. package/lib/Spinner-BlzrEEk1.js.map +1 -0
  180. package/lib/{SyntaxHighlight-CJCSPG1F.js → SyntaxHighlight-C1w1QPdY.js} +300 -295
  181. package/lib/{SyntaxHighlight-CJCSPG1F.js.map → SyntaxHighlight-C1w1QPdY.js.map} +1 -1
  182. package/lib/{ZudokuContext-D3ayHjP-.js → ZudokuContext-8jts0fF3.js} +259 -248
  183. package/lib/ZudokuContext-8jts0fF3.js.map +1 -0
  184. package/lib/{chunk-SYFQ2XB5-KWlHsT7t.js → chunk-SYFQ2XB5-BPvC-soB.js} +6 -5
  185. package/lib/{chunk-SYFQ2XB5-KWlHsT7t.js.map → chunk-SYFQ2XB5-BPvC-soB.js.map} +1 -1
  186. package/lib/circular-Dgpd6AN-.js +15397 -0
  187. package/lib/circular-Dgpd6AN-.js.map +1 -0
  188. package/lib/{createServer-BcaswoFO.js → createServer-BV0tHzLK.js} +3450 -5577
  189. package/lib/createServer-BV0tHzLK.js.map +1 -0
  190. package/lib/{hook-DUyACbIK.js → hook-BG02esyv.js} +2 -2
  191. package/lib/{hook-DUyACbIK.js.map → hook-BG02esyv.js.map} +1 -1
  192. package/lib/index-B7mqiOei.js +509 -0
  193. package/lib/index-B7mqiOei.js.map +1 -0
  194. package/lib/index-DmqsUPcm.js +1915 -0
  195. package/lib/index-DmqsUPcm.js.map +1 -0
  196. package/lib/joinUrl-BTy9bvoK.js +20 -0
  197. package/lib/joinUrl-BTy9bvoK.js.map +1 -0
  198. package/lib/post-processors/removeExtensions.js +7 -7
  199. package/lib/post-processors/removeExtensions.js.map +1 -1
  200. package/lib/post-processors/removeParameters.js +48 -0
  201. package/lib/post-processors/removeParameters.js.map +1 -0
  202. package/lib/ui/ActionButton.js +10 -11
  203. package/lib/ui/ActionButton.js.map +1 -1
  204. package/lib/ui/Command.js +125 -13
  205. package/lib/ui/Command.js.map +1 -1
  206. package/lib/ui/Select.js +2 -2
  207. package/lib/ui/Select.js.map +1 -1
  208. package/lib/{useExposedProps-BBHR7aLM.js → useExposedProps-BLKFBylA.js} +2 -2
  209. package/lib/{useExposedProps-BBHR7aLM.js.map → useExposedProps-BLKFBylA.js.map} +1 -1
  210. package/lib/useScrollToAnchor-Bl6mz9_x.js +288 -0
  211. package/lib/useScrollToAnchor-Bl6mz9_x.js.map +1 -0
  212. package/lib/zudoku.auth-auth0.js +7 -9
  213. package/lib/zudoku.auth-auth0.js.map +1 -1
  214. package/lib/zudoku.auth-clerk.js +1 -1
  215. package/lib/zudoku.auth-openid.js +223 -219
  216. package/lib/zudoku.auth-openid.js.map +1 -1
  217. package/lib/zudoku.components.js +754 -992
  218. package/lib/zudoku.components.js.map +1 -1
  219. package/lib/zudoku.plugin-api-catalog.js +3 -3
  220. package/lib/zudoku.plugin-api-keys.js +5 -5
  221. package/lib/zudoku.plugin-custom-pages.js +2 -2
  222. package/lib/zudoku.plugin-markdown.js +1 -1
  223. package/lib/zudoku.plugin-openapi.js +4 -4
  224. package/lib/zudoku.plugin-redirect.js +1 -1
  225. package/package.json +2 -2
  226. package/src/app/main.css +50 -50
  227. package/src/app/main.tsx +26 -7
  228. package/src/lib/authentication/providers/auth0.tsx +1 -4
  229. package/src/lib/authentication/providers/openid.tsx +12 -5
  230. package/src/lib/components/AnchorLink.tsx +5 -2
  231. package/src/lib/components/Autocomplete.tsx +111 -0
  232. package/src/lib/components/Header.tsx +4 -4
  233. package/src/lib/components/Markdown.tsx +14 -15
  234. package/src/lib/components/StatusPage.tsx +91 -0
  235. package/src/lib/components/SyntaxHighlight.tsx +14 -0
  236. package/src/lib/components/ThemeSwitch.tsx +14 -15
  237. package/src/lib/components/cache.ts +15 -0
  238. package/src/lib/components/context/ViewportAnchorContext.tsx +20 -6
  239. package/src/lib/components/context/ZudokuContext.ts +3 -1
  240. package/src/lib/components/index.ts +9 -2
  241. package/src/lib/core/RouteGuard.tsx +35 -0
  242. package/src/lib/core/ZudokuContext.ts +9 -8
  243. package/src/lib/oas/graphql/circular.ts +29 -0
  244. package/src/lib/oas/graphql/index.ts +9 -9
  245. package/src/lib/oas/parser/dereference/index.ts +1 -2
  246. package/src/lib/plugins/markdown/MdxPage.tsx +9 -1
  247. package/src/lib/plugins/openapi/OperationListItem.tsx +0 -2
  248. package/src/lib/plugins/openapi/ParameterListItem.tsx +1 -0
  249. package/src/lib/plugins/openapi/PlaygroundDialogWrapper.tsx +5 -0
  250. package/src/lib/plugins/openapi/Sidecar.tsx +4 -2
  251. package/src/lib/plugins/openapi/index.tsx +9 -15
  252. package/src/lib/plugins/openapi/interfaces.ts +10 -2
  253. package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +54 -0
  254. package/src/lib/plugins/openapi/playground/Headers.tsx +136 -39
  255. package/src/lib/plugins/openapi/playground/ParamsGrid.tsx +8 -0
  256. package/src/lib/plugins/openapi/playground/PathParams.tsx +34 -74
  257. package/src/lib/plugins/openapi/playground/Playground.tsx +219 -177
  258. package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +1 -1
  259. package/src/lib/plugins/openapi/playground/QueryParams.tsx +90 -122
  260. package/src/lib/plugins/openapi/playground/SubmitButton.tsx +75 -0
  261. package/src/lib/plugins/openapi/playground/result-panel/RequestTab.tsx +73 -0
  262. package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +210 -0
  263. package/src/lib/plugins/openapi/playground/result-panel/ResultPanel.tsx +101 -0
  264. package/src/lib/plugins/openapi/playground/result-panel/convertToTypes.test.ts +64 -0
  265. package/src/lib/plugins/openapi/playground/result-panel/convertToTypes.ts +36 -0
  266. package/src/lib/plugins/openapi/post-processors/removeExtensions.test.ts +58 -0
  267. package/src/lib/plugins/openapi/post-processors/removeExtensions.ts +7 -4
  268. package/src/lib/plugins/openapi/post-processors/removeParameters.test.ts +148 -0
  269. package/src/lib/plugins/openapi/post-processors/removeParameters.ts +101 -0
  270. package/src/lib/plugins/openapi/schema/SchemaComponents.tsx +1 -1
  271. package/src/lib/ui/Command.tsx +20 -0
  272. package/src/lib/ui/Select.tsx +1 -1
  273. package/src/lib/util/MdxComponents.tsx +2 -1
  274. package/src/lib/util/joinUrl.ts +57 -0
  275. package/src/lib/util/useScrollToAnchor.ts +32 -15
  276. package/dist/lib/plugins/openapi/playground/EnumSelector.d.ts +0 -8
  277. package/dist/lib/plugins/openapi/playground/EnumSelector.js +0 -21
  278. package/dist/lib/plugins/openapi/playground/EnumSelector.js.map +0 -1
  279. package/dist/lib/plugins/openapi/playground/ResponseTab.d.ts +0 -4
  280. package/dist/lib/plugins/openapi/playground/ResponseTab.js +0 -42
  281. package/dist/lib/plugins/openapi/playground/ResponseTab.js.map +0 -1
  282. package/lib/AnchorLink-_Vu02ceN.js +0 -34
  283. package/lib/AnchorLink-_Vu02ceN.js.map +0 -1
  284. package/lib/Button-oroWHXAy.js.map +0 -1
  285. package/lib/Command-D5DE0DD7.js +0 -611
  286. package/lib/Command-D5DE0DD7.js.map +0 -1
  287. package/lib/MdxPage-LNZLj_A5.js.map +0 -1
  288. package/lib/OperationList-PCwzTp1r.js +0 -5144
  289. package/lib/OperationList-PCwzTp1r.js.map +0 -1
  290. package/lib/Select-DkOpAG0c.js.map +0 -1
  291. package/lib/Spinner-C5gHXrVz.js +0 -7
  292. package/lib/Spinner-C5gHXrVz.js.map +0 -1
  293. package/lib/ZudokuContext-D3ayHjP-.js.map +0 -1
  294. package/lib/createServer-BcaswoFO.js.map +0 -1
  295. package/lib/index-CaILD1AV.js +0 -1292
  296. package/lib/index-CaILD1AV.js.map +0 -1
  297. package/lib/index-TaRXY2w1.js +0 -43
  298. package/lib/index-TaRXY2w1.js.map +0 -1
  299. package/src/lib/plugins/openapi/playground/EnumSelector.tsx +0 -86
  300. package/src/lib/plugins/openapi/playground/ResponseTab.tsx +0 -76
@@ -1,9 +1,49 @@
1
1
  import { XIcon } from "lucide-react";
2
- import { Control, useFieldArray, UseFormRegister } from "react-hook-form";
2
+ import { useRef } from "react";
3
+ import {
4
+ Control,
5
+ Controller,
6
+ useFieldArray,
7
+ useFormContext,
8
+ UseFormRegister,
9
+ } from "react-hook-form";
10
+ import { Card } from "zudoku/ui/Card.js";
11
+ import { Checkbox } from "zudoku/ui/Checkbox.js";
12
+ import { Autocomplete } from "../../../components/Autocomplete.js";
3
13
  import { Button } from "../../../ui/Button.js";
4
14
  import { Input } from "../../../ui/Input.js";
15
+ import ParamsGrid from "./ParamsGrid.js";
5
16
  import { type PlaygroundForm } from "./Playground.js";
6
17
 
18
+ const headerOptions = Object.freeze([
19
+ "Accept",
20
+ "Accept-Encoding",
21
+ "Accept-Language",
22
+ "Authorization",
23
+ "Cache-Control",
24
+ "Connection",
25
+ "Content-Disposition",
26
+ "Content-Encoding",
27
+ "Content-Language",
28
+ "Content-Length",
29
+ "Content-Range",
30
+ "Content-Security-Policy",
31
+ "Content-Type",
32
+ "Cookie",
33
+ "Date",
34
+ "ETag",
35
+ "Expires",
36
+ "Host",
37
+ "If-Modified-Since",
38
+ "Location",
39
+ "Origin",
40
+ "Pragma",
41
+ "Referer",
42
+ "Set-Cookie",
43
+ "User-Agent",
44
+ "X-Requested-With",
45
+ ]);
46
+
7
47
  export const Headers = ({
8
48
  control,
9
49
  register,
@@ -15,53 +55,110 @@ export const Headers = ({
15
55
  control,
16
56
  name: "headers",
17
57
  });
58
+ const { setValue } = useFormContext<PlaygroundForm>();
59
+ const valueRefs = useRef<Array<HTMLInputElement | null>>([]);
60
+ const nameRefs = useRef<Array<HTMLInputElement | null>>([]);
61
+
62
+ const addNewHeader = () => {
63
+ append({
64
+ name: "",
65
+ value: "",
66
+ active: false,
67
+ } as PlaygroundForm["headers"][number]);
68
+ };
69
+
70
+ const handleHeaderEnter = (index: number) => {
71
+ valueRefs.current[index]?.focus();
72
+ };
73
+
74
+ const handleValueEnter = (index: number) => {
75
+ addNewHeader();
76
+ requestAnimationFrame(() => nameRefs.current[index + 1]?.focus());
77
+ };
18
78
 
19
79
  return (
20
80
  <div className="flex flex-col gap-2">
21
- <table className="w-full [&_td]:border [&_td]:p-1.5 [&_td]:px-2">
22
- <tbody>
81
+ <Card className="overflow-hidden">
82
+ <ParamsGrid>
23
83
  {fields.map((header, i) => (
24
- <tr
25
- key={header.id}
26
- className="group has-[:focus]:bg-muted/50 hover:bg-muted/50"
27
- >
28
- <td className="flex gap-2 items-center">
29
- <Input
30
- {...register(`headers.${i}.name`)}
31
- placeholder="Name"
32
- className="border-0 shadow-none text-xs font-mono"
33
- autoComplete="off"
84
+ <div key={i} className="group grid col-span-full grid-cols-subgrid">
85
+ <div className="flex items-center gap-2 ">
86
+ <Controller
87
+ control={control}
88
+ name={`headers.${i}.active`}
89
+ render={({ field }) => (
90
+ <Checkbox
91
+ variant="outline"
92
+ id={`headers.${i}.active`}
93
+ checked={field.value}
94
+ onCheckedChange={(checked) => {
95
+ field.onChange(checked);
96
+ }}
97
+ />
98
+ )}
99
+ />
100
+ <Controller
101
+ control={control}
102
+ name={`headers.${i}.name`}
103
+ render={({ field }) => (
104
+ <Autocomplete
105
+ {...field}
106
+ placeholder="Name"
107
+ className="border-0 shadow-none bg-transparent text-xs font-mono"
108
+ options={headerOptions}
109
+ onEnterPress={() => handleHeaderEnter(i)}
110
+ onChange={(e) => {
111
+ field.onChange(e);
112
+ setValue(`headers.${i}.active`, true);
113
+ }}
114
+ ref={(el) => {
115
+ nameRefs.current[i] = el;
116
+ }}
117
+ />
118
+ )}
119
+ />
120
+ </div>
121
+ <div className="flex items-center gap-2">
122
+ <Controller
123
+ control={control}
124
+ name={`headers.${i}.value`}
125
+ render={({ field }) => (
126
+ <Input
127
+ placeholder="Value"
128
+ className="w-full border-0 shadow-none text-xs font-mono focus-visible:ring-0"
129
+ {...field}
130
+ ref={(el) => {
131
+ valueRefs.current[i] = el;
132
+ }}
133
+ onKeyDown={(e) => {
134
+ if (e.key === "Enter" && e.currentTarget.value.trim()) {
135
+ handleValueEnter(i);
136
+ }
137
+ }}
138
+ autoComplete="off"
139
+ />
140
+ )}
34
141
  />
35
- </td>
36
- <td>
37
- <div className="flex items-center gap-2">
38
- <Input
39
- placeholder={"Value"}
40
- className="border-0 shadow-none text-xs font-mono"
41
- {...register(`headers.${i}.value`)}
42
- autoComplete="off"
43
- />
44
- <Button
45
- size="icon"
46
- variant="ghost"
47
- className="text-muted-foreground opacity-0 group-hover:opacity-100"
48
- onClick={() => {
49
- remove(i);
50
- }}
51
- type="button"
52
- >
53
- <XIcon size={16} />
54
- </Button>
55
- </div>
56
- </td>
57
- </tr>
142
+ <Button
143
+ size="icon"
144
+ variant="ghost"
145
+ className="text-muted-foreground opacity-0 group-hover:opacity-100 rounded-full w-8 h-7"
146
+ onClick={() => {
147
+ remove(i);
148
+ }}
149
+ type="button"
150
+ >
151
+ <XIcon size={16} />
152
+ </Button>
153
+ </div>
154
+ </div>
58
155
  ))}
59
- </tbody>
60
- </table>
156
+ </ParamsGrid>
157
+ </Card>
61
158
  <div className="text-end">
62
159
  <Button
63
160
  className=""
64
- onClick={() => append({ name: "", value: "" })}
161
+ onClick={addNewHeader}
65
162
  type="button"
66
163
  variant="secondary"
67
164
  >
@@ -0,0 +1,8 @@
1
+ import createVariantComponent from "../../../util/createVariantComponent.js";
2
+
3
+ const ParamsGrid = createVariantComponent(
4
+ "div",
5
+ "hover:bg-accent/40 grid grid-cols-[2fr_3fr] gap-2 items-center px-3",
6
+ );
7
+
8
+ export default ParamsGrid;
@@ -1,31 +1,10 @@
1
- import { EraserIcon } from "lucide-react";
2
1
  import { Control, Controller, useFieldArray } from "react-hook-form";
3
2
  import { Card } from "zudoku/ui/Card.js";
4
- import { Button } from "../../../ui/Button.js";
5
3
  import { Input } from "../../../ui/Input.js";
6
- import { cn } from "../../../util/cn.js";
7
- import { ColorizedParam, useParamColor } from "../ColorizedParam.js";
4
+ import { ColorizedParam } from "../ColorizedParam.js";
5
+ import ParamsGrid from "./ParamsGrid.js";
8
6
  import type { PlaygroundForm } from "./Playground.js";
9
7
 
10
- const PathParamLabel = ({ name }: { name: string }) => {
11
- const color = useParamColor(name);
12
-
13
- return (
14
- <div className="flex items-center">
15
- <div
16
- className="w-2 h-2 rounded-full"
17
- style={{ backgroundColor: `hsl(${color})` }}
18
- />
19
-
20
- <ColorizedParam
21
- slug={name}
22
- name={name}
23
- className="font-mono text-xs m-2 px-1"
24
- />
25
- </div>
26
- );
27
- };
28
-
29
8
  export const PathParams = ({
30
9
  control,
31
10
  }: {
@@ -38,59 +17,40 @@ export const PathParams = ({
38
17
 
39
18
  return (
40
19
  <Card className="rounded-lg">
41
- <table className="w-full">
42
- <tbody>
43
- {fields.map((part, i) => (
44
- <tr key={part.id} className="hover:bg-accent/40">
45
- <td className="w-5/12">
46
- <Controller
47
- control={control}
48
- name={`pathParams.${i}.value`}
49
- render={() => <PathParamLabel name={part.name} />}
50
- />
51
- </td>
52
- <td className="w-7/12">
53
- <div className="flex justify-between items-center">
54
- <Controller
55
- control={control}
56
- name={`pathParams.${i}.value`}
57
- render={({ field }) => (
58
- <Input
59
- {...field}
60
- required
61
- placeholder="Enter value"
62
- className="w-full border-0 shadow-none text-xs font-mono hover:bg-accent"
63
- />
64
- )}
65
- />
66
- <Controller
67
- control={control}
68
- name={`pathParams.${i}.value`}
69
- render={({ field }) => (
70
- <Button
71
- size="icon"
72
- type="button"
73
- variant="ghost"
74
- aria-label="Clear value"
75
- className={cn(
76
- "ms-2 mr-1",
77
- field.value.length === 0
78
- ? "opacity-0 pointer-events-none"
79
- : "opacity-100",
80
- )}
81
- title="Clear value"
82
- onClick={() => field.onChange("")}
83
- >
84
- <EraserIcon size={16} />
85
- </Button>
86
- )}
20
+ <ParamsGrid>
21
+ {fields.map((part, i) => (
22
+ <>
23
+ <Controller
24
+ control={control}
25
+ name={`pathParams.${i}.value`}
26
+ render={() => (
27
+ <div>
28
+ <ColorizedParam
29
+ slug={part.name}
30
+ name={part.name}
31
+ className="font-mono text-xs px-2"
87
32
  />
88
33
  </div>
89
- </td>
90
- </tr>
91
- ))}
92
- </tbody>
93
- </table>
34
+ )}
35
+ />
36
+
37
+ <div className="flex justify-between items-center">
38
+ <Controller
39
+ control={control}
40
+ name={`pathParams.${i}.value`}
41
+ render={({ field }) => (
42
+ <Input
43
+ {...field}
44
+ required
45
+ placeholder="Enter value"
46
+ className="w-full border-0 shadow-none text-xs font-mono hover:bg-accent"
47
+ />
48
+ )}
49
+ />
50
+ </div>
51
+ </>
52
+ ))}
53
+ </ParamsGrid>
94
54
  </Card>
95
55
  );
96
56
  };