@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,53 @@
|
|
|
1
|
+
// src/components/ContributorAvatars/ContributorAvatars.tsx
|
|
2
|
+
import React, { Fragment } from "react";
|
|
3
|
+
import block from "bem-cn-lite";
|
|
4
|
+
import Link from "../Link";
|
|
5
|
+
import Avatar from "./Avatars/Avatar";
|
|
6
|
+
import AvatarWithDescription from "./Avatars/AvatarWithDescription";
|
|
7
|
+
import HiddenAvatars from "./Avatars/HiddenAvatars";
|
|
8
|
+
import { AvatarSizes } from "./models";
|
|
9
|
+
import { getName } from "./utils";
|
|
10
|
+
import "./ContributorAvatars.css";
|
|
11
|
+
var b = block("contributor-avatars");
|
|
12
|
+
var MAX_DISPLAYED_CONTRIBUTORS = 3;
|
|
13
|
+
var ContributorAvatars = (props) => {
|
|
14
|
+
const { contributors, isAuthor = false, onlyAuthor = false } = props;
|
|
15
|
+
if (!contributors || contributors.length === 0) {
|
|
16
|
+
return null;
|
|
17
|
+
}
|
|
18
|
+
if (contributors.length === 1) {
|
|
19
|
+
const oneAvatar = getOneAvatar(contributors[0], isAuthor, onlyAuthor);
|
|
20
|
+
return oneAvatar;
|
|
21
|
+
}
|
|
22
|
+
const displayedContributors = [...contributors];
|
|
23
|
+
const hiddenContributors = displayedContributors.splice(MAX_DISPLAYED_CONTRIBUTORS);
|
|
24
|
+
const displayedAvatars = displayedContributors.map((contributor) => {
|
|
25
|
+
const { url, login, email } = contributor;
|
|
26
|
+
return /* @__PURE__ */ React.createElement(Link, { key: `displayed-contributors-${login || email}`, url }, /* @__PURE__ */ React.createElement(AvatarWithDescription, { contributor, avatarSize: AvatarSizes.SMALL }));
|
|
27
|
+
});
|
|
28
|
+
const hiddenAvatars = /* @__PURE__ */ React.createElement(HiddenAvatars, { contributors: hiddenContributors, avatarsSize: AvatarSizes.SMALL });
|
|
29
|
+
const avatars = /* @__PURE__ */ React.createElement(Fragment, null, /* @__PURE__ */ React.createElement("div", { className: b("displayed_avatars") }, displayedAvatars), /* @__PURE__ */ React.createElement("div", { className: b("hidden_avatars") }, hiddenAvatars));
|
|
30
|
+
return avatars;
|
|
31
|
+
};
|
|
32
|
+
function getOneAvatar(contributor, isAuthor, onlyAuthor) {
|
|
33
|
+
const avatarData = {
|
|
34
|
+
contributor,
|
|
35
|
+
size: AvatarSizes.SMALL
|
|
36
|
+
};
|
|
37
|
+
const wrapperModifiers = isAuthor ? { onlyAuthor } : {};
|
|
38
|
+
return /* @__PURE__ */ React.createElement("div", { className: b("one_contributor", wrapperModifiers) }, /* @__PURE__ */ React.createElement("div", { className: "desktop" }, getRedirectingAvatar(avatarData, contributor.url), " "), /* @__PURE__ */ React.createElement("div", { className: "mobile" }, isAuthor && onlyAuthor ? getRedirectingAvatar(avatarData, contributor.url, true) : /* @__PURE__ */ React.createElement(
|
|
39
|
+
AvatarWithDescription,
|
|
40
|
+
{
|
|
41
|
+
contributor,
|
|
42
|
+
avatarSize: AvatarSizes.SMALL
|
|
43
|
+
}
|
|
44
|
+
)), /* @__PURE__ */ React.createElement("div", null, /* @__PURE__ */ React.createElement(Link, { url: contributor.url }, getName(contributor, isAuthor))));
|
|
45
|
+
}
|
|
46
|
+
function getRedirectingAvatar(avatarData, url, isRedirect = false) {
|
|
47
|
+
return /* @__PURE__ */ React.createElement(Link, { url }, /* @__PURE__ */ React.createElement(Avatar, { avatarData, isRedirect }));
|
|
48
|
+
}
|
|
49
|
+
var ContributorAvatars_default = ContributorAvatars;
|
|
50
|
+
export {
|
|
51
|
+
ContributorAvatars_default as default
|
|
52
|
+
};
|
|
53
|
+
//# sourceMappingURL=ContributorAvatars.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/ContributorAvatars/ContributorAvatars.tsx"],
|
|
4
|
+
"sourcesContent": ["import React, {Fragment, ReactElement} from 'react';\n\nimport block from 'bem-cn-lite';\n\nimport {Contributor} from '../../models';\nimport Link from '../Link';\n\nimport Avatar from './Avatars/Avatar';\nimport AvatarWithDescription from './Avatars/AvatarWithDescription';\nimport HiddenAvatars from './Avatars/HiddenAvatars';\nimport {AvatarData, AvatarSizes} from './models';\nimport {getName} from './utils';\n\nimport './ContributorAvatars.scss';\n\nconst b = block('contributor-avatars');\n\nconst MAX_DISPLAYED_CONTRIBUTORS = 3;\n\nexport interface ContributorAvatarsProps {\n contributors: Contributor[];\n isAuthor?: boolean;\n onlyAuthor?: boolean;\n}\n\nconst ContributorAvatars: React.FC<ContributorAvatarsProps> = (props) => {\n const {contributors, isAuthor = false, onlyAuthor = false} = props;\n\n if (!contributors || contributors.length === 0) {\n return null;\n }\n\n if (contributors.length === 1) {\n const oneAvatar = getOneAvatar(contributors[0], isAuthor, onlyAuthor);\n return oneAvatar;\n }\n\n const displayedContributors = [...contributors];\n const hiddenContributors = displayedContributors.splice(MAX_DISPLAYED_CONTRIBUTORS);\n\n const displayedAvatars = displayedContributors.map((contributor: Contributor) => {\n const {url, login, email} = contributor;\n return (\n <Link key={`displayed-contributors-${login || email}`} url={url}>\n <AvatarWithDescription contributor={contributor} avatarSize={AvatarSizes.SMALL} />\n </Link>\n );\n });\n\n const hiddenAvatars = (\n <HiddenAvatars contributors={hiddenContributors} avatarsSize={AvatarSizes.SMALL} />\n );\n\n const avatars = (\n <Fragment>\n <div className={b('displayed_avatars')}>{displayedAvatars}</div>\n <div className={b('hidden_avatars')}>{hiddenAvatars}</div>\n </Fragment>\n );\n\n return avatars;\n};\n\nfunction getOneAvatar(\n contributor: Contributor,\n isAuthor: boolean,\n onlyAuthor: boolean,\n): ReactElement {\n const avatarData: AvatarData = {\n contributor,\n size: AvatarSizes.SMALL,\n };\n\n const wrapperModifiers = isAuthor ? {onlyAuthor} : {};\n\n return (\n <div className={b('one_contributor', wrapperModifiers)}>\n <div className={'desktop'}>{getRedirectingAvatar(avatarData, contributor.url)} </div>\n <div className={'mobile'}>\n {isAuthor && onlyAuthor ? (\n getRedirectingAvatar(avatarData, contributor.url, true)\n ) : (\n <AvatarWithDescription\n contributor={contributor}\n avatarSize={AvatarSizes.SMALL}\n />\n )}\n </div>\n <div>\n <Link url={contributor.url}>{getName(contributor, isAuthor)}</Link>\n </div>\n </div>\n );\n}\n\nfunction getRedirectingAvatar(avatarData: AvatarData, url: string, isRedirect = false) {\n return (\n <Link url={url}>\n <Avatar avatarData={avatarData} isRedirect={isRedirect} />\n </Link>\n );\n}\n\nexport default ContributorAvatars;\n"],
|
|
5
|
+
"mappings": ";AAAA,OAAO,SAAQ,gBAA6B;AAE5C,OAAO,WAAW;AAGlB,OAAO,UAAU;AAEjB,OAAO,YAAY;AACnB,OAAO,2BAA2B;AAClC,OAAO,mBAAmB;AAC1B,SAAoB,mBAAkB;AACtC,SAAQ,eAAc;AAEtB,OAAO;AAEP,IAAM,IAAI,MAAM,qBAAqB;AAErC,IAAM,6BAA6B;AAQnC,IAAM,qBAAwD,CAAC,UAAU;AACrE,QAAM,EAAC,cAAc,WAAW,OAAO,aAAa,MAAK,IAAI;AAE7D,MAAI,CAAC,gBAAgB,aAAa,WAAW,GAAG;AAC5C,WAAO;AAAA,EACX;AAEA,MAAI,aAAa,WAAW,GAAG;AAC3B,UAAM,YAAY,aAAa,aAAa,CAAC,GAAG,UAAU,UAAU;AACpE,WAAO;AAAA,EACX;AAEA,QAAM,wBAAwB,CAAC,GAAG,YAAY;AAC9C,QAAM,qBAAqB,sBAAsB,OAAO,0BAA0B;AAElF,QAAM,mBAAmB,sBAAsB,IAAI,CAAC,gBAA6B;AAC7E,UAAM,EAAC,KAAK,OAAO,MAAK,IAAI;AAC5B,WACI,oCAAC,QAAK,KAAK,0BAA0B,SAAS,KAAK,IAAI,OACnD,oCAAC,yBAAsB,aAA0B,YAAY,YAAY,OAAO,CACpF;AAAA,EAER,CAAC;AAED,QAAM,gBACF,oCAAC,iBAAc,cAAc,oBAAoB,aAAa,YAAY,OAAO;AAGrF,QAAM,UACF,oCAAC,gBACG,oCAAC,SAAI,WAAW,EAAE,mBAAmB,KAAI,gBAAiB,GAC1D,oCAAC,SAAI,WAAW,EAAE,gBAAgB,KAAI,aAAc,CACxD;AAGJ,SAAO;AACX;AAEA,SAAS,aACL,aACA,UACA,YACY;AACZ,QAAM,aAAyB;AAAA,IAC3B;AAAA,IACA,MAAM,YAAY;AAAA,EACtB;AAEA,QAAM,mBAAmB,WAAW,EAAC,WAAU,IAAI,CAAC;AAEpD,SACI,oCAAC,SAAI,WAAW,EAAE,mBAAmB,gBAAgB,KACjD,oCAAC,SAAI,WAAW,aAAY,qBAAqB,YAAY,YAAY,GAAG,GAAE,GAAC,GAC/E,oCAAC,SAAI,WAAW,YACX,YAAY,aACT,qBAAqB,YAAY,YAAY,KAAK,IAAI,IAEtD;AAAA,IAAC;AAAA;AAAA,MACG;AAAA,MACA,YAAY,YAAY;AAAA;AAAA,EAC5B,CAER,GACA,oCAAC,aACG,oCAAC,QAAK,KAAK,YAAY,OAAM,QAAQ,aAAa,QAAQ,CAAE,CAChE,CACJ;AAER;AAEA,SAAS,qBAAqB,YAAwB,KAAa,aAAa,OAAO;AACnF,SACI,oCAAC,QAAK,OACF,oCAAC,UAAO,YAAwB,YAAwB,CAC5D;AAER;AAEA,IAAO,6BAAQ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/ContributorAvatars/index.ts"],
|
|
4
|
+
"sourcesContent": ["export * from './ContributorAvatars';\nexport {default as ContributorAvatars} from './ContributorAvatars';\n"],
|
|
5
|
+
"mappings": ";AAAA,cAAc;AACd,SAAmB,WAAXA,gBAAoC;",
|
|
6
|
+
"names": ["default"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
// src/components/ContributorAvatars/models.ts
|
|
2
|
+
var AvatarSizes = /* @__PURE__ */ ((AvatarSizes2) => {
|
|
3
|
+
AvatarSizes2["BIG"] = "big";
|
|
4
|
+
AvatarSizes2["SMALL"] = "small";
|
|
5
|
+
return AvatarSizes2;
|
|
6
|
+
})(AvatarSizes || {});
|
|
7
|
+
export {
|
|
8
|
+
AvatarSizes
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=models.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/ContributorAvatars/models.ts"],
|
|
4
|
+
"sourcesContent": ["import {Contributor} from '../../models';\n\nexport type PopupData = {\n ref: React.MutableRefObject<HTMLImageElement | null>;\n isVisiblePopup: boolean;\n changeVisiblilityPopup: (visible?: boolean) => void;\n};\n\nexport type AvatarData = {\n contributor: Contributor;\n size?: string;\n inDetails?: boolean;\n};\n\nexport enum AvatarSizes {\n BIG = 'big',\n SMALL = 'small',\n}\n"],
|
|
5
|
+
"mappings": ";AAcO,IAAK,cAAL,kBAAKA,iBAAL;AACH,EAAAA,aAAA,SAAM;AACN,EAAAA,aAAA,WAAQ;AAFA,SAAAA;AAAA,GAAA;",
|
|
6
|
+
"names": ["AvatarSizes"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// src/components/ContributorAvatars/utils.ts
|
|
2
|
+
function getName(contributor, useFullName = false) {
|
|
3
|
+
return useFullName ? getUserIdentificator(contributor) : getShortContributorName(getUserIdentificator(contributor));
|
|
4
|
+
}
|
|
5
|
+
function getUserIdentificator(contributor) {
|
|
6
|
+
const { name, email, login } = contributor;
|
|
7
|
+
return name || email || login || "";
|
|
8
|
+
}
|
|
9
|
+
function getShortContributorName(fullContributorName) {
|
|
10
|
+
return fullContributorName.split(" ").reduce((result, current, index) => {
|
|
11
|
+
return index > 0 ? `${result} ${current.charAt(0)}.` : current;
|
|
12
|
+
}, "");
|
|
13
|
+
}
|
|
14
|
+
export {
|
|
15
|
+
getName,
|
|
16
|
+
getUserIdentificator
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/ContributorAvatars/utils.ts"],
|
|
4
|
+
"sourcesContent": ["import {Contributor} from '../../models';\n\nexport function getName(contributor: Contributor, useFullName = false): string {\n return useFullName\n ? getUserIdentificator(contributor)\n : getShortContributorName(getUserIdentificator(contributor));\n}\n\nexport function getUserIdentificator(contributor: Contributor): string {\n const {name, email, login} = contributor;\n\n return name || email || login || '';\n}\n\nfunction getShortContributorName(fullContributorName: string): string {\n return fullContributorName.split(' ').reduce((result, current, index) => {\n return index > 0 ? `${result} ${current.charAt(0)}.` : current;\n }, '');\n}\n"],
|
|
5
|
+
"mappings": ";AAEO,SAAS,QAAQ,aAA0B,cAAc,OAAe;AAC3E,SAAO,cACD,qBAAqB,WAAW,IAChC,wBAAwB,qBAAqB,WAAW,CAAC;AACnE;AAEO,SAAS,qBAAqB,aAAkC;AACnE,QAAM,EAAC,MAAM,OAAO,MAAK,IAAI;AAE7B,SAAO,QAAQ,SAAS,SAAS;AACrC;AAEA,SAAS,wBAAwB,qBAAqC;AAClE,SAAO,oBAAoB,MAAM,GAAG,EAAE,OAAO,CAAC,QAAQ,SAAS,UAAU;AACrE,WAAO,QAAQ,IAAI,GAAG,MAAM,IAAI,QAAQ,OAAO,CAAC,CAAC,MAAM;AAAA,EAC3D,GAAG,EAAE;AACT;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/* src/components/Contributors/Contributors.scss */
|
|
2
|
+
.contributors {
|
|
3
|
+
display: flex;
|
|
4
|
+
margin: 0 0 32px;
|
|
5
|
+
}
|
|
6
|
+
.contributors__title {
|
|
7
|
+
font-size: 13px;
|
|
8
|
+
font-weight: 400;
|
|
9
|
+
margin-right: 5px;
|
|
10
|
+
align-self: center;
|
|
11
|
+
}
|
|
12
|
+
/*# sourceMappingURL=Contributors.css.map */
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Contributors/Users/3y3k0/doctools/docs-components/src/components/Contributors/Contributors.scss", "../../../../src/components/Contributors/%3Cinput%20css%20AwfKGD%3E", "../../../../src/components/Contributors/Users/3y3k0/doctools/docs-components/src/styles/mixins.scss"],
|
|
4
|
+
"sourcesContent": ["@import '../../styles/mixins';\n\n.contributors {\n display: flex;\n margin: 0 0 32px;\n\n &__title {\n @include contributors-text();\n }\n}\n", ".contributors {\n display: flex;\n margin: 0 0 32px;\n}\n.contributors__title {\n font-size: 13px;\n font-weight: 400;\n margin-right: 5px;\n align-self: center;\n}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL1VzZXJzLzN5M2swL2RvY3Rvb2xzL2RvY3MtY29tcG9uZW50cy9zcmMvY29tcG9uZW50cy9Db250cmlidXRvcnMiLCJzb3VyY2VzIjpbIkNvbnRyaWJ1dG9ycy5zY3NzIiwiLi4vLi4vc3R5bGVzL21peGlucy5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBO0VBQ0k7RUFDQTs7QUFFQTtFQ3lFQTtFQUNBO0VBQ0E7RUFDQSIsInNvdXJjZXNDb250ZW50IjpbIkBpbXBvcnQgJy4uLy4uL3N0eWxlcy9taXhpbnMnO1xuXG4uY29udHJpYnV0b3JzIHtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIG1hcmdpbjogMCAwIDMycHg7XG5cbiAgICAmX190aXRsZSB7XG4gICAgICAgIEBpbmNsdWRlIGNvbnRyaWJ1dG9ycy10ZXh0KCk7XG4gICAgfVxufVxuIiwiQGltcG9ydCAnLi92YXJpYWJsZXMnO1xuXG5AbWl4aW4gdGV4dC1zaXplKCRuYW1lKSB7XG4gICAgZm9udC1zaXplOiB2YXIoLS1nLXRleHQtI3skbmFtZX0tZm9udC1zaXplKTtcbiAgICBsaW5lLWhlaWdodDogdmFyKC0tZy10ZXh0LSN7JG5hbWV9LWxpbmUtaGVpZ2h0KTtcbn1cblxuQG1peGluIHJlc2V0LWxpc3Qtc3R5bGUoKSB7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG4gICAgbGlzdC1zdHlsZTogbm9uZTtcbn1cblxuQG1peGluIGZpeEFuY2hvclBvc2l0aW9uKCRvZmZzZXQ6IDBweCkge1xuICAgIHBhZGRpbmctdG9wOiBjYWxjKHZhcigtLWRjLWhlYWRlci1oZWlnaHQsICN7JGhlYWRlckhlaWdodH0pKTtcbiAgICBtYXJnaW4tdG9wOiBjYWxjKCN7JG9mZnNldH0gLSB2YXIoLS1kYy1oZWFkZXItaGVpZ2h0LCAjeyRoZWFkZXJIZWlnaHR9KSk7XG59XG5cbkBtaXhpbiByZXNldC1saW5rLXN0eWxlKCkge1xuICAgIGNvbG9yOiBpbmhlcml0O1xuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbn1cblxuQG1peGluIGlzbGFuZHMtZm9jdXMoKSB7XG4gICAgb3V0bGluZTogbm9uZTtcblxuICAgIC51dGlsaXR5Zm9jdXMgJjpmb2N1cyB7XG4gICAgICAgIG91dGxpbmU6IDJweCBzb2xpZCAjZmZkYjRkO1xuICAgIH1cbn1cblxuQG1peGluIGxpbmsoKSB7XG4gICAgQGluY2x1ZGUgaXNsYW5kcy1mb2N1cygpO1xuXG4gICAgY29sb3I6IHZhcigtLWctY29sb3ItdGV4dC1saW5rKTtcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuXG4gICAgJjpob3ZlcixcbiAgICAmOmFjdGl2ZSB7XG4gICAgICAgIGNvbG9yOiB2YXIoLS1nLWNvbG9yLXRleHQtbGluay1ob3Zlcik7XG4gICAgfVxufVxuXG5AbWl4aW4gaGVhZGluZzEoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGRpc3BsYXktMyk7XG4gICAgZm9udC13ZWlnaHQ6IDUwMDtcblxuICAgIEBtZWRpYSAobWF4LXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykgLSAxKSB7XG4gICAgICAgIEBpbmNsdWRlIHRleHQtc2l6ZShkaXNwbGF5LTIpO1xuICAgIH1cbn1cblxuQG1peGluIGhlYWRpbmcyKCkge1xuICAgIEBpbmNsdWRlIHRleHQtc2l6ZShkaXNwbGF5LTEpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nMygpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoaGVhZGVyLTIpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nNCgpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoaGVhZGVyLTEpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nNSgpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0zKTtcbiAgICBmb250LXdlaWdodDogNTAwO1xufVxuXG5AbWl4aW4gaGVhZGluZzYoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGJvZHktMyk7XG4gICAgZm9udC13ZWlnaHQ6IDQwMDtcbn1cblxuQG1peGluIGNvbnRyaWJ1dG9ycy10ZXh0KCkge1xuICAgIGZvbnQtc2l6ZTogMTNweDtcbiAgICBmb250LXdlaWdodDogNDAwO1xuICAgIG1hcmdpbi1yaWdodDogNXB4O1xuICAgIGFsaWduLXNlbGY6IGNlbnRlcjtcbn1cblxuQG1peGluIHRleHQtYm9keS0xKCkge1xuICAgIGZvbnQtc2l6ZTogdmFyKC0tZy10ZXh0LWJvZHktMS1mb250LXNpemUpO1xuICAgIGxpbmUtaGVpZ2h0OiB2YXIoLS1nLXRleHQtYm9keS0xLWxpbmUtaGVpZ2h0KTtcbiAgICBmb250LXdlaWdodDogdmFyKC0tZy10ZXh0LWJvZHktZm9udC13ZWlnaHQpO1xufVxuXG5AbWl4aW4gZGVza3RvcC1vbmx5KCkge1xuICAgIEBtZWRpYSAobWF4LXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykgLSAxKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuXG5AbWl4aW4gZGVza3RvcC10YWJsZXQtb25seSgpIHtcbiAgICBAbWVkaWEgKG1heC13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdzbScpIC0gMSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cblxuQG1peGluIG1vYmlsZS10YWJsZXQtb25seSgpIHtcbiAgICBAbWVkaWEgKG1pbi13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdtZCcpKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuXG5AbWl4aW4gbW9iaWxlLW9ubHkoKSB7XG4gICAgQG1lZGlhIChtaW4td2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnc20nKSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cbiJdfQ== */", "@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"],
|
|
5
|
+
"mappings": ";AAEA,CAAA;AACI,WAAA;AACA,UAAA,EAAA,EAAA;ACDJ;ADGI,CAAA;AEyEA,aAAA;AACA,eAAA;AACA,gBAAA;AACA,cAAA;ADzEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
// src/components/Contributors/Contributors.tsx
|
|
2
|
+
import React from "react";
|
|
3
|
+
import block from "bem-cn-lite";
|
|
4
|
+
import { useTranslation } from "../../hooks";
|
|
5
|
+
import { ContributorAvatars } from "../ContributorAvatars";
|
|
6
|
+
import "./Contributors.css";
|
|
7
|
+
var b = block("contributors");
|
|
8
|
+
var Contributors = (props) => {
|
|
9
|
+
const { users, onlyAuthor = false, isAuthor = false, translationName = "contributors" } = props;
|
|
10
|
+
const { t } = useTranslation(translationName);
|
|
11
|
+
return /* @__PURE__ */ React.createElement("div", { className: b() }, /* @__PURE__ */ React.createElement("div", { className: b("title") }, t("title")), /* @__PURE__ */ React.createElement(ContributorAvatars, { contributors: users, isAuthor, onlyAuthor }));
|
|
12
|
+
};
|
|
13
|
+
var Contributors_default = Contributors;
|
|
14
|
+
export {
|
|
15
|
+
Contributors_default as default
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=Contributors.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Contributors/Contributors.tsx"],
|
|
4
|
+
"sourcesContent": ["import React from 'react';\n\nimport block from 'bem-cn-lite';\n\nimport {useTranslation} from '../../hooks';\nimport {Contributor} from '../../models';\nimport {ContributorAvatars} from '../ContributorAvatars';\n\nimport './Contributors.scss';\n\nconst b = block('contributors');\n\nexport interface ContributorsProps {\n users: Contributor[];\n onlyAuthor?: boolean;\n isAuthor?: boolean;\n translationName?: string;\n}\n\nconst Contributors: React.FC<ContributorsProps> = (props) => {\n const {users, onlyAuthor = false, isAuthor = false, translationName = 'contributors'} = props;\n const {t} = useTranslation(translationName);\n\n return (\n <div className={b()}>\n <div className={b('title')}>{t<string>('title')}</div>\n <ContributorAvatars contributors={users} isAuthor={isAuthor} onlyAuthor={onlyAuthor} />\n </div>\n );\n};\n\nexport default Contributors;\n"],
|
|
5
|
+
"mappings": ";AAAA,OAAO,WAAW;AAElB,OAAO,WAAW;AAElB,SAAQ,sBAAqB;AAE7B,SAAQ,0BAAyB;AAEjC,OAAO;AAEP,IAAM,IAAI,MAAM,cAAc;AAS9B,IAAM,eAA4C,CAAC,UAAU;AACzD,QAAM,EAAC,OAAO,aAAa,OAAO,WAAW,OAAO,kBAAkB,eAAc,IAAI;AACxF,QAAM,EAAC,EAAC,IAAI,eAAe,eAAe;AAE1C,SACI,oCAAC,SAAI,WAAW,EAAE,KACd,oCAAC,SAAI,WAAW,EAAE,OAAO,KAAI,EAAU,OAAO,CAAE,GAChD,oCAAC,sBAAmB,cAAc,OAAO,UAAoB,YAAwB,CACzF;AAER;AAEA,IAAO,uBAAQ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/* src/components/Control/Control.scss */
|
|
2
|
+
.dc-control__tooltip {
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
padding: 4px 8px;
|
|
6
|
+
border: none;
|
|
7
|
+
height: 26px;
|
|
8
|
+
}
|
|
9
|
+
.dc-control__tooltip-text {
|
|
10
|
+
font-size: var(--g-text-body-1-font-size);
|
|
11
|
+
line-height: var(--g-text-body-1-line-height);
|
|
12
|
+
display: block;
|
|
13
|
+
white-space: nowrap;
|
|
14
|
+
}
|
|
15
|
+
/*# sourceMappingURL=Control.css.map */
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Control/Users/3y3k0/doctools/docs-components/src/components/Control/Control.scss", "../../../../src/components/Control/%3Cinput%20css%20gm_LLb%3E", "../../../../src/components/Control/Users/3y3k0/doctools/docs-components/src/styles/mixins.scss"],
|
|
4
|
+
"sourcesContent": ["@import '../../styles/mixins';\n\n.dc-control {\n &__tooltip {\n display: flex;\n align-items: center;\n padding: 4px 8px;\n border: none;\n height: 26px;\n }\n\n &__tooltip-text {\n @include text-size(body-1);\n display: block;\n white-space: nowrap;\n }\n}\n", ".dc-control__tooltip {\n display: flex;\n align-items: center;\n padding: 4px 8px;\n border: none;\n height: 26px;\n}\n.dc-control__tooltip-text {\n font-size: var(--g-text-body-1-font-size);\n line-height: var(--g-text-body-1-line-height);\n display: block;\n white-space: nowrap;\n}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL1VzZXJzLzN5M2swL2RvY3Rvb2xzL2RvY3MtY29tcG9uZW50cy9zcmMvY29tcG9uZW50cy9Db250cm9sIiwic291cmNlcyI6WyJDb250cm9sLnNjc3MiLCIuLi8uLi9zdHlsZXMvbWl4aW5zLnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0k7RUFDSTtFQUNBO0VBQ0E7RUFDQTtFQUNBOztBQUdKO0VDUkE7RUFDQTtFRFNJO0VBQ0EiLCJzb3VyY2VzQ29udGVudCI6WyJAaW1wb3J0ICcuLi8uLi9zdHlsZXMvbWl4aW5zJztcblxuLmRjLWNvbnRyb2wge1xuICAgICZfX3Rvb2x0aXAge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBwYWRkaW5nOiA0cHggOHB4O1xuICAgICAgICBib3JkZXI6IG5vbmU7XG4gICAgICAgIGhlaWdodDogMjZweDtcbiAgICB9XG5cbiAgICAmX190b29sdGlwLXRleHQge1xuICAgICAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0xKTtcbiAgICAgICAgZGlzcGxheTogYmxvY2s7XG4gICAgICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gICAgfVxufVxuIiwiQGltcG9ydCAnLi92YXJpYWJsZXMnO1xuXG5AbWl4aW4gdGV4dC1zaXplKCRuYW1lKSB7XG4gICAgZm9udC1zaXplOiB2YXIoLS1nLXRleHQtI3skbmFtZX0tZm9udC1zaXplKTtcbiAgICBsaW5lLWhlaWdodDogdmFyKC0tZy10ZXh0LSN7JG5hbWV9LWxpbmUtaGVpZ2h0KTtcbn1cblxuQG1peGluIHJlc2V0LWxpc3Qtc3R5bGUoKSB7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG4gICAgbGlzdC1zdHlsZTogbm9uZTtcbn1cblxuQG1peGluIGZpeEFuY2hvclBvc2l0aW9uKCRvZmZzZXQ6IDBweCkge1xuICAgIHBhZGRpbmctdG9wOiBjYWxjKHZhcigtLWRjLWhlYWRlci1oZWlnaHQsICN7JGhlYWRlckhlaWdodH0pKTtcbiAgICBtYXJnaW4tdG9wOiBjYWxjKCN7JG9mZnNldH0gLSB2YXIoLS1kYy1oZWFkZXItaGVpZ2h0LCAjeyRoZWFkZXJIZWlnaHR9KSk7XG59XG5cbkBtaXhpbiByZXNldC1saW5rLXN0eWxlKCkge1xuICAgIGNvbG9yOiBpbmhlcml0O1xuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbn1cblxuQG1peGluIGlzbGFuZHMtZm9jdXMoKSB7XG4gICAgb3V0bGluZTogbm9uZTtcblxuICAgIC51dGlsaXR5Zm9jdXMgJjpmb2N1cyB7XG4gICAgICAgIG91dGxpbmU6IDJweCBzb2xpZCAjZmZkYjRkO1xuICAgIH1cbn1cblxuQG1peGluIGxpbmsoKSB7XG4gICAgQGluY2x1ZGUgaXNsYW5kcy1mb2N1cygpO1xuXG4gICAgY29sb3I6IHZhcigtLWctY29sb3ItdGV4dC1saW5rKTtcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuXG4gICAgJjpob3ZlcixcbiAgICAmOmFjdGl2ZSB7XG4gICAgICAgIGNvbG9yOiB2YXIoLS1nLWNvbG9yLXRleHQtbGluay1ob3Zlcik7XG4gICAgfVxufVxuXG5AbWl4aW4gaGVhZGluZzEoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGRpc3BsYXktMyk7XG4gICAgZm9udC13ZWlnaHQ6IDUwMDtcblxuICAgIEBtZWRpYSAobWF4LXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykgLSAxKSB7XG4gICAgICAgIEBpbmNsdWRlIHRleHQtc2l6ZShkaXNwbGF5LTIpO1xuICAgIH1cbn1cblxuQG1peGluIGhlYWRpbmcyKCkge1xuICAgIEBpbmNsdWRlIHRleHQtc2l6ZShkaXNwbGF5LTEpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nMygpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoaGVhZGVyLTIpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nNCgpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoaGVhZGVyLTEpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nNSgpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0zKTtcbiAgICBmb250LXdlaWdodDogNTAwO1xufVxuXG5AbWl4aW4gaGVhZGluZzYoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGJvZHktMyk7XG4gICAgZm9udC13ZWlnaHQ6IDQwMDtcbn1cblxuQG1peGluIGNvbnRyaWJ1dG9ycy10ZXh0KCkge1xuICAgIGZvbnQtc2l6ZTogMTNweDtcbiAgICBmb250LXdlaWdodDogNDAwO1xuICAgIG1hcmdpbi1yaWdodDogNXB4O1xuICAgIGFsaWduLXNlbGY6IGNlbnRlcjtcbn1cblxuQG1peGluIHRleHQtYm9keS0xKCkge1xuICAgIGZvbnQtc2l6ZTogdmFyKC0tZy10ZXh0LWJvZHktMS1mb250LXNpemUpO1xuICAgIGxpbmUtaGVpZ2h0OiB2YXIoLS1nLXRleHQtYm9keS0xLWxpbmUtaGVpZ2h0KTtcbiAgICBmb250LXdlaWdodDogdmFyKC0tZy10ZXh0LWJvZHktZm9udC13ZWlnaHQpO1xufVxuXG5AbWl4aW4gZGVza3RvcC1vbmx5KCkge1xuICAgIEBtZWRpYSAobWF4LXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykgLSAxKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuXG5AbWl4aW4gZGVza3RvcC10YWJsZXQtb25seSgpIHtcbiAgICBAbWVkaWEgKG1heC13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdzbScpIC0gMSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cblxuQG1peGluIG1vYmlsZS10YWJsZXQtb25seSgpIHtcbiAgICBAbWVkaWEgKG1pbi13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdtZCcpKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuXG5AbWl4aW4gbW9iaWxlLW9ubHkoKSB7XG4gICAgQG1lZGlhIChtaW4td2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnc20nKSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cbiJdfQ== */", "@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"],
|
|
5
|
+
"mappings": ";AAGI,CAAA;AACI,WAAA;AACA,eAAA;AACA,WAAA,IAAA;AACA,UAAA;AACA,UAAA;ACFR;ADKI,CAAA;AERA,aAAA,IAAA;AACA,eAAA,IAAA;AFSI,WAAA;AACA,eAAA;ACFR;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
// src/components/Control/Control.tsx
|
|
2
|
+
import React, { forwardRef, useCallback, useImperativeHandle, useRef } from "react";
|
|
3
|
+
import { Button, Popup } from "@gravity-ui/uikit";
|
|
4
|
+
import block from "bem-cn-lite";
|
|
5
|
+
import { PopperPosition, usePopupState } from "../../hooks";
|
|
6
|
+
import { ControlSizes } from "../../models";
|
|
7
|
+
import "./Control.css";
|
|
8
|
+
var b = block("dc-control");
|
|
9
|
+
var ICONS_SIZES = {
|
|
10
|
+
[ControlSizes.M]: 16,
|
|
11
|
+
[ControlSizes.L]: 20
|
|
12
|
+
};
|
|
13
|
+
var Control = forwardRef((props, ref) => {
|
|
14
|
+
const {
|
|
15
|
+
onClick,
|
|
16
|
+
className,
|
|
17
|
+
tooltipText,
|
|
18
|
+
isVerticalView,
|
|
19
|
+
size = ControlSizes.M,
|
|
20
|
+
icon,
|
|
21
|
+
popupPosition
|
|
22
|
+
} = props;
|
|
23
|
+
const controlRef = useRef(null);
|
|
24
|
+
const popupState = usePopupState({ autoclose: 3e3 });
|
|
25
|
+
const getTooltipAlign = useCallback(() => {
|
|
26
|
+
if (popupPosition) {
|
|
27
|
+
return popupPosition;
|
|
28
|
+
}
|
|
29
|
+
return isVerticalView ? PopperPosition.LEFT_START : PopperPosition.BOTTOM_END;
|
|
30
|
+
}, [isVerticalView, popupPosition]);
|
|
31
|
+
useImperativeHandle(ref, () => controlRef.current, [controlRef]);
|
|
32
|
+
const position = getTooltipAlign();
|
|
33
|
+
const Icon = icon;
|
|
34
|
+
const iconSize = ICONS_SIZES[size];
|
|
35
|
+
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
|
|
36
|
+
Button,
|
|
37
|
+
{
|
|
38
|
+
view: "flat-secondary",
|
|
39
|
+
onClick,
|
|
40
|
+
ref: controlRef,
|
|
41
|
+
onMouseEnter: popupState.open,
|
|
42
|
+
onMouseLeave: popupState.close,
|
|
43
|
+
className: b(null, className),
|
|
44
|
+
size
|
|
45
|
+
},
|
|
46
|
+
/* @__PURE__ */ React.createElement(Button.Icon, null, /* @__PURE__ */ React.createElement(Icon, { width: iconSize, height: iconSize }))
|
|
47
|
+
), controlRef.current && /* @__PURE__ */ React.createElement(
|
|
48
|
+
Popup,
|
|
49
|
+
{
|
|
50
|
+
anchorRef: controlRef,
|
|
51
|
+
open: popupState.visible,
|
|
52
|
+
onOutsideClick: popupState.close,
|
|
53
|
+
contentClassName: b("tooltip"),
|
|
54
|
+
placement: position
|
|
55
|
+
},
|
|
56
|
+
/* @__PURE__ */ React.createElement("span", { className: b("tooltip-text") }, tooltipText)
|
|
57
|
+
));
|
|
58
|
+
});
|
|
59
|
+
Control.displayName = "DCControl";
|
|
60
|
+
var Control_default = Control;
|
|
61
|
+
export {
|
|
62
|
+
Control_default as default
|
|
63
|
+
};
|
|
64
|
+
//# sourceMappingURL=Control.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Control/Control.tsx"],
|
|
4
|
+
"sourcesContent": ["import React, {forwardRef, useCallback, useImperativeHandle, useRef} from 'react';\n\nimport {Button, Popup} from '@gravity-ui/uikit';\nimport block from 'bem-cn-lite';\n\nimport {PopperPosition, usePopupState} from '../../hooks';\nimport {ControlSizes} from '../../models';\n\nimport './Control.scss';\n\nconst b = block('dc-control');\n\nexport interface IconProps {\n width: number;\n height: number;\n}\n\nexport interface ControlProps {\n onClick?: () => void;\n setRef?: (ref: HTMLButtonElement) => void;\n isVerticalView?: boolean;\n tooltipText: string;\n className?: string;\n size?: ControlSizes;\n icon: React.FC<IconProps>;\n popupPosition?: PopperPosition;\n}\n\nconst ICONS_SIZES = {\n [ControlSizes.M]: 16,\n [ControlSizes.L]: 20,\n};\n\nconst Control = forwardRef((props: ControlProps, ref) => {\n const {\n onClick,\n className,\n tooltipText,\n isVerticalView,\n size = ControlSizes.M,\n icon,\n popupPosition,\n } = props;\n\n const controlRef = useRef<HTMLButtonElement | null>(null);\n\n const popupState = usePopupState({autoclose: 3000});\n\n const getTooltipAlign = useCallback(() => {\n if (popupPosition) {\n return popupPosition;\n }\n\n return isVerticalView ? PopperPosition.LEFT_START : PopperPosition.BOTTOM_END;\n }, [isVerticalView, popupPosition]);\n\n useImperativeHandle(ref, () => controlRef.current, [controlRef]);\n\n const position = getTooltipAlign();\n const Icon = icon;\n const iconSize = ICONS_SIZES[size];\n\n return (\n <React.Fragment>\n <Button\n view=\"flat-secondary\"\n onClick={onClick}\n ref={controlRef}\n onMouseEnter={popupState.open}\n onMouseLeave={popupState.close}\n className={b(null, className)}\n size={size}\n >\n <Button.Icon>\n <Icon width={iconSize} height={iconSize} />\n </Button.Icon>\n </Button>\n {controlRef.current && (\n <Popup\n anchorRef={controlRef}\n open={popupState.visible}\n onOutsideClick={popupState.close}\n contentClassName={b('tooltip')}\n placement={position}\n >\n <span className={b('tooltip-text')}>{tooltipText}</span>\n </Popup>\n )}\n </React.Fragment>\n );\n});\n\nControl.displayName = 'DCControl';\n\nexport default Control;\n"],
|
|
5
|
+
"mappings": ";AAAA,OAAO,SAAQ,YAAY,aAAa,qBAAqB,cAAa;AAE1E,SAAQ,QAAQ,aAAY;AAC5B,OAAO,WAAW;AAElB,SAAQ,gBAAgB,qBAAoB;AAC5C,SAAQ,oBAAmB;AAE3B,OAAO;AAEP,IAAM,IAAI,MAAM,YAAY;AAkB5B,IAAM,cAAc;AAAA,EAChB,CAAC,aAAa,CAAC,GAAG;AAAA,EAClB,CAAC,aAAa,CAAC,GAAG;AACtB;AAEA,IAAM,UAAU,WAAW,CAAC,OAAqB,QAAQ;AACrD,QAAM;AAAA,IACF;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,OAAO,aAAa;AAAA,IACpB;AAAA,IACA;AAAA,EACJ,IAAI;AAEJ,QAAM,aAAa,OAAiC,IAAI;AAExD,QAAM,aAAa,cAAc,EAAC,WAAW,IAAI,CAAC;AAElD,QAAM,kBAAkB,YAAY,MAAM;AACtC,QAAI,eAAe;AACf,aAAO;AAAA,IACX;AAEA,WAAO,iBAAiB,eAAe,aAAa,eAAe;AAAA,EACvE,GAAG,CAAC,gBAAgB,aAAa,CAAC;AAElC,sBAAoB,KAAK,MAAM,WAAW,SAAS,CAAC,UAAU,CAAC;AAE/D,QAAM,WAAW,gBAAgB;AACjC,QAAM,OAAO;AACb,QAAM,WAAW,YAAY,IAAI;AAEjC,SACI,oCAAC,MAAM,UAAN,MACG;AAAA,IAAC;AAAA;AAAA,MACG,MAAK;AAAA,MACL;AAAA,MACA,KAAK;AAAA,MACL,cAAc,WAAW;AAAA,MACzB,cAAc,WAAW;AAAA,MACzB,WAAW,EAAE,MAAM,SAAS;AAAA,MAC5B;AAAA;AAAA,IAEA,oCAAC,OAAO,MAAP,MACG,oCAAC,QAAK,OAAO,UAAU,QAAQ,UAAU,CAC7C;AAAA,EACJ,GACC,WAAW,WACR;AAAA,IAAC;AAAA;AAAA,MACG,WAAW;AAAA,MACX,MAAM,WAAW;AAAA,MACjB,gBAAgB,WAAW;AAAA,MAC3B,kBAAkB,EAAE,SAAS;AAAA,MAC7B,WAAW;AAAA;AAAA,IAEX,oCAAC,UAAK,WAAW,EAAE,cAAc,KAAI,WAAY;AAAA,EACrD,CAER;AAER,CAAC;AAED,QAAQ,cAAc;AAEtB,IAAO,kBAAQ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/* src/components/Controls/Controls.scss */
|
|
2
|
+
.dc-controls {
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
font-size: var(--g-text-body-1-font-size);
|
|
6
|
+
line-height: var(--g-text-body-1-line-height);
|
|
7
|
+
}
|
|
8
|
+
.dc-controls__control:not(:last-child),
|
|
9
|
+
.dc-controls__divider {
|
|
10
|
+
margin-right: 4px;
|
|
11
|
+
}
|
|
12
|
+
.dc-controls__list {
|
|
13
|
+
padding: 4px 0;
|
|
14
|
+
}
|
|
15
|
+
.dc-controls__list_langs {
|
|
16
|
+
width: 120px;
|
|
17
|
+
}
|
|
18
|
+
.dc-controls__list-icon {
|
|
19
|
+
margin-right: 8px;
|
|
20
|
+
font-size: 22px;
|
|
21
|
+
}
|
|
22
|
+
.dc-controls__lang-item {
|
|
23
|
+
display: flex;
|
|
24
|
+
padding: 6px 12px;
|
|
25
|
+
width: 100%;
|
|
26
|
+
}
|
|
27
|
+
.dc-controls__edit-text {
|
|
28
|
+
margin-left: 8px;
|
|
29
|
+
}
|
|
30
|
+
.dc-controls__icon-rotated {
|
|
31
|
+
transform: rotate(90deg);
|
|
32
|
+
}
|
|
33
|
+
@media (min-width: 769px) {
|
|
34
|
+
.dc-controls {
|
|
35
|
+
right: 0;
|
|
36
|
+
}
|
|
37
|
+
.dc-controls_vertical {
|
|
38
|
+
flex-direction: column;
|
|
39
|
+
}
|
|
40
|
+
.dc-controls_vertical .dc-controls__divider {
|
|
41
|
+
height: 1px;
|
|
42
|
+
width: 16px;
|
|
43
|
+
}
|
|
44
|
+
.dc-controls_vertical .dc-controls__control:not(:last-child),
|
|
45
|
+
.dc-controls_vertical .dc-controls__divider {
|
|
46
|
+
margin-right: 0;
|
|
47
|
+
margin-bottom: 4px;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
/*# sourceMappingURL=Controls.css.map */
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Controls/Users/3y3k0/doctools/docs-components/src/components/Controls/Controls.scss", "../../../../src/components/Controls/Users/3y3k0/doctools/docs-components/src/styles/mixins.scss", "../../../../src/components/Controls/%3Cinput%20css%20sxbPx_%3E"],
|
|
4
|
+
"sourcesContent": ["@import '../../styles/mixins';\n@import '../../styles/variables';\n\n.dc-controls {\n display: flex;\n align-items: center;\n @include text-size(body-1);\n\n &__control:not(:last-child),\n &__divider {\n margin-right: 4px;\n }\n\n &__list {\n padding: 4px 0;\n\n &_langs {\n width: 120px;\n }\n }\n\n &__list-icon {\n margin-right: 8px;\n font-size: 22px;\n }\n\n &__lang-item {\n display: flex;\n padding: 6px 12px;\n width: 100%;\n }\n\n &__edit-text {\n margin-left: 8px;\n }\n\n &__icon-rotated {\n transform: rotate(90deg);\n }\n\n @media (min-width: map-get($screenBreakpoints, 'md')) {\n right: 0;\n\n &_vertical {\n flex-direction: column;\n }\n\n &_vertical &__divider {\n height: 1px;\n width: 16px;\n }\n\n &_vertical &__control:not(:last-child),\n &_vertical &__divider {\n margin-right: 0;\n margin-bottom: 4px;\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", ".dc-controls {\n display: flex;\n align-items: center;\n font-size: var(--g-text-body-1-font-size);\n line-height: var(--g-text-body-1-line-height);\n}\n.dc-controls__control:not(:last-child), .dc-controls__divider {\n margin-right: 4px;\n}\n.dc-controls__list {\n padding: 4px 0;\n}\n.dc-controls__list_langs {\n width: 120px;\n}\n.dc-controls__list-icon {\n margin-right: 8px;\n font-size: 22px;\n}\n.dc-controls__lang-item {\n display: flex;\n padding: 6px 12px;\n width: 100%;\n}\n.dc-controls__edit-text {\n margin-left: 8px;\n}\n.dc-controls__icon-rotated {\n transform: rotate(90deg);\n}\n@media (min-width: 769px) {\n .dc-controls {\n right: 0;\n }\n .dc-controls_vertical {\n flex-direction: column;\n }\n .dc-controls_vertical .dc-controls__divider {\n height: 1px;\n width: 16px;\n }\n .dc-controls_vertical .dc-controls__control:not(:last-child), .dc-controls_vertical .dc-controls__divider {\n margin-right: 0;\n margin-bottom: 4px;\n }\n}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL1VzZXJzLzN5M2swL2RvY3Rvb2xzL2RvY3MtY29tcG9uZW50cy9zcmMvY29tcG9uZW50cy9Db250cm9scyIsInNvdXJjZXMiOlsiQ29udHJvbHMuc2NzcyIsIi4uLy4uL3N0eWxlcy9taXhpbnMuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQTtFQUNJO0VBQ0E7RUNGQTtFQUNBOztBRElBO0VBRUk7O0FBR0o7RUFDSTs7QUFFQTtFQUNJOztBQUlSO0VBQ0k7RUFDQTs7QUFHSjtFQUNJO0VBQ0E7RUFDQTs7QUFHSjtFQUNJOztBQUdKO0VBQ0k7O0FBR0o7RUFyQ0o7SUFzQ1E7O0VBRUE7SUFDSTs7RUFHSjtJQUNJO0lBQ0E7O0VBR0o7SUFFSTtJQUNBIiwic291cmNlc0NvbnRlbnQiOlsiQGltcG9ydCAnLi4vLi4vc3R5bGVzL21peGlucyc7XG5AaW1wb3J0ICcuLi8uLi9zdHlsZXMvdmFyaWFibGVzJztcblxuLmRjLWNvbnRyb2xzIHtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGJvZHktMSk7XG5cbiAgICAmX19jb250cm9sOm5vdCg6bGFzdC1jaGlsZCksXG4gICAgJl9fZGl2aWRlciB7XG4gICAgICAgIG1hcmdpbi1yaWdodDogNHB4O1xuICAgIH1cblxuICAgICZfX2xpc3Qge1xuICAgICAgICBwYWRkaW5nOiA0cHggMDtcblxuICAgICAgICAmX2xhbmdzIHtcbiAgICAgICAgICAgIHdpZHRoOiAxMjBweDtcbiAgICAgICAgfVxuICAgIH1cblxuICAgICZfX2xpc3QtaWNvbiB7XG4gICAgICAgIG1hcmdpbi1yaWdodDogOHB4O1xuICAgICAgICBmb250LXNpemU6IDIycHg7XG4gICAgfVxuXG4gICAgJl9fbGFuZy1pdGVtIHtcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgcGFkZGluZzogNnB4IDEycHg7XG4gICAgICAgIHdpZHRoOiAxMDAlO1xuICAgIH1cblxuICAgICZfX2VkaXQtdGV4dCB7XG4gICAgICAgIG1hcmdpbi1sZWZ0OiA4cHg7XG4gICAgfVxuXG4gICAgJl9faWNvbi1yb3RhdGVkIHtcbiAgICAgICAgdHJhbnNmb3JtOiByb3RhdGUoOTBkZWcpO1xuICAgIH1cblxuICAgIEBtZWRpYSAobWluLXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykpIHtcbiAgICAgICAgcmlnaHQ6IDA7XG5cbiAgICAgICAgJl92ZXJ0aWNhbCB7XG4gICAgICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICB9XG5cbiAgICAgICAgJl92ZXJ0aWNhbCAmX19kaXZpZGVyIHtcbiAgICAgICAgICAgIGhlaWdodDogMXB4O1xuICAgICAgICAgICAgd2lkdGg6IDE2cHg7XG4gICAgICAgIH1cblxuICAgICAgICAmX3ZlcnRpY2FsICZfX2NvbnRyb2w6bm90KDpsYXN0LWNoaWxkKSxcbiAgICAgICAgJl92ZXJ0aWNhbCAmX19kaXZpZGVyIHtcbiAgICAgICAgICAgIG1hcmdpbi1yaWdodDogMDtcbiAgICAgICAgICAgIG1hcmdpbi1ib3R0b206IDRweDtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIkBpbXBvcnQgJy4vdmFyaWFibGVzJztcblxuQG1peGluIHRleHQtc2l6ZSgkbmFtZSkge1xuICAgIGZvbnQtc2l6ZTogdmFyKC0tZy10ZXh0LSN7JG5hbWV9LWZvbnQtc2l6ZSk7XG4gICAgbGluZS1oZWlnaHQ6IHZhcigtLWctdGV4dC0jeyRuYW1lfS1saW5lLWhlaWdodCk7XG59XG5cbkBtaXhpbiByZXNldC1saXN0LXN0eWxlKCkge1xuICAgIG1hcmdpbjogMDtcbiAgICBwYWRkaW5nOiAwO1xuICAgIGxpc3Qtc3R5bGU6IG5vbmU7XG59XG5cbkBtaXhpbiBmaXhBbmNob3JQb3NpdGlvbigkb2Zmc2V0OiAwcHgpIHtcbiAgICBwYWRkaW5nLXRvcDogY2FsYyh2YXIoLS1kYy1oZWFkZXItaGVpZ2h0LCAjeyRoZWFkZXJIZWlnaHR9KSk7XG4gICAgbWFyZ2luLXRvcDogY2FsYygjeyRvZmZzZXR9IC0gdmFyKC0tZGMtaGVhZGVyLWhlaWdodCwgI3skaGVhZGVySGVpZ2h0fSkpO1xufVxuXG5AbWl4aW4gcmVzZXQtbGluay1zdHlsZSgpIHtcbiAgICBjb2xvcjogaW5oZXJpdDtcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG59XG5cbkBtaXhpbiBpc2xhbmRzLWZvY3VzKCkge1xuICAgIG91dGxpbmU6IG5vbmU7XG5cbiAgICAudXRpbGl0eWZvY3VzICY6Zm9jdXMge1xuICAgICAgICBvdXRsaW5lOiAycHggc29saWQgI2ZmZGI0ZDtcbiAgICB9XG59XG5cbkBtaXhpbiBsaW5rKCkge1xuICAgIEBpbmNsdWRlIGlzbGFuZHMtZm9jdXMoKTtcblxuICAgIGNvbG9yOiB2YXIoLS1nLWNvbG9yLXRleHQtbGluayk7XG4gICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgIGN1cnNvcjogcG9pbnRlcjtcblxuICAgICY6aG92ZXIsXG4gICAgJjphY3RpdmUge1xuICAgICAgICBjb2xvcjogdmFyKC0tZy1jb2xvci10ZXh0LWxpbmstaG92ZXIpO1xuICAgIH1cbn1cblxuQG1peGluIGhlYWRpbmcxKCkge1xuICAgIEBpbmNsdWRlIHRleHQtc2l6ZShkaXNwbGF5LTMpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG5cbiAgICBAbWVkaWEgKG1heC13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdtZCcpIC0gMSkge1xuICAgICAgICBAaW5jbHVkZSB0ZXh0LXNpemUoZGlzcGxheS0yKTtcbiAgICB9XG59XG5cbkBtaXhpbiBoZWFkaW5nMigpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoZGlzcGxheS0xKTtcbiAgICBmb250LXdlaWdodDogNTAwO1xufVxuXG5AbWl4aW4gaGVhZGluZzMoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGhlYWRlci0yKTtcbiAgICBmb250LXdlaWdodDogNTAwO1xufVxuXG5AbWl4aW4gaGVhZGluZzQoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGhlYWRlci0xKTtcbiAgICBmb250LXdlaWdodDogNTAwO1xufVxuXG5AbWl4aW4gaGVhZGluZzUoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGJvZHktMyk7XG4gICAgZm9udC13ZWlnaHQ6IDUwMDtcbn1cblxuQG1peGluIGhlYWRpbmc2KCkge1xuICAgIEBpbmNsdWRlIHRleHQtc2l6ZShib2R5LTMpO1xuICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG59XG5cbkBtaXhpbiBjb250cmlidXRvcnMtdGV4dCgpIHtcbiAgICBmb250LXNpemU6IDEzcHg7XG4gICAgZm9udC13ZWlnaHQ6IDQwMDtcbiAgICBtYXJnaW4tcmlnaHQ6IDVweDtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG59XG5cbkBtaXhpbiB0ZXh0LWJvZHktMSgpIHtcbiAgICBmb250LXNpemU6IHZhcigtLWctdGV4dC1ib2R5LTEtZm9udC1zaXplKTtcbiAgICBsaW5lLWhlaWdodDogdmFyKC0tZy10ZXh0LWJvZHktMS1saW5lLWhlaWdodCk7XG4gICAgZm9udC13ZWlnaHQ6IHZhcigtLWctdGV4dC1ib2R5LWZvbnQtd2VpZ2h0KTtcbn1cblxuQG1peGluIGRlc2t0b3Atb25seSgpIHtcbiAgICBAbWVkaWEgKG1heC13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdtZCcpIC0gMSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cblxuQG1peGluIGRlc2t0b3AtdGFibGV0LW9ubHkoKSB7XG4gICAgQG1lZGlhIChtYXgtd2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnc20nKSAtIDEpIHtcbiAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICB9XG59XG5cbkBtaXhpbiBtb2JpbGUtdGFibGV0LW9ubHkoKSB7XG4gICAgQG1lZGlhIChtaW4td2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnbWQnKSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cblxuQG1peGluIG1vYmlsZS1vbmx5KCkge1xuICAgIEBtZWRpYSAobWluLXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ3NtJykpIHtcbiAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICB9XG59XG4iXX0= */"],
|
|
5
|
+
"mappings": ";AAGA,CAAA;AACI,WAAA;AACA,eAAA;ACFA,aAAA,IAAA;AACA,eAAA,IAAA;ACCJ;AFGI,CAAA,oBAAA,KAAA;AAAA,CAAA;AAEI,gBAAA;AEFR;AFKI,CAAA;AACI,WAAA,IAAA;AEHR;AFKQ,CAAA;AACI,SAAA;AEHZ;AFOI,CAAA;AACI,gBAAA;AACA,aAAA;AELR;AFQI,CAAA;AACI,WAAA;AACA,WAAA,IAAA;AACA,SAAA;AENR;AFSI,CAAA;AACI,eAAA;AEPR;AFUI,CAAA;AACI,aAAA,OAAA;AERR;AFWI,OAAA,CAAA,SAAA,EAAA;AArCJ,GAAA;AAsCQ,WAAA;AERN;AFUM,GAAA;AACI,oBAAA;AERV;AFWM,GAJA,qBAIA,CAvCJ;AAwCQ,YAAA;AACA,WAAA;AETV;AFYM,GATA,qBASA,CA5CJ,oBA4CI,KAAA;EAAA,CATA,qBASA,CA5CJ;AA8CQ,kBAAA;AACA,mBAAA;AEXV;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
// src/components/Controls/Controls.tsx
|
|
2
|
+
import React, { memo, useContext } from "react";
|
|
3
|
+
import block from "bem-cn-lite";
|
|
4
|
+
import { Feedback, FeedbackView } from "../Feedback";
|
|
5
|
+
import { Subscribe, SubscribeView } from "../Subscribe";
|
|
6
|
+
import { ControlsLayoutContext } from "./ControlsLayout";
|
|
7
|
+
import {
|
|
8
|
+
DividerControl,
|
|
9
|
+
EditControl,
|
|
10
|
+
FullScreenControl,
|
|
11
|
+
LangControl,
|
|
12
|
+
PdfControl,
|
|
13
|
+
SettingsControl,
|
|
14
|
+
SinglePageControl
|
|
15
|
+
} from "./";
|
|
16
|
+
import "./Controls.css";
|
|
17
|
+
var b = block("dc-controls");
|
|
18
|
+
var Controls = memo((props) => {
|
|
19
|
+
const { isVerticalView } = useContext(ControlsLayoutContext);
|
|
20
|
+
const {
|
|
21
|
+
className,
|
|
22
|
+
fullScreen,
|
|
23
|
+
singlePage,
|
|
24
|
+
theme,
|
|
25
|
+
wideFormat,
|
|
26
|
+
showMiniToc,
|
|
27
|
+
hideEditControl,
|
|
28
|
+
hideFeedbackControls,
|
|
29
|
+
textSize,
|
|
30
|
+
onChangeFullScreen,
|
|
31
|
+
onChangeTheme,
|
|
32
|
+
onChangeShowMiniToc,
|
|
33
|
+
onChangeTextSize,
|
|
34
|
+
onChangeWideFormat,
|
|
35
|
+
onChangeLang,
|
|
36
|
+
onChangeSinglePage,
|
|
37
|
+
onSendFeedback,
|
|
38
|
+
onSubscribe,
|
|
39
|
+
lang,
|
|
40
|
+
langs,
|
|
41
|
+
pdfLink,
|
|
42
|
+
vcsUrl,
|
|
43
|
+
vcsType,
|
|
44
|
+
isLiked,
|
|
45
|
+
isDisliked
|
|
46
|
+
} = props;
|
|
47
|
+
const withFullscreenControl = Boolean(onChangeFullScreen);
|
|
48
|
+
const withSettingsControl = Boolean(
|
|
49
|
+
onChangeWideFormat || onChangeTheme || onChangeShowMiniToc || onChangeTextSize
|
|
50
|
+
);
|
|
51
|
+
const withLangControl = Boolean(lang && onChangeLang);
|
|
52
|
+
const withSinglePageControl = Boolean(onChangeSinglePage);
|
|
53
|
+
const withPdfControl = Boolean(pdfLink);
|
|
54
|
+
const withEditControl = Boolean(!singlePage && !hideEditControl && vcsUrl);
|
|
55
|
+
const withFeedbackControl = Boolean(!singlePage && !hideFeedbackControls && onSendFeedback);
|
|
56
|
+
const withSubscribeControls = Boolean(!singlePage && onSubscribe);
|
|
57
|
+
const controls = [
|
|
58
|
+
withFullscreenControl && /* @__PURE__ */ React.createElement(
|
|
59
|
+
FullScreenControl,
|
|
60
|
+
{
|
|
61
|
+
key: "fullscreen-control",
|
|
62
|
+
value: fullScreen,
|
|
63
|
+
onChange: onChangeFullScreen
|
|
64
|
+
}
|
|
65
|
+
),
|
|
66
|
+
withSettingsControl && /* @__PURE__ */ React.createElement(
|
|
67
|
+
SettingsControl,
|
|
68
|
+
{
|
|
69
|
+
key: "settings-control",
|
|
70
|
+
theme,
|
|
71
|
+
wideFormat,
|
|
72
|
+
showMiniToc,
|
|
73
|
+
textSize,
|
|
74
|
+
onChangeTheme,
|
|
75
|
+
onChangeShowMiniToc,
|
|
76
|
+
onChangeTextSize,
|
|
77
|
+
onChangeWideFormat
|
|
78
|
+
}
|
|
79
|
+
),
|
|
80
|
+
withLangControl && /* @__PURE__ */ React.createElement(
|
|
81
|
+
LangControl,
|
|
82
|
+
{
|
|
83
|
+
key: "lang-control",
|
|
84
|
+
lang,
|
|
85
|
+
langs,
|
|
86
|
+
onChangeLang
|
|
87
|
+
}
|
|
88
|
+
),
|
|
89
|
+
withSinglePageControl && /* @__PURE__ */ React.createElement(
|
|
90
|
+
SinglePageControl,
|
|
91
|
+
{
|
|
92
|
+
key: "single-page-control",
|
|
93
|
+
value: singlePage,
|
|
94
|
+
onChange: onChangeSinglePage
|
|
95
|
+
}
|
|
96
|
+
),
|
|
97
|
+
withPdfControl && /* @__PURE__ */ React.createElement(PdfControl, { key: "pdf-control", pdfLink }),
|
|
98
|
+
"---",
|
|
99
|
+
withEditControl && /* @__PURE__ */ React.createElement(
|
|
100
|
+
EditControl,
|
|
101
|
+
{
|
|
102
|
+
key: "edit-control",
|
|
103
|
+
vcsUrl,
|
|
104
|
+
vcsType
|
|
105
|
+
}
|
|
106
|
+
),
|
|
107
|
+
"---",
|
|
108
|
+
withFeedbackControl && /* @__PURE__ */ React.createElement(
|
|
109
|
+
Feedback,
|
|
110
|
+
{
|
|
111
|
+
key: "feedback-control",
|
|
112
|
+
isLiked,
|
|
113
|
+
isDisliked,
|
|
114
|
+
onSendFeedback,
|
|
115
|
+
view: FeedbackView.Regular
|
|
116
|
+
}
|
|
117
|
+
),
|
|
118
|
+
"---",
|
|
119
|
+
withSubscribeControls && /* @__PURE__ */ React.createElement(
|
|
120
|
+
Subscribe,
|
|
121
|
+
{
|
|
122
|
+
key: "subscribe-control",
|
|
123
|
+
onSubscribe,
|
|
124
|
+
view: SubscribeView.Regular
|
|
125
|
+
}
|
|
126
|
+
)
|
|
127
|
+
].filter(Boolean).reduce((result, control, index, array) => {
|
|
128
|
+
if (control === "---") {
|
|
129
|
+
if (array[index - 1] && array[index + 1] && array[index + 1] !== "---") {
|
|
130
|
+
result.push(
|
|
131
|
+
/* @__PURE__ */ React.createElement(DividerControl, { key: "divider-" + index, className: b("divider") })
|
|
132
|
+
);
|
|
133
|
+
}
|
|
134
|
+
} else {
|
|
135
|
+
result.push(control);
|
|
136
|
+
}
|
|
137
|
+
return result;
|
|
138
|
+
}, []);
|
|
139
|
+
return /* @__PURE__ */ React.createElement("div", { className: b({ vertical: isVerticalView }, className) }, controls);
|
|
140
|
+
});
|
|
141
|
+
Controls.displayName = "DCControls";
|
|
142
|
+
var Controls_default = Controls;
|
|
143
|
+
export {
|
|
144
|
+
Controls_default as default
|
|
145
|
+
};
|
|
146
|
+
//# sourceMappingURL=Controls.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/Controls/Controls.tsx"],
|
|
4
|
+
"sourcesContent": ["import React, {memo, useContext} from 'react';\n\nimport block from 'bem-cn-lite';\n\nimport {FeedbackSendData, Lang, SubscribeData, TextSizes, Theme} from '../../models';\nimport {Feedback, FeedbackView} from '../Feedback';\nimport {Subscribe, SubscribeView} from '../Subscribe';\n\nimport {ControlsLayoutContext} from './ControlsLayout';\n\nimport {\n DividerControl,\n EditControl,\n FullScreenControl,\n LangControl,\n PdfControl,\n SettingsControl,\n SinglePageControl,\n} from './';\n\nimport './Controls.scss';\n\nconst b = block('dc-controls');\n\nexport interface ControlsProps {\n lang?: Lang;\n langs?: string[];\n fullScreen?: boolean;\n singlePage?: boolean;\n wideFormat?: boolean;\n showMiniToc?: boolean;\n theme?: Theme;\n textSize?: TextSizes;\n vcsUrl?: string;\n vcsType?: string;\n isLiked?: boolean;\n isDisliked?: boolean;\n onChangeLang?: (lang: Lang) => void;\n onChangeFullScreen?: (value: boolean) => void;\n onChangeSinglePage?: (value: boolean) => void;\n onChangeWideFormat?: (value: boolean) => void;\n onChangeShowMiniToc?: (value: boolean) => void;\n onChangeTheme?: (theme: Theme) => void;\n onChangeTextSize?: (textSize: TextSizes) => void;\n onSendFeedback?: (data: FeedbackSendData) => void;\n onSubscribe?: (data: SubscribeData) => void;\n pdfLink?: string;\n className?: string;\n hideEditControl?: boolean;\n hideFeedbackControls?: boolean;\n}\n\ntype Defined = {\n [P in keyof ControlsProps]-?: ControlsProps[P];\n};\n\nconst Controls = memo<ControlsProps>((props) => {\n const {isVerticalView} = useContext(ControlsLayoutContext);\n const {\n className,\n fullScreen,\n singlePage,\n theme,\n wideFormat,\n showMiniToc,\n hideEditControl,\n hideFeedbackControls,\n textSize,\n onChangeFullScreen,\n onChangeTheme,\n onChangeShowMiniToc,\n onChangeTextSize,\n onChangeWideFormat,\n onChangeLang,\n onChangeSinglePage,\n onSendFeedback,\n onSubscribe,\n lang,\n langs,\n pdfLink,\n vcsUrl,\n vcsType,\n isLiked,\n isDisliked,\n } = props;\n\n const withFullscreenControl = Boolean(onChangeFullScreen);\n const withSettingsControl = Boolean(\n onChangeWideFormat || onChangeTheme || onChangeShowMiniToc || onChangeTextSize,\n );\n const withLangControl = Boolean(lang && onChangeLang);\n const withSinglePageControl = Boolean(onChangeSinglePage);\n const withPdfControl = Boolean(pdfLink);\n const withEditControl = Boolean(!singlePage && !hideEditControl && vcsUrl);\n const withFeedbackControl = Boolean(!singlePage && !hideFeedbackControls && onSendFeedback);\n const withSubscribeControls = Boolean(!singlePage && onSubscribe);\n\n const controls = [\n withFullscreenControl && (\n <FullScreenControl\n key=\"fullscreen-control\"\n value={fullScreen}\n onChange={onChangeFullScreen}\n />\n ),\n withSettingsControl && (\n <SettingsControl\n key=\"settings-control\"\n theme={theme}\n wideFormat={wideFormat}\n showMiniToc={showMiniToc}\n textSize={textSize}\n onChangeTheme={onChangeTheme}\n onChangeShowMiniToc={onChangeShowMiniToc}\n onChangeTextSize={onChangeTextSize}\n onChangeWideFormat={onChangeWideFormat}\n />\n ),\n withLangControl && (\n <LangControl\n key=\"lang-control\"\n lang={lang as Lang}\n langs={langs}\n onChangeLang={onChangeLang as Defined['onChangeLang']}\n />\n ),\n withSinglePageControl && (\n <SinglePageControl\n key=\"single-page-control\"\n value={singlePage}\n onChange={onChangeSinglePage as Defined['onChangeSinglePage']}\n />\n ),\n withPdfControl && <PdfControl key=\"pdf-control\" pdfLink={pdfLink as Defined['pdfLink']} />,\n '---',\n withEditControl && (\n <EditControl\n key=\"edit-control\"\n vcsUrl={vcsUrl as Defined['vcsUrl']}\n vcsType={vcsType as Defined['vcsType']}\n />\n ),\n '---',\n withFeedbackControl && (\n <Feedback\n key=\"feedback-control\"\n isLiked={isLiked}\n isDisliked={isDisliked}\n onSendFeedback={onSendFeedback as Defined['onSendFeedback']}\n view={FeedbackView.Regular}\n />\n ),\n '---',\n withSubscribeControls && (\n <Subscribe\n key=\"subscribe-control\"\n onSubscribe={onSubscribe as Defined['onSubscribe']}\n view={SubscribeView.Regular}\n />\n ),\n ]\n .filter(Boolean)\n .reduce((result, control, index, array) => {\n if (control === '---') {\n if (array[index - 1] && array[index + 1] && array[index + 1] !== '---') {\n result.push(\n <DividerControl key={'divider-' + index} className={b('divider')} />,\n );\n }\n } else {\n result.push(control as React.ReactElement);\n }\n\n return result;\n }, [] as React.ReactElement[]);\n\n return <div className={b({vertical: isVerticalView}, className)}>{controls}</div>;\n});\n\nControls.displayName = 'DCControls';\n\nexport default Controls;\n"],
|
|
5
|
+
"mappings": ";AAAA,OAAO,SAAQ,MAAM,kBAAiB;AAEtC,OAAO,WAAW;AAGlB,SAAQ,UAAU,oBAAmB;AACrC,SAAQ,WAAW,qBAAoB;AAEvC,SAAQ,6BAA4B;AAEpC;AAAA,EACI;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACG;AAEP,OAAO;AAEP,IAAM,IAAI,MAAM,aAAa;AAkC7B,IAAM,WAAW,KAAoB,CAAC,UAAU;AAC5C,QAAM,EAAC,eAAc,IAAI,WAAW,qBAAqB;AACzD,QAAM;AAAA,IACF;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACJ,IAAI;AAEJ,QAAM,wBAAwB,QAAQ,kBAAkB;AACxD,QAAM,sBAAsB;AAAA,IACxB,sBAAsB,iBAAiB,uBAAuB;AAAA,EAClE;AACA,QAAM,kBAAkB,QAAQ,QAAQ,YAAY;AACpD,QAAM,wBAAwB,QAAQ,kBAAkB;AACxD,QAAM,iBAAiB,QAAQ,OAAO;AACtC,QAAM,kBAAkB,QAAQ,CAAC,cAAc,CAAC,mBAAmB,MAAM;AACzE,QAAM,sBAAsB,QAAQ,CAAC,cAAc,CAAC,wBAAwB,cAAc;AAC1F,QAAM,wBAAwB,QAAQ,CAAC,cAAc,WAAW;AAEhE,QAAM,WAAW;AAAA,IACb,yBACI;AAAA,MAAC;AAAA;AAAA,QACG,KAAI;AAAA,QACJ,OAAO;AAAA,QACP,UAAU;AAAA;AAAA,IACd;AAAA,IAEJ,uBACI;AAAA,MAAC;AAAA;AAAA,QACG,KAAI;AAAA,QACJ;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA;AAAA,IACJ;AAAA,IAEJ,mBACI;AAAA,MAAC;AAAA;AAAA,QACG,KAAI;AAAA,QACJ;AAAA,QACA;AAAA,QACA;AAAA;AAAA,IACJ;AAAA,IAEJ,yBACI;AAAA,MAAC;AAAA;AAAA,QACG,KAAI;AAAA,QACJ,OAAO;AAAA,QACP,UAAU;AAAA;AAAA,IACd;AAAA,IAEJ,kBAAkB,oCAAC,cAAW,KAAI,eAAc,SAAwC;AAAA,IACxF;AAAA,IACA,mBACI;AAAA,MAAC;AAAA;AAAA,QACG,KAAI;AAAA,QACJ;AAAA,QACA;AAAA;AAAA,IACJ;AAAA,IAEJ;AAAA,IACA,uBACI;AAAA,MAAC;AAAA;AAAA,QACG,KAAI;AAAA,QACJ;AAAA,QACA;AAAA,QACA;AAAA,QACA,MAAM,aAAa;AAAA;AAAA,IACvB;AAAA,IAEJ;AAAA,IACA,yBACI;AAAA,MAAC;AAAA;AAAA,QACG,KAAI;AAAA,QACJ;AAAA,QACA,MAAM,cAAc;AAAA;AAAA,IACxB;AAAA,EAER,EACK,OAAO,OAAO,EACd,OAAO,CAAC,QAAQ,SAAS,OAAO,UAAU;AACvC,QAAI,YAAY,OAAO;AACnB,UAAI,MAAM,QAAQ,CAAC,KAAK,MAAM,QAAQ,CAAC,KAAK,MAAM,QAAQ,CAAC,MAAM,OAAO;AACpE,eAAO;AAAA,UACH,oCAAC,kBAAe,KAAK,aAAa,OAAO,WAAW,EAAE,SAAS,GAAG;AAAA,QACtE;AAAA,MACJ;AAAA,IACJ,OAAO;AACH,aAAO,KAAK,OAA6B;AAAA,IAC7C;AAEA,WAAO;AAAA,EACX,GAAG,CAAC,CAAyB;AAEjC,SAAO,oCAAC,SAAI,WAAW,EAAE,EAAC,UAAU,eAAc,GAAG,SAAS,KAAI,QAAS;AAC/E,CAAC;AAED,SAAS,cAAc;AAEvB,IAAO,mBAAQ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
// src/components/Controls/ControlsLayout.tsx
|
|
2
|
+
import React, { createContext } from "react";
|
|
3
|
+
import block from "bem-cn-lite";
|
|
4
|
+
import { PopperPosition } from "../../hooks";
|
|
5
|
+
import { ControlSizes } from "../../models";
|
|
6
|
+
var ControlsLayoutContext = createContext({
|
|
7
|
+
controlClassName: "",
|
|
8
|
+
isVerticalView: false,
|
|
9
|
+
controlSize: ControlSizes.M,
|
|
10
|
+
popupPosition: PopperPosition.BOTTOM_END
|
|
11
|
+
});
|
|
12
|
+
var b = block("dc-controls");
|
|
13
|
+
var ControlsLayout = ({
|
|
14
|
+
isVerticalView,
|
|
15
|
+
controlClassName,
|
|
16
|
+
controlSize,
|
|
17
|
+
popupPosition,
|
|
18
|
+
children
|
|
19
|
+
}) => {
|
|
20
|
+
return /* @__PURE__ */ React.createElement(
|
|
21
|
+
ControlsLayoutContext.Provider,
|
|
22
|
+
{
|
|
23
|
+
value: {
|
|
24
|
+
controlClassName: controlClassName || b("control"),
|
|
25
|
+
isVerticalView,
|
|
26
|
+
controlSize,
|
|
27
|
+
popupPosition
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
children
|
|
31
|
+
);
|
|
32
|
+
};
|
|
33
|
+
export {
|
|
34
|
+
ControlsLayout,
|
|
35
|
+
ControlsLayoutContext
|
|
36
|
+
};
|
|
37
|
+
//# sourceMappingURL=ControlsLayout.js.map
|