@scalar/api-reference 1.49.3 → 1.49.5

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 (655) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/dist/_virtual/_plugin-vue_export-helper.js +8 -0
  3. package/dist/blocks/index.js +4 -2
  4. package/dist/blocks/scalar-client-selector-block/components/ClientDropdown.vue.d.ts.map +1 -1
  5. package/dist/blocks/scalar-client-selector-block/components/ClientDropdown.vue.js +9 -0
  6. package/dist/blocks/scalar-client-selector-block/components/ClientDropdown.vue.js.map +1 -0
  7. package/dist/blocks/scalar-client-selector-block/components/ClientDropdown.vue.script.js +106 -0
  8. package/dist/blocks/scalar-client-selector-block/components/ClientDropdown.vue.script.js.map +1 -0
  9. package/dist/blocks/scalar-client-selector-block/components/ClientSelector.vue.js +9 -0
  10. package/dist/blocks/scalar-client-selector-block/components/ClientSelector.vue.js.map +1 -0
  11. package/dist/blocks/scalar-client-selector-block/components/ClientSelector.vue.script.js +121 -0
  12. package/dist/blocks/scalar-client-selector-block/components/ClientSelector.vue.script.js.map +1 -0
  13. package/dist/blocks/scalar-client-selector-block/helpers/featured-clients.js +27 -0
  14. package/dist/blocks/scalar-client-selector-block/helpers/featured-clients.js.map +1 -0
  15. package/dist/blocks/scalar-client-selector-block/index.d.ts +1 -1
  16. package/dist/blocks/scalar-info-block/components/DownloadLink.vue.js +9 -0
  17. package/dist/blocks/scalar-info-block/components/DownloadLink.vue.js.map +1 -0
  18. package/dist/blocks/scalar-info-block/components/DownloadLink.vue.script.js +55 -0
  19. package/dist/blocks/scalar-info-block/components/DownloadLink.vue.script.js.map +1 -0
  20. package/dist/blocks/scalar-info-block/components/InfoBlock.vue.js +7 -0
  21. package/dist/blocks/scalar-info-block/components/InfoBlock.vue.js.map +1 -0
  22. package/dist/blocks/scalar-info-block/components/InfoBlock.vue.script.js +69 -0
  23. package/dist/blocks/scalar-info-block/components/InfoBlock.vue.script.js.map +1 -0
  24. package/dist/blocks/scalar-info-block/components/InfoDescription.vue.js +9 -0
  25. package/dist/blocks/scalar-info-block/components/InfoDescription.vue.js.map +1 -0
  26. package/dist/blocks/scalar-info-block/components/InfoDescription.vue.script.js +68 -0
  27. package/dist/blocks/scalar-info-block/components/InfoDescription.vue.script.js.map +1 -0
  28. package/dist/blocks/scalar-info-block/components/InfoLinks.vue.js +7 -0
  29. package/dist/blocks/scalar-info-block/components/InfoLinks.vue.js.map +1 -0
  30. package/dist/blocks/scalar-info-block/components/InfoLinks.vue.script.js +40 -0
  31. package/dist/blocks/scalar-info-block/components/InfoLinks.vue.script.js.map +1 -0
  32. package/dist/blocks/scalar-info-block/components/InfoMarkdownSection.vue.js +7 -0
  33. package/dist/blocks/scalar-info-block/components/InfoMarkdownSection.vue.js.map +1 -0
  34. package/dist/blocks/scalar-info-block/components/InfoMarkdownSection.vue.script.js +35 -0
  35. package/dist/blocks/scalar-info-block/components/InfoMarkdownSection.vue.script.js.map +1 -0
  36. package/dist/blocks/scalar-info-block/components/InfoVersion.vue.js +7 -0
  37. package/dist/blocks/scalar-info-block/components/InfoVersion.vue.js.map +1 -0
  38. package/dist/blocks/scalar-info-block/components/InfoVersion.vue.script.js +25 -0
  39. package/dist/blocks/scalar-info-block/components/InfoVersion.vue.script.js.map +1 -0
  40. package/dist/blocks/scalar-info-block/components/IntroductionCard.vue.js +9 -0
  41. package/dist/blocks/scalar-info-block/components/IntroductionCard.vue.js.map +1 -0
  42. package/dist/blocks/scalar-info-block/components/IntroductionCard.vue.script.js +15 -0
  43. package/dist/blocks/scalar-info-block/components/IntroductionCard.vue.script.js.map +1 -0
  44. package/dist/blocks/scalar-info-block/components/IntroductionCardItem.vue.js +14 -0
  45. package/dist/blocks/scalar-info-block/components/IntroductionCardItem.vue.js.map +1 -0
  46. package/dist/blocks/scalar-info-block/components/IntroductionLayout.vue.js +9 -0
  47. package/dist/blocks/scalar-info-block/components/IntroductionLayout.vue.js.map +1 -0
  48. package/dist/blocks/scalar-info-block/components/IntroductionLayout.vue.script.js +92 -0
  49. package/dist/blocks/scalar-info-block/components/IntroductionLayout.vue.script.js.map +1 -0
  50. package/dist/blocks/scalar-info-block/components/OpenApiVersion.vue.js +7 -0
  51. package/dist/blocks/scalar-info-block/components/OpenApiVersion.vue.js.map +1 -0
  52. package/dist/blocks/scalar-info-block/components/OpenApiVersion.vue.script.js +19 -0
  53. package/dist/blocks/scalar-info-block/components/OpenApiVersion.vue.script.js.map +1 -0
  54. package/dist/blocks/scalar-info-block/index.d.ts +2 -2
  55. package/dist/blocks/scalar-server-selector-block/components/Selector.vue.js +7 -0
  56. package/dist/blocks/scalar-server-selector-block/components/Selector.vue.js.map +1 -0
  57. package/dist/blocks/scalar-server-selector-block/components/Selector.vue.script.js +71 -0
  58. package/dist/blocks/scalar-server-selector-block/components/Selector.vue.script.js.map +1 -0
  59. package/dist/blocks/scalar-server-selector-block/components/ServerSelector.vue.js +7 -0
  60. package/dist/blocks/scalar-server-selector-block/components/ServerSelector.vue.js.map +1 -0
  61. package/dist/blocks/scalar-server-selector-block/components/ServerSelector.vue.script.js +69 -0
  62. package/dist/blocks/scalar-server-selector-block/components/ServerSelector.vue.script.js.map +1 -0
  63. package/dist/blocks/scalar-server-selector-block/index.d.ts +1 -1
  64. package/dist/browser/standalone.js +2310 -45326
  65. package/dist/browser/webpack-stats.json +1 -1
  66. package/dist/components/AgentScalar/AgentScalarButton.vue.js +7 -0
  67. package/dist/components/AgentScalar/AgentScalarButton.vue.js.map +1 -0
  68. package/dist/components/AgentScalar/AgentScalarButton.vue.script.js +21 -0
  69. package/dist/components/AgentScalar/AgentScalarButton.vue.script.js.map +1 -0
  70. package/dist/components/AgentScalar/AgentScalarChatInterface.vue.d.ts +2 -1
  71. package/dist/components/AgentScalar/AgentScalarChatInterface.vue.d.ts.map +1 -1
  72. package/dist/components/AgentScalar/AgentScalarChatInterface.vue.js +7 -0
  73. package/dist/components/AgentScalar/AgentScalarChatInterface.vue.js.map +1 -0
  74. package/dist/{AgentScalarChatInterface-MUbtSqMw.js → components/AgentScalar/AgentScalarChatInterface.vue.script.js} +10 -9
  75. package/dist/components/AgentScalar/AgentScalarChatInterface.vue.script.js.map +1 -0
  76. package/dist/components/AgentScalar/AgentScalarDrawer.vue.d.ts +2 -4
  77. package/dist/components/AgentScalar/AgentScalarDrawer.vue.d.ts.map +1 -1
  78. package/dist/components/AgentScalar/AgentScalarDrawer.vue.js +9 -0
  79. package/dist/components/AgentScalar/AgentScalarDrawer.vue.js.map +1 -0
  80. package/dist/components/AgentScalar/AgentScalarDrawer.vue.script.js +67 -0
  81. package/dist/components/AgentScalar/AgentScalarDrawer.vue.script.js.map +1 -0
  82. package/dist/components/AgentScalar/OpenMCPButton.vue.d.ts +2 -0
  83. package/dist/components/AgentScalar/OpenMCPButton.vue.d.ts.map +1 -1
  84. package/dist/components/AgentScalar/OpenMCPButton.vue.js +9 -0
  85. package/dist/components/AgentScalar/OpenMCPButton.vue.js.map +1 -0
  86. package/dist/components/AgentScalar/OpenMCPButton.vue.script.js +184 -0
  87. package/dist/components/AgentScalar/OpenMCPButton.vue.script.js.map +1 -0
  88. package/dist/components/AgentScalar/index.d.ts +3 -3
  89. package/dist/components/Anchor/Anchor.vue.js +7 -0
  90. package/dist/components/Anchor/Anchor.vue.js.map +1 -0
  91. package/dist/components/Anchor/Anchor.vue.script.js +40 -0
  92. package/dist/components/Anchor/Anchor.vue.script.js.map +1 -0
  93. package/dist/components/Anchor/WithBreadcrumb.vue.js +7 -0
  94. package/dist/components/Anchor/WithBreadcrumb.vue.js.map +1 -0
  95. package/dist/components/Anchor/WithBreadcrumb.vue.script.js +32 -0
  96. package/dist/components/Anchor/WithBreadcrumb.vue.script.js.map +1 -0
  97. package/dist/components/Anchor/index.d.ts +2 -2
  98. package/dist/components/ApiReference.vue.d.ts.map +1 -1
  99. package/dist/components/ApiReference.vue.js +12 -0
  100. package/dist/components/ApiReference.vue.js.map +1 -0
  101. package/dist/components/ApiReference.vue.script.js +668 -0
  102. package/dist/components/ApiReference.vue.script.js.map +1 -0
  103. package/dist/components/Badge/Badge.vue.js +9 -0
  104. package/dist/components/Badge/Badge.vue.js.map +1 -0
  105. package/dist/components/Badge/Badge.vue.script.js +22 -0
  106. package/dist/components/Badge/Badge.vue.script.js.map +1 -0
  107. package/dist/components/Badge/index.d.ts +1 -1
  108. package/dist/components/ClassicHeader.vue.js +16 -0
  109. package/dist/components/ClassicHeader.vue.js.map +1 -0
  110. package/dist/components/Content/Auth/Auth.vue.js +7 -0
  111. package/dist/components/Content/Auth/Auth.vue.js.map +1 -0
  112. package/dist/components/Content/Auth/Auth.vue.script.js +70 -0
  113. package/dist/components/Content/Auth/Auth.vue.script.js.map +1 -0
  114. package/dist/components/Content/Auth/helpers/get-default-security.js +64 -0
  115. package/dist/components/Content/Auth/helpers/get-default-security.js.map +1 -0
  116. package/dist/components/Content/Auth/index.d.ts +1 -1
  117. package/dist/components/Content/Content.vue.js +8 -0
  118. package/dist/components/Content/Content.vue.js.map +1 -0
  119. package/dist/components/Content/Content.vue.script.js +192 -0
  120. package/dist/components/Content/Content.vue.script.js.map +1 -0
  121. package/dist/components/Content/Models/Model.vue.js +7 -0
  122. package/dist/components/Content/Models/Model.vue.js.map +1 -0
  123. package/dist/components/Content/Models/Model.vue.script.js +61 -0
  124. package/dist/components/Content/Models/Model.vue.script.js.map +1 -0
  125. package/dist/components/Content/Models/ModelTag.vue.js +7 -0
  126. package/dist/components/Content/Models/ModelTag.vue.js.map +1 -0
  127. package/dist/components/Content/Models/ModelTag.vue.script.js +69 -0
  128. package/dist/components/Content/Models/ModelTag.vue.script.js.map +1 -0
  129. package/dist/components/Content/Models/components/ClassicLayout.vue.js +9 -0
  130. package/dist/components/Content/Models/components/ClassicLayout.vue.js.map +1 -0
  131. package/dist/components/Content/Models/components/ClassicLayout.vue.script.js +81 -0
  132. package/dist/components/Content/Models/components/ClassicLayout.vue.script.js.map +1 -0
  133. package/dist/components/Content/Models/components/ModernLayout.vue.js +7 -0
  134. package/dist/components/Content/Models/components/ModernLayout.vue.js.map +1 -0
  135. package/dist/components/Content/Models/components/ModernLayout.vue.script.js +66 -0
  136. package/dist/components/Content/Models/components/ModernLayout.vue.script.js.map +1 -0
  137. package/dist/components/Content/Models/index.d.ts +2 -2
  138. package/dist/components/Content/Operations/TraversedEntry.vue.js +7 -0
  139. package/dist/components/Content/Operations/TraversedEntry.vue.js.map +1 -0
  140. package/dist/components/Content/Operations/TraversedEntry.vue.script.js +213 -0
  141. package/dist/components/Content/Operations/TraversedEntry.vue.script.js.map +1 -0
  142. package/dist/components/Content/Schema/RenderString.vue.js +7 -0
  143. package/dist/components/Content/Schema/RenderString.vue.js.map +1 -0
  144. package/dist/components/Content/Schema/RenderString.vue.script.js +36 -0
  145. package/dist/components/Content/Schema/RenderString.vue.script.js.map +1 -0
  146. package/dist/components/Content/Schema/Schema.vue.d.ts +4 -0
  147. package/dist/components/Content/Schema/Schema.vue.d.ts.map +1 -1
  148. package/dist/components/Content/Schema/Schema.vue.js +9 -0
  149. package/dist/components/Content/Schema/Schema.vue.js.map +1 -0
  150. package/dist/components/Content/Schema/Schema.vue.script.js +194 -0
  151. package/dist/components/Content/Schema/Schema.vue.script.js.map +1 -0
  152. package/dist/components/Content/Schema/SchemaComposition.vue.d.ts +5 -1
  153. package/dist/components/Content/Schema/SchemaComposition.vue.d.ts.map +1 -1
  154. package/dist/components/Content/Schema/SchemaComposition.vue.js +7 -0
  155. package/dist/components/Content/Schema/SchemaComposition.vue.js.map +1 -0
  156. package/dist/components/Content/Schema/SchemaComposition.vue.script.js +176 -0
  157. package/dist/components/Content/Schema/SchemaComposition.vue.script.js.map +1 -0
  158. package/dist/components/Content/Schema/SchemaEnumPropertyItem.vue.js +9 -0
  159. package/dist/components/Content/Schema/SchemaEnumPropertyItem.vue.js.map +1 -0
  160. package/dist/components/Content/Schema/SchemaEnumPropertyItem.vue.script.js +29 -0
  161. package/dist/components/Content/Schema/SchemaEnumPropertyItem.vue.script.js.map +1 -0
  162. package/dist/components/Content/Schema/SchemaEnums.vue.js +9 -0
  163. package/dist/components/Content/Schema/SchemaEnums.vue.js.map +1 -0
  164. package/dist/components/Content/Schema/SchemaEnums.vue.script.js +108 -0
  165. package/dist/components/Content/Schema/SchemaEnums.vue.script.js.map +1 -0
  166. package/dist/components/Content/Schema/SchemaHeading.vue.js +9 -0
  167. package/dist/components/Content/Schema/SchemaHeading.vue.js.map +1 -0
  168. package/dist/components/Content/Schema/SchemaHeading.vue.script.js +45 -0
  169. package/dist/components/Content/Schema/SchemaHeading.vue.script.js.map +1 -0
  170. package/dist/components/Content/Schema/SchemaObjectExampleCodeBlock.vue.js +7 -0
  171. package/dist/components/Content/Schema/SchemaObjectExampleCodeBlock.vue.js.map +1 -0
  172. package/dist/components/Content/Schema/SchemaObjectExampleCodeBlock.vue.script.js +55 -0
  173. package/dist/components/Content/Schema/SchemaObjectExampleCodeBlock.vue.script.js.map +1 -0
  174. package/dist/components/Content/Schema/SchemaObjectProperties.vue.d.ts +2 -0
  175. package/dist/components/Content/Schema/SchemaObjectProperties.vue.d.ts.map +1 -1
  176. package/dist/components/Content/Schema/SchemaObjectProperties.vue.js +7 -0
  177. package/dist/components/Content/Schema/SchemaObjectProperties.vue.js.map +1 -0
  178. package/dist/components/Content/Schema/SchemaObjectProperties.vue.script.js +181 -0
  179. package/dist/components/Content/Schema/SchemaObjectProperties.vue.script.js.map +1 -0
  180. package/dist/components/Content/Schema/SchemaProperty.vue.d.ts +6 -0
  181. package/dist/components/Content/Schema/SchemaProperty.vue.d.ts.map +1 -1
  182. package/dist/components/Content/Schema/SchemaProperty.vue.js +9 -0
  183. package/dist/components/Content/Schema/SchemaProperty.vue.js.map +1 -0
  184. package/dist/components/Content/Schema/SchemaProperty.vue.script.js +273 -0
  185. package/dist/components/Content/Schema/SchemaProperty.vue.script.js.map +1 -0
  186. package/dist/components/Content/Schema/SchemaPropertyDefault.vue.js +9 -0
  187. package/dist/components/Content/Schema/SchemaPropertyDefault.vue.js.map +1 -0
  188. package/dist/components/Content/Schema/SchemaPropertyDefault.vue.script.js +35 -0
  189. package/dist/components/Content/Schema/SchemaPropertyDefault.vue.script.js.map +1 -0
  190. package/dist/components/Content/Schema/SchemaPropertyDetail.vue.js +9 -0
  191. package/dist/components/Content/Schema/SchemaPropertyDetail.vue.js.map +1 -0
  192. package/dist/components/Content/Schema/SchemaPropertyDetail.vue.script.js +30 -0
  193. package/dist/components/Content/Schema/SchemaPropertyDetail.vue.script.js.map +1 -0
  194. package/dist/components/Content/Schema/SchemaPropertyExamples.vue.js +9 -0
  195. package/dist/components/Content/Schema/SchemaPropertyExamples.vue.js.map +1 -0
  196. package/dist/components/Content/Schema/SchemaPropertyExamples.vue.script.js +67 -0
  197. package/dist/components/Content/Schema/SchemaPropertyExamples.vue.script.js.map +1 -0
  198. package/dist/components/Content/Schema/SchemaPropertyHeading.vue.js +9 -0
  199. package/dist/components/Content/Schema/SchemaPropertyHeading.vue.js.map +1 -0
  200. package/dist/components/Content/Schema/SchemaPropertyHeading.vue.script.js +251 -0
  201. package/dist/components/Content/Schema/SchemaPropertyHeading.vue.script.js.map +1 -0
  202. package/dist/components/Content/Schema/helpers/format-example.js +26 -0
  203. package/dist/components/Content/Schema/helpers/format-example.js.map +1 -0
  204. package/dist/components/Content/Schema/helpers/format-value.js +22 -0
  205. package/dist/components/Content/Schema/helpers/format-value.js.map +1 -0
  206. package/dist/components/Content/Schema/helpers/get-compositions-to-render.d.ts +1 -1
  207. package/dist/components/Content/Schema/helpers/get-compositions-to-render.js +32 -0
  208. package/dist/components/Content/Schema/helpers/get-compositions-to-render.js.map +1 -0
  209. package/dist/components/Content/Schema/helpers/get-enum-values.js +22 -0
  210. package/dist/components/Content/Schema/helpers/get-enum-values.js.map +1 -0
  211. package/dist/components/Content/Schema/helpers/get-property-description.js +36 -0
  212. package/dist/components/Content/Schema/helpers/get-property-description.js.map +1 -0
  213. package/dist/components/Content/Schema/helpers/get-ref-name.js +19 -0
  214. package/dist/components/Content/Schema/helpers/get-ref-name.js.map +1 -0
  215. package/dist/components/Content/Schema/helpers/get-schema-type.js +49 -0
  216. package/dist/components/Content/Schema/helpers/get-schema-type.js.map +1 -0
  217. package/dist/components/Content/Schema/helpers/has-complex-array-items.js +53 -0
  218. package/dist/components/Content/Schema/helpers/has-complex-array-items.js.map +1 -0
  219. package/dist/components/Content/Schema/helpers/is-empty-schema-object.js +18 -0
  220. package/dist/components/Content/Schema/helpers/is-empty-schema-object.js.map +1 -0
  221. package/dist/components/Content/Schema/helpers/is-type-object.js +18 -0
  222. package/dist/components/Content/Schema/helpers/is-type-object.js.map +1 -0
  223. package/dist/components/Content/Schema/helpers/merge-all-of-schemas.js +175 -0
  224. package/dist/components/Content/Schema/helpers/merge-all-of-schemas.js.map +1 -0
  225. package/dist/components/Content/Schema/helpers/optimize-value-for-display.js +68 -0
  226. package/dist/components/Content/Schema/helpers/optimize-value-for-display.js.map +1 -0
  227. package/dist/components/Content/Schema/helpers/schema-composition.js +11 -0
  228. package/dist/components/Content/Schema/helpers/schema-composition.js.map +1 -0
  229. package/dist/components/Content/Schema/helpers/schema-name.js +23 -0
  230. package/dist/components/Content/Schema/helpers/schema-name.js.map +1 -0
  231. package/dist/components/Content/Schema/helpers/should-display-description.js +17 -0
  232. package/dist/components/Content/Schema/helpers/should-display-description.js.map +1 -0
  233. package/dist/components/Content/Schema/helpers/should-display-heading.js +18 -0
  234. package/dist/components/Content/Schema/helpers/should-display-heading.js.map +1 -0
  235. package/dist/components/Content/Schema/helpers/should-render-array-item-composition.js +20 -0
  236. package/dist/components/Content/Schema/helpers/should-render-array-item-composition.js.map +1 -0
  237. package/dist/components/Content/Schema/helpers/sort-property-names.js +45 -0
  238. package/dist/components/Content/Schema/helpers/sort-property-names.js.map +1 -0
  239. package/dist/components/Content/Schema/index.d.ts +4 -4
  240. package/dist/components/Content/Tags/Tag.vue.js +7 -0
  241. package/dist/components/Content/Tags/Tag.vue.js.map +1 -0
  242. package/dist/components/Content/Tags/Tag.vue.script.js +56 -0
  243. package/dist/components/Content/Tags/Tag.vue.script.js.map +1 -0
  244. package/dist/components/Content/Tags/components/ClassicLayout.vue.js +9 -0
  245. package/dist/components/Content/Tags/components/ClassicLayout.vue.js.map +1 -0
  246. package/dist/components/Content/Tags/components/ClassicLayout.vue.script.js +49 -0
  247. package/dist/components/Content/Tags/components/ClassicLayout.vue.script.js.map +1 -0
  248. package/dist/components/Content/Tags/components/ModernLayout.vue.js +9 -0
  249. package/dist/components/Content/Tags/components/ModernLayout.vue.js.map +1 -0
  250. package/dist/components/Content/Tags/components/ModernLayout.vue.script.js +63 -0
  251. package/dist/components/Content/Tags/components/ModernLayout.vue.script.js.map +1 -0
  252. package/dist/components/Content/Tags/components/TagSection.vue.js +7 -0
  253. package/dist/components/Content/Tags/components/TagSection.vue.js.map +1 -0
  254. package/dist/components/Content/Tags/components/TagSection.vue.script.js +78 -0
  255. package/dist/components/Content/Tags/components/TagSection.vue.script.js.map +1 -0
  256. package/dist/components/Content/Tags/index.d.ts +1 -1
  257. package/dist/components/Content/index.d.ts +2 -2
  258. package/dist/components/GettingStarted.vue.js +9 -0
  259. package/dist/components/GettingStarted.vue.js.map +1 -0
  260. package/dist/components/GettingStarted.vue.script.js +71 -0
  261. package/dist/components/GettingStarted.vue.script.js.map +1 -0
  262. package/dist/components/HttpMethod/HttpMethod.vue.js +7 -0
  263. package/dist/components/HttpMethod/HttpMethod.vue.js.map +1 -0
  264. package/dist/components/HttpMethod/HttpMethod.vue.script.js +33 -0
  265. package/dist/components/HttpMethod/HttpMethod.vue.script.js.map +1 -0
  266. package/dist/components/HttpMethod/index.d.ts +1 -1
  267. package/dist/components/IntersectionObserver.vue.js +7 -0
  268. package/dist/components/IntersectionObserver.vue.js.map +1 -0
  269. package/dist/components/IntersectionObserver.vue.script.js +45 -0
  270. package/dist/components/IntersectionObserver.vue.script.js.map +1 -0
  271. package/dist/components/Lazy/Lazy.vue.js +7 -0
  272. package/dist/components/Lazy/Lazy.vue.js.map +1 -0
  273. package/dist/components/Lazy/Lazy.vue.script.js +101 -0
  274. package/dist/components/Lazy/Lazy.vue.script.js.map +1 -0
  275. package/dist/components/LinkList/LinkList.vue.js +9 -0
  276. package/dist/components/LinkList/LinkList.vue.js.map +1 -0
  277. package/dist/components/LinkList/LinkList.vue.script.js +53 -0
  278. package/dist/components/LinkList/LinkList.vue.script.js.map +1 -0
  279. package/dist/components/LinkList/index.d.ts +1 -1
  280. package/dist/components/LoadingSkeleton.vue.js +9 -0
  281. package/dist/components/LoadingSkeleton.vue.js.map +1 -0
  282. package/dist/components/LoadingSkeleton.vue.script.js +20 -0
  283. package/dist/components/LoadingSkeleton.vue.script.js.map +1 -0
  284. package/dist/components/MobileHeader.vue.d.ts.map +1 -1
  285. package/dist/components/MobileHeader.vue.js +7 -0
  286. package/dist/components/MobileHeader.vue.js.map +1 -0
  287. package/dist/components/MobileHeader.vue.script.js +43 -0
  288. package/dist/components/MobileHeader.vue.script.js.map +1 -0
  289. package/dist/components/OperationPath.vue.js +9 -0
  290. package/dist/components/OperationPath.vue.js.map +1 -0
  291. package/dist/components/OperationPath.vue.script.js +24 -0
  292. package/dist/components/OperationPath.vue.script.js.map +1 -0
  293. package/dist/components/OperationsList/OperationsList.vue.js +9 -0
  294. package/dist/components/OperationsList/OperationsList.vue.js.map +1 -0
  295. package/dist/components/OperationsList/OperationsList.vue.script.js +49 -0
  296. package/dist/components/OperationsList/OperationsList.vue.script.js.map +1 -0
  297. package/dist/components/OperationsList/OperationsListItem.vue.js +9 -0
  298. package/dist/components/OperationsList/OperationsListItem.vue.js.map +1 -0
  299. package/dist/components/OperationsList/OperationsListItem.vue.script.js +51 -0
  300. package/dist/components/OperationsList/OperationsListItem.vue.script.js.map +1 -0
  301. package/dist/components/OperationsList/index.d.ts +1 -1
  302. package/dist/components/RenderPlugins/RenderPlugins.vue.js +7 -0
  303. package/dist/components/RenderPlugins/RenderPlugins.vue.js.map +1 -0
  304. package/dist/components/RenderPlugins/RenderPlugins.vue.script.js +44 -0
  305. package/dist/components/RenderPlugins/RenderPlugins.vue.script.js.map +1 -0
  306. package/dist/components/RenderPlugins/index.d.ts +1 -1
  307. package/dist/components/ScreenReader.vue.js +9 -0
  308. package/dist/components/ScreenReader.vue.js.map +1 -0
  309. package/dist/components/ScreenReader.vue.script.js +22 -0
  310. package/dist/components/ScreenReader.vue.script.js.map +1 -0
  311. package/dist/components/Section/CompactSection.vue.js +9 -0
  312. package/dist/components/Section/CompactSection.vue.js.map +1 -0
  313. package/dist/components/Section/CompactSection.vue.script.js +56 -0
  314. package/dist/components/Section/CompactSection.vue.script.js.map +1 -0
  315. package/dist/components/Section/Section.vue.js +9 -0
  316. package/dist/components/Section/Section.vue.js.map +1 -0
  317. package/dist/components/Section/Section.vue.script.js +23 -0
  318. package/dist/components/Section/Section.vue.script.js.map +1 -0
  319. package/dist/components/Section/SectionAccordion.vue.js +9 -0
  320. package/dist/components/Section/SectionAccordion.vue.js.map +1 -0
  321. package/dist/components/Section/SectionAccordion.vue.script.js +60 -0
  322. package/dist/components/Section/SectionAccordion.vue.script.js.map +1 -0
  323. package/dist/components/Section/SectionColumn.vue.js +14 -0
  324. package/dist/components/Section/SectionColumn.vue.js.map +1 -0
  325. package/dist/components/Section/SectionColumns.vue.js +14 -0
  326. package/dist/components/Section/SectionColumns.vue.js.map +1 -0
  327. package/dist/components/Section/SectionContainer.vue.js +9 -0
  328. package/dist/components/Section/SectionContainer.vue.js.map +1 -0
  329. package/dist/components/Section/SectionContainer.vue.script.js +19 -0
  330. package/dist/components/Section/SectionContainer.vue.script.js.map +1 -0
  331. package/dist/components/Section/SectionContainerAccordion.vue.js +9 -0
  332. package/dist/components/Section/SectionContainerAccordion.vue.js.map +1 -0
  333. package/dist/components/Section/SectionContainerAccordion.vue.script.js +40 -0
  334. package/dist/components/Section/SectionContainerAccordion.vue.script.js.map +1 -0
  335. package/dist/components/Section/SectionContent.vue.js +9 -0
  336. package/dist/components/Section/SectionContent.vue.js.map +1 -0
  337. package/dist/components/Section/SectionContent.vue.script.js +23 -0
  338. package/dist/components/Section/SectionContent.vue.script.js.map +1 -0
  339. package/dist/components/Section/SectionHeader.vue.js +9 -0
  340. package/dist/components/Section/SectionHeader.vue.js.map +1 -0
  341. package/dist/components/Section/SectionHeader.vue.script.js +23 -0
  342. package/dist/components/Section/SectionHeader.vue.script.js.map +1 -0
  343. package/dist/components/Section/SectionHeaderTag.vue.js +9 -0
  344. package/dist/components/Section/SectionHeaderTag.vue.js.map +1 -0
  345. package/dist/components/Section/SectionHeaderTag.vue.script.js +18 -0
  346. package/dist/components/Section/SectionHeaderTag.vue.script.js.map +1 -0
  347. package/dist/components/Section/index.d.ts +10 -10
  348. package/dist/components/SectionFlare/SectionFlare.vue.js +14 -0
  349. package/dist/components/SectionFlare/SectionFlare.vue.js.map +1 -0
  350. package/dist/components/SectionFlare/index.d.ts +1 -1
  351. package/dist/components/ShowMoreButton.vue.js +9 -0
  352. package/dist/components/ShowMoreButton.vue.js.map +1 -0
  353. package/dist/components/ShowMoreButton.vue.script.js +22 -0
  354. package/dist/components/ShowMoreButton.vue.script.js.map +1 -0
  355. package/dist/components/index.d.ts +5 -5
  356. package/dist/components/index.js +20 -102
  357. package/dist/features/Operation/Operation.vue.js +7 -0
  358. package/dist/features/Operation/Operation.vue.js.map +1 -0
  359. package/dist/features/Operation/Operation.vue.script.js +115 -0
  360. package/dist/features/Operation/Operation.vue.script.js.map +1 -0
  361. package/dist/features/Operation/components/ContentTypeSelect.vue.js +7 -0
  362. package/dist/features/Operation/components/ContentTypeSelect.vue.js.map +1 -0
  363. package/dist/features/Operation/components/ContentTypeSelect.vue.script.js +75 -0
  364. package/dist/features/Operation/components/ContentTypeSelect.vue.script.js.map +1 -0
  365. package/dist/features/Operation/components/Header.vue.js +7 -0
  366. package/dist/features/Operation/components/Header.vue.js.map +1 -0
  367. package/dist/features/Operation/components/Header.vue.script.js +42 -0
  368. package/dist/features/Operation/components/Header.vue.script.js.map +1 -0
  369. package/dist/features/Operation/components/Headers.vue.js +9 -0
  370. package/dist/features/Operation/components/Headers.vue.js.map +1 -0
  371. package/dist/features/Operation/components/Headers.vue.script.js +58 -0
  372. package/dist/features/Operation/components/Headers.vue.script.js.map +1 -0
  373. package/dist/features/Operation/components/OperationParameters.vue.d.ts +1 -1
  374. package/dist/features/Operation/components/OperationParameters.vue.js +7 -0
  375. package/dist/features/Operation/components/OperationParameters.vue.js.map +1 -0
  376. package/dist/features/Operation/components/OperationParameters.vue.script.js +108 -0
  377. package/dist/features/Operation/components/OperationParameters.vue.script.js.map +1 -0
  378. package/dist/features/Operation/components/OperationResponses.vue.d.ts +1 -1
  379. package/dist/features/Operation/components/OperationResponses.vue.js +7 -0
  380. package/dist/features/Operation/components/OperationResponses.vue.js.map +1 -0
  381. package/dist/features/Operation/components/OperationResponses.vue.script.js +48 -0
  382. package/dist/features/Operation/components/OperationResponses.vue.script.js.map +1 -0
  383. package/dist/features/Operation/components/ParameterList.vue.d.ts +1 -1
  384. package/dist/features/Operation/components/ParameterList.vue.js +7 -0
  385. package/dist/features/Operation/components/ParameterList.vue.js.map +1 -0
  386. package/dist/features/Operation/components/ParameterList.vue.script.js +53 -0
  387. package/dist/features/Operation/components/ParameterList.vue.script.js.map +1 -0
  388. package/dist/features/Operation/components/ParameterListItem.vue.d.ts +1 -1
  389. package/dist/features/Operation/components/ParameterListItem.vue.js +9 -0
  390. package/dist/features/Operation/components/ParameterListItem.vue.js.map +1 -0
  391. package/dist/features/Operation/components/ParameterListItem.vue.script.js +161 -0
  392. package/dist/features/Operation/components/ParameterListItem.vue.script.js.map +1 -0
  393. package/dist/features/Operation/components/RequestBody.vue.d.ts.map +1 -1
  394. package/dist/features/Operation/components/RequestBody.vue.js +9 -0
  395. package/dist/features/Operation/components/RequestBody.vue.js.map +1 -0
  396. package/dist/features/Operation/components/RequestBody.vue.script.js +160 -0
  397. package/dist/features/Operation/components/RequestBody.vue.script.js.map +1 -0
  398. package/dist/features/Operation/components/callbacks/Callback.vue.d.ts +1 -1
  399. package/dist/features/Operation/components/callbacks/Callback.vue.js +9 -0
  400. package/dist/features/Operation/components/callbacks/Callback.vue.js.map +1 -0
  401. package/dist/features/Operation/components/callbacks/Callback.vue.script.js +62 -0
  402. package/dist/features/Operation/components/callbacks/Callback.vue.script.js.map +1 -0
  403. package/dist/features/Operation/components/callbacks/Callbacks.vue.d.ts +1 -1
  404. package/dist/features/Operation/components/callbacks/Callbacks.vue.js +7 -0
  405. package/dist/features/Operation/components/callbacks/Callbacks.vue.js.map +1 -0
  406. package/dist/features/Operation/components/callbacks/Callbacks.vue.script.js +67 -0
  407. package/dist/features/Operation/components/callbacks/Callbacks.vue.script.js.map +1 -0
  408. package/dist/features/Operation/helpers/filter-selected-security.js +30 -0
  409. package/dist/features/Operation/helpers/filter-selected-security.js.map +1 -0
  410. package/dist/features/Operation/helpers/get-first-server.js +27 -0
  411. package/dist/features/Operation/helpers/get-first-server.js.map +1 -0
  412. package/dist/features/Operation/index.d.ts +1 -1
  413. package/dist/features/Operation/layouts/ClassicLayout.vue.d.ts +1 -1
  414. package/dist/features/Operation/layouts/ClassicLayout.vue.d.ts.map +1 -1
  415. package/dist/features/Operation/layouts/ClassicLayout.vue.js +9 -0
  416. package/dist/features/Operation/layouts/ClassicLayout.vue.js.map +1 -0
  417. package/dist/features/Operation/layouts/ClassicLayout.vue.script.js +254 -0
  418. package/dist/features/Operation/layouts/ClassicLayout.vue.script.js.map +1 -0
  419. package/dist/features/Operation/layouts/ModernLayout.vue.d.ts +1 -1
  420. package/dist/features/Operation/layouts/ModernLayout.vue.d.ts.map +1 -1
  421. package/dist/features/Operation/layouts/ModernLayout.vue.js +9 -0
  422. package/dist/features/Operation/layouts/ModernLayout.vue.js.map +1 -0
  423. package/dist/features/Operation/layouts/ModernLayout.vue.script.js +254 -0
  424. package/dist/features/Operation/layouts/ModernLayout.vue.script.js.map +1 -0
  425. package/dist/features/Operation/request-body-composition-index.d.ts +8 -0
  426. package/dist/features/Operation/request-body-composition-index.d.ts.map +1 -0
  427. package/dist/features/Operation/request-body-composition-index.js +10 -0
  428. package/dist/features/Operation/request-body-composition-index.js.map +1 -0
  429. package/dist/features/Search/components/SearchButton.vue.js +7 -0
  430. package/dist/features/Search/components/SearchButton.vue.js.map +1 -0
  431. package/dist/features/Search/components/SearchButton.vue.script.js +77 -0
  432. package/dist/features/Search/components/SearchButton.vue.script.js.map +1 -0
  433. package/dist/features/Search/components/SearchModal.vue.js +9 -0
  434. package/dist/features/Search/components/SearchModal.vue.js.map +1 -0
  435. package/dist/features/Search/components/SearchModal.vue.script.js +115 -0
  436. package/dist/features/Search/components/SearchModal.vue.script.js.map +1 -0
  437. package/dist/features/Search/components/SearchResult.vue.js +7 -0
  438. package/dist/features/Search/components/SearchResult.vue.js.map +1 -0
  439. package/dist/features/Search/components/SearchResult.vue.script.js +69 -0
  440. package/dist/features/Search/components/SearchResult.vue.script.js.map +1 -0
  441. package/dist/features/Search/helpers/create-fuse-instance.js +52 -0
  442. package/dist/features/Search/helpers/create-fuse-instance.js.map +1 -0
  443. package/dist/features/Search/helpers/create-search-index.js +127 -0
  444. package/dist/features/Search/helpers/create-search-index.js.map +1 -0
  445. package/dist/features/Search/hooks/useSearchIndex.js +31 -0
  446. package/dist/features/Search/hooks/useSearchIndex.js.map +1 -0
  447. package/dist/features/Search/index.d.ts +2 -2
  448. package/dist/features/Search/types.d.ts +1 -1
  449. package/dist/features/ask-agent-button/AskAgentButton.vue.js +9 -0
  450. package/dist/features/ask-agent-button/AskAgentButton.vue.js.map +1 -0
  451. package/dist/features/ask-agent-button/AskAgentButton.vue.script.js +49 -0
  452. package/dist/features/ask-agent-button/AskAgentButton.vue.script.js.map +1 -0
  453. package/dist/features/developer-tools/DeveloperTools.vue.d.ts +2 -1
  454. package/dist/features/developer-tools/DeveloperTools.vue.d.ts.map +1 -1
  455. package/dist/features/developer-tools/DeveloperTools.vue.js +7 -0
  456. package/dist/features/developer-tools/DeveloperTools.vue.js.map +1 -0
  457. package/dist/features/developer-tools/DeveloperTools.vue.script.js +56 -0
  458. package/dist/features/developer-tools/DeveloperTools.vue.script.js.map +1 -0
  459. package/dist/features/developer-tools/components/ApiReferenceToolbarBlurb.vue.js +13 -0
  460. package/dist/features/developer-tools/components/ApiReferenceToolbarBlurb.vue.js.map +1 -0
  461. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigLayout.vue.js +7 -0
  462. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigLayout.vue.js.map +1 -0
  463. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigLayout.vue.script.js +38 -0
  464. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigLayout.vue.script.js.map +1 -0
  465. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigLayoutOptions.vue.js +7 -0
  466. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigLayoutOptions.vue.js.map +1 -0
  467. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigLayoutOptions.vue.script.js +112 -0
  468. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigLayoutOptions.vue.script.js.map +1 -0
  469. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigTheme.vue.js +7 -0
  470. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigTheme.vue.js.map +1 -0
  471. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigTheme.vue.script.js +60 -0
  472. package/dist/features/developer-tools/components/ApiReferenceToolbarConfigTheme.vue.script.js.map +1 -0
  473. package/dist/features/developer-tools/components/ApiReferenceToolbarPopover.vue.js +7 -0
  474. package/dist/features/developer-tools/components/ApiReferenceToolbarPopover.vue.js.map +1 -0
  475. package/dist/features/developer-tools/components/ApiReferenceToolbarPopover.vue.script.js +35 -0
  476. package/dist/features/developer-tools/components/ApiReferenceToolbarPopover.vue.script.js.map +1 -0
  477. package/dist/features/developer-tools/components/ApiReferenceToolbarRegisterButton.vue.d.ts +2 -0
  478. package/dist/features/developer-tools/components/ApiReferenceToolbarRegisterButton.vue.d.ts.map +1 -1
  479. package/dist/features/developer-tools/components/ApiReferenceToolbarRegisterButton.vue.js +7 -0
  480. package/dist/features/developer-tools/components/ApiReferenceToolbarRegisterButton.vue.js.map +1 -0
  481. package/dist/features/developer-tools/components/ApiReferenceToolbarRegisterButton.vue.script.js +68 -0
  482. package/dist/features/developer-tools/components/ApiReferenceToolbarRegisterButton.vue.script.js.map +1 -0
  483. package/dist/features/developer-tools/components/ApiReferenceToolbarShareRegister.vue.d.ts +2 -0
  484. package/dist/features/developer-tools/components/ApiReferenceToolbarShareRegister.vue.d.ts.map +1 -1
  485. package/dist/features/developer-tools/components/ApiReferenceToolbarShareRegister.vue.js +7 -0
  486. package/dist/features/developer-tools/components/ApiReferenceToolbarShareRegister.vue.js.map +1 -0
  487. package/dist/features/developer-tools/components/ApiReferenceToolbarShareRegister.vue.script.js +86 -0
  488. package/dist/features/developer-tools/components/ApiReferenceToolbarShareRegister.vue.script.js.map +1 -0
  489. package/dist/features/developer-tools/components/ApiReferenceToolbarShareTemporary.vue.d.ts +2 -0
  490. package/dist/features/developer-tools/components/ApiReferenceToolbarShareTemporary.vue.d.ts.map +1 -1
  491. package/dist/features/developer-tools/components/ApiReferenceToolbarShareTemporary.vue.js +7 -0
  492. package/dist/features/developer-tools/components/ApiReferenceToolbarShareTemporary.vue.js.map +1 -0
  493. package/dist/features/developer-tools/components/ApiReferenceToolbarShareTemporary.vue.script.js +68 -0
  494. package/dist/features/developer-tools/components/ApiReferenceToolbarShareTemporary.vue.script.js.map +1 -0
  495. package/dist/features/developer-tools/components/ApiReferenceToolbarTitle.vue.js +7 -0
  496. package/dist/features/developer-tools/components/ApiReferenceToolbarTitle.vue.js.map +1 -0
  497. package/dist/features/developer-tools/components/ApiReferenceToolbarTitle.vue.script.js +44 -0
  498. package/dist/features/developer-tools/components/ApiReferenceToolbarTitle.vue.script.js.map +1 -0
  499. package/dist/features/developer-tools/components/DeployApiReference.vue.d.ts +2 -0
  500. package/dist/features/developer-tools/components/DeployApiReference.vue.d.ts.map +1 -1
  501. package/dist/features/developer-tools/components/DeployApiReference.vue.js +7 -0
  502. package/dist/features/developer-tools/components/DeployApiReference.vue.js.map +1 -0
  503. package/dist/features/developer-tools/components/DeployApiReference.vue.script.js +32 -0
  504. package/dist/features/developer-tools/components/DeployApiReference.vue.script.js.map +1 -0
  505. package/dist/features/developer-tools/components/ModifyConfiguration.vue.js +7 -0
  506. package/dist/features/developer-tools/components/ModifyConfiguration.vue.js.map +1 -0
  507. package/dist/features/developer-tools/components/ModifyConfiguration.vue.script.js +86 -0
  508. package/dist/features/developer-tools/components/ModifyConfiguration.vue.script.js.map +1 -0
  509. package/dist/features/developer-tools/components/ShareApiReference.vue.d.ts +2 -0
  510. package/dist/features/developer-tools/components/ShareApiReference.vue.d.ts.map +1 -1
  511. package/dist/features/developer-tools/components/ShareApiReference.vue.js +7 -0
  512. package/dist/features/developer-tools/components/ShareApiReference.vue.js.map +1 -0
  513. package/dist/features/developer-tools/components/ShareApiReference.vue.script.js +32 -0
  514. package/dist/features/developer-tools/components/ShareApiReference.vue.script.js.map +1 -0
  515. package/dist/features/developer-tools/index.d.ts +1 -1
  516. package/dist/features/example-responses/ExampleResponse.vue.js +9 -0
  517. package/dist/features/example-responses/ExampleResponse.vue.js.map +1 -0
  518. package/dist/features/example-responses/ExampleResponse.vue.script.js +56 -0
  519. package/dist/features/example-responses/ExampleResponse.vue.script.js.map +1 -0
  520. package/dist/features/example-responses/ExampleResponseTab.vue.js +9 -0
  521. package/dist/features/example-responses/ExampleResponseTab.vue.js.map +1 -0
  522. package/dist/features/example-responses/ExampleResponseTab.vue.script.js +21 -0
  523. package/dist/features/example-responses/ExampleResponseTab.vue.script.js.map +1 -0
  524. package/dist/features/example-responses/ExampleResponseTabList.vue.js +9 -0
  525. package/dist/features/example-responses/ExampleResponseTabList.vue.js.map +1 -0
  526. package/dist/features/example-responses/ExampleResponseTabList.vue.script.js +31 -0
  527. package/dist/features/example-responses/ExampleResponseTabList.vue.script.js.map +1 -0
  528. package/dist/features/example-responses/ExampleResponses.vue.js +9 -0
  529. package/dist/features/example-responses/ExampleResponses.vue.js.map +1 -0
  530. package/dist/features/example-responses/ExampleResponses.vue.script.js +157 -0
  531. package/dist/features/example-responses/ExampleResponses.vue.script.js.map +1 -0
  532. package/dist/features/example-responses/ExampleSchema.vue.js +7 -0
  533. package/dist/features/example-responses/ExampleSchema.vue.js.map +1 -0
  534. package/dist/features/example-responses/ExampleSchema.vue.script.js +42 -0
  535. package/dist/features/example-responses/ExampleSchema.vue.script.js.map +1 -0
  536. package/dist/features/example-responses/has-response-content.js +37 -0
  537. package/dist/features/example-responses/has-response-content.js.map +1 -0
  538. package/dist/features/example-responses/index.d.ts +1 -1
  539. package/dist/features/external-docs/ExternalDocs.vue.js +7 -0
  540. package/dist/features/external-docs/ExternalDocs.vue.js.map +1 -0
  541. package/dist/features/external-docs/ExternalDocs.vue.script.js +37 -0
  542. package/dist/features/external-docs/ExternalDocs.vue.script.js.map +1 -0
  543. package/dist/features/external-docs/index.d.ts +1 -1
  544. package/dist/features/index.d.ts +2 -2
  545. package/dist/features/index.js +4 -3
  546. package/dist/features/info-object/Contact.vue.js +7 -0
  547. package/dist/features/info-object/Contact.vue.js.map +1 -0
  548. package/dist/features/info-object/Contact.vue.script.js +37 -0
  549. package/dist/features/info-object/Contact.vue.script.js.map +1 -0
  550. package/dist/features/info-object/License.vue.js +7 -0
  551. package/dist/features/info-object/License.vue.js.map +1 -0
  552. package/dist/features/info-object/License.vue.script.js +32 -0
  553. package/dist/features/info-object/License.vue.script.js.map +1 -0
  554. package/dist/features/info-object/TermsOfService.vue.js +7 -0
  555. package/dist/features/info-object/TermsOfService.vue.js.map +1 -0
  556. package/dist/features/info-object/TermsOfService.vue.script.js +29 -0
  557. package/dist/features/info-object/TermsOfService.vue.script.js.map +1 -0
  558. package/dist/features/info-object/index.d.ts +3 -3
  559. package/dist/features/multiple-documents/DocumentSelector.vue.js +7 -0
  560. package/dist/features/multiple-documents/DocumentSelector.vue.js.map +1 -0
  561. package/dist/features/multiple-documents/DocumentSelector.vue.script.js +48 -0
  562. package/dist/features/multiple-documents/DocumentSelector.vue.script.js.map +1 -0
  563. package/dist/features/specification-extension/SpecificationExtension.vue.js +7 -0
  564. package/dist/features/specification-extension/SpecificationExtension.vue.js.map +1 -0
  565. package/dist/features/specification-extension/SpecificationExtension.vue.script.js +56 -0
  566. package/dist/features/specification-extension/SpecificationExtension.vue.script.js.map +1 -0
  567. package/dist/features/specification-extension/helpers.js +15 -0
  568. package/dist/features/specification-extension/helpers.js.map +1 -0
  569. package/dist/features/specification-extension/index.d.ts +2 -2
  570. package/dist/features/test-request-button/TestRequestButton.vue.d.ts +1 -0
  571. package/dist/features/test-request-button/TestRequestButton.vue.d.ts.map +1 -1
  572. package/dist/features/test-request-button/TestRequestButton.vue.js +9 -0
  573. package/dist/features/test-request-button/TestRequestButton.vue.js.map +1 -0
  574. package/dist/features/test-request-button/TestRequestButton.vue.script.js +49 -0
  575. package/dist/features/test-request-button/TestRequestButton.vue.script.js.map +1 -0
  576. package/dist/features/test-request-button/index.d.ts +1 -1
  577. package/dist/features/x-badges/XBadges.vue.js +7 -0
  578. package/dist/features/x-badges/XBadges.vue.js.map +1 -0
  579. package/dist/features/x-badges/XBadges.vue.script.js +31 -0
  580. package/dist/features/x-badges/XBadges.vue.script.js.map +1 -0
  581. package/dist/features/x-badges/index.d.ts +1 -1
  582. package/dist/helpers/color-mode.js +15 -0
  583. package/dist/helpers/color-mode.js.map +1 -0
  584. package/dist/helpers/download.js +77 -0
  585. package/dist/helpers/download.js.map +1 -0
  586. package/dist/helpers/id-routing.js +107 -0
  587. package/dist/helpers/id-routing.js.map +1 -0
  588. package/dist/helpers/index.d.ts +8 -8
  589. package/dist/helpers/index.js +8 -2
  590. package/dist/{lazy-bus-CV8Ox5hD.js → helpers/lazy-bus.js} +3 -106
  591. package/dist/helpers/lazy-bus.js.map +1 -0
  592. package/dist/helpers/load-from-perssistance.js +23 -0
  593. package/dist/helpers/load-from-perssistance.js.map +1 -0
  594. package/dist/helpers/map-config-plugins.js +44 -0
  595. package/dist/helpers/map-config-plugins.js.map +1 -0
  596. package/dist/helpers/map-config-to-workspace-store.js +24 -0
  597. package/dist/helpers/map-config-to-workspace-store.js.map +1 -0
  598. package/dist/helpers/normalize-configurations.js +66 -0
  599. package/dist/helpers/normalize-configurations.js.map +1 -0
  600. package/dist/helpers/openapi.js +132 -0
  601. package/dist/helpers/openapi.js.map +1 -0
  602. package/dist/{storage--3JuzjCI.js → helpers/storage.js} +2 -2
  603. package/dist/helpers/storage.js.map +1 -0
  604. package/dist/helpers/upload-temp-document.d.ts +2 -1
  605. package/dist/helpers/upload-temp-document.d.ts.map +1 -1
  606. package/dist/helpers/upload-temp-document.js +24 -0
  607. package/dist/helpers/upload-temp-document.js.map +1 -0
  608. package/dist/hooks/index.d.ts +2 -2
  609. package/dist/hooks/index.js +2 -2
  610. package/dist/{use-agent-Bnm1de0n.js → hooks/use-agent.js} +2 -2
  611. package/dist/hooks/use-agent.js.map +1 -0
  612. package/dist/{use-intersection-8QqPi2O-.js → hooks/use-intersection.js} +2 -2
  613. package/dist/hooks/use-intersection.js.map +1 -0
  614. package/dist/index.d.ts +4 -4
  615. package/dist/index.js +6 -6
  616. package/dist/plugins/hooks/usePluginManager.d.ts +1 -1
  617. package/dist/plugins/hooks/usePluginManager.js +16 -0
  618. package/dist/plugins/hooks/usePluginManager.js.map +1 -0
  619. package/dist/plugins/index.d.ts +3 -3
  620. package/dist/plugins/index.js +3 -1
  621. package/dist/plugins/persistance-plugin.js +39 -0
  622. package/dist/plugins/persistance-plugin.js.map +1 -0
  623. package/dist/plugins/plugin-manager.js +32 -0
  624. package/dist/plugins/plugin-manager.js.map +1 -0
  625. package/dist/ssr.js +6 -6
  626. package/dist/standalone/lib/html-api.js +73 -0
  627. package/dist/standalone/lib/html-api.js.map +1 -0
  628. package/dist/style.css +7171 -5725
  629. package/package.json +14 -14
  630. package/dist/AgentScalarChatInterface-MUbtSqMw.js.map +0 -1
  631. package/dist/ExternalDocs-phu7GxpZ.js +0 -272
  632. package/dist/ExternalDocs-phu7GxpZ.js.map +0 -1
  633. package/dist/MobileHeader-DAm6yQX0.js +0 -1373
  634. package/dist/MobileHeader-DAm6yQX0.js.map +0 -1
  635. package/dist/Operation-CvpVIkc3.js +0 -3829
  636. package/dist/Operation-CvpVIkc3.js.map +0 -1
  637. package/dist/SearchButton-xzhIpMCZ.js +0 -621
  638. package/dist/SearchButton-xzhIpMCZ.js.map +0 -1
  639. package/dist/ServerSelector-5y29y2BJ.js +0 -852
  640. package/dist/ServerSelector-5y29y2BJ.js.map +0 -1
  641. package/dist/components/index.js.map +0 -1
  642. package/dist/consts/urls.d.ts +0 -13
  643. package/dist/consts/urls.d.ts.map +0 -1
  644. package/dist/lazy-bus-CV8Ox5hD.js.map +0 -1
  645. package/dist/normalize-configurations-DcVpOEjD.js +0 -232
  646. package/dist/normalize-configurations-DcVpOEjD.js.map +0 -1
  647. package/dist/plugins-4EyiUD_A.js +0 -80
  648. package/dist/plugins-4EyiUD_A.js.map +0 -1
  649. package/dist/src-DJwsRvMU.js +0 -1686
  650. package/dist/src-DJwsRvMU.js.map +0 -1
  651. package/dist/storage--3JuzjCI.js.map +0 -1
  652. package/dist/urls-gPTXGgbj.js +0 -17
  653. package/dist/urls-gPTXGgbj.js.map +0 -1
  654. package/dist/use-agent-Bnm1de0n.js.map +0 -1
  655. package/dist/use-intersection-8QqPi2O-.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaComposition.vue.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaComposition.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { ScalarListbox, type ScalarListboxOption } from '@scalar/components'\nimport { isDefined } from '@scalar/helpers/array/is-defined'\nimport { ScalarIconCaretDown } from '@scalar/icons'\nimport type { WorkspaceEventBus } from '@scalar/workspace-store/events'\nimport { resolve } from '@scalar/workspace-store/resolve'\nimport type {\n DiscriminatorObject,\n SchemaObject,\n} from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { computed, inject, ref, watch } from 'vue'\n\nimport type { SchemaOptions } from '@/components/Content/Schema/types'\nimport {\n REQUEST_BODY_COMPOSITION_INDEX_SYMBOL,\n type RequestBodyCompositionSelection,\n} from '@/features/Operation/request-body-composition-index'\n\nimport { getSchemaType } from './helpers/get-schema-type'\nimport { mergeAllOfSchemas } from './helpers/merge-all-of-schemas'\nimport { type CompositionKeyword } from './helpers/schema-composition'\nimport { getModelNameFromSchema } from './helpers/schema-name'\nimport Schema from './Schema.vue'\n\nconst props = withDefaults(\n defineProps<{\n /** The composition keyword (oneOf, anyOf, allOf) */\n composition: CompositionKeyword\n /** Optional discriminator object for polymorphic schemas */\n discriminator?: DiscriminatorObject\n /** Optional name for the schema */\n name?: string\n /** The schema value containing the composition */\n schema: SchemaObject\n /** Nesting level for proper indentation */\n level: number\n /** Whether to use compact layout */\n compact?: boolean\n /** Whether to hide the heading */\n hideHeading?: boolean\n /** Breadcrumb for navigation */\n breadcrumb?: string[]\n /** Event bus emitting actions */\n eventBus: WorkspaceEventBus | null\n /** Move the options into single prop so they are easy to pass around */\n options: SchemaOptions\n /** When \"requestBody\", sync selected index with the example snippet */\n schemaContext?: string\n /** Internal path used to sync nested request body compositions with the code sample */\n compositionPath?: string[]\n }>(),\n {\n compact: false,\n hideHeading: false,\n },\n)\n\n/** The current composition */\nconst composition = computed(() =>\n [props.schema[props.composition]]\n .flat()\n .map((schema) => ({ value: resolve.schema(schema), original: schema }))\n .filter((it) => isDefined(it.value)),\n)\n\n/**\n * Generate listbox options for the composition selector.\n * Each option represents a schema in the composition with a human-readable label.\n * Prefers schema title/name over structural type when present.\n */\nconst listboxOptions = computed((): ScalarListboxOption[] =>\n composition.value.map((schema, index: number) => {\n const resolved = resolve.schema(schema.original!)\n const label =\n (getModelNameFromSchema(resolved) ?? getSchemaType(resolved)) || 'Schema'\n return { id: String(index), label }\n }),\n)\n\nconst compositionSelectionKey = computed(() =>\n props.compositionPath?.length\n ? [...props.compositionPath, props.composition].join('.')\n : '',\n)\n\n/** When this composition is in the request body, sync selection with the example snippet */\nconst requestBodyCompositionSelectionRef = inject(\n REQUEST_BODY_COMPOSITION_INDEX_SYMBOL,\n undefined,\n)\n\nconst initialSelectedIndex = computed(() => {\n if (\n props.schemaContext !== 'requestBody' ||\n !requestBodyCompositionSelectionRef?.value ||\n !compositionSelectionKey.value\n ) {\n return 0\n }\n\n const selectedIndex =\n requestBodyCompositionSelectionRef.value[compositionSelectionKey.value]\n\n if (typeof selectedIndex !== 'number' || Number.isNaN(selectedIndex)) {\n return 0\n }\n\n return Math.max(0, Math.min(selectedIndex, listboxOptions.value.length - 1))\n})\n\n/**\n * Two-way computed property for the selected option.\n * Handles conversion between the selected index and the listbox option format.\n */\nconst selectedOption = ref<ScalarListboxOption | undefined>()\n\nwatch(\n [listboxOptions, initialSelectedIndex],\n ([options, selectedIndex]) => {\n if (\n !selectedOption.value ||\n !options.some((option) => option.id === selectedOption.value?.id)\n ) {\n selectedOption.value = options[selectedIndex] ?? options[0]\n }\n },\n { immediate: true },\n)\n\n/**\n * Humanize composition keyword name for display.\n * Converts camelCase to Title Case (e.g., oneOf -> One of).\n */\nconst humanizeType = (type: CompositionKeyword): string =>\n type\n .replace(/([A-Z])/g, ' $1')\n .replace(/^./, (str) => str.toUpperCase())\n .toLowerCase()\n .replace(/^(\\w)/, (c) => c.toUpperCase())\n\n/** Inside the currently selected composition */\nconst selectedComposition = computed(\n () => composition.value[Number(selectedOption.value?.id ?? '0')]?.value,\n)\n\n/** Controls whether the nested schema is displayed */\nconst showNestedSchema = ref(false)\n\nif (\n requestBodyCompositionSelectionRef &&\n props.schemaContext === 'requestBody' &&\n compositionSelectionKey.value\n) {\n watch(\n selectedOption,\n (option) => {\n const index = option ? Number(option.id) : 0\n if (!Number.isNaN(index)) {\n requestBodyCompositionSelectionRef.value = {\n ...requestBodyCompositionSelectionRef.value,\n [compositionSelectionKey.value]: index,\n } satisfies RequestBodyCompositionSelection\n }\n },\n { immediate: true },\n )\n}\n</script>\n\n<template>\n <div class=\"property-rule\">\n <!-- We merge allOf schemas into a single schema -->\n <Schema\n v-if=\"props.composition === 'allOf'\"\n :breadcrumb=\"breadcrumb\"\n :compact=\"compact\"\n :discriminator=\"discriminator\"\n :eventBus=\"eventBus\"\n :hideHeading=\"hideHeading\"\n :level=\"level + 1\"\n :name=\"name\"\n :noncollapsible=\"true\"\n :options=\"options\"\n :compositionPath=\"compositionPath\"\n :schemaContext=\"schemaContext\"\n :schema=\"mergeAllOfSchemas(schema)\" />\n\n <template v-else>\n <!-- Composition selector and panel for nested compositions -->\n <ScalarListbox\n v-model=\"selectedOption\"\n :options=\"listboxOptions\"\n resize>\n <button\n class=\"composition-selector bg-b-1.5 hover:bg-b-2 flex w-full cursor-pointer items-center gap-1 rounded-t-lg border px-2.5 py-2.5 pr-3 text-left\"\n type=\"button\">\n <span class=\"text-c-2\">{{ humanizeType(props.composition) }}</span>\n <span\n class=\"composition-selector-label text-c-1\"\n :class=\"{\n 'line-through': selectedComposition?.deprecated,\n }\">\n {{ selectedOption?.label || 'Schema' }}\n </span>\n <div\n v-if=\"selectedComposition?.deprecated\"\n class=\"text-red\">\n deprecated\n </div>\n <ScalarIconCaretDown />\n </button>\n </ScalarListbox>\n\n <div class=\"composition-panel\">\n <!-- Button to toggle nested schema display -->\n <button\n v-if=\"!showNestedSchema && level > 2\"\n class=\"bg-b-1 hover:bg-b-2 text-c-1 flex w-full items-center justify-center gap-2 rounded-b-lg border border-t-0 px-2 py-2 text-sm font-medium transition-colors\"\n type=\"button\"\n @click=\"showNestedSchema = true\">\n Show Schema Details\n <ScalarIconCaretDown class=\"h-3 w-3\" />\n </button>\n\n <!-- Render the selected schema if it has content to display -->\n <Schema\n v-else\n :breadcrumb=\"breadcrumb\"\n :compact=\"compact\"\n :discriminator=\"discriminator\"\n :eventBus=\"eventBus\"\n :hideHeading=\"hideHeading\"\n :level=\"level + 1\"\n :name=\"name\"\n :noncollapsible=\"true\"\n :options=\"options\"\n :compositionPath=\"compositionPath\"\n :schemaContext=\"schemaContext\"\n :schema=\"selectedComposition\" />\n </div>\n </template>\n </div>\n</template>\n"],"mappings":""}
@@ -0,0 +1,176 @@
1
+ import { REQUEST_BODY_COMPOSITION_INDEX_SYMBOL } from "../../../features/Operation/request-body-composition-index.js";
2
+ import { getSchemaType } from "./helpers/get-schema-type.js";
3
+ import { mergeAllOfSchemas } from "./helpers/merge-all-of-schemas.js";
4
+ import { getModelNameFromSchema } from "./helpers/schema-name.js";
5
+ import Schema_default from "./Schema.vue.js";
6
+ import { Fragment, computed, createBlock, createCommentVNode, createElementBlock, createElementVNode, createTextVNode, createVNode, defineComponent, inject, normalizeClass, openBlock, ref, toDisplayString, unref, watch, withCtx } from "vue";
7
+ import { ScalarListbox } from "@scalar/components";
8
+ import { ScalarIconCaretDown } from "@scalar/icons";
9
+ import { resolve } from "@scalar/workspace-store/resolve";
10
+ import { isDefined } from "@scalar/helpers/array/is-defined";
11
+ //#region src/components/Content/Schema/SchemaComposition.vue?vue&type=script&setup=true&lang.ts
12
+ var _hoisted_1 = { class: "property-rule" };
13
+ var _hoisted_2 = {
14
+ class: "composition-selector bg-b-1.5 hover:bg-b-2 flex w-full cursor-pointer items-center gap-1 rounded-t-lg border px-2.5 py-2.5 pr-3 text-left",
15
+ type: "button"
16
+ };
17
+ var _hoisted_3 = { class: "text-c-2" };
18
+ var _hoisted_4 = {
19
+ key: 0,
20
+ class: "text-red"
21
+ };
22
+ var _hoisted_5 = { class: "composition-panel" };
23
+ var SchemaComposition_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
24
+ __name: "SchemaComposition",
25
+ props: {
26
+ composition: {},
27
+ discriminator: {},
28
+ name: {},
29
+ schema: {},
30
+ level: {},
31
+ compact: {
32
+ type: Boolean,
33
+ default: false
34
+ },
35
+ hideHeading: {
36
+ type: Boolean,
37
+ default: false
38
+ },
39
+ breadcrumb: {},
40
+ eventBus: {},
41
+ options: {},
42
+ schemaContext: {},
43
+ compositionPath: {}
44
+ },
45
+ setup(__props) {
46
+ const props = __props;
47
+ /** The current composition */
48
+ const composition = computed(() => [props.schema[props.composition]].flat().map((schema) => ({
49
+ value: resolve.schema(schema),
50
+ original: schema
51
+ })).filter((it) => isDefined(it.value)));
52
+ /**
53
+ * Generate listbox options for the composition selector.
54
+ * Each option represents a schema in the composition with a human-readable label.
55
+ * Prefers schema title/name over structural type when present.
56
+ */
57
+ const listboxOptions = computed(() => composition.value.map((schema, index) => {
58
+ const resolved = resolve.schema(schema.original);
59
+ const label = (getModelNameFromSchema(resolved) ?? getSchemaType(resolved)) || "Schema";
60
+ return {
61
+ id: String(index),
62
+ label
63
+ };
64
+ }));
65
+ const compositionSelectionKey = computed(() => props.compositionPath?.length ? [...props.compositionPath, props.composition].join(".") : "");
66
+ /** When this composition is in the request body, sync selection with the example snippet */
67
+ const requestBodyCompositionSelectionRef = inject(REQUEST_BODY_COMPOSITION_INDEX_SYMBOL, void 0);
68
+ const initialSelectedIndex = computed(() => {
69
+ if (props.schemaContext !== "requestBody" || !requestBodyCompositionSelectionRef?.value || !compositionSelectionKey.value) return 0;
70
+ const selectedIndex = requestBodyCompositionSelectionRef.value[compositionSelectionKey.value];
71
+ if (typeof selectedIndex !== "number" || Number.isNaN(selectedIndex)) return 0;
72
+ return Math.max(0, Math.min(selectedIndex, listboxOptions.value.length - 1));
73
+ });
74
+ /**
75
+ * Two-way computed property for the selected option.
76
+ * Handles conversion between the selected index and the listbox option format.
77
+ */
78
+ const selectedOption = ref();
79
+ watch([listboxOptions, initialSelectedIndex], ([options, selectedIndex]) => {
80
+ if (!selectedOption.value || !options.some((option) => option.id === selectedOption.value?.id)) selectedOption.value = options[selectedIndex] ?? options[0];
81
+ }, { immediate: true });
82
+ /**
83
+ * Humanize composition keyword name for display.
84
+ * Converts camelCase to Title Case (e.g., oneOf -> One of).
85
+ */
86
+ const humanizeType = (type) => type.replace(/([A-Z])/g, " $1").replace(/^./, (str) => str.toUpperCase()).toLowerCase().replace(/^(\w)/, (c) => c.toUpperCase());
87
+ /** Inside the currently selected composition */
88
+ const selectedComposition = computed(() => composition.value[Number(selectedOption.value?.id ?? "0")]?.value);
89
+ /** Controls whether the nested schema is displayed */
90
+ const showNestedSchema = ref(false);
91
+ if (requestBodyCompositionSelectionRef && props.schemaContext === "requestBody" && compositionSelectionKey.value) watch(selectedOption, (option) => {
92
+ const index = option ? Number(option.id) : 0;
93
+ if (!Number.isNaN(index)) requestBodyCompositionSelectionRef.value = {
94
+ ...requestBodyCompositionSelectionRef.value,
95
+ [compositionSelectionKey.value]: index
96
+ };
97
+ }, { immediate: true });
98
+ return (_ctx, _cache) => {
99
+ return openBlock(), createElementBlock("div", _hoisted_1, [props.composition === "allOf" ? (openBlock(), createBlock(Schema_default, {
100
+ key: 0,
101
+ breadcrumb: __props.breadcrumb,
102
+ compact: __props.compact,
103
+ discriminator: __props.discriminator,
104
+ eventBus: __props.eventBus,
105
+ hideHeading: __props.hideHeading,
106
+ level: __props.level + 1,
107
+ name: __props.name,
108
+ noncollapsible: true,
109
+ options: __props.options,
110
+ compositionPath: __props.compositionPath,
111
+ schemaContext: __props.schemaContext,
112
+ schema: unref(mergeAllOfSchemas)(__props.schema)
113
+ }, null, 8, [
114
+ "breadcrumb",
115
+ "compact",
116
+ "discriminator",
117
+ "eventBus",
118
+ "hideHeading",
119
+ "level",
120
+ "name",
121
+ "options",
122
+ "compositionPath",
123
+ "schemaContext",
124
+ "schema"
125
+ ])) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [createVNode(unref(ScalarListbox), {
126
+ modelValue: selectedOption.value,
127
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => selectedOption.value = $event),
128
+ options: listboxOptions.value,
129
+ resize: ""
130
+ }, {
131
+ default: withCtx(() => [createElementVNode("button", _hoisted_2, [
132
+ createElementVNode("span", _hoisted_3, toDisplayString(humanizeType(props.composition)), 1),
133
+ createElementVNode("span", { class: normalizeClass(["composition-selector-label text-c-1", { "line-through": selectedComposition.value?.deprecated }]) }, toDisplayString(selectedOption.value?.label || "Schema"), 3),
134
+ selectedComposition.value?.deprecated ? (openBlock(), createElementBlock("div", _hoisted_4, " deprecated ")) : createCommentVNode("", true),
135
+ createVNode(unref(ScalarIconCaretDown))
136
+ ])]),
137
+ _: 1
138
+ }, 8, ["modelValue", "options"]), createElementVNode("div", _hoisted_5, [!showNestedSchema.value && __props.level > 2 ? (openBlock(), createElementBlock("button", {
139
+ key: 0,
140
+ class: "bg-b-1 hover:bg-b-2 text-c-1 flex w-full items-center justify-center gap-2 rounded-b-lg border border-t-0 px-2 py-2 text-sm font-medium transition-colors",
141
+ type: "button",
142
+ onClick: _cache[1] || (_cache[1] = ($event) => showNestedSchema.value = true)
143
+ }, [_cache[2] || (_cache[2] = createTextVNode(" Show Schema Details ", -1)), createVNode(unref(ScalarIconCaretDown), { class: "h-3 w-3" })])) : (openBlock(), createBlock(Schema_default, {
144
+ key: 1,
145
+ breadcrumb: __props.breadcrumb,
146
+ compact: __props.compact,
147
+ discriminator: __props.discriminator,
148
+ eventBus: __props.eventBus,
149
+ hideHeading: __props.hideHeading,
150
+ level: __props.level + 1,
151
+ name: __props.name,
152
+ noncollapsible: true,
153
+ options: __props.options,
154
+ compositionPath: __props.compositionPath,
155
+ schemaContext: __props.schemaContext,
156
+ schema: selectedComposition.value
157
+ }, null, 8, [
158
+ "breadcrumb",
159
+ "compact",
160
+ "discriminator",
161
+ "eventBus",
162
+ "hideHeading",
163
+ "level",
164
+ "name",
165
+ "options",
166
+ "compositionPath",
167
+ "schemaContext",
168
+ "schema"
169
+ ]))])], 64))]);
170
+ };
171
+ }
172
+ });
173
+ //#endregion
174
+ export { SchemaComposition_vue_vue_type_script_setup_true_lang_default as default };
175
+
176
+ //# sourceMappingURL=SchemaComposition.vue.script.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaComposition.vue.script.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaComposition.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { ScalarListbox, type ScalarListboxOption } from '@scalar/components'\nimport { isDefined } from '@scalar/helpers/array/is-defined'\nimport { ScalarIconCaretDown } from '@scalar/icons'\nimport type { WorkspaceEventBus } from '@scalar/workspace-store/events'\nimport { resolve } from '@scalar/workspace-store/resolve'\nimport type {\n DiscriminatorObject,\n SchemaObject,\n} from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { computed, inject, ref, watch } from 'vue'\n\nimport type { SchemaOptions } from '@/components/Content/Schema/types'\nimport {\n REQUEST_BODY_COMPOSITION_INDEX_SYMBOL,\n type RequestBodyCompositionSelection,\n} from '@/features/Operation/request-body-composition-index'\n\nimport { getSchemaType } from './helpers/get-schema-type'\nimport { mergeAllOfSchemas } from './helpers/merge-all-of-schemas'\nimport { type CompositionKeyword } from './helpers/schema-composition'\nimport { getModelNameFromSchema } from './helpers/schema-name'\nimport Schema from './Schema.vue'\n\nconst props = withDefaults(\n defineProps<{\n /** The composition keyword (oneOf, anyOf, allOf) */\n composition: CompositionKeyword\n /** Optional discriminator object for polymorphic schemas */\n discriminator?: DiscriminatorObject\n /** Optional name for the schema */\n name?: string\n /** The schema value containing the composition */\n schema: SchemaObject\n /** Nesting level for proper indentation */\n level: number\n /** Whether to use compact layout */\n compact?: boolean\n /** Whether to hide the heading */\n hideHeading?: boolean\n /** Breadcrumb for navigation */\n breadcrumb?: string[]\n /** Event bus emitting actions */\n eventBus: WorkspaceEventBus | null\n /** Move the options into single prop so they are easy to pass around */\n options: SchemaOptions\n /** When \"requestBody\", sync selected index with the example snippet */\n schemaContext?: string\n /** Internal path used to sync nested request body compositions with the code sample */\n compositionPath?: string[]\n }>(),\n {\n compact: false,\n hideHeading: false,\n },\n)\n\n/** The current composition */\nconst composition = computed(() =>\n [props.schema[props.composition]]\n .flat()\n .map((schema) => ({ value: resolve.schema(schema), original: schema }))\n .filter((it) => isDefined(it.value)),\n)\n\n/**\n * Generate listbox options for the composition selector.\n * Each option represents a schema in the composition with a human-readable label.\n * Prefers schema title/name over structural type when present.\n */\nconst listboxOptions = computed((): ScalarListboxOption[] =>\n composition.value.map((schema, index: number) => {\n const resolved = resolve.schema(schema.original!)\n const label =\n (getModelNameFromSchema(resolved) ?? getSchemaType(resolved)) || 'Schema'\n return { id: String(index), label }\n }),\n)\n\nconst compositionSelectionKey = computed(() =>\n props.compositionPath?.length\n ? [...props.compositionPath, props.composition].join('.')\n : '',\n)\n\n/** When this composition is in the request body, sync selection with the example snippet */\nconst requestBodyCompositionSelectionRef = inject(\n REQUEST_BODY_COMPOSITION_INDEX_SYMBOL,\n undefined,\n)\n\nconst initialSelectedIndex = computed(() => {\n if (\n props.schemaContext !== 'requestBody' ||\n !requestBodyCompositionSelectionRef?.value ||\n !compositionSelectionKey.value\n ) {\n return 0\n }\n\n const selectedIndex =\n requestBodyCompositionSelectionRef.value[compositionSelectionKey.value]\n\n if (typeof selectedIndex !== 'number' || Number.isNaN(selectedIndex)) {\n return 0\n }\n\n return Math.max(0, Math.min(selectedIndex, listboxOptions.value.length - 1))\n})\n\n/**\n * Two-way computed property for the selected option.\n * Handles conversion between the selected index and the listbox option format.\n */\nconst selectedOption = ref<ScalarListboxOption | undefined>()\n\nwatch(\n [listboxOptions, initialSelectedIndex],\n ([options, selectedIndex]) => {\n if (\n !selectedOption.value ||\n !options.some((option) => option.id === selectedOption.value?.id)\n ) {\n selectedOption.value = options[selectedIndex] ?? options[0]\n }\n },\n { immediate: true },\n)\n\n/**\n * Humanize composition keyword name for display.\n * Converts camelCase to Title Case (e.g., oneOf -> One of).\n */\nconst humanizeType = (type: CompositionKeyword): string =>\n type\n .replace(/([A-Z])/g, ' $1')\n .replace(/^./, (str) => str.toUpperCase())\n .toLowerCase()\n .replace(/^(\\w)/, (c) => c.toUpperCase())\n\n/** Inside the currently selected composition */\nconst selectedComposition = computed(\n () => composition.value[Number(selectedOption.value?.id ?? '0')]?.value,\n)\n\n/** Controls whether the nested schema is displayed */\nconst showNestedSchema = ref(false)\n\nif (\n requestBodyCompositionSelectionRef &&\n props.schemaContext === 'requestBody' &&\n compositionSelectionKey.value\n) {\n watch(\n selectedOption,\n (option) => {\n const index = option ? Number(option.id) : 0\n if (!Number.isNaN(index)) {\n requestBodyCompositionSelectionRef.value = {\n ...requestBodyCompositionSelectionRef.value,\n [compositionSelectionKey.value]: index,\n } satisfies RequestBodyCompositionSelection\n }\n },\n { immediate: true },\n )\n}\n</script>\n\n<template>\n <div class=\"property-rule\">\n <!-- We merge allOf schemas into a single schema -->\n <Schema\n v-if=\"props.composition === 'allOf'\"\n :breadcrumb=\"breadcrumb\"\n :compact=\"compact\"\n :discriminator=\"discriminator\"\n :eventBus=\"eventBus\"\n :hideHeading=\"hideHeading\"\n :level=\"level + 1\"\n :name=\"name\"\n :noncollapsible=\"true\"\n :options=\"options\"\n :compositionPath=\"compositionPath\"\n :schemaContext=\"schemaContext\"\n :schema=\"mergeAllOfSchemas(schema)\" />\n\n <template v-else>\n <!-- Composition selector and panel for nested compositions -->\n <ScalarListbox\n v-model=\"selectedOption\"\n :options=\"listboxOptions\"\n resize>\n <button\n class=\"composition-selector bg-b-1.5 hover:bg-b-2 flex w-full cursor-pointer items-center gap-1 rounded-t-lg border px-2.5 py-2.5 pr-3 text-left\"\n type=\"button\">\n <span class=\"text-c-2\">{{ humanizeType(props.composition) }}</span>\n <span\n class=\"composition-selector-label text-c-1\"\n :class=\"{\n 'line-through': selectedComposition?.deprecated,\n }\">\n {{ selectedOption?.label || 'Schema' }}\n </span>\n <div\n v-if=\"selectedComposition?.deprecated\"\n class=\"text-red\">\n deprecated\n </div>\n <ScalarIconCaretDown />\n </button>\n </ScalarListbox>\n\n <div class=\"composition-panel\">\n <!-- Button to toggle nested schema display -->\n <button\n v-if=\"!showNestedSchema && level > 2\"\n class=\"bg-b-1 hover:bg-b-2 text-c-1 flex w-full items-center justify-center gap-2 rounded-b-lg border border-t-0 px-2 py-2 text-sm font-medium transition-colors\"\n type=\"button\"\n @click=\"showNestedSchema = true\">\n Show Schema Details\n <ScalarIconCaretDown class=\"h-3 w-3\" />\n </button>\n\n <!-- Render the selected schema if it has content to display -->\n <Schema\n v-else\n :breadcrumb=\"breadcrumb\"\n :compact=\"compact\"\n :discriminator=\"discriminator\"\n :eventBus=\"eventBus\"\n :hideHeading=\"hideHeading\"\n :level=\"level + 1\"\n :name=\"name\"\n :noncollapsible=\"true\"\n :options=\"options\"\n :compositionPath=\"compositionPath\"\n :schemaContext=\"schemaContext\"\n :schema=\"selectedComposition\" />\n </div>\n </template>\n </div>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAwBA,MAAM,QAAQ;;EAkCd,MAAM,cAAc,eAClB,CAAC,MAAM,OAAO,MAAM,aAAY,CAC7B,MAAK,CACL,KAAK,YAAY;GAAE,OAAO,QAAQ,OAAO,OAAO;GAAE,UAAU;GAAQ,EAAC,CACrE,QAAQ,OAAO,UAAU,GAAG,MAAM,CAAC,CACxC;;;;;;EAOA,MAAM,iBAAiB,eACrB,YAAY,MAAM,KAAK,QAAQ,UAAkB;GAC/C,MAAM,WAAW,QAAQ,OAAO,OAAO,SAAS;GAChD,MAAM,SACH,uBAAuB,SAAS,IAAI,cAAc,SAAS,KAAK;AACnE,UAAO;IAAE,IAAI,OAAO,MAAM;IAAE;IAAM;IAClC,CACJ;EAEA,MAAM,0BAA0B,eAC9B,MAAM,iBAAiB,SACnB,CAAC,GAAG,MAAM,iBAAiB,MAAM,YAAY,CAAC,KAAK,IAAG,GACtD,GACN;;EAGA,MAAM,qCAAqC,OACzC,uCACA,KAAA,EACF;EAEA,MAAM,uBAAuB,eAAe;AAC1C,OACE,MAAM,kBAAkB,iBACxB,CAAC,oCAAoC,SACrC,CAAC,wBAAwB,MAEzB,QAAO;GAGT,MAAM,gBACJ,mCAAmC,MAAM,wBAAwB;AAEnE,OAAI,OAAO,kBAAkB,YAAY,OAAO,MAAM,cAAc,CAClE,QAAO;AAGT,UAAO,KAAK,IAAI,GAAG,KAAK,IAAI,eAAe,eAAe,MAAM,SAAS,EAAE,CAAA;IAC5E;;;;;EAMD,MAAM,iBAAiB,KAAqC;AAE5D,QACE,CAAC,gBAAgB,qBAAqB,GACrC,CAAC,SAAS,mBAAmB;AAC5B,OACE,CAAC,eAAe,SAChB,CAAC,QAAQ,MAAM,WAAW,OAAO,OAAO,eAAe,OAAO,GAAE,CAEhE,gBAAe,QAAQ,QAAQ,kBAAkB,QAAQ;KAG7D,EAAE,WAAW,MAAM,CACrB;;;;;EAMA,MAAM,gBAAgB,SACpB,KACG,QAAQ,YAAY,MAAK,CACzB,QAAQ,OAAO,QAAQ,IAAI,aAAa,CAAA,CACxC,aAAY,CACZ,QAAQ,UAAU,MAAM,EAAE,aAAa,CAAA;;EAG5C,MAAM,sBAAsB,eACpB,YAAY,MAAM,OAAO,eAAe,OAAO,MAAM,IAAI,GAAG,MACpE;;EAGA,MAAM,mBAAmB,IAAI,MAAK;AAElC,MACE,sCACA,MAAM,kBAAkB,iBACxB,wBAAwB,MAExB,OACE,iBACC,WAAW;GACV,MAAM,QAAQ,SAAS,OAAO,OAAO,GAAG,GAAG;AAC3C,OAAI,CAAC,OAAO,MAAM,MAAM,CACtB,oCAAmC,QAAQ;IACzC,GAAG,mCAAmC;KACrC,wBAAwB,QAAQ;IAClC;KAGL,EAAE,WAAW,MAAM,CACrB;;uBAKA,mBAuEM,OAvEN,YAuEM,CApEI,MAAM,gBAAW,WAAA,WAAA,EADzB,YAawC,gBAAA;;IAXrC,YAAY,QAAA;IACZ,SAAS,QAAA;IACT,eAAe,QAAA;IACf,UAAU,QAAA;IACV,aAAa,QAAA;IACb,OAAO,QAAA,QAAK;IACZ,MAAM,QAAA;IACN,gBAAgB;IAChB,SAAS,QAAA;IACT,iBAAiB,QAAA;IACjB,eAAe,QAAA;IACf,QAAQ,MAAA,kBAAiB,CAAC,QAAA,OAAM;;;;;;;;;;;;;uBAEnC,mBAqDW,UAAA,EAAA,KAAA,GAAA,EAAA,CAnDT,YAsBgB,MAAA,cAAA,EAAA;gBArBL,eAAA;gFAAc,QAAA;IACtB,SAAS,eAAA;IACV,QAAA;;2BAkBS,CAjBT,mBAiBS,UAjBT,YAiBS;KAdP,mBAAmE,QAAnE,YAAmE,gBAAzC,aAAa,MAAM,YAAW,CAAA,EAAA,EAAA;KACxD,mBAMO,QAAA,EALL,OAAK,eAAA,CAAC,uCAAqC,EAAA,gBACH,oBAAA,OAAqB,YAAA,CAAA,CAAA,EAAA,EAAA,gBAG1D,eAAA,OAAgB,SAAK,SAAA,EAAA,EAAA;KAGlB,oBAAA,OAAqB,cAAA,WAAA,EAD7B,mBAIM,OAJN,YAEmB,eAEnB,IAAA,mBAAA,IAAA,KAAA;KACA,YAAuB,MAAA,oBAAA,CAAA;;;qCAI3B,mBA0BM,OA1BN,YA0BM,CAAA,CAvBK,iBAAA,SAAoB,QAAA,QAAK,KAAA,WAAA,EADlC,mBAOS,UAAA;;IALP,OAAM;IACN,MAAK;IACJ,SAAK,OAAA,OAAA,OAAA,MAAA,WAAE,iBAAA,QAAgB;iDAAS,yBAEjC,GAAA,GAAA,YAAuC,MAAA,oBAAA,EAAA,EAAlB,OAAM,WAAS,CAAA,CAAA,CAAA,KAAA,WAAA,EAItC,YAakC,gBAAA;;IAX/B,YAAY,QAAA;IACZ,SAAS,QAAA;IACT,eAAe,QAAA;IACf,UAAU,QAAA;IACV,aAAa,QAAA;IACb,OAAO,QAAA,QAAK;IACZ,MAAM,QAAA;IACN,gBAAgB;IAChB,SAAS,QAAA;IACT,iBAAiB,QAAA;IACjB,eAAe,QAAA;IACf,QAAQ,oBAAA"}
@@ -0,0 +1,9 @@
1
+ import _plugin_vue_export_helper_default from "../../../_virtual/_plugin-vue_export-helper.js";
2
+ import SchemaEnumPropertyItem_vue_vue_type_script_setup_true_lang_default from "./SchemaEnumPropertyItem.vue.script.js";
3
+ /* empty css */
4
+ //#region src/components/Content/Schema/SchemaEnumPropertyItem.vue
5
+ var SchemaEnumPropertyItem_default = /* @__PURE__ */ _plugin_vue_export_helper_default(SchemaEnumPropertyItem_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-f4b54bdd"]]);
6
+ //#endregion
7
+ export { SchemaEnumPropertyItem_default as default };
8
+
9
+ //# sourceMappingURL=SchemaEnumPropertyItem.vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaEnumPropertyItem.vue.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaEnumPropertyItem.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { ScalarMarkdown, ScalarWrappingText } from '@scalar/components'\n\ndefineProps<{\n label: string\n description?: string\n}>()\n</script>\n\n<template>\n <li class=\"property-enum-value\">\n <div class=\"property-enum-value-content\">\n <span class=\"property-enum-value-label\">\n <ScalarWrappingText\n :text=\"label\"\n preset=\"property\" />\n </span>\n <span\n v-if=\"description\"\n class=\"property-enum-value-description\">\n <ScalarMarkdown :value=\"description\" />\n </span>\n </div>\n </li>\n</template>\n\n<style scoped>\n.property-enum-value {\n color: var(--scalar-color-3);\n line-height: 1.5;\n overflow-wrap: break-word;\n display: flex;\n align-items: stretch;\n position: relative;\n\n --decorator-width: 1px;\n --decorator-color: color-mix(\n in srgb,\n var(--scalar-background-1),\n var(--scalar-color-1) 25%\n );\n}\n\n.property-enum-value-content {\n display: flex;\n flex-direction: column;\n padding: 3px 0;\n}\n\n.property-enum-value-label {\n font-family: var(--scalar-font-code);\n color: var(--scalar-color-1);\n font-size: var(--scalar-font-size-4);\n position: relative;\n}\n\n.property-enum-value:last-of-type .property-enum-value-label {\n padding-bottom: 0;\n}\n\n.property-enum-value::before {\n content: '';\n margin-right: 12px;\n width: var(--decorator-width);\n display: block;\n background-color: var(--decorator-color);\n}\n\n.property-enum-value:last-of-type::before,\n.property-enum-values:has(.enum-toggle-button)\n .property-enum-value:nth-last-child(2)::before {\n height: calc(0.5lh + 4px);\n}\n\n.property-enum-value-label::after {\n content: '';\n position: absolute;\n top: calc(0.5lh);\n left: -12px;\n width: 8px;\n height: var(--decorator-width);\n background-color: var(--decorator-color);\n}\n\n.property-enum-value:last-of-type::after {\n bottom: 0;\n height: 50%;\n background: var(--scalar-background-1);\n border-top: var(--scalar-border-width) solid var(--decorator-color);\n}\n\n.property-enum-value-description {\n color: var(--scalar-color-3);\n}\n</style>\n"],"mappings":""}
@@ -0,0 +1,29 @@
1
+ import { createCommentVNode, createElementBlock, createElementVNode, createVNode, defineComponent, openBlock, unref } from "vue";
2
+ import { ScalarMarkdown, ScalarWrappingText } from "@scalar/components";
3
+ //#region src/components/Content/Schema/SchemaEnumPropertyItem.vue?vue&type=script&setup=true&lang.ts
4
+ var _hoisted_1 = { class: "property-enum-value" };
5
+ var _hoisted_2 = { class: "property-enum-value-content" };
6
+ var _hoisted_3 = { class: "property-enum-value-label" };
7
+ var _hoisted_4 = {
8
+ key: 0,
9
+ class: "property-enum-value-description"
10
+ };
11
+ var SchemaEnumPropertyItem_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
12
+ __name: "SchemaEnumPropertyItem",
13
+ props: {
14
+ label: {},
15
+ description: {}
16
+ },
17
+ setup(__props) {
18
+ return (_ctx, _cache) => {
19
+ return openBlock(), createElementBlock("li", _hoisted_1, [createElementVNode("div", _hoisted_2, [createElementVNode("span", _hoisted_3, [createVNode(unref(ScalarWrappingText), {
20
+ text: __props.label,
21
+ preset: "property"
22
+ }, null, 8, ["text"])]), __props.description ? (openBlock(), createElementBlock("span", _hoisted_4, [createVNode(unref(ScalarMarkdown), { value: __props.description }, null, 8, ["value"])])) : createCommentVNode("", true)])]);
23
+ };
24
+ }
25
+ });
26
+ //#endregion
27
+ export { SchemaEnumPropertyItem_vue_vue_type_script_setup_true_lang_default as default };
28
+
29
+ //# sourceMappingURL=SchemaEnumPropertyItem.vue.script.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaEnumPropertyItem.vue.script.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaEnumPropertyItem.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { ScalarMarkdown, ScalarWrappingText } from '@scalar/components'\n\ndefineProps<{\n label: string\n description?: string\n}>()\n</script>\n\n<template>\n <li class=\"property-enum-value\">\n <div class=\"property-enum-value-content\">\n <span class=\"property-enum-value-label\">\n <ScalarWrappingText\n :text=\"label\"\n preset=\"property\" />\n </span>\n <span\n v-if=\"description\"\n class=\"property-enum-value-description\">\n <ScalarMarkdown :value=\"description\" />\n </span>\n </div>\n </li>\n</template>\n\n<style scoped>\n.property-enum-value {\n color: var(--scalar-color-3);\n line-height: 1.5;\n overflow-wrap: break-word;\n display: flex;\n align-items: stretch;\n position: relative;\n\n --decorator-width: 1px;\n --decorator-color: color-mix(\n in srgb,\n var(--scalar-background-1),\n var(--scalar-color-1) 25%\n );\n}\n\n.property-enum-value-content {\n display: flex;\n flex-direction: column;\n padding: 3px 0;\n}\n\n.property-enum-value-label {\n font-family: var(--scalar-font-code);\n color: var(--scalar-color-1);\n font-size: var(--scalar-font-size-4);\n position: relative;\n}\n\n.property-enum-value:last-of-type .property-enum-value-label {\n padding-bottom: 0;\n}\n\n.property-enum-value::before {\n content: '';\n margin-right: 12px;\n width: var(--decorator-width);\n display: block;\n background-color: var(--decorator-color);\n}\n\n.property-enum-value:last-of-type::before,\n.property-enum-values:has(.enum-toggle-button)\n .property-enum-value:nth-last-child(2)::before {\n height: calc(0.5lh + 4px);\n}\n\n.property-enum-value-label::after {\n content: '';\n position: absolute;\n top: calc(0.5lh);\n left: -12px;\n width: 8px;\n height: var(--decorator-width);\n background-color: var(--decorator-color);\n}\n\n.property-enum-value:last-of-type::after {\n bottom: 0;\n height: 50%;\n background: var(--scalar-background-1);\n border-top: var(--scalar-border-width) solid var(--decorator-color);\n}\n\n.property-enum-value-description {\n color: var(--scalar-color-3);\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;;;;;uBAUE,mBAaK,MAbL,YAaK,CAZH,mBAWM,OAXN,YAWM,CAVJ,mBAIO,QAJP,YAIO,CAHL,YAEsB,MAAA,mBAAA,EAAA;IADnB,MAAM,QAAA;IACP,QAAO;4BAGH,QAAA,eAAA,WAAA,EADR,mBAIO,QAJP,YAIO,CADL,YAAuC,MAAA,eAAA,EAAA,EAAtB,OAAO,QAAA,aAAW,EAAA,MAAA,GAAA,CAAA,QAAA,CAAA,CAAA,CAAA,IAAA,mBAAA,IAAA,KAAA,CAAA,CAAA,CAAA,CAAA"}
@@ -0,0 +1,9 @@
1
+ import _plugin_vue_export_helper_default from "../../../_virtual/_plugin-vue_export-helper.js";
2
+ import SchemaEnums_vue_vue_type_script_setup_true_lang_default from "./SchemaEnums.vue.script.js";
3
+ /* empty css */
4
+ //#region src/components/Content/Schema/SchemaEnums.vue
5
+ var SchemaEnums_default = /* @__PURE__ */ _plugin_vue_export_helper_default(SchemaEnums_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-55c01b89"]]);
6
+ //#endregion
7
+ export { SchemaEnums_default as default };
8
+
9
+ //# sourceMappingURL=SchemaEnums.vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaEnums.vue.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaEnums.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ScalarButton } from '@scalar/components'\nimport { ScalarIconPlus } from '@scalar/icons'\nimport { resolve } from '@scalar/workspace-store/resolve'\nimport type { SchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { isArraySchema } from '@scalar/workspace-store/schemas/v3.1/strict/type-guards'\nimport { computed, ref } from 'vue'\n\nimport SchemaEnumPropertyItem from './SchemaEnumPropertyItem.vue'\n\nconst { value } = defineProps<{\n /** The schema object containing enum values and metadata */\n value: SchemaObject | undefined\n /** Whether to display the enum for property names */\n propertyNames?: boolean\n}>()\n\nconst ENUM_DISPLAY_THRESHOLD = 9\nconst INITIAL_VISIBLE_COUNT = 5\nconst THIN_SPACE = '\\u2009'\n\n/**\n * Extracts enum values from the schema object.\n * Handles both direct enum values and nested enum arrays.\n */\nconst enumValues = computed(() => {\n if (!value) {\n return []\n }\n return (\n value.enum ||\n (isArraySchema(value) && resolve.schema(value.items)?.enum) ||\n []\n )\n})\n\n/**\n * Determines if we should show the long enum list UI.\n * When there are many enum values, we initially show only a subset.\n */\nconst shouldUseLongListDisplay = computed(\n () => enumValues.value.length > ENUM_DISPLAY_THRESHOLD,\n)\n\nconst initialVisibleCount = computed(() =>\n shouldUseLongListDisplay.value\n ? INITIAL_VISIBLE_COUNT\n : enumValues.value.length,\n)\n\nconst visibleEnumValues = computed(() =>\n enumValues.value.slice(0, initialVisibleCount.value),\n)\n\nconst hiddenEnumValues = computed(() =>\n enumValues.value.slice(initialVisibleCount.value),\n)\n\n/**\n * Gets the description for an enum value.\n * Supports both array and object formats for x-enumDescriptions.\n */\nconst getEnumValueDescription = (\n enumValue: any,\n index: number,\n): string | undefined => {\n const descriptions =\n value?.['x-enumDescriptions'] ?? value?.['x-enum-descriptions']\n\n if (!descriptions) {\n return undefined\n }\n\n if (Array.isArray(descriptions)) {\n return descriptions[index]\n }\n\n if (typeof descriptions === 'object' && descriptions !== null) {\n return (descriptions as Record<string, string>)[String(enumValue)]\n }\n\n return undefined\n}\n\n/**\n * Formats an enum value with its variable name if available.\n * This supports both x-enum-varnames and x-enumNames extensions.\n */\nconst formatEnumValueWithName = (enumValue: any, index: number): string => {\n const varNames = value?.['x-enum-varnames'] ?? value?.['x-enumNames']\n const varName = Array.isArray(varNames) ? varNames[index] : undefined\n return varName\n ? `${enumValue}${THIN_SPACE}=${THIN_SPACE}${varName}`\n : String(enumValue)\n}\n\n/**\n * Controls whether the hidden enum values are visible.\n */\nconst isExpanded = ref(false)\n\nconst toggleExpanded = () => {\n isExpanded.value = !isExpanded.value\n}\n</script>\n\n<template>\n <div\n v-if=\"enumValues.length > 0\"\n class=\"property-enum\">\n <div\n v-if=\"propertyNames\"\n class=\"property-enum-property-names\">\n property names\n </div>\n <div\n v-else\n class=\"property-enum-property-names\">\n values\n </div>\n <ul class=\"property-enum-values\">\n <!-- Visible enum values -->\n <SchemaEnumPropertyItem\n v-for=\"(enumValue, index) in visibleEnumValues\"\n :key=\"String(enumValue)\"\n :description=\"getEnumValueDescription(enumValue, index)\"\n :label=\"formatEnumValueWithName(enumValue, index)\" />\n\n <!-- Hidden enum values (when expanded) -->\n <template v-if=\"shouldUseLongListDisplay && isExpanded\">\n <SchemaEnumPropertyItem\n v-for=\"(enumValue, index) in hiddenEnumValues\"\n :key=\"String(enumValue)\"\n :description=\"\n getEnumValueDescription(enumValue, initialVisibleCount + index)\n \"\n :label=\"\n formatEnumValueWithName(enumValue, initialVisibleCount + index)\n \" />\n </template>\n\n <!-- Toggle button for long lists -->\n <li v-if=\"shouldUseLongListDisplay\">\n <ScalarButton\n class=\"enum-toggle-button my-2 flex h-fit gap-1 rounded-full border py-1.5 pr-2.5 pl-2 leading-none\"\n variant=\"ghost\"\n @click=\"toggleExpanded\">\n <ScalarIconPlus\n :class=\"{ 'rotate-45': isExpanded }\"\n weight=\"bold\" />\n {{ isExpanded ? 'Hide values' : 'Show all values' }}\n </ScalarButton>\n </li>\n </ul>\n </div>\n</template>\n\n<style scoped>\n.property-heading:empty + .property-description:last-of-type,\n.property-description:first-of-type:last-of-type {\n margin-top: 0;\n}\n\n.property-list {\n border: var(--scalar-border-width) solid var(--scalar-border-color);\n border-radius: var(--scalar-radius);\n margin-top: 10px;\n}\n\n.property-list .property:last-of-type {\n padding-bottom: 10px;\n}\n\n.property-enum-values {\n font-size: var(--scalar-font-size-3);\n list-style: none;\n margin-top: 8px;\n padding-left: 2px;\n}\n\n.enum-toggle-button:hover {\n color: var(--scalar-color-1);\n}\n\n.property-enum-property-names {\n font-size: var(--scalar-font-size-4);\n color: var(--scalar-color-2);\n display: inline-block;\n padding: 0 2px;\n margin-top: 8px;\n}\n</style>\n"],"mappings":""}
@@ -0,0 +1,108 @@
1
+ import SchemaEnumPropertyItem_default from "./SchemaEnumPropertyItem.vue.js";
2
+ import { Fragment, computed, createBlock, createCommentVNode, createElementBlock, createElementVNode, createTextVNode, createVNode, defineComponent, normalizeClass, openBlock, ref, renderList, toDisplayString, unref, withCtx } from "vue";
3
+ import { ScalarButton } from "@scalar/components";
4
+ import { ScalarIconPlus } from "@scalar/icons";
5
+ import { resolve } from "@scalar/workspace-store/resolve";
6
+ import { isArraySchema } from "@scalar/workspace-store/schemas/v3.1/strict/type-guards";
7
+ //#region src/components/Content/Schema/SchemaEnums.vue?vue&type=script&setup=true&lang.ts
8
+ var _hoisted_1 = {
9
+ key: 0,
10
+ class: "property-enum"
11
+ };
12
+ var _hoisted_2 = {
13
+ key: 0,
14
+ class: "property-enum-property-names"
15
+ };
16
+ var _hoisted_3 = {
17
+ key: 1,
18
+ class: "property-enum-property-names"
19
+ };
20
+ var _hoisted_4 = { class: "property-enum-values" };
21
+ var _hoisted_5 = { key: 1 };
22
+ var ENUM_DISPLAY_THRESHOLD = 9;
23
+ var INITIAL_VISIBLE_COUNT = 5;
24
+ var THIN_SPACE = " ";
25
+ /**
26
+ * Extracts enum values from the schema object.
27
+ * Handles both direct enum values and nested enum arrays.
28
+ */
29
+ var SchemaEnums_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
30
+ __name: "SchemaEnums",
31
+ props: {
32
+ value: {},
33
+ propertyNames: { type: Boolean }
34
+ },
35
+ setup(__props) {
36
+ const enumValues = computed(() => {
37
+ if (!__props.value) return [];
38
+ return __props.value.enum || isArraySchema(__props.value) && resolve.schema(__props.value.items)?.enum || [];
39
+ });
40
+ /**
41
+ * Determines if we should show the long enum list UI.
42
+ * When there are many enum values, we initially show only a subset.
43
+ */
44
+ const shouldUseLongListDisplay = computed(() => enumValues.value.length > ENUM_DISPLAY_THRESHOLD);
45
+ const initialVisibleCount = computed(() => shouldUseLongListDisplay.value ? INITIAL_VISIBLE_COUNT : enumValues.value.length);
46
+ const visibleEnumValues = computed(() => enumValues.value.slice(0, initialVisibleCount.value));
47
+ const hiddenEnumValues = computed(() => enumValues.value.slice(initialVisibleCount.value));
48
+ /**
49
+ * Gets the description for an enum value.
50
+ * Supports both array and object formats for x-enumDescriptions.
51
+ */
52
+ const getEnumValueDescription = (enumValue, index) => {
53
+ const descriptions = __props.value?.["x-enumDescriptions"] ?? __props.value?.["x-enum-descriptions"];
54
+ if (!descriptions) return;
55
+ if (Array.isArray(descriptions)) return descriptions[index];
56
+ if (typeof descriptions === "object" && descriptions !== null) return descriptions[String(enumValue)];
57
+ };
58
+ /**
59
+ * Formats an enum value with its variable name if available.
60
+ * This supports both x-enum-varnames and x-enumNames extensions.
61
+ */
62
+ const formatEnumValueWithName = (enumValue, index) => {
63
+ const varNames = __props.value?.["x-enum-varnames"] ?? __props.value?.["x-enumNames"];
64
+ const varName = Array.isArray(varNames) ? varNames[index] : void 0;
65
+ return varName ? `${enumValue}${THIN_SPACE}=${THIN_SPACE}${varName}` : String(enumValue);
66
+ };
67
+ /**
68
+ * Controls whether the hidden enum values are visible.
69
+ */
70
+ const isExpanded = ref(false);
71
+ const toggleExpanded = () => {
72
+ isExpanded.value = !isExpanded.value;
73
+ };
74
+ return (_ctx, _cache) => {
75
+ return enumValues.value.length > 0 ? (openBlock(), createElementBlock("div", _hoisted_1, [__props.propertyNames ? (openBlock(), createElementBlock("div", _hoisted_2, " property names ")) : (openBlock(), createElementBlock("div", _hoisted_3, " values ")), createElementVNode("ul", _hoisted_4, [
76
+ (openBlock(true), createElementBlock(Fragment, null, renderList(visibleEnumValues.value, (enumValue, index) => {
77
+ return openBlock(), createBlock(SchemaEnumPropertyItem_default, {
78
+ key: String(enumValue),
79
+ description: getEnumValueDescription(enumValue, index),
80
+ label: formatEnumValueWithName(enumValue, index)
81
+ }, null, 8, ["description", "label"]);
82
+ }), 128)),
83
+ shouldUseLongListDisplay.value && isExpanded.value ? (openBlock(true), createElementBlock(Fragment, { key: 0 }, renderList(hiddenEnumValues.value, (enumValue, index) => {
84
+ return openBlock(), createBlock(SchemaEnumPropertyItem_default, {
85
+ key: String(enumValue),
86
+ description: getEnumValueDescription(enumValue, initialVisibleCount.value + index),
87
+ label: formatEnumValueWithName(enumValue, initialVisibleCount.value + index)
88
+ }, null, 8, ["description", "label"]);
89
+ }), 128)) : createCommentVNode("", true),
90
+ shouldUseLongListDisplay.value ? (openBlock(), createElementBlock("li", _hoisted_5, [createVNode(unref(ScalarButton), {
91
+ class: "enum-toggle-button my-2 flex h-fit gap-1 rounded-full border py-1.5 pr-2.5 pl-2 leading-none",
92
+ variant: "ghost",
93
+ onClick: toggleExpanded
94
+ }, {
95
+ default: withCtx(() => [createVNode(unref(ScalarIconPlus), {
96
+ class: normalizeClass({ "rotate-45": isExpanded.value }),
97
+ weight: "bold"
98
+ }, null, 8, ["class"]), createTextVNode(" " + toDisplayString(isExpanded.value ? "Hide values" : "Show all values"), 1)]),
99
+ _: 1
100
+ })])) : createCommentVNode("", true)
101
+ ])])) : createCommentVNode("", true);
102
+ };
103
+ }
104
+ });
105
+ //#endregion
106
+ export { SchemaEnums_vue_vue_type_script_setup_true_lang_default as default };
107
+
108
+ //# sourceMappingURL=SchemaEnums.vue.script.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaEnums.vue.script.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaEnums.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ScalarButton } from '@scalar/components'\nimport { ScalarIconPlus } from '@scalar/icons'\nimport { resolve } from '@scalar/workspace-store/resolve'\nimport type { SchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { isArraySchema } from '@scalar/workspace-store/schemas/v3.1/strict/type-guards'\nimport { computed, ref } from 'vue'\n\nimport SchemaEnumPropertyItem from './SchemaEnumPropertyItem.vue'\n\nconst { value } = defineProps<{\n /** The schema object containing enum values and metadata */\n value: SchemaObject | undefined\n /** Whether to display the enum for property names */\n propertyNames?: boolean\n}>()\n\nconst ENUM_DISPLAY_THRESHOLD = 9\nconst INITIAL_VISIBLE_COUNT = 5\nconst THIN_SPACE = '\\u2009'\n\n/**\n * Extracts enum values from the schema object.\n * Handles both direct enum values and nested enum arrays.\n */\nconst enumValues = computed(() => {\n if (!value) {\n return []\n }\n return (\n value.enum ||\n (isArraySchema(value) && resolve.schema(value.items)?.enum) ||\n []\n )\n})\n\n/**\n * Determines if we should show the long enum list UI.\n * When there are many enum values, we initially show only a subset.\n */\nconst shouldUseLongListDisplay = computed(\n () => enumValues.value.length > ENUM_DISPLAY_THRESHOLD,\n)\n\nconst initialVisibleCount = computed(() =>\n shouldUseLongListDisplay.value\n ? INITIAL_VISIBLE_COUNT\n : enumValues.value.length,\n)\n\nconst visibleEnumValues = computed(() =>\n enumValues.value.slice(0, initialVisibleCount.value),\n)\n\nconst hiddenEnumValues = computed(() =>\n enumValues.value.slice(initialVisibleCount.value),\n)\n\n/**\n * Gets the description for an enum value.\n * Supports both array and object formats for x-enumDescriptions.\n */\nconst getEnumValueDescription = (\n enumValue: any,\n index: number,\n): string | undefined => {\n const descriptions =\n value?.['x-enumDescriptions'] ?? value?.['x-enum-descriptions']\n\n if (!descriptions) {\n return undefined\n }\n\n if (Array.isArray(descriptions)) {\n return descriptions[index]\n }\n\n if (typeof descriptions === 'object' && descriptions !== null) {\n return (descriptions as Record<string, string>)[String(enumValue)]\n }\n\n return undefined\n}\n\n/**\n * Formats an enum value with its variable name if available.\n * This supports both x-enum-varnames and x-enumNames extensions.\n */\nconst formatEnumValueWithName = (enumValue: any, index: number): string => {\n const varNames = value?.['x-enum-varnames'] ?? value?.['x-enumNames']\n const varName = Array.isArray(varNames) ? varNames[index] : undefined\n return varName\n ? `${enumValue}${THIN_SPACE}=${THIN_SPACE}${varName}`\n : String(enumValue)\n}\n\n/**\n * Controls whether the hidden enum values are visible.\n */\nconst isExpanded = ref(false)\n\nconst toggleExpanded = () => {\n isExpanded.value = !isExpanded.value\n}\n</script>\n\n<template>\n <div\n v-if=\"enumValues.length > 0\"\n class=\"property-enum\">\n <div\n v-if=\"propertyNames\"\n class=\"property-enum-property-names\">\n property names\n </div>\n <div\n v-else\n class=\"property-enum-property-names\">\n values\n </div>\n <ul class=\"property-enum-values\">\n <!-- Visible enum values -->\n <SchemaEnumPropertyItem\n v-for=\"(enumValue, index) in visibleEnumValues\"\n :key=\"String(enumValue)\"\n :description=\"getEnumValueDescription(enumValue, index)\"\n :label=\"formatEnumValueWithName(enumValue, index)\" />\n\n <!-- Hidden enum values (when expanded) -->\n <template v-if=\"shouldUseLongListDisplay && isExpanded\">\n <SchemaEnumPropertyItem\n v-for=\"(enumValue, index) in hiddenEnumValues\"\n :key=\"String(enumValue)\"\n :description=\"\n getEnumValueDescription(enumValue, initialVisibleCount + index)\n \"\n :label=\"\n formatEnumValueWithName(enumValue, initialVisibleCount + index)\n \" />\n </template>\n\n <!-- Toggle button for long lists -->\n <li v-if=\"shouldUseLongListDisplay\">\n <ScalarButton\n class=\"enum-toggle-button my-2 flex h-fit gap-1 rounded-full border py-1.5 pr-2.5 pl-2 leading-none\"\n variant=\"ghost\"\n @click=\"toggleExpanded\">\n <ScalarIconPlus\n :class=\"{ 'rotate-45': isExpanded }\"\n weight=\"bold\" />\n {{ isExpanded ? 'Hide values' : 'Show all values' }}\n </ScalarButton>\n </li>\n </ul>\n </div>\n</template>\n\n<style scoped>\n.property-heading:empty + .property-description:last-of-type,\n.property-description:first-of-type:last-of-type {\n margin-top: 0;\n}\n\n.property-list {\n border: var(--scalar-border-width) solid var(--scalar-border-color);\n border-radius: var(--scalar-radius);\n margin-top: 10px;\n}\n\n.property-list .property:last-of-type {\n padding-bottom: 10px;\n}\n\n.property-enum-values {\n font-size: var(--scalar-font-size-3);\n list-style: none;\n margin-top: 8px;\n padding-left: 2px;\n}\n\n.enum-toggle-button:hover {\n color: var(--scalar-color-1);\n}\n\n.property-enum-property-names {\n font-size: var(--scalar-font-size-4);\n color: var(--scalar-color-2);\n display: inline-block;\n padding: 0 2px;\n margin-top: 8px;\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAiBA,IAAM,yBAAyB;AAC/B,IAAM,wBAAwB;AAC9B,IAAM,aAAa;;;;;;;;;;;;EAMnB,MAAM,aAAa,eAAe;AAChC,OAAI,CAAC,QAAA,MACH,QAAO,EAAC;AAEV,UACE,QAAA,MAAM,QACL,cAAc,QAAA,MAAM,IAAI,QAAQ,OAAO,QAAA,MAAM,MAAM,EAAE,QACtD,EAAC;IAEJ;;;;;EAMD,MAAM,2BAA2B,eACzB,WAAW,MAAM,SAAS,uBAClC;EAEA,MAAM,sBAAsB,eAC1B,yBAAyB,QACrB,wBACA,WAAW,MAAM,OACvB;EAEA,MAAM,oBAAoB,eACxB,WAAW,MAAM,MAAM,GAAG,oBAAoB,MAAM,CACtD;EAEA,MAAM,mBAAmB,eACvB,WAAW,MAAM,MAAM,oBAAoB,MAAM,CACnD;;;;;EAMA,MAAM,2BACJ,WACA,UACuB;GACvB,MAAM,eACJ,QAAA,QAAQ,yBAAyB,QAAA,QAAQ;AAE3C,OAAI,CAAC,aACH;AAGF,OAAI,MAAM,QAAQ,aAAa,CAC7B,QAAO,aAAa;AAGtB,OAAI,OAAO,iBAAiB,YAAY,iBAAiB,KACvD,QAAQ,aAAwC,OAAO,UAAU;;;;;;EAUrE,MAAM,2BAA2B,WAAgB,UAA0B;GACzE,MAAM,WAAW,QAAA,QAAQ,sBAAsB,QAAA,QAAQ;GACvD,MAAM,UAAU,MAAM,QAAQ,SAAS,GAAG,SAAS,SAAS,KAAA;AAC5D,UAAO,UACH,GAAG,YAAY,WAAW,GAAG,aAAa,YAC1C,OAAO,UAAS;;;;;EAMtB,MAAM,aAAa,IAAI,MAAK;EAE5B,MAAM,uBAAuB;AAC3B,cAAW,QAAQ,CAAC,WAAW;;;UAMvB,WAAA,MAAW,SAAM,KAAA,WAAA,EADzB,mBA+CM,OA/CN,YA+CM,CA3CI,QAAA,iBAAA,WAAA,EADR,mBAIM,OAJN,YAEuC,mBAEvC,KAAA,WAAA,EACA,mBAIM,OAJN,YAEuC,WAEvC,GACA,mBAiCK,MAjCL,YAiCK;sBA/BH,mBAIuD,UAAA,MAAA,WAHxB,kBAAA,QAArB,WAAW,UAAK;yBAD1B,YAIuD,gCAAA;MAFpD,KAAK,OAAO,UAAS;MACrB,aAAa,wBAAwB,WAAW,MAAK;MACrD,OAAO,wBAAwB,WAAW,MAAK;;;IAGlC,yBAAA,SAA4B,WAAA,SAAA,UAAA,KAAA,EAC1C,mBAQM,UAAA,EAAA,KAAA,GAAA,EAAA,WAPyB,iBAAA,QAArB,WAAW,UAAK;yBAD1B,YAQM,gCAAA;MANH,KAAK,OAAO,UAAS;MACrB,aAA0B,wBAAwB,WAAW,oBAAA,QAAsB,MAAK;MAGxF,OAAoB,wBAAwB,WAAW,oBAAA,QAAsB,MAAK;;;IAM7E,yBAAA,SAAA,WAAA,EAAV,mBAUK,MAAA,YAAA,CATH,YAQe,MAAA,aAAA,EAAA;KAPb,OAAM;KACN,SAAQ;KACP,SAAO;;4BAGU,CAFlB,YAEkB,MAAA,eAAA,EAAA;MADf,OAAK,eAAA,EAAA,aAAiB,WAAA,OAAU,CAAA;MACjC,QAAO;6CAAS,MAClB,gBAAG,WAAA,QAAU,gBAAA,kBAAA,EAAA,EAAA,CAAA,CAAA"}
@@ -0,0 +1,9 @@
1
+ import _plugin_vue_export_helper_default from "../../../_virtual/_plugin-vue_export-helper.js";
2
+ import SchemaHeading_vue_vue_type_script_setup_true_lang_default from "./SchemaHeading.vue.script.js";
3
+ /* empty css */
4
+ //#region src/components/Content/Schema/SchemaHeading.vue
5
+ var SchemaHeading_default = /* @__PURE__ */ _plugin_vue_export_helper_default(SchemaHeading_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-70cb5c13"]]);
6
+ //#endregion
7
+ export { SchemaHeading_default as default };
8
+
9
+ //# sourceMappingURL=SchemaHeading.vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaHeading.vue.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaHeading.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { ScalarWrappingText } from '@scalar/components'\nimport type { SchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { isArraySchema } from '@scalar/workspace-store/schemas/v3.1/strict/type-guards'\nimport { computed } from 'vue'\n\nimport { isTypeObject } from '@/components/Content/Schema/helpers/is-type-object'\n\nconst { value } = defineProps<{\n value: SchemaObject\n name?: string\n}>()\n\n/** Generate a failsafe type from the properties when we don't have one */\nconst failsafeType = computed(() => {\n if ('type' in value) {\n return value.type\n }\n\n if (value.enum) {\n return 'enum'\n }\n\n if (isArraySchema(value) && value.items) {\n return 'array'\n }\n\n if (isTypeObject(value) && (value.properties || value.additionalProperties)) {\n return 'object'\n }\n\n return 'unknown'\n})\n</script>\n\n<template>\n <span\n v-if=\"typeof value === 'object'\"\n class=\"schema-type\">\n <span\n class=\"schema-type-icon\"\n :title=\"\n 'type' in value && typeof value.type === 'string'\n ? value.type\n : 'type' in value && Array.isArray(value.type)\n ? value.type.join(' | ')\n : 'unknown type'\n \">\n <template v-if=\"isTypeObject(value)\"> {} </template>\n <template v-if=\"isArraySchema(value)\"> [] </template>\n <template v-if=\"value.enum\"> enum </template>\n </span>\n <template v-if=\"name\">\n <ScalarWrappingText\n :text=\"name\"\n preset=\"property\" />\n </template>\n <template v-else>\n {{ failsafeType }}\n </template>\n </span>\n</template>\n<style scoped>\n/* Style the \"icon\" */\n.schema-type-icon {\n color: var(--scalar-color-1);\n display: none;\n}\n.schema-type {\n font-family: var(--scalar-font-code);\n color: var(--scalar-color-1);\n}\n</style>\n"],"mappings":""}
@@ -0,0 +1,45 @@
1
+ import { isTypeObject } from "./helpers/is-type-object.js";
2
+ import { Fragment, computed, createBlock, createCommentVNode, createElementBlock, createElementVNode, createTextVNode, defineComponent, openBlock, toDisplayString, unref } from "vue";
3
+ import { ScalarWrappingText } from "@scalar/components";
4
+ import { isArraySchema } from "@scalar/workspace-store/schemas/v3.1/strict/type-guards";
5
+ //#region src/components/Content/Schema/SchemaHeading.vue?vue&type=script&setup=true&lang.ts
6
+ var _hoisted_1 = {
7
+ key: 0,
8
+ class: "schema-type"
9
+ };
10
+ var _hoisted_2 = ["title"];
11
+ var SchemaHeading_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
12
+ __name: "SchemaHeading",
13
+ props: {
14
+ value: {},
15
+ name: {}
16
+ },
17
+ setup(__props) {
18
+ /** Generate a failsafe type from the properties when we don't have one */
19
+ const failsafeType = computed(() => {
20
+ if ("type" in __props.value) return __props.value.type;
21
+ if (__props.value.enum) return "enum";
22
+ if (isArraySchema(__props.value) && __props.value.items) return "array";
23
+ if (isTypeObject(__props.value) && (__props.value.properties || __props.value.additionalProperties)) return "object";
24
+ return "unknown";
25
+ });
26
+ return (_ctx, _cache) => {
27
+ return typeof __props.value === "object" ? (openBlock(), createElementBlock("span", _hoisted_1, [createElementVNode("span", {
28
+ class: "schema-type-icon",
29
+ title: "type" in __props.value && typeof __props.value.type === "string" ? __props.value.type : "type" in __props.value && Array.isArray(__props.value.type) ? __props.value.type.join(" | ") : "unknown type"
30
+ }, [
31
+ unref(isTypeObject)(__props.value) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [createTextVNode(" {} ")], 64)) : createCommentVNode("", true),
32
+ unref(isArraySchema)(__props.value) ? (openBlock(), createElementBlock(Fragment, { key: 1 }, [createTextVNode(" [] ")], 64)) : createCommentVNode("", true),
33
+ __props.value.enum ? (openBlock(), createElementBlock(Fragment, { key: 2 }, [createTextVNode(" enum ")], 64)) : createCommentVNode("", true)
34
+ ], 8, _hoisted_2), __props.name ? (openBlock(), createBlock(unref(ScalarWrappingText), {
35
+ key: 0,
36
+ text: __props.name,
37
+ preset: "property"
38
+ }, null, 8, ["text"])) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [createTextVNode(toDisplayString(failsafeType.value), 1)], 64))])) : createCommentVNode("", true);
39
+ };
40
+ }
41
+ });
42
+ //#endregion
43
+ export { SchemaHeading_vue_vue_type_script_setup_true_lang_default as default };
44
+
45
+ //# sourceMappingURL=SchemaHeading.vue.script.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaHeading.vue.script.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaHeading.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { ScalarWrappingText } from '@scalar/components'\nimport type { SchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { isArraySchema } from '@scalar/workspace-store/schemas/v3.1/strict/type-guards'\nimport { computed } from 'vue'\n\nimport { isTypeObject } from '@/components/Content/Schema/helpers/is-type-object'\n\nconst { value } = defineProps<{\n value: SchemaObject\n name?: string\n}>()\n\n/** Generate a failsafe type from the properties when we don't have one */\nconst failsafeType = computed(() => {\n if ('type' in value) {\n return value.type\n }\n\n if (value.enum) {\n return 'enum'\n }\n\n if (isArraySchema(value) && value.items) {\n return 'array'\n }\n\n if (isTypeObject(value) && (value.properties || value.additionalProperties)) {\n return 'object'\n }\n\n return 'unknown'\n})\n</script>\n\n<template>\n <span\n v-if=\"typeof value === 'object'\"\n class=\"schema-type\">\n <span\n class=\"schema-type-icon\"\n :title=\"\n 'type' in value && typeof value.type === 'string'\n ? value.type\n : 'type' in value && Array.isArray(value.type)\n ? value.type.join(' | ')\n : 'unknown type'\n \">\n <template v-if=\"isTypeObject(value)\"> {} </template>\n <template v-if=\"isArraySchema(value)\"> [] </template>\n <template v-if=\"value.enum\"> enum </template>\n </span>\n <template v-if=\"name\">\n <ScalarWrappingText\n :text=\"name\"\n preset=\"property\" />\n </template>\n <template v-else>\n {{ failsafeType }}\n </template>\n </span>\n</template>\n<style scoped>\n/* Style the \"icon\" */\n.schema-type-icon {\n color: var(--scalar-color-1);\n display: none;\n}\n.schema-type {\n font-family: var(--scalar-font-code);\n color: var(--scalar-color-1);\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;;;;;EAcA,MAAM,eAAe,eAAe;AAClC,OAAI,UAAU,QAAA,MACZ,QAAO,QAAA,MAAM;AAGf,OAAI,QAAA,MAAM,KACR,QAAO;AAGT,OAAI,cAAc,QAAA,MAAM,IAAI,QAAA,MAAM,MAChC,QAAO;AAGT,OAAI,aAAa,QAAA,MAAM,KAAK,QAAA,MAAM,cAAc,QAAA,MAAM,sBACpD,QAAO;AAGT,UAAO;IACR;;iBAKgB,QAAA,UAAK,YAAA,WAAA,EADpB,mBAwBO,QAxBP,YAwBO,CArBL,mBAYO,QAAA;IAXL,OAAM;IACL,OAAA,UAA0B,QAAA,SAAK,OAAW,QAAA,MAAM,SAAI,WAA0B,QAAA,MAAM,OAAA,UAA2B,QAAA,SAAS,MAAM,QAAQ,QAAA,MAAM,KAAI,GAAgB,QAAA,MAAM,KAAK,KAAI,MAAA,GAAA;;IAOhK,MAAA,aAAY,CAAC,QAAA,MAAK,IAAA,WAAA,EAAlC,mBAAoD,UAAA,EAAA,KAAA,GAAA,EAAA,CAAA,gBAAf,OAAI,CAAA,EAAA,GAAA,IAAA,mBAAA,IAAA,KAAA;IACzB,MAAA,cAAa,CAAC,QAAA,MAAK,IAAA,WAAA,EAAnC,mBAAqD,UAAA,EAAA,KAAA,GAAA,EAAA,CAAA,gBAAf,OAAI,CAAA,EAAA,GAAA,IAAA,mBAAA,IAAA,KAAA;IAC1B,QAAA,MAAM,QAAA,WAAA,EAAtB,mBAA6C,UAAA,EAAA,KAAA,GAAA,EAAA,CAAA,gBAAjB,SAAM,CAAA,EAAA,GAAA,IAAA,mBAAA,IAAA,KAAA;sBAEpB,QAAA,QAAA,WAAA,EACd,YAEsB,MAAA,mBAAA,EAAA;;IADnB,MAAM,QAAA;IACP,QAAO;0CAEX,mBAEW,UAAA,EAAA,KAAA,GAAA,EAAA,CAAA,gBAAA,gBADN,aAAA,MAAY,EAAA,EAAA,CAAA,EAAA,GAAA,EAAA,CAAA,IAAA,mBAAA,IAAA,KAAA"}
@@ -0,0 +1,7 @@
1
+ import SchemaObjectExampleCodeBlock_vue_vue_type_script_setup_true_lang_default from "./SchemaObjectExampleCodeBlock.vue.script.js";
2
+ //#region src/components/Content/Schema/SchemaObjectExampleCodeBlock.vue
3
+ var SchemaObjectExampleCodeBlock_default = SchemaObjectExampleCodeBlock_vue_vue_type_script_setup_true_lang_default;
4
+ //#endregion
5
+ export { SchemaObjectExampleCodeBlock_default as default };
6
+
7
+ //# sourceMappingURL=SchemaObjectExampleCodeBlock.vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaObjectExampleCodeBlock.vue.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaObjectExampleCodeBlock.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ExamplePicker } from '@scalar/api-client/v2/blocks/operation-code-sample'\nimport {\n ScalarCard,\n ScalarCardFooter,\n ScalarCardSection,\n ScalarCodeBlock,\n} from '@scalar/components'\nimport type { SchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { computed, ref } from 'vue'\n\nconst { schema } = defineProps<{ schema: SchemaObject }>()\n\n/** Grab the examples for the schema object */\nconst examples = computed<Record<string, string>>(() => {\n const base: Record<string, string> = {}\n\n // x-examples extension\n if (schema['x-examples']) {\n Object.entries(schema['x-examples']).forEach(([key, value]) => {\n base[key] =\n typeof value === 'object'\n ? JSON.stringify(value, null, 2)\n : String(value)\n })\n }\n\n // Regular schema examples array\n if (schema.examples) {\n schema.examples.forEach((value, index) => {\n base[`Example ${index + 1}`] =\n typeof value === 'object'\n ? JSON.stringify(value, null, 2)\n : String(value)\n })\n }\n\n return base\n})\n\n/** The currently selected example key */\nconst selectedExampleKey = ref<string>(Object.keys(examples.value)[0] ?? '')\n</script>\n<template>\n <ScalarCard\n v-if=\"Object.keys(examples).length > 0\"\n class=\"dark-mode\">\n <!-- Code snippet -->\n <ScalarCardSection>\n <div class=\"code-snippet\">\n <ScalarCodeBlock\n class=\"bg-b-2\"\n lang=\"json\"\n lineNumbers\n :prettyPrintedContent=\"\n examples[selectedExampleKey] ??\n 'There was an error loading the example'\n \" />\n </div>\n </ScalarCardSection>\n\n <!-- Example picker -->\n <ScalarCardFooter\n v-if=\"Object.keys(examples).length > 1\"\n class=\"bg-b-3\">\n <ExamplePicker\n v-model=\"selectedExampleKey\"\n :examples />\n </ScalarCardFooter>\n </ScalarCard>\n</template>\n"],"mappings":""}
@@ -0,0 +1,55 @@
1
+ import { computed, createBlock, createCommentVNode, createElementVNode, createVNode, defineComponent, openBlock, ref, unref, withCtx } from "vue";
2
+ import { ScalarCard, ScalarCardFooter, ScalarCardSection, ScalarCodeBlock } from "@scalar/components";
3
+ import { ExamplePicker } from "@scalar/api-client/v2/blocks/operation-code-sample";
4
+ //#region src/components/Content/Schema/SchemaObjectExampleCodeBlock.vue?vue&type=script&setup=true&lang.ts
5
+ var _hoisted_1 = { class: "code-snippet" };
6
+ var SchemaObjectExampleCodeBlock_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
7
+ __name: "SchemaObjectExampleCodeBlock",
8
+ props: { schema: {} },
9
+ setup(__props) {
10
+ /** Grab the examples for the schema object */
11
+ const examples = computed(() => {
12
+ const base = {};
13
+ if (__props.schema["x-examples"]) Object.entries(__props.schema["x-examples"]).forEach(([key, value]) => {
14
+ base[key] = typeof value === "object" ? JSON.stringify(value, null, 2) : String(value);
15
+ });
16
+ if (__props.schema.examples) __props.schema.examples.forEach((value, index) => {
17
+ base[`Example ${index + 1}`] = typeof value === "object" ? JSON.stringify(value, null, 2) : String(value);
18
+ });
19
+ return base;
20
+ });
21
+ /** The currently selected example key */
22
+ const selectedExampleKey = ref(Object.keys(examples.value)[0] ?? "");
23
+ return (_ctx, _cache) => {
24
+ return Object.keys(examples.value).length > 0 ? (openBlock(), createBlock(unref(ScalarCard), {
25
+ key: 0,
26
+ class: "dark-mode"
27
+ }, {
28
+ default: withCtx(() => [createVNode(unref(ScalarCardSection), null, {
29
+ default: withCtx(() => [createElementVNode("div", _hoisted_1, [createVNode(unref(ScalarCodeBlock), {
30
+ class: "bg-b-2",
31
+ lang: "json",
32
+ lineNumbers: "",
33
+ prettyPrintedContent: examples.value[selectedExampleKey.value] ?? "There was an error loading the example"
34
+ }, null, 8, ["prettyPrintedContent"])])]),
35
+ _: 1
36
+ }), Object.keys(examples.value).length > 1 ? (openBlock(), createBlock(unref(ScalarCardFooter), {
37
+ key: 0,
38
+ class: "bg-b-3"
39
+ }, {
40
+ default: withCtx(() => [createVNode(unref(ExamplePicker), {
41
+ modelValue: selectedExampleKey.value,
42
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => selectedExampleKey.value = $event),
43
+ examples: examples.value
44
+ }, null, 8, ["modelValue", "examples"])]),
45
+ _: 1
46
+ })) : createCommentVNode("", true)]),
47
+ _: 1
48
+ })) : createCommentVNode("", true);
49
+ };
50
+ }
51
+ });
52
+ //#endregion
53
+ export { SchemaObjectExampleCodeBlock_vue_vue_type_script_setup_true_lang_default as default };
54
+
55
+ //# sourceMappingURL=SchemaObjectExampleCodeBlock.vue.script.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaObjectExampleCodeBlock.vue.script.js","names":[],"sources":["../../../../src/components/Content/Schema/SchemaObjectExampleCodeBlock.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ExamplePicker } from '@scalar/api-client/v2/blocks/operation-code-sample'\nimport {\n ScalarCard,\n ScalarCardFooter,\n ScalarCardSection,\n ScalarCodeBlock,\n} from '@scalar/components'\nimport type { SchemaObject } from '@scalar/workspace-store/schemas/v3.1/strict/openapi-document'\nimport { computed, ref } from 'vue'\n\nconst { schema } = defineProps<{ schema: SchemaObject }>()\n\n/** Grab the examples for the schema object */\nconst examples = computed<Record<string, string>>(() => {\n const base: Record<string, string> = {}\n\n // x-examples extension\n if (schema['x-examples']) {\n Object.entries(schema['x-examples']).forEach(([key, value]) => {\n base[key] =\n typeof value === 'object'\n ? JSON.stringify(value, null, 2)\n : String(value)\n })\n }\n\n // Regular schema examples array\n if (schema.examples) {\n schema.examples.forEach((value, index) => {\n base[`Example ${index + 1}`] =\n typeof value === 'object'\n ? JSON.stringify(value, null, 2)\n : String(value)\n })\n }\n\n return base\n})\n\n/** The currently selected example key */\nconst selectedExampleKey = ref<string>(Object.keys(examples.value)[0] ?? '')\n</script>\n<template>\n <ScalarCard\n v-if=\"Object.keys(examples).length > 0\"\n class=\"dark-mode\">\n <!-- Code snippet -->\n <ScalarCardSection>\n <div class=\"code-snippet\">\n <ScalarCodeBlock\n class=\"bg-b-2\"\n lang=\"json\"\n lineNumbers\n :prettyPrintedContent=\"\n examples[selectedExampleKey] ??\n 'There was an error loading the example'\n \" />\n </div>\n </ScalarCardSection>\n\n <!-- Example picker -->\n <ScalarCardFooter\n v-if=\"Object.keys(examples).length > 1\"\n class=\"bg-b-3\">\n <ExamplePicker\n v-model=\"selectedExampleKey\"\n :examples />\n </ScalarCardFooter>\n </ScalarCard>\n</template>\n"],"mappings":";;;;;;;;;;EAcA,MAAM,WAAW,eAAuC;GACtD,MAAM,OAA+B,EAAC;AAGtC,OAAI,QAAA,OAAO,cACT,QAAO,QAAQ,QAAA,OAAO,cAAc,CAAC,SAAS,CAAC,KAAK,WAAW;AAC7D,SAAK,OACH,OAAO,UAAU,WACb,KAAK,UAAU,OAAO,MAAM,EAAC,GAC7B,OAAO,MAAK;KACnB;AAIH,OAAI,QAAA,OAAO,SACT,SAAA,OAAO,SAAS,SAAS,OAAO,UAAU;AACxC,SAAK,WAAW,QAAQ,OACtB,OAAO,UAAU,WACb,KAAK,UAAU,OAAO,MAAM,EAAC,GAC7B,OAAO,MAAK;KACnB;AAGH,UAAO;IACR;;EAGD,MAAM,qBAAqB,IAAY,OAAO,KAAK,SAAS,MAAM,CAAC,MAAM,GAAE;;UAIjE,OAAO,KAAK,SAAA,MAAQ,CAAE,SAAM,KAAA,WAAA,EADpC,YAyBa,MAAA,WAAA,EAAA;;IAvBX,OAAM;;2BAac,CAXpB,YAWoB,MAAA,kBAAA,EAAA,MAAA;4BADZ,CATN,mBASM,OATN,YASM,CARJ,YAOM,MAAA,gBAAA,EAAA;MANJ,OAAM;MACN,MAAK;MACL,aAAA;MACC,sBAAmC,SAAA,MAAS,mBAAA,UAAA;;;QAS3C,OAAO,KAAK,SAAA,MAAQ,CAAE,SAAM,KAAA,WAAA,EADpC,YAMmB,MAAA,iBAAA,EAAA;;KAJjB,OAAM;;4BAGQ,CAFd,YAEc,MAAA,cAAA,EAAA;kBADH,mBAAA;sFAAkB,QAAA;MAC1B,UAAA,SAAA"}
@@ -11,6 +11,8 @@ type __VLS_Props = {
11
11
  breadcrumb?: string[];
12
12
  eventBus: WorkspaceEventBus | null;
13
13
  options: SchemaOptions;
14
+ schemaContext?: string;
15
+ compositionPath?: string[];
14
16
  };
15
17
  declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
16
18
  declare const _default: typeof __VLS_export;
@@ -1 +1 @@
1
- {"version":3,"file":"SchemaObjectProperties.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Content/Schema/SchemaObjectProperties.vue"],"names":[],"mappings":"AAsMA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAA;AAEvE,OAAO,KAAK,EACV,mBAAmB,EACnB,YAAY,EACb,MAAM,8DAA8D,CAAA;AAKrE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAA;AAItE,KAAK,WAAW,GAAG;IACjB,MAAM,EAAE,YAAY,CAAA;IACpB,aAAa,CAAC,EAAE,mBAAmB,CAAA;IACnC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAA;IACrB,QAAQ,EAAE,iBAAiB,GAAG,IAAI,CAAA;IAClC,OAAO,EAAE,aAAa,CAAA;CACvB,CAAC;AA0PF,QAAA,MAAM,YAAY,kSAEhB,CAAC;wBACkB,OAAO,YAAY;AAAxC,wBAAyC"}
1
+ {"version":3,"file":"SchemaObjectProperties.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Content/Schema/SchemaObjectProperties.vue"],"names":[],"mappings":"AAuNA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAA;AAEvE,OAAO,KAAK,EACV,mBAAmB,EACnB,YAAY,EACb,MAAM,8DAA8D,CAAA;AAKrE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAA;AAItE,KAAK,WAAW,GAAG;IACf,MAAM,EAAE,YAAY,CAAA;IACpB,aAAa,CAAC,EAAE,mBAAmB,CAAA;IACnC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAA;IACrB,QAAQ,EAAE,iBAAiB,GAAG,IAAI,CAAA;IAClC,OAAO,EAAE,aAAa,CAAA;IACtB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAA;CAC3B,CAAC;AAuRJ,QAAA,MAAM,YAAY,kSAEhB,CAAC;wBACkB,OAAO,YAAY;AAAxC,wBAAyC"}