@redocly/openapi-docs 3.12.0-rc.7 → 3.12.1

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 (390) hide show
  1. package/dist/redocly-openapi-docs.min.js +2153 -1963
  2. package/lib/components/ApiInfo/ApiInfo.js +29 -1
  3. package/lib/components/ApiInfo/Metadata.js +29 -1
  4. package/lib/components/ApiInfo/index.js +2 -1
  5. package/lib/components/ApiInfo/styled.js +17 -8
  6. package/lib/components/CallbackSamples/CallbackSamples.js +25 -4
  7. package/lib/components/CallbackSamples/index.js +2 -1
  8. package/lib/components/Callbacks/CallbackDetails.js +17 -3
  9. package/lib/components/Callbacks/CallbackOperation.js +24 -3
  10. package/lib/components/Callbacks/CallbackSummary.js +19 -3
  11. package/lib/components/Callbacks/CallbacksList.js +16 -1
  12. package/lib/components/Callbacks/index.js +4 -1
  13. package/lib/components/Callbacks/styled.js +6 -3
  14. package/lib/components/Content/Content.js +10 -1
  15. package/lib/components/Content/index.js +2 -1
  16. package/lib/components/Content/useAutoScroll.js +50 -1
  17. package/lib/components/ContentItem/ContentItem.js +31 -1
  18. package/lib/components/ContentItem/index.js +2 -1
  19. package/lib/components/ContentItem/useIsExpanded.js +33 -1
  20. package/lib/components/ContentItems/ContentItems.js +19 -1
  21. package/lib/components/ContentItems/Items.js +13 -1
  22. package/lib/components/ContentItems/VirtualList.js +35 -1
  23. package/lib/components/ContentItems/helpers.js +49 -1
  24. package/lib/components/ContentItems/index.js +2 -1
  25. package/lib/components/ContentItems/useScrollOnRender.js +26 -1
  26. package/lib/components/Discriminator/Discriminator.js +27 -2
  27. package/lib/components/Discriminator/index.js +2 -1
  28. package/lib/components/Download/DownloadSpecification.js +46 -4
  29. package/lib/components/Download/index.js +2 -1
  30. package/lib/components/Download/types.js +2 -0
  31. package/lib/components/Download/useDownloadInfo.js +42 -1
  32. package/lib/components/ErrorBoundary/ErrorBoundary.js +22 -2
  33. package/lib/components/ErrorBoundary/index.js +2 -1
  34. package/lib/components/ExpandAllButton/ExpandAllButton.js +31 -2
  35. package/lib/components/ExpandAllButton/index.js +2 -1
  36. package/lib/components/ExternalDocumentation/ExternalDocumentation.js +18 -4
  37. package/lib/components/ExternalDocumentation/index.js +2 -1
  38. package/lib/components/Language/LanguageDropdown.js +21 -1
  39. package/lib/components/Language/LanguageItem.js +33 -1
  40. package/lib/components/Language/LanguageList.js +93 -1
  41. package/lib/components/Language/_tests_/LanguageDropdown.test.js +23 -1
  42. package/lib/components/Language/constants.js +3 -1
  43. package/lib/components/Language/index.js +4 -1
  44. package/lib/components/Language/styled.js +29 -15
  45. package/lib/components/Markdown/Markdown.js +64 -1
  46. package/lib/components/Markdown/index.js +3 -1
  47. package/lib/components/Markdown/types.js +2 -0
  48. package/lib/components/MediaTypeSwitch/MediaTypesSwitch.js +51 -1
  49. package/lib/components/MediaTypeSwitch/index.js +2 -1
  50. package/lib/components/OperationItem/Description.d.ts +1 -4
  51. package/lib/components/OperationItem/Description.js +9 -1
  52. package/lib/components/OperationItem/OperationItem.js +70 -5
  53. package/lib/components/OperationItem/_tests_/OperationItem.test.js +70 -1
  54. package/lib/components/OperationItem/_tests_/__mocks__/mock-intersection-observer.js +40 -1
  55. package/lib/components/OperationItem/index.js +2 -1
  56. package/lib/components/OperationItem/types.js +2 -0
  57. package/lib/components/Overlay.js +48 -3
  58. package/lib/components/Overview/Overview.js +20 -1
  59. package/lib/components/Overview/index.js +2 -1
  60. package/lib/components/PageFooter/PageFooter.js +19 -1
  61. package/lib/components/PageFooter/index.js +2 -1
  62. package/lib/components/Panel/ResponsePanel.js +12 -6
  63. package/lib/components/Panel/Trigger.js +4 -2
  64. package/lib/components/Panel/index.js +3 -1
  65. package/lib/components/PanelItem/PanelItem.js +6 -1
  66. package/lib/components/PanelItem/index.js +3 -1
  67. package/lib/components/PanelItem/styled.js +20 -10
  68. package/lib/components/PayloadSamples/Example.js +6 -1
  69. package/lib/components/PayloadSamples/ExampleValue.js +30 -1
  70. package/lib/components/PayloadSamples/MediaTypeSamples.js +36 -2
  71. package/lib/components/PayloadSamples/PayloadSamples.js +26 -1
  72. package/lib/components/PayloadSamples/index.js +7 -1
  73. package/lib/components/PayloadSamples/styled.js +9 -4
  74. package/lib/components/PayloadSamples/types.js +2 -0
  75. package/lib/components/PropertyDetails/DescriptionEnums.js +19 -3
  76. package/lib/components/PropertyDetails/EnumValues.js +37 -1
  77. package/lib/components/PropertyDetails/Examples.js +26 -1
  78. package/lib/components/PropertyDetails/Extensions.js +17 -2
  79. package/lib/components/PropertyDetails/FieldDetail.js +15 -2
  80. package/lib/components/PropertyDetails/FieldDetails.js +51 -6
  81. package/lib/components/PropertyDetails/Pattern.js +21 -1
  82. package/lib/components/PropertyDetails/PlusCircleIcon.js +10 -4
  83. package/lib/components/PropertyDetails/PropertyDetails.js +22 -5
  84. package/lib/components/PropertyDetails/SchemaTypeInfo.js +10 -2
  85. package/lib/components/PropertyDetails/SimpleEnums.js +13 -2
  86. package/lib/components/PropertyDetails/cycleColorsByLevel.js +18 -1
  87. package/lib/components/PropertyDetails/index.js +4 -1
  88. package/lib/components/PropertyDetails/styled.js +15 -7
  89. package/lib/components/PropertyDetails/types.js +2 -0
  90. package/lib/components/RedoclyOpenAPIDocs/Providers.js +114 -1
  91. package/lib/components/RedoclyOpenAPIDocs/RedoclyOpenAPIDocs.js +57 -1
  92. package/lib/components/RedoclyOpenAPIDocs/RedoclyOpenAPIDocsStandalone.js +86 -1
  93. package/lib/components/RedoclyOpenAPIDocs/index.js +5 -1
  94. package/lib/components/RedoclyOpenAPIDocs/styled.js +4 -2
  95. package/lib/components/RedoclyOpenAPIDocs/types.js +2 -0
  96. package/lib/components/RedoclyOpenAPIDocs/utils.js +33 -1
  97. package/lib/components/RenderHook/RenderHook.js +17 -1
  98. package/lib/components/RenderHook/index.js +2 -1
  99. package/lib/components/Replay/EmbeddedReplay.js +41 -3
  100. package/lib/components/Replay/Replay.js +99 -1
  101. package/lib/components/Replay/index.js +3 -1
  102. package/lib/components/Replay/utils.js +208 -1
  103. package/lib/components/Request/RequestDetails.js +33 -2
  104. package/lib/components/Request/types.js +2 -0
  105. package/lib/components/RequestParameters/Body.js +8 -1
  106. package/lib/components/RequestParameters/ParametersGroup.js +19 -4
  107. package/lib/components/RequestParameters/RequestParameters.js +40 -1
  108. package/lib/components/RequestParameters/index.js +4 -1
  109. package/lib/components/RequestSamples/CodeSample.js +55 -2
  110. package/lib/components/RequestSamples/Example.js +37 -1
  111. package/lib/components/RequestSamples/RequestSamples.js +89 -5
  112. package/lib/components/RequestSamples/index.js +3 -1
  113. package/lib/components/RequestSamples/useCodeSamples.js +92 -1
  114. package/lib/components/ResponseSamples/ResponseSamples.js +47 -1
  115. package/lib/components/ResponseSamples/Summary.js +9 -1
  116. package/lib/components/ResponseSamples/index.js +2 -1
  117. package/lib/components/Responses/OperationResponseList.js +42 -2
  118. package/lib/components/Responses/ResponseDetails.js +18 -1
  119. package/lib/components/Responses/ResponseHeaders.js +15 -1
  120. package/lib/components/Responses/index.js +6 -1
  121. package/lib/components/Responses/styled.js +14 -6
  122. package/lib/components/Responses/types.js +2 -0
  123. package/lib/components/RightPanel/RightPanel.js +21 -1
  124. package/lib/components/RightPanel/index.js +2 -1
  125. package/lib/components/Samples/ExampleSwitch.js +33 -1
  126. package/lib/components/Samples/index.js +3 -1
  127. package/lib/components/Samples/use-example-key.js +12 -1
  128. package/lib/components/Schema/ArraySchema.js +45 -1
  129. package/lib/components/Schema/ObjectSchema.js +29 -1
  130. package/lib/components/Schema/OneOfSchema.js +47 -3
  131. package/lib/components/Schema/RecursiveSchema.js +10 -1
  132. package/lib/components/Schema/Schema.js +63 -2
  133. package/lib/components/Schema/SubSchema.js +20 -1
  134. package/lib/components/Schema/helpers.js +16 -1
  135. package/lib/components/Schema/index.js +5 -1
  136. package/lib/components/Schema/types.js +2 -0
  137. package/lib/components/Schema/useOneOfLocationIdx.js +11 -1
  138. package/lib/components/SchemaDefinition/SchemaDefinition.js +65 -2
  139. package/lib/components/SchemaDefinition/index.js +2 -1
  140. package/lib/components/SectionContent/SectionContent.js +49 -6
  141. package/lib/components/SectionContent/index.js +2 -1
  142. package/lib/components/SectionItem/SectionItem.js +14 -1
  143. package/lib/components/SectionItem/index.js +2 -1
  144. package/lib/components/Security/Divider.js +9 -2
  145. package/lib/components/Security/OAuthFlow.js +11 -1
  146. package/lib/components/Security/OAuthScopes.js +59 -9
  147. package/lib/components/Security/Security.js +15 -1
  148. package/lib/components/Security/SecurityButton.js +31 -7
  149. package/lib/components/Security/SecurityFlow.js +28 -4
  150. package/lib/components/Security/SecurityModal.js +34 -5
  151. package/lib/components/Security/SecuritySchemeItem.js +15 -4
  152. package/lib/components/Security/helper.js +16 -1
  153. package/lib/components/Security/index.js +11 -1
  154. package/lib/components/Security/styled.js +6 -3
  155. package/lib/components/SelectOrLabel/SelectOrLabel.js +12 -2
  156. package/lib/components/SelectOrLabel/index.js +2 -1
  157. package/lib/components/ServerList/ServerList.js +36 -10
  158. package/lib/components/ServerList/index.js +2 -1
  159. package/lib/components/ServerList/types.js +2 -0
  160. package/lib/components/ServerListDropdown/ServerListDropdown.js +54 -1
  161. package/lib/components/ServerListDropdown/index.js +2 -1
  162. package/lib/components/ServerListDropdown/styled.js +15 -6
  163. package/lib/components/SideMenu/SideMenu.js +13 -2
  164. package/lib/components/SideMenu/hooks/useMenuItems.js +110 -1
  165. package/lib/components/SideMenu/index.js +2 -1
  166. package/lib/components/SideMenu/types.js +2 -0
  167. package/lib/components/StickySidebar/SidebarActions.js +14 -2
  168. package/lib/components/StickySidebar/StickyResponsiveSidebar.js +37 -7
  169. package/lib/components/StickySidebar/index.js +2 -1
  170. package/lib/components/Tabs/Tabs.js +16 -5
  171. package/lib/components/Tabs/index.js +3 -1
  172. package/lib/components/Tabs/useTabsState.js +22 -1
  173. package/lib/components/TagItem/OperationNavigationItems.js +18 -4
  174. package/lib/components/TagItem/OperationsNavigation.js +46 -2
  175. package/lib/components/TagItem/TagItem.js +41 -8
  176. package/lib/components/TagItem/index.js +2 -1
  177. package/lib/components/TagItem/styled.js +5 -2
  178. package/lib/components/TagItem/types.js +2 -0
  179. package/lib/components/ViewNested/ViewNested.js +42 -9
  180. package/lib/components/ViewNested/index.js +2 -1
  181. package/lib/components/common/Badges.js +21 -5
  182. package/lib/components/common/BodyContent/BodyContent.js +31 -4
  183. package/lib/components/common/BodyContent/index.js +2 -1
  184. package/lib/components/common/ClearButton/ClearButton.js +5 -1
  185. package/lib/components/common/ClearButton/index.js +3 -1
  186. package/lib/components/common/ClearButton/styled.js +5 -2
  187. package/lib/components/common/ClearButton/types.js +2 -0
  188. package/lib/components/common/CodeBlockPanel.js +7 -3
  189. package/lib/components/common/ConstraintsView.js +14 -2
  190. package/lib/components/common/Dropdown/Dropdown.js +22 -4
  191. package/lib/components/common/Dropdown/index.js +2 -1
  192. package/lib/components/common/ExpandableExample/ExpandableExample.js +24 -3
  193. package/lib/components/common/ExpandableExample/index.js +2 -1
  194. package/lib/components/common/Extensions.js +17 -2
  195. package/lib/components/common/Fields/fields-layout.js +76 -51
  196. package/lib/components/common/Fields/fields.js +39 -17
  197. package/lib/components/common/Fields/index.js +3 -1
  198. package/lib/components/common/LinkToField.js +33 -6
  199. package/lib/components/common/OperationItemTitle.d.ts +1 -0
  200. package/lib/components/common/OperationItemTitle.js +16 -5
  201. package/lib/components/common/SchemaSelection/SchemaSelection.js +51 -1
  202. package/lib/components/common/SchemaSelection/index.js +2 -1
  203. package/lib/components/common/Select/Select.js +21 -1
  204. package/lib/components/common/Select/index.js +3 -1
  205. package/lib/components/common/Select/styled.js +17 -9
  206. package/lib/components/common/Select/types.js +2 -0
  207. package/lib/components/common/Skeleton/LanguageListSkeleton.js +16 -6
  208. package/lib/components/common/Skeleton/Skeleton.js +15 -5
  209. package/lib/components/common/Skeleton/index.js +3 -1
  210. package/lib/components/common/headers.js +4 -2
  211. package/lib/components/common/index.js +14 -1
  212. package/lib/components/common/linkify.js +28 -4
  213. package/lib/components/common/mixins.js +4 -2
  214. package/lib/components/common/panels.js +58 -33
  215. package/lib/components/common/schema.js +16 -8
  216. package/lib/components/common/styled.js +15 -7
  217. package/lib/components/index.js +25 -1
  218. package/lib/components/pluggable/RedocExample.js +20 -1
  219. package/lib/components/pluggable/RedocSchema.js +22 -1
  220. package/lib/components/pluggable/index.js +3 -1
  221. package/lib/components/pluggable/styled.components.js +9 -4
  222. package/lib/constants.js +30 -1
  223. package/lib/empty.js +7 -1
  224. package/lib/events/codeSampleCopy.js +19 -1
  225. package/lib/events/creator.js +5 -1
  226. package/lib/events/index.js +8 -1
  227. package/lib/events/languageSwitch.js +18 -1
  228. package/lib/events/panelToggle.js +16 -1
  229. package/lib/events/serverSwitch.js +13 -1
  230. package/lib/events/tryItOpen.js +12 -1
  231. package/lib/events/tryItSent.js +12 -1
  232. package/lib/events/types.js +11 -1
  233. package/lib/hoc/types.js +2 -0
  234. package/lib/hoc/utils.js +4 -1
  235. package/lib/hoc/withRouter.js +17 -1
  236. package/lib/hoc/withStore.js +28 -1
  237. package/lib/hooks/index.js +9 -1
  238. package/lib/hooks/useActivateExample.js +35 -1
  239. package/lib/hooks/useActiveWithFallback.js +12 -1
  240. package/lib/hooks/useContentItems.js +10 -1
  241. package/lib/hooks/useLicense.js +17 -1
  242. package/lib/hooks/usePerformanceMetrics.js +26 -1
  243. package/lib/hooks/useRouter.js +17 -1
  244. package/lib/hooks/useTelemetry.js +5 -1
  245. package/lib/hooks/useTranslate.js +6 -1
  246. package/lib/hooks/useUppercase2LowercaseRedirect.js +12 -1
  247. package/lib/icons/CSharpIcon/CSharpIcon.js +7 -1
  248. package/lib/icons/CSharpIcon/index.js +2 -1
  249. package/lib/icons/CurlIcon/CurlIcon.js +8 -2
  250. package/lib/icons/CurlIcon/index.js +2 -1
  251. package/lib/icons/GOIcon/GOIcon.js +7 -1
  252. package/lib/icons/GOIcon/index.js +2 -1
  253. package/lib/icons/JavaIcon/JavaIcon.js +7 -1
  254. package/lib/icons/JavaIcon/index.js +2 -1
  255. package/lib/icons/JavaScriptIcon/JavaScriptIcon.js +7 -1
  256. package/lib/icons/JavaScriptIcon/index.js +2 -1
  257. package/lib/icons/NodeJSIcon/NodeJSIcon.js +7 -1
  258. package/lib/icons/NodeJSIcon/index.js +2 -1
  259. package/lib/icons/PHPIcon/PHPIcon.js +7 -1
  260. package/lib/icons/PHPIcon/index.js +2 -1
  261. package/lib/icons/PayloadIcon/PayloadIcon.js +7 -1
  262. package/lib/icons/PayloadIcon/index.js +2 -1
  263. package/lib/icons/PythonIcon/PythonIcon.js +7 -1
  264. package/lib/icons/PythonIcon/index.js +2 -1
  265. package/lib/icons/RIcon/RIcon.js +7 -1
  266. package/lib/icons/RIcon/index.js +2 -1
  267. package/lib/icons/RubyIcon/RubyIcon.js +7 -1
  268. package/lib/icons/RubyIcon/index.js +2 -1
  269. package/lib/index.js +49 -1
  270. package/lib/jotai/app.js +113 -1
  271. package/lib/jotai/operation.js +28 -1
  272. package/lib/jotai/replay.js +5 -1
  273. package/lib/jotai/store.js +8 -1
  274. package/lib/jotai/use-write-atom.js +9 -1
  275. package/lib/models/callback.js +28 -1
  276. package/lib/models/code-sample-options.js +2 -0
  277. package/lib/models/example.js +17 -1
  278. package/lib/models/field.js +109 -1
  279. package/lib/models/group.js +38 -1
  280. package/lib/models/index.js +14 -1
  281. package/lib/models/mediaContent.js +26 -1
  282. package/lib/models/mediaType.js +153 -1
  283. package/lib/models/operation.js +166 -1
  284. package/lib/models/request.js +25 -1
  285. package/lib/models/response.js +46 -1
  286. package/lib/models/schema.js +474 -2
  287. package/lib/models/security.js +84 -1
  288. package/lib/models/tab.js +2 -0
  289. package/lib/models/types.js +2 -0
  290. package/lib/services/OpenAPIParser.js +321 -1
  291. package/lib/services/check.js +104 -1
  292. package/lib/services/code-samples/constants.js +16 -1
  293. package/lib/services/code-samples/generator.js +540 -1
  294. package/lib/services/code-samples/httpsnippet/helpers/code-builder.d.ts +5 -1
  295. package/lib/services/code-samples/httpsnippet/helpers/code-builder.js +252 -3
  296. package/lib/services/code-samples/httpsnippet/helpers/code-helpers.d.ts +2 -2
  297. package/lib/services/code-samples/httpsnippet/helpers/code-helpers.js +90 -2
  298. package/lib/services/code-samples/httpsnippet/helpers/constants.js +28 -1
  299. package/lib/services/code-samples/httpsnippet/helpers/lodash-int.js +173 -1
  300. package/lib/services/code-samples/httpsnippet/helpers/mocks/code-helpers-mock.js +76 -37
  301. package/lib/services/code-samples/httpsnippet/helpers/reducer.js +16 -1
  302. package/lib/services/code-samples/httpsnippet/helpers/shell.js +20 -1
  303. package/lib/services/code-samples/httpsnippet/helpers/string-utility.js +19 -1
  304. package/lib/services/code-samples/httpsnippet/index.js +166 -1
  305. package/lib/services/code-samples/httpsnippet/targets/__mocks__/mock.js +2340 -146
  306. package/lib/services/code-samples/httpsnippet/targets/csharp/httpclient.js +227 -2
  307. package/lib/services/code-samples/httpsnippet/targets/csharp/index.js +11 -1
  308. package/lib/services/code-samples/httpsnippet/targets/csharpNewtonsoft/httpclient.js +185 -2
  309. package/lib/services/code-samples/httpsnippet/targets/csharpNewtonsoft/index.js +11 -1
  310. package/lib/services/code-samples/httpsnippet/targets/go/index.js +11 -1
  311. package/lib/services/code-samples/httpsnippet/targets/go/native.js +222 -3
  312. package/lib/services/code-samples/httpsnippet/targets/index.js +28 -1
  313. package/lib/services/code-samples/httpsnippet/targets/java/httpclient.js +184 -3
  314. package/lib/services/code-samples/httpsnippet/targets/java/index.js +11 -1
  315. package/lib/services/code-samples/httpsnippet/targets/java8/apachehttp.js +223 -2
  316. package/lib/services/code-samples/httpsnippet/targets/java8/index.js +11 -1
  317. package/lib/services/code-samples/httpsnippet/targets/javascript/fetch.js +147 -1
  318. package/lib/services/code-samples/httpsnippet/targets/javascript/index.js +11 -1
  319. package/lib/services/code-samples/httpsnippet/targets/node/fetch.js +199 -1
  320. package/lib/services/code-samples/httpsnippet/targets/node/index.js +11 -1
  321. package/lib/services/code-samples/httpsnippet/targets/php/curl.js +203 -5
  322. package/lib/services/code-samples/httpsnippet/targets/php/index.js +11 -1
  323. package/lib/services/code-samples/httpsnippet/targets/php/types.js +2 -0
  324. package/lib/services/code-samples/httpsnippet/targets/php/utils.js +106 -5
  325. package/lib/services/code-samples/httpsnippet/targets/python/index.js +11 -1
  326. package/lib/services/code-samples/httpsnippet/targets/python/requests.js +185 -6
  327. package/lib/services/code-samples/httpsnippet/targets/r/httr.js +111 -1
  328. package/lib/services/code-samples/httpsnippet/targets/r/index.js +11 -1
  329. package/lib/services/code-samples/httpsnippet/targets/r/utils.js +18 -6
  330. package/lib/services/code-samples/httpsnippet/targets/ruby/index.js +11 -1
  331. package/lib/services/code-samples/httpsnippet/targets/ruby/native.js +169 -1
  332. package/lib/services/code-samples/httpsnippet/targets/shell/curl.js +94 -6
  333. package/lib/services/code-samples/httpsnippet/targets/shell/index.js +11 -1
  334. package/lib/services/code-samples/index.js +3 -1
  335. package/lib/services/code-samples/types.js +2 -0
  336. package/lib/services/config-options/helpers.js +49 -1
  337. package/lib/services/config-options/index.js +3 -1
  338. package/lib/services/config-options/normalizeOptions.js +83 -1
  339. package/lib/services/config-options/types.js +2 -0
  340. package/lib/services/history/helpers.js +63 -1
  341. package/lib/services/history/index.js +2 -1
  342. package/lib/services/index.js +9 -1
  343. package/lib/services/menu/builder.js +47 -1
  344. package/lib/services/menu/index.js +2 -1
  345. package/lib/services/menu/markdown.js +93 -1
  346. package/lib/services/menu/operation.js +50 -1
  347. package/lib/services/menu/tags.js +166 -1
  348. package/lib/services/types.d.ts +0 -3
  349. package/lib/services/types.js +2 -0
  350. package/lib/services/utils.js +83 -1
  351. package/lib/standalone.js +68 -1
  352. package/lib/styled-components.js +6 -1
  353. package/lib/types/app.js +2 -0
  354. package/lib/types/index.js +4 -1
  355. package/lib/types/open-api.d.ts +1 -0
  356. package/lib/types/open-api.js +2 -0
  357. package/lib/types/security.js +2 -0
  358. package/lib/utils/JsonPointer.js +84 -1
  359. package/lib/utils/areArraysEqual.js +4 -1
  360. package/lib/utils/argValuesHelpers.js +35 -1
  361. package/lib/utils/compose.js +2 -1
  362. package/lib/utils/configure-helpers.js +223 -1
  363. package/lib/utils/convertSwagger2OpenAPI.js +14 -1
  364. package/lib/utils/cookies.js +73 -1
  365. package/lib/utils/debounce.js +22 -1
  366. package/lib/utils/debug.js +11 -1
  367. package/lib/utils/dom.js +65 -1
  368. package/lib/utils/environments.js +13 -1
  369. package/lib/utils/helpers.js +222 -12
  370. package/lib/utils/index.js +25 -1
  371. package/lib/utils/isMobile.js +13 -1
  372. package/lib/utils/loadAndBundleSpec.js +32 -1
  373. package/lib/utils/local-storage.js +12 -1
  374. package/lib/utils/object.js +31 -1
  375. package/lib/utils/openapi.js +592 -1
  376. package/lib/utils/parameters.js +13 -1
  377. package/lib/utils/path.js +22 -1
  378. package/lib/utils/queryString.js +60 -1
  379. package/lib/utils/replaceVariables.js +14 -1
  380. package/lib/utils/saveTextBeforeHeading.js +35 -1
  381. package/lib/utils/security-details.js +49 -1
  382. package/lib/utils/session-storage.js +12 -1
  383. package/lib/utils/simplifyAstStructure.js +22 -1
  384. package/lib/utils/sort.js +21 -1
  385. package/lib/utils/string.js +65 -1
  386. package/lib/utils/telemetry.js +7 -1
  387. package/lib/utils/test-utils.js +26 -1
  388. package/lib/utils/theme-helpers.js +24 -3
  389. package/lib/utils/url.js +38 -1
  390. package/package.json +5 -5
@@ -1 +1,26 @@
1
- import{useEffect as l,useRef as i}from"react";import{useLocation as s}from"react-router-dom";import{removeLeadingSlash as n}from"@redocly/theme/core/openapi";import{getElementById as a}from"../Content/useAutoScroll.js";function m(r,c){const e=i(null),o=s(),f=n(o.pathname.replace(c,""));return l(()=>{if(e.current&&r.href&&n(r.href)===f&&(typeof e?.current?.scrollIntoView=="function"&&e.current.scrollIntoView(),o.hash)){const t=a(o.hash.replace("#","").toLowerCase());t&&t.scrollIntoView()}},[]),e}var w=m;export{w as default};
1
+ import { useEffect, useRef } from 'react';
2
+ import { useLocation } from 'react-router-dom';
3
+ import { removeLeadingSlash } from '@redocly/theme/core/openapi';
4
+ import { getElementById } from '../Content/useAutoScroll.js';
5
+ function useScrollOnRender(item, routingBasePath) {
6
+ const ref = useRef(null);
7
+ const location = useLocation();
8
+ const pathname = removeLeadingSlash(location.pathname.replace(routingBasePath, ''));
9
+ useEffect(() => {
10
+ if (ref.current && item.href && removeLeadingSlash(item.href) === pathname) {
11
+ if (typeof ref?.current?.scrollIntoView === 'function') {
12
+ ref.current.scrollIntoView();
13
+ }
14
+ if (location.hash) {
15
+ const element = getElementById(location.hash.replace('#', '').toLowerCase());
16
+ if (element) {
17
+ element.scrollIntoView();
18
+ }
19
+ }
20
+ }
21
+ // eslint-disable-next-line react-hooks/exhaustive-deps
22
+ }, []);
23
+ return ref;
24
+ }
25
+ export default useScrollOnRender;
26
+ //# sourceMappingURL=useScrollOnRender.js.map
@@ -1,5 +1,30 @@
1
- import{jsx as r,jsxs as l}from"react/jsx-runtime";import{memo as p,useMemo as c}from"react";import{strikethroughText as d}from"../../utils/index.js";import{SchemaSelection as a}from"../common/SchemaSelection/SchemaSelection.js";import{SelectionTitle as f}from"../common/index.js";import{styled as u}from"../../styled-components.js";function x({activeOneOfIdx:t,parent:e,onChange:n,translate:o}){const m=c(()=>(e.oneOf||[]).map((i,s)=>({label:i.schema.deprecated?`${d(i.title)} (${o("openapi.badges.deprecated","deprecated").toLowerCase()}`:i.title,value:s})),[e.oneOf,o]);return e.oneOf===void 0?null:l(h,{children:[r(f,{children:o("openapi.discriminator","Discriminator")}),r(a,{options:m,pointer:e.operationPointer,onChange:n,schema:e,defaultOneOfIdx:t})]})}const y=p(x),h=u.div`
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { memo, useMemo } from 'react';
3
+ import { strikethroughText } from '../../utils/index.js';
4
+ import { SchemaSelection } from '../common/SchemaSelection/SchemaSelection.js';
5
+ import { SelectionTitle } from '../common/index.js';
6
+ import { styled } from '../../styled-components.js';
7
+ function DiscriminatorDropdownComponent({ activeOneOfIdx, parent, onChange, translate, }) {
8
+ const options = useMemo(() => {
9
+ return (parent.oneOf || []).map((subSchema, idx) => {
10
+ const label = subSchema.schema.deprecated
11
+ ? `${strikethroughText(subSchema.title)} (${translate('openapi.badges.deprecated', 'deprecated').toLowerCase()}`
12
+ : subSchema.title;
13
+ return {
14
+ label,
15
+ value: idx,
16
+ };
17
+ });
18
+ }, [parent.oneOf, translate]);
19
+ if (parent.oneOf === undefined) {
20
+ return null;
21
+ }
22
+ return (_jsxs(Wrapper, { children: [_jsx(SelectionTitle, { children: translate('openapi.discriminator', 'Discriminator') }), _jsx(SchemaSelection, { options: options, pointer: parent.operationPointer, onChange: onChange, schema: parent, defaultOneOfIdx: activeOneOfIdx })] }));
23
+ }
24
+ export const Discriminator = memo(DiscriminatorDropdownComponent);
25
+ const Wrapper = styled.div `
2
26
  display: flex;
3
27
  flex-direction: column;
4
28
  align-items: flex-start;
5
- `;export{y as Discriminator};
29
+ `;
30
+ //# sourceMappingURL=Discriminator.js.map
@@ -1 +1,2 @@
1
- import{Discriminator as o}from"./Discriminator.js";export{o as Discriminator};
1
+ export { Discriminator } from './Discriminator.js';
2
+ //# sourceMappingURL=index.js.map
@@ -1,4 +1,43 @@
1
- import{jsx as o,Fragment as p,jsxs as s}from"react/jsx-runtime";import{memo as f,useCallback as w}from"react";import{useAtomValue as x}from"jotai";import{DownloadIcon as b}from"@redocly/theme/icons/DownloadIcon/DownloadIcon";import{getPathPrefix as u,combineUrls as g}from"@redocly/theme/core/openapi";import{Button as h}from"@redocly/theme/components/Button/Button";import{DocumentIcon as y}from"@redocly/theme/icons/DocumentIcon/DocumentIcon";import{JsonIcon as v}from"@redocly/theme/icons/JsonIcon/JsonIcon";import{FileIcon as j}from"@redocly/theme/icons/FileIcon/FileIcon";import{useDownloadInfo as k}from"./useDownloadInfo.js";import{globalStoreAtom as _}from"../../jotai/store.js";import{useTelemetry as I}from"../../hooks/index.js";import{styled as r}from"../../styled-components.js";function D(){const l=I(),{options:c}=x(_),t=u(),n=k({downloadUrls:c.downloadUrls}),d=w(e=>{switch(e){case"yaml":return o(y,{});case"json":return o(v,{});default:return o(j,{})}},[]);return n?o(U,{children:(n||[]).map(({title:e,url:a,iconType:m})=>{const i=t?g(t,a):a;return s(C,{onClick:()=>l.send({type:"openapi_docs.download_definition.clicked"}),children:[s(F,{children:[d(m),o("a",{href:i,target:"_blank",download:!0,rel:"noreferrer",children:e})]}),o("a",{href:i,target:"_blank",download:!0,rel:"noreferrer",children:o(h,{variant:"text",size:"small",icon:o(b,{})})})]},e)})}):o(p,{})}const G=f(D),C=r.div`
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { memo, useCallback } from 'react';
3
+ import { useAtomValue } from 'jotai';
4
+ import { DownloadIcon } from '@redocly/theme/icons/DownloadIcon/DownloadIcon';
5
+ import { getPathPrefix, combineUrls } from '@redocly/theme/core/openapi';
6
+ import { Button } from '@redocly/theme/components/Button/Button';
7
+ import { DocumentIcon } from '@redocly/theme/icons/DocumentIcon/DocumentIcon';
8
+ import { JsonIcon } from '@redocly/theme/icons/JsonIcon/JsonIcon';
9
+ import { FileIcon } from '@redocly/theme/icons/FileIcon/FileIcon';
10
+ import { useDownloadInfo } from './useDownloadInfo.js';
11
+ import { globalStoreAtom } from '../../jotai/store.js';
12
+ import { useTelemetry } from '../../hooks/index.js';
13
+ import { styled } from '../../styled-components.js';
14
+ function DownloadSpecificationComponent() {
15
+ const telemetry = useTelemetry();
16
+ const { options } = useAtomValue(globalStoreAtom);
17
+ const pathPrefix = getPathPrefix();
18
+ const downloadObjects = useDownloadInfo({
19
+ downloadUrls: options.downloadUrls,
20
+ });
21
+ const renderIcon = useCallback((iconType) => {
22
+ switch (iconType) {
23
+ case 'yaml':
24
+ return _jsx(DocumentIcon, {});
25
+ case 'json':
26
+ return _jsx(JsonIcon, {});
27
+ default:
28
+ return _jsx(FileIcon, {});
29
+ }
30
+ }, []);
31
+ if (!downloadObjects) {
32
+ return _jsx(_Fragment, {});
33
+ }
34
+ return (_jsx(Wrapper, { children: (downloadObjects || []).map(({ title, url, iconType }) => {
35
+ const downloadUrl = pathPrefix ? combineUrls(pathPrefix, url) : url;
36
+ return (_jsxs(Card, { onClick: () => telemetry.send({ type: 'openapi_docs.download_definition.clicked' }), children: [_jsxs(FileName, { children: [renderIcon(iconType), _jsx("a", { href: downloadUrl, target: "_blank", download: true, rel: "noreferrer", children: title })] }), _jsx("a", { href: downloadUrl, target: "_blank", download: true, rel: "noreferrer", children: _jsx(Button, { variant: "text", size: "small", icon: _jsx(DownloadIcon, {}) }) })] }, title));
37
+ }) }));
38
+ }
39
+ export const DownloadSpecification = memo(DownloadSpecificationComponent);
40
+ const Card = styled.div `
2
41
  display: flex;
3
42
  align-items: baseline;
4
43
  justify-content: space-between;
@@ -10,7 +49,8 @@ import{jsx as o,Fragment as p,jsxs as s}from"react/jsx-runtime";import{memo as f
10
49
  padding-bottom: 0px;
11
50
  border-bottom: none;
12
51
  }
13
- `,F=r.span`
52
+ `;
53
+ const FileName = styled.span `
14
54
  display: flex;
15
55
  width: calc(100% - 25px);
16
56
  gap: var(--spacing-xs);
@@ -28,7 +68,8 @@ import{jsx as o,Fragment as p,jsxs as s}from"react/jsx-runtime";import{memo as f
28
68
  overflow: hidden;
29
69
  white-space: nowrap;
30
70
  }
31
- `,U=r.div`
71
+ `;
72
+ const Wrapper = styled.div `
32
73
  display: flex;
33
74
  align-items: center;
34
75
  align-self: flex-start;
@@ -36,4 +77,5 @@ import{jsx as o,Fragment as p,jsxs as s}from"react/jsx-runtime";import{memo as f
36
77
  flex-direction: column;
37
78
  gap: var(--spacing-sm);
38
79
  font-size: var(--font-size-base);
39
- `;export{G as DownloadSpecification};
80
+ `;
81
+ //# sourceMappingURL=DownloadSpecification.js.map
@@ -1 +1,2 @@
1
- import{DownloadSpecification as a}from"./DownloadSpecification.js";export{a as DownloadSpecification};
1
+ export { DownloadSpecification } from './DownloadSpecification.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -1 +1,42 @@
1
- import{useMemo as r}from"react";const p=({downloadUrls:n,defaultFileName:i})=>r(()=>{if(n)return n.map(({title:e,url:t})=>({url:t,title:e||o(t,i||"openapi.yaml"),iconType:s(t)}))},[n,i]);function o(n,i){const e=n.split("?")[0].split(/[\\\/]/).pop();return!e||!e.includes("yaml")&&!e.includes("json")?i:e}function s(n,i){const e=i||n.split("?")[0].split(/[\\\/]/).pop();return e?e.includes("yaml")?"yaml":e.includes("json")?"json":"file":"file"}export{p as useDownloadInfo};
1
+ import { useMemo } from 'react';
2
+ export const useDownloadInfo = ({ downloadUrls, defaultFileName, }) => {
3
+ return useMemo(() => {
4
+ if (downloadUrls) {
5
+ return downloadUrls.map(({ title, url }) => ({
6
+ url,
7
+ title: title || getFileNameFromUrl(url, defaultFileName || 'openapi.yaml'),
8
+ iconType: getIconTypeFromUrl(url),
9
+ }));
10
+ }
11
+ }, [downloadUrls, defaultFileName]);
12
+ };
13
+ function getFileNameFromUrl(url, defaultValue) {
14
+ const filename = url
15
+ .split('?')[0]
16
+ .split(/[\\\/]/) // handle backslash for Windows system
17
+ .pop();
18
+ if (!filename || (!filename.includes('yaml') && !filename.includes('json'))) {
19
+ return defaultValue;
20
+ }
21
+ else {
22
+ return filename;
23
+ }
24
+ }
25
+ function getIconTypeFromUrl(url, title) {
26
+ const filename = title ||
27
+ url
28
+ .split('?')[0]
29
+ .split(/[\\\/]/) // handle backslash for Windows system
30
+ .pop();
31
+ if (!filename) {
32
+ return 'file';
33
+ }
34
+ if (filename.includes('yaml')) {
35
+ return 'yaml';
36
+ }
37
+ else if (filename.includes('json')) {
38
+ return 'json';
39
+ }
40
+ return 'file';
41
+ }
42
+ //# sourceMappingURL=useDownloadInfo.js.map
@@ -1,4 +1,24 @@
1
- import{jsx as r,jsxs as e,Fragment as n}from"react/jsx-runtime";import{Children as s,Component as i}from"react";import{styled as o}from"../../styled-components.js";const d=o.div`
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { Children, Component } from 'react';
3
+ import { styled } from '../../styled-components.js';
4
+ const ErrorWrapper = styled.div `
2
5
  padding: 20px;
3
6
  color: red;
4
- `;class h extends i{constructor(t){super(t),this.state={error:void 0}}componentDidCatch(t){return this.setState({error:t}),!1}render(){return this.state.error?e(d,{children:[r("h1",{children:"Something went wrong..."}),e("small",{children:[" ",this.state.error.message," "]}),r("p",{children:e("details",{children:[r("summary",{children:"Stack trace"}),r("pre",{children:this.state.error.stack})]})}),typeof __REDOC_VERSION__<"u"?e(n,{children:[e("small",{children:[" References docs version: ",__REDOC_VERSION__]})," ",r("br",{})]}):null,typeof __REDOC_REVISION__<"u"?e("small",{children:[" Commit: ",__REDOC_REVISION__]}):null]}):r(n,{children:s.only(this.props.children)})}}export{h as ErrorBoundary};
7
+ `;
8
+ export class ErrorBoundary extends Component {
9
+ constructor(props) {
10
+ super(props);
11
+ this.state = { error: undefined };
12
+ }
13
+ componentDidCatch(error) {
14
+ this.setState({ error });
15
+ return false;
16
+ }
17
+ render() {
18
+ if (this.state.error) {
19
+ return (_jsxs(ErrorWrapper, { children: [_jsx("h1", { children: "Something went wrong..." }), _jsxs("small", { children: [" ", this.state.error.message, " "] }), _jsx("p", { children: _jsxs("details", { children: [_jsx("summary", { children: "Stack trace" }), _jsx("pre", { children: this.state.error.stack })] }) }), typeof __REDOC_VERSION__ !== 'undefined' ? (_jsxs(_Fragment, { children: [_jsxs("small", { children: [" References docs version: ", __REDOC_VERSION__] }), " ", _jsx("br", {})] })) : null, typeof __REDOC_REVISION__ !== 'undefined' ? (_jsxs("small", { children: [" Commit: ", __REDOC_REVISION__] })) : null] }));
20
+ }
21
+ return _jsx(_Fragment, { children: Children.only(this.props.children) });
22
+ }
23
+ }
24
+ //# sourceMappingURL=ErrorBoundary.js.map
@@ -1 +1,2 @@
1
- import{ErrorBoundary as a}from"./ErrorBoundary.js";export{a as ErrorBoundary};
1
+ export { ErrorBoundary } from './ErrorBoundary.js';
2
+ //# sourceMappingURL=index.js.map
@@ -1,3 +1,32 @@
1
- import{jsx as n}from"react/jsx-runtime";import{useAtom as d}from"jotai";import{MaximizeIcon as m}from"@redocly/theme/icons/MaximizeIcon/MaximizeIcon";import{Button as c}from"@redocly/theme/components/Button/Button";import{operationStore as x}from"../../jotai/operation.js";import{useTelemetry as u,useTranslate as f}from"../../hooks/index.js";import{styled as A}from"../../styled-components.js";const k=({operationPointer:a,type:e,onPanelToggle:r})=>{const t=f(),[l,s]=d(x(a)),p=u(),i=()=>{const o=!l[e].expandedAll;p.send({type:"openapi_docs.expand_collapse_all.clicked",payload:{is_expanded:o}}),s({[e]:{expandedAll:o}}),r?.(o,e==="request"?"request":"responses")};return n(g,{icon:n(m,{}),iconPosition:"right",size:"small",variant:"ghost",onClick:i,children:l[e].expandedAll?t("openapi.collapseAll","Collapse all"):t("openapi.expandAll","Expand all")})},g=A(c)`
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useAtom } from 'jotai';
3
+ import { MaximizeIcon } from '@redocly/theme/icons/MaximizeIcon/MaximizeIcon';
4
+ import { Button } from '@redocly/theme/components/Button/Button';
5
+ import { operationStore } from '../../jotai/operation.js';
6
+ import { useTelemetry, useTranslate } from '../../hooks/index.js';
7
+ import { styled } from '../../styled-components.js';
8
+ export const ExpandAllButton = ({ operationPointer, type, onPanelToggle, }) => {
9
+ const translate = useTranslate();
10
+ const [operationState, setOperationState] = useAtom(operationStore(operationPointer));
11
+ const telemetry = useTelemetry();
12
+ const handleToggle = () => {
13
+ const expandedAll = !operationState[type].expandedAll;
14
+ telemetry.send({
15
+ type: 'openapi_docs.expand_collapse_all.clicked',
16
+ payload: { isExpanded: expandedAll },
17
+ });
18
+ setOperationState({
19
+ [type]: {
20
+ expandedAll,
21
+ },
22
+ });
23
+ onPanelToggle?.(expandedAll, type === 'request' ? 'request' : 'responses');
24
+ };
25
+ return (_jsx(StyledButton, { icon: _jsx(MaximizeIcon, {}), iconPosition: "right", size: "small", variant: "ghost", onClick: handleToggle, children: operationState[type].expandedAll
26
+ ? translate('openapi.collapseAll', 'Collapse all')
27
+ : translate('openapi.expandAll', 'Expand all') }));
28
+ };
29
+ const StyledButton = styled(Button) `
2
30
  margin-left: auto;
3
- `;export{k as ExpandAllButton};
31
+ `;
32
+ //# sourceMappingURL=ExpandAllButton.js.map
@@ -1 +1,2 @@
1
- import{ExpandAllButton as l}from"./ExpandAllButton.js";export{l as ExpandAllButton};
1
+ export { ExpandAllButton } from './ExpandAllButton.js';
2
+ //# sourceMappingURL=index.js.map
@@ -1,4 +1,18 @@
1
- import{jsx as n}from"react/jsx-runtime";import{memo as i}from"react";import{markdownLinksCss as m}from"@redocly/theme/components/Markdown/styles/links";import{normalizeText as a}from"../../utils/index.js";import{styled as e}from"../../styled-components.js";const l=e.div`
2
- ${m};
3
- ${({compact:r})=>r?"":"margin: var(--spacing-sm) 0 0"}
4
- `;function p({externalDocs:r,compact:o}){if(!r||!r.url)return null;const t=a(r.description);return n(l,{compact:o,"data-testid":"external-documentation",children:n("a",{href:r.url,target:"_blank",rel:"noreferrer","aria-label":t||r.url,children:t||r.url})})}const k=i(p);export{k as ExternalDocumentation};
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { memo } from 'react';
3
+ import { markdownLinksCss } from '@redocly/theme/components/Markdown/styles/links';
4
+ import { normalizeText } from '../../utils/index.js';
5
+ import { styled } from '../../styled-components.js';
6
+ const LinkWrap = styled.div `
7
+ ${markdownLinksCss};
8
+ ${({ compact }) => (!compact ? 'margin: var(--spacing-sm) 0 0' : '')}
9
+ `;
10
+ function ExternalDocumentationComponent({ externalDocs, compact, }) {
11
+ if (!externalDocs || !externalDocs.url) {
12
+ return null;
13
+ }
14
+ const description = normalizeText(externalDocs.description);
15
+ return (_jsx(LinkWrap, { compact: compact, "data-testid": "external-documentation", children: _jsx("a", { href: externalDocs.url, target: "_blank", rel: "noreferrer", "aria-label": description || externalDocs.url, children: description || externalDocs.url }) }));
16
+ }
17
+ export const ExternalDocumentation = memo(ExternalDocumentationComponent);
18
+ //# sourceMappingURL=ExternalDocumentation.js.map
@@ -1 +1,2 @@
1
- import{ExternalDocumentation as e}from"./ExternalDocumentation.js";export{e as ExternalDocumentation};
1
+ export { ExternalDocumentation } from './ExternalDocumentation.js';
2
+ //# sourceMappingURL=index.js.map
@@ -1 +1,21 @@
1
- import{jsx as t}from"react/jsx-runtime";import{useCallback as h,useMemo as s}from"react";import{Dropdown as k}from"@redocly/theme/components/Dropdown/Dropdown";import{DropdownMenu as y}from"@redocly/theme/components/Dropdown/DropdownMenu";import{LanguageItem as D}from"./LanguageItem.js";import{DropdownTriggerButton as x,StyledDropdownMenuItem as A}from"./styled.js";const B=({samples:o,activeTab:n,onChange:e,trigger:l,width:i,withArrow:f=!0,withCheckmark:d=!0,withIcon:c=!0})=>{const m=h(r=>()=>{const u=o.find(({key:a})=>a===r.key);u&&e(u.key)},[e,o]),g=s(()=>o.map(r=>t(A,{$width:i,onAction:m(r),children:t(D,{item:r,active:n===r.key,withCheckmark:d,withIcon:c})},r.key)),[n,m,o,i,d,c]),w=o.find(({key:r})=>r===n),p=l||t(x,{variant:"ghost",children:w?.title});return g.length>1?t(k,{trigger:p,withArrow:f,alignment:"end",children:t(y,{children:g})}):p};export{B as LanguageDropdown};
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useCallback, useMemo } from 'react';
3
+ import { Dropdown } from '@redocly/theme/components/Dropdown/Dropdown';
4
+ import { DropdownMenu } from '@redocly/theme/components/Dropdown/DropdownMenu';
5
+ import { LanguageItem } from './LanguageItem.js';
6
+ import { DropdownTriggerButton, StyledDropdownMenuItem } from './styled.js';
7
+ export const LanguageDropdown = ({ samples, activeTab, onChange, trigger, width, withArrow = true, withCheckmark = true, withIcon = true, }) => {
8
+ const handleAction = useCallback((value) => () => {
9
+ const selectedSample = samples.find(({ key }) => key === value.key);
10
+ if (selectedSample) {
11
+ onChange(selectedSample.key);
12
+ }
13
+ }, [onChange, samples]);
14
+ const items = useMemo(() => samples.map((item) => {
15
+ return (_jsx(StyledDropdownMenuItem, { "$width": width, onAction: handleAction(item), children: _jsx(LanguageItem, { item: item, active: activeTab === item.key, withCheckmark: withCheckmark, withIcon: withIcon }) }, item.key));
16
+ }), [activeTab, handleAction, samples, width, withCheckmark, withIcon]);
17
+ const activeSample = samples.find(({ key }) => key === activeTab);
18
+ const dropdownTrigger = trigger || (_jsx(DropdownTriggerButton, { variant: "ghost", children: activeSample?.title }));
19
+ return items.length > 1 ? (_jsx(Dropdown, { trigger: dropdownTrigger, withArrow: withArrow, alignment: "end", children: _jsx(DropdownMenu, { children: items }) })) : (dropdownTrigger);
20
+ };
21
+ //# sourceMappingURL=LanguageDropdown.js.map
@@ -1 +1,33 @@
1
- import{jsx as o,jsxs as a,Fragment as e}from"react/jsx-runtime";import{CheckmarkIcon as p}from"@redocly/theme/icons/CheckmarkIcon/CheckmarkIcon";import{CurlIcon as f}from"../../icons/CurlIcon/index.js";import{CSharpIcon as n}from"../../icons/CSharpIcon/index.js";import{NodeJSIcon as l}from"../../icons/NodeJSIcon/index.js";import{JavaScriptIcon as I}from"../../icons/JavaScriptIcon/index.js";import{PythonIcon as s}from"../../icons/PythonIcon/index.js";import{RIcon as g}from"../../icons/RIcon/index.js";import{RubyIcon as h}from"../../icons/RubyIcon/index.js";import{PHPIcon as u}from"../../icons/PHPIcon/index.js";import{GOIcon as d}from"../../icons/GOIcon/index.js";import{JavaIcon as m}from"../../icons/JavaIcon/index.js";import{PayloadIcon as P}from"../../icons/PayloadIcon/index.js";import{LanguageIcon as y,LanguageTitle as C,LanguageTitleContainer as J}from"./styled.js";const j={Payload:o(P,{}),curl:o(f,{}),"C#":o(n,{}),"C#+Newtonsoft":o(n,{}),"Node.js":o(l,{}),JavaScript:o(I,{}),Python:o(s,{}),R:o(g,{}),Ruby:o(h,{}),PHP:o(u,{}),Go:o(d,{}),Java:o(m,{}),"Java8+Apache":o(m,{})},A=({item:r,active:t,withCheckmark:c,withIcon:i})=>a(e,{children:[a(J,{children:[i&&o(y,{children:j[r.lang]}),o(C,{active:t,title:r.title,children:r.title})]}),c&&t&&o(p,{})]});export{A as LanguageItem};
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { CheckmarkIcon } from '@redocly/theme/icons/CheckmarkIcon/CheckmarkIcon';
3
+ import { CurlIcon } from '../../icons/CurlIcon/index.js';
4
+ import { CSharpIcon } from '../../icons/CSharpIcon/index.js';
5
+ import { NodeJSIcon } from '../../icons/NodeJSIcon/index.js';
6
+ import { JavaScriptIcon } from '../../icons/JavaScriptIcon/index.js';
7
+ import { PythonIcon } from '../../icons/PythonIcon/index.js';
8
+ import { RIcon } from '../../icons/RIcon/index.js';
9
+ import { RubyIcon } from '../../icons/RubyIcon/index.js';
10
+ import { PHPIcon } from '../../icons/PHPIcon/index.js';
11
+ import { GOIcon } from '../../icons/GOIcon/index.js';
12
+ import { JavaIcon } from '../../icons/JavaIcon/index.js';
13
+ import { PayloadIcon } from '../../icons/PayloadIcon/index.js';
14
+ import { LanguageIcon, LanguageTitle, LanguageTitleContainer } from './styled.js';
15
+ const iconMap = {
16
+ Payload: _jsx(PayloadIcon, {}),
17
+ curl: _jsx(CurlIcon, {}),
18
+ 'C#': _jsx(CSharpIcon, {}),
19
+ 'C#+Newtonsoft': _jsx(CSharpIcon, {}),
20
+ 'Node.js': _jsx(NodeJSIcon, {}),
21
+ JavaScript: _jsx(JavaScriptIcon, {}),
22
+ Python: _jsx(PythonIcon, {}),
23
+ R: _jsx(RIcon, {}),
24
+ Ruby: _jsx(RubyIcon, {}),
25
+ PHP: _jsx(PHPIcon, {}),
26
+ Go: _jsx(GOIcon, {}),
27
+ Java: _jsx(JavaIcon, {}),
28
+ 'Java8+Apache': _jsx(JavaIcon, {}),
29
+ };
30
+ export const LanguageItem = ({ item, active, withCheckmark, withIcon }) => {
31
+ return (_jsxs(_Fragment, { children: [_jsxs(LanguageTitleContainer, { children: [withIcon && _jsx(LanguageIcon, { children: iconMap[item.lang] }), _jsx(LanguageTitle, { active: active, title: item.title, children: item.title })] }), withCheckmark && active && _jsx(CheckmarkIcon, {})] }));
32
+ };
33
+ //# sourceMappingURL=LanguageItem.js.map
@@ -1 +1,93 @@
1
- import{jsx as a,jsxs as I}from"react/jsx-runtime";import{useLayoutEffect as T,useRef as A,useState as y,useCallback as _,memo as j,useMemo as E}from"react";import{useAtomValue as H,useSetAtom as S}from"jotai";import{Button as V}from"@redocly/theme/components/Button/Button";import{OverflowMenuVerticalIcon as W}from"@redocly/theme/icons/OverflowMenuVerticalIcon/OverflowMenuVerticalIcon";import{LanguageDropdown as v}from"./LanguageDropdown.js";import{languageAtom as D,layoutAtom as R}from"../../jotai/app.js";import{LanguageListContainer as M,LanguageListItem as O,Container as z}from"./styled.js";import{LanguageItem as G}from"./LanguageItem.js";import{DROPDOWN_TRIGGER_WIDTH as B,ITEM_WIDTH as L}from"./constants.js";import{LanguageListSkeleton as N}from"../common/Skeleton/LanguageListSkeleton.js";import{useTelemetry as P}from"../../hooks/index.js";function $({languages:o,activeLanguage:t}){const[n,i]=y([]),[s,l]=y([]),u=P(),d=A(null),f=H(R),h=S(D),p=e=>{u.send({type:"openapi_docs.select_language.clicked",payload:{language:e}})},k=e=>{h(e),p(e)},x=e=>{const m=s.findIndex(r=>r.key===e);if(m!==-1){const r=[...s],c=[...n];w(c,r,m),i(c),l(r),p(e),h(e)}},g=_(()=>{const e=d?.current?.offsetWidth;if(!e)return;const{newVisibleItems:m,newHiddenItems:r}=q(e,[...o]),c=r.findIndex(b=>b.key===t);c!==-1&&w(m,r,c),i(m),l(r)},[t,o]);T(()=>(g(),window.addEventListener("resize",g),()=>{window.removeEventListener("resize",g)}),[f,t]);const C=E(()=>n.length>=5||s.length?"space-between":"start",[s.length,n.length]);return I(z,{ref:d,children:[I(M,{$justifyContent:C,children:[!n.length&&a(N,{}),n.map(e=>a(O,{onClick:()=>k(e.key),active:t===e.key,children:a(G,{item:e,withIcon:!0})},e.key))]}),s.length?a(v,{activeTab:t,samples:s,onChange:x,trigger:a(V,{icon:a(W,{}),variant:"text",style:{height:"100%"}}),withArrow:!1,withCheckmark:!1,width:156}):null]})}const se=j($);function q(o,t){let n=0;const i=[],s=[];return t.forEach((l,u)=>{const f=u===t.length-1&&s.length===0?0:B;o&&n+L+f<=o?(i.push(l),n+=L):s.push(l)}),{newVisibleItems:i,newHiddenItems:s}}function w(o,t,n){const i=o[o.length-1];i&&(o[o.length-1]=t[n],t[n]=i)}export{se as LanguageList};
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useLayoutEffect, useRef, useState, useCallback, memo, useMemo } from 'react';
3
+ import { useAtomValue, useSetAtom } from 'jotai';
4
+ import { Button } from '@redocly/theme/components/Button/Button';
5
+ import { OverflowMenuVerticalIcon } from '@redocly/theme/icons/OverflowMenuVerticalIcon/OverflowMenuVerticalIcon';
6
+ import { LanguageDropdown } from './LanguageDropdown.js';
7
+ import { languageAtom, layoutAtom } from '../../jotai/app.js';
8
+ import { LanguageListContainer, LanguageListItem, Container } from './styled.js';
9
+ import { LanguageItem } from './LanguageItem.js';
10
+ import { DROPDOWN_TRIGGER_WIDTH, ITEM_WIDTH } from './constants.js';
11
+ import { LanguageListSkeleton } from '../common/Skeleton/LanguageListSkeleton.js';
12
+ import { useTelemetry } from '../../hooks/index.js';
13
+ function LanguageListComponent({ languages, activeLanguage }) {
14
+ const [visibleItems, setVisibleItems] = useState([]);
15
+ const [hiddenItems, setHiddenItems] = useState([]);
16
+ const telemetry = useTelemetry();
17
+ const containerRef = useRef(null);
18
+ const layout = useAtomValue(layoutAtom);
19
+ const setLanguage = useSetAtom(languageAtom);
20
+ const setLanguageSendTelemetry = (selectedItem) => {
21
+ telemetry.send({
22
+ type: 'openapi_docs.select_language.clicked',
23
+ payload: { language: selectedItem },
24
+ });
25
+ };
26
+ const onSelectLanguage = (selectedItem) => {
27
+ setLanguage(selectedItem);
28
+ setLanguageSendTelemetry(selectedItem);
29
+ };
30
+ const handleSetActiveLanguage = (selectedItem) => {
31
+ const selectedItemIndex = hiddenItems.findIndex((item) => item.key === selectedItem);
32
+ if (selectedItemIndex !== -1) {
33
+ const newHiddenItems = [...hiddenItems];
34
+ const newVisibleItems = [...visibleItems];
35
+ swapItems(newVisibleItems, newHiddenItems, selectedItemIndex);
36
+ setVisibleItems(newVisibleItems);
37
+ setHiddenItems(newHiddenItems);
38
+ setLanguageSendTelemetry(selectedItem);
39
+ setLanguage(selectedItem);
40
+ }
41
+ };
42
+ const updateItemsVisibility = useCallback(() => {
43
+ const containerWidth = containerRef?.current?.offsetWidth;
44
+ if (!containerWidth)
45
+ return;
46
+ const { newVisibleItems, newHiddenItems } = calculateVisibleAndHiddenItems(containerWidth, [
47
+ ...languages,
48
+ ]);
49
+ const selectedItemIndex = newHiddenItems.findIndex((item) => item.key === activeLanguage);
50
+ if (selectedItemIndex !== -1) {
51
+ swapItems(newVisibleItems, newHiddenItems, selectedItemIndex);
52
+ }
53
+ setVisibleItems(newVisibleItems);
54
+ setHiddenItems(newHiddenItems);
55
+ }, [activeLanguage, languages]);
56
+ useLayoutEffect(() => {
57
+ updateItemsVisibility();
58
+ window.addEventListener('resize', updateItemsVisibility);
59
+ return () => {
60
+ window.removeEventListener('resize', updateItemsVisibility);
61
+ };
62
+ // eslint-disable-next-line react-hooks/exhaustive-deps
63
+ }, [layout, activeLanguage]);
64
+ const justifyContent = useMemo(() => (visibleItems.length >= 5 || hiddenItems.length ? 'space-between' : 'start'), [hiddenItems.length, visibleItems.length]);
65
+ return (_jsxs(Container, { ref: containerRef, children: [_jsxs(LanguageListContainer, { "$justifyContent": justifyContent, children: [!visibleItems.length && _jsx(LanguageListSkeleton, {}), visibleItems.map((item) => (_jsx(LanguageListItem, { onClick: () => onSelectLanguage(item.key), active: activeLanguage === item.key, children: _jsx(LanguageItem, { item: item, withIcon: true }) }, item.key)))] }), hiddenItems.length ? (_jsx(LanguageDropdown, { activeTab: activeLanguage, samples: hiddenItems, onChange: handleSetActiveLanguage, trigger: _jsx(Button, { icon: _jsx(OverflowMenuVerticalIcon, {}), variant: "text", style: { height: '100%' } }), withArrow: false, withCheckmark: false, width: 156 })) : null] }));
66
+ }
67
+ export const LanguageList = memo(LanguageListComponent);
68
+ function calculateVisibleAndHiddenItems(containerWidth, items) {
69
+ let totalWidth = 0;
70
+ const newVisibleItems = [];
71
+ const newHiddenItems = [];
72
+ items.forEach((item, idx) => {
73
+ const isLastItem = idx === items.length - 1;
74
+ // We won't display dropdown if the last item will fit in the container
75
+ const dropdownTriggerWidth = isLastItem && newHiddenItems.length === 0 ? 0 : DROPDOWN_TRIGGER_WIDTH;
76
+ if (containerWidth && totalWidth + ITEM_WIDTH + dropdownTriggerWidth <= containerWidth) {
77
+ newVisibleItems.push(item);
78
+ totalWidth += ITEM_WIDTH;
79
+ }
80
+ else {
81
+ newHiddenItems.push(item);
82
+ }
83
+ });
84
+ return { newVisibleItems, newHiddenItems };
85
+ }
86
+ function swapItems(newVisibleItems, newHiddenItems, selectedItemIndex) {
87
+ const lastVisibleItems = newVisibleItems[newVisibleItems.length - 1];
88
+ if (lastVisibleItems) {
89
+ newVisibleItems[newVisibleItems.length - 1] = newHiddenItems[selectedItemIndex];
90
+ newHiddenItems[selectedItemIndex] = lastVisibleItems;
91
+ }
92
+ }
93
+ //# sourceMappingURL=LanguageList.js.map
@@ -1 +1,23 @@
1
- import{jsx as a}from"react/jsx-runtime";import{render as c,fireEvent as s,screen as g}from"@testing-library/react";import{LanguageDropdown as l}from"../LanguageDropdown";const e=[{key:"js",title:"JS",lang:"js"},{key:"node.js",title:"Node.JS",lang:"nodejs"}],r=e[0].key,n=jest.fn();describe("LanguageDropdown",()=>{test("LanguageDropdown renders correctly",()=>{const{getAllByText:t}=c(a(l,{samples:e,activeTab:r,onChange:n}));expect(t(e[0].title)[0]).toBeInTheDocument()}),test("LanguageDropdown handles onChange correctly",()=>{const{getAllByText:t}=c(a(l,{samples:e,activeTab:r,onChange:n}));s.click(g.getAllByText(e[0].title)[0]);const o=e[1];s.click(t(o.title)[0]),expect(n).toHaveBeenCalledWith(o.key)})});
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { render, fireEvent, screen } from '@testing-library/react';
3
+ import { LanguageDropdown } from '../LanguageDropdown';
4
+ const mockSamples = [
5
+ { key: 'js', title: 'JS', lang: 'js' },
6
+ { key: 'node.js', title: 'Node.JS', lang: 'nodejs' },
7
+ ];
8
+ const mockActiveTab = mockSamples[0].key;
9
+ const mockOnChange = jest.fn();
10
+ describe('LanguageDropdown', () => {
11
+ test('LanguageDropdown renders correctly', () => {
12
+ const { getAllByText } = render(_jsx(LanguageDropdown, { samples: mockSamples, activeTab: mockActiveTab, onChange: mockOnChange }));
13
+ expect(getAllByText(mockSamples[0].title)[0]).toBeInTheDocument();
14
+ });
15
+ test('LanguageDropdown handles onChange correctly', () => {
16
+ const { getAllByText } = render(_jsx(LanguageDropdown, { samples: mockSamples, activeTab: mockActiveTab, onChange: mockOnChange }));
17
+ fireEvent.click(screen.getAllByText(mockSamples[0].title)[0]);
18
+ const otherLanguage = mockSamples[1];
19
+ fireEvent.click(getAllByText(otherLanguage.title)[0]);
20
+ expect(mockOnChange).toHaveBeenCalledWith(otherLanguage.key);
21
+ });
22
+ });
23
+ //# sourceMappingURL=LanguageDropdown.test.js.map
@@ -1 +1,3 @@
1
- const o=78,t=32;export{t as DROPDOWN_TRIGGER_WIDTH,o as ITEM_WIDTH};
1
+ export const ITEM_WIDTH = 78;
2
+ export const DROPDOWN_TRIGGER_WIDTH = 32;
3
+ //# sourceMappingURL=constants.js.map
@@ -1 +1,4 @@
1
- import{LanguageDropdown as r}from"./LanguageDropdown.js";import{LanguageList as g}from"./LanguageList.js";import{LanguageItem as m}from"./LanguageItem.js";export{r as LanguageDropdown,m as LanguageItem,g as LanguageList};
1
+ export { LanguageDropdown } from './LanguageDropdown.js';
2
+ export { LanguageList } from './LanguageList.js';
3
+ export { LanguageItem } from './LanguageItem.js';
4
+ //# sourceMappingURL=index.js.map
@@ -1,8 +1,14 @@
1
- import{css as i}from"styled-components";import{Button as r}from"@redocly/theme/components/Button/Button";import{DropdownMenuItem as n}from"@redocly/theme/components/Dropdown/DropdownMenuItem";import{ITEM_WIDTH as o}from"./constants.js";import{styled as t}from"../../styled-components.js";const d=t.span`
1
+ import { css } from 'styled-components';
2
+ import { Button } from '@redocly/theme/components/Button/Button';
3
+ import { DropdownMenuItem } from '@redocly/theme/components/Dropdown/DropdownMenuItem';
4
+ import { ITEM_WIDTH } from './constants.js';
5
+ import { styled } from '../../styled-components.js';
6
+ export const Container = styled.span `
2
7
  display: flex;
3
8
  justify-content: space-between;
4
9
  align-items: center;
5
- `,g=t.span`
10
+ `;
11
+ export const LanguageTitle = styled.span `
6
12
  max-width: 150px;
7
13
  text-overflow: ellipsis;
8
14
  overflow: hidden;
@@ -10,15 +16,17 @@ import{css as i}from"styled-components";import{Button as r}from"@redocly/theme/c
10
16
  padding: 0 var(--spacing-xxs);
11
17
  font-size: var(--font-size-base);
12
18
  line-height: var(--line-height-base);
13
- font-weight: ${({active:e})=>e?"var(--font-weight-medium)":"var(--font-weight-regular)"};
14
- `,x=t.span`
19
+ font-weight: ${({ active }) => active ? 'var(--font-weight-medium)' : 'var(--font-weight-regular)'};
20
+ `;
21
+ export const LanguageTitleContainer = styled.span `
15
22
  width: 100%;
16
23
  display: inherit;
17
24
  gap: inherit;
18
25
  flex-direction: inherit;
19
26
  justify-content: inherit;
20
27
  align-items: inherit;
21
- `,f=t.span`
28
+ `;
29
+ export const LanguageIcon = styled.span `
22
30
  width: 24px;
23
31
  height: 24px;
24
32
  display: flex;
@@ -26,15 +34,17 @@ import{css as i}from"styled-components";import{Button as r}from"@redocly/theme/c
26
34
  justify-content: center;
27
35
  flex-shrink: 0;
28
36
  overflow: hidden;
29
- `,h=t.div`
37
+ `;
38
+ export const LanguageListContainer = styled.div `
30
39
  display: flex;
31
- justify-content: ${({$justifyContent:e="start"})=>e};
40
+ justify-content: ${({ $justifyContent = 'start' }) => $justifyContent};
32
41
  align-items: center;
33
42
  width: 100%;
34
- `,u=t.button`
43
+ `;
44
+ export const LanguageListItem = styled.button `
35
45
  background: none;
36
46
  border: none;
37
- width: ${o}px;
47
+ width: ${ITEM_WIDTH}px;
38
48
  flex-shrink: 0;
39
49
  display: flex;
40
50
  align-items: center;
@@ -42,7 +52,7 @@ import{css as i}from"styled-components";import{Button as r}from"@redocly/theme/c
42
52
  flex-direction: column;
43
53
  gap: calc(var(--spacing-unit) * 0.5);
44
54
  padding: var(--spacing-xs) 0;
45
- color: ${({active:e})=>e?"var(--text-color-primary)":"var(--text-color-description)"};
55
+ color: ${({ active }) => active ? 'var(--text-color-primary)' : 'var(--text-color-description)'};
46
56
  border-radius: var(--border-radius);
47
57
  text-align: center;
48
58
  position: relative;
@@ -51,7 +61,8 @@ import{css as i}from"styled-components";import{Button as r}from"@redocly/theme/c
51
61
  color: var(--text-color-primary);
52
62
  }
53
63
 
54
- ${({active:e})=>e&&i`
64
+ ${({ active }) => active &&
65
+ css `
55
66
  &::before {
56
67
  position: absolute;
57
68
  top: -21px;
@@ -62,20 +73,23 @@ import{css as i}from"styled-components";import{Button as r}from"@redocly/theme/c
62
73
  border-bottom-right-radius: calc(var(--border-radius) / 2);
63
74
  }
64
75
  `}
65
- `,m=t(n)`
76
+ `;
77
+ export const StyledDropdownMenuItem = styled(DropdownMenuItem) `
66
78
  display: flex;
67
79
  justify-content: space-between;
68
80
  align-items: center;
69
81
  gap: var(--spacing-xs);
70
82
  padding: calc(var(--spacing-unit) * 1.5) var(--spacing-xs) calc(var(--spacing-unit) * 1.5)
71
83
  var(--spacing-sm);
72
- width: ${({$width:e=204})=>e}px;
84
+ width: ${({ $width = 204 }) => $width}px;
73
85
  fill: var(--menu-content-color-active);
74
- `,v=t(r)`
86
+ `;
87
+ export const DropdownTriggerButton = styled(Button) `
75
88
  display: inline-flex;
76
89
 
77
90
  line-height: var(--line-height-base);
78
91
  font-size: var(--font-size-base);
79
92
  font-weight: var(--font-weight-medium);
80
93
  cursor: pointer;
81
- `;export{d as Container,v as DropdownTriggerButton,f as LanguageIcon,h as LanguageListContainer,u as LanguageListItem,g as LanguageTitle,x as LanguageTitleContainer,m as StyledDropdownMenuItem};
94
+ `;
95
+ //# sourceMappingURL=styled.js.map