@gravity-ui/blog-constructor 6.5.1-beta.0 → 6.6.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/build/cjs/blocks/Author/Author.d.ts +3 -2
- package/build/cjs/blocks/Author/Author.js +13 -13
- package/build/cjs/blocks/Author/schema.js +3 -4
- package/build/cjs/blocks/Banner/Banner.d.ts +3 -2
- package/build/cjs/blocks/Banner/Banner.js +15 -11
- package/build/cjs/blocks/Banner/schema.js +3 -4
- package/build/cjs/blocks/CTA/CTA.d.ts +3 -2
- package/build/cjs/blocks/CTA/CTA.js +20 -19
- package/build/cjs/blocks/CTA/schema.js +3 -4
- package/build/cjs/blocks/ColoredText/ColoredText.d.ts +3 -2
- package/build/cjs/blocks/ColoredText/ColoredText.js +12 -9
- package/build/cjs/blocks/ColoredText/schema.js +3 -4
- package/build/cjs/blocks/Feed/Feed.d.ts +3 -2
- package/build/cjs/blocks/Feed/Feed.js +31 -31
- package/build/cjs/blocks/Feed/reducer.d.ts +1 -1
- package/build/cjs/blocks/Feed/reducer.js +2 -3
- package/build/cjs/blocks/Feed/schema.js +2 -3
- package/build/cjs/blocks/Form/Form.d.ts +3 -2
- package/build/cjs/blocks/Form/Form.js +10 -10
- package/build/cjs/blocks/Form/schema.js +3 -4
- package/build/cjs/blocks/Header/Header.d.ts +3 -2
- package/build/cjs/blocks/Header/Header.js +18 -18
- package/build/cjs/blocks/Header/schema.d.ts +0 -3
- package/build/cjs/blocks/Header/schema.js +3 -4
- package/build/cjs/blocks/Layout/Layout.d.ts +3 -3
- package/build/cjs/blocks/Layout/Layout.js +13 -12
- package/build/cjs/blocks/Layout/schema.js +3 -4
- package/build/cjs/blocks/Media/Media.d.ts +3 -2
- package/build/cjs/blocks/Media/Media.js +15 -12
- package/build/cjs/blocks/Media/schema.d.ts +0 -3
- package/build/cjs/blocks/Media/schema.js +3 -4
- package/build/cjs/blocks/Meta/Meta.d.ts +3 -2
- package/build/cjs/blocks/Meta/Meta.js +23 -22
- package/build/cjs/blocks/Meta/schema.js +3 -4
- package/build/cjs/blocks/Suggest/Suggest.d.ts +3 -2
- package/build/cjs/blocks/Suggest/Suggest.js +14 -15
- package/build/cjs/blocks/Suggest/schema.js +3 -4
- package/build/cjs/blocks/YFM/YFM.d.ts +3 -2
- package/build/cjs/blocks/YFM/YFM.js +11 -10
- package/build/cjs/blocks/YFM/schema.js +3 -4
- package/build/cjs/blocks/constants.js +1 -2
- package/build/cjs/components/FeedHeader/FeedHeader.d.ts +4 -3
- package/build/cjs/components/FeedHeader/FeedHeader.js +14 -10
- package/build/cjs/components/FeedHeader/components/Controls/Controls.d.ts +4 -4
- package/build/cjs/components/FeedHeader/components/Controls/Controls.js +40 -30
- package/build/cjs/components/FeedHeader/components/Controls/customRenders.d.ts +3 -2
- package/build/cjs/components/FeedHeader/components/Controls/customRenders.js +9 -13
- package/build/cjs/components/FeedHeader/components/CustomSelectOption/CustomSelectOption.d.ts +2 -2
- package/build/cjs/components/FeedHeader/components/CustomSelectOption/CustomSelectOption.js +7 -5
- package/build/cjs/components/FeedHeader/components/CustomSwitcher/CustomSwitcher.css +1 -1
- package/build/cjs/components/FeedHeader/components/CustomSwitcher/CustomSwitcher.d.ts +3 -2
- package/build/cjs/components/FeedHeader/components/CustomSwitcher/CustomSwitcher.js +17 -13
- package/build/cjs/components/MetaWrapper/MetaWrapper.d.ts +1 -1
- package/build/cjs/components/MetaWrapper/MetaWrapper.js +4 -4
- package/build/cjs/components/Paginator/Paginator.d.ts +3 -2
- package/build/cjs/components/Paginator/Paginator.js +29 -25
- package/build/cjs/components/Paginator/components/NavigationButton.d.ts +3 -2
- package/build/cjs/components/Paginator/components/NavigationButton.js +7 -7
- package/build/cjs/components/Paginator/components/PaginatorItem.d.ts +3 -2
- package/build/cjs/components/Paginator/components/PaginatorItem.js +11 -13
- package/build/cjs/components/Paginator/types.d.ts +3 -3
- package/build/cjs/components/Paginator/types.js +1 -2
- package/build/cjs/components/Paginator/utils.d.ts +2 -2
- package/build/cjs/components/Paginator/utils.js +1 -2
- package/build/cjs/components/PostCard/PostCard.d.ts +3 -2
- package/build/cjs/components/PostCard/PostCard.js +23 -16
- package/build/cjs/components/PostInfo/PostInfo.d.ts +3 -2
- package/build/cjs/components/PostInfo/PostInfo.js +15 -13
- package/build/cjs/components/PostInfo/SuggestPostInfo.d.ts +3 -2
- package/build/cjs/components/PostInfo/SuggestPostInfo.js +16 -12
- package/build/cjs/components/PostInfo/components/Date.d.ts +3 -2
- package/build/cjs/components/PostInfo/components/Date.js +8 -10
- package/build/cjs/components/PostInfo/components/ReadingTime.d.ts +3 -2
- package/build/cjs/components/PostInfo/components/ReadingTime.js +10 -7
- package/build/cjs/components/PostInfo/components/Save.d.ts +3 -2
- package/build/cjs/components/PostInfo/components/Save.js +16 -14
- package/build/cjs/components/PostInfo/components/Sharing.d.ts +2 -1
- package/build/cjs/components/PostInfo/components/Sharing.js +17 -17
- package/build/cjs/components/Posts/Posts.d.ts +4 -4
- package/build/cjs/components/Posts/Posts.js +28 -16
- package/build/cjs/components/PostsEmpty/PostsEmpty.d.ts +2 -1
- package/build/cjs/components/PostsEmpty/PostsEmpty.js +8 -6
- package/build/cjs/components/PostsError/PostsError.d.ts +2 -1
- package/build/cjs/components/PostsError/PostsError.js +10 -6
- package/build/cjs/components/Prompt/Prompt.d.ts +2 -1
- package/build/cjs/components/Prompt/Prompt.js +12 -10
- package/build/cjs/components/PromptSignIn/PromptSignIn.d.ts +4 -4
- package/build/cjs/components/PromptSignIn/PromptSignIn.js +5 -6
- package/build/cjs/components/PromptSignIn/hooks/usePromptSignInProps.d.ts +2 -2
- package/build/cjs/components/PromptSignIn/hooks/usePromptSignInProps.js +5 -6
- package/build/cjs/components/Search/Search.d.ts +3 -2
- package/build/cjs/components/Search/Search.js +17 -17
- package/build/cjs/components/Wrapper/Wrapper.d.ts +3 -3
- package/build/cjs/components/Wrapper/Wrapper.js +7 -7
- package/build/cjs/constants.d.ts +2 -2
- package/build/cjs/constants.js +3 -4
- package/build/cjs/constructor/BlogConstructorProvider.d.ts +7 -7
- package/build/cjs/constructor/BlogConstructorProvider.js +19 -21
- package/build/cjs/constructor/blocksMap.d.ts +12 -12
- package/build/cjs/constructor/blocksMap.js +14 -15
- package/build/cjs/containers/BlogPage/BlogPage.d.ts +4 -4
- package/build/cjs/containers/BlogPage/BlogPage.js +25 -22
- package/build/cjs/containers/BlogPostPage/BlogPostPage.d.ts +4 -4
- package/build/cjs/containers/BlogPostPage/BlogPostPage.js +30 -27
- package/build/cjs/contexts/DeviceContext.d.ts +2 -2
- package/build/cjs/contexts/DeviceContext.js +2 -3
- package/build/cjs/contexts/FeedContext.d.ts +2 -2
- package/build/cjs/contexts/FeedContext.js +2 -3
- package/build/cjs/contexts/LikesContext.d.ts +2 -2
- package/build/cjs/contexts/LikesContext.js +2 -3
- package/build/cjs/contexts/LocaleContext.d.ts +2 -2
- package/build/cjs/contexts/LocaleContext.js +3 -4
- package/build/cjs/contexts/MobileContext.d.ts +1 -1
- package/build/cjs/contexts/MobileContext.js +2 -3
- package/build/cjs/contexts/PostPageContext.d.ts +2 -2
- package/build/cjs/contexts/PostPageContext.js +2 -3
- package/build/cjs/contexts/RouterContext.d.ts +2 -2
- package/build/cjs/contexts/RouterContext.js +2 -3
- package/build/cjs/contexts/SettingsContext.d.ts +1 -1
- package/build/cjs/contexts/SettingsContext.js +2 -3
- package/build/cjs/contexts/theme/ThemeContext.d.ts +2 -2
- package/build/cjs/contexts/theme/ThemeContext.js +3 -4
- package/build/cjs/contexts/theme/ThemeProvider.d.ts +4 -4
- package/build/cjs/contexts/theme/ThemeProvider.js +8 -9
- package/build/cjs/contexts/theme/ThemeValueContext.d.ts +1 -1
- package/build/cjs/contexts/theme/ThemeValueContext.js +2 -3
- package/build/cjs/contexts/theme/index.d.ts +6 -6
- package/build/cjs/contexts/theme/index.js +6 -7
- package/build/cjs/contexts/theme/useTheme.d.ts +1 -1
- package/build/cjs/contexts/theme/useTheme.js +5 -5
- package/build/cjs/contexts/theme/useThemeValue.d.ts +1 -1
- package/build/cjs/contexts/theme/useThemeValue.js +5 -5
- package/build/cjs/contexts/theme/withTheme.d.ts +2 -2
- package/build/cjs/contexts/theme/withTheme.js +6 -7
- package/build/cjs/contexts/theme/withThemeValue.d.ts +2 -2
- package/build/cjs/contexts/theme/withThemeValue.js +6 -7
- package/build/cjs/counters/metrika.js +3 -3
- package/build/cjs/counters/utils.js +1 -2
- package/build/cjs/hooks/useAriaAttributes.js +4 -6
- package/build/cjs/hooks/useExtendedComponentMap.d.ts +17 -18
- package/build/cjs/hooks/useExtendedComponentMap.js +4 -5
- package/build/cjs/hooks/useHover.d.ts +1 -1
- package/build/cjs/hooks/useHover.js +6 -6
- package/build/cjs/hooks/useIsIPhone.js +4 -6
- package/build/cjs/hooks/useLikes.d.ts +1 -1
- package/build/cjs/hooks/useLikes.js +6 -8
- package/build/cjs/hooks/useOpenCloseTimer.js +5 -6
- package/build/cjs/i18n/index.d.ts +1 -5
- package/build/cjs/i18n/index.js +2 -3
- package/build/cjs/icons/Close.d.ts +2 -2
- package/build/cjs/icons/Close.js +6 -5
- package/build/cjs/icons/DropdownArrow.d.ts +2 -2
- package/build/cjs/icons/DropdownArrow.js +6 -5
- package/build/cjs/icons/Save.d.ts +2 -2
- package/build/cjs/icons/Save.js +6 -5
- package/build/cjs/icons/SaveFilled.d.ts +2 -2
- package/build/cjs/icons/SaveFilled.js +6 -5
- package/build/cjs/icons/SearchIcon.d.ts +2 -2
- package/build/cjs/icons/SearchIcon.js +6 -5
- package/build/cjs/icons/ShareArrowUp.d.ts +2 -2
- package/build/cjs/icons/ShareArrowUp.js +6 -5
- package/build/cjs/icons/Time.d.ts +2 -2
- package/build/cjs/icons/Time.js +6 -5
- package/build/cjs/index.d.ts +8 -8
- package/build/cjs/index.js +8 -9
- package/build/cjs/models/blocks.d.ts +4 -4
- package/build/cjs/models/blocks.js +1 -2
- package/build/cjs/models/common.d.ts +3 -3
- package/build/cjs/models/common.js +5 -6
- package/build/cjs/models/locale.js +1 -2
- package/build/cjs/models/paddings.js +1 -2
- package/build/cjs/schema/blocks.d.ts +10 -10
- package/build/cjs/schema/blocks.js +10 -11
- package/build/cjs/schema/common.js +1 -2
- package/build/cjs/schema/headers.d.ts +1 -1
- package/build/cjs/schema/headers.js +1 -2
- package/build/cjs/schema/index.d.ts +2 -8
- package/build/cjs/schema/index.js +4 -5
- package/build/cjs/schema/utils.d.ts +1 -1
- package/build/cjs/schema/utils.js +1 -2
- package/build/cjs/utils/cn.js +1 -2
- package/build/cjs/utils/common.d.ts +19 -18
- package/build/cjs/utils/common.js +8 -9
- package/build/cjs/utils/date.js +1 -2
- package/build/cjs/utils/index.d.ts +1 -1
- package/build/cjs/utils/index.js +2 -3
- package/build/cjs/utils/svg.js +1 -2
- package/build/esm/blocks/Author/Author.d.ts +3 -2
- package/build/esm/blocks/Author/Author.js +13 -13
- package/build/esm/blocks/Author/schema.js +3 -4
- package/build/esm/blocks/Banner/Banner.d.ts +3 -2
- package/build/esm/blocks/Banner/Banner.js +15 -11
- package/build/esm/blocks/Banner/schema.js +3 -4
- package/build/esm/blocks/CTA/CTA.d.ts +3 -2
- package/build/esm/blocks/CTA/CTA.js +19 -19
- package/build/esm/blocks/CTA/schema.js +3 -4
- package/build/esm/blocks/ColoredText/ColoredText.d.ts +3 -2
- package/build/esm/blocks/ColoredText/ColoredText.js +12 -9
- package/build/esm/blocks/ColoredText/schema.js +3 -4
- package/build/esm/blocks/Feed/Feed.d.ts +3 -2
- package/build/esm/blocks/Feed/Feed.js +31 -31
- package/build/esm/blocks/Feed/reducer.d.ts +1 -1
- package/build/esm/blocks/Feed/reducer.js +1 -2
- package/build/esm/blocks/Feed/schema.js +2 -3
- package/build/esm/blocks/Form/Form.d.ts +3 -2
- package/build/esm/blocks/Form/Form.js +10 -10
- package/build/esm/blocks/Form/schema.js +3 -4
- package/build/esm/blocks/Header/Header.d.ts +3 -2
- package/build/esm/blocks/Header/Header.js +18 -18
- package/build/esm/blocks/Header/schema.d.ts +0 -3
- package/build/esm/blocks/Header/schema.js +3 -4
- package/build/esm/blocks/Layout/Layout.d.ts +3 -3
- package/build/esm/blocks/Layout/Layout.js +13 -12
- package/build/esm/blocks/Layout/schema.js +3 -4
- package/build/esm/blocks/Media/Media.d.ts +3 -2
- package/build/esm/blocks/Media/Media.js +15 -12
- package/build/esm/blocks/Media/schema.d.ts +0 -3
- package/build/esm/blocks/Media/schema.js +3 -4
- package/build/esm/blocks/Meta/Meta.d.ts +3 -2
- package/build/esm/blocks/Meta/Meta.js +23 -22
- package/build/esm/blocks/Meta/schema.js +3 -4
- package/build/esm/blocks/Suggest/Suggest.d.ts +3 -2
- package/build/esm/blocks/Suggest/Suggest.js +14 -15
- package/build/esm/blocks/Suggest/schema.js +3 -4
- package/build/esm/blocks/YFM/YFM.d.ts +3 -2
- package/build/esm/blocks/YFM/YFM.js +10 -10
- package/build/esm/blocks/YFM/schema.js +3 -4
- package/build/esm/blocks/constants.js +1 -2
- package/build/esm/components/FeedHeader/FeedHeader.d.ts +4 -3
- package/build/esm/components/FeedHeader/FeedHeader.js +13 -10
- package/build/esm/components/FeedHeader/components/Controls/Controls.d.ts +4 -4
- package/build/esm/components/FeedHeader/components/Controls/Controls.js +40 -30
- package/build/esm/components/FeedHeader/components/Controls/customRenders.d.ts +3 -2
- package/build/esm/components/FeedHeader/components/Controls/customRenders.js +8 -12
- package/build/esm/components/FeedHeader/components/CustomSelectOption/CustomSelectOption.d.ts +2 -2
- package/build/esm/components/FeedHeader/components/CustomSelectOption/CustomSelectOption.js +5 -4
- package/build/esm/components/FeedHeader/components/CustomSwitcher/CustomSwitcher.css +1 -1
- package/build/esm/components/FeedHeader/components/CustomSwitcher/CustomSwitcher.d.ts +3 -2
- package/build/esm/components/FeedHeader/components/CustomSwitcher/CustomSwitcher.js +17 -13
- package/build/esm/components/MetaWrapper/MetaWrapper.d.ts +1 -1
- package/build/esm/components/MetaWrapper/MetaWrapper.js +2 -3
- package/build/esm/components/Paginator/Paginator.d.ts +3 -2
- package/build/esm/components/Paginator/Paginator.js +29 -25
- package/build/esm/components/Paginator/components/NavigationButton.d.ts +3 -2
- package/build/esm/components/Paginator/components/NavigationButton.js +5 -6
- package/build/esm/components/Paginator/components/PaginatorItem.d.ts +3 -2
- package/build/esm/components/Paginator/components/PaginatorItem.js +11 -13
- package/build/esm/components/Paginator/types.d.ts +3 -3
- package/build/esm/components/Paginator/types.js +1 -2
- package/build/esm/components/Paginator/utils.d.ts +2 -2
- package/build/esm/components/Paginator/utils.js +1 -2
- package/build/esm/components/PostCard/PostCard.d.ts +3 -2
- package/build/esm/components/PostCard/PostCard.js +23 -16
- package/build/esm/components/PostInfo/PostInfo.d.ts +3 -2
- package/build/esm/components/PostInfo/PostInfo.js +15 -13
- package/build/esm/components/PostInfo/SuggestPostInfo.d.ts +3 -2
- package/build/esm/components/PostInfo/SuggestPostInfo.js +15 -12
- package/build/esm/components/PostInfo/components/Date.d.ts +3 -2
- package/build/esm/components/PostInfo/components/Date.js +8 -10
- package/build/esm/components/PostInfo/components/ReadingTime.d.ts +3 -2
- package/build/esm/components/PostInfo/components/ReadingTime.js +8 -6
- package/build/esm/components/PostInfo/components/Save.d.ts +3 -2
- package/build/esm/components/PostInfo/components/Save.js +16 -14
- package/build/esm/components/PostInfo/components/Sharing.d.ts +2 -1
- package/build/esm/components/PostInfo/components/Sharing.js +17 -17
- package/build/esm/components/Posts/Posts.d.ts +4 -4
- package/build/esm/components/Posts/Posts.js +26 -15
- package/build/esm/components/PostsEmpty/PostsEmpty.d.ts +2 -1
- package/build/esm/components/PostsEmpty/PostsEmpty.js +6 -5
- package/build/esm/components/PostsError/PostsError.d.ts +2 -1
- package/build/esm/components/PostsError/PostsError.js +9 -6
- package/build/esm/components/Prompt/Prompt.d.ts +2 -1
- package/build/esm/components/Prompt/Prompt.js +12 -10
- package/build/esm/components/PromptSignIn/PromptSignIn.d.ts +4 -4
- package/build/esm/components/PromptSignIn/PromptSignIn.js +5 -6
- package/build/esm/components/PromptSignIn/hooks/usePromptSignInProps.d.ts +2 -2
- package/build/esm/components/PromptSignIn/hooks/usePromptSignInProps.js +4 -5
- package/build/esm/components/Search/Search.d.ts +3 -2
- package/build/esm/components/Search/Search.js +17 -17
- package/build/esm/components/Wrapper/Wrapper.d.ts +3 -3
- package/build/esm/components/Wrapper/Wrapper.js +5 -6
- package/build/esm/constants.d.ts +2 -2
- package/build/esm/constants.js +2 -3
- package/build/esm/constructor/BlogConstructorProvider.d.ts +7 -7
- package/build/esm/constructor/BlogConstructorProvider.js +18 -20
- package/build/esm/constructor/blocksMap.d.ts +12 -12
- package/build/esm/constructor/blocksMap.js +14 -15
- package/build/esm/containers/BlogPage/BlogPage.d.ts +4 -4
- package/build/esm/containers/BlogPage/BlogPage.js +25 -22
- package/build/esm/containers/BlogPostPage/BlogPostPage.d.ts +4 -4
- package/build/esm/containers/BlogPostPage/BlogPostPage.js +30 -27
- package/build/esm/contexts/DeviceContext.d.ts +2 -2
- package/build/esm/contexts/DeviceContext.js +2 -3
- package/build/esm/contexts/FeedContext.d.ts +2 -2
- package/build/esm/contexts/FeedContext.js +2 -3
- package/build/esm/contexts/LikesContext.d.ts +2 -2
- package/build/esm/contexts/LikesContext.js +2 -3
- package/build/esm/contexts/LocaleContext.d.ts +2 -2
- package/build/esm/contexts/LocaleContext.js +2 -3
- package/build/esm/contexts/MobileContext.d.ts +1 -1
- package/build/esm/contexts/MobileContext.js +2 -3
- package/build/esm/contexts/PostPageContext.d.ts +2 -2
- package/build/esm/contexts/PostPageContext.js +2 -3
- package/build/esm/contexts/RouterContext.d.ts +2 -2
- package/build/esm/contexts/RouterContext.js +2 -3
- package/build/esm/contexts/SettingsContext.d.ts +1 -1
- package/build/esm/contexts/SettingsContext.js +2 -3
- package/build/esm/contexts/theme/ThemeContext.d.ts +2 -2
- package/build/esm/contexts/theme/ThemeContext.js +3 -4
- package/build/esm/contexts/theme/ThemeProvider.d.ts +4 -4
- package/build/esm/contexts/theme/ThemeProvider.js +7 -8
- package/build/esm/contexts/theme/ThemeValueContext.d.ts +1 -1
- package/build/esm/contexts/theme/ThemeValueContext.js +2 -3
- package/build/esm/contexts/theme/index.d.ts +6 -6
- package/build/esm/contexts/theme/index.js +6 -7
- package/build/esm/contexts/theme/useTheme.d.ts +1 -1
- package/build/esm/contexts/theme/useTheme.js +3 -4
- package/build/esm/contexts/theme/useThemeValue.d.ts +1 -1
- package/build/esm/contexts/theme/useThemeValue.js +3 -4
- package/build/esm/contexts/theme/withTheme.d.ts +2 -2
- package/build/esm/contexts/theme/withTheme.js +4 -6
- package/build/esm/contexts/theme/withThemeValue.d.ts +2 -2
- package/build/esm/contexts/theme/withThemeValue.js +4 -6
- package/build/esm/counters/metrika.js +1 -2
- package/build/esm/counters/utils.js +1 -2
- package/build/esm/hooks/useAriaAttributes.js +4 -5
- package/build/esm/hooks/useExtendedComponentMap.d.ts +17 -18
- package/build/esm/hooks/useExtendedComponentMap.js +3 -4
- package/build/esm/hooks/useHover.d.ts +1 -1
- package/build/esm/hooks/useHover.js +2 -3
- package/build/esm/hooks/useIsIPhone.js +4 -5
- package/build/esm/hooks/useLikes.d.ts +1 -1
- package/build/esm/hooks/useLikes.js +6 -7
- package/build/esm/hooks/useOpenCloseTimer.js +4 -5
- package/build/esm/i18n/index.d.ts +1 -5
- package/build/esm/i18n/index.js +1 -2
- package/build/esm/icons/Close.d.ts +2 -2
- package/build/esm/icons/Close.js +4 -4
- package/build/esm/icons/DropdownArrow.d.ts +2 -2
- package/build/esm/icons/DropdownArrow.js +4 -4
- package/build/esm/icons/Save.d.ts +2 -2
- package/build/esm/icons/Save.js +4 -4
- package/build/esm/icons/SaveFilled.d.ts +2 -2
- package/build/esm/icons/SaveFilled.js +4 -4
- package/build/esm/icons/SearchIcon.d.ts +2 -2
- package/build/esm/icons/SearchIcon.js +4 -4
- package/build/esm/icons/ShareArrowUp.d.ts +2 -2
- package/build/esm/icons/ShareArrowUp.js +4 -4
- package/build/esm/icons/Time.d.ts +2 -2
- package/build/esm/icons/Time.js +4 -4
- package/build/esm/index.d.ts +8 -8
- package/build/esm/index.js +8 -9
- package/build/esm/models/blocks.d.ts +4 -4
- package/build/esm/models/blocks.js +1 -2
- package/build/esm/models/common.d.ts +3 -3
- package/build/esm/models/common.js +1 -2
- package/build/esm/models/locale.js +1 -2
- package/build/esm/models/paddings.js +1 -2
- package/build/esm/schema/blocks.d.ts +10 -10
- package/build/esm/schema/blocks.js +10 -11
- package/build/esm/schema/common.js +1 -2
- package/build/esm/schema/headers.d.ts +1 -1
- package/build/esm/schema/headers.js +1 -2
- package/build/esm/schema/index.d.ts +2 -8
- package/build/esm/schema/index.js +4 -5
- package/build/esm/schema/utils.d.ts +1 -1
- package/build/esm/schema/utils.js +1 -2
- package/build/esm/utils/cn.js +1 -2
- package/build/esm/utils/common.d.ts +19 -18
- package/build/esm/utils/common.js +6 -7
- package/build/esm/utils/date.js +1 -2
- package/build/esm/utils/index.d.ts +1 -1
- package/build/esm/utils/index.js +1 -2
- package/build/esm/utils/svg.js +1 -2
- package/package.json +24 -37
- package/server/data/config.js +1 -1
- package/server/data/contentFilter.js +3 -5
- package/server/data/createReadableContent.js +1 -1
- package/server/data/sanitizeMeta.d.ts +5 -5
- package/server/data/sanitizeMeta.js +1 -1
- package/server/data/transformPageContent.js +3 -5
- package/server/data/transformPost.js +3 -13
- package/server/index.d.ts +4 -4
- package/server/models/blocks.d.ts +2 -2
- package/server/models/blocks.js +1 -1
- package/server/models/common.d.ts +2 -2
- package/server/models/common.js +5 -5
- package/server/models/locale.js +1 -1
- package/server/models/paddings.js +1 -1
- package/styles/storybook/common.scss +0 -7
- package/build/cjs/blocks/Author/Author.js.map +0 -1
- package/build/cjs/blocks/Author/schema.js.map +0 -1
- package/build/cjs/blocks/Banner/Banner.js.map +0 -1
- package/build/cjs/blocks/Banner/schema.js.map +0 -1
- package/build/cjs/blocks/CTA/CTA.js.map +0 -1
- package/build/cjs/blocks/CTA/schema.js.map +0 -1
- package/build/cjs/blocks/ColoredText/ColoredText.js.map +0 -1
- package/build/cjs/blocks/ColoredText/schema.js.map +0 -1
- package/build/cjs/blocks/Feed/Feed.js.map +0 -1
- package/build/cjs/blocks/Feed/reducer.js.map +0 -1
- package/build/cjs/blocks/Feed/schema.js.map +0 -1
- package/build/cjs/blocks/Form/Form.js.map +0 -1
- package/build/cjs/blocks/Form/schema.js.map +0 -1
- package/build/cjs/blocks/Header/Header.js.map +0 -1
- package/build/cjs/blocks/Header/schema.js.map +0 -1
- package/build/cjs/blocks/Layout/Layout.js.map +0 -1
- package/build/cjs/blocks/Layout/schema.js.map +0 -1
- package/build/cjs/blocks/Media/Media.js.map +0 -1
- package/build/cjs/blocks/Media/schema.js.map +0 -1
- package/build/cjs/blocks/Meta/Meta.js.map +0 -1
- package/build/cjs/blocks/Meta/schema.js.map +0 -1
- package/build/cjs/blocks/Suggest/Suggest.js.map +0 -1
- package/build/cjs/blocks/Suggest/schema.js.map +0 -1
- package/build/cjs/blocks/YFM/YFM.js.map +0 -1
- package/build/cjs/blocks/YFM/schema.js.map +0 -1
- package/build/cjs/blocks/constants.js.map +0 -1
- package/build/cjs/components/FeedHeader/FeedHeader.js.map +0 -1
- package/build/cjs/components/FeedHeader/components/Controls/Controls.js.map +0 -1
- package/build/cjs/components/FeedHeader/components/Controls/customRenders.js.map +0 -1
- package/build/cjs/components/FeedHeader/components/CustomSelectOption/CustomSelectOption.js.map +0 -1
- package/build/cjs/components/FeedHeader/components/CustomSwitcher/CustomSwitcher.js.map +0 -1
- package/build/cjs/components/MetaWrapper/MetaWrapper.js.map +0 -1
- package/build/cjs/components/Paginator/Paginator.js.map +0 -1
- package/build/cjs/components/Paginator/components/NavigationButton.js.map +0 -1
- package/build/cjs/components/Paginator/components/PaginatorItem.js.map +0 -1
- package/build/cjs/components/Paginator/types.js.map +0 -1
- package/build/cjs/components/Paginator/utils.js.map +0 -1
- package/build/cjs/components/PostCard/PostCard.js.map +0 -1
- package/build/cjs/components/PostInfo/PostInfo.js.map +0 -1
- package/build/cjs/components/PostInfo/SuggestPostInfo.js.map +0 -1
- package/build/cjs/components/PostInfo/components/Date.js.map +0 -1
- package/build/cjs/components/PostInfo/components/ReadingTime.js.map +0 -1
- package/build/cjs/components/PostInfo/components/Save.js.map +0 -1
- package/build/cjs/components/PostInfo/components/Sharing.js.map +0 -1
- package/build/cjs/components/Posts/Posts.js.map +0 -1
- package/build/cjs/components/PostsEmpty/PostsEmpty.js.map +0 -1
- package/build/cjs/components/PostsError/PostsError.js.map +0 -1
- package/build/cjs/components/Prompt/Prompt.js.map +0 -1
- package/build/cjs/components/PromptSignIn/PromptSignIn.js.map +0 -1
- package/build/cjs/components/PromptSignIn/hooks/usePromptSignInProps.js.map +0 -1
- package/build/cjs/components/Search/Search.js.map +0 -1
- package/build/cjs/components/Wrapper/Wrapper.js.map +0 -1
- package/build/cjs/constants.js.map +0 -1
- package/build/cjs/constructor/BlogConstructorProvider.js.map +0 -1
- package/build/cjs/constructor/blocksMap.js.map +0 -1
- package/build/cjs/containers/BlogPage/BlogPage.js.map +0 -1
- package/build/cjs/containers/BlogPostPage/BlogPostPage.js.map +0 -1
- package/build/cjs/contexts/DeviceContext.js.map +0 -1
- package/build/cjs/contexts/FeedContext.js.map +0 -1
- package/build/cjs/contexts/LikesContext.js.map +0 -1
- package/build/cjs/contexts/LocaleContext.js.map +0 -1
- package/build/cjs/contexts/MobileContext.js.map +0 -1
- package/build/cjs/contexts/PostPageContext.js.map +0 -1
- package/build/cjs/contexts/RouterContext.js.map +0 -1
- package/build/cjs/contexts/SettingsContext.js.map +0 -1
- package/build/cjs/contexts/theme/ThemeContext.js.map +0 -1
- package/build/cjs/contexts/theme/ThemeProvider.js.map +0 -1
- package/build/cjs/contexts/theme/ThemeValueContext.js.map +0 -1
- package/build/cjs/contexts/theme/index.js.map +0 -1
- package/build/cjs/contexts/theme/useTheme.js.map +0 -1
- package/build/cjs/contexts/theme/useThemeValue.js.map +0 -1
- package/build/cjs/contexts/theme/withTheme.js.map +0 -1
- package/build/cjs/contexts/theme/withThemeValue.js.map +0 -1
- package/build/cjs/counters/metrika.js.map +0 -1
- package/build/cjs/counters/utils.js.map +0 -1
- package/build/cjs/hooks/useAriaAttributes.js.map +0 -1
- package/build/cjs/hooks/useExtendedComponentMap.js.map +0 -1
- package/build/cjs/hooks/useHover.js.map +0 -1
- package/build/cjs/hooks/useIsIPhone.js.map +0 -1
- package/build/cjs/hooks/useLikes.js.map +0 -1
- package/build/cjs/hooks/useOpenCloseTimer.js.map +0 -1
- package/build/cjs/i18n/index.js.map +0 -1
- package/build/cjs/icons/Close.js.map +0 -1
- package/build/cjs/icons/DropdownArrow.js.map +0 -1
- package/build/cjs/icons/Save.js.map +0 -1
- package/build/cjs/icons/SaveFilled.js.map +0 -1
- package/build/cjs/icons/SearchIcon.js.map +0 -1
- package/build/cjs/icons/ShareArrowUp.js.map +0 -1
- package/build/cjs/icons/Time.js.map +0 -1
- package/build/cjs/index.js.map +0 -1
- package/build/cjs/models/blocks.js.map +0 -1
- package/build/cjs/models/common.js.map +0 -1
- package/build/cjs/models/locale.js.map +0 -1
- package/build/cjs/models/paddings.js.map +0 -1
- package/build/cjs/package.json +0 -1
- package/build/cjs/schema/blocks.js.map +0 -1
- package/build/cjs/schema/common.js.map +0 -1
- package/build/cjs/schema/headers.js.map +0 -1
- package/build/cjs/schema/index.js.map +0 -1
- package/build/cjs/schema/utils.js.map +0 -1
- package/build/cjs/utils/cn.js.map +0 -1
- package/build/cjs/utils/common.js.map +0 -1
- package/build/cjs/utils/date.js.map +0 -1
- package/build/cjs/utils/index.js.map +0 -1
- package/build/cjs/utils/svg.js.map +0 -1
- package/build/esm/blocks/Author/Author.js.map +0 -1
- package/build/esm/blocks/Author/schema.js.map +0 -1
- package/build/esm/blocks/Banner/Banner.js.map +0 -1
- package/build/esm/blocks/Banner/schema.js.map +0 -1
- package/build/esm/blocks/CTA/CTA.js.map +0 -1
- package/build/esm/blocks/CTA/schema.js.map +0 -1
- package/build/esm/blocks/ColoredText/ColoredText.js.map +0 -1
- package/build/esm/blocks/ColoredText/schema.js.map +0 -1
- package/build/esm/blocks/Feed/Feed.js.map +0 -1
- package/build/esm/blocks/Feed/reducer.js.map +0 -1
- package/build/esm/blocks/Feed/schema.js.map +0 -1
- package/build/esm/blocks/Form/Form.js.map +0 -1
- package/build/esm/blocks/Form/schema.js.map +0 -1
- package/build/esm/blocks/Header/Header.js.map +0 -1
- package/build/esm/blocks/Header/schema.js.map +0 -1
- package/build/esm/blocks/Layout/Layout.js.map +0 -1
- package/build/esm/blocks/Layout/schema.js.map +0 -1
- package/build/esm/blocks/Media/Media.js.map +0 -1
- package/build/esm/blocks/Media/schema.js.map +0 -1
- package/build/esm/blocks/Meta/Meta.js.map +0 -1
- package/build/esm/blocks/Meta/schema.js.map +0 -1
- package/build/esm/blocks/Suggest/Suggest.js.map +0 -1
- package/build/esm/blocks/Suggest/schema.js.map +0 -1
- package/build/esm/blocks/YFM/YFM.js.map +0 -1
- package/build/esm/blocks/YFM/schema.js.map +0 -1
- package/build/esm/blocks/constants.js.map +0 -1
- package/build/esm/components/FeedHeader/FeedHeader.js.map +0 -1
- package/build/esm/components/FeedHeader/components/Controls/Controls.js.map +0 -1
- package/build/esm/components/FeedHeader/components/Controls/customRenders.js.map +0 -1
- package/build/esm/components/FeedHeader/components/CustomSelectOption/CustomSelectOption.js.map +0 -1
- package/build/esm/components/FeedHeader/components/CustomSwitcher/CustomSwitcher.js.map +0 -1
- package/build/esm/components/MetaWrapper/MetaWrapper.js.map +0 -1
- package/build/esm/components/Paginator/Paginator.js.map +0 -1
- package/build/esm/components/Paginator/components/NavigationButton.js.map +0 -1
- package/build/esm/components/Paginator/components/PaginatorItem.js.map +0 -1
- package/build/esm/components/Paginator/types.js.map +0 -1
- package/build/esm/components/Paginator/utils.js.map +0 -1
- package/build/esm/components/PostCard/PostCard.js.map +0 -1
- package/build/esm/components/PostInfo/PostInfo.js.map +0 -1
- package/build/esm/components/PostInfo/SuggestPostInfo.js.map +0 -1
- package/build/esm/components/PostInfo/components/Date.js.map +0 -1
- package/build/esm/components/PostInfo/components/ReadingTime.js.map +0 -1
- package/build/esm/components/PostInfo/components/Save.js.map +0 -1
- package/build/esm/components/PostInfo/components/Sharing.js.map +0 -1
- package/build/esm/components/Posts/Posts.js.map +0 -1
- package/build/esm/components/PostsEmpty/PostsEmpty.js.map +0 -1
- package/build/esm/components/PostsError/PostsError.js.map +0 -1
- package/build/esm/components/Prompt/Prompt.js.map +0 -1
- package/build/esm/components/PromptSignIn/PromptSignIn.js.map +0 -1
- package/build/esm/components/PromptSignIn/hooks/usePromptSignInProps.js.map +0 -1
- package/build/esm/components/Search/Search.js.map +0 -1
- package/build/esm/components/Wrapper/Wrapper.js.map +0 -1
- package/build/esm/constants.js.map +0 -1
- package/build/esm/constructor/BlogConstructorProvider.js.map +0 -1
- package/build/esm/constructor/blocksMap.js.map +0 -1
- package/build/esm/containers/BlogPage/BlogPage.js.map +0 -1
- package/build/esm/containers/BlogPostPage/BlogPostPage.js.map +0 -1
- package/build/esm/contexts/DeviceContext.js.map +0 -1
- package/build/esm/contexts/FeedContext.js.map +0 -1
- package/build/esm/contexts/LikesContext.js.map +0 -1
- package/build/esm/contexts/LocaleContext.js.map +0 -1
- package/build/esm/contexts/MobileContext.js.map +0 -1
- package/build/esm/contexts/PostPageContext.js.map +0 -1
- package/build/esm/contexts/RouterContext.js.map +0 -1
- package/build/esm/contexts/SettingsContext.js.map +0 -1
- package/build/esm/contexts/theme/ThemeContext.js.map +0 -1
- package/build/esm/contexts/theme/ThemeProvider.js.map +0 -1
- package/build/esm/contexts/theme/ThemeValueContext.js.map +0 -1
- package/build/esm/contexts/theme/index.js.map +0 -1
- package/build/esm/contexts/theme/useTheme.js.map +0 -1
- package/build/esm/contexts/theme/useThemeValue.js.map +0 -1
- package/build/esm/contexts/theme/withTheme.js.map +0 -1
- package/build/esm/contexts/theme/withThemeValue.js.map +0 -1
- package/build/esm/counters/metrika.js.map +0 -1
- package/build/esm/counters/utils.js.map +0 -1
- package/build/esm/hooks/useAriaAttributes.js.map +0 -1
- package/build/esm/hooks/useExtendedComponentMap.js.map +0 -1
- package/build/esm/hooks/useHover.js.map +0 -1
- package/build/esm/hooks/useIsIPhone.js.map +0 -1
- package/build/esm/hooks/useLikes.js.map +0 -1
- package/build/esm/hooks/useOpenCloseTimer.js.map +0 -1
- package/build/esm/i18n/index.js.map +0 -1
- package/build/esm/icons/Close.js.map +0 -1
- package/build/esm/icons/DropdownArrow.js.map +0 -1
- package/build/esm/icons/Save.js.map +0 -1
- package/build/esm/icons/SaveFilled.js.map +0 -1
- package/build/esm/icons/SearchIcon.js.map +0 -1
- package/build/esm/icons/ShareArrowUp.js.map +0 -1
- package/build/esm/icons/Time.js.map +0 -1
- package/build/esm/index.js.map +0 -1
- package/build/esm/models/blocks.js.map +0 -1
- package/build/esm/models/common.js.map +0 -1
- package/build/esm/models/locale.js.map +0 -1
- package/build/esm/models/paddings.js.map +0 -1
- package/build/esm/package.json +0 -1
- package/build/esm/schema/blocks.js.map +0 -1
- package/build/esm/schema/common.js.map +0 -1
- package/build/esm/schema/headers.js.map +0 -1
- package/build/esm/schema/index.js.map +0 -1
- package/build/esm/schema/utils.js.map +0 -1
- package/build/esm/utils/cn.js.map +0 -1
- package/build/esm/utils/common.js.map +0 -1
- package/build/esm/utils/date.js.map +0 -1
- package/build/esm/utils/index.js.map +0 -1
- package/build/esm/utils/svg.js.map +0 -1
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Paginator.js","sourceRoot":"../../../../src","sources":["components/Paginator/Paginator.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {useAnalytics} from '@gravity-ui/page-constructor';\n\nimport {DefaultGoalIds} from '../../constants';\nimport {AnalyticsCounter} from '../../counters/utils';\nimport {DefaultEventNames} from '../../models/common';\nimport {block} from '../../utils/cn';\n\nimport {NavigationButton} from './components/NavigationButton';\nimport {PaginatorItem} from './components/PaginatorItem';\nimport {ArrowType, PaginatorItemProps, PaginatorProps} from './types';\nimport {getPageConfigs, getPagesCount} from './utils';\nimport {prepareAnalyticsEvent} from '../../utils/common';\n\nimport _ from 'lodash';\n\nimport './Paginator.scss';\n\nconst b = block('paginator');\n\nconst DEFAULT_PAGE_COUNT_FOR_SHOW_SUPPORT_BUTTONS = 6;\n\nexport const Paginator = ({\n itemsPerPage,\n totalItems,\n maxPages,\n page,\n className,\n onPageChange,\n queryParams,\n pageCountForShowSupportButtons = DEFAULT_PAGE_COUNT_FOR_SHOW_SUPPORT_BUTTONS,\n}: PaginatorProps) => {\n const [pagesCount, setPagesCount] = React.useState(\n getPagesCount({itemsPerPage, totalItems, maxPages}),\n );\n\n const nonPagedQuery = React.useMemo(() => {\n return _.omit(queryParams, ['page']);\n }, [queryParams]);\n\n React.useEffect(() => {\n const count = getPagesCount({itemsPerPage, totalItems, maxPages});\n setPagesCount(count);\n }, [itemsPerPage, totalItems, maxPages]);\n\n const handlePageChange = (pageIndex: number) => onPageChange?.(pageIndex);\n\n const isShowSupportButtons = React.useMemo(\n () => pagesCount > pageCountForShowSupportButtons,\n [pageCountForShowSupportButtons, pagesCount],\n );\n\n const handleAnalyticsHome = useAnalytics(DefaultEventNames.PaginatorHome);\n const handleAnalyticsNext = useAnalytics(DefaultEventNames.PaginatorNext);\n const handleAnalyticsPage = useAnalytics(DefaultEventNames.PaginatorPage);\n\n if (pagesCount <= 1) {\n return null;\n }\n\n const handleArrowClick = (type: ArrowType | number) => {\n let newPage = page;\n\n if (type === 'prev' && page > 1) {\n const event = prepareAnalyticsEvent({\n name: DefaultGoalIds.home,\n counter: AnalyticsCounter.CrossSite,\n });\n handleAnalyticsHome(event);\n newPage = 1;\n } else if (type === 'next' && page < pagesCount) {\n const event = prepareAnalyticsEvent({\n name: DefaultGoalIds.next,\n counter: AnalyticsCounter.CrossSite,\n });\n handleAnalyticsNext(event);\n newPage = page + 1;\n }\n\n if (newPage !== page) {\n handlePageChange(newPage);\n }\n };\n\n const handlePageClick = (index: number | ArrowType) => {\n if (index !== page && typeof index === 'number') {\n const event = prepareAnalyticsEvent({\n name: DefaultGoalIds.page,\n counter: AnalyticsCounter.CrossSite,\n });\n handleAnalyticsPage(event, {page: String(index)});\n handlePageChange(index);\n }\n };\n\n const paginatorItems = getPageConfigs({\n page,\n pagesCount,\n queryParams: nonPagedQuery,\n handlePageClick,\n });\n\n if (page > 1 && isShowSupportButtons) {\n paginatorItems.unshift({\n key: ArrowType.Prev,\n dataKey: ArrowType.Prev,\n queryParams: nonPagedQuery,\n mods: {type: ArrowType.Prev},\n onClick: handleArrowClick,\n index: 0,\n content: <NavigationButton arrowType={ArrowType.Prev} />,\n });\n }\n\n if (page < pagesCount && isShowSupportButtons) {\n paginatorItems.push({\n key: ArrowType.Next,\n queryParams: nonPagedQuery,\n dataKey: ArrowType.Next,\n mods: {type: ArrowType.Next},\n index: page + 1,\n onClick: handleArrowClick,\n content: <NavigationButton arrowType={ArrowType.Next} />,\n });\n }\n\n const renderPaginatorItem = (item: PaginatorItemProps) => {\n const {key, ...rest} = item;\n return <PaginatorItem key={`page_${key}`} {...rest} />;\n };\n\n return (\n <div className={b('pagination')}>\n {page > 1 && (\n <div className={b('pagination-block')}>\n <ul className={b(null, className)}>\n {paginatorItems.slice(0, 1).map(renderPaginatorItem)}\n </ul>\n </div>\n )}\n <div className={b('pagination-block')}>\n <ul className={b(null, className)}>\n {paginatorItems\n .slice(\n page > 1 ? 1 : 0,\n page < pagesCount ? paginatorItems.length - 1 : paginatorItems.length,\n )\n .map(renderPaginatorItem)}\n </ul>\n </div>\n {page < pagesCount && (\n <div className={b('pagination-block')}>\n <ul className={b(null, className)}>\n {paginatorItems\n .slice(paginatorItems.length - 1, paginatorItems.length)\n .map(renderPaginatorItem)}\n </ul>\n </div>\n )}\n </div>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"NavigationButton.js","sourceRoot":"../../../../../src","sources":["components/Paginator/components/NavigationButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,MAAM,EAAE,IAAI,EAAC,+BAAsB;AAC3C,OAAO,EAAC,KAAK,EAAC,6BAA0B;AACxC,OAAO,EAAC,SAAS,EAAC,oBAAiB;AAEnC,OAAO,kBAAkB,CAAC;AAE1B,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;AAO7B,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAAC,SAAS,EAAE,QAAQ,EAAwB,EAAE,EAAE,CAC7E,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CACd,cAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YACpB,SAAS,KAAK,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,GACnF,CACT,CAAC","sourcesContent":["import {Keyset, i18n} from '../../../i18n';\nimport {block} from '../../../utils/cn';\nimport {ArrowType} from '../types';\n\nimport '../Paginator.scss';\n\nconst b = block('paginator');\n\nexport type NavigationButtonProps = {\n arrowType: ArrowType;\n disabled?: boolean;\n};\n\nexport const NavigationButton = ({arrowType, disabled}: NavigationButtonProps) =>\n disabled ? null : (\n <div className={b('icon')}>\n {arrowType === ArrowType.Prev ? i18n(Keyset.ButtonBegin) : i18n(Keyset.ButtonFarther)}\n </div>\n );\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"PaginatorItem.js","sourceRoot":"../../../../../src","sources":["components/Paginator/components/PaginatorItem.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,MAAM,EAAC,MAAM,mBAAmB,CAAC;AAEzC,OAAO,EAAC,aAAa,EAAC,2CAAwC;AAC9D,OAAO,EAAC,eAAe,EAAC,6CAA0C;AAClE,OAAO,EAAC,KAAK,EAAC,6BAA0B;AACxC,OAAO,EAAC,WAAW,IAAI,kBAAkB,EAAC,iCAA8B;AAGxE,OAAO,kBAAkB,CAAC;AAE1B,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;AAE7B,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,EAC1B,OAAO,EACP,IAAI,EACJ,OAAO,EACP,WAAW,EACX,OAAO,EACP,OAAO,GAAG,KAAK,EACf,KAAK,GACY,EAAE,EAAE;IACrB,MAAM,EAAC,MAAM,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IACjD,MAAM,EAAC,yBAAyB,EAAE,WAAW,GAAG,kBAAkB,EAAC,GAC/D,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;IACtC,MAAM,OAAO,GAAG,WAAW,CAAC,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,UAAU,KAAI,EAAE,CAAC,CAAC;IAEtD,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAE,OAAqB,CAAC;IAC/E,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACtC,MAAM,WAAW,GAAG,MAAM,CAAC,OAAO,iCAC3B,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,EAAC,IAAI,EAAE,KAAK,EAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GACvC,WAAW,EAChB;aACG,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK,IAAI,KAAK,EAAE,CAAC;aAC5C,IAAI,CAAC,GAAG,CAAC,CAAC;QACf,OAAO,WAAW,CAAC,CAAC,CAAC,GAAG,OAAO,IAAI,WAAW,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;IAC/D,CAAC,EAAE,CAAC,WAAW,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC;IAElC,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,CAGjC,CAAC,KAAK,EAAE,EAAE;QACN,IAAI,yBAAyB,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;YAChE,OAAO;QACX,CAAC;QAED,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAG,OAAO,CAAC,CAAC;IACvB,CAAC,EACD,CAAC,yBAAyB,EAAE,OAAO,EAAE,OAAO,CAAC,CAChD,CAAC;IAEF,OAAO,CACH,KAAC,MAAM,IACH,IAAI,EAAC,MAAM,EACX,IAAI,EAAC,IAAI,EACT,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,IAAI,CAAC,EAC1B,OAAO,EAAE,WAAW,EACpB,IAAI,EAAE,yBAAyB,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,EAC5D,OAAO,EAAE,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,YAEvC,OAAO,GACH,CACZ,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Button} from '@gravity-ui/uikit';\n\nimport {LocaleContext} from '../../../contexts/LocaleContext';\nimport {SettingsContext} from '../../../contexts/SettingsContext';\nimport {block} from '../../../utils/cn';\nimport {getBlogPath as getDefaultBlogPath} from '../../../utils/common';\nimport {ArrowType, PaginatorItemProps} from '../types';\n\nimport '../Paginator.scss';\n\nconst b = block('paginator');\n\nexport const PaginatorItem = ({\n dataKey,\n mods,\n content,\n queryParams,\n onClick,\n loading = false,\n index,\n}: PaginatorItemProps) => {\n const {locale} = React.useContext(LocaleContext);\n const {addNavigationLinkForPages, getBlogPath = getDefaultBlogPath} =\n React.useContext(SettingsContext);\n const urlPath = getBlogPath(locale?.pathPrefix || '');\n\n const itemKey = Number(dataKey) > 0 ? Number(dataKey) : (dataKey as ArrowType);\n const navigationLink = React.useMemo(() => {\n const queryString = Object.entries({\n ...(index > 1 ? {page: index} : undefined),\n ...queryParams,\n })\n .map(([param, value]) => `${param}=${value}`)\n .join('&');\n return queryString ? `${urlPath}?${queryString}` : urlPath;\n }, [queryParams, index, urlPath]);\n\n const handleClick = React.useCallback<\n (event: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement, MouseEvent>) => void\n >(\n (event) => {\n if (addNavigationLinkForPages && (event.metaKey || event.ctrlKey)) {\n return;\n }\n\n onClick?.(itemKey);\n },\n [addNavigationLinkForPages, itemKey, onClick],\n );\n\n return (\n <Button\n view=\"flat\"\n size=\"xl\"\n className={b('item', mods)}\n onClick={handleClick}\n href={addNavigationLinkForPages ? navigationLink : undefined}\n loading={loading && Boolean(mods.active)}\n >\n {content}\n </Button>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"../../../../src","sources":["components/Paginator/types.ts"],"names":[],"mappings":"AA2BA,MAAM,CAAN,IAAY,SAGX;AAHD,WAAY,SAAS;IACjB,0BAAa,CAAA;IACb,0BAAa,CAAA;AACjB,CAAC,EAHW,SAAS,KAAT,SAAS,QAGpB","sourcesContent":["import * as React from 'react';\n\nimport type {NoStrictEntityMods} from '@bem-react/classname';\n\nimport type {ClassNameProps, Query} from '../../models/common';\n\nexport interface PaginatorItemProps {\n key: string | ArrowType;\n dataKey: string | ArrowType;\n mods: NoStrictEntityMods;\n content: React.ReactNode;\n queryParams: Query;\n onClick?: (key: number | ArrowType) => void;\n loading?: boolean;\n index: number;\n}\n\nexport type PaginatorProps = {\n page: number;\n totalItems: number;\n itemsPerPage: number;\n maxPages: number;\n onPageChange: (page: number) => void;\n pageCountForShowSupportButtons?: number;\n queryParams: Query;\n} & ClassNameProps;\n\nexport enum ArrowType {\n Prev = 'prev',\n Next = 'next',\n}\n\nexport type GetPageConfigParams = {\n page: number;\n pagesCount: number;\n queryParams: Query;\n handlePageClick: (key: number | ArrowType) => void;\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"../../../../src","sources":["components/Paginator/utils.ts"],"names":[],"mappings":"AAEA,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAE5B,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAC3B,IAAI,EACJ,WAAW,EACX,UAAU,EACV,eAAe,GACG,EAAE,EAAE;IACtB,MAAM,cAAc,GAA8B,EAAE,CAAC;IACrD,sDAAsD;IACtD,MAAM,UAAU,GAAG,CAAC,iBAAiB,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IAC/C,IAAI,SAAS,GAAG,IAAI,GAAG,UAAU,CAAC;IAClC,IAAI,OAAO,GAAG,IAAI,GAAG,UAAU,CAAC;IAEhC,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;QAChB,OAAO,GAAG,IAAI,GAAG,UAAU,GAAG,SAAS,GAAG,CAAC,CAAC;QAC5C,SAAS,GAAG,CAAC,CAAC;IAClB,CAAC;IAED,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IAExC,KAAK,IAAI,CAAC,GAAG,SAAS,EAAE,CAAC,IAAI,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC;QACxC,cAAc,CAAC,IAAI,CAAC;YAChB,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC;YACd,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;YAClB,KAAK,EAAE,CAAC;YACR,IAAI,EAAE,EAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,KAAK,CAAC,EAAC;YACxC,WAAW;YACX,OAAO,EAAE,eAAe;YACxB,OAAO,EAAE,CAAC;SACb,CAAC,CAAC;IACP,CAAC;IAED,OAAO,cAAc,CAAC;AAC1B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,CACzB,KAAuE,EACzE,EAAE;IACA,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC;IAEpE,OAAO,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;AAChD,CAAC,CAAC","sourcesContent":["import {GetPageConfigParams, PaginatorItemProps, PaginatorProps} from './types';\n\nconst MAX_VISIBLE_PAGES = 5;\n\nexport const getPageConfigs = ({\n page,\n queryParams,\n pagesCount,\n handlePageClick,\n}: GetPageConfigParams) => {\n const paginatorItems: Array<PaginatorItemProps> = [];\n // it is calculating the middle of visible pages below\n const pageOffset = (MAX_VISIBLE_PAGES - 1) / 2;\n let startPage = page - pageOffset;\n let endPage = page + pageOffset;\n\n if (startPage < 1) {\n endPage = page + pageOffset - startPage + 1;\n startPage = 1;\n }\n\n endPage = Math.min(endPage, pagesCount);\n\n for (let i = startPage; i <= endPage; i++) {\n paginatorItems.push({\n key: String(i),\n dataKey: String(i),\n index: i,\n mods: {type: 'page', active: page === i},\n queryParams,\n onClick: handlePageClick,\n content: i,\n });\n }\n\n return paginatorItems;\n};\n\nexport const getPagesCount = (\n props: Pick<PaginatorProps, 'totalItems' | 'itemsPerPage' | 'maxPages'>,\n) => {\n const totalPages = Math.ceil(props.totalItems / props.itemsPerPage);\n\n return Math.min(totalPages, props.maxPages);\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"PostCard.js","sourceRoot":"../../../../src","sources":["components/PostCard/PostCard.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport {AnalyticsEventsProp, CardBase, HTML, YFMWrapper} from '@gravity-ui/page-constructor';\nimport {useUniqId} from '@gravity-ui/uikit';\n\nimport {LikesContext} from '../../contexts/LikesContext';\nimport {PostCardSize, PostCardTitleHeadingLevel, PostData} from '../../models/common';\nimport {block} from '../../utils/cn';\nimport {SuggestPostInfo} from '../PostInfo/SuggestPostInfo';\nimport {useAriaAttributes} from '../../hooks/useAriaAttributes';\n\nimport './PostCard.scss';\n\ntype PostCardProps = {\n post: PostData;\n fullWidth?: boolean;\n showTag?: boolean;\n size?: PostCardSize;\n titleHeadingLevel?: PostCardTitleHeadingLevel;\n analyticsEvents?: AnalyticsEventsProp;\n};\n\nconst b = block('post-card');\n\nexport const PostCard = ({\n post,\n fullWidth = false,\n size = PostCardSize.SMALL,\n showTag = false,\n titleHeadingLevel = PostCardTitleHeadingLevel.H3,\n analyticsEvents,\n}: PostCardProps) => {\n const {\n title: postTitle,\n htmlTitle,\n textTitle,\n blogPostId,\n id,\n date,\n readingTime,\n hasUserLike,\n likes,\n image,\n description,\n tags,\n url,\n } = post;\n\n const title = postTitle || textTitle || htmlTitle;\n\n const {toggleLike, hasLikes} = React.useContext(LikesContext);\n\n const likesProps = React.useMemo(\n () =>\n hasLikes\n ? {\n hasUserLike,\n likesCount: likes,\n toggleLike,\n }\n : undefined,\n [hasUserLike, likes, toggleLike, hasLikes],\n );\n const titleId = useUniqId();\n const descriptionId = useUniqId();\n const dateId = useUniqId();\n const tagId = useUniqId();\n const readingTimeId = useUniqId();\n const isTagVisible = showTag && tags?.[0]?.name;\n const ariaAttributes = useAriaAttributes({\n labelIds: [isTagVisible && tagId, title && titleId],\n descriptionIds: [\n description && descriptionId,\n date && dateId,\n readingTime && readingTimeId,\n ],\n });\n\n return (\n <CardBase\n url={url}\n analyticsEvents={analyticsEvents}\n className={b('card', {fullWidth})}\n extraProps={ariaAttributes}\n >\n <CardBase.Header image={image} className={b('header', {fullWidth})}>\n <div className={b('image-container')} data-qa=\"blog-suggest-header\" />\n </CardBase.Header>\n <CardBase.Content>\n {isTagVisible && (\n <div id={tagId} className={b('tag', {size})}>\n {tags[0].name}\n </div>\n )}\n {title &&\n React.createElement(\n titleHeadingLevel,\n {className: b('title', {size})},\n <span>\n <HTML id={titleId}>{title}</HTML>\n </span>,\n )}\n {description && (\n <YFMWrapper\n className={b('description')}\n content={description}\n modifiers={{\n blog: size === 'm',\n blogCard: true,\n }}\n id={descriptionId}\n />\n )}\n </CardBase.Content>\n <CardBase.Footer>\n <SuggestPostInfo\n postId={blogPostId || id}\n date={date}\n readingTime={readingTime}\n hasUserLike={hasUserLike}\n likes={likesProps}\n size={size}\n qa=\"blog-suggest-block\"\n dateId={dateId}\n readingTimeId={readingTimeId}\n />\n </CardBase.Footer>\n </CardBase>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"PostInfo.js","sourceRoot":"../../../../src","sources":["components/PostInfo/PostInfo.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,EAAC,eAAe,EAAC,0CAAuC;AAE/D,OAAO,EAAC,KAAK,EAAC,0BAAuB;AAErC,OAAO,EAAC,IAAI,EAAC,6BAA0B;AACvC,OAAO,EAAC,WAAW,EAAC,oCAAiC;AACrD,OAAO,EAAC,IAAI,EAAC,6BAA0B;AACvC,OAAO,EAAC,OAAO,EAAC,gCAA6B;AAC7C,OAAO,EAAC,eAAe,EAAC,8BAA2B;AAEnD,OAAO,gBAAgB,CAAC;AAExB,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;AAU7B;;;;;;;;;;;GAWG;AACH,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,EACrB,IAAI,EACJ,WAAW,EACX,MAAM,EACN,KAAK,GAAG,OAAO,EACf,EAAE,EACF,wBAAwB,GACZ,EAAE,EAAE;IAChB,MAAM,EAAC,KAAK,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;IAClD,MAAM,YAAY,GAAG,eAAe,CAAC,EAAE,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;IAEzE,OAAO,CACH,eAAK,SAAS,EAAE,CAAC,CAAC,WAAW,EAAE,EAAC,KAAK,EAAC,CAAC,aAClC,IAAI,IAAI,KAAC,IAAI,IAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,YAAY,CAAC,IAAI,GAAI,EACnD,WAAW,IAAI,KAAC,WAAW,IAAC,WAAW,EAAE,WAAW,EAAE,EAAE,EAAE,YAAY,CAAC,WAAW,GAAI,EACvF,KAAC,OAAO,IAAC,KAAK,EAAE,KAAK,EAAE,eAAe,EAAE,wBAAwB,aAAxB,wBAAwB,uBAAxB,wBAAwB,CAAE,OAAO,GAAI,EAC5E,KAAK,IAAI,CACN,KAAC,IAAI,IACD,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAK,CAAC,UAAU,EACvB,WAAW,EAAE,KAAK,CAAC,WAAW,EAC9B,cAAc,EAAE,KAAK,CAAC,cAAc,EACpC,eAAe,EAAE,wBAAwB,aAAxB,wBAAwB,uBAAxB,wBAAwB,CAAE,IAAI,EAC/C,KAAK,EAAE,KAAK,EACZ,EAAE,EAAE,YAAY,CAAC,IAAI,GACvB,CACL,IACC,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {AnalyticsEventsProp} from '@gravity-ui/page-constructor';\nimport {PostPageContext} from '../../contexts/PostPageContext';\nimport {PostData, QAProps} from '../../models/common';\nimport {block} from '../../utils/cn';\n\nimport {Date} from './components/Date';\nimport {ReadingTime} from './components/ReadingTime';\nimport {Save} from './components/Save';\nimport {Sharing} from './components/Sharing';\nimport {getQaAttributes} from '../../utils/common';\n\nimport './PostInfo.scss';\n\nconst b = block('post-info');\n\ntype PostInfoProps = QAProps & {\n postId: PostData['id'];\n readingTime: PostData['readingTime'];\n date: PostData['date'];\n theme?: 'light' | 'dark';\n analyticsEventsContainer?: Record<string, AnalyticsEventsProp>;\n};\n\n/**\n * Blog post info panel component\n *\n * @param postId - post id\n * @param readingTime - post reading time\n * @param date - post create date\n * @param theme - theme name\n * @param qa - test-attr\n * @param analyticsEventsContainer - a map of records with a single or collection of objects detailing analytics events\n *\n * @returns jsx\n */\nexport const PostInfo = ({\n date,\n readingTime,\n postId,\n theme = 'light',\n qa,\n analyticsEventsContainer,\n}: PostInfoProps) => {\n const {likes} = React.useContext(PostPageContext);\n const qaAttributes = getQaAttributes(qa, 'date', 'reading-time', 'save');\n\n return (\n <div className={b('container', {theme})}>\n {date && <Date date={date} qa={qaAttributes.date} />}\n {readingTime && <ReadingTime readingTime={readingTime} qa={qaAttributes.readingTime} />}\n <Sharing theme={theme} analyticsEvents={analyticsEventsContainer?.sharing} />\n {likes && (\n <Save\n postId={postId}\n title={likes.likesCount}\n hasUserLike={likes.hasUserLike}\n handleUserLike={likes.handleUserLike}\n analyticsEvents={analyticsEventsContainer?.save}\n theme={theme}\n qa={qaAttributes.save}\n />\n )}\n </div>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"SuggestPostInfo.js","sourceRoot":"../../../../src","sources":["components/PostInfo/SuggestPostInfo.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,QAAQ,EAAC,gCAA6B;AAC9C,OAAO,EAAC,YAAY,EAA4C,+BAA4B;AAC5F,OAAO,EAAC,KAAK,EAAC,0BAAuB;AAErC,OAAO,EAAC,IAAI,EAAC,6BAA0B;AACvC,OAAO,EAAC,WAAW,EAAC,oCAAiC;AACrD,OAAO,EAAC,IAAI,EAAC,6BAA0B;AACvC,OAAO,EAAC,qBAAqB,EAAC,8BAA2B;AACzD,OAAO,EAAC,cAAc,EAAC,2BAAwB;AAE/C,OAAO,gBAAgB,CAAC;AAExB,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;AAE7B,MAAM,UAAU,GAAG,qBAAqB,CAAC,EAAC,IAAI,EAAE,cAAc,CAAC,WAAW,EAAC,CAAC,CAAC;AAgB7E;;;;;;;;;;;;;;;GAeG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAC5B,MAAM,EACN,IAAI,EACJ,WAAW,EACX,KAAK,EACL,IAAI,GAAG,YAAY,CAAC,KAAK,EACzB,EAAE,EACF,MAAM,EACN,aAAa,GACM,EAAE,EAAE;IACvB,MAAM,EAAC,WAAW,EAAE,UAAU,EAAE,UAAU,EAAC,GAAG,QAAQ,CAAC;QACnD,OAAO,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,WAAW;QAC3B,KAAK,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU;QACxB,kBAAkB,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU;QACrC,MAAM,EAAE,MAAM;KACjB,CAAC,CAAC;IAEH,OAAO,CACH,eAAK,SAAS,EAAE,CAAC,CAAC,WAAW,CAAC,aAC1B,eAAK,SAAS,EAAE,CAAC,CAAC,mBAAmB,CAAC,aACjC,IAAI,IAAI,KAAC,IAAI,IAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,GAAI,EACpD,WAAW,IAAI,CACZ,KAAC,WAAW,IAAC,WAAW,EAAE,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,aAAa,GAAI,CAC3E,IACC,EACL,KAAK,IAAI,MAAM,IAAI,CAChB,KAAC,IAAI,IACD,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,UAAU,EACjB,eAAe,EAAE,UAAU,EAC3B,WAAW,EAAE,WAAW,EACxB,cAAc,EAAE,UAAU,EAC1B,IAAI,EAAE,IAAI,EACV,EAAE,EAAE,EAAE,GACR,CACL,IACC,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import {useLikes} from '../../hooks/useLikes';\nimport {PostCardSize, PostData, QAProps, ToggleLikeCallbackType} from '../../models/common';\nimport {block} from '../../utils/cn';\n\nimport {Date} from './components/Date';\nimport {ReadingTime} from './components/ReadingTime';\nimport {Save} from './components/Save';\nimport {prepareAnalyticsEvent} from '../../utils/common';\nimport {DefaultGoalIds} from '../../constants';\n\nimport './PostInfo.scss';\n\nconst b = block('post-info');\n\nconst saveEvents = prepareAnalyticsEvent({name: DefaultGoalIds.saveSuggest});\n\nexport interface SuggestPostInfoProps\n extends Pick<PostData, 'date' | 'readingTime' | 'hasUserLike'>,\n QAProps {\n postId: PostData['blogPostId'];\n size?: PostCardSize;\n likes?: {\n likesCount?: number;\n hasUserLike?: boolean;\n toggleLike?: ToggleLikeCallbackType;\n };\n dateId?: string;\n readingTimeId?: string;\n}\n\n/**\n * Suggest blog card info component\n *\n * @param postId - post id\n * @param date - post create date\n * @param readingTime - post reading time\n * @param hasUserLike - flag that the user liked the post\n * @param likes - likes count\n * @param qa - test-attr\n * @param size - text size\n * @param isModernIcon - flag what we need render 'bookmark' icon\n * @param dateId - id value for element with post date. Useful when providing accessible description\n * @param readingTimeId - id value for element with reading time. Useful when providing accessible description\n *\n * @returns jsx\n */\nexport const SuggestPostInfo = ({\n postId,\n date,\n readingTime,\n likes,\n size = PostCardSize.SMALL,\n qa,\n dateId,\n readingTimeId,\n}: SuggestPostInfoProps) => {\n const {hasUserLike, likesCount, handleLike} = useLikes({\n hasLike: likes?.hasUserLike,\n count: likes?.likesCount,\n toggleLikeCallback: likes?.toggleLike,\n postId: postId,\n });\n\n return (\n <div className={b('container')}>\n <div className={b('suggest-container')}>\n {date && <Date date={date} size={size} id={dateId} />}\n {readingTime && (\n <ReadingTime readingTime={readingTime} size={size} id={readingTimeId} />\n )}\n </div>\n {likes && postId && (\n <Save\n postId={postId}\n title={likesCount}\n analyticsEvents={saveEvents}\n hasUserLike={hasUserLike}\n handleUserLike={handleLike}\n size={size}\n qa={qa}\n />\n )}\n </div>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Date.js","sourceRoot":"../../../../../src","sources":["components/PostInfo/components/Date.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,aAAa,EAAC,2CAAwC;AAC9D,OAAO,EAAC,YAAY,EAAU,kCAA+B;AAC7D,OAAO,EAAC,KAAK,EAAC,6BAA0B;AACxC,OAAO,EAAC,MAAM,EAAC,+BAA4B;AAE3C,OAAO,iBAAiB,CAAC;AAEzB,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;AAQ7B,MAAM,CAAC,MAAM,IAAI,GAAG,CAAC,EAAC,IAAI,EAAE,IAAI,GAAG,YAAY,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,EAAY,EAAE,EAAE;IACzE,MAAM,EAAC,MAAM,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAEjD,OAAO,CACH,cAAK,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,EAAC,IAAI,EAAC,CAAC,EAAE,EAAE,EAAE,EAAE,aAAW,EAAE,YACjD,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,IAAI,CAAC,GACrC,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {LocaleContext} from '../../../contexts/LocaleContext';\nimport {PostCardSize, QAProps} from '../../../models/common';\nimport {block} from '../../../utils/cn';\nimport {format} from '../../../utils/date';\n\nimport '../PostInfo.scss';\n\nconst b = block('post-info');\n\ntype DateProps = QAProps & {\n date: string | number;\n size?: PostCardSize;\n id?: string;\n};\n\nexport const Date = ({date, size = PostCardSize.SMALL, id, qa}: DateProps) => {\n const {locale} = React.useContext(LocaleContext);\n\n return (\n <div className={b('item', {size})} id={id} data-qa={qa}>\n {format(date, 'longDate', locale?.code)}\n </div>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"ReadingTime.js","sourceRoot":"../../../../../src","sources":["components/PostInfo/components/ReadingTime.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAEvC,OAAO,EAAC,MAAM,EAAE,IAAI,EAAC,+BAAsB;AAC3C,OAAO,EAAC,IAAI,EAAC,+BAA4B;AACzC,OAAO,EAAC,KAAK,EAAC,6BAA0B;AAGxC,OAAO,iBAAiB,CAAC;AAEzB,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;AAE7B,MAAM,SAAS,GAAG,EAAE,CAAC;AAQrB,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,EAAC,WAAW,EAAE,IAAI,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAAmB,EAAE,EAAE,CAAC,CAChF,eAAK,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,EAAC,IAAI,EAAC,CAAC,EAAE,EAAE,EAAE,EAAE,aAAW,EAAE,aAClD,eAAM,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YACtB,KAAC,IAAI,IAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC,YAAY,CAAC,GAAI,GAC9D,EACN,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,EAAC,KAAK,EAAE,WAAW,EAAC,CAAC,IACpD,CACT,CAAC","sourcesContent":["import {Icon} from '@gravity-ui/uikit';\n\nimport {Keyset, i18n} from '../../../i18n';\nimport {Time} from '../../../icons/Time';\nimport {block} from '../../../utils/cn';\n\nimport {QAProps} from '../../../models/common';\nimport '../PostInfo.scss';\n\nconst b = block('post-info');\n\nconst ICON_SIZE = 16;\n\ntype ReadingTimeProps = QAProps & {\n readingTime: number;\n size?: 's' | 'm';\n id?: string;\n};\n\nexport const ReadingTime = ({readingTime, size = 's', id, qa}: ReadingTimeProps) => (\n <div className={b('item', {size})} id={id} data-qa={qa}>\n <span className={b('icon')}>\n <Icon data={Time} size={ICON_SIZE} className={b('icon-color')} />\n </span>\n {i18n(Keyset.ContextReadingTime, {count: readingTime})}\n </div>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Save.js","sourceRoot":"../../../../../src","sources":["components/PostInfo/components/Save.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {AnalyticsEventsProp, useAnalytics} from '@gravity-ui/page-constructor';\nimport {Icon, useUniqId} from '@gravity-ui/uikit';\n\nimport {LikesContext} from '../../../contexts/LikesContext';\nimport {Save as SaveIcon} from '../../../icons/Save';\nimport {SaveFilled} from '../../../icons/SaveFilled';\nimport {DefaultEventNames, QAProps} from '../../../models/common';\nimport {block} from '../../../utils/cn';\nimport {postLikeStatus} from '../../../utils/common';\n\nimport '../PostInfo.scss';\nimport {Keyset, i18n} from '../../../i18n';\n\nconst ICON_SIZE = 16;\n\nconst b = block('post-info');\n\ntype SaveProps = QAProps & {\n title: string | number;\n postId: number | string;\n hasUserLike: boolean;\n handleUserLike: () => void;\n theme?: 'light' | 'dark';\n size?: 's' | 'm';\n analyticsEvents?: AnalyticsEventsProp;\n};\n\n/**\n * Components for 'save' blog UI-component\n *\n * @param title - post title\n * @param postId - post id\n * @param hasUserLike - flag what blog has like from current user\n * @param qa - test-attr\n * @param size - text size\n * @param analyticsEvents - a single or collection of objects detailing analytics events\n *\n * @returns jsx\n */\nexport const Save = ({\n title,\n postId,\n hasUserLike,\n handleUserLike,\n size,\n theme,\n qa,\n analyticsEvents,\n}: SaveProps) => {\n const {toggleLike, isSignedInUser, requireSignIn} = React.useContext(LikesContext);\n const handleAnalytics = useAnalytics(DefaultEventNames.SaveButton);\n const isLikeable = Boolean(toggleLike);\n\n const titleElementId = useUniqId();\n const isNumericTitle = typeof title === 'number';\n\n return (\n <button\n className={b('item', {size, save: true})}\n onClick={(event) => {\n // both preventDefault and stopImmediatePropagation required to work properly\n // https://stackoverflow.com/questions/24415631/reactjs-syntheticevent-stoppropagation-only-works-with-react-events\n event.preventDefault();\n event.nativeEvent.stopImmediatePropagation();\n\n if (!isLikeable) {\n return;\n }\n\n // Open Popup to ask the User to sign in first\n if (!isSignedInUser && requireSignIn) {\n requireSignIn(event);\n return;\n }\n\n postLikeStatus(postId, Boolean(hasUserLike));\n handleUserLike();\n handleAnalytics(analyticsEvents);\n }}\n data-qa={qa}\n aria-pressed={hasUserLike}\n aria-label={isNumericTitle ? i18n(Keyset.Save) : undefined}\n aria-describedby={isNumericTitle ? titleElementId : undefined}\n >\n <div className={b('content', {cursor: isLikeable, theme})}>\n <span className={b('icon')}>\n <Icon\n data={hasUserLike ? SaveFilled : SaveIcon}\n size={ICON_SIZE}\n className={b({filled: Boolean(hasUserLike)})}\n />\n </span>\n <span id={titleElementId} className={b('title', {cursor: isLikeable})}>\n {title}\n </span>\n </div>\n </button>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Sharing.js","sourceRoot":"../../../../../src","sources":["components/PostInfo/components/Sharing.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,oBAAoB,EAAE,YAAY,EAAC,MAAM,wBAAwB,CAAC;AAC1E,OAAO,EAAsB,YAAY,EAAC,MAAM,8BAA8B,CAAC;AAE/E,OAAO,EAAC,aAAa,EAAC,2CAAwC;AAC9D,OAAO,EAAC,eAAe,EAAC,6CAA0C;AAClE,OAAO,EAAC,aAAa,EAAC,2CAAwC;AAC9D,OAAO,EAAC,MAAM,EAAE,IAAI,EAAC,+BAAsB;AAC3C,OAAO,EAAC,YAAY,EAAC,uCAAoC;AACzD,OAAO,EAAC,iBAAiB,EAAC,kCAA+B;AACzD,OAAO,EAAC,KAAK,EAAC,6BAA0B;AACxC,OAAO,EAAC,eAAe,EAAC,iCAA8B;AAEtD,OAAO,iBAAiB,CAAC;AAEzB,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;AAO7B,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,EAAC,KAAK,EAAE,eAAe,EAAe,EAAE,EAAE;IAC9D,MAAM,MAAM,GAAG,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAC/C,MAAM,QAAQ,GAAG,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IACjD,MAAM,EAAC,YAAY,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;IACzD,MAAM,qBAAqB,GAAG,YAAY,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;IAE1E,MAAM,eAAe,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QAC3C,qBAAqB,CAAC,eAAe,CAAC,CAAC;IAC3C,CAAC,EAAE,CAAC,eAAe,EAAE,qBAAqB,CAAC,CAAC,CAAC;IAE7C,OAAO,CACH,cAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YACrB,cAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YACrB,KAAC,YAAY,IACT,GAAG,EAAE,eAAe,CAAC,MAAM,CAAC,EAC5B,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,EACrB,SAAS,EAAE,CAAC,CAAC,YAAY,CAAC,EAC1B,iBAAiB,EAAE,CAAC,CAAC,UAAU,EAAE,EAAC,KAAK,EAAC,CAAC,EACzC,gBAAgB,EAAE,CAAC,CAAC,OAAO,CAAC,EAC5B,cAAc,EAAE,QAAQ,EACxB,SAAS,EAAE,oBAAoB,CAAC,MAAM,EACtC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,EACrC,UAAU,EAAE,YAAY,EACxB,SAAS,EAAC,QAAQ,EAClB,WAAW,EAAE,KAAK,EAClB,YAAY,EAAE,YAAY,EAC1B,OAAO,EAAE,eAAe,GAC1B,GACA,GACJ,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {ShareLayoutDirection, SharePopover} from '@gravity-ui/components';\nimport {AnalyticsEventsProp, useAnalytics} from '@gravity-ui/page-constructor';\n\nimport {MobileContext} from '../../../contexts/MobileContext';\nimport {PostPageContext} from '../../../contexts/PostPageContext';\nimport {RouterContext} from '../../../contexts/RouterContext';\nimport {Keyset, i18n} from '../../../i18n';\nimport {ShareArrowUp} from '../../../icons/ShareArrowUp';\nimport {DefaultEventNames} from '../../../models/common';\nimport {block} from '../../../utils/cn';\nimport {getAbsolutePath} from '../../../utils/common';\n\nimport '../PostInfo.scss';\n\nconst b = block('post-info');\n\ntype SharingProps = {\n theme?: 'light' | 'dark';\n analyticsEvents?: AnalyticsEventsProp;\n};\n\nexport const Sharing = ({theme, analyticsEvents}: SharingProps) => {\n const router = React.useContext(RouterContext);\n const isMobile = React.useContext(MobileContext);\n const {shareOptions} = React.useContext(PostPageContext);\n const handleAnalyticsGlobal = useAnalytics(DefaultEventNames.ShareButton);\n\n const handleAnalytics = React.useCallback(() => {\n handleAnalyticsGlobal(analyticsEvents);\n }, [analyticsEvents, handleAnalyticsGlobal]);\n\n return (\n <div className={b('item')}>\n <div className={b('icon')}>\n <SharePopover\n url={getAbsolutePath(router)}\n className={b('share')}\n iconClass={b('share-icon')}\n switcherClassName={b('switcher', {theme})}\n tooltipClassName={b('popup')}\n useWebShareApi={isMobile}\n direction={ShareLayoutDirection.Column}\n buttonTitle={i18n(Keyset.ActionShare)}\n customIcon={ShareArrowUp}\n placement=\"bottom\"\n openByHover={false}\n shareOptions={shareOptions}\n onClick={handleAnalytics}\n />\n </div>\n </div>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Posts.js","sourceRoot":"../../../../src","sources":["components/Posts/Posts.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {CardLayoutBlock} from '@gravity-ui/page-constructor';\nimport {Button} from '@gravity-ui/uikit';\n\nimport {Keyset, i18n} from '../../i18n';\nimport {PostCardSize, PostCardTitleHeadingLevel, PostData, Query} from '../../models/common';\nimport {block} from '../../utils/cn';\nimport {Paginator} from '../Paginator/Paginator';\nimport {PostCard} from '../PostCard/PostCard';\nimport {PostsEmpty} from '../PostsEmpty/PostsEmpty';\n\nimport './Posts.scss';\n\nconst b = block('posts');\n\ntype PostCardProps = {\n containerId: string;\n currentPage: number;\n isShowMoreVisible: boolean;\n errorShowMore: boolean;\n postCountOnPage: number;\n perPageInQuery: number;\n isFetching: boolean;\n handleShowMore: (\n value?: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>,\n ) => Promise<void> | void;\n handlePageChange: (value: number) => Promise<void> | void;\n postsOnPage?: PostData[];\n pinnedPostOnPage?: PostData;\n pageCountForShowSupportButtons?: number;\n queryParams: Query;\n};\n\nexport const Posts = ({\n containerId,\n pinnedPostOnPage,\n currentPage,\n postsOnPage,\n isShowMoreVisible,\n errorShowMore,\n postCountOnPage,\n perPageInQuery,\n isFetching,\n handleShowMore,\n handlePageChange,\n pageCountForShowSupportButtons,\n queryParams,\n}: PostCardProps) => (\n <div className={b()}>\n {isFetching && <div className={b('loaderContainer')} />}\n <div id={containerId} className={b('cards-container', {isLoading: isFetching})}>\n {pinnedPostOnPage && currentPage === 1 && (\n <div className={b('pinned-container')}>\n <PostCard\n post={pinnedPostOnPage}\n size={PostCardSize.MEDIUM}\n fullWidth\n showTag\n titleHeadingLevel={PostCardTitleHeadingLevel.H2}\n />\n </div>\n )}\n {postsOnPage?.length ? (\n <CardLayoutBlock\n title={''}\n colSizes={{\n all: 12,\n lg: 4,\n md: 6,\n }}\n >\n {postsOnPage?.map((post) => (\n <PostCard\n key={post.id}\n post={post}\n showTag\n titleHeadingLevel={\n pinnedPostOnPage\n ? PostCardTitleHeadingLevel.H3\n : PostCardTitleHeadingLevel.H2\n }\n />\n ))}\n </CardLayoutBlock>\n ) : (\n <PostsEmpty />\n )}\n </div>\n\n <div className={b('pagination')}>\n {Boolean(isShowMoreVisible && postsOnPage?.length) && (\n <Button\n view=\"outlined\"\n size=\"xl\"\n className={b('more-button')}\n onClick={handleShowMore}\n >\n {i18n(Keyset.ActionLoadMore)}\n </Button>\n )}\n {errorShowMore && (\n <div className={b('error-show-more')}>\n <div>{i18n(Keyset.ErrorTitle)}</div>\n <div>{i18n(Keyset.PostLoadError)}</div>\n </div>\n )}\n {Boolean(currentPage && postCountOnPage) && (\n <div className={b('paginator')}>\n <Paginator\n onPageChange={handlePageChange}\n page={currentPage}\n totalItems={postCountOnPage}\n itemsPerPage={perPageInQuery}\n maxPages={Infinity}\n pageCountForShowSupportButtons={pageCountForShowSupportButtons}\n queryParams={queryParams}\n />\n </div>\n )}\n </div>\n </div>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"PostsEmpty.js","sourceRoot":"../../../../src","sources":["components/PostsEmpty/PostsEmpty.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,MAAM,EAAE,IAAI,EAAC,4BAAmB;AACxC,OAAO,EAAC,KAAK,EAAC,0BAAuB;AAErC,OAAO,kBAAkB,CAAC;AAE1B,MAAM,CAAC,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC;AAE/B,MAAM,CAAC,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,CAC5B,eAAK,SAAS,EAAE,CAAC,CAAC,WAAW,CAAC,aAC1B,cAAK,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,YAAG,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,GAAO,EACpE,cAAK,SAAS,EAAE,CAAC,CAAC,UAAU,CAAC,YAAG,IAAI,CAAC,MAAM,CAAC,qBAAqB,CAAC,GAAO,IACvE,CACT,CAAC","sourcesContent":["import {Keyset, i18n} from '../../i18n';\nimport {block} from '../../utils/cn';\n\nimport './PostsEmpty.scss';\n\nconst b = block('posts-empty');\n\nexport const PostsEmpty = () => (\n <div className={b('container')}>\n <div className={b('title')}>{i18n(Keyset.TitleEmptyContainer)}</div>\n <div className={b('subtitle')}>{i18n(Keyset.ContextEmptyContainer)}</div>\n </div>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"PostsError.js","sourceRoot":"../../../../src","sources":["components/PostsError/PostsError.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,MAAM,EAAC,MAAM,mBAAmB,CAAC;AAEzC,OAAO,EAAC,MAAM,EAAE,IAAI,EAAC,4BAAmB;AACxC,OAAO,EAAC,KAAK,EAAC,0BAAuB;AAErC,OAAO,iBAAiB,CAAC;AAEzB,MAAM,CAAC,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC;AAM/B,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EAAC,aAAa,EAA2B,EAAE,EAAE;IACpE,MAAM,WAAW,GAAG,GAAG,EAAE,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;IAEvF,OAAO,CACH,eAAK,SAAS,EAAE,CAAC,CAAC,WAAW,CAAC,aAC1B,cAAK,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,YAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,GAAO,EAC3D,cAAK,SAAS,EAAE,CAAC,CAAC,UAAU,CAAC,YAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,GAAO,EACjE,cAAK,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,YACvB,KAAC,MAAM,IAAC,IAAI,EAAC,IAAI,EAAC,IAAI,EAAC,UAAU,EAAC,OAAO,EAAE,WAAW,YACjD,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,GACvB,GACP,IACJ,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import {Button} from '@gravity-ui/uikit';\n\nimport {Keyset, i18n} from '../../i18n';\nimport {block} from '../../utils/cn';\n\nimport './PostError.scss';\n\nconst b = block('posts-error');\n\ntype PostsErrorContainerProps = {\n onButtonClick?: () => void | Promise<void>;\n};\n\nexport const PostsError = ({onButtonClick}: PostsErrorContainerProps) => {\n const handleClick = () => (onButtonClick ? onButtonClick() : window.location.reload());\n\n return (\n <div className={b('container')}>\n <div className={b('title')}>{i18n(Keyset.ErrorTitle)}</div>\n <div className={b('subtitle')}>{i18n(Keyset.PostLoadError)}</div>\n <div className={b('button')}>\n <Button size=\"xl\" view=\"outlined\" onClick={handleClick}>\n {i18n(Keyset.ActionTryAgain)}\n </Button>\n </div>\n </div>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Prompt.js","sourceRoot":"../../../../src","sources":["components/Prompt/Prompt.tsx"],"names":[],"mappings":";;AAAA,OAAO,EAAC,MAAM,EAAc,MAAM,mBAAmB,CAAC;AAEtD,OAAO,EAAC,QAAQ,EAAC,gCAA6B;AAC9C,OAAO,EAAC,iBAAiB,EAAC,yCAAsC;AAChE,OAAO,EAAC,KAAK,EAAC,0BAAuB;AAErC,OAAO,cAAc,CAAC;AAEtB,MAAM,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC;AAc1B;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,EACnB,IAAI,EACJ,OAAO,EACP,SAAS,EACT,aAAa,GAAG,CAAC,EACjB,YAAY,EACZ,KAAK,GACK,EAAE,EAAE;IACd,MAAM,CAAC,GAAG,EAAE,QAAQ,CAAC,GAAG,QAAQ,EAAkB,CAAC;IACnD,MAAM,EAAC,IAAI,EAAE,MAAM,EAAC,GAAG,iBAAiB,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;IACtE,MAAM,IAAI,GAAG,MAAM,IAAI,QAAQ,CAAC;IAChC,MAAM,OAAO,GAAG,aAAa,GAAG,CAAC,CAAC;IAElC,OAAO,CACH,cAAK,SAAS,EAAE,CAAC,CAAC,EAAC,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,IAAI,EAAE,OAAO,EAAC,EAAE,SAAS,CAAC,YAC9D,eAAK,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,EAAE,GAAG,EAAE,GAAG,aAClC,eAAM,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YAAG,IAAI,GAAQ,EACzC,cAAK,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,YACvB,OAAO,CAAC,GAAG,CAAC,CAAC,EAAmD,EAAE,CAAC,EAAE,EAAE;4BAA1D,EAAC,IAAI,GAAG,QAAQ,EAAE,SAAS,EAAE,QAAQ,OAAc,EAAT,QAAQ,cAAlD,qBAAmD,CAAD;wBAAS,OAAA,CACrE,KAAC,MAAM,kBAEH,SAAS,EAAE,CAAC,CAAC,QAAQ,EAAE,QAAQ,CAAC,EAChC,IAAI,EAAE,IAAI,IACN,QAAQ,GAHP,CAAC,CAIR,CACL,CAAA;qBAAA,CAAC,GACA,IACJ,GACJ,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import {Button, ButtonProps} from '@gravity-ui/uikit';\n\nimport {useHover} from '../../hooks/useHover';\nimport {useOpenCloseTimer} from '../../hooks/useOpenCloseTimer';\nimport {block} from '../../utils/cn';\n\nimport './Prompt.scss';\n\nconst b = block('prompt');\n\nexport interface PromptProps {\n // Prompt message\n text: string;\n actions: ButtonProps[];\n // Unix Timestamp in milliseconds when the Prompt opens\n openTimestamp?: number;\n // Milliseconds to remain visible\n openDuration?: number;\n className?: string;\n theme?: 'grey' | 'beige' | 'white';\n}\n\n/**\n * Popup that appears with text message and button(s) for given `actions`.\n * Features:\n * - Automatically disappears after `openDuration` in milliseconds\n * - `openTimestamp` (`Date.now()`) resets the visible duration\n * @returns {JSX|null}\n */\nexport const Prompt = ({\n text,\n actions,\n className,\n openTimestamp = 0,\n openDuration,\n theme,\n}: PromptProps) => {\n const [ref, hovering] = useHover<HTMLDivElement>();\n const {open: isOpen} = useOpenCloseTimer(openTimestamp, openDuration);\n const open = isOpen || hovering;\n const mounted = openTimestamp > 0;\n\n return (\n <div className={b({theme, open, close: !open, mounted}, className)}>\n <div className={b('content')} ref={ref}>\n <span className={b('text')}>{text}</span>\n <div className={b('actions')}>\n {actions.map(({view = 'action', className: btnClass, ...btnProps}, i) => (\n <Button\n key={i}\n className={b('action', btnClass)}\n view={view}\n {...btnProps}\n />\n ))}\n </div>\n </div>\n </div>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"PromptSignIn.js","sourceRoot":"../../../../src","sources":["components/PromptSignIn/PromptSignIn.tsx"],"names":[],"mappings":";;AAEA,OAAO,EAAC,MAAM,EAAE,IAAI,EAAC,4BAAmB;AACxC,OAAO,EAAC,MAAM,EAAc,4BAAyB;AAMrD;;;GAGG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAWT,EAAE,EAAE;QAXK,EACzB,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,EACtC,aAAa,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAChD,OAAO,GAAG;QACN;YACI,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YAC7B,OAAO,EAAE,aAAa;YACtB,IAAI,EAAE,GAAG;SACZ;KACJ,OAEe,EADb,KAAK,cAViB,oCAW5B,CADW;IACa,OAAA,KAAC,MAAM,kBAAM,IAAI,EAAE,OAAO,IAAO,KAAK,EAAI,CAAA;CAAA,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Keyset, i18n} from '../../i18n';\nimport {Prompt, PromptProps} from '../Prompt/Prompt';\n\nexport interface PromptSignInProps extends Partial<PromptProps> {\n onClickSignIn?: React.EventHandler<React.SyntheticEvent>;\n}\n\n/**\n * Authentication Popup that appears when user action requires login\n * @returns {JSX|null}\n */\nexport const PromptSignIn = ({\n text = i18n(Keyset.PromptSignInOnLike),\n onClickSignIn = () => alert(i18n(Keyset.SignIn)),\n actions = [\n {\n children: i18n(Keyset.SignIn),\n onClick: onClickSignIn,\n size: 'l',\n },\n ],\n ...props\n}: PromptSignInProps) => <Prompt {...{text, actions}} {...props} />;\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"usePromptSignInProps.js","sourceRoot":"../../../../../src","sources":["components/PromptSignIn/hooks/usePromptSignInProps.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,MAAM,UAAU,oBAAoB,CAAC,aAAwD;IACzF,MAAM,CAAC,aAAa,EAAE,OAAO,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IACnD,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACrC,OAAO,aAAa;YAChB,CAAC,CAAC,GAAG,EAAE;gBACD,OAAO,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YACxB,CAAC;YACH,CAAC,CAAC,SAAS,CAAC;IACpB,CAAC,EAAE,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,CAAC;IAE7B,OAAO,EAAC,aAAa,EAAE,aAAa,EAAE,aAAa,EAAC,CAAC;AACzD,CAAC","sourcesContent":["import * as React from 'react';\n\nexport function usePromptSignInProps(onClickSignIn?: React.EventHandler<React.SyntheticEvent>) {\n const [openTimestamp, setTime] = React.useState(0);\n const requireSignIn = React.useMemo(() => {\n return onClickSignIn\n ? () => {\n setTime(Date.now());\n }\n : undefined;\n }, [onClickSignIn, setTime]);\n\n return {onClickSignIn, openTimestamp, requireSignIn};\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Search.js","sourceRoot":"../../../../src","sources":["components/Search/Search.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {Icon, TextInput} from '@gravity-ui/uikit';\nimport lodashDebounce from 'lodash/debounce';\n\nimport {useIsIPhone} from '../../hooks/useIsIPhone';\nimport {Keyset, i18n} from '../../i18n';\nimport {Close} from '../../icons/Close';\nimport {SearchIcon} from '../../icons/SearchIcon';\nimport {ClassNameProps} from '../../models/common';\nimport {block} from '../../utils/cn';\n\nimport './Search.scss';\n\nconst b = block('search');\n\nexport type SearchSize = 's' | 'm';\n\ninterface SearchProps extends ClassNameProps {\n value?: string;\n initialValue: string;\n onSubmit: (value: string) => void;\n debounce?: number;\n placeholder?: string;\n size?: SearchSize;\n autoFocus?: boolean;\n className?: string;\n}\n\nconst SEARCH_ICON_SIZE = 16;\nconst CLOSE_ICON_SIZE = 12;\nconst AUTOFOCUS_TIMEOUT = 0;\n\n/**\n * Search component, placed on blog main page,\n * based on TextInput from uikit\n *\n * @returns {JSX|null}\n */\nexport const Search = ({\n className,\n initialValue,\n onSubmit,\n debounce = 300,\n placeholder = i18n(Keyset.Search),\n size = 'm',\n autoFocus = false,\n value: externalValue,\n}: SearchProps) => {\n const handleChange = lodashDebounce(onSubmit, debounce);\n\n const [value, setValue] = React.useState<string>(initialValue);\n const inputRef = React.useRef<HTMLInputElement>(null);\n const isIPhone = useIsIPhone();\n\n React.useEffect(() => {\n if (externalValue !== undefined) {\n setValue(externalValue);\n }\n }, [externalValue]);\n\n React.useEffect(() => {\n if (autoFocus && !isIPhone) {\n setTimeout(() => inputRef?.current?.focus({preventScroll: true}), AUTOFOCUS_TIMEOUT);\n }\n }, [autoFocus, inputRef, isIPhone]);\n\n const rightContent = React.useMemo(() => {\n const iconData = value ? Close : SearchIcon;\n const iconSize = value ? CLOSE_ICON_SIZE : SEARCH_ICON_SIZE;\n\n const handleClick = () => {\n if (value) {\n handleChange.cancel();\n setValue('');\n onSubmit('');\n inputRef.current?.focus();\n }\n };\n\n return (\n <button\n className={b('input-icon')}\n onClick={handleClick}\n aria-label={value ? i18n(Keyset.ClearAction) : undefined}\n aria-hidden={!value}\n >\n <Icon size={iconSize} data={iconData} />\n </button>\n );\n }, [handleChange, onSubmit, value]);\n\n return (\n <div className={b({size}, className)}>\n <TextInput\n className={b('search-suggest')}\n value={value}\n onUpdate={(query) => {\n setValue(query);\n handleChange(query);\n }}\n placeholder={placeholder}\n size={size === 'm' ? 'xl' : 'l'}\n controlRef={inputRef}\n view=\"clear\"\n controlProps={{\n className: b('search-suggest-control'),\n }}\n endContent={rightContent}\n />\n </div>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Wrapper.js","sourceRoot":"../../../../src","sources":["components/Wrapper/Wrapper.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,gBAAgB,EAAC,2BAAwB;AAGjD,OAAO,EAAC,KAAK,EAAC,0BAAuB;AAErC,OAAO,eAAe,CAAC;AAEvB,MAAM,CAAC,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC;AAQ3B,MAAM,CAAC,MAAM,OAAO,GAA0C,CAAC,EAC3D,QAAQ,EACR,QAAQ,GAAG,gBAAgB,EAC3B,SAAS,EACT,EAAE,GACL,EAAE,EAAE,CAAC,CACF,kBACI,SAAS,EAAE,CAAC,CACR;QACI,CAAC,aAAa,CAAC,EAAE,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,GAAG,KAAI,IAAI;QACtC,CAAC,gBAAgB,CAAC,EAAE,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,MAAM,KAAI,GAAG;QAC3C,CAAC,cAAc,CAAC,EAAE,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI,KAAI,EAAE;QACtC,CAAC,eAAe,CAAC,EAAE,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,KAAK,KAAI,EAAE;KAC3C,EACD,SAAS,CACZ,aACQ,EAAE,YAEV,QAAQ,GACH,CACb,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {DEFAULT_PADDINGS} from '../../constants';\nimport {ClassNameProps, QAProps} from '../../models/common';\nimport {Paddings} from '../../models/paddings';\nimport {block} from '../../utils/cn';\n\nimport './Wrapper.scss';\n\nconst b = block('wrapper');\n\ntype WrapperProps = ClassNameProps &\n QAProps & {\n paddings?: Paddings;\n children?: React.ReactNode;\n };\n\nexport const Wrapper: React.FunctionComponent<WrapperProps> = ({\n children,\n paddings = DEFAULT_PADDINGS,\n className,\n qa,\n}) => (\n <section\n className={b(\n {\n ['padding-top']: paddings?.top || 'xs',\n ['padding-bottom']: paddings?.bottom || 'l',\n ['padding-left']: paddings?.left || '',\n ['padding-right']: paddings?.right || '',\n },\n className,\n )}\n data-qa={qa}\n >\n {children}\n </section>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"constants.js","sourceRoot":"../../src","sources":["constants.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,kBAAkB,EAAC,6BAA0B;AAE/D,MAAM,CAAC,MAAM,WAAW,GAAG;IACvB,EAAE,EAAE,CAAC;IACL,EAAE,EAAE,GAAG;IACP,EAAE,EAAE,GAAG;IACP,EAAE,EAAE,IAAI;IACR,EAAE,EAAE,IAAI;CACX,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,OAAO,CAAC;AAErC,MAAM,CAAC,MAAM,gBAAgB,GAAG,QAAQ,CAAC;AACzC,MAAM,CAAC,MAAM,uBAAuB,GAAG,GAAG,gBAAgB,UAAU,aAAa,EAAE,CAAC;AAEpF,MAAM,CAAN,IAAY,cAiBX;AAjBD,WAAY,cAAc;IACtB,wDAAsC,CAAA;IACtC,8DAA4C,CAAA;IAC5C,oEAAkD,CAAA;IAClD,0EAAwD,CAAA;IACxD,sDAAoC,CAAA;IACpC,4DAA0C,CAAA;IAC1C,8DAA4C,CAAA;IAC5C,8DAA4C,CAAA;IAC5C,8DAA4C,CAAA;IAC5C,6CAA2B,CAAA;IAC3B,uDAAqC,CAAA;IACrC,6DAA2C,CAAA;IAC3C,kEAAgD,CAAA;IAChD,yDAAuC,CAAA;IACvC,yDAAuC,CAAA;IACvC,8DAA4C,CAAA;AAChD,CAAC,EAjBW,cAAc,KAAd,cAAc,QAiBzB;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAa;IACtC,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAE,GAAG;IAChC,CAAC,kBAAkB,CAAC,GAAG,CAAC,EAAE,IAAI;CACjC,CAAC","sourcesContent":["import {Paddings, PaddingsDirections} from './models/paddings';\n\nexport const BREAKPOINTS = {\n xs: 0,\n sm: 577,\n md: 769,\n lg: 1081,\n xl: 1185,\n};\n\nexport const DEFAULT_THEME = 'light';\n\nexport const UIKIT_ROOT_CLASS = 'g-root';\nexport const UIKIT_THEME_LIGHT_CLASS = `${UIKIT_ROOT_CLASS}_theme_${DEFAULT_THEME}`;\n\nexport enum DefaultGoalIds {\n shareTop = 'SITE_BLOG_SHARE-TOP_CLICK',\n shareBottom = 'SITE_BLOG_SHARE-BOTTOM_CLICK',\n breadcrumbsTop = 'SITE_BLOG_BREADCRUMBS-TOP_CLICK',\n breadcrumbsBottom = 'SITE_BLOG_BREADCRUMBS-BOTTOM_CLICK',\n saveTop = 'SITE_BLOG_SAVE-TOP_CLICK',\n saveBottom = 'SITE_BLOG_SAVE-BOTTOM_CLICK',\n saveSuggest = 'SITE_BLOG_SAVE-SUGGEST_CLICK',\n suggest = 'SITE_BLOG_INTERESTING-CARD_CLICK',\n bannerCommon = 'SITE_BLOG_TEXT-BANNER_CLICK',\n cta = 'SITE_BLOG_CTA_CLICK',\n tag = 'SITE_BLOG_THEME-SELECTOR_CLCK',\n service = 'SITE_BLOG_SERVICE-SELECTOR_CLCK',\n showMore = 'SITE_BLOG-PAGINATION_SHOW-MORE_CLCK',\n next = 'SITE_BLOG-PAGINATION_NEXT_CLCK',\n home = 'SITE_BLOG-PAGINATION_HOME_CLCK',\n page = 'SITE_BLOG-PAGINATION_PAGE-NMBR_CLCK',\n}\n\nexport const DEFAULT_PADDINGS: Paddings = {\n [PaddingsDirections.bottom]: 'l',\n [PaddingsDirections.top]: 'xs',\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"BlogConstructorProvider.js","sourceRoot":"../../../src","sources":["constructor/BlogConstructorProvider.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EACH,gBAAgB,EAGhB,YAAY,GACf,MAAM,8BAA8B,CAAC;AAEtC,OAAO,EAAC,aAAa,EAAC,wBAAqB;AAC3C,OAAO,EAAC,aAAa,EAAqB,qCAAkC;AAC5E,OAAO,EAAC,aAAa,EAAC,qCAAkC;AACxD,OAAO,EAAC,aAAa,EAAC,qCAAkC;AACxD,OAAO,EAAC,aAAa,EAAqB,qCAAkC;AAC5E,OAAO,EAAC,eAAe,EAAuB,uCAAoC;AAClF,OAAO,EAAC,iBAAiB,EAAiB,+CAA4C;AActF,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,EACpC,QAAQ,EACR,MAAM,GAAG,EAAY,EACrB,MAAM,GAAG,EAAwB,EACjC,KAAK,GAAG,aAAa,EACrB,MAAM,GAAG,EAAE,EACX,SAAS,GAAG,EAAE,EACd,QAAQ,GAAG,EAAE,EACb,QAAQ,GAC4C,EAAE,EAAE;IACxD,MAAM,OAAO,GAAG;QACZ,KAAC,iBAAiB,CAAC,QAAQ,IAAC,KAAK,EAAE,EAAC,UAAU,EAAE,KAAK,EAAC,IAAM,eAAe,CAAG;QAC9E,KAAC,YAAY,CAAC,QAAQ,IAAC,KAAK,EAAE,EAAC,KAAK,EAAE,KAAc,EAAC,IAAM,UAAU,CAAG;QACxE,KAAC,aAAa,CAAC,QAAQ,IAAC,KAAK,EAAE,EAAC,MAAM,EAAC,IAAM,gBAAgB,CAAG;QAChE,KAAC,aAAa,CAAC,QAAQ,IAAC,KAAK,EAAE,MAAM,IAAM,gBAAgB,CAAG;QAC9D,KAAC,aAAa,CAAC,QAAQ,IAAC,KAAK,EAAE,OAAO,CAAC,QAAQ,CAAC,IAAM,mBAAmB,CAAG;QAC5E,KAAC,aAAa,CAAC,QAAQ,IAAC,KAAK,EAAE,MAAM,IAAM,gBAAgB,CAAG;QAC9D,KAAC,eAAe,CAAC,QAAQ,IAAC,KAAK,EAAE,QAAQ,IAAM,kBAAkB,CAAG;QACpE,KAAC,gBAAgB,CAAC,QAAQ,IAAC,KAAK,EAAE,SAAS,IAAM,mBAAmB,CAAG;KAC1E,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,QAAQ,CAAC,CAAC;IAEpF,OAAO,KAAC,KAAK,CAAC,QAAQ,cAAE,OAAO,GAAkB,CAAC;AACtD,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {\n AnalyticsContext,\n AnalyticsContextProps,\n Theme,\n ThemeContext,\n} from '@gravity-ui/page-constructor';\n\nimport {DEFAULT_THEME} from '../constants';\nimport {DeviceContext, DeviceContextProps} from '../contexts/DeviceContext';\nimport {LocaleContext} from '../contexts/LocaleContext';\nimport {MobileContext} from '../contexts/MobileContext';\nimport {RouterContext, RouterContextProps} from '../contexts/RouterContext';\nimport {SettingsContext, SettingsContextProps} from '../contexts/SettingsContext';\nimport {ThemeValueContext, ThemeValueType} from '../contexts/theme/ThemeValueContext';\nimport {Locale} from '../models/locale';\n\nexport interface BlogConstructorProviderProps {\n isMobile?: boolean;\n locale?: Locale;\n router?: RouterContextProps;\n theme?: ThemeValueType;\n device?: DeviceContextProps;\n analytics?: AnalyticsContextProps;\n settings?: SettingsContextProps;\n children?: React.ReactNode;\n}\n\nexport const BlogConstructorProvider = ({\n isMobile,\n locale = {} as Locale,\n router = {} as RouterContextProps,\n theme = DEFAULT_THEME,\n device = {},\n analytics = {},\n settings = {},\n children,\n}: React.PropsWithChildren<BlogConstructorProviderProps>) => {\n const context = [\n <ThemeValueContext.Provider value={{themeValue: theme}} key=\"theme-context\" />,\n <ThemeContext.Provider value={{theme: theme as Theme}} key=\"pc-theme\" />,\n <LocaleContext.Provider value={{locale}} key=\"locale-context\" />,\n <RouterContext.Provider value={router} key=\"router-context\" />,\n <MobileContext.Provider value={Boolean(isMobile)} key=\"is-mobile-context\" />,\n <DeviceContext.Provider value={device} key=\"device-context\" />,\n <SettingsContext.Provider value={settings} key=\"settings-context\" />,\n <AnalyticsContext.Provider value={analytics} key=\"analytics-context\" />,\n ].reduceRight((prev, provider) => React.cloneElement(provider, {}, prev), children);\n\n return <React.Fragment>{context}</React.Fragment>;\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"blocksMap.js","sourceRoot":"../../../src","sources":["constructor/blocksMap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,EAAC,mCAAgC;AAC/C,OAAO,EAAC,MAAM,EAAC,mCAAgC;AAC/C,OAAO,EAAC,GAAG,EAAC,6BAA0B;AACtC,OAAO,EAAC,WAAW,EAAC,6CAA0C;AAC9D,OAAO,EAAC,IAAI,EAAC,+BAA4B;AACzC,OAAO,EAAC,IAAI,EAAC,+BAA4B;AACzC,OAAO,EAAC,MAAM,EAAC,mCAAgC;AAC/C,OAAO,EAAC,MAAM,EAAC,mCAAgC;AAC/C,OAAO,EAAC,KAAK,EAAC,iCAA8B;AAC5C,OAAO,EAAC,IAAI,EAAC,+BAA4B;AACzC,OAAO,EAAC,OAAO,EAAC,qCAAkC;AAClD,OAAO,EAAC,GAAG,EAAC,6BAA0B;AACtC,OAAO,EAAC,SAAS,EAAC,4BAAyB;AAE3C,MAAM,MAAM,GAAG;IACX,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,GAAG;IACpB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM;IAC1B,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,KAAK;IACxB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM;IAC1B,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,GAAG;IACpB,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE,WAAW;IACpC,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM;IAC1B,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,OAAO;IAC5B,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI;IACtB,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI;IACtB,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI;CACzB,CAAC;AAEF,MAAM,OAAO,GAAG;IACZ,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM;CAC7B,CAAC;AAEF,eAAe,EAAC,MAAM,EAAE,OAAO,EAAC,CAAC","sourcesContent":["import {Author} from '../blocks/Author/Author';\nimport {Banner} from '../blocks/Banner/Banner';\nimport {CTA} from '../blocks/CTA/CTA';\nimport {ColoredText} from '../blocks/ColoredText/ColoredText';\nimport {Feed} from '../blocks/Feed/Feed';\nimport {Form} from '../blocks/Form/Form';\nimport {Header} from '../blocks/Header/Header';\nimport {Layout} from '../blocks/Layout/Layout';\nimport {Media} from '../blocks/Media/Media';\nimport {Meta} from '../blocks/Meta/Meta';\nimport {Suggest} from '../blocks/Suggest/Suggest';\nimport {YFM} from '../blocks/YFM/YFM';\nimport {BlockType} from '../models/common';\n\nconst blocks = {\n [BlockType.YFM]: YFM,\n [BlockType.Layout]: Layout,\n [BlockType.Media]: Media,\n [BlockType.Banner]: Banner,\n [BlockType.CTA]: CTA,\n [BlockType.ColoredText]: ColoredText,\n [BlockType.Author]: Author,\n [BlockType.Suggest]: Suggest,\n [BlockType.Meta]: Meta,\n [BlockType.Feed]: Feed,\n [BlockType.Form]: Form,\n};\n\nconst headers = {\n [BlockType.Header]: Header,\n};\n\nexport default {blocks, headers};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"BlogPage.js","sourceRoot":"../../../../src","sources":["containers/BlogPage/BlogPage.tsx"],"names":[],"mappings":";;AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAGH,eAAe,EACf,uBAAuB,GAG1B,MAAM,8BAA8B,CAAC;AAEtC,OAAO,EAAC,WAAW,EAAC,oDAAiD;AACrE,OAAO,EAAC,YAAY,EAAC,sDAAmD;AACxE,OAAO,EAAC,oBAAoB,EAAC,oEAAiE;AAC9F,OAAO,EAAC,WAAW,EAAC,sCAAmC;AACvD,OAAO,EAAC,YAAY,EAAC,uCAAoC;AACzD,OAAO,EAAC,uBAAuB,EAAC,+CAA4C;AAS5E,OAAO,EAAC,eAAe,EAAC,0CAAuC;AAE/D,OAAO,gBAAgB,CAAC;AAoBxB,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,EACrB,OAAO,EACP,KAAK,EACL,IAAI,EACJ,QAAQ,EACR,QAAQ,EACR,QAAQ,EACR,MAAM,EACN,QAAQ,GAAG,KAAK,EAChB,UAAU,EACV,UAAU,EACV,QAAQ,EACR,8BAA8B,EAC9B,cAAc,GAAG,KAAK,EACtB,aAAa,GACD,EAAE,EAAE;IAChB,MAAM,EAAC,kBAAkB,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;IAC/D,MAAM,KAAwC,oBAAoB,CAAC,aAAa,CAAC,EAA3E,EAAC,aAAa,OAA6D,EAAxD,iBAAiB,cAApC,iBAAqC,CAAsC,CAAC;IAElF,MAAM,gBAAgB,GAAG,KAAK,CAAC,OAAO,CAClC,GAAG,EAAE,CAAC,CAAC,EAAC,UAAU,EAAE,QAAQ,EAAE,cAAc,EAAE,aAAa,EAAC,CAAC,EAC7D,CAAC,UAAU,EAAE,QAAQ,EAAE,cAAc,EAAE,aAAa,CAAC,CACxD,CAAC;IAEF,MAAM,kBAAkB,GAAG,uBAAuB,CAAC,MAAM,CAAC,CAAC;IAE3D,OAAO,CACH,MAAC,YAAY,CAAC,QAAQ,IAAC,KAAK,EAAE,gBAAgB,aAC1C,KAAC,WAAW,CAAC,QAAQ,IACjB,KAAK,EAAE;oBACH,KAAK,EAAE,KAAK,CAAC,KAAK;oBAClB,UAAU,EAAE,KAAK,CAAC,UAAU;oBAC5B,UAAU,EAAE,KAAK,CAAC,KAAK;oBACvB,IAAI;oBACJ,QAAQ,EAAE,QAAQ,aAAR,QAAQ,cAAR,QAAQ,GAAI,EAAE;oBACxB,QAAQ;oBACR,8BAA8B;iBACjC,YAED,MAAC,uBAAuB,oBAChB,QAAQ,IACZ,eAAe,kCAAM,CAAC,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,eAAe,KAAI,EAAE,CAAC,KAAE,kBAAkB,gBAEzE,QAAQ,CAAC,CAAC,CAAC,KAAC,WAAW,oBAAK,QAAQ,EAAI,CAAC,CAAC,CAAC,IAAI,EAChD,KAAC,eAAe,IACZ,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,kBAAkB,EAC1B,UAAU,EAAE,UAAU,GACxB,KACoB,GACP,EACvB,KAAC,YAAY,oBAAK,iBAAiB,EAAI,IACnB,CAC3B,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {\n CustomConfig,\n NavigationData,\n PageConstructor,\n PageConstructorProvider,\n PageConstructorProviderProps,\n PageContent,\n} from '@gravity-ui/page-constructor';\n\nimport {MetaWrapper} from '../../components/MetaWrapper/MetaWrapper';\nimport {PromptSignIn} from '../../components/PromptSignIn/PromptSignIn';\nimport {usePromptSignInProps} from '../../components/PromptSignIn/hooks/usePromptSignInProps';\nimport {FeedContext} from '../../contexts/FeedContext';\nimport {LikesContext} from '../../contexts/LikesContext';\nimport {useExtendedComponentMap} from '../../hooks/useExtendedComponentMap';\nimport {\n GetPostsType,\n MetaProps,\n PostsProps,\n Service,\n Tag,\n ToggleLikeCallbackType,\n} from '../../models/common';\nimport {SettingsContext} from '../../contexts/SettingsContext';\n\nimport './BlogPage.scss';\n\nexport type BlogPageProps = {\n content: PageContent;\n posts: PostsProps;\n tags: Tag[];\n services?: Service[];\n navigation?: NavigationData;\n getPosts: GetPostsType;\n hasLikes?: boolean;\n toggleLike?: ToggleLikeCallbackType;\n metaData?: MetaProps;\n settings?: PageConstructorProviderProps;\n custom?: CustomConfig;\n pageCountForShowSupportButtons?: number;\n isSignedInUser?: boolean;\n // Required to enable Sign In on Post like\n onClickSignIn?: React.EventHandler<React.SyntheticEvent>;\n};\n\nexport const BlogPage = ({\n content,\n posts,\n tags,\n services,\n getPosts,\n metaData,\n custom,\n hasLikes = false,\n toggleLike,\n navigation,\n settings,\n pageCountForShowSupportButtons,\n isSignedInUser = false,\n onClickSignIn,\n}: BlogPageProps) => {\n const {isAnimationEnabled} = React.useContext(SettingsContext);\n const {requireSignIn, ...promptSignInProps} = usePromptSignInProps(onClickSignIn);\n\n const likesContextData = React.useMemo(\n () => ({toggleLike, hasLikes, isSignedInUser, requireSignIn}),\n [toggleLike, hasLikes, isSignedInUser, requireSignIn],\n );\n\n const actualComponentMap = useExtendedComponentMap(custom);\n\n return (\n <LikesContext.Provider value={likesContextData}>\n <FeedContext.Provider\n value={{\n posts: posts.posts,\n pinnedPost: posts.pinnedPost,\n totalCount: posts.count,\n tags,\n services: services ?? [],\n getPosts,\n pageCountForShowSupportButtons,\n }}\n >\n <PageConstructorProvider\n {...settings}\n projectSettings={{...(settings?.projectSettings || {}), isAnimationEnabled}}\n >\n {metaData ? <MetaWrapper {...metaData} /> : null}\n <PageConstructor\n content={content}\n custom={actualComponentMap}\n navigation={navigation}\n />\n </PageConstructorProvider>\n </FeedContext.Provider>\n <PromptSignIn {...promptSignInProps} />\n </LikesContext.Provider>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"BlogPostPage.js","sourceRoot":"../../../../src","sources":["containers/BlogPostPage/BlogPostPage.tsx"],"names":[],"mappings":";;AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,EAIH,eAAe,EACf,uBAAuB,GAG1B,MAAM,8BAA8B,CAAC;AAEtC,OAAO,EAAC,WAAW,EAAC,oDAAiD;AACrE,OAAO,EAAC,YAAY,EAAC,sDAAmD;AACxE,OAAO,EAAC,oBAAoB,EAAC,oEAAiE;AAC9F,OAAO,EAAC,YAAY,EAAC,uCAAoC;AACzD,OAAO,EAAC,eAAe,EAAC,0CAAuC;AAC/D,OAAO,EAAC,uBAAuB,EAAC,+CAA4C;AAC5E,OAAO,EAAC,QAAQ,EAAC,gCAA6B;AAE9C,OAAO,EAAC,eAAe,EAAC,0CAAuC;AAE/D,OAAO,oBAAoB,CAAC;AAsB5B,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EACzB,QAAQ,EACR,cAAc,EACd,KAAK,EACL,OAAO,EACP,IAAI,EACJ,QAAQ,EACR,UAAU,EACV,MAAM,EACN,YAAY,EACZ,cAAc,GAAG,KAAK,EACtB,aAAa,EACb,WAAW,GACK,EAAE,EAAE;IACpB,MAAM,EAAC,kBAAkB,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;IAC/D,MAAM,EAAC,WAAW,EAAE,UAAU,EAAE,UAAU,EAAC,GAAG,QAAQ,CAAC;QACnD,OAAO,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,WAAW;QAC3B,KAAK,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU;QACxB,kBAAkB,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU;QACrC,MAAM,EAAE,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,UAAU;KAC3B,CAAC,CAAC;IAEH,MAAM,KAAwC,oBAAoB,CAAC,aAAa,CAAC,EAA3E,EAAC,aAAa,OAA6D,EAAxD,iBAAiB,cAApC,iBAAqC,CAAsC,CAAC;IAElF,MAAM,gBAAgB,GAAG,KAAK,CAAC,OAAO,CAClC,GAAG,EAAE,CAAC,CAAC;QACH,UAAU,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU;QAC7B,QAAQ,EAAE,OAAO,CAAC,KAAK,CAAC;QACxB,cAAc;QACd,aAAa;KAChB,CAAC,EACF,CAAC,KAAK,EAAE,cAAc,EAAE,aAAa,CAAC,CACzC,CAAC;IAEF,MAAM,kBAAkB,GAAG,uBAAuB,CAAC,MAAM,CAAC,CAAC;IAE3D,OAAO,CACH,MAAC,YAAY,CAAC,QAAQ,IAAC,KAAK,EAAE,gBAAgB,aAC1C,KAAC,eAAe,CAAC,QAAQ,IACrB,KAAK,EAAE;oBACH,IAAI;oBACJ,cAAc;oBACd,KAAK,EAAE,KAAK;wBACR,CAAC,CAAC;4BACI,cAAc,EAAE,UAAU;4BAC1B,WAAW;4BACX,UAAU;yBACb;wBACH,CAAC,CAAC,SAAS;oBACf,YAAY;oBACZ,WAAW;iBACd,YAED,MAAC,uBAAuB,oBAChB,QAAQ,IACZ,eAAe,kCAAM,CAAC,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,eAAe,KAAI,EAAE,CAAC,KAAE,kBAAkB,gBAEzE,QAAQ,CAAC,CAAC,CAAC,KAAC,WAAW,oBAAK,QAAQ,EAAI,CAAC,CAAC,CAAC,IAAI,EAChD,KAAC,eAAe,IACZ,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,kBAAkB,EAC1B,UAAU,EAAE,UAAU,GACxB,KACoB,GACH,EAC3B,KAAC,YAAY,oBAAK,iBAAiB,EAAI,IACnB,CAC3B,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {ShareOptions} from '@gravity-ui/components';\nimport {\n CustomConfig,\n HeaderBreadCrumbsProps,\n NavigationData,\n PageConstructor,\n PageConstructorProvider,\n PageConstructorProviderProps,\n PageContent,\n} from '@gravity-ui/page-constructor';\n\nimport {MetaWrapper} from '../../components/MetaWrapper/MetaWrapper';\nimport {PromptSignIn} from '../../components/PromptSignIn/PromptSignIn';\nimport {usePromptSignInProps} from '../../components/PromptSignIn/hooks/usePromptSignInProps';\nimport {LikesContext} from '../../contexts/LikesContext';\nimport {PostPageContext} from '../../contexts/PostPageContext';\nimport {useExtendedComponentMap} from '../../hooks/useExtendedComponentMap';\nimport {useLikes} from '../../hooks/useLikes';\nimport {MetaProps, PostData, ToggleLikeCallbackType} from '../../models/common';\nimport {SettingsContext} from '../../contexts/SettingsContext';\n\nimport './BlogPostPage.scss';\n\nexport interface BlogPostPageProps {\n suggestedPosts: PostData[];\n metaData?: MetaProps;\n likes?: {\n hasUserLike?: boolean;\n likesCount?: number;\n toggleLike?: ToggleLikeCallbackType;\n };\n content: PageContent;\n post: PostData;\n settings?: PageConstructorProviderProps;\n navigation?: NavigationData;\n custom?: CustomConfig;\n shareOptions?: ShareOptions[];\n isSignedInUser?: boolean;\n // Required to enable Sign In on Post like\n onClickSignIn?: React.EventHandler<React.SyntheticEvent>;\n breadcrumbs?: HeaderBreadCrumbsProps;\n}\n\nexport const BlogPostPage = ({\n metaData,\n suggestedPosts,\n likes,\n content,\n post,\n settings,\n navigation,\n custom,\n shareOptions,\n isSignedInUser = false,\n onClickSignIn,\n breadcrumbs,\n}: BlogPostPageProps) => {\n const {isAnimationEnabled} = React.useContext(SettingsContext);\n const {hasUserLike, likesCount, handleLike} = useLikes({\n hasLike: likes?.hasUserLike,\n count: likes?.likesCount,\n toggleLikeCallback: likes?.toggleLike,\n postId: post?.blogPostId,\n });\n\n const {requireSignIn, ...promptSignInProps} = usePromptSignInProps(onClickSignIn);\n\n const likesContextData = React.useMemo(\n () => ({\n toggleLike: likes?.toggleLike,\n hasLikes: Boolean(likes),\n isSignedInUser,\n requireSignIn,\n }),\n [likes, isSignedInUser, requireSignIn],\n );\n\n const actualComponentMap = useExtendedComponentMap(custom);\n\n return (\n <LikesContext.Provider value={likesContextData}>\n <PostPageContext.Provider\n value={{\n post,\n suggestedPosts,\n likes: likes\n ? {\n handleUserLike: handleLike,\n hasUserLike,\n likesCount,\n }\n : undefined,\n shareOptions,\n breadcrumbs,\n }}\n >\n <PageConstructorProvider\n {...settings}\n projectSettings={{...(settings?.projectSettings || {}), isAnimationEnabled}}\n >\n {metaData ? <MetaWrapper {...metaData} /> : null}\n <PageConstructor\n content={content}\n custom={actualComponentMap}\n navigation={navigation}\n />\n </PageConstructorProvider>\n </PostPageContext.Provider>\n <PromptSignIn {...promptSignInProps} />\n </LikesContext.Provider>\n );\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"DeviceContext.js","sourceRoot":"../../../src","sources":["contexts/DeviceContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAM/B,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,CAAqB,EAAwB,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {WithDeviceProps} from '../models/common';\n\nexport type DeviceContextProps = Partial<WithDeviceProps>;\n\nexport const DeviceContext = React.createContext<DeviceContextProps>({} as DeviceContextProps);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"FeedContext.js","sourceRoot":"../../../src","sources":["contexts/FeedContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAc/B,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,CAAC,aAAa,CAAmB,EAAsB,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {GetPostsType, PostData, Service, Tag} from '../models/common';\n\nexport interface FeedContextProps {\n posts?: PostData[];\n pinnedPost?: PostData;\n totalCount?: number;\n tags?: Tag[];\n services?: Service[];\n getPosts?: GetPostsType;\n pageCountForShowSupportButtons?: number;\n}\n\nexport const FeedContext = React.createContext<FeedContextProps>({} as FeedContextProps);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"LikesContext.js","sourceRoot":"../../../src","sources":["contexts/LikesContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAW/B,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,CAAC,aAAa,CAAoB,EAAuB,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {ToggleLikeCallbackType} from '../models/common';\n\nexport interface LikesContextProps {\n toggleLike?: ToggleLikeCallbackType;\n hasLikes?: boolean;\n isSignedInUser?: boolean;\n requireSignIn?: React.MouseEventHandler;\n}\n\nexport const LikesContext = React.createContext<LikesContextProps>({} as LikesContextProps);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"LocaleContext.js","sourceRoot":"../../../src","sources":["contexts/LocaleContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,EAAC,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAMvC,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,CAAqB;IACjE,MAAM,EAAE;QACJ,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,IAAI,CAAC,EAAE;QACb,QAAQ,EAAE,SAAS;QACnB,UAAU,EAAE,IAAI;KACnB;CACJ,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Locale} from '../models/locale';\nimport {Lang} from '@gravity-ui/uikit';\n\nexport type LocaleContextProps = {\n locale: Locale;\n};\n\nexport const LocaleContext = React.createContext<LocaleContextProps>({\n locale: {\n code: 'en-En',\n lang: Lang.En,\n langName: 'English',\n pathPrefix: 'en',\n },\n});\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"MobileContext.js","sourceRoot":"../../../src","sources":["contexts/MobileContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,CAAU,KAAK,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nexport const MobileContext = React.createContext<boolean>(false);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"PostPageContext.js","sourceRoot":"../../../src","sources":["contexts/PostPageContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAqB/B,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,CAAC,aAAa,CAC9C,EAA0B,CAC7B,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {ShareOptions} from '@gravity-ui/components';\n\nimport {PostData} from '../models/common';\nimport {HeaderBreadCrumbsProps} from '@gravity-ui/page-constructor';\n\nexport type LikesRoutineType = {\n handleUserLike: () => void;\n hasUserLike: boolean;\n likesCount: number;\n};\n\nexport interface PostPageContextProps {\n post: PostData;\n suggestedPosts: PostData[];\n likes?: LikesRoutineType;\n shareOptions?: ShareOptions[];\n breadcrumbs?: HeaderBreadCrumbsProps;\n}\n\nexport const PostPageContext = React.createContext<PostPageContextProps>(\n {} as PostPageContextProps,\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"RouterContext.js","sourceRoot":"../../../src","sources":["contexts/RouterContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAY/B,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,CAAqB,EAAwB,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Query} from '../models/common';\n\nexport interface RouterContextProps {\n pathname: string;\n as: string;\n hostname: string;\n query?: Query;\n updateQueryCallback: (query: Query) => void;\n}\n\nexport const RouterContext = React.createContext<RouterContextProps>({} as RouterContextProps);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"SettingsContext.js","sourceRoot":"../../../src","sources":["contexts/SettingsContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAS/B,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,CAAC,aAAa,CAAuB,EAAE,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nexport interface SettingsContextProps {\n addNavigationLinkForPages?: boolean;\n isAnimationEnabled?: boolean;\n\n getBlogPath?: (pathPrefix: string) => string;\n}\n\nexport const SettingsContext = React.createContext<SettingsContextProps>({});\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"ThemeContext.js","sourceRoot":"../../../../src","sources":["contexts/theme/ThemeContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,aAAa,EAAC,2BAAwB;AAS9C,MAAM,CAAC,MAAM,YAAY,GAAsB;IAC3C,KAAK,EAAE,aAAa;IACpB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;CACrB,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {DEFAULT_THEME} from '../../constants';\n\nimport {ThemeValueType} from './ThemeValueContext';\n\nexport interface ThemeContextProps {\n theme: ThemeValueType;\n setTheme: (newTheme: ThemeValueType) => void;\n}\n\nexport const initialValue: ThemeContextProps = {\n theme: DEFAULT_THEME,\n setTheme: () => {},\n};\n\nexport const ThemeContext = React.createContext(initialValue);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"ThemeProvider.js","sourceRoot":"../../../../src","sources":["contexts/theme/ThemeProvider.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,aAAa,EAAE,gBAAgB,EAAC,2BAAwB;AAEhE,OAAO,EAAC,YAAY,EAAoB,0BAAuB;AAC/D,OAAO,EAAC,iBAAiB,EAAiB,+BAA4B;AAiBtE,MAAM,OAAO,aAAc,SAAQ,KAAK,CAAC,SAGxC;IAHD;;QAQI,UAAK,GAAuB;YACxB,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK;YACvB,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK;YAC5B,QAAQ,EAAE,CAAC,KAAqB,EAAE,EAAE;gBAChC,IAAI,CAAC,QAAQ,CAAC,EAAC,KAAK,EAAC,CAAC,CAAC;YAC3B,CAAC;SACJ,CAAC;IAsCN,CAAC;IApCG,iBAAiB;QACb,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IACpD,CAAC;IAED,kBAAkB,CAAC,SAA6B,EAAE,SAA6B;QAC3E,IAAI,SAAS,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YACvC,IAAI,CAAC,QAAQ,CAAC,EAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,EAAC,CAAC,CAAC;YAC9C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC/C,CAAC;QAED,IAAI,SAAS,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YACvC,IAAI,CAAC,QAAQ,CAAC,EAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,EAAC,CAAC,CAAC;YAC9C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC/C,CAAC;IACL,CAAC;IAED,MAAM;QACF,OAAO,CACH,KAAC,YAAY,CAAC,QAAQ,IAAC,KAAK,EAAE,IAAI,CAAC,KAAK,YACpC,KAAC,iBAAiB,CAAC,QAAQ,IAAC,KAAK,EAAE,EAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,EAAC,YACjE,IAAI,CAAC,KAAK,CAAC,QAAQ,GACK,GACT,CAC3B,CAAC;IACN,CAAC;IAEO,mBAAmB,CAAC,KAAa;QACrC,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC;QAE7B,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC;YAC/C,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAC3C,CAAC;QAED,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,gBAAgB,cAAc,EAAE,KAAK,KAAK,OAAO,CAAC,CAAC;QAC9E,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,gBAAgB,aAAa,EAAE,KAAK,KAAK,MAAM,CAAC,CAAC;IAChF,CAAC;;AA/CM,0BAAY,GAA8B;IAC7C,KAAK,EAAE,aAAa;CACvB,AAFkB,CAEjB","sourcesContent":["import * as React from 'react';\n\nimport {DEFAULT_THEME, UIKIT_ROOT_CLASS} from '../../constants';\n\nimport {ThemeContext, ThemeContextProps} from './ThemeContext';\nimport {ThemeValueContext, ThemeValueType} from './ThemeValueContext';\n\ninterface ThemeProviderExternalProps {}\n\ninterface ThemeProviderDefaultProps {\n theme: ThemeValueType;\n children?: React.ReactNode;\n}\n\nexport interface ThemeProviderProps\n extends ThemeProviderExternalProps,\n Partial<ThemeProviderDefaultProps> {}\n\ninterface ThemeProviderState extends ThemeContextProps {\n themeValue: ThemeValueType;\n}\n\nexport class ThemeProvider extends React.Component<\n ThemeProviderExternalProps & ThemeProviderDefaultProps,\n ThemeProviderState\n> {\n static defaultProps: ThemeProviderDefaultProps = {\n theme: DEFAULT_THEME,\n };\n\n state: ThemeProviderState = {\n theme: this.props.theme,\n themeValue: this.props.theme,\n setTheme: (theme: ThemeValueType) => {\n this.setState({theme});\n },\n };\n\n componentDidMount() {\n this.updateBodyClassName(this.state.themeValue);\n }\n\n componentDidUpdate(prevProps: ThemeProviderProps, prevState: ThemeProviderState) {\n if (prevState.theme !== this.state.theme) {\n this.setState({themeValue: this.state.theme});\n this.updateBodyClassName(this.state.theme);\n }\n\n if (prevProps.theme !== this.props.theme) {\n this.setState({themeValue: this.state.theme});\n this.updateBodyClassName(this.state.theme);\n }\n }\n\n render() {\n return (\n <ThemeContext.Provider value={this.state}>\n <ThemeValueContext.Provider value={{themeValue: this.state.themeValue}}>\n {this.props.children}\n </ThemeValueContext.Provider>\n </ThemeContext.Provider>\n );\n }\n\n private updateBodyClassName(theme: string) {\n const bodyEl = document.body;\n\n if (!bodyEl.classList.contains(UIKIT_ROOT_CLASS)) {\n bodyEl.classList.add(UIKIT_ROOT_CLASS);\n }\n\n bodyEl.classList.toggle(`${UIKIT_ROOT_CLASS}_theme_light`, theme === 'light');\n bodyEl.classList.toggle(`${UIKIT_ROOT_CLASS}_theme_dark`, theme === 'dark');\n }\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"ThemeValueContext.js","sourceRoot":"../../../../src","sources":["contexts/theme/ThemeValueContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAQ/B,MAAM,CAAC,MAAM,YAAY,GAA2B;IAChD,UAAU,EAAE,OAAO;CACtB,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,KAAK,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nexport type ThemeValueType = 'light' | 'dark';\n\nexport interface ThemeValueContextProps {\n themeValue: ThemeValueType;\n}\n\nexport const initialValue: ThemeValueContextProps = {\n themeValue: 'light',\n};\n\nexport const ThemeValueContext = React.createContext(initialValue);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"../../../../src","sources":["contexts/theme/index.ts"],"names":[],"mappings":"AAAA,kCAA+B;AAC/B,mCAAgC;AAChC,8BAA2B;AAC3B,mCAAgC;AAChC,+BAA4B;AAC5B,oCAAiC","sourcesContent":["export * from './ThemeContext';\nexport * from './ThemeProvider';\nexport * from './useTheme';\nexport * from './useThemeValue';\nexport * from './withTheme';\nexport * from './withThemeValue';\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useTheme.js","sourceRoot":"../../../../src","sources":["contexts/theme/useTheme.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,YAAY,EAAoB,0BAAuB;AAE/D,MAAM,UAAU,QAAQ;IACpB,MAAM,EAAC,KAAK,EAAE,QAAQ,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;IACzD,OAAO,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;AAC7B,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {ThemeContext, ThemeContextProps} from './ThemeContext';\n\nexport function useTheme(): [ThemeContextProps['theme'], ThemeContextProps['setTheme']] {\n const {theme, setTheme} = React.useContext(ThemeContext);\n return [theme, setTheme];\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useThemeValue.js","sourceRoot":"../../../../src","sources":["contexts/theme/useThemeValue.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,iBAAiB,EAAyB,+BAA4B;AAE9E,MAAM,UAAU,aAAa;IACzB,MAAM,EAAC,UAAU,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;IACzD,OAAO,UAAU,CAAC;AACtB,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {ThemeValueContext, ThemeValueContextProps} from './ThemeValueContext';\n\nexport function useThemeValue(): ThemeValueContextProps['themeValue'] {\n const {themeValue} = React.useContext(ThemeValueContext);\n return themeValue;\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"withTheme.js","sourceRoot":"../../../../src","sources":["contexts/theme/withTheme.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,OAAO,EAAC,YAAY,EAAoB,0BAAuB;AAI/D,MAAM,UAAU,SAAS,CACrB,gBAAwC;;IAExC,MAAM,aAAa,GAAG,gBAAgB,CAAC,WAAW,IAAI,gBAAgB,CAAC,IAAI,IAAI,WAAW,CAAC;IAE3F,YAAO,MAAM,kBAAmB,SAAQ,KAAK,CAAC,SAAsC;YAKhF,MAAM;gBACF,OAAO,CACH,KAAC,gBAAgB,oBACR,IAAI,CAAC,KAAW,IACrB,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EACzB,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,IACjC,CACL,CAAC;YACN,CAAC;SACJ;QAbU,cAAW,GAAG,aAAa,aAAa,GAAI;QAC5C,cAAW,GAAG,YAAa;WAYpC;AACN,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Subtract} from 'utility-types';\n\nimport {ThemeContext, ThemeContextProps} from './ThemeContext';\n\nexport interface WithThemeProps extends ThemeContextProps {}\n\nexport function withTheme<T extends WithThemeProps>(\n WrappedComponent: React.ComponentType<T>,\n): React.ComponentType<Subtract<T, WithThemeProps>> {\n const componentName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\n\n return class WithThemeComponent extends React.Component<Subtract<T, WithThemeProps>> {\n static displayName = `withTheme(${componentName})`;\n static contextType = ThemeContext;\n context!: ThemeContextProps;\n\n render() {\n return (\n <WrappedComponent\n {...(this.props as T)}\n theme={this.context.theme}\n setTheme={this.context.setTheme}\n />\n );\n }\n };\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"withThemeValue.js","sourceRoot":"../../../../src","sources":["contexts/theme/withThemeValue.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,OAAO,EAAC,iBAAiB,EAAyB,+BAA4B;AAI9E,MAAM,UAAU,cAAc,CAC1B,gBAAwC;;IAExC,MAAM,aAAa,GAAG,gBAAgB,CAAC,WAAW,IAAI,gBAAgB,CAAC,IAAI,IAAI,WAAW,CAAC;IAE3F,YAAO,MAAM,uBAAwB,SAAQ,KAAK,CAAC,SAA2C;YAK1F,MAAM;gBACF,OAAO,KAAC,gBAAgB,oBAAM,IAAI,CAAC,KAAW,IAAE,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,CAAC;YAC5F,CAAC;SACJ;QAPU,cAAW,GAAG,kBAAkB,aAAa,GAAI;QACjD,cAAW,GAAG,iBAAkB;WAMzC;AACN,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Subtract} from 'utility-types';\n\nimport {ThemeValueContext, ThemeValueContextProps} from './ThemeValueContext';\n\nexport interface WithThemeValueProps extends ThemeValueContextProps {}\n\nexport function withThemeValue<T extends WithThemeValueProps>(\n WrappedComponent: React.ComponentType<T>,\n): React.ComponentType<Subtract<T, WithThemeValueProps>> {\n const componentName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\n\n return class WithThemeValueComponent extends React.Component<Subtract<T, WithThemeValueProps>> {\n static displayName = `withThemeValue(${componentName})`;\n static contextType = ThemeValueContext;\n context!: ThemeValueContextProps;\n\n render() {\n return <WrappedComponent {...(this.props as T)} themeValue={this.context.themeValue} />;\n }\n };\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"metrika.js","sourceRoot":"../../../src","sources":["counters/metrika.ts"],"names":[],"mappings":"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","sourcesContent":["const Goal = {\n SUPPORT_OPEN_FORM: 'SUPPORTOPENFORM',\n SUPPORT_STEP_1_SUBMIT: 'SUPPORTSTEP1SUBMIT',\n SUPPORT_STEP_2_SUBMIT: 'SUPPORTSTEP2SUBMIT',\n SUPPORT_STEP_3_SUBMIT: 'SUPPORTSTEP3SUBMIT',\n SUPPORT_THANKYOU_SUBMIT: 'SUPPORTTHANKYOUSUBMIT',\n\n MP_OPEN_FORM: 'MPOPENFORM',\n\n EDIT_ON_GITHUB: 'EDITONGITHUB',\n\n MAIN_GO_TO_VAR: 'MAINGOTOVAR',\n MAIN_GO_TO_ISV: 'MAINGOTOISV',\n MAIN_ALL_PARTNERS: 'MAINALLPARTNERS',\n FIND_GO_TO_VAR: 'FINDGOTOVAR',\n ISV_GO_TO_MP: 'ISVGOTOMP',\n\n FOOTER_SUBSCRIBE: 'FOOTERSUBSCRIBE',\n FOOTER_MNG_SUBSCRIPTIONS: 'FOOTERMNGSUBSCRIPTIONS',\n\n MOBILE_STORE_IOS: '154_Mobile_App_Store_Badge',\n MOBILE_STORE_ANDROID: '155_Mobile_Google_Play_Badge',\n\n REGION_POPUP_SHOW: 'REGIONPOPUP',\n REGION_POPUP_YES: 'REGIONPOPUPYES',\n REGION_POPUP_NO: 'REGIONPOPUPNO',\n REGION_POPUP_CLOSE: 'REGIONPOPUPCLOSE',\n\n SCALE_REGISTRATION: 'Scale_registration',\n DLGOTOPRODUCT_MPSITE: 'DLGOTOPRODUCT_MPSITE',\n MPK8S_CLCK: 'MPK8S_CLCK',\n 'SITE_CALCULATOR_SHARE-RESULT_CLICK': 'SITE_CALCULATOR_SHARE-RESULT_CLICK',\n};\n\nconst HIT_COUNTERS = ['main', 'cross-site', 'scale'];\n\nconst counterIds: Record<string, string> = {};\n\nfunction getCounter(name: string) {\n const counterId = counterIds[name];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return (window as unknown as Record<string, any>)['yaCounter' + counterId];\n}\n\nexport function initCounters(configs: Record<string, string>[]) {\n configs.forEach((config) => {\n counterIds[config.name] = config.id;\n });\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction hit(...args: any[]) {\n HIT_COUNTERS.forEach((counterName) => {\n const counter = getCounter(counterName);\n\n if (!counter) {\n return;\n }\n\n counter.hit(...args);\n });\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction params(...args: Record<string, any>[]) {\n const counter = getCounter('main');\n\n if (!counter) {\n return;\n }\n\n counter.params(...args);\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction reachGoal(counterName: string, ...args: any[]) {\n const counter = getCounter(counterName);\n\n if (!counter) {\n return;\n }\n\n counter.reachGoal(...args);\n}\n\nfunction reachGoals(goals: string | object, counterName = 'main') {\n if (!goals) {\n return;\n }\n\n const goalsArray = Array.isArray(goals) ? goals : [goals];\n\n goalsArray.forEach((goal) => {\n if (typeof goal === 'object') {\n reachGoal(counterName, goal.name, goal.params);\n } else {\n reachGoal(counterName, goal);\n }\n });\n}\n\n// eslint-disable-next-line complexity\nfunction getServicePrefix(id: string) {\n switch (id) {\n case 'compute':\n return 'CMPT';\n case 'iam':\n return 'IAM';\n case 'vpc':\n return 'VPC';\n case 'storage':\n return 'STRG';\n case 'speechkit':\n return 'SK';\n case 'managed-clickhouse':\n return 'CH';\n case 'managed-mongodb':\n return 'MONGO';\n case 'managed-postgresql':\n return 'POSTGR';\n case 'managed-redis':\n return 'MR';\n case 'managed-mysql':\n return 'MMSQL';\n case 'managed-kubernetes':\n return 'MK';\n case 'translate':\n return 'TRSL';\n case 'instance-groups':\n return 'INSTGR';\n case 'load-balancer':\n return 'LB';\n case 'message-queue':\n return 'MQ';\n case 'datalens':\n return 'DL';\n case 'monitoring':\n return 'MNTRG';\n case 'data-proc':\n return 'DP';\n case 'kms':\n return 'KMS';\n case 'ydb':\n return 'YDB';\n case 'interconnect':\n return 'INTRCNCT';\n }\n\n return undefined;\n}\n\nfunction getMarketPlacePrefix(id: string) {\n return `product_${id}_`;\n}\n\nfunction goalGoToConsole(prefix: string) {\n return prefix && `${prefix}GOTOCONSOLE`;\n}\n\nfunction goalGoToForm(prefix: string) {\n return prefix && `${prefix}GOTOFORM`;\n}\n\nfunction goalGoToDocs(prefix: string) {\n return prefix && `${prefix}GOTODOCS`;\n}\n\nfunction goalFormSubmit(prefix: string) {\n return prefix && `${prefix}FORMSUBMIT`;\n}\n\nfunction goalEventFormSubmit(id: string) {\n return `event${id || 's'}_form_submit`;\n}\n\nfunction goalEventVideoAction(id: string, action: string) {\n return `event${id}_video_${action}`;\n}\n\nfunction goalCaseFormSubmit(id: string) {\n return `case${id ? `_${id}` : 's'}_form_submit`;\n}\n\nfunction goalSwitchLang(place: string) {\n return `SWITCH_LANG_${place}`;\n}\n\nexport default {\n hit,\n params,\n reachGoal,\n reachGoals,\n Goal,\n getServicePrefix,\n getMarketPlacePrefix,\n goalGoToConsole,\n goalGoToForm,\n goalGoToDocs,\n goalFormSubmit,\n goalEventFormSubmit,\n goalEventVideoAction,\n goalCaseFormSubmit,\n goalSwitchLang,\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"../../../src","sources":["counters/utils.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,gBAIX;AAJD,WAAY,gBAAgB;IACxB,iCAAa,CAAA;IACb,4CAAwB,CAAA;IACxB,mCAAe,CAAA;AACnB,CAAC,EAJW,gBAAgB,KAAhB,gBAAgB,QAI3B","sourcesContent":["export enum AnalyticsCounter {\n Main = 'main',\n CrossSite = 'cross-site',\n Scale = 'scale',\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useAriaAttributes.js","sourceRoot":"../../../src","sources":["hooks/useAriaAttributes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAS/B;;;;;GAKG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAC,QAAQ,GAAG,EAAE,EAAE,cAAc,GAAG,EAAE,EAAyB,EAAE,EAAE;IAC9F,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IACvF,MAAM,WAAW,GAAG,KAAK,CAAC,OAAO,CAC7B,GAAG,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAC9C,CAAC,cAAc,CAAC,CACnB,CAAC;IAEF,OAAO;QACH,iBAAiB,EAAE,UAAU;QAC7B,kBAAkB,EAAE,WAAW;KAClC,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\ntype Labels = string | number | boolean | undefined;\ntype Description = string | number | boolean | undefined;\ninterface UseAriaAttributesProps {\n labelIds?: Labels[];\n descriptionIds: Description[];\n}\n\n/**\n * Returns aria-attributes\n * @param labelIds - labels ids. Falsy values will be ignored\n * @param descriptionIds - descriptions ids. Falsy values will be ignored\n * @returns aria attributes for the element to be labelled\n */\nexport const useAriaAttributes = ({labelIds = [], descriptionIds = []}: UseAriaAttributesProps) => {\n const labelledBy = React.useMemo(() => labelIds.filter(Boolean).join(' '), [labelIds]);\n const describedBy = React.useMemo(\n () => descriptionIds.filter(Boolean).join(' '),\n [descriptionIds],\n );\n\n return {\n 'aria-labelledby': labelledBy,\n 'aria-describedby': describedBy,\n };\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useExtendedComponentMap.js","sourceRoot":"../../../src","sources":["hooks/useExtendedComponentMap.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAe,cAAc,EAAC,MAAM,8BAA8B,CAAC;AAE1E,OAAO,YAAY,oCAAiC;AAEpD,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,MAAgC,EAAE,EAAE,CACxE,KAAK,CAAC,OAAO,CACT,GAAG,EAAE,CAAC,iCACC,MAAM,KACT,MAAM,kCAAM,YAAY,CAAC,MAAM,GAAK,cAAc,CAAC,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,GACtE,OAAO,kCAAM,YAAY,CAAC,OAAO,GAAK,cAAc,CAAC,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC,KAC3E,EACF,CAAC,MAAM,CAAC,CACX,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {CustomConfig, getCustomItems} from '@gravity-ui/page-constructor';\n\nimport componentMap from '../constructor/blocksMap';\n\nexport const useExtendedComponentMap = (custom: CustomConfig | undefined) =>\n React.useMemo(\n () => ({\n ...custom,\n blocks: {...componentMap.blocks, ...getCustomItems(['blocks'], custom)},\n headers: {...componentMap.headers, ...getCustomItems(['headers'], custom)},\n }),\n [custom],\n );\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useHover.js","sourceRoot":"../../../src","sources":["hooks/useHover.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B;;;GAGG;AACH,MAAM,UAAU,QAAQ;IAIpB,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACtD,MAAM,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAE/B,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,MAAM,IAAI,GAAG,GAAG,CAAC,OAAiC,CAAC;QAEnD,IAAI,CAAC,IAAI;YAAE,OAAO;QAElB,MAAM,gBAAgB,GAAG,GAAG,EAAE;YAC1B,WAAW,CAAC,IAAI,CAAC,CAAC;QACtB,CAAC,CAAC;QAEF,MAAM,gBAAgB,GAAG,GAAG,EAAE;YAC1B,WAAW,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC,CAAC;QAEF,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;QACtD,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;QAEtD,6CAA6C;QAC7C,OAAO,GAAG,EAAE;YACR,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;YACzD,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;QAC7D,CAAC,CAAC;IACN,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;AAC3B,CAAC","sourcesContent":["import * as React from 'react';\n\n/*\n * Source code copied from https://github.com/uidotdev/usehooks | MIT License\n * @see https://usehooks.com/usehover\n */\nexport function useHover<T extends HTMLElement = HTMLElement>(): [\n ref: React.RefObject<T>,\n hovering: boolean,\n] {\n const [hovering, setHovering] = React.useState(false);\n const ref = React.useRef(null);\n\n React.useEffect(() => {\n const node = ref.current as unknown as HTMLElement;\n\n if (!node) return;\n\n const handleMouseEnter = () => {\n setHovering(true);\n };\n\n const handleMouseLeave = () => {\n setHovering(false);\n };\n\n node.addEventListener('mouseenter', handleMouseEnter);\n node.addEventListener('mouseleave', handleMouseLeave);\n\n // eslint-disable-next-line consistent-return\n return () => {\n node.removeEventListener('mouseenter', handleMouseEnter);\n node.removeEventListener('mouseleave', handleMouseLeave);\n };\n }, []);\n\n return [ref, hovering];\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useIsIPhone.js","sourceRoot":"../../../src","sources":["hooks/useIsIPhone.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,aAAa,EAAC,qCAAkC;AAExD,MAAM,CAAC,MAAM,WAAW,GAAG,GAAG,EAAE;IAC5B,MAAM,EAAC,MAAM,EAAC,GAAG,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAEjD,OAAO,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK,MAAK,QAAQ,CAAC;AACtC,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {DeviceContext} from '../contexts/DeviceContext';\n\nexport const useIsIPhone = () => {\n const {device} = React.useContext(DeviceContext);\n\n return device?.model === 'iPhone';\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useLikes.js","sourceRoot":"../../../src","sources":["hooks/useLikes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAmB/B,MAAM,CAAC,MAAM,QAAQ,GAAiB,CAAC,EAAC,OAAO,EAAE,KAAK,EAAE,kBAAkB,EAAE,MAAM,EAAC,EAAE,EAAE;IACnF,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,KAAK,CAAC,CAAC;IACvE,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,CAAC,CAAC,CAAC;IAE/D,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QACtC,IAAI,aAAa,GAAG,UAAU,CAAC;QAE/B,IAAI,WAAW,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;YAChC,aAAa,EAAE,CAAC;QACpB,CAAC;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;YACf,aAAa,EAAE,CAAC;QACpB,CAAC;QAED,cAAc,CAAC,CAAC,WAAW,CAAC,CAAC;QAC7B,aAAa,CAAC,aAAa,CAAC,CAAC;QAE7B,IAAI,kBAAkB,EAAE,CAAC;YACrB,kBAAkB,CAAC;gBACf,MAAM;gBACN,OAAO,EAAE,CAAC,WAAW;aACxB,CAAC,CAAC;QACP,CAAC;IACL,CAAC,EAAE,CAAC,WAAW,EAAE,UAAU,EAAE,MAAM,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAE1D,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,cAAc,CAAC,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,KAAK,CAAC,CAAC;QACjC,aAAa,CAAC,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,CAAC,CAAC,CAAC;IAC9B,CAAC,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC;IAErB,OAAO;QACH,UAAU;QACV,WAAW;QACX,UAAU;KACb,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {ToggleLikeCallbackType} from '../models/common';\n\ntype UseLikesProps = {\n hasLike?: boolean;\n count?: number;\n postId?: number | string;\n toggleLikeCallback?: ToggleLikeCallbackType;\n};\n\ntype UseLikeData = {\n likesCount: number;\n hasUserLike: boolean;\n handleLike: () => void;\n};\n\ntype UseLikesType = (props: UseLikesProps) => UseLikeData;\n\nexport const useLikes: UseLikesType = ({hasLike, count, toggleLikeCallback, postId}) => {\n const [hasUserLike, setHasUserLike] = React.useState(hasLike ?? false);\n const [likesCount, setLikesCount] = React.useState(count ?? 0);\n\n const handleLike = React.useCallback(() => {\n let newLikesCount = likesCount;\n\n if (hasUserLike && likesCount > 0) {\n newLikesCount--;\n }\n\n if (!hasUserLike) {\n newLikesCount++;\n }\n\n setHasUserLike(!hasUserLike);\n setLikesCount(newLikesCount);\n\n if (toggleLikeCallback) {\n toggleLikeCallback({\n postId,\n hasLike: !hasUserLike,\n });\n }\n }, [hasUserLike, likesCount, postId, toggleLikeCallback]);\n\n React.useEffect(() => {\n setHasUserLike(hasLike ?? false);\n setLikesCount(count ?? 0);\n }, [hasLike, count]);\n\n return {\n likesCount,\n hasUserLike,\n handleLike,\n };\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useOpenCloseTimer.js","sourceRoot":"../../../src","sources":["hooks/useOpenCloseTimer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B;;;;;GAKG;AACH,MAAM,UAAU,iBAAiB,CAAC,aAAa,GAAG,IAAI,CAAC,GAAG,EAAE,EAAE,YAAY,GAAG,IAAI;IAC7E,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,aAAa,GAAG,YAAY,CAAC;IACvD,MAAM,CAAC,EAAE,KAAK,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,6BAA6B;IAElE,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,MAAM,SAAS,GAAG,aAAa,GAAG,YAAY,CAAC;QAC/C,MAAM,KAAK,GAAG,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAErC,IAAI,KAAK,IAAI,CAAC,EAAE,CAAC;YACb,OAAO;QACX,CAAC;QAED,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC1B,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpB,CAAC,EAAE,KAAK,CAAC,CAAC;QAEV,6CAA6C;QAC7C,OAAO,GAAG,EAAE;YACR,YAAY,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC,CAAC;IACN,CAAC,EAAE,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC,CAAC;IAElC,OAAO,EAAC,IAAI,EAAC,CAAC;AAClB,CAAC","sourcesContent":["import * as React from 'react';\n\n/**\n * Timer to automatically update `open` state after a given duration\n * @param {number} openTimestamp - UNIX timestamp in milliseconds\n * @param {number} openDuration - in milliseconds\n * @returns {{open: boolean}} {open} - whether the state is open\n */\nexport function useOpenCloseTimer(openTimestamp = Date.now(), openDuration = 4000) {\n const open = Date.now() - openTimestamp < openDuration;\n const [, reset] = React.useState(0); // time to reset `open` state\n\n React.useEffect(() => {\n const closeTime = openTimestamp + openDuration;\n const delay = closeTime - Date.now();\n\n if (delay <= 0) {\n return;\n }\n\n const timer = setTimeout(() => {\n reset(Date.now);\n }, delay);\n\n // eslint-disable-next-line consistent-return\n return () => {\n clearTimeout(timer);\n };\n }, [openTimestamp, openDuration]);\n\n return {open};\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"../../../src","sources":["i18n/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {addComponentKeysets} from '@gravity-ui/uikit/i18n';\n\nconst NAMESPACE = 'blog';\n\nexport enum Keyset {\n Title = 'title',\n TitleBreadcrumbs = 'title_breadcrumbs',\n TitleSuggest = 'title_suggest',\n ActionShare = 'action_share',\n ContextReadingTime = 'context_reading_time',\n ActionTryAgain = 'action_try_again',\n ActionLoadMore = 'action_load_more',\n ErrorTitle = 'error_title',\n PostLoadError = 'post_load_error',\n TitleEmptyContainer = 'title_empty_container',\n ContextEmptyContainer = 'context_empty_container',\n ButtonBegin = 'button_begin',\n ButtonFarther = 'button_farther',\n Search = 'search_placeholder',\n AllTags = 'label_all_tags',\n ActionSavedOnly = 'action_saved_only',\n AllServices = 'label_all_services',\n PromptSignInOnLike = 'prompt_sign_in_on_like',\n SignIn = 'Sign In',\n Save = 'save',\n ClearAction = 'clear_action',\n}\n\nconst en = {\n [Keyset.Title]: 'Blog',\n [Keyset.TitleBreadcrumbs]: 'Blog',\n [Keyset.TitleSuggest]: 'See also',\n [Keyset.ActionShare]: 'Share',\n [Keyset.ActionTryAgain]: 'Try again',\n [Keyset.ActionLoadMore]: 'See more',\n [Keyset.ErrorTitle]: 'Error',\n [Keyset.PostLoadError]: \"Posts didn't load\",\n [Keyset.TitleEmptyContainer]: \"Looks like we haven't written about that yet\",\n [Keyset.ContextEmptyContainer]: 'Try different spellings or other keywords',\n [Keyset.ButtonBegin]: 'Back to top',\n [Keyset.ButtonFarther]: 'Load more',\n [Keyset.Search]: 'Search',\n [Keyset.AllTags]: 'All topics',\n [Keyset.ActionSavedOnly]: 'Saved',\n [Keyset.AllServices]: 'All Services',\n [Keyset.PromptSignInOnLike]: 'Sign in to save this post',\n [Keyset.ContextReadingTime]: [\n '{{count}} min to read',\n '{{count}} mins to read',\n '{{count}} mins to read',\n ],\n [Keyset.SignIn]: 'Sign In',\n [Keyset.Save]: 'Save',\n [Keyset.ClearAction]: 'Clear',\n};\n\nconst ru = {\n [Keyset.Title]: 'Блог',\n [Keyset.TitleBreadcrumbs]: 'Блог',\n [Keyset.TitleSuggest]: 'Читать также',\n [Keyset.ActionShare]: 'Поделиться',\n [Keyset.ActionTryAgain]: 'Попробуйте ещё раз',\n [Keyset.ActionLoadMore]: 'Показать ещё',\n [Keyset.ErrorTitle]: 'Произошла ошибка',\n [Keyset.PostLoadError]: 'Посты не загрузились',\n [Keyset.TitleEmptyContainer]: 'Возможно, мы об этом ещё не написали',\n [Keyset.ContextEmptyContainer]:\n 'Пожалуйста, проверьте правильность написания или попробуйте другие ключевые слова',\n [Keyset.ButtonBegin]: 'В начало',\n [Keyset.ButtonFarther]: 'Дальше',\n [Keyset.Search]: 'Поиск',\n [Keyset.AllTags]: 'Все темы',\n [Keyset.ActionSavedOnly]: 'Сохранённые',\n [Keyset.AllServices]: 'Все сервисы',\n [Keyset.PromptSignInOnLike]: 'Войдите, чтобы сохранить пост',\n [Keyset.ContextReadingTime]: [\n '{{count}} минута чтения',\n '{{count}} минуты чтения',\n '{{count}} минут чтения',\n ],\n [Keyset.SignIn]: 'Войти',\n [Keyset.Save]: 'Сохранить',\n [Keyset.ClearAction]: 'Очистить',\n};\n\nexport const i18n = addComponentKeysets({en, ru}, NAMESPACE);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Close.js","sourceRoot":"../../../src","sources":["icons/Close.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,kBAAkB,EAAC,wBAAqB;AAEhD,MAAM,CAAC,MAAM,KAAK,GAAG,CAAC,KAAoC,EAAE,EAAE,CAAC,CAC3D,4BACI,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,cAAc,IACf,kBAAkB,EAClB,KAAK,cAET,eACI,CAAC,EAAC,sFAAsF,EACxF,IAAI,EAAC,cAAc,GACrB,IACA,CACT,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {a11yHiddenSvgProps} from '../utils/svg';\n\nexport const Close = (props: React.SVGProps<SVGSVGElement>) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"10\"\n height=\"10\"\n viewBox=\"0 0 10 10\"\n fill=\"currentColor\"\n {...a11yHiddenSvgProps}\n {...props}\n >\n <path\n d=\"M10 0.7L9.3 0L5 4.3L0.7 0L0 0.7L4.3 5L0 9.3L0.7 10L5 5.7L9.3 10L10 9.3L5.7 5L10 0.7Z\"\n fill=\"currentColor\"\n />\n </svg>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"DropdownArrow.js","sourceRoot":"../../../src","sources":["icons/DropdownArrow.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,kBAAkB,EAAC,wBAAqB;AAEhD,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,KAAoC,EAAE,EAAE,CAAC,CACnE,4BACI,KAAK,EAAC,4BAA4B,EAClC,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,IAAI,EAAC,cAAc,IACf,kBAAkB,EAClB,KAAK,cAET,eAAM,CAAC,EAAC,mfAAmf,GAAG,IAC5f,CACT,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {a11yHiddenSvgProps} from '../utils/svg';\n\nexport const DropdownArrow = (props: React.SVGProps<SVGSVGElement>) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 16 16\"\n width=\"16\"\n height=\"16\"\n fill=\"currentColor\"\n {...a11yHiddenSvgProps}\n {...props}\n >\n <path d=\"M3.50172 5.44253C3.19384 5.16544 2.71962 5.19039 2.44253 5.49828C2.16544 5.80616 2.19039 6.28038 2.49828 6.55747L3.50172 5.44253ZM8 10.5L7.49828 11.0575C7.7835 11.3142 8.2165 11.3142 8.50172 11.0575L8 10.5ZM13.5017 6.55747C13.8096 6.28038 13.8346 5.80616 13.5575 5.49828C13.2804 5.19039 12.8062 5.16544 12.4983 5.44253L13.5017 6.55747ZM2.49828 6.55747L7.49828 11.0575L8.50172 9.94253L3.50172 5.44253L2.49828 6.55747ZM8.50172 11.0575L13.5017 6.55747L12.4983 5.44253L7.49828 9.94253L8.50172 11.0575Z\" />\n </svg>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Save.js","sourceRoot":"../../../src","sources":["icons/Save.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,kBAAkB,EAAC,wBAAqB;AAEhD,MAAM,CAAC,MAAM,IAAI,GAAG,CAAC,KAAoC,EAAE,EAAE,CAAC,CAC1D,4BACI,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,cAAc,IACf,kBAAkB,EAClB,KAAK,cAET,eACI,QAAQ,EAAC,SAAS,EAClB,QAAQ,EAAC,SAAS,EAClB,CAAC,EAAC,uVAAuV,GAC3V,IACA,CACT,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {a11yHiddenSvgProps} from '../utils/svg';\n\nexport const Save = (props: React.SVGProps<SVGSVGElement>) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"currentColor\"\n {...a11yHiddenSvgProps}\n {...props}\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13 3H3v9.6l3.445-2.94.028-.022a2.624 2.624 0 0 1 3.054 0l.028.021L13 12.6V3Zm1.357-1.614A1.593 1.593 0 0 1 15 2.655v10.547c0 .678-.416 1.218-.841 1.499-.417.275-1.24.517-1.898-.103L8.32 11.234a.64.64 0 0 0-.64 0l-3.942 3.364c-.58.546-1.348.461-1.838.18a1.808 1.808 0 0 1-.9-1.576V2.786C1 2.055 1.515 1 2.667 1H13.2c.405 0 .822.13 1.157.386Z\"\n />\n </svg>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"SaveFilled.js","sourceRoot":"../../../src","sources":["icons/SaveFilled.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,kBAAkB,EAAC,wBAAqB;AAEhD,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,KAAoC,EAAE,EAAE,CAAC,CAChE,4BACI,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,cAAc,IACf,kBAAkB,EAClB,KAAK,cAET,eACI,QAAQ,EAAC,SAAS,EAClB,QAAQ,EAAC,SAAS,EAClB,CAAC,EAAC,2QAA2Q,GAC/Q,IACA,CACT,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {a11yHiddenSvgProps} from '../utils/svg';\n\nexport const SaveFilled = (props: React.SVGProps<SVGSVGElement>) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"currentColor\"\n {...a11yHiddenSvgProps}\n {...props}\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M14.357 1.386A1.593 1.593 0 0 1 15 2.655v10.547c0 .678-.416 1.218-.841 1.499-.417.275-1.24.517-1.898-.103L8.32 11.234a.64.64 0 0 0-.64 0l-3.942 3.364c-.58.546-1.348.461-1.838.18a1.808 1.808 0 0 1-.9-1.576V2.786C1 2.055 1.515 1 2.667 1H13.2c.405 0 .822.13 1.157.386Z\"\n />\n </svg>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"SearchIcon.js","sourceRoot":"../../../src","sources":["icons/SearchIcon.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,kBAAkB,EAAC,wBAAqB;AAEhD,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,KAAoC,EAAE,EAAE,CAAC,CAChE,4BACI,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,IACP,kBAAkB,EAClB,KAAK,cAET,eACI,CAAC,EAAC,mEAAmE,EACrE,MAAM,EAAC,cAAc,EACrB,WAAW,EAAC,GAAG,EACf,aAAa,EAAC,OAAO,EACrB,YAAY,EAAC,oBAAoB,GACnC,IACA,CACT,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {a11yHiddenSvgProps} from '../utils/svg';\n\nexport const SearchIcon = (props: React.SVGProps<SVGSVGElement>) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n {...a11yHiddenSvgProps}\n {...props}\n >\n <path\n d=\"M9.532 9.539A5 5 0 1 0 2.468 2.46a5 5 0 0 0 7.064 7.08zm0 0L15 15\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n vectorEffect=\"non-scaling-stroke\"\n />\n </svg>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"ShareArrowUp.js","sourceRoot":"../../../src","sources":["icons/ShareArrowUp.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,kBAAkB,EAAC,wBAAqB;AAEhD,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,KAAoC,EAAE,EAAE,CAAC,CAClE,4BACI,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,cAAc,IACf,kBAAkB,EAClB,KAAK,cAET,eACI,QAAQ,EAAC,SAAS,EAClB,QAAQ,EAAC,SAAS,EAClB,CAAC,EAAC,mOAAmO,GACvO,IACA,CACT,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {a11yHiddenSvgProps} from '../utils/svg';\n\nexport const ShareArrowUp = (props: React.SVGProps<SVGSVGElement>) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"currentColor\"\n {...a11yHiddenSvgProps}\n {...props}\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M4.798 3.16a.5.5 0 0 0 .363.842H7V9a1 1 0 0 0 2 0V4.002h1.839a.5.5 0 0 0 .363-.844L8.363.156a.5.5 0 0 0-.726 0l-2.84 3.002.001.001ZM13 7a1 1 0 0 1 2 0v6.5a1.5 1.5 0 0 1-1.5 1.5h-11A1.5 1.5 0 0 1 1 13.5V7a1 1 0 0 1 2 0v6h10V7Z\"\n />\n </svg>\n);\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Time.js","sourceRoot":"../../../src","sources":["icons/Time.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,kBAAkB,EAAC,wBAAqB;AAEhD,MAAM,CAAC,MAAM,IAAI,GAAG,CAAC,KAAoC,EAAE,EAAE,CAAC,CAC1D,4BACI,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,cAAc,IACf,kBAAkB,EAClB,KAAK,cAET,eACI,QAAQ,EAAC,SAAS,EAClB,QAAQ,EAAC,SAAS,EAClB,CAAC,EAAC,gMAAgM,GACpM,IACA,CACT,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {a11yHiddenSvgProps} from '../utils/svg';\n\nexport const Time = (props: React.SVGProps<SVGSVGElement>) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"17\"\n viewBox=\"0 0 16 17\"\n fill=\"currentColor\"\n {...a11yHiddenSvgProps}\n {...props}\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M8 16.004a8 8 0 1 1 0-16 8 8 0 0 1 0 16Zm0-2a6 6 0 1 0 0-12 6 6 0 0 0 0 12Zm3.357-3.736a1 1 0 0 0-.342-1.372L9 7.688V5.004a1 1 0 0 0-2 0v3.25a1 1 0 0 0 .486.857l2.5 1.5a1 1 0 0 0 1.371-.343Z\"\n />\n </svg>\n);\n"]}
|
package/build/esm/index.js.map
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"../../src","sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAC,iDAA8C;AAE9E,OAAO,EAAC,YAAY,EAAC,kDAA+C;AACpE,OAAO,EAAC,QAAQ,EAAC,0CAAuC;AAExD,mCAAgC;AAChC,mCAAgC;AAEhC,kCAAyB;AAEzB,OAAO,EAAC,WAAW,EAAC,uBAAoB;AAExC,iCAAwB","sourcesContent":["export {BlogConstructorProvider} from './constructor/BlogConstructorProvider';\n\nexport {BlogPostPage} from './containers/BlogPostPage/BlogPostPage';\nexport {BlogPage} from './containers/BlogPage/BlogPage';\n\nexport * from './models/common';\nexport * from './models/locale';\n\nexport * from './schema';\n\nexport {BREAKPOINTS} from './constants';\n\nexport * from './utils';\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"blocks.js","sourceRoot":"../../../src","sources":["models/blocks.ts"],"names":[],"mappings":"","sourcesContent":["import * as React from 'react';\n\nimport {\n ContentBlockProps,\n FormBlockData,\n HeaderBlockProps,\n MediaProps as PCMediaProps,\n TextTheme,\n} from '@gravity-ui/page-constructor';\n\nimport {BlockType, ClassNameProps, PostData, QAProps} from './common';\nimport {PaddingsYFMProps} from './paddings';\n\n// blocks props\nexport type AuthorProps = ClassNameProps & {\n authorId: number | string;\n image: string;\n} & PaddingsYFMProps &\n QAProps;\n\nexport type BannerProps = ContentBlockProps &\n QAProps & {\n color?: string;\n image?: string;\n imageSize?: 's' | 'm';\n } & PaddingsYFMProps;\n\nexport type ColoredTextProps = ContentBlockProps &\n QAProps & {\n background?: {\n color?: string;\n image?: string;\n altText?: string;\n };\n } & PaddingsYFMProps;\n\nexport type CTAProps = QAProps & {\n items: Array<ContentBlockProps>;\n} & PaddingsYFMProps;\n\nexport type HeaderProps = HeaderBlockProps & PaddingsYFMProps;\n\nexport type LayoutProps = {\n fullWidth?: boolean;\n mobileOrder?: string;\n children: React.ReactElement[];\n} & PaddingsYFMProps;\n\nexport type MediaProps = ClassNameProps &\n PaddingsYFMProps &\n Partial<Pick<PCMediaProps, 'youtube' | 'previewImg' | 'image' | 'video' | 'dataLens'>> & {\n text?: string;\n };\n\nexport type MetaProps = QAProps & {\n locale: string;\n theme?: TextTheme;\n} & PaddingsYFMProps;\n\nexport type SuggestProps = ClassNameProps & {\n posts: PostData[];\n} & PaddingsYFMProps;\n\nexport type YFMProps = {\n text: string;\n} & PaddingsYFMProps &\n QAProps;\n\nexport type FeedProps = {\n image: string;\n};\n\nexport type FormProps = {\n formData: FormBlockData;\n border?: 'shadow' | 'line' | 'none';\n} & PaddingsYFMProps &\n QAProps;\n\n// blocks models\nexport type AuthorBlockModel = {\n type: BlockType.Author;\n} & AuthorProps;\n\nexport type BannerBlockModel = {\n type: BlockType.Banner;\n} & BannerProps;\n\nexport type ColoredTextBlockModel = {\n type: BlockType.ColoredText;\n} & ColoredTextProps;\n\nexport type CTABlockModel = {\n type: BlockType.CTA;\n} & CTAProps;\n\nexport type HeaderBlockModel = {\n type: BlockType.Header;\n} & HeaderProps;\n\nexport type LayoutBlockModel = {\n type: BlockType.Layout;\n} & LayoutProps;\n\nexport type MediaBlockModel = {\n type: BlockType.Media;\n} & MediaProps;\n\nexport type MetaBlockModel = {\n type: BlockType.Meta;\n} & MetaProps;\n\nexport type SuggestBlockModel = {\n type: BlockType.Suggest;\n} & SuggestProps;\n\nexport type YFMBlockModel = {\n type: BlockType.YFM;\n} & YFMProps;\n\nexport type FeedBlockModel = {\n type: BlockType.Feed;\n} & FeedProps;\n\nexport type FormBlockModel = {\n type: BlockType.Form;\n} & FormProps;\n\nexport type BlockModel =\n | AuthorBlockModel\n | BannerBlockModel\n | ColoredTextBlockModel\n | CTABlockModel\n | HeaderBlockModel\n | LayoutBlockModel\n | MediaBlockModel\n | MetaBlockModel\n | SuggestBlockModel\n | YFMBlockModel\n | FeedBlockModel;\n\nexport type Block = BlockModel & {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [x: string]: any;\n};\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"common.js","sourceRoot":"../../../src","sources":["models/common.ts"],"names":[],"mappings":"AASA,MAAM,CAAN,IAAY,KAGX;AAHD,WAAY,KAAK;IACb,wBAAe,CAAA;IACf,sBAAa,CAAA;AACjB,CAAC,EAHW,KAAK,KAAL,KAAK,QAGhB;AA2FD,MAAM,CAAN,IAAY,SAaX;AAbD,WAAY,SAAS;IACjB,yCAA4B,CAAA;IAC5B,mCAAsB,CAAA;IACtB,yCAA4B,CAAA;IAC5B,uCAA0B,CAAA;IAC1B,yCAA4B,CAAA;IAC5B,mCAAsB,CAAA;IACtB,oDAAuC,CAAA;IACvC,yCAA4B,CAAA;IAC5B,2CAA8B,CAAA;IAC9B,qCAAwB,CAAA;IACxB,qCAAwB,CAAA;IACxB,qCAAwB,CAAA;AAC5B,CAAC,EAbW,SAAS,KAAT,SAAS,QAapB;AA+DD,MAAM,CAAN,IAAY,iBAUX;AAVD,WAAY,iBAAiB;IACzB,uDAAkC,CAAA;IAClC,qDAAgC,CAAA;IAChC,wDAAmC,CAAA;IACnC,kEAA6C,CAAA;IAC7C,kEAA6C,CAAA;IAC7C,kEAA6C,CAAA;IAC7C,+CAA0B,CAAA;IAC1B,uDAAkC,CAAA;IAClC,wDAAmC,CAAA;AACvC,CAAC,EAVW,iBAAiB,KAAjB,iBAAiB,QAU5B;AAWD,MAAM,CAAN,IAAY,YAGX;AAHD,WAAY,YAAY;IACpB,2BAAW,CAAA;IACX,4BAAY,CAAA;AAChB,CAAC,EAHW,YAAY,KAAZ,YAAY,QAGvB;AAED,MAAM,CAAN,IAAY,yBAGX;AAHD,WAAY,yBAAyB;IACjC,sCAAS,CAAA;IACT,sCAAS,CAAA;AACb,CAAC,EAHW,yBAAyB,KAAzB,yBAAyB,QAGpC","sourcesContent":["import * as React from 'react';\n\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport {MarkdownItPluginCb} from '@diplodoc/transform/lib/plugins/typings';\nimport {HeaderBlockProps as PageConstructorHeaderBlockProps} from '@gravity-ui/page-constructor';\nimport {IBrowser, IDevice} from 'ua-parser-js';\n\nimport {Locale} from '../models/locale';\n\nexport enum Theme {\n Light = 'light',\n Dark = 'dark',\n}\n\nexport interface ClassNameProps {\n className?: string;\n}\n\nexport type Author = {\n id: number | string;\n avatar: string | null;\n createdAt: string;\n updatedAt: string;\n firstName: string | null;\n secondName: string | null;\n description: string | null;\n fullDescription: string | null;\n shortDescription: string | null;\n} & {\n [x: string]: string | null;\n};\n\nexport type Service = {\n id: number | string;\n slug: string;\n name: string;\n} & {\n [x: string]: string | null;\n};\n\nexport type Query = Record<string, number | string | null>;\n\n//page models\n\nexport interface Menu {\n title: string;\n}\n\nexport interface WithDeviceProps {\n device: IDevice;\n browser: IBrowser;\n isRobot: boolean;\n}\n\nexport interface PostsProps {\n posts: PostData[];\n count: number;\n totalCount: number;\n pinnedPost?: PostData;\n}\n\nexport type Tag = {\n slug: string;\n name: string;\n createdAt?: string;\n updatedAt?: string;\n icon?: string;\n isDeleted?: boolean;\n locale?: string;\n blogTagId?: number | string;\n count?: number;\n};\n\nexport interface PostData {\n author?: string;\n authors?: Author[];\n blogPostId?: number | string;\n content?: string;\n date: string;\n description?: string;\n hasUserLike: boolean;\n htmlTitle: string;\n id: number;\n image: string;\n isPublished?: boolean;\n sharedImage?: string;\n likes: number;\n locale: Locale;\n metaDescription?: string | null;\n metaTitle?: string | null;\n readingTime?: number;\n shareDescription?: string;\n shareImage?: string;\n shareTitle?: string;\n slug: string;\n keywords?: string[];\n tags: Tag[];\n textTitle: string;\n title: string;\n url: string;\n noIndex?: boolean;\n}\n\nexport enum BlockType {\n Header = 'blog-header-block',\n YFM = 'blog-yfm-block',\n Layout = 'blog-layout-block',\n Media = 'blog-media-block',\n Banner = 'blog-banner-block',\n CTA = 'blog-cta-block',\n ColoredText = 'blog-colored-text-block',\n Author = 'blog-author-block',\n Suggest = 'blog-suggest-block',\n Meta = 'blog-meta-block',\n Feed = 'blog-feed-block',\n Form = 'blog-form-block',\n}\n\nexport type MetaProps = {\n metaComponent: JSX.Element;\n needHelmetWrapper: boolean;\n};\n\nexport type MetaOrganizationType = {\n url: string;\n appTitle: string;\n legalName: string;\n supportEmail: string;\n};\n\nexport interface PostMetaProps {\n title: string;\n date: string;\n image: string;\n canonicalUrl: string;\n content?: string;\n description?: string;\n sharing: {\n shareTitle: string;\n shareDescription: string;\n shareImage: string;\n shareGenImage: string;\n shareGenTitle: string;\n };\n keywords?: string[];\n noIndex?: boolean;\n authors?: Author[];\n tags?: Tag[];\n organization: MetaOrganizationType;\n}\n\nexport type ToggleLikeCallbackType = ({\n postId,\n hasLike,\n}: {\n postId?: number | string;\n hasLike?: boolean;\n}) => void;\n\nexport interface HeaderBlockProps extends PageConstructorHeaderBlockProps {\n backLink?: {\n url: string;\n title: React.ReactNode;\n };\n}\n\nexport type GetPostsRequest = {\n tags: string | undefined;\n page: number;\n perPage: number;\n savedOnly: boolean;\n search: string | undefined;\n services: string | undefined;\n};\n\nexport type GetPostsType = (query: GetPostsRequest) => Promise<PostsProps>;\n\nexport type HandleChangeQueryParams = (params: Query) => void;\n\nexport enum DefaultEventNames {\n ShareButton = 'share-button-click',\n SaveButton = 'save-button-click',\n ShowMore = 'show-more-button-click',\n PaginatorHome = 'paginator-home-button-click',\n PaginatorNext = 'paginator-next-button-click',\n PaginatorPage = 'paginator-page-button-click',\n Tag = 'selector-tag-click',\n Service = 'selector-service-click',\n SaveOnly = 'save-only-button-click',\n}\n\nexport type FetchArgs = {\n page?: number;\n query: Query;\n};\n\nexport interface QAProps {\n qa?: string;\n}\n\nexport enum PostCardSize {\n SMALL = 's',\n MEDIUM = 'm',\n}\n\nexport enum PostCardTitleHeadingLevel {\n H2 = 'h2',\n H3 = 'h3',\n}\n\nexport interface TransformPostOptions {\n plugins?: MarkdownItPluginCb[];\n}\n"]}
|