@diplodoc/components 3.0.0-alpha-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.
- package/LICENSE +21 -0
- package/README.md +67 -0
- package/assets/icons/link.svg +3 -0
- package/assets/icons/pdf.svg +6 -0
- package/build/cjs/components/BookmarkButton/BookmarkButton.css +12 -0
- package/build/cjs/components/BookmarkButton/BookmarkButton.css.map +7 -0
- package/build/cjs/components/BookmarkButton/BookmarkButton.d.ts +8 -0
- package/build/cjs/components/BookmarkButton/BookmarkButton.js +56 -0
- package/build/cjs/components/BookmarkButton/BookmarkButton.js.map +7 -0
- package/build/cjs/components/BookmarkButton/index.d.ts +1 -0
- package/build/cjs/components/BookmarkButton/index.js +21 -0
- package/build/cjs/components/BookmarkButton/index.js.map +7 -0
- package/build/cjs/components/Breadcrumbs/Breadcrumbs.css +35 -0
- package/build/cjs/components/Breadcrumbs/Breadcrumbs.css.map +7 -0
- package/build/cjs/components/Breadcrumbs/Breadcrumbs.d.ts +8 -0
- package/build/cjs/components/Breadcrumbs/Breadcrumbs.js +58 -0
- package/build/cjs/components/Breadcrumbs/Breadcrumbs.js.map +7 -0
- package/build/cjs/components/Breadcrumbs/index.d.ts +1 -0
- package/build/cjs/components/Breadcrumbs/index.js +21 -0
- package/build/cjs/components/Breadcrumbs/index.js.map +7 -0
- package/build/cjs/components/ContributorAvatars/Avatars/Avatar.d.ts +10 -0
- package/build/cjs/components/ContributorAvatars/Avatars/Avatar.js +89 -0
- package/build/cjs/components/ContributorAvatars/Avatars/Avatar.js.map +7 -0
- package/build/cjs/components/ContributorAvatars/Avatars/AvatarWithDescription.d.ts +9 -0
- package/build/cjs/components/ContributorAvatars/Avatars/AvatarWithDescription.js +63 -0
- package/build/cjs/components/ContributorAvatars/Avatars/AvatarWithDescription.js.map +7 -0
- package/build/cjs/components/ContributorAvatars/Avatars/Details.d.ts +10 -0
- package/build/cjs/components/ContributorAvatars/Avatars/Details.js +77 -0
- package/build/cjs/components/ContributorAvatars/Avatars/Details.js.map +7 -0
- package/build/cjs/components/ContributorAvatars/Avatars/HiddenAvatars.d.ts +10 -0
- package/build/cjs/components/ContributorAvatars/Avatars/HiddenAvatars.js +70 -0
- package/build/cjs/components/ContributorAvatars/Avatars/HiddenAvatars.js.map +7 -0
- package/build/cjs/components/ContributorAvatars/ContributorAvatars.css +135 -0
- package/build/cjs/components/ContributorAvatars/ContributorAvatars.css.map +7 -0
- package/build/cjs/components/ContributorAvatars/ContributorAvatars.d.ts +10 -0
- package/build/cjs/components/ContributorAvatars/ContributorAvatars.js +84 -0
- package/build/cjs/components/ContributorAvatars/ContributorAvatars.js.map +7 -0
- package/build/cjs/components/ContributorAvatars/index.d.ts +2 -0
- package/build/cjs/components/ContributorAvatars/index.js +39 -0
- package/build/cjs/components/ContributorAvatars/index.js.map +7 -0
- package/build/cjs/components/ContributorAvatars/models.d.ts +16 -0
- package/build/cjs/components/ContributorAvatars/models.js +31 -0
- package/build/cjs/components/ContributorAvatars/models.js.map +7 -0
- package/build/cjs/components/ContributorAvatars/utils.d.ts +3 -0
- package/build/cjs/components/ContributorAvatars/utils.js +39 -0
- package/build/cjs/components/ContributorAvatars/utils.js.map +7 -0
- package/build/cjs/components/Contributors/Contributors.css +12 -0
- package/build/cjs/components/Contributors/Contributors.css.map +7 -0
- package/build/cjs/components/Contributors/Contributors.d.ts +11 -0
- package/build/cjs/components/Contributors/Contributors.js +48 -0
- package/build/cjs/components/Contributors/Contributors.js.map +7 -0
- package/build/cjs/components/Contributors/index.d.ts +2 -0
- package/build/cjs/components/Control/Control.css +15 -0
- package/build/cjs/components/Control/Control.css.map +7 -0
- package/build/cjs/components/Control/Control.d.ts +20 -0
- package/build/cjs/components/Control/Control.js +95 -0
- package/build/cjs/components/Control/Control.js.map +7 -0
- package/build/cjs/components/Control/index.d.ts +2 -0
- package/build/cjs/components/Control/index.js +39 -0
- package/build/cjs/components/Control/index.js.map +7 -0
- package/build/cjs/components/Controls/Controls.css +50 -0
- package/build/cjs/components/Controls/Controls.css.map +7 -0
- package/build/cjs/components/Controls/Controls.d.ts +32 -0
- package/build/cjs/components/Controls/Controls.js +169 -0
- package/build/cjs/components/Controls/Controls.js.map +7 -0
- package/build/cjs/components/Controls/ControlsLayout.d.ts +12 -0
- package/build/cjs/components/Controls/ControlsLayout.js +68 -0
- package/build/cjs/components/Controls/ControlsLayout.js.map +7 -0
- package/build/cjs/components/Controls/index.d.ts +4 -0
- package/build/cjs/components/Controls/index.js +42 -0
- package/build/cjs/components/Controls/index.js.map +7 -0
- package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.css +21 -0
- package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.css.map +7 -0
- package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.d.ts +7 -0
- package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.js +46 -0
- package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.js.map +7 -0
- package/build/cjs/components/Controls/single-controls/EditControl.d.ts +9 -0
- package/build/cjs/components/Controls/single-controls/EditControl.js +73 -0
- package/build/cjs/components/Controls/single-controls/EditControl.js.map +7 -0
- package/build/cjs/components/Controls/single-controls/FullScreenControl.d.ts +7 -0
- package/build/cjs/components/Controls/single-controls/FullScreenControl.js +82 -0
- package/build/cjs/components/Controls/single-controls/FullScreenControl.js.map +7 -0
- package/build/cjs/components/Controls/single-controls/LangControl.d.ts +10 -0
- package/build/cjs/components/Controls/single-controls/LangControl.js +122 -0
- package/build/cjs/components/Controls/single-controls/LangControl.js.map +7 -0
- package/build/cjs/components/Controls/single-controls/PdfControl.d.ts +6 -0
- package/build/cjs/components/Controls/single-controls/PdfControl.js +60 -0
- package/build/cjs/components/Controls/single-controls/PdfControl.js.map +7 -0
- package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.css +49 -0
- package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.css.map +7 -0
- package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.d.ts +17 -0
- package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.js +198 -0
- package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.js.map +7 -0
- package/build/cjs/components/Controls/single-controls/SinglePageControl.d.ts +7 -0
- package/build/cjs/components/Controls/single-controls/SinglePageControl.js +67 -0
- package/build/cjs/components/Controls/single-controls/SinglePageControl.js.map +7 -0
- package/build/cjs/components/Controls/single-controls/index.d.ts +7 -0
- package/build/cjs/components/Controls/single-controls/index.js +49 -0
- package/build/cjs/components/Controls/single-controls/index.js.map +7 -0
- package/build/cjs/components/Controls/single-controls/utils.d.ts +2 -0
- package/build/cjs/components/Controls/single-controls/utils.js +30 -0
- package/build/cjs/components/Controls/single-controls/utils.js.map +7 -0
- package/build/cjs/components/DocLayout/DocLayout.css +102 -0
- package/build/cjs/components/DocLayout/DocLayout.css.map +7 -0
- package/build/cjs/components/DocLayout/DocLayout.d.ts +34 -0
- package/build/cjs/components/DocLayout/DocLayout.js +117 -0
- package/build/cjs/components/DocLayout/DocLayout.js.map +7 -0
- package/build/cjs/components/DocLayout/index.d.ts +1 -0
- package/build/cjs/components/DocLayout/index.js +21 -0
- package/build/cjs/components/DocLayout/index.js.map +7 -0
- package/build/cjs/components/DocLeadingPage/DocLeadingPage.css +93 -0
- package/build/cjs/components/DocLeadingPage/DocLeadingPage.css.map +7 -0
- package/build/cjs/components/DocLeadingPage/DocLeadingPage.d.ts +22 -0
- package/build/cjs/components/DocLeadingPage/DocLeadingPage.js +109 -0
- package/build/cjs/components/DocLeadingPage/DocLeadingPage.js.map +7 -0
- package/build/cjs/components/DocLeadingPage/index.d.ts +1 -0
- package/build/cjs/components/DocLeadingPage/index.js +21 -0
- package/build/cjs/components/DocLeadingPage/index.js.map +7 -0
- package/build/cjs/components/DocPage/DocPage.css +231 -0
- package/build/cjs/components/DocPage/DocPage.css.map +7 -0
- package/build/cjs/components/DocPage/DocPage.d.ts +41 -0
- package/build/cjs/components/DocPage/DocPage.js +460 -0
- package/build/cjs/components/DocPage/DocPage.js.map +7 -0
- package/build/cjs/components/DocPage/index.d.ts +2 -0
- package/build/cjs/components/DocPage/index.js +39 -0
- package/build/cjs/components/DocPage/index.js.map +7 -0
- package/build/cjs/components/DocPageTitle/DocPageTitle.css +10 -0
- package/build/cjs/components/DocPageTitle/DocPageTitle.css.map +7 -0
- package/build/cjs/components/DocPageTitle/DocPageTitle.d.ts +7 -0
- package/build/cjs/components/DocPageTitle/DocPageTitle.js +50 -0
- package/build/cjs/components/DocPageTitle/DocPageTitle.js.map +7 -0
- package/build/cjs/components/DocPageTitle/index.d.ts +1 -0
- package/build/cjs/components/DocPageTitle/index.js +21 -0
- package/build/cjs/components/DocPageTitle/index.js.map +7 -0
- package/build/cjs/components/ErrorBoundary/ErrorBoundary.d.ts +12 -0
- package/build/cjs/components/ErrorBoundary/ErrorBoundary.js +56 -0
- package/build/cjs/components/ErrorBoundary/ErrorBoundary.js.map +7 -0
- package/build/cjs/components/ErrorBoundary/index.d.ts +2 -0
- package/build/cjs/components/ErrorBoundary/index.js +39 -0
- package/build/cjs/components/ErrorBoundary/index.js.map +7 -0
- package/build/cjs/components/ErrorPage/ErrorPage.css +65 -0
- package/build/cjs/components/ErrorPage/ErrorPage.css.map +7 -0
- package/build/cjs/components/ErrorPage/ErrorPage.d.ts +10 -0
- package/build/cjs/components/ErrorPage/ErrorPage.js +83 -0
- package/build/cjs/components/ErrorPage/ErrorPage.js.map +7 -0
- package/build/cjs/components/ErrorPage/index.d.ts +2 -0
- package/build/cjs/components/ErrorPage/index.js +39 -0
- package/build/cjs/components/ErrorPage/index.js.map +7 -0
- package/build/cjs/components/Feedback/Feedback.css +109 -0
- package/build/cjs/components/Feedback/Feedback.css.map +7 -0
- package/build/cjs/components/Feedback/Feedback.d.ts +15 -0
- package/build/cjs/components/Feedback/Feedback.js +163 -0
- package/build/cjs/components/Feedback/Feedback.js.map +7 -0
- package/build/cjs/components/Feedback/controls/DislikeControl.d.ts +11 -0
- package/build/cjs/components/Feedback/controls/DislikeControl.js +69 -0
- package/build/cjs/components/Feedback/controls/DislikeControl.js.map +7 -0
- package/build/cjs/components/Feedback/controls/DislikeVariantsPopup.d.ts +18 -0
- package/build/cjs/components/Feedback/controls/DislikeVariantsPopup.js +150 -0
- package/build/cjs/components/Feedback/controls/DislikeVariantsPopup.js.map +7 -0
- package/build/cjs/components/Feedback/controls/LikeControl.d.ts +13 -0
- package/build/cjs/components/Feedback/controls/LikeControl.js +81 -0
- package/build/cjs/components/Feedback/controls/LikeControl.js.map +7 -0
- package/build/cjs/components/Feedback/controls/SuccessPopup.d.ts +10 -0
- package/build/cjs/components/Feedback/controls/SuccessPopup.js +67 -0
- package/build/cjs/components/Feedback/controls/SuccessPopup.js.map +7 -0
- package/build/cjs/components/Feedback/index.d.ts +2 -0
- package/build/cjs/components/Feedback/index.js +39 -0
- package/build/cjs/components/Feedback/index.js.map +7 -0
- package/build/cjs/components/HTML/HTML.d.ts +7 -0
- package/build/cjs/components/HTML/HTML.js +46 -0
- package/build/cjs/components/HTML/HTML.js.map +7 -0
- package/build/cjs/components/HTML/index.d.ts +1 -0
- package/build/cjs/components/HTML/index.js +21 -0
- package/build/cjs/components/HTML/index.js.map +7 -0
- package/build/cjs/components/Link.d.ts +6 -0
- package/build/cjs/components/Link.js +41 -0
- package/build/cjs/components/Link.js.map +7 -0
- package/build/cjs/components/Mark/Mark.css +22 -0
- package/build/cjs/components/Mark/Mark.css.map +7 -0
- package/build/cjs/components/Mark/Mark.d.ts +10 -0
- package/build/cjs/components/Mark/Mark.js +43 -0
- package/build/cjs/components/Mark/Mark.js.map +7 -0
- package/build/cjs/components/Mark/index.d.ts +1 -0
- package/build/cjs/components/Mark/index.js +21 -0
- package/build/cjs/components/Mark/index.js.map +7 -0
- package/build/cjs/components/MiniToc/MiniToc.css +44 -0
- package/build/cjs/components/MiniToc/MiniToc.css.map +7 -0
- package/build/cjs/components/MiniToc/MiniToc.d.ts +15 -0
- package/build/cjs/components/MiniToc/MiniToc.js +71 -0
- package/build/cjs/components/MiniToc/MiniToc.js.map +7 -0
- package/build/cjs/components/MiniToc/index.d.ts +2 -0
- package/build/cjs/components/MiniToc/index.js +39 -0
- package/build/cjs/components/MiniToc/index.js.map +7 -0
- package/build/cjs/components/OutsideClick/OutsideClick.d.ts +12 -0
- package/build/cjs/components/OutsideClick/OutsideClick.js +56 -0
- package/build/cjs/components/OutsideClick/OutsideClick.js.map +7 -0
- package/build/cjs/components/OutsideClick/index.d.ts +2 -0
- package/build/cjs/components/OutsideClick/index.js +39 -0
- package/build/cjs/components/OutsideClick/index.js.map +7 -0
- package/build/cjs/components/Paginator/Paginator.css +45 -0
- package/build/cjs/components/Paginator/Paginator.css.map +7 -0
- package/build/cjs/components/Paginator/Paginator.d.ts +22 -0
- package/build/cjs/components/Paginator/Paginator.js +132 -0
- package/build/cjs/components/Paginator/Paginator.js.map +7 -0
- package/build/cjs/components/Paginator/index.d.ts +2 -0
- package/build/cjs/components/Paginator/index.js +39 -0
- package/build/cjs/components/Paginator/index.js.map +7 -0
- package/build/cjs/components/Scrollspy/Scrollspy.d.ts +48 -0
- package/build/cjs/components/Scrollspy/Scrollspy.js +259 -0
- package/build/cjs/components/Scrollspy/Scrollspy.js.map +7 -0
- package/build/cjs/components/Scrollspy/index.d.ts +1 -0
- package/build/cjs/components/Scrollspy/index.js +21 -0
- package/build/cjs/components/Scrollspy/index.js.map +7 -0
- package/build/cjs/components/SearchBar/SearchBar.css +59 -0
- package/build/cjs/components/SearchBar/SearchBar.css.map +7 -0
- package/build/cjs/components/SearchBar/SearchBar.d.ts +12 -0
- package/build/cjs/components/SearchBar/SearchBar.js +88 -0
- package/build/cjs/components/SearchBar/SearchBar.js.map +7 -0
- package/build/cjs/components/SearchBar/constants.d.ts +7 -0
- package/build/cjs/components/SearchBar/constants.js +39 -0
- package/build/cjs/components/SearchBar/constants.js.map +7 -0
- package/build/cjs/components/SearchBar/hooks.d.ts +55 -0
- package/build/cjs/components/SearchBar/hooks.js +292 -0
- package/build/cjs/components/SearchBar/hooks.js.map +7 -0
- package/build/cjs/components/SearchBar/index.d.ts +4 -0
- package/build/cjs/components/SearchBar/index.js +42 -0
- package/build/cjs/components/SearchBar/index.js.map +7 -0
- package/build/cjs/components/SearchBar/utils.d.ts +26 -0
- package/build/cjs/components/SearchBar/utils.js +108 -0
- package/build/cjs/components/SearchBar/utils.js.map +7 -0
- package/build/cjs/components/SearchBar/withHighlightedSearchWords.d.ts +16 -0
- package/build/cjs/components/SearchBar/withHighlightedSearchWords.js +123 -0
- package/build/cjs/components/SearchBar/withHighlightedSearchWords.js.map +7 -0
- package/build/cjs/components/SearchItem/SearchItem.css +88 -0
- package/build/cjs/components/SearchItem/SearchItem.css.map +7 -0
- package/build/cjs/components/SearchItem/SearchItem.d.ts +19 -0
- package/build/cjs/components/SearchItem/SearchItem.js +91 -0
- package/build/cjs/components/SearchItem/SearchItem.js.map +7 -0
- package/build/cjs/components/SearchItem/index.d.ts +2 -0
- package/build/cjs/components/SearchItem/index.js +39 -0
- package/build/cjs/components/SearchItem/index.js.map +7 -0
- package/build/cjs/components/SearchPage/SearchPage.css +43 -0
- package/build/cjs/components/SearchPage/SearchPage.css.map +7 -0
- package/build/cjs/components/SearchPage/SearchPage.d.ts +20 -0
- package/build/cjs/components/SearchPage/SearchPage.js +165 -0
- package/build/cjs/components/SearchPage/SearchPage.js.map +7 -0
- package/build/cjs/components/SearchPage/index.d.ts +2 -0
- package/build/cjs/components/SearchPage/index.js +39 -0
- package/build/cjs/components/SearchPage/index.js.map +7 -0
- package/build/cjs/components/StageLabel/StageLabel.d.ts +8 -0
- package/build/cjs/components/StageLabel/StageLabel.js +50 -0
- package/build/cjs/components/StageLabel/StageLabel.js.map +7 -0
- package/build/cjs/components/StageLabel/index.d.ts +1 -0
- package/build/cjs/components/StageLabel/index.js +21 -0
- package/build/cjs/components/StageLabel/index.js.map +7 -0
- package/build/cjs/components/Subscribe/Subscribe.css +98 -0
- package/build/cjs/components/Subscribe/Subscribe.css.map +7 -0
- package/build/cjs/components/Subscribe/Subscribe.d.ts +13 -0
- package/build/cjs/components/Subscribe/Subscribe.js +136 -0
- package/build/cjs/components/Subscribe/Subscribe.js.map +7 -0
- package/build/cjs/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.d.ts +8 -0
- package/build/cjs/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.js +61 -0
- package/build/cjs/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.js.map +7 -0
- package/build/cjs/components/Subscribe/SubscribeSuccessPopup/index.d.ts +1 -0
- package/build/cjs/components/Subscribe/SubscribeSuccessPopup/index.js +37 -0
- package/build/cjs/components/Subscribe/SubscribeSuccessPopup/index.js.map +7 -0
- package/build/cjs/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.d.ts +11 -0
- package/build/cjs/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.js +126 -0
- package/build/cjs/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.js.map +7 -0
- package/build/cjs/components/Subscribe/SubscribeVariantsPopup/index.d.ts +1 -0
- package/build/cjs/components/Subscribe/SubscribeVariantsPopup/index.js +37 -0
- package/build/cjs/components/Subscribe/SubscribeVariantsPopup/index.js.map +7 -0
- package/build/cjs/components/Subscribe/index.d.ts +2 -0
- package/build/cjs/components/Subscribe/index.js +39 -0
- package/build/cjs/components/Subscribe/index.js.map +7 -0
- package/build/cjs/components/Subscribe/utils.d.ts +3 -0
- package/build/cjs/components/Subscribe/utils.js +34 -0
- package/build/cjs/components/Subscribe/utils.js.map +7 -0
- package/build/cjs/components/Text/Text.d.ts +7 -0
- package/build/cjs/components/Text/Text.js +54 -0
- package/build/cjs/components/Text/Text.js.map +7 -0
- package/build/cjs/components/Text/index.d.ts +1 -0
- package/build/cjs/components/Text/index.js +21 -0
- package/build/cjs/components/Text/index.js.map +7 -0
- package/build/cjs/components/TextInput/TextInput.d.ts +0 -0
- package/build/cjs/components/Toc/Toc.css +102 -0
- package/build/cjs/components/Toc/Toc.css.map +7 -0
- package/build/cjs/components/Toc/Toc.d.ts +58 -0
- package/build/cjs/components/Toc/Toc.js +275 -0
- package/build/cjs/components/Toc/Toc.js.map +7 -0
- package/build/cjs/components/Toc/TocItemRegistry.d.ts +16 -0
- package/build/cjs/components/Toc/TocItemRegistry.js +81 -0
- package/build/cjs/components/Toc/TocItemRegistry.js.map +7 -0
- package/build/cjs/components/Toc/index.d.ts +2 -0
- package/build/cjs/components/Toc/index.js +39 -0
- package/build/cjs/components/Toc/index.js.map +7 -0
- package/build/cjs/components/TocItem/TocItem.css +39 -0
- package/build/cjs/components/TocItem/TocItem.css.map +7 -0
- package/build/cjs/components/TocItem/TocItem.d.ts +20 -0
- package/build/cjs/components/TocItem/TocItem.js +105 -0
- package/build/cjs/components/TocItem/TocItem.js.map +7 -0
- package/build/cjs/components/TocItem/index.d.ts +2 -0
- package/build/cjs/components/TocItem/index.js +39 -0
- package/build/cjs/components/TocItem/index.js.map +7 -0
- package/build/cjs/components/TocNavPanel/TocNavPanel.css +64 -0
- package/build/cjs/components/TocNavPanel/TocNavPanel.css.map +7 -0
- package/build/cjs/components/TocNavPanel/TocNavPanel.d.ts +10 -0
- package/build/cjs/components/TocNavPanel/TocNavPanel.js +94 -0
- package/build/cjs/components/TocNavPanel/TocNavPanel.js.map +7 -0
- package/build/cjs/components/TocNavPanel/index.d.ts +2 -0
- package/build/cjs/components/TocNavPanel/index.js +39 -0
- package/build/cjs/components/TocNavPanel/index.js.map +7 -0
- package/build/cjs/components/ToggleArrow/ToggleArrow.css +24 -0
- package/build/cjs/components/ToggleArrow/ToggleArrow.css.map +7 -0
- package/build/cjs/components/ToggleArrow/ToggleArrow.d.ts +11 -0
- package/build/cjs/components/ToggleArrow/ToggleArrow.js +49 -0
- package/build/cjs/components/ToggleArrow/ToggleArrow.js.map +7 -0
- package/build/cjs/components/ToggleArrow/index.d.ts +1 -0
- package/build/cjs/components/ToggleArrow/index.js +21 -0
- package/build/cjs/components/ToggleArrow/index.js.map +7 -0
- package/build/cjs/config/i18n.d.ts +7 -0
- package/build/cjs/config/i18n.js +68 -0
- package/build/cjs/config/i18n.js.map +7 -0
- package/build/cjs/config/index.d.ts +6 -0
- package/build/cjs/config/index.js +51 -0
- package/build/cjs/config/index.js.map +7 -0
- package/build/cjs/constants.d.ts +19 -0
- package/build/cjs/constants.js +46 -0
- package/build/cjs/constants.js.map +7 -0
- package/build/cjs/hooks/index.d.ts +4 -0
- package/build/cjs/hooks/index.js +24 -0
- package/build/cjs/hooks/index.js.map +7 -0
- package/build/cjs/hooks/usePopper.d.ts +33 -0
- package/build/cjs/hooks/usePopper.js +93 -0
- package/build/cjs/hooks/usePopper.js.map +7 -0
- package/build/cjs/hooks/usePopupState.d.ts +8 -0
- package/build/cjs/hooks/usePopupState.js +62 -0
- package/build/cjs/hooks/usePopupState.js.map +7 -0
- package/build/cjs/hooks/useTimer.d.ts +1 -0
- package/build/cjs/hooks/useTimer.js +44 -0
- package/build/cjs/hooks/useTimer.js.map +7 -0
- package/build/cjs/hooks/useTranslation.d.ts +2 -0
- package/build/cjs/hooks/useTranslation.js +32 -0
- package/build/cjs/hooks/useTranslation.js.map +7 -0
- package/build/cjs/i18n/en.js +124 -0
- package/build/cjs/i18n/en.js.map +7 -0
- package/build/cjs/i18n/ru.js +124 -0
- package/build/cjs/i18n/ru.js.map +7 -0
- package/build/cjs/index.d.ts +28 -0
- package/build/cjs/index.js +48 -0
- package/build/cjs/index.js.map +7 -0
- package/build/cjs/models/index.d.ts +139 -0
- package/build/cjs/models/index.js +69 -0
- package/build/cjs/models/index.js.map +7 -0
- package/build/cjs/utils/index.d.ts +14 -0
- package/build/cjs/utils/index.js +109 -0
- package/build/cjs/utils/index.js.map +7 -0
- package/build/esm/components/BookmarkButton/BookmarkButton.css +12 -0
- package/build/esm/components/BookmarkButton/BookmarkButton.css.map +7 -0
- package/build/esm/components/BookmarkButton/BookmarkButton.js +25 -0
- package/build/esm/components/BookmarkButton/BookmarkButton.js.map +7 -0
- package/build/esm/components/BookmarkButton/index.js +3 -0
- package/build/esm/components/BookmarkButton/index.js.map +7 -0
- package/build/esm/components/Breadcrumbs/Breadcrumbs.css +35 -0
- package/build/esm/components/Breadcrumbs/Breadcrumbs.css.map +7 -0
- package/build/esm/components/Breadcrumbs/Breadcrumbs.js +27 -0
- package/build/esm/components/Breadcrumbs/Breadcrumbs.js.map +7 -0
- package/build/esm/components/Breadcrumbs/index.js +3 -0
- package/build/esm/components/Breadcrumbs/index.js.map +7 -0
- package/build/esm/components/ContributorAvatars/Avatars/Avatar.js +58 -0
- package/build/esm/components/ContributorAvatars/Avatars/Avatar.js.map +7 -0
- package/build/esm/components/ContributorAvatars/Avatars/AvatarWithDescription.js +32 -0
- package/build/esm/components/ContributorAvatars/Avatars/AvatarWithDescription.js.map +7 -0
- package/build/esm/components/ContributorAvatars/Avatars/Details.js +46 -0
- package/build/esm/components/ContributorAvatars/Avatars/Details.js.map +7 -0
- package/build/esm/components/ContributorAvatars/Avatars/HiddenAvatars.js +39 -0
- package/build/esm/components/ContributorAvatars/Avatars/HiddenAvatars.js.map +7 -0
- package/build/esm/components/ContributorAvatars/ContributorAvatars.css +135 -0
- package/build/esm/components/ContributorAvatars/ContributorAvatars.css.map +7 -0
- package/build/esm/components/ContributorAvatars/ContributorAvatars.js +53 -0
- package/build/esm/components/ContributorAvatars/ContributorAvatars.js.map +7 -0
- package/build/esm/components/ContributorAvatars/index.js +7 -0
- package/build/esm/components/ContributorAvatars/index.js.map +7 -0
- package/build/esm/components/ContributorAvatars/models.js +10 -0
- package/build/esm/components/ContributorAvatars/models.js.map +7 -0
- package/build/esm/components/ContributorAvatars/utils.js +18 -0
- package/build/esm/components/ContributorAvatars/utils.js.map +7 -0
- package/build/esm/components/Contributors/Contributors.css +12 -0
- package/build/esm/components/Contributors/Contributors.css.map +7 -0
- package/build/esm/components/Contributors/Contributors.js +17 -0
- package/build/esm/components/Contributors/Contributors.js.map +7 -0
- package/build/esm/components/Control/Control.css +15 -0
- package/build/esm/components/Control/Control.css.map +7 -0
- package/build/esm/components/Control/Control.js +64 -0
- package/build/esm/components/Control/Control.js.map +7 -0
- package/build/esm/components/Control/index.js +7 -0
- package/build/esm/components/Control/index.js.map +7 -0
- package/build/esm/components/Controls/Controls.css +50 -0
- package/build/esm/components/Controls/Controls.css.map +7 -0
- package/build/esm/components/Controls/Controls.js +146 -0
- package/build/esm/components/Controls/Controls.js.map +7 -0
- package/build/esm/components/Controls/ControlsLayout.js +37 -0
- package/build/esm/components/Controls/ControlsLayout.js.map +7 -0
- package/build/esm/components/Controls/index.js +10 -0
- package/build/esm/components/Controls/index.js.map +7 -0
- package/build/esm/components/Controls/single-controls/DividerControl/DividerControl.css +21 -0
- package/build/esm/components/Controls/single-controls/DividerControl/DividerControl.css.map +7 -0
- package/build/esm/components/Controls/single-controls/DividerControl/DividerControl.js +15 -0
- package/build/esm/components/Controls/single-controls/DividerControl/DividerControl.js.map +7 -0
- package/build/esm/components/Controls/single-controls/EditControl.js +42 -0
- package/build/esm/components/Controls/single-controls/EditControl.js.map +7 -0
- package/build/esm/components/Controls/single-controls/FullScreenControl.js +51 -0
- package/build/esm/components/Controls/single-controls/FullScreenControl.js.map +7 -0
- package/build/esm/components/Controls/single-controls/LangControl.js +91 -0
- package/build/esm/components/Controls/single-controls/LangControl.js.map +7 -0
- package/build/esm/components/Controls/single-controls/PdfControl.js +29 -0
- package/build/esm/components/Controls/single-controls/PdfControl.js.map +7 -0
- package/build/esm/components/Controls/single-controls/SettingsControl/SettingsControl.css +49 -0
- package/build/esm/components/Controls/single-controls/SettingsControl/SettingsControl.css.map +7 -0
- package/build/esm/components/Controls/single-controls/SettingsControl/SettingsControl.js +167 -0
- package/build/esm/components/Controls/single-controls/SettingsControl/SettingsControl.js.map +7 -0
- package/build/esm/components/Controls/single-controls/SinglePageControl.js +36 -0
- package/build/esm/components/Controls/single-controls/SinglePageControl.js.map +7 -0
- package/build/esm/components/Controls/single-controls/index.js +18 -0
- package/build/esm/components/Controls/single-controls/index.js.map +7 -0
- package/build/esm/components/Controls/single-controls/utils.js +9 -0
- package/build/esm/components/Controls/single-controls/utils.js.map +7 -0
- package/build/esm/components/DocLayout/DocLayout.css +102 -0
- package/build/esm/components/DocLayout/DocLayout.css.map +7 -0
- package/build/esm/components/DocLayout/DocLayout.js +86 -0
- package/build/esm/components/DocLayout/DocLayout.js.map +7 -0
- package/build/esm/components/DocLayout/index.js +3 -0
- package/build/esm/components/DocLayout/index.js.map +7 -0
- package/build/esm/components/DocLeadingPage/DocLeadingPage.css +93 -0
- package/build/esm/components/DocLeadingPage/DocLeadingPage.css.map +7 -0
- package/build/esm/components/DocLeadingPage/DocLeadingPage.js +78 -0
- package/build/esm/components/DocLeadingPage/DocLeadingPage.js.map +7 -0
- package/build/esm/components/DocLeadingPage/index.js +3 -0
- package/build/esm/components/DocLeadingPage/index.js.map +7 -0
- package/build/esm/components/DocPage/DocPage.css +231 -0
- package/build/esm/components/DocPage/DocPage.css.map +7 -0
- package/build/esm/components/DocPage/DocPage.js +436 -0
- package/build/esm/components/DocPage/DocPage.js.map +7 -0
- package/build/esm/components/DocPage/index.js +7 -0
- package/build/esm/components/DocPage/index.js.map +7 -0
- package/build/esm/components/DocPageTitle/DocPageTitle.css +10 -0
- package/build/esm/components/DocPageTitle/DocPageTitle.css.map +7 -0
- package/build/esm/components/DocPageTitle/DocPageTitle.js +19 -0
- package/build/esm/components/DocPageTitle/DocPageTitle.js.map +7 -0
- package/build/esm/components/DocPageTitle/index.js +3 -0
- package/build/esm/components/DocPageTitle/index.js.map +7 -0
- package/build/esm/components/ErrorBoundary/ErrorBoundary.js +25 -0
- package/build/esm/components/ErrorBoundary/ErrorBoundary.js.map +7 -0
- package/build/esm/components/ErrorBoundary/index.js +7 -0
- package/build/esm/components/ErrorBoundary/index.js.map +7 -0
- package/build/esm/components/ErrorPage/ErrorPage.css +65 -0
- package/build/esm/components/ErrorPage/ErrorPage.css.map +7 -0
- package/build/esm/components/ErrorPage/ErrorPage.js +52 -0
- package/build/esm/components/ErrorPage/ErrorPage.js.map +7 -0
- package/build/esm/components/ErrorPage/index.js +7 -0
- package/build/esm/components/ErrorPage/index.js.map +7 -0
- package/build/esm/components/Feedback/Feedback.css +109 -0
- package/build/esm/components/Feedback/Feedback.css.map +7 -0
- package/build/esm/components/Feedback/Feedback.js +132 -0
- package/build/esm/components/Feedback/Feedback.js.map +7 -0
- package/build/esm/components/Feedback/controls/DislikeControl.js +38 -0
- package/build/esm/components/Feedback/controls/DislikeControl.js.map +7 -0
- package/build/esm/components/Feedback/controls/DislikeVariantsPopup.js +128 -0
- package/build/esm/components/Feedback/controls/DislikeVariantsPopup.js.map +7 -0
- package/build/esm/components/Feedback/controls/LikeControl.js +50 -0
- package/build/esm/components/Feedback/controls/LikeControl.js.map +7 -0
- package/build/esm/components/Feedback/controls/SuccessPopup.js +36 -0
- package/build/esm/components/Feedback/controls/SuccessPopup.js.map +7 -0
- package/build/esm/components/Feedback/index.js +7 -0
- package/build/esm/components/Feedback/index.js.map +7 -0
- package/build/esm/components/HTML/HTML.js +15 -0
- package/build/esm/components/HTML/HTML.js.map +7 -0
- package/build/esm/components/HTML/index.js +3 -0
- package/build/esm/components/HTML/index.js.map +7 -0
- package/build/esm/components/Link.js +10 -0
- package/build/esm/components/Link.js.map +7 -0
- package/build/esm/components/Mark/Mark.css +22 -0
- package/build/esm/components/Mark/Mark.css.map +7 -0
- package/build/esm/components/Mark/Mark.js +12 -0
- package/build/esm/components/Mark/Mark.js.map +7 -0
- package/build/esm/components/Mark/index.js +3 -0
- package/build/esm/components/Mark/index.js.map +7 -0
- package/build/esm/components/MiniToc/MiniToc.css +44 -0
- package/build/esm/components/MiniToc/MiniToc.css.map +7 -0
- package/build/esm/components/MiniToc/MiniToc.js +40 -0
- package/build/esm/components/MiniToc/MiniToc.js.map +7 -0
- package/build/esm/components/MiniToc/index.js +7 -0
- package/build/esm/components/MiniToc/index.js.map +7 -0
- package/build/esm/components/OutsideClick/OutsideClick.js +25 -0
- package/build/esm/components/OutsideClick/OutsideClick.js.map +7 -0
- package/build/esm/components/OutsideClick/index.js +7 -0
- package/build/esm/components/OutsideClick/index.js.map +7 -0
- package/build/esm/components/Paginator/Paginator.css +45 -0
- package/build/esm/components/Paginator/Paginator.css.map +7 -0
- package/build/esm/components/Paginator/Paginator.js +101 -0
- package/build/esm/components/Paginator/Paginator.js.map +7 -0
- package/build/esm/components/Paginator/index.js +7 -0
- package/build/esm/components/Paginator/index.js.map +7 -0
- package/build/esm/components/Scrollspy/Scrollspy.js +228 -0
- package/build/esm/components/Scrollspy/Scrollspy.js.map +7 -0
- package/build/esm/components/Scrollspy/index.js +3 -0
- package/build/esm/components/Scrollspy/index.js.map +7 -0
- package/build/esm/components/SearchBar/SearchBar.css +59 -0
- package/build/esm/components/SearchBar/SearchBar.css.map +7 -0
- package/build/esm/components/SearchBar/SearchBar.js +57 -0
- package/build/esm/components/SearchBar/SearchBar.js.map +7 -0
- package/build/esm/components/SearchBar/constants.js +18 -0
- package/build/esm/components/SearchBar/constants.js.map +7 -0
- package/build/esm/components/SearchBar/hooks.js +271 -0
- package/build/esm/components/SearchBar/hooks.js.map +7 -0
- package/build/esm/components/SearchBar/index.js +10 -0
- package/build/esm/components/SearchBar/index.js.map +7 -0
- package/build/esm/components/SearchBar/utils.js +77 -0
- package/build/esm/components/SearchBar/utils.js.map +7 -0
- package/build/esm/components/SearchBar/withHighlightedSearchWords.js +97 -0
- package/build/esm/components/SearchBar/withHighlightedSearchWords.js.map +7 -0
- package/build/esm/components/SearchItem/SearchItem.css +88 -0
- package/build/esm/components/SearchItem/SearchItem.css.map +7 -0
- package/build/esm/components/SearchItem/SearchItem.js +60 -0
- package/build/esm/components/SearchItem/SearchItem.js.map +7 -0
- package/build/esm/components/SearchItem/index.js +7 -0
- package/build/esm/components/SearchItem/index.js.map +7 -0
- package/build/esm/components/SearchPage/SearchPage.css +43 -0
- package/build/esm/components/SearchPage/SearchPage.css.map +7 -0
- package/build/esm/components/SearchPage/SearchPage.js +134 -0
- package/build/esm/components/SearchPage/SearchPage.js.map +7 -0
- package/build/esm/components/SearchPage/index.js +7 -0
- package/build/esm/components/SearchPage/index.js.map +7 -0
- package/build/esm/components/StageLabel/StageLabel.js +19 -0
- package/build/esm/components/StageLabel/StageLabel.js.map +7 -0
- package/build/esm/components/StageLabel/index.js +3 -0
- package/build/esm/components/StageLabel/index.js.map +7 -0
- package/build/esm/components/Subscribe/Subscribe.css +98 -0
- package/build/esm/components/Subscribe/Subscribe.css.map +7 -0
- package/build/esm/components/Subscribe/Subscribe.js +105 -0
- package/build/esm/components/Subscribe/Subscribe.js.map +7 -0
- package/build/esm/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.js +30 -0
- package/build/esm/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.js.map +7 -0
- package/build/esm/components/Subscribe/SubscribeSuccessPopup/index.js +6 -0
- package/build/esm/components/Subscribe/SubscribeSuccessPopup/index.js.map +7 -0
- package/build/esm/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.js +95 -0
- package/build/esm/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.js.map +7 -0
- package/build/esm/components/Subscribe/SubscribeVariantsPopup/index.js +6 -0
- package/build/esm/components/Subscribe/SubscribeVariantsPopup/index.js.map +7 -0
- package/build/esm/components/Subscribe/index.js +7 -0
- package/build/esm/components/Subscribe/index.js.map +7 -0
- package/build/esm/components/Subscribe/utils.js +13 -0
- package/build/esm/components/Subscribe/utils.js.map +7 -0
- package/build/esm/components/Text/Text.js +23 -0
- package/build/esm/components/Text/Text.js.map +7 -0
- package/build/esm/components/Text/index.js +3 -0
- package/build/esm/components/Text/index.js.map +7 -0
- package/build/esm/components/Toc/Toc.css +102 -0
- package/build/esm/components/Toc/Toc.css.map +7 -0
- package/build/esm/components/Toc/Toc.js +244 -0
- package/build/esm/components/Toc/Toc.js.map +7 -0
- package/build/esm/components/Toc/TocItemRegistry.js +60 -0
- package/build/esm/components/Toc/TocItemRegistry.js.map +7 -0
- package/build/esm/components/Toc/index.js +7 -0
- package/build/esm/components/Toc/index.js.map +7 -0
- package/build/esm/components/TocItem/TocItem.css +39 -0
- package/build/esm/components/TocItem/TocItem.css.map +7 -0
- package/build/esm/components/TocItem/TocItem.js +74 -0
- package/build/esm/components/TocItem/TocItem.js.map +7 -0
- package/build/esm/components/TocItem/index.js +7 -0
- package/build/esm/components/TocItem/index.js.map +7 -0
- package/build/esm/components/TocNavPanel/TocNavPanel.css +64 -0
- package/build/esm/components/TocNavPanel/TocNavPanel.css.map +7 -0
- package/build/esm/components/TocNavPanel/TocNavPanel.js +63 -0
- package/build/esm/components/TocNavPanel/TocNavPanel.js.map +7 -0
- package/build/esm/components/TocNavPanel/index.js +7 -0
- package/build/esm/components/TocNavPanel/index.js.map +7 -0
- package/build/esm/components/ToggleArrow/ToggleArrow.css +24 -0
- package/build/esm/components/ToggleArrow/ToggleArrow.css.map +7 -0
- package/build/esm/components/ToggleArrow/ToggleArrow.js +18 -0
- package/build/esm/components/ToggleArrow/ToggleArrow.js.map +7 -0
- package/build/esm/components/ToggleArrow/index.js +3 -0
- package/build/esm/components/ToggleArrow/index.js.map +7 -0
- package/build/esm/config/i18n.js +37 -0
- package/build/esm/config/i18n.js.map +7 -0
- package/build/esm/config/index.js +30 -0
- package/build/esm/config/index.js.map +7 -0
- package/build/esm/constants.js +25 -0
- package/build/esm/constants.js.map +7 -0
- package/build/esm/hooks/index.js +6 -0
- package/build/esm/hooks/index.js.map +7 -0
- package/build/esm/hooks/usePopper.js +62 -0
- package/build/esm/hooks/usePopper.js.map +7 -0
- package/build/esm/hooks/usePopupState.js +41 -0
- package/build/esm/hooks/usePopupState.js.map +7 -0
- package/build/esm/hooks/useTimer.js +23 -0
- package/build/esm/hooks/useTimer.js.map +7 -0
- package/build/esm/hooks/useTranslation.js +11 -0
- package/build/esm/hooks/useTranslation.js.map +7 -0
- package/build/esm/i18n/en.js +137 -0
- package/build/esm/i18n/en.js.map +7 -0
- package/build/esm/i18n/ru.js +137 -0
- package/build/esm/i18n/ru.js.map +7 -0
- package/build/esm/index.js +30 -0
- package/build/esm/index.js.map +7 -0
- package/build/esm/models/index.js +48 -0
- package/build/esm/models/index.js.map +7 -0
- package/build/esm/utils/index.js +88 -0
- package/build/esm/utils/index.js.map +7 -0
- package/build/index.css +197 -0
- package/build/index.css.map +7 -0
- package/build/themes/common/index.css +1170 -0
- package/build/themes/common/index.css.map +7 -0
- package/package.json +145 -0
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/* src/components/Paginator/Paginator.scss */
|
|
2
|
+
.Paginator {
|
|
3
|
+
margin: 0;
|
|
4
|
+
padding: 0;
|
|
5
|
+
list-style: none;
|
|
6
|
+
display: flex;
|
|
7
|
+
align-items: center;
|
|
8
|
+
}
|
|
9
|
+
.Paginator__item {
|
|
10
|
+
display: inline-flex;
|
|
11
|
+
align-items: center;
|
|
12
|
+
justify-content: center;
|
|
13
|
+
min-width: 28px;
|
|
14
|
+
min-height: 28px;
|
|
15
|
+
margin: 4px;
|
|
16
|
+
color: var(--g-color-text-primary);
|
|
17
|
+
font-size: var(--g-text-body-1-font-size);
|
|
18
|
+
line-height: var(--g-text-body-1-line-height);
|
|
19
|
+
}
|
|
20
|
+
.Paginator__item_type_prev {
|
|
21
|
+
margin-left: -6px;
|
|
22
|
+
}
|
|
23
|
+
.Paginator__item_type_prev .Paginator__icon {
|
|
24
|
+
transform: rotate(180deg);
|
|
25
|
+
}
|
|
26
|
+
.Paginator__item_type_dots {
|
|
27
|
+
min-width: 0;
|
|
28
|
+
color: var(--g-color-text-secondary);
|
|
29
|
+
}
|
|
30
|
+
.Paginator__item_type_page {
|
|
31
|
+
cursor: pointer;
|
|
32
|
+
border-radius: 14px;
|
|
33
|
+
}
|
|
34
|
+
.Paginator__item_type_page:hover {
|
|
35
|
+
background: var(--g-color-base-simple-hover);
|
|
36
|
+
}
|
|
37
|
+
.Paginator__item_type_page.Paginator__item_active {
|
|
38
|
+
color: var(--g-color-text-light-primary);
|
|
39
|
+
background: var(--g-color-base-brand);
|
|
40
|
+
cursor: default;
|
|
41
|
+
}
|
|
42
|
+
.Paginator__item_type_next {
|
|
43
|
+
margin-right: -6px;
|
|
44
|
+
}
|
|
45
|
+
/*# sourceMappingURL=Paginator.css.map */
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Paginator/Users/3y3k0/doctools/docs-components/src/components/Paginator/Paginator.scss", "../../../../src/components/Paginator/Users/3y3k0/doctools/docs-components/src/styles/mixins.scss", "../../../../src/components/Paginator/%3Cinput%20css%20pk6c7-%3E"],
|
|
4
|
+
"sourcesContent": ["@import '../../styles/variables';\n@import '../../styles/mixins';\n\n.Paginator {\n $block: &;\n\n @include reset-list-style();\n\n display: flex;\n align-items: center;\n\n &__item {\n $item: &;\n\n display: inline-flex;\n align-items: center;\n justify-content: center;\n\n min-width: 28px;\n min-height: 28px;\n margin: 4px;\n\n color: var(--g-color-text-primary);\n @include text-size(body-1);\n\n &_type {\n &_prev {\n margin-left: -6px;\n\n #{$block}__icon {\n transform: rotate(180deg);\n }\n }\n\n &_dots {\n min-width: 0;\n color: var(--g-color-text-secondary);\n }\n\n &_page {\n cursor: pointer;\n border-radius: 14px;\n\n &:hover {\n background: var(--g-color-base-simple-hover);\n }\n\n &#{$item}_active {\n color: var(--g-color-text-light-primary);\n background: var(--g-color-base-brand);\n cursor: default;\n }\n }\n\n &_next {\n margin-right: -6px;\n }\n }\n }\n}\n", "@import './variables';\n\n@mixin text-size($name) {\n font-size: var(--g-text-#{$name}-font-size);\n line-height: var(--g-text-#{$name}-line-height);\n}\n\n@mixin reset-list-style() {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n@mixin fixAnchorPosition($offset: 0px) {\n padding-top: calc(var(--dc-header-height, #{$headerHeight}));\n margin-top: calc(#{$offset} - var(--dc-header-height, #{$headerHeight}));\n}\n\n@mixin reset-link-style() {\n color: inherit;\n text-decoration: none;\n}\n\n@mixin islands-focus() {\n outline: none;\n\n .utilityfocus &:focus {\n outline: 2px solid #ffdb4d;\n }\n}\n\n@mixin link() {\n @include islands-focus();\n\n color: var(--g-color-text-link);\n text-decoration: none;\n cursor: pointer;\n\n &:hover,\n &:active {\n color: var(--g-color-text-link-hover);\n }\n}\n\n@mixin heading1() {\n @include text-size(display-3);\n font-weight: 500;\n\n @media (max-width: map-get($screenBreakpoints, 'md') - 1) {\n @include text-size(display-2);\n }\n}\n\n@mixin heading2() {\n @include text-size(display-1);\n font-weight: 500;\n}\n\n@mixin heading3() {\n @include text-size(header-2);\n font-weight: 500;\n}\n\n@mixin heading4() {\n @include text-size(header-1);\n font-weight: 500;\n}\n\n@mixin heading5() {\n @include text-size(body-3);\n font-weight: 500;\n}\n\n@mixin heading6() {\n @include text-size(body-3);\n font-weight: 400;\n}\n\n@mixin contributors-text() {\n font-size: 13px;\n font-weight: 400;\n margin-right: 5px;\n align-self: center;\n}\n\n@mixin text-body-1() {\n font-size: var(--g-text-body-1-font-size);\n line-height: var(--g-text-body-1-line-height);\n font-weight: var(--g-text-body-font-weight);\n}\n\n@mixin desktop-only() {\n @media (max-width: map-get($screenBreakpoints, 'md') - 1) {\n display: none;\n }\n}\n\n@mixin desktop-tablet-only() {\n @media (max-width: map-get($screenBreakpoints, 'sm') - 1) {\n display: none;\n }\n}\n\n@mixin mobile-tablet-only() {\n @media (min-width: map-get($screenBreakpoints, 'md')) {\n display: none;\n }\n}\n\n@mixin mobile-only() {\n @media (min-width: map-get($screenBreakpoints, 'sm')) {\n display: none;\n }\n}\n", ".Paginator {\n margin: 0;\n padding: 0;\n list-style: none;\n display: flex;\n align-items: center;\n}\n.Paginator__item {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n min-width: 28px;\n min-height: 28px;\n margin: 4px;\n color: var(--g-color-text-primary);\n font-size: var(--g-text-body-1-font-size);\n line-height: var(--g-text-body-1-line-height);\n}\n.Paginator__item_type_prev {\n margin-left: -6px;\n}\n.Paginator__item_type_prev .Paginator__icon {\n transform: rotate(180deg);\n}\n.Paginator__item_type_dots {\n min-width: 0;\n color: var(--g-color-text-secondary);\n}\n.Paginator__item_type_page {\n cursor: pointer;\n border-radius: 14px;\n}\n.Paginator__item_type_page:hover {\n background: var(--g-color-base-simple-hover);\n}\n.Paginator__item_type_page.Paginator__item_active {\n color: var(--g-color-text-light-primary);\n background: var(--g-color-base-brand);\n cursor: default;\n}\n.Paginator__item_type_next {\n margin-right: -6px;\n}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL1VzZXJzLzN5M2swL2RvY3Rvb2xzL2RvY3MtY29tcG9uZW50cy9zcmMvY29tcG9uZW50cy9QYWdpbmF0b3IiLCJzb3VyY2VzIjpbIlBhZ2luYXRvci5zY3NzIiwiLi4vLi4vc3R5bGVzL21peGlucy5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBO0VDS0k7RUFDQTtFQUNBO0VERkE7RUFDQTs7QUFFQTtFQUdJO0VBQ0E7RUFDQTtFQUVBO0VBQ0E7RUFDQTtFQUVBO0VDbkJKO0VBQ0E7O0FEc0JRO0VBQ0k7O0FBRUE7RUFDSTs7QUFJUjtFQUNJO0VBQ0E7O0FBR0o7RUFDSTtFQUNBOztBQUVBO0VBQ0k7O0FBR0o7RUFDSTtFQUNBO0VBQ0E7O0FBSVI7RUFDSSIsInNvdXJjZXNDb250ZW50IjpbIkBpbXBvcnQgJy4uLy4uL3N0eWxlcy92YXJpYWJsZXMnO1xuQGltcG9ydCAnLi4vLi4vc3R5bGVzL21peGlucyc7XG5cbi5QYWdpbmF0b3Ige1xuICAgICRibG9jazogJjtcblxuICAgIEBpbmNsdWRlIHJlc2V0LWxpc3Qtc3R5bGUoKTtcblxuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICAgICZfX2l0ZW0ge1xuICAgICAgICAkaXRlbTogJjtcblxuICAgICAgICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cbiAgICAgICAgbWluLXdpZHRoOiAyOHB4O1xuICAgICAgICBtaW4taGVpZ2h0OiAyOHB4O1xuICAgICAgICBtYXJnaW46IDRweDtcblxuICAgICAgICBjb2xvcjogdmFyKC0tZy1jb2xvci10ZXh0LXByaW1hcnkpO1xuICAgICAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0xKTtcblxuICAgICAgICAmX3R5cGUge1xuICAgICAgICAgICAgJl9wcmV2IHtcbiAgICAgICAgICAgICAgICBtYXJnaW4tbGVmdDogLTZweDtcblxuICAgICAgICAgICAgICAgICN7JGJsb2NrfV9faWNvbiB7XG4gICAgICAgICAgICAgICAgICAgIHRyYW5zZm9ybTogcm90YXRlKDE4MGRlZyk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAmX2RvdHMge1xuICAgICAgICAgICAgICAgIG1pbi13aWR0aDogMDtcbiAgICAgICAgICAgICAgICBjb2xvcjogdmFyKC0tZy1jb2xvci10ZXh0LXNlY29uZGFyeSk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICZfcGFnZSB7XG4gICAgICAgICAgICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgICAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDE0cHg7XG5cbiAgICAgICAgICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZDogdmFyKC0tZy1jb2xvci1iYXNlLXNpbXBsZS1ob3Zlcik7XG4gICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgJiN7JGl0ZW19X2FjdGl2ZSB7XG4gICAgICAgICAgICAgICAgICAgIGNvbG9yOiB2YXIoLS1nLWNvbG9yLXRleHQtbGlnaHQtcHJpbWFyeSk7XG4gICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQ6IHZhcigtLWctY29sb3ItYmFzZS1icmFuZCk7XG4gICAgICAgICAgICAgICAgICAgIGN1cnNvcjogZGVmYXVsdDtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICZfbmV4dCB7XG4gICAgICAgICAgICAgICAgbWFyZ2luLXJpZ2h0OiAtNnB4O1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxufVxuIiwiQGltcG9ydCAnLi92YXJpYWJsZXMnO1xuXG5AbWl4aW4gdGV4dC1zaXplKCRuYW1lKSB7XG4gICAgZm9udC1zaXplOiB2YXIoLS1nLXRleHQtI3skbmFtZX0tZm9udC1zaXplKTtcbiAgICBsaW5lLWhlaWdodDogdmFyKC0tZy10ZXh0LSN7JG5hbWV9LWxpbmUtaGVpZ2h0KTtcbn1cblxuQG1peGluIHJlc2V0LWxpc3Qtc3R5bGUoKSB7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG4gICAgbGlzdC1zdHlsZTogbm9uZTtcbn1cblxuQG1peGluIGZpeEFuY2hvclBvc2l0aW9uKCRvZmZzZXQ6IDBweCkge1xuICAgIHBhZGRpbmctdG9wOiBjYWxjKHZhcigtLWRjLWhlYWRlci1oZWlnaHQsICN7JGhlYWRlckhlaWdodH0pKTtcbiAgICBtYXJnaW4tdG9wOiBjYWxjKCN7JG9mZnNldH0gLSB2YXIoLS1kYy1oZWFkZXItaGVpZ2h0LCAjeyRoZWFkZXJIZWlnaHR9KSk7XG59XG5cbkBtaXhpbiByZXNldC1saW5rLXN0eWxlKCkge1xuICAgIGNvbG9yOiBpbmhlcml0O1xuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbn1cblxuQG1peGluIGlzbGFuZHMtZm9jdXMoKSB7XG4gICAgb3V0bGluZTogbm9uZTtcblxuICAgIC51dGlsaXR5Zm9jdXMgJjpmb2N1cyB7XG4gICAgICAgIG91dGxpbmU6IDJweCBzb2xpZCAjZmZkYjRkO1xuICAgIH1cbn1cblxuQG1peGluIGxpbmsoKSB7XG4gICAgQGluY2x1ZGUgaXNsYW5kcy1mb2N1cygpO1xuXG4gICAgY29sb3I6IHZhcigtLWctY29sb3ItdGV4dC1saW5rKTtcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuXG4gICAgJjpob3ZlcixcbiAgICAmOmFjdGl2ZSB7XG4gICAgICAgIGNvbG9yOiB2YXIoLS1nLWNvbG9yLXRleHQtbGluay1ob3Zlcik7XG4gICAgfVxufVxuXG5AbWl4aW4gaGVhZGluZzEoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGRpc3BsYXktMyk7XG4gICAgZm9udC13ZWlnaHQ6IDUwMDtcblxuICAgIEBtZWRpYSAobWF4LXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykgLSAxKSB7XG4gICAgICAgIEBpbmNsdWRlIHRleHQtc2l6ZShkaXNwbGF5LTIpO1xuICAgIH1cbn1cblxuQG1peGluIGhlYWRpbmcyKCkge1xuICAgIEBpbmNsdWRlIHRleHQtc2l6ZShkaXNwbGF5LTEpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nMygpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoaGVhZGVyLTIpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nNCgpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoaGVhZGVyLTEpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nNSgpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0zKTtcbiAgICBmb250LXdlaWdodDogNTAwO1xufVxuXG5AbWl4aW4gaGVhZGluZzYoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGJvZHktMyk7XG4gICAgZm9udC13ZWlnaHQ6IDQwMDtcbn1cblxuQG1peGluIGNvbnRyaWJ1dG9ycy10ZXh0KCkge1xuICAgIGZvbnQtc2l6ZTogMTNweDtcbiAgICBmb250LXdlaWdodDogNDAwO1xuICAgIG1hcmdpbi1yaWdodDogNXB4O1xuICAgIGFsaWduLXNlbGY6IGNlbnRlcjtcbn1cblxuQG1peGluIHRleHQtYm9keS0xKCkge1xuICAgIGZvbnQtc2l6ZTogdmFyKC0tZy10ZXh0LWJvZHktMS1mb250LXNpemUpO1xuICAgIGxpbmUtaGVpZ2h0OiB2YXIoLS1nLXRleHQtYm9keS0xLWxpbmUtaGVpZ2h0KTtcbiAgICBmb250LXdlaWdodDogdmFyKC0tZy10ZXh0LWJvZHktZm9udC13ZWlnaHQpO1xufVxuXG5AbWl4aW4gZGVza3RvcC1vbmx5KCkge1xuICAgIEBtZWRpYSAobWF4LXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykgLSAxKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuXG5AbWl4aW4gZGVza3RvcC10YWJsZXQtb25seSgpIHtcbiAgICBAbWVkaWEgKG1heC13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdzbScpIC0gMSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cblxuQG1peGluIG1vYmlsZS10YWJsZXQtb25seSgpIHtcbiAgICBAbWVkaWEgKG1pbi13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdtZCcpKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuXG5AbWl4aW4gbW9iaWxlLW9ubHkoKSB7XG4gICAgQG1lZGlhIChtaW4td2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnc20nKSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cbiJdfQ== */"],
|
|
5
|
+
"mappings": ";AAGA,CAAA;ACKI,UAAA;AACA,WAAA;AACA,cAAA;ADFA,WAAA;AACA,eAAA;AEHJ;AFKI,CAAA;AAGI,WAAA;AACA,eAAA;AACA,mBAAA;AAEA,aAAA;AACA,cAAA;AACA,UAAA;AAEA,SAAA,IAAA;ACnBJ,aAAA,IAAA;AACA,eAAA,IAAA;ACaJ;AFSY,CAAA;AACI,eAAA;AEPhB;AFSgB,CAHJ,0BAGI,CAAA;AACI,aAAA,OAAA;AEPpB;AFWY,CAAA;AACI,aAAA;AACA,SAAA,IAAA;AEThB;AFYY,CAAA;AACI,UAAA;AACA,iBAAA;AEVhB;AFYgB,CAJJ,yBAII;AACI,cAAA,IAAA;AEVpB;AFagB,CARJ,yBAQI,CAAA;AACI,SAAA,IAAA;AACA,cAAA,IAAA;AACA,UAAA;AEXpB;AFeY,CAAA;AACI,gBAAA;AEbhB;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
// src/components/Paginator/Paginator.tsx
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { Button, Icon } from "@gravity-ui/uikit";
|
|
4
|
+
import block from "bem-cn-lite";
|
|
5
|
+
import ArrowRightIcon from "@gravity-ui/icons/svgs/arrow-right.svg";
|
|
6
|
+
import "./Paginator.css";
|
|
7
|
+
var b = block("Paginator");
|
|
8
|
+
var MOBILE_VISIBLE_PAGES = 1;
|
|
9
|
+
var DESKTOP_VISIBLE_PAGES = 3;
|
|
10
|
+
var MAX_VISIBLE_PAGES = 6;
|
|
11
|
+
var Paginator = ({
|
|
12
|
+
page = 1,
|
|
13
|
+
itemsPerPage = 10,
|
|
14
|
+
totalItems,
|
|
15
|
+
maxPages = Infinity,
|
|
16
|
+
className,
|
|
17
|
+
isMobile = false,
|
|
18
|
+
onPageChange
|
|
19
|
+
}) => {
|
|
20
|
+
const getPagesCount = () => {
|
|
21
|
+
const totalPages = Math.ceil(totalItems / itemsPerPage);
|
|
22
|
+
return Math.min(totalPages, maxPages);
|
|
23
|
+
};
|
|
24
|
+
const pagesCount = getPagesCount();
|
|
25
|
+
if (pagesCount <= 1) {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
const renderPaginatorItem = ({ key, mods, content, onClick }) => {
|
|
29
|
+
return /* @__PURE__ */ React.createElement(
|
|
30
|
+
"li",
|
|
31
|
+
{
|
|
32
|
+
key: `page_${key}`,
|
|
33
|
+
className: b("item", mods),
|
|
34
|
+
onClick: onClick && onClick.bind(void 0, key)
|
|
35
|
+
},
|
|
36
|
+
content
|
|
37
|
+
);
|
|
38
|
+
};
|
|
39
|
+
const handlePageChange = (newPage) => {
|
|
40
|
+
if (onPageChange) {
|
|
41
|
+
onPageChange(newPage);
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
const handleArrowClick = (type) => {
|
|
45
|
+
let newPage = page;
|
|
46
|
+
if (type === "prev" && page > 1) {
|
|
47
|
+
newPage = page - 1;
|
|
48
|
+
} else if (type === "next" && page < pagesCount) {
|
|
49
|
+
newPage = page + 1;
|
|
50
|
+
}
|
|
51
|
+
if (newPage !== page) {
|
|
52
|
+
handlePageChange(newPage);
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
const handlePageClick = (index) => {
|
|
56
|
+
if (index !== page) {
|
|
57
|
+
handlePageChange(index);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
const getPageConfigs = () => {
|
|
61
|
+
const visiblePages = isMobile ? MOBILE_VISIBLE_PAGES : DESKTOP_VISIBLE_PAGES;
|
|
62
|
+
const pages2 = [];
|
|
63
|
+
for (let i = 1; i <= pagesCount; i++) {
|
|
64
|
+
if (pagesCount <= MAX_VISIBLE_PAGES || i <= visiblePages || i > pagesCount - visiblePages || i >= page - 1 && i <= page + 1) {
|
|
65
|
+
pages2.push({
|
|
66
|
+
key: i,
|
|
67
|
+
mods: { type: "page", active: page === i },
|
|
68
|
+
onClick: handlePageClick,
|
|
69
|
+
content: i
|
|
70
|
+
});
|
|
71
|
+
} else if (pages2.length > 0 && pages2[pages2.length - 1].key !== "dots") {
|
|
72
|
+
pages2.push({
|
|
73
|
+
key: "dots",
|
|
74
|
+
mods: { type: "dots" },
|
|
75
|
+
content: "..."
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
return pages2;
|
|
80
|
+
};
|
|
81
|
+
const arrowButton = (disable) => /* @__PURE__ */ React.createElement(Button, { className: b("icon"), size: "s", view: "flat", disabled: disable }, /* @__PURE__ */ React.createElement(Icon, { data: ArrowRightIcon, size: 16 }));
|
|
82
|
+
const pages = getPageConfigs();
|
|
83
|
+
pages.unshift({
|
|
84
|
+
key: "prev" /* Prev */,
|
|
85
|
+
mods: { type: "prev" },
|
|
86
|
+
onClick: handleArrowClick,
|
|
87
|
+
content: arrowButton(page === 1)
|
|
88
|
+
});
|
|
89
|
+
pages.push({
|
|
90
|
+
key: "next" /* Next */,
|
|
91
|
+
mods: { type: "next" },
|
|
92
|
+
onClick: handleArrowClick,
|
|
93
|
+
content: arrowButton(page === pagesCount)
|
|
94
|
+
});
|
|
95
|
+
return /* @__PURE__ */ React.createElement("ul", { className: b(null, className) }, pages.map(renderPaginatorItem));
|
|
96
|
+
};
|
|
97
|
+
var Paginator_default = Paginator;
|
|
98
|
+
export {
|
|
99
|
+
Paginator_default as default
|
|
100
|
+
};
|
|
101
|
+
//# sourceMappingURL=Paginator.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Paginator/Paginator.tsx"],
|
|
4
|
+
"sourcesContent": ["import React, {ReactNode} from 'react';\n\nimport {Button, Icon} from '@gravity-ui/uikit';\nimport block from 'bem-cn-lite';\n\nimport ArrowRightIcon from '@gravity-ui/icons/svgs/arrow-right.svg';\n\nimport './Paginator.scss';\n\nconst b = block('Paginator');\n\nconst MOBILE_VISIBLE_PAGES = 1;\nconst DESKTOP_VISIBLE_PAGES = 3;\nconst MAX_VISIBLE_PAGES = 6;\n\nexport interface PaginatorDefaultProps {\n page: number;\n maxPages?: number;\n onPageChange: (page: number) => void;\n}\n\nexport interface PaginatorExtraProps {\n className?: string;\n isMobile?: boolean;\n}\n\nexport interface Test {\n aaa: never;\n}\n\nexport interface TotalCountItems {\n totalItems: number;\n itemsPerPage?: number;\n}\n\nexport type PaginatorProps = PaginatorDefaultProps & TotalCountItems;\n\nexport type PaginatorInnerProps = PaginatorExtraProps & PaginatorProps;\n\ninterface Modifications {\n [name: string]: string | boolean | undefined;\n}\n\ninterface PaginatorItemProps<T> {\n key: T;\n mods: Modifications;\n content: ReactNode;\n onClick?: (key: T) => void;\n}\n\nenum ArrowType {\n Prev = 'prev',\n Next = 'next',\n}\n\nconst Paginator = ({\n page = 1,\n itemsPerPage = 10,\n totalItems,\n maxPages = Infinity,\n className,\n isMobile = false,\n onPageChange,\n}: PaginatorInnerProps) => {\n const getPagesCount = () => {\n const totalPages = Math.ceil(totalItems / itemsPerPage);\n\n return Math.min(totalPages, maxPages);\n };\n\n const pagesCount = getPagesCount();\n\n if (pagesCount <= 1) {\n return null;\n }\n\n const renderPaginatorItem = <T,>({key, mods, content, onClick}: PaginatorItemProps<T>) => {\n return (\n <li\n key={`page_${key}`}\n className={b('item', mods)}\n onClick={onClick && onClick.bind(this, key)}\n >\n {content}\n </li>\n );\n };\n\n const handlePageChange = (newPage: number) => {\n if (onPageChange) {\n onPageChange(newPage);\n }\n };\n\n const handleArrowClick = (type: string) => {\n let newPage = page;\n if (type === 'prev' && page > 1) {\n newPage = page - 1;\n } else if (type === 'next' && page < pagesCount) {\n newPage = page + 1;\n }\n if (newPage !== page) {\n handlePageChange(newPage);\n }\n };\n\n const handlePageClick = (index: number) => {\n if (index !== page) {\n handlePageChange(index);\n }\n };\n\n const getPageConfigs = () => {\n const visiblePages = isMobile ? MOBILE_VISIBLE_PAGES : DESKTOP_VISIBLE_PAGES;\n\n const pages = [];\n\n for (let i = 1; i <= pagesCount; i++) {\n if (\n pagesCount <= MAX_VISIBLE_PAGES ||\n i <= visiblePages ||\n i > pagesCount - visiblePages ||\n (i >= page - 1 && i <= page + 1)\n ) {\n pages.push({\n key: i,\n mods: {type: 'page', active: page === i},\n onClick: handlePageClick,\n content: i,\n });\n } else if (pages.length > 0 && pages[pages.length - 1].key !== 'dots') {\n pages.push({\n key: 'dots',\n mods: {type: 'dots'},\n content: '...',\n });\n }\n }\n\n return pages;\n };\n\n const arrowButton = (disable: boolean) => (\n <Button className={b('icon')} size=\"s\" view={'flat'} disabled={disable}>\n <Icon data={ArrowRightIcon} size={16} />\n </Button>\n );\n\n const pages = getPageConfigs() as PaginatorItemProps<string>[];\n\n pages.unshift({\n key: ArrowType.Prev,\n mods: {type: 'prev'},\n onClick: handleArrowClick,\n content: arrowButton(page === 1),\n });\n\n pages.push({\n key: ArrowType.Next,\n mods: {type: 'next'},\n onClick: handleArrowClick,\n content: arrowButton(page === pagesCount),\n });\n\n return <ul className={b(null, className)}>{pages.map(renderPaginatorItem)}</ul>;\n};\n\nexport default Paginator;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["pages"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Paginator/index.ts"],
|
|
4
|
+
"sourcesContent": ["export {default as Paginator} from './Paginator';\nexport * from './Paginator';\n"],
|
|
5
|
+
"mappings": ";AAAA,SAAmB,WAAXA,gBAA2B;AACnC,cAAc;",
|
|
6
|
+
"names": ["default"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
// src/components/Scrollspy/Scrollspy.tsx
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { debounce, isEqual } from "lodash";
|
|
4
|
+
import scrollIntoView from "scroll-into-view-if-needed";
|
|
5
|
+
var Scrollspy = class extends React.Component {
|
|
6
|
+
static defaultProps = {
|
|
7
|
+
currentClassName: "Scrollspy",
|
|
8
|
+
sectionOffset: 20,
|
|
9
|
+
headerHeight: 0
|
|
10
|
+
};
|
|
11
|
+
containerRef = React.createRef();
|
|
12
|
+
itemRefs = this.props.items.map(() => React.createRef());
|
|
13
|
+
scrollByClick;
|
|
14
|
+
firstItemIndexInView;
|
|
15
|
+
lastItemIndexInView;
|
|
16
|
+
constructor(props) {
|
|
17
|
+
super(props);
|
|
18
|
+
this.state = {
|
|
19
|
+
targetItems: [],
|
|
20
|
+
inViewState: []
|
|
21
|
+
};
|
|
22
|
+
this.scrollByClick = false;
|
|
23
|
+
this.firstItemIndexInView = -1;
|
|
24
|
+
this.lastItemIndexInView = -1;
|
|
25
|
+
}
|
|
26
|
+
componentDidMount() {
|
|
27
|
+
this.initItems();
|
|
28
|
+
window.addEventListener("scroll", this.handleScroll);
|
|
29
|
+
const containerEl = this.containerRef.current;
|
|
30
|
+
if (containerEl) {
|
|
31
|
+
containerEl.addEventListener("scroll", this.updateScrollValues);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
componentDidUpdate(prevProps, prevState) {
|
|
35
|
+
const { items, router } = this.props;
|
|
36
|
+
const { inViewState } = this.state;
|
|
37
|
+
if (!isEqual(inViewState, prevState.inViewState)) {
|
|
38
|
+
this.scrollToListItem();
|
|
39
|
+
}
|
|
40
|
+
if (!isEqual(items, prevProps.items) || prevProps.router.pathname !== router.pathname) {
|
|
41
|
+
this.initItems();
|
|
42
|
+
}
|
|
43
|
+
if (router.hash !== prevProps.router.hash) {
|
|
44
|
+
this.pauseScrollHandler();
|
|
45
|
+
this.saveActiveItems(router.hash);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
componentWillUnmount() {
|
|
49
|
+
window.removeEventListener("scroll", this.handleScroll);
|
|
50
|
+
const containerEl = this.containerRef.current;
|
|
51
|
+
if (containerEl) {
|
|
52
|
+
containerEl.removeEventListener("scroll", this.updateScrollValues);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
render() {
|
|
56
|
+
const { children, currentClassName, className } = this.props;
|
|
57
|
+
const { inViewState } = this.state;
|
|
58
|
+
const items = children.map((child, index) => {
|
|
59
|
+
if (!child) {
|
|
60
|
+
return null;
|
|
61
|
+
}
|
|
62
|
+
const ChildTag = child.type;
|
|
63
|
+
let childClassNames = child.props.className;
|
|
64
|
+
if (inViewState[index] && currentClassName.length > 0) {
|
|
65
|
+
childClassNames += ` ${currentClassName}`;
|
|
66
|
+
this.syncScroll(index);
|
|
67
|
+
}
|
|
68
|
+
return /* @__PURE__ */ React.createElement(
|
|
69
|
+
ChildTag,
|
|
70
|
+
{
|
|
71
|
+
key: child.key,
|
|
72
|
+
className: childClassNames,
|
|
73
|
+
onClick: this.handleSectionClick,
|
|
74
|
+
ref: this.itemRefs[index]
|
|
75
|
+
},
|
|
76
|
+
child.props.children
|
|
77
|
+
);
|
|
78
|
+
});
|
|
79
|
+
return /* @__PURE__ */ React.createElement("ul", { className, ref: this.containerRef }, items);
|
|
80
|
+
}
|
|
81
|
+
updateFirstItemIndexInView(maxItemsInView) {
|
|
82
|
+
this.firstItemIndexInView = Math.max(this.lastItemIndexInView - (maxItemsInView - 1), 0);
|
|
83
|
+
}
|
|
84
|
+
getContainerValues(containerEl) {
|
|
85
|
+
const { children } = this.props;
|
|
86
|
+
const childHeight = Math.round(containerEl.scrollHeight / children.length);
|
|
87
|
+
const maxItemsInView = Math.round(containerEl.clientHeight / childHeight);
|
|
88
|
+
return { childHeight, maxItemsInView };
|
|
89
|
+
}
|
|
90
|
+
updateScrollValues = () => {
|
|
91
|
+
const containerEl = this.containerRef.current;
|
|
92
|
+
if (!containerEl) {
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
const { childHeight, maxItemsInView } = this.getContainerValues(containerEl);
|
|
96
|
+
this.lastItemIndexInView = Math.round(containerEl.scrollTop / childHeight) + maxItemsInView - 1;
|
|
97
|
+
this.updateFirstItemIndexInView(maxItemsInView);
|
|
98
|
+
};
|
|
99
|
+
syncScroll(index) {
|
|
100
|
+
const { children } = this.props;
|
|
101
|
+
const containerEl = this.containerRef.current;
|
|
102
|
+
if (!containerEl) {
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
const { childHeight, maxItemsInView } = this.getContainerValues(containerEl);
|
|
106
|
+
if (this.lastItemIndexInView === -1) {
|
|
107
|
+
this.lastItemIndexInView = maxItemsInView - 1;
|
|
108
|
+
}
|
|
109
|
+
this.updateFirstItemIndexInView(maxItemsInView);
|
|
110
|
+
let itemInView = false;
|
|
111
|
+
if (index >= this.lastItemIndexInView) {
|
|
112
|
+
this.lastItemIndexInView = Math.min(index + 1, children.length - 1);
|
|
113
|
+
} else if (index <= this.firstItemIndexInView) {
|
|
114
|
+
this.lastItemIndexInView = Math.max(index + maxItemsInView - 2, maxItemsInView - 1);
|
|
115
|
+
} else {
|
|
116
|
+
itemInView = true;
|
|
117
|
+
}
|
|
118
|
+
this.updateFirstItemIndexInView(maxItemsInView);
|
|
119
|
+
const endIsNear = index + maxItemsInView / 2 > children.length;
|
|
120
|
+
if (itemInView) {
|
|
121
|
+
return;
|
|
122
|
+
} else if (endIsNear) {
|
|
123
|
+
containerEl.scrollTop = containerEl.scrollHeight;
|
|
124
|
+
} else {
|
|
125
|
+
containerEl.scrollTop = childHeight * this.firstItemIndexInView;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
scrollToListItem = () => {
|
|
129
|
+
if (!this.props.scrollToListItem) {
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
let itemIndex = this.state.inViewState.findIndex((isActive) => isActive);
|
|
133
|
+
if (itemIndex < 0) {
|
|
134
|
+
itemIndex = 0;
|
|
135
|
+
}
|
|
136
|
+
const ref = this.itemRefs[itemIndex] && this.itemRefs[itemIndex].current;
|
|
137
|
+
if (ref) {
|
|
138
|
+
scrollIntoView(ref, {
|
|
139
|
+
scrollMode: "if-needed",
|
|
140
|
+
block: "nearest",
|
|
141
|
+
inline: "nearest",
|
|
142
|
+
behavior: "smooth"
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
initItems() {
|
|
147
|
+
const { items } = this.props;
|
|
148
|
+
const targetItems = items.map((item) => document.getElementById(item.slice(1))).filter(Boolean);
|
|
149
|
+
this.setState({ targetItems }, this.initSections);
|
|
150
|
+
this.scrollToListItem();
|
|
151
|
+
}
|
|
152
|
+
initSections = () => {
|
|
153
|
+
this.saveActiveItems();
|
|
154
|
+
};
|
|
155
|
+
saveActiveItems(hash) {
|
|
156
|
+
const visibleItems = this.getViewState(hash);
|
|
157
|
+
this.setState({ inViewState: visibleItems });
|
|
158
|
+
}
|
|
159
|
+
getViewState(hash) {
|
|
160
|
+
const { targetItems, inViewState } = this.state;
|
|
161
|
+
const { headerHeight } = this.props;
|
|
162
|
+
const currentOffset = window.pageYOffset;
|
|
163
|
+
const visibleItemOffset = [];
|
|
164
|
+
let isOneActive = false;
|
|
165
|
+
const pureHash = hash && hash.startsWith("#") ? hash.substring(1) : hash;
|
|
166
|
+
targetItems.forEach((item, index) => {
|
|
167
|
+
if (!item) {
|
|
168
|
+
return;
|
|
169
|
+
}
|
|
170
|
+
const offsetTop = item.getBoundingClientRect().top;
|
|
171
|
+
const isVisibleItem = offsetTop < headerHeight + 1;
|
|
172
|
+
if (pureHash) {
|
|
173
|
+
if (pureHash === item.getAttribute("id")) {
|
|
174
|
+
visibleItemOffset.push(true);
|
|
175
|
+
isOneActive = true;
|
|
176
|
+
} else {
|
|
177
|
+
visibleItemOffset.push(false);
|
|
178
|
+
}
|
|
179
|
+
} else if (isVisibleItem) {
|
|
180
|
+
if (visibleItemOffset[index - 1]) {
|
|
181
|
+
visibleItemOffset[index - 1] = false;
|
|
182
|
+
}
|
|
183
|
+
visibleItemOffset.push(true);
|
|
184
|
+
isOneActive = true;
|
|
185
|
+
} else {
|
|
186
|
+
visibleItemOffset.push(false);
|
|
187
|
+
}
|
|
188
|
+
});
|
|
189
|
+
if (targetItems && targetItems.length && !isOneActive) {
|
|
190
|
+
if (currentOffset < targetItems[0].getBoundingClientRect().top) {
|
|
191
|
+
visibleItemOffset[0] = true;
|
|
192
|
+
isOneActive = true;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
return isOneActive ? visibleItemOffset : inViewState;
|
|
196
|
+
}
|
|
197
|
+
handleScroll = () => {
|
|
198
|
+
if (this.scrollByClick) {
|
|
199
|
+
window.removeEventListener("scroll", this.handleScrollDebounced);
|
|
200
|
+
window.addEventListener("scroll", this.handleScroll);
|
|
201
|
+
this.scrollByClick = false;
|
|
202
|
+
}
|
|
203
|
+
this.saveActiveItems();
|
|
204
|
+
};
|
|
205
|
+
// eslint-disable-next-line @typescript-eslint/member-ordering, react/sort-comp
|
|
206
|
+
handleScrollDebounced = debounce(this.handleScroll, 100);
|
|
207
|
+
pauseScrollHandler() {
|
|
208
|
+
this.scrollByClick = true;
|
|
209
|
+
window.removeEventListener("scroll", this.handleScroll);
|
|
210
|
+
window.addEventListener("scroll", this.handleScrollDebounced);
|
|
211
|
+
}
|
|
212
|
+
handleSectionClick = (event) => {
|
|
213
|
+
const { onSectionClick } = this.props;
|
|
214
|
+
const { target } = event;
|
|
215
|
+
if (target && target.tagName === "A") {
|
|
216
|
+
event.stopPropagation();
|
|
217
|
+
this.pauseScrollHandler();
|
|
218
|
+
this.saveActiveItems(target.hash);
|
|
219
|
+
if (onSectionClick) {
|
|
220
|
+
onSectionClick(event);
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
};
|
|
224
|
+
};
|
|
225
|
+
export {
|
|
226
|
+
Scrollspy
|
|
227
|
+
};
|
|
228
|
+
//# sourceMappingURL=Scrollspy.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Scrollspy/Scrollspy.tsx"],
|
|
4
|
+
"sourcesContent": ["import React, {ReactElement} from 'react';\n\nimport {debounce, isEqual} from 'lodash';\nimport scrollIntoView from 'scroll-into-view-if-needed';\n\nimport {Router} from '../../models';\nimport {InnerProps} from '../../utils';\n\ninterface ScrollspyDefaultProps {\n currentClassName: string;\n sectionOffset: number;\n headerHeight: number;\n}\n\nexport interface ScrollspyProps extends Partial<ScrollspyDefaultProps> {\n items: string[];\n children: ReactElement[];\n router: Router;\n onSectionClick?: (event: MouseEvent) => void;\n className?: string;\n scrollToListItem?: boolean;\n}\n\ninterface ScrollspyState {\n targetItems: HTMLElement[];\n inViewState: boolean[];\n}\n\ntype ScrollspyInnerProps = InnerProps<ScrollspyProps, ScrollspyDefaultProps>;\n\nexport class Scrollspy extends React.Component<ScrollspyInnerProps, ScrollspyState> {\n static defaultProps: ScrollspyDefaultProps = {\n currentClassName: 'Scrollspy',\n sectionOffset: 20,\n headerHeight: 0,\n };\n\n containerRef = React.createRef<HTMLUListElement>();\n itemRefs = this.props.items.map(() => React.createRef<HTMLDivElement>());\n\n scrollByClick: boolean;\n firstItemIndexInView: number;\n lastItemIndexInView: number;\n\n constructor(props: ScrollspyInnerProps) {\n super(props);\n\n this.state = {\n targetItems: [],\n inViewState: [],\n };\n\n this.scrollByClick = false;\n this.firstItemIndexInView = -1;\n this.lastItemIndexInView = -1;\n }\n\n componentDidMount() {\n this.initItems();\n window.addEventListener('scroll', this.handleScroll);\n\n const containerEl = this.containerRef.current;\n if (containerEl) {\n containerEl.addEventListener('scroll', this.updateScrollValues);\n }\n }\n\n componentDidUpdate(prevProps: Readonly<ScrollspyProps>, prevState: Readonly<ScrollspyState>) {\n const {items, router} = this.props;\n const {inViewState} = this.state;\n\n if (!isEqual(inViewState, prevState.inViewState)) {\n this.scrollToListItem();\n }\n\n if (!isEqual(items, prevProps.items) || prevProps.router.pathname !== router.pathname) {\n this.initItems();\n }\n\n if (router.hash !== prevProps.router.hash) {\n this.pauseScrollHandler();\n this.saveActiveItems(router.hash);\n }\n }\n\n componentWillUnmount() {\n window.removeEventListener('scroll', this.handleScroll);\n\n const containerEl = this.containerRef.current;\n if (containerEl) {\n containerEl.removeEventListener('scroll', this.updateScrollValues);\n }\n }\n\n render() {\n const {children, currentClassName, className} = this.props;\n const {inViewState} = this.state;\n\n const items = children.map((child, index) => {\n if (!child) {\n return null;\n }\n\n const ChildTag = child.type;\n let childClassNames = child.props.className;\n\n if (inViewState[index] && currentClassName.length > 0) {\n childClassNames += ` ${currentClassName}`;\n\n this.syncScroll(index);\n }\n\n return (\n <ChildTag\n key={child.key}\n className={childClassNames}\n onClick={this.handleSectionClick}\n ref={this.itemRefs[index]}\n >\n {child.props.children}\n </ChildTag>\n );\n });\n\n return (\n <ul className={className} ref={this.containerRef}>\n {items}\n </ul>\n );\n }\n\n private updateFirstItemIndexInView(maxItemsInView: number) {\n this.firstItemIndexInView = Math.max(this.lastItemIndexInView - (maxItemsInView - 1), 0);\n }\n\n private getContainerValues(containerEl: HTMLUListElement) {\n const {children} = this.props;\n\n /* Average values */\n const childHeight = Math.round(containerEl.scrollHeight / children.length);\n const maxItemsInView = Math.round(containerEl.clientHeight / childHeight);\n\n return {childHeight, maxItemsInView};\n }\n\n private updateScrollValues = () => {\n const containerEl = this.containerRef.current;\n\n if (!containerEl) {\n return;\n }\n\n const {childHeight, maxItemsInView} = this.getContainerValues(containerEl);\n this.lastItemIndexInView =\n Math.round(containerEl.scrollTop / childHeight) + maxItemsInView - 1;\n\n this.updateFirstItemIndexInView(maxItemsInView);\n };\n\n private syncScroll(index: number) {\n const {children} = this.props;\n const containerEl = this.containerRef.current;\n\n if (!containerEl) {\n return;\n }\n\n const {childHeight, maxItemsInView} = this.getContainerValues(containerEl);\n\n if (this.lastItemIndexInView === -1) {\n this.lastItemIndexInView = maxItemsInView - 1;\n }\n\n this.updateFirstItemIndexInView(maxItemsInView);\n\n let itemInView = false;\n if (index >= this.lastItemIndexInView) {\n this.lastItemIndexInView = Math.min(index + 1, children.length - 1);\n } else if (index <= this.firstItemIndexInView) {\n this.lastItemIndexInView = Math.max(index + maxItemsInView - 2, maxItemsInView - 1);\n } else {\n itemInView = true;\n }\n\n this.updateFirstItemIndexInView(maxItemsInView);\n\n const endIsNear = index + maxItemsInView / 2 > children.length;\n if (itemInView) {\n return;\n } else if (endIsNear) {\n containerEl.scrollTop = containerEl.scrollHeight;\n } else {\n containerEl.scrollTop = childHeight * this.firstItemIndexInView;\n }\n }\n\n private scrollToListItem = () => {\n if (!this.props.scrollToListItem) {\n return;\n }\n\n let itemIndex = this.state.inViewState.findIndex((isActive) => isActive);\n\n if (itemIndex < 0) {\n itemIndex = 0;\n }\n\n const ref = this.itemRefs[itemIndex] && this.itemRefs[itemIndex].current;\n\n if (ref) {\n scrollIntoView(ref, {\n scrollMode: 'if-needed',\n block: 'nearest',\n inline: 'nearest',\n behavior: 'smooth',\n });\n }\n };\n\n private initItems() {\n const {items} = this.props;\n const targetItems = items\n .map((item) => document.getElementById(item.slice(1)))\n .filter(Boolean) as HTMLElement[];\n\n this.setState({targetItems}, this.initSections);\n this.scrollToListItem();\n }\n\n private initSections = () => {\n this.saveActiveItems();\n };\n\n private saveActiveItems(hash?: string) {\n const visibleItems = this.getViewState(hash);\n\n this.setState({inViewState: visibleItems});\n }\n\n private getViewState(hash?: string) {\n const {targetItems, inViewState} = this.state;\n const {headerHeight} = this.props;\n const currentOffset = window.pageYOffset;\n const visibleItemOffset: boolean[] = [];\n let isOneActive = false;\n\n const pureHash = hash && hash.startsWith('#') ? hash.substring(1) : hash;\n\n targetItems.forEach((item, index) => {\n if (!item) {\n return;\n }\n\n const offsetTop = item.getBoundingClientRect().top;\n const isVisibleItem = offsetTop < headerHeight + 1;\n\n if (pureHash) {\n if (pureHash === item.getAttribute('id')) {\n visibleItemOffset.push(true);\n isOneActive = true;\n } else {\n visibleItemOffset.push(false);\n }\n } else if (isVisibleItem) {\n if (visibleItemOffset[index - 1]) {\n visibleItemOffset[index - 1] = false;\n }\n\n visibleItemOffset.push(true);\n isOneActive = true;\n } else {\n visibleItemOffset.push(false);\n }\n });\n\n if (targetItems && targetItems.length && !isOneActive) {\n if (currentOffset < targetItems[0].getBoundingClientRect().top) {\n visibleItemOffset[0] = true;\n isOneActive = true;\n }\n }\n\n return isOneActive ? visibleItemOffset : inViewState;\n }\n\n private handleScroll = () => {\n if (this.scrollByClick) {\n // the end of smooth auto-scroll\n window.removeEventListener('scroll', this.handleScrollDebounced);\n window.addEventListener('scroll', this.handleScroll);\n this.scrollByClick = false;\n }\n this.saveActiveItems();\n };\n\n // eslint-disable-next-line @typescript-eslint/member-ordering, react/sort-comp\n private handleScrollDebounced = debounce(this.handleScroll, 100);\n\n private pauseScrollHandler() {\n // wait for the end of smooth auto-scroll\n this.scrollByClick = true;\n window.removeEventListener('scroll', this.handleScroll);\n window.addEventListener('scroll', this.handleScrollDebounced);\n }\n\n private handleSectionClick = (event: MouseEvent) => {\n const {onSectionClick} = this.props;\n const {target} = event;\n\n if (target && (target as HTMLElement).tagName === 'A') {\n event.stopPropagation();\n this.pauseScrollHandler();\n this.saveActiveItems((target as HTMLAnchorElement).hash);\n\n if (onSectionClick) {\n onSectionClick(event);\n }\n }\n };\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/* src/components/SearchBar/SearchBar.scss */
|
|
2
|
+
.dc-search-bar {
|
|
3
|
+
width: 100%;
|
|
4
|
+
height: 100%;
|
|
5
|
+
border-radius: 5px;
|
|
6
|
+
box-sizing: border-box;
|
|
7
|
+
box-shadow: 0px 3px 10px var(--g-color-base-generic-accent);
|
|
8
|
+
padding: 11px;
|
|
9
|
+
display: flex;
|
|
10
|
+
align-items: center;
|
|
11
|
+
justify-content: space-between;
|
|
12
|
+
font-size: var(--g-text-body-short-font-size);
|
|
13
|
+
line-height: var(--g-text-body-short-line-height);
|
|
14
|
+
}
|
|
15
|
+
.dc-search-bar__search-query-label {
|
|
16
|
+
color: var(--g-color-text-secondary);
|
|
17
|
+
white-space: nowrap;
|
|
18
|
+
text-overflow: ellipsis;
|
|
19
|
+
overflow: hidden;
|
|
20
|
+
}
|
|
21
|
+
@media (max-width: 770px) {
|
|
22
|
+
.dc-search-bar__search-query-label {
|
|
23
|
+
display: none;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
.dc-search-bar__search-query {
|
|
27
|
+
max-width: 400px;
|
|
28
|
+
white-space: nowrap;
|
|
29
|
+
text-overflow: ellipsis;
|
|
30
|
+
overflow: hidden;
|
|
31
|
+
}
|
|
32
|
+
@media (max-width: 770px) {
|
|
33
|
+
.dc-search-bar__search-query {
|
|
34
|
+
display: none;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
.dc-search-bar__left {
|
|
38
|
+
width: 90%;
|
|
39
|
+
display: flex;
|
|
40
|
+
align-items: center;
|
|
41
|
+
}
|
|
42
|
+
.dc-search-bar__navigation {
|
|
43
|
+
display: flex;
|
|
44
|
+
align-items: center;
|
|
45
|
+
margin-right: 11px;
|
|
46
|
+
}
|
|
47
|
+
.dc-search-bar__next-arrow {
|
|
48
|
+
transform: rotate(-180deg);
|
|
49
|
+
}
|
|
50
|
+
.dc-search-bar__counter {
|
|
51
|
+
margin: 0 4px;
|
|
52
|
+
}
|
|
53
|
+
.dc-search-highlighted {
|
|
54
|
+
background: var(--dc-text-highlight);
|
|
55
|
+
}
|
|
56
|
+
.dc-search-highlighted_selected {
|
|
57
|
+
background: var(--dc-text-highlight-selected);
|
|
58
|
+
}
|
|
59
|
+
/*# sourceMappingURL=SearchBar.css.map */
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/SearchBar/Users/3y3k0/doctools/docs-components/src/components/SearchBar/SearchBar.scss", "../../../../src/components/SearchBar/%3Cinput%20css%20YSUvwV%3E"],
|
|
4
|
+
"sourcesContent": ["@import '../../styles/variables';\n@import '../../styles/mixins';\n\n.dc-search-bar {\n width: 100%;\n height: 100%;\n border-radius: 5px;\n box-sizing: border-box;\n box-shadow: 0px 3px 10px var(--g-color-base-generic-accent);\n padding: 11px;\n display: flex;\n align-items: center;\n justify-content: space-between;\n\n font-size: var(--g-text-body-short-font-size);\n line-height: var(--g-text-body-short-line-height);\n\n &__search-query-label {\n color: var(--g-color-text-secondary);\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n\n @media (max-width: map-get($screenBreakpoints, 'md') + 1) {\n display: none;\n }\n }\n\n &__search-query {\n max-width: 400px;\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n\n @media (max-width: map-get($screenBreakpoints, 'md') + 1) {\n display: none;\n }\n }\n\n &__left {\n width: 90%;\n display: flex;\n align-items: center;\n }\n\n &__navigation {\n display: flex;\n align-items: center;\n margin-right: 11px;\n }\n\n &__next-arrow {\n transform: rotate(-180deg);\n }\n\n &__counter {\n margin: 0 4px;\n }\n}\n\n$hl-class: '.dc-search-highlighted';\n\n#{$hl-class} {\n background: var(--dc-text-highlight);\n\n &_selected {\n background: var(--dc-text-highlight-selected);\n }\n}\n", ".dc-search-bar {\n width: 100%;\n height: 100%;\n border-radius: 5px;\n box-sizing: border-box;\n box-shadow: 0px 3px 10px var(--g-color-base-generic-accent);\n padding: 11px;\n display: flex;\n align-items: center;\n justify-content: space-between;\n font-size: var(--g-text-body-short-font-size);\n line-height: var(--g-text-body-short-line-height);\n}\n.dc-search-bar__search-query-label {\n color: var(--g-color-text-secondary);\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n@media (max-width: 770px) {\n .dc-search-bar__search-query-label {\n display: none;\n }\n}\n.dc-search-bar__search-query {\n max-width: 400px;\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n@media (max-width: 770px) {\n .dc-search-bar__search-query {\n display: none;\n }\n}\n.dc-search-bar__left {\n width: 90%;\n display: flex;\n align-items: center;\n}\n.dc-search-bar__navigation {\n display: flex;\n align-items: center;\n margin-right: 11px;\n}\n.dc-search-bar__next-arrow {\n transform: rotate(-180deg);\n}\n.dc-search-bar__counter {\n margin: 0 4px;\n}\n\n.dc-search-highlighted {\n background: var(--dc-text-highlight);\n}\n.dc-search-highlighted_selected {\n background: var(--dc-text-highlight-selected);\n}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL1VzZXJzLzN5M2swL2RvY3Rvb2xzL2RvY3MtY29tcG9uZW50cy9zcmMvY29tcG9uZW50cy9TZWFyY2hCYXIiLCJzb3VyY2VzIjpbIlNlYXJjaEJhci5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBO0VBQ0k7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBRUE7RUFDQTs7QUFFQTtFQUNJO0VBQ0E7RUFDQTtFQUNBOztBQUVBO0VBTko7SUFPUTs7O0FBSVI7RUFDSTtFQUNBO0VBQ0E7RUFDQTs7QUFFQTtFQU5KO0lBT1E7OztBQUlSO0VBQ0k7RUFDQTtFQUNBOztBQUdKO0VBQ0k7RUFDQTtFQUNBOztBQUdKO0VBQ0k7O0FBR0o7RUFDSTs7O0FBTVI7RUFDSTs7QUFFQTtFQUNJIiwic291cmNlc0NvbnRlbnQiOlsiQGltcG9ydCAnLi4vLi4vc3R5bGVzL3ZhcmlhYmxlcyc7XG5AaW1wb3J0ICcuLi8uLi9zdHlsZXMvbWl4aW5zJztcblxuLmRjLXNlYXJjaC1iYXIge1xuICAgIHdpZHRoOiAxMDAlO1xuICAgIGhlaWdodDogMTAwJTtcbiAgICBib3JkZXItcmFkaXVzOiA1cHg7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBib3gtc2hhZG93OiAwcHggM3B4IDEwcHggdmFyKC0tZy1jb2xvci1iYXNlLWdlbmVyaWMtYWNjZW50KTtcbiAgICBwYWRkaW5nOiAxMXB4O1xuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cbiAgICBmb250LXNpemU6IHZhcigtLWctdGV4dC1ib2R5LXNob3J0LWZvbnQtc2l6ZSk7XG4gICAgbGluZS1oZWlnaHQ6IHZhcigtLWctdGV4dC1ib2R5LXNob3J0LWxpbmUtaGVpZ2h0KTtcblxuICAgICZfX3NlYXJjaC1xdWVyeS1sYWJlbCB7XG4gICAgICAgIGNvbG9yOiB2YXIoLS1nLWNvbG9yLXRleHQtc2Vjb25kYXJ5KTtcbiAgICAgICAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgICAgICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG5cbiAgICAgICAgQG1lZGlhIChtYXgtd2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnbWQnKSArIDEpIHtcbiAgICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAmX19zZWFyY2gtcXVlcnkge1xuICAgICAgICBtYXgtd2lkdGg6IDQwMHB4O1xuICAgICAgICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAgICAgICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcblxuICAgICAgICBAbWVkaWEgKG1heC13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdtZCcpICsgMSkge1xuICAgICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgICZfX2xlZnQge1xuICAgICAgICB3aWR0aDogOTAlO1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgIH1cblxuICAgICZfX25hdmlnYXRpb24ge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBtYXJnaW4tcmlnaHQ6IDExcHg7XG4gICAgfVxuXG4gICAgJl9fbmV4dC1hcnJvdyB7XG4gICAgICAgIHRyYW5zZm9ybTogcm90YXRlKC0xODBkZWcpO1xuICAgIH1cblxuICAgICZfX2NvdW50ZXIge1xuICAgICAgICBtYXJnaW46IDAgNHB4O1xuICAgIH1cbn1cblxuJGhsLWNsYXNzOiAnLmRjLXNlYXJjaC1oaWdobGlnaHRlZCc7XG5cbiN7JGhsLWNsYXNzfSB7XG4gICAgYmFja2dyb3VuZDogdmFyKC0tZGMtdGV4dC1oaWdobGlnaHQpO1xuXG4gICAgJl9zZWxlY3RlZCB7XG4gICAgICAgIGJhY2tncm91bmQ6IHZhcigtLWRjLXRleHQtaGlnaGxpZ2h0LXNlbGVjdGVkKTtcbiAgICB9XG59XG4iXX0= */"],
|
|
5
|
+
"mappings": ";AAGA,CAAA;AACI,SAAA;AACA,UAAA;AACA,iBAAA;AACA,cAAA;AACA,cAAA,IAAA,IAAA,KAAA,IAAA;AACA,WAAA;AACA,WAAA;AACA,eAAA;AACA,mBAAA;AAEA,aAAA,IAAA;AACA,eAAA,IAAA;ACHJ;ADKI,CAAA;AACI,SAAA,IAAA;AACA,eAAA;AACA,iBAAA;AACA,YAAA;ACHR;ADKQ,OAAA,CAAA,SAAA,EAAA;AANJ,GAAA;AAOQ,aAAA;ACFV;AACF;ADKI,CAAA;AACI,aAAA;AACA,eAAA;AACA,iBAAA;AACA,YAAA;ACHR;ADKQ,OAAA,CAAA,SAAA,EAAA;AANJ,GAAA;AAOQ,aAAA;ACFV;AACF;ADKI,CAAA;AACI,SAAA;AACA,WAAA;AACA,eAAA;ACHR;ADMI,CAAA;AACI,WAAA;AACA,eAAA;AACA,gBAAA;ACJR;ADOI,CAAA;AACI,aAAA,OAAA;ACLR;ADQI,CAAA;AACI,UAAA,EAAA;ACNR;ADYA,CAAA;AACI,cAAA,IAAA;ACTJ;ADWI,CAAA;AACI,cAAA,IAAA;ACTR;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
// src/components/SearchBar/SearchBar.tsx
|
|
2
|
+
import React, { memo } from "react";
|
|
3
|
+
import { Icon } from "@gravity-ui/uikit";
|
|
4
|
+
import block from "bem-cn-lite";
|
|
5
|
+
import { useHotkeys } from "react-hotkeys-hook";
|
|
6
|
+
import { useTranslation } from "../../hooks";
|
|
7
|
+
import { Control } from "../Control";
|
|
8
|
+
import ArrowLeftIcon from "@gravity-ui/icons/svgs/chevron-left.svg";
|
|
9
|
+
import CloseIcon from "@gravity-ui/icons/svgs/xmark.svg";
|
|
10
|
+
import "./SearchBar.css";
|
|
11
|
+
var b = block("dc-search-bar");
|
|
12
|
+
var noop = () => {
|
|
13
|
+
};
|
|
14
|
+
var SearchBar = memo((props) => {
|
|
15
|
+
const { t } = useTranslation("search-bar");
|
|
16
|
+
const {
|
|
17
|
+
searchQuery,
|
|
18
|
+
searchCurrentIndex,
|
|
19
|
+
searchCountResults,
|
|
20
|
+
onClickPrevSearch = noop,
|
|
21
|
+
onClickNextSearch = noop,
|
|
22
|
+
onCloseSearchBar = noop
|
|
23
|
+
} = props;
|
|
24
|
+
const hotkeysOptions = { filterPreventDefault: true };
|
|
25
|
+
const hotkeysPrev = "\u21E7+enter";
|
|
26
|
+
const hotkeysNext = "enter";
|
|
27
|
+
useHotkeys(hotkeysPrev, onClickPrevSearch, hotkeysOptions, [onClickPrevSearch]);
|
|
28
|
+
useHotkeys(hotkeysNext, onClickNextSearch, hotkeysOptions, [onClickNextSearch]);
|
|
29
|
+
return /* @__PURE__ */ React.createElement("div", { className: b() }, /* @__PURE__ */ React.createElement("div", { className: b("left") }, /* @__PURE__ */ React.createElement("div", { className: b("navigation") }, /* @__PURE__ */ React.createElement(
|
|
30
|
+
Control,
|
|
31
|
+
{
|
|
32
|
+
onClick: onClickPrevSearch,
|
|
33
|
+
tooltipText: `${t("prev")} (${hotkeysPrev})`,
|
|
34
|
+
icon: (args) => /* @__PURE__ */ React.createElement(Icon, { data: ArrowLeftIcon, ...args })
|
|
35
|
+
}
|
|
36
|
+
), /* @__PURE__ */ React.createElement("span", { className: b("counter") }, searchCurrentIndex, "/", searchCountResults), /* @__PURE__ */ React.createElement(
|
|
37
|
+
Control,
|
|
38
|
+
{
|
|
39
|
+
onClick: onClickNextSearch,
|
|
40
|
+
tooltipText: `${t("next")} (${hotkeysNext})`,
|
|
41
|
+
icon: (args) => /* @__PURE__ */ React.createElement(Icon, { data: ArrowLeftIcon, className: b("next-arrow"), ...args })
|
|
42
|
+
}
|
|
43
|
+
)), /* @__PURE__ */ React.createElement("span", { className: b("search-query-label") }, t("search-query-label"), ":\xA0"), /* @__PURE__ */ React.createElement("span", { className: b("search-query") }, searchQuery)), /* @__PURE__ */ React.createElement("div", { className: b("right") }, /* @__PURE__ */ React.createElement(
|
|
44
|
+
Control,
|
|
45
|
+
{
|
|
46
|
+
onClick: onCloseSearchBar,
|
|
47
|
+
tooltipText: t("close"),
|
|
48
|
+
icon: () => /* @__PURE__ */ React.createElement(Icon, { data: CloseIcon, size: 16 })
|
|
49
|
+
}
|
|
50
|
+
)));
|
|
51
|
+
});
|
|
52
|
+
SearchBar.displayName = "DCSearchBar";
|
|
53
|
+
var SearchBar_default = SearchBar;
|
|
54
|
+
export {
|
|
55
|
+
SearchBar_default as default
|
|
56
|
+
};
|
|
57
|
+
//# sourceMappingURL=SearchBar.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/SearchBar/SearchBar.tsx"],
|
|
4
|
+
"sourcesContent": ["import React, {memo} from 'react';\n\nimport {Icon} from '@gravity-ui/uikit';\nimport block from 'bem-cn-lite';\nimport {useHotkeys} from 'react-hotkeys-hook';\n\nimport {useTranslation} from '../../hooks';\nimport {Control} from '../Control';\n\nimport ArrowLeftIcon from '@gravity-ui/icons/svgs/chevron-left.svg';\nimport CloseIcon from '@gravity-ui/icons/svgs/xmark.svg';\n\nimport './SearchBar.scss';\n\nconst b = block('dc-search-bar');\n\nexport interface SearchBarProps {\n searchQuery?: string;\n onClickPrevSearch?: () => void;\n onClickNextSearch?: () => void;\n onCloseSearchBar?: () => void;\n searchCurrentIndex?: number;\n searchCountResults?: number;\n}\n\nconst noop = () => {};\n\nconst SearchBar = memo<SearchBarProps>((props) => {\n const {t} = useTranslation('search-bar');\n const {\n searchQuery,\n searchCurrentIndex,\n searchCountResults,\n onClickPrevSearch = noop,\n onClickNextSearch = noop,\n onCloseSearchBar = noop,\n } = props;\n\n const hotkeysOptions = {filterPreventDefault: true};\n const hotkeysPrev = '\u21E7+enter';\n const hotkeysNext = 'enter';\n useHotkeys(hotkeysPrev, onClickPrevSearch, hotkeysOptions, [onClickPrevSearch]);\n useHotkeys(hotkeysNext, onClickNextSearch, hotkeysOptions, [onClickNextSearch]);\n\n return (\n <div className={b()}>\n <div className={b('left')}>\n <div className={b('navigation')}>\n <Control\n onClick={onClickPrevSearch}\n tooltipText={`${t('prev')} (${hotkeysPrev})`}\n icon={(args) => <Icon data={ArrowLeftIcon} {...args} />}\n />\n <span className={b('counter')}>\n {searchCurrentIndex}/{searchCountResults}\n </span>\n <Control\n onClick={onClickNextSearch}\n tooltipText={`${t('next')} (${hotkeysNext})`}\n icon={(args) => (\n <Icon data={ArrowLeftIcon} className={b('next-arrow')} {...args} />\n )}\n />\n </div>\n <span className={b('search-query-label')}>\n {t<string>('search-query-label')}: \n </span>\n <span className={b('search-query')}>{searchQuery}</span>\n </div>\n <div className={b('right')}>\n <Control\n onClick={onCloseSearchBar}\n tooltipText={t('close')}\n icon={() => <Icon data={CloseIcon} size={16} />}\n />\n </div>\n </div>\n );\n});\n\nSearchBar.displayName = 'DCSearchBar';\n\nexport default SearchBar;\n"],
|
|
5
|
+
"mappings": ";AAAA,OAAO,SAAQ,YAAW;AAE1B,SAAQ,YAAW;AACnB,OAAO,WAAW;AAClB,SAAQ,kBAAiB;AAEzB,SAAQ,sBAAqB;AAC7B,SAAQ,eAAc;AAEtB,OAAO,mBAAmB;AAC1B,OAAO,eAAe;AAEtB,OAAO;AAEP,IAAM,IAAI,MAAM,eAAe;AAW/B,IAAM,OAAO,MAAM;AAAC;AAEpB,IAAM,YAAY,KAAqB,CAAC,UAAU;AAC9C,QAAM,EAAC,EAAC,IAAI,eAAe,YAAY;AACvC,QAAM;AAAA,IACF;AAAA,IACA;AAAA,IACA;AAAA,IACA,oBAAoB;AAAA,IACpB,oBAAoB;AAAA,IACpB,mBAAmB;AAAA,EACvB,IAAI;AAEJ,QAAM,iBAAiB,EAAC,sBAAsB,KAAI;AAClD,QAAM,cAAc;AACpB,QAAM,cAAc;AACpB,aAAW,aAAa,mBAAmB,gBAAgB,CAAC,iBAAiB,CAAC;AAC9E,aAAW,aAAa,mBAAmB,gBAAgB,CAAC,iBAAiB,CAAC;AAE9E,SACI,oCAAC,SAAI,WAAW,EAAE,KACd,oCAAC,SAAI,WAAW,EAAE,MAAM,KACpB,oCAAC,SAAI,WAAW,EAAE,YAAY,KAC1B;AAAA,IAAC;AAAA;AAAA,MACG,SAAS;AAAA,MACT,aAAa,GAAG,EAAE,MAAM,CAAC,KAAK,WAAW;AAAA,MACzC,MAAM,CAAC,SAAS,oCAAC,QAAK,MAAM,eAAgB,GAAG,MAAM;AAAA;AAAA,EACzD,GACA,oCAAC,UAAK,WAAW,EAAE,SAAS,KACvB,oBAAmB,KAAE,kBAC1B,GACA;AAAA,IAAC;AAAA;AAAA,MACG,SAAS;AAAA,MACT,aAAa,GAAG,EAAE,MAAM,CAAC,KAAK,WAAW;AAAA,MACzC,MAAM,CAAC,SACH,oCAAC,QAAK,MAAM,eAAe,WAAW,EAAE,YAAY,GAAI,GAAG,MAAM;AAAA;AAAA,EAEzE,CACJ,GACA,oCAAC,UAAK,WAAW,EAAE,oBAAoB,KAClC,EAAU,oBAAoB,GAAE,OACrC,GACA,oCAAC,UAAK,WAAW,EAAE,cAAc,KAAI,WAAY,CACrD,GACA,oCAAC,SAAI,WAAW,EAAE,OAAO,KACrB;AAAA,IAAC;AAAA;AAAA,MACG,SAAS;AAAA,MACT,aAAa,EAAE,OAAO;AAAA,MACtB,MAAM,MAAM,oCAAC,QAAK,MAAM,WAAW,MAAM,IAAI;AAAA;AAAA,EACjD,CACJ,CACJ;AAER,CAAC;AAED,UAAU,cAAc;AAExB,IAAO,oBAAQ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|