@redocly/openapi-docs 3.12.0 → 3.12.2
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.
- package/dist/redocly-openapi-docs.min.js +753 -750
- package/lib/components/ApiInfo/ApiInfo.js +29 -1
- package/lib/components/ApiInfo/Metadata.js +29 -1
- package/lib/components/ApiInfo/index.js +2 -1
- package/lib/components/ApiInfo/styled.js +16 -8
- package/lib/components/CallbackSamples/CallbackSamples.js +25 -4
- package/lib/components/CallbackSamples/index.js +2 -1
- package/lib/components/Callbacks/CallbackDetails.js +17 -3
- package/lib/components/Callbacks/CallbackOperation.js +24 -3
- package/lib/components/Callbacks/CallbackSummary.js +19 -3
- package/lib/components/Callbacks/CallbacksList.js +16 -1
- package/lib/components/Callbacks/index.js +4 -1
- package/lib/components/Callbacks/styled.js +6 -3
- package/lib/components/Content/Content.js +10 -1
- package/lib/components/Content/index.js +2 -1
- package/lib/components/Content/useAutoScroll.js +50 -1
- package/lib/components/ContentItem/ContentItem.js +31 -1
- package/lib/components/ContentItem/index.js +2 -1
- package/lib/components/ContentItem/useIsExpanded.js +33 -1
- package/lib/components/ContentItems/ContentItems.js +19 -1
- package/lib/components/ContentItems/Items.js +13 -1
- package/lib/components/ContentItems/VirtualList.js +35 -1
- package/lib/components/ContentItems/helpers.js +49 -1
- package/lib/components/ContentItems/index.js +2 -1
- package/lib/components/ContentItems/useScrollOnRender.js +26 -1
- package/lib/components/Discriminator/Discriminator.js +27 -2
- package/lib/components/Discriminator/index.js +2 -1
- package/lib/components/Download/DownloadSpecification.js +46 -4
- package/lib/components/Download/index.js +2 -1
- package/lib/components/Download/types.js +2 -0
- package/lib/components/Download/useDownloadInfo.js +42 -1
- package/lib/components/ErrorBoundary/ErrorBoundary.js +22 -2
- package/lib/components/ErrorBoundary/index.js +2 -1
- package/lib/components/ExpandAllButton/ExpandAllButton.js +31 -2
- package/lib/components/ExpandAllButton/index.js +2 -1
- package/lib/components/ExternalDocumentation/ExternalDocumentation.js +18 -4
- package/lib/components/ExternalDocumentation/index.js +2 -1
- package/lib/components/Language/LanguageDropdown.js +21 -1
- package/lib/components/Language/LanguageItem.js +33 -1
- package/lib/components/Language/LanguageList.js +93 -1
- package/lib/components/Language/_tests_/LanguageDropdown.test.js +23 -1
- package/lib/components/Language/constants.js +3 -1
- package/lib/components/Language/index.js +4 -1
- package/lib/components/Language/styled.js +29 -15
- package/lib/components/Markdown/Markdown.js +64 -1
- package/lib/components/Markdown/index.js +3 -1
- package/lib/components/Markdown/types.js +2 -0
- package/lib/components/MediaTypeSwitch/MediaTypesSwitch.js +51 -1
- package/lib/components/MediaTypeSwitch/index.js +2 -1
- package/lib/components/OperationItem/Description.js +9 -1
- package/lib/components/OperationItem/OperationItem.js +70 -5
- package/lib/components/OperationItem/_tests_/OperationItem.test.js +70 -1
- package/lib/components/OperationItem/_tests_/__mocks__/mock-intersection-observer.js +40 -1
- package/lib/components/OperationItem/index.js +2 -1
- package/lib/components/OperationItem/types.js +2 -0
- package/lib/components/Overlay.js +48 -3
- package/lib/components/Overview/Overview.js +20 -1
- package/lib/components/Overview/index.js +2 -1
- package/lib/components/PageFooter/PageFooter.js +19 -1
- package/lib/components/PageFooter/index.js +2 -1
- package/lib/components/Panel/ResponsePanel.js +12 -6
- package/lib/components/Panel/Trigger.js +4 -2
- package/lib/components/Panel/index.js +3 -1
- package/lib/components/PanelItem/PanelItem.js +6 -1
- package/lib/components/PanelItem/index.js +3 -1
- package/lib/components/PanelItem/styled.js +20 -10
- package/lib/components/PayloadSamples/Example.js +6 -1
- package/lib/components/PayloadSamples/ExampleValue.js +30 -1
- package/lib/components/PayloadSamples/MediaTypeSamples.js +36 -2
- package/lib/components/PayloadSamples/PayloadSamples.js +26 -1
- package/lib/components/PayloadSamples/index.js +7 -1
- package/lib/components/PayloadSamples/styled.js +9 -4
- package/lib/components/PayloadSamples/types.js +2 -0
- package/lib/components/PropertyDetails/DescriptionEnums.js +19 -3
- package/lib/components/PropertyDetails/EnumValues.js +37 -1
- package/lib/components/PropertyDetails/Examples.js +26 -1
- package/lib/components/PropertyDetails/Extensions.js +17 -2
- package/lib/components/PropertyDetails/FieldDetail.js +15 -2
- package/lib/components/PropertyDetails/FieldDetails.js +51 -6
- package/lib/components/PropertyDetails/Pattern.js +21 -1
- package/lib/components/PropertyDetails/PlusCircleIcon.js +10 -4
- package/lib/components/PropertyDetails/PropertyDetails.js +22 -5
- package/lib/components/PropertyDetails/SchemaTypeInfo.js +10 -2
- package/lib/components/PropertyDetails/SimpleEnums.js +13 -2
- package/lib/components/PropertyDetails/cycleColorsByLevel.js +18 -1
- package/lib/components/PropertyDetails/index.js +4 -1
- package/lib/components/PropertyDetails/styled.js +15 -7
- package/lib/components/PropertyDetails/types.js +2 -0
- package/lib/components/RedoclyOpenAPIDocs/Providers.js +114 -1
- package/lib/components/RedoclyOpenAPIDocs/RedoclyOpenAPIDocs.js +57 -1
- package/lib/components/RedoclyOpenAPIDocs/RedoclyOpenAPIDocsStandalone.js +86 -1
- package/lib/components/RedoclyOpenAPIDocs/index.js +5 -1
- package/lib/components/RedoclyOpenAPIDocs/styled.js +4 -2
- package/lib/components/RedoclyOpenAPIDocs/types.js +2 -0
- package/lib/components/RedoclyOpenAPIDocs/utils.js +33 -1
- package/lib/components/RenderHook/RenderHook.js +17 -1
- package/lib/components/RenderHook/index.js +2 -1
- package/lib/components/Replay/EmbeddedReplay.js +41 -3
- package/lib/components/Replay/Replay.js +99 -1
- package/lib/components/Replay/index.js +3 -1
- package/lib/components/Replay/utils.js +208 -1
- package/lib/components/Request/RequestDetails.js +33 -2
- package/lib/components/Request/types.js +2 -0
- package/lib/components/RequestParameters/Body.js +8 -1
- package/lib/components/RequestParameters/ParametersGroup.js +19 -4
- package/lib/components/RequestParameters/RequestParameters.js +40 -1
- package/lib/components/RequestParameters/index.js +4 -1
- package/lib/components/RequestSamples/CodeSample.js +55 -2
- package/lib/components/RequestSamples/Example.js +37 -1
- package/lib/components/RequestSamples/RequestSamples.js +89 -5
- package/lib/components/RequestSamples/index.js +3 -1
- package/lib/components/RequestSamples/useCodeSamples.js +92 -1
- package/lib/components/ResponseSamples/ResponseSamples.js +47 -1
- package/lib/components/ResponseSamples/Summary.js +9 -1
- package/lib/components/ResponseSamples/index.js +2 -1
- package/lib/components/Responses/OperationResponseList.js +42 -2
- package/lib/components/Responses/ResponseDetails.js +18 -1
- package/lib/components/Responses/ResponseHeaders.js +15 -1
- package/lib/components/Responses/index.js +6 -1
- package/lib/components/Responses/styled.js +14 -6
- package/lib/components/Responses/types.js +2 -0
- package/lib/components/RightPanel/RightPanel.js +21 -1
- package/lib/components/RightPanel/index.js +2 -1
- package/lib/components/Samples/ExampleSwitch.js +33 -1
- package/lib/components/Samples/index.js +3 -1
- package/lib/components/Samples/use-example-key.js +12 -1
- package/lib/components/Schema/ArraySchema.js +45 -1
- package/lib/components/Schema/ObjectSchema.js +29 -1
- package/lib/components/Schema/OneOfSchema.js +47 -3
- package/lib/components/Schema/RecursiveSchema.js +10 -1
- package/lib/components/Schema/Schema.js +63 -2
- package/lib/components/Schema/SubSchema.js +20 -1
- package/lib/components/Schema/helpers.js +16 -1
- package/lib/components/Schema/index.js +5 -1
- package/lib/components/Schema/types.js +2 -0
- package/lib/components/Schema/useOneOfLocationIdx.js +11 -1
- package/lib/components/SchemaDefinition/SchemaDefinition.js +65 -2
- package/lib/components/SchemaDefinition/index.js +2 -1
- package/lib/components/SectionContent/SectionContent.js +49 -6
- package/lib/components/SectionContent/index.js +2 -1
- package/lib/components/SectionItem/SectionItem.js +14 -1
- package/lib/components/SectionItem/index.js +2 -1
- package/lib/components/Security/Divider.js +9 -2
- package/lib/components/Security/OAuthFlow.js +11 -1
- package/lib/components/Security/OAuthScopes.js +59 -9
- package/lib/components/Security/Security.js +15 -1
- package/lib/components/Security/SecurityButton.js +31 -7
- package/lib/components/Security/SecurityFlow.js +28 -4
- package/lib/components/Security/SecurityModal.js +34 -5
- package/lib/components/Security/SecuritySchemeItem.js +15 -4
- package/lib/components/Security/helper.js +16 -1
- package/lib/components/Security/index.js +11 -1
- package/lib/components/Security/styled.js +6 -3
- package/lib/components/SelectOrLabel/SelectOrLabel.js +12 -2
- package/lib/components/SelectOrLabel/index.js +2 -1
- package/lib/components/ServerList/ServerList.js +36 -10
- package/lib/components/ServerList/index.js +2 -1
- package/lib/components/ServerList/types.js +2 -0
- package/lib/components/ServerListDropdown/ServerListDropdown.js +54 -1
- package/lib/components/ServerListDropdown/index.js +2 -1
- package/lib/components/ServerListDropdown/styled.js +15 -6
- package/lib/components/SideMenu/SideMenu.js +13 -2
- package/lib/components/SideMenu/hooks/useMenuItems.js +110 -1
- package/lib/components/SideMenu/index.js +2 -1
- package/lib/components/SideMenu/types.js +2 -0
- package/lib/components/StickySidebar/SidebarActions.js +14 -2
- package/lib/components/StickySidebar/StickyResponsiveSidebar.js +37 -7
- package/lib/components/StickySidebar/index.js +2 -1
- package/lib/components/Tabs/Tabs.js +16 -5
- package/lib/components/Tabs/index.js +3 -1
- package/lib/components/Tabs/useTabsState.js +22 -1
- package/lib/components/TagItem/OperationNavigationItems.js +18 -4
- package/lib/components/TagItem/OperationsNavigation.js +46 -2
- package/lib/components/TagItem/TagItem.js +40 -7
- package/lib/components/TagItem/index.js +2 -1
- package/lib/components/TagItem/styled.js +5 -2
- package/lib/components/TagItem/types.js +2 -0
- package/lib/components/ViewNested/ViewNested.js +42 -9
- package/lib/components/ViewNested/index.js +2 -1
- package/lib/components/common/Badges.js +21 -5
- package/lib/components/common/BodyContent/BodyContent.js +31 -4
- package/lib/components/common/BodyContent/index.js +2 -1
- package/lib/components/common/ClearButton/ClearButton.js +5 -1
- package/lib/components/common/ClearButton/index.js +3 -1
- package/lib/components/common/ClearButton/styled.js +5 -2
- package/lib/components/common/ClearButton/types.js +2 -0
- package/lib/components/common/CodeBlockPanel.js +7 -3
- package/lib/components/common/ConstraintsView.js +14 -2
- package/lib/components/common/Dropdown/Dropdown.js +22 -4
- package/lib/components/common/Dropdown/index.js +2 -1
- package/lib/components/common/ExpandableExample/ExpandableExample.js +24 -3
- package/lib/components/common/ExpandableExample/index.js +2 -1
- package/lib/components/common/Extensions.js +17 -2
- package/lib/components/common/Fields/fields-layout.js +76 -51
- package/lib/components/common/Fields/fields.js +39 -17
- package/lib/components/common/Fields/index.js +3 -1
- package/lib/components/common/LinkToField.js +33 -6
- package/lib/components/common/OperationItemTitle.js +12 -6
- package/lib/components/common/SchemaSelection/SchemaSelection.js +51 -1
- package/lib/components/common/SchemaSelection/index.js +2 -1
- package/lib/components/common/Select/Select.js +21 -1
- package/lib/components/common/Select/index.js +3 -1
- package/lib/components/common/Select/styled.js +17 -9
- package/lib/components/common/Select/types.js +2 -0
- package/lib/components/common/Skeleton/LanguageListSkeleton.js +16 -6
- package/lib/components/common/Skeleton/Skeleton.js +15 -5
- package/lib/components/common/Skeleton/index.js +3 -1
- package/lib/components/common/headers.js +4 -2
- package/lib/components/common/index.js +14 -1
- package/lib/components/common/linkify.js +28 -4
- package/lib/components/common/mixins.js +4 -2
- package/lib/components/common/panels.js +52 -29
- package/lib/components/common/schema.js +16 -8
- package/lib/components/common/styled.js +15 -7
- package/lib/components/index.js +25 -1
- package/lib/components/pluggable/RedocExample.js +20 -1
- package/lib/components/pluggable/RedocSchema.js +22 -1
- package/lib/components/pluggable/index.js +3 -1
- package/lib/components/pluggable/styled.components.js +9 -4
- package/lib/constants.js +30 -1
- package/lib/empty.js +7 -1
- package/lib/events/codeSampleCopy.js +19 -1
- package/lib/events/creator.js +5 -1
- package/lib/events/index.js +8 -1
- package/lib/events/languageSwitch.js +18 -1
- package/lib/events/panelToggle.js +16 -1
- package/lib/events/serverSwitch.js +13 -1
- package/lib/events/tryItOpen.js +12 -1
- package/lib/events/tryItSent.js +12 -1
- package/lib/events/types.js +11 -1
- package/lib/hoc/types.js +2 -0
- package/lib/hoc/utils.js +4 -1
- package/lib/hoc/withRouter.js +17 -1
- package/lib/hoc/withStore.js +28 -1
- package/lib/hooks/index.js +9 -1
- package/lib/hooks/useActivateExample.js +35 -1
- package/lib/hooks/useActiveWithFallback.js +12 -1
- package/lib/hooks/useContentItems.js +10 -1
- package/lib/hooks/useLicense.js +17 -1
- package/lib/hooks/usePerformanceMetrics.js +26 -1
- package/lib/hooks/useRouter.js +17 -1
- package/lib/hooks/useTelemetry.js +5 -1
- package/lib/hooks/useTranslate.js +6 -1
- package/lib/hooks/useUppercase2LowercaseRedirect.js +12 -1
- package/lib/icons/CSharpIcon/CSharpIcon.js +7 -1
- package/lib/icons/CSharpIcon/index.js +2 -1
- package/lib/icons/CurlIcon/CurlIcon.js +8 -2
- package/lib/icons/CurlIcon/index.js +2 -1
- package/lib/icons/GOIcon/GOIcon.js +7 -1
- package/lib/icons/GOIcon/index.js +2 -1
- package/lib/icons/JavaIcon/JavaIcon.js +7 -1
- package/lib/icons/JavaIcon/index.js +2 -1
- package/lib/icons/JavaScriptIcon/JavaScriptIcon.js +7 -1
- package/lib/icons/JavaScriptIcon/index.js +2 -1
- package/lib/icons/NodeJSIcon/NodeJSIcon.js +7 -1
- package/lib/icons/NodeJSIcon/index.js +2 -1
- package/lib/icons/PHPIcon/PHPIcon.js +7 -1
- package/lib/icons/PHPIcon/index.js +2 -1
- package/lib/icons/PayloadIcon/PayloadIcon.js +7 -1
- package/lib/icons/PayloadIcon/index.js +2 -1
- package/lib/icons/PythonIcon/PythonIcon.js +7 -1
- package/lib/icons/PythonIcon/index.js +2 -1
- package/lib/icons/RIcon/RIcon.js +7 -1
- package/lib/icons/RIcon/index.js +2 -1
- package/lib/icons/RubyIcon/RubyIcon.js +7 -1
- package/lib/icons/RubyIcon/index.js +2 -1
- package/lib/index.js +49 -1
- package/lib/jotai/app.js +113 -1
- package/lib/jotai/operation.js +28 -1
- package/lib/jotai/replay.js +5 -1
- package/lib/jotai/store.js +8 -1
- package/lib/jotai/use-write-atom.js +9 -1
- package/lib/models/callback.js +28 -1
- package/lib/models/code-sample-options.js +2 -0
- package/lib/models/example.js +17 -1
- package/lib/models/field.js +109 -1
- package/lib/models/group.js +38 -1
- package/lib/models/index.js +14 -1
- package/lib/models/mediaContent.js +26 -1
- package/lib/models/mediaType.js +153 -1
- package/lib/models/operation.js +166 -1
- package/lib/models/request.js +25 -1
- package/lib/models/response.js +46 -1
- package/lib/models/schema.js +474 -2
- package/lib/models/security.js +84 -1
- package/lib/models/tab.js +2 -0
- package/lib/models/types.js +2 -0
- package/lib/services/OpenAPIParser.js +321 -1
- package/lib/services/check.js +104 -1
- package/lib/services/code-samples/constants.js +16 -1
- package/lib/services/code-samples/generator.js +540 -1
- package/lib/services/code-samples/httpsnippet/helpers/code-builder.js +252 -3
- package/lib/services/code-samples/httpsnippet/helpers/code-helpers.js +90 -2
- package/lib/services/code-samples/httpsnippet/helpers/constants.js +28 -1
- package/lib/services/code-samples/httpsnippet/helpers/lodash-int.js +173 -1
- package/lib/services/code-samples/httpsnippet/helpers/mocks/code-helpers-mock.js +76 -37
- package/lib/services/code-samples/httpsnippet/helpers/reducer.js +16 -1
- package/lib/services/code-samples/httpsnippet/helpers/shell.js +20 -1
- package/lib/services/code-samples/httpsnippet/helpers/string-utility.js +19 -1
- package/lib/services/code-samples/httpsnippet/index.js +166 -1
- package/lib/services/code-samples/httpsnippet/targets/__mocks__/mock.js +2340 -146
- package/lib/services/code-samples/httpsnippet/targets/csharp/httpclient.js +227 -2
- package/lib/services/code-samples/httpsnippet/targets/csharp/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/csharpNewtonsoft/httpclient.js +185 -2
- package/lib/services/code-samples/httpsnippet/targets/csharpNewtonsoft/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/go/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/go/native.js +222 -3
- package/lib/services/code-samples/httpsnippet/targets/index.js +28 -1
- package/lib/services/code-samples/httpsnippet/targets/java/httpclient.js +184 -3
- package/lib/services/code-samples/httpsnippet/targets/java/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/java8/apachehttp.js +223 -2
- package/lib/services/code-samples/httpsnippet/targets/java8/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/javascript/fetch.js +147 -1
- package/lib/services/code-samples/httpsnippet/targets/javascript/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/node/fetch.js +199 -1
- package/lib/services/code-samples/httpsnippet/targets/node/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/php/curl.js +203 -5
- package/lib/services/code-samples/httpsnippet/targets/php/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/php/types.js +2 -0
- package/lib/services/code-samples/httpsnippet/targets/php/utils.js +106 -5
- package/lib/services/code-samples/httpsnippet/targets/python/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/python/requests.js +185 -6
- package/lib/services/code-samples/httpsnippet/targets/r/httr.js +111 -1
- package/lib/services/code-samples/httpsnippet/targets/r/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/r/utils.js +18 -6
- package/lib/services/code-samples/httpsnippet/targets/ruby/index.js +11 -1
- package/lib/services/code-samples/httpsnippet/targets/ruby/native.js +169 -1
- package/lib/services/code-samples/httpsnippet/targets/shell/curl.js +94 -6
- package/lib/services/code-samples/httpsnippet/targets/shell/index.js +11 -1
- package/lib/services/code-samples/index.js +3 -1
- package/lib/services/code-samples/types.js +2 -0
- package/lib/services/config-options/helpers.js +49 -1
- package/lib/services/config-options/index.js +3 -1
- package/lib/services/config-options/normalizeOptions.js +83 -1
- package/lib/services/config-options/types.js +2 -0
- package/lib/services/history/helpers.js +63 -1
- package/lib/services/history/index.js +2 -1
- package/lib/services/index.js +9 -1
- package/lib/services/menu/builder.js +47 -1
- package/lib/services/menu/index.js +2 -1
- package/lib/services/menu/markdown.js +93 -1
- package/lib/services/menu/operation.js +50 -1
- package/lib/services/menu/tags.js +166 -1
- package/lib/services/types.js +2 -0
- package/lib/services/utils.js +83 -1
- package/lib/standalone.js +68 -1
- package/lib/styled-components.js +6 -1
- package/lib/types/app.js +2 -0
- package/lib/types/index.js +4 -1
- package/lib/types/open-api.js +2 -0
- package/lib/types/security.js +2 -0
- package/lib/utils/JsonPointer.js +84 -1
- package/lib/utils/areArraysEqual.js +4 -1
- package/lib/utils/argValuesHelpers.js +35 -1
- package/lib/utils/compose.js +2 -1
- package/lib/utils/configure-helpers.js +223 -1
- package/lib/utils/convertSwagger2OpenAPI.js +14 -1
- package/lib/utils/cookies.js +73 -1
- package/lib/utils/debounce.js +22 -1
- package/lib/utils/debug.js +11 -1
- package/lib/utils/dom.js +65 -1
- package/lib/utils/environments.js +13 -1
- package/lib/utils/helpers.js +222 -12
- package/lib/utils/index.js +25 -1
- package/lib/utils/isMobile.js +13 -1
- package/lib/utils/loadAndBundleSpec.js +32 -1
- package/lib/utils/local-storage.js +12 -1
- package/lib/utils/object.js +31 -1
- package/lib/utils/openapi.js +592 -1
- package/lib/utils/parameters.js +13 -1
- package/lib/utils/path.js +22 -1
- package/lib/utils/queryString.js +60 -1
- package/lib/utils/replaceVariables.js +14 -1
- package/lib/utils/saveTextBeforeHeading.js +35 -1
- package/lib/utils/security-details.js +49 -1
- package/lib/utils/session-storage.js +12 -1
- package/lib/utils/simplifyAstStructure.js +22 -1
- package/lib/utils/sort.js +21 -1
- package/lib/utils/string.js +65 -1
- package/lib/utils/telemetry.js +7 -1
- package/lib/utils/test-utils.js +26 -1
- package/lib/utils/theme-helpers.js +24 -3
- package/lib/utils/url.js +38 -1
- package/package.json +4 -4
|
@@ -1 +1,26 @@
|
|
|
1
|
-
import{useEffect
|
|
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
|
|
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
|
-
`;
|
|
29
|
+
`;
|
|
30
|
+
//# sourceMappingURL=Discriminator.js.map
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
export { Discriminator } from './Discriminator.js';
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1,4 +1,43 @@
|
|
|
1
|
-
import{
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
`;
|
|
80
|
+
`;
|
|
81
|
+
//# sourceMappingURL=DownloadSpecification.js.map
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
export { DownloadSpecification } from './DownloadSpecification.js';
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1,42 @@
|
|
|
1
|
-
import
|
|
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
|
|
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
|
-
`;
|
|
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
|
-
|
|
1
|
+
export { ErrorBoundary } from './ErrorBoundary.js';
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1,3 +1,32 @@
|
|
|
1
|
-
import{
|
|
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
|
-
`;
|
|
31
|
+
`;
|
|
32
|
+
//# sourceMappingURL=ExpandAllButton.js.map
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
export { ExpandAllButton } from './ExpandAllButton.js';
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1,4 +1,18 @@
|
|
|
1
|
-
import{jsx as
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
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
|
-
|
|
1
|
+
export { ExternalDocumentation } from './ExternalDocumentation.js';
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1,21 @@
|
|
|
1
|
-
import{jsx as
|
|
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
|
|
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{
|
|
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
|
|
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,4 @@
|
|
|
1
|
-
|
|
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
|
|
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
|
-
|
|
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
|
|
14
|
-
|
|
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
|
-
|
|
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
|
-
|
|
37
|
+
`;
|
|
38
|
+
export const LanguageListContainer = styled.div `
|
|
30
39
|
display: flex;
|
|
31
|
-
justify-content: ${({$justifyContent
|
|
40
|
+
justify-content: ${({ $justifyContent = 'start' }) => $justifyContent};
|
|
32
41
|
align-items: center;
|
|
33
42
|
width: 100%;
|
|
34
|
-
|
|
43
|
+
`;
|
|
44
|
+
export const LanguageListItem = styled.button `
|
|
35
45
|
background: none;
|
|
36
46
|
border: none;
|
|
37
|
-
width: ${
|
|
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
|
|
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
|
|
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
|
-
|
|
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
|
|
84
|
+
width: ${({ $width = 204 }) => $width}px;
|
|
73
85
|
fill: var(--menu-content-color-active);
|
|
74
|
-
|
|
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
|
-
`;
|
|
94
|
+
`;
|
|
95
|
+
//# sourceMappingURL=styled.js.map
|