@reuters-graphics/graphics-components 2.0.2 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/cssVariables/cssVariables.mdx +4 -5
- package/dist/actions/cssVariables/index.d.ts +2 -2
- package/dist/actions/cssVariables/index.js +14 -16
- package/dist/actions/resizeObserver/index.d.ts +1 -1
- package/dist/actions/resizeObserver/index.js +18 -20
- package/dist/actions/resizeObserver/resizeObserver.mdx +1 -1
- package/dist/app.html +11 -0
- package/dist/components/@types/global.d.ts +9 -7
- package/dist/components/AdSlot/AdScripts.svelte +15 -12
- package/dist/components/AdSlot/AdScripts.svelte.d.ts +16 -14
- package/dist/components/AdSlot/AdSlot.svelte +53 -31
- package/dist/components/AdSlot/AdSlot.svelte.d.ts +10 -21
- package/dist/components/AdSlot/{stories/docs/inline.md → InlineAd.mdx} +14 -4
- package/dist/components/AdSlot/InlineAd.stories.svelte +11 -14
- package/dist/components/AdSlot/InlineAd.stories.svelte.d.ts +17 -21
- package/dist/components/AdSlot/InlineAd.svelte +18 -7
- package/dist/components/AdSlot/InlineAd.svelte.d.ts +12 -20
- package/dist/components/AdSlot/{stories/docs/leaderboard.md → LeaderboardAd.mdx} +10 -0
- package/dist/components/AdSlot/LeaderboardAd.stories.svelte +13 -16
- package/dist/components/AdSlot/LeaderboardAd.stories.svelte.d.ts +17 -21
- package/dist/components/AdSlot/LeaderboardAd.svelte +45 -29
- package/dist/components/AdSlot/LeaderboardAd.svelte.d.ts +10 -19
- package/dist/components/AdSlot/OneTrust.svelte +39 -34
- package/dist/components/AdSlot/OneTrust.svelte.d.ts +16 -14
- package/dist/components/AdSlot/ResponsiveAd.svelte +69 -45
- package/dist/components/AdSlot/ResponsiveAd.svelte.d.ts +6 -18
- package/dist/components/AdSlot/{stories/docs/sponsorship.md → SponsorshipAd.mdx} +11 -1
- package/dist/components/AdSlot/SponsorshipAd.stories.svelte +11 -15
- package/dist/components/AdSlot/SponsorshipAd.stories.svelte.d.ts +17 -21
- package/dist/components/AdSlot/SponsorshipAd.svelte +21 -7
- package/dist/components/AdSlot/SponsorshipAd.svelte.d.ts +14 -22
- package/dist/components/Analytics/Analytics.mdx +73 -0
- package/dist/components/Analytics/Analytics.stories.svelte +11 -31
- package/dist/components/Analytics/Analytics.stories.svelte.d.ts +17 -21
- package/dist/components/Analytics/Analytics.svelte +27 -11
- package/dist/components/Analytics/Analytics.svelte.d.ts +14 -23
- package/dist/components/Article/Article.mdx +117 -0
- package/dist/components/Article/Article.stories.svelte +39 -40
- package/dist/components/Article/Article.stories.svelte.d.ts +17 -21
- package/dist/components/Article/Article.svelte +50 -20
- package/dist/components/Article/Article.svelte.d.ts +26 -34
- package/dist/components/BeforeAfter/BeforeAfter.mdx +111 -0
- package/dist/components/BeforeAfter/BeforeAfter.stories.svelte +38 -80
- package/dist/components/BeforeAfter/BeforeAfter.stories.svelte.d.ts +17 -30
- package/dist/components/BeforeAfter/BeforeAfter.svelte +240 -141
- package/dist/components/BeforeAfter/BeforeAfter.svelte.d.ts +60 -62
- package/dist/components/Block/Block.mdx +99 -0
- package/dist/components/Block/Block.stories.svelte +82 -72
- package/dist/components/Block/Block.stories.svelte.d.ts +17 -30
- package/dist/components/Block/Block.svelte +33 -11
- package/dist/components/Block/Block.svelte.d.ts +20 -25
- package/dist/components/BodyText/BodyText.mdx +115 -0
- package/dist/components/BodyText/BodyText.stories.svelte +28 -194
- package/dist/components/BodyText/BodyText.stories.svelte.d.ts +17 -21
- package/dist/components/BodyText/BodyText.svelte +14 -7
- package/dist/components/BodyText/BodyText.svelte.d.ts +11 -24
- package/dist/components/Byline/Byline.mdx +110 -0
- package/dist/components/Byline/Byline.stories.svelte +50 -26
- package/dist/components/Byline/Byline.stories.svelte.d.ts +17 -27
- package/dist/components/Byline/Byline.svelte +109 -43
- package/dist/components/Byline/Byline.svelte.d.ts +48 -48
- package/dist/components/DatawrapperChart/{stories/docs/component.md → DatawrapperChart.mdx} +20 -0
- package/dist/components/DatawrapperChart/DatawrapperChart.stories.svelte +31 -39
- package/dist/components/DatawrapperChart/DatawrapperChart.stories.svelte.d.ts +17 -27
- package/dist/components/DatawrapperChart/DatawrapperChart.svelte +94 -40
- package/dist/components/DatawrapperChart/DatawrapperChart.svelte.d.ts +42 -53
- package/dist/components/DocumentCloud/DocumentCloud.mdx +26 -0
- package/dist/components/DocumentCloud/DocumentCloud.stories.svelte +16 -25
- package/dist/components/DocumentCloud/DocumentCloud.stories.svelte.d.ts +17 -27
- package/dist/components/DocumentCloud/DocumentCloud.svelte +31 -10
- package/dist/components/DocumentCloud/DocumentCloud.svelte.d.ts +21 -30
- package/dist/components/EmbedPreviewerLink/EmbedPreviewerLink.mdx +19 -0
- package/dist/components/EmbedPreviewerLink/EmbedPreviewerLink.stories.svelte +11 -18
- package/dist/components/EmbedPreviewerLink/EmbedPreviewerLink.stories.svelte.d.ts +17 -21
- package/dist/components/EmbedPreviewerLink/EmbedPreviewerLink.svelte +9 -4
- package/dist/components/EmbedPreviewerLink/EmbedPreviewerLink.svelte.d.ts +5 -17
- package/dist/components/EndNotes/EndNotes.mdx +67 -0
- package/dist/components/EndNotes/EndNotes.stories.svelte +10 -15
- package/dist/components/EndNotes/EndNotes.stories.svelte.d.ts +17 -21
- package/dist/components/EndNotes/EndNotes.svelte +30 -14
- package/dist/components/EndNotes/EndNotes.svelte.d.ts +19 -31
- package/dist/components/FeaturePhoto/FeaturePhoto.mdx +72 -0
- package/dist/components/FeaturePhoto/FeaturePhoto.stories.svelte +24 -49
- package/dist/components/FeaturePhoto/FeaturePhoto.stories.svelte.d.ts +17 -31
- package/dist/components/FeaturePhoto/FeaturePhoto.svelte +108 -43
- package/dist/components/FeaturePhoto/FeaturePhoto.svelte.d.ts +57 -58
- package/dist/components/Framer/Framer.mdx +19 -0
- package/dist/components/Framer/Framer.stories.svelte +11 -18
- package/dist/components/Framer/Framer.stories.svelte.d.ts +17 -21
- package/dist/components/Framer/Framer.svelte +97 -69
- package/dist/components/Framer/Framer.svelte.d.ts +8 -30
- package/dist/components/Framer/Resizer/index.svelte +54 -41
- package/dist/components/Framer/Resizer/index.svelte.d.ts +7 -28
- package/dist/components/Framer/Typeahead/Search.svelte +101 -0
- package/dist/components/Framer/Typeahead/Search.svelte.d.ts +18 -0
- package/dist/components/Framer/Typeahead/fuzzy.d.ts +22 -9
- package/dist/components/Framer/Typeahead/fuzzy.js +70 -129
- package/dist/components/Framer/Typeahead/index.svelte +133 -121
- package/dist/components/Framer/Typeahead/index.svelte.d.ts +31 -138
- package/dist/components/Framer/stores.d.ts +1 -1
- package/dist/components/Framer/stores.js +0 -1
- package/dist/components/Framer/stories/docs/component.md +1 -1
- package/dist/components/Framer/uniqNames.d.ts +1 -1
- package/dist/components/Framer/uniqNames.js +45 -49
- package/dist/components/GraphicBlock/GraphicBlock.mdx +215 -0
- package/dist/components/GraphicBlock/GraphicBlock.stories.svelte +80 -60
- package/dist/components/GraphicBlock/GraphicBlock.stories.svelte.d.ts +17 -31
- package/dist/components/GraphicBlock/GraphicBlock.svelte +130 -69
- package/dist/components/GraphicBlock/GraphicBlock.svelte.d.ts +50 -65
- package/dist/components/GraphicBlock/components/AriaHidden.svelte +22 -0
- package/dist/components/GraphicBlock/components/AriaHidden.svelte.d.ts +12 -0
- package/dist/components/GraphicBlock/components/TextBlock.svelte +23 -0
- package/dist/components/GraphicBlock/components/TextBlock.svelte.d.ts +11 -0
- package/dist/components/GraphicBlock/{stories → demo}/ai2svelte/ai-chart.svelte +7 -11
- package/dist/components/GraphicBlock/demo/ai2svelte/ai-chart.svelte.d.ts +3 -0
- package/dist/components/Headline/Headline.mdx +150 -0
- package/dist/components/Headline/Headline.stories.svelte +78 -92
- package/dist/components/Headline/Headline.stories.svelte.d.ts +17 -31
- package/dist/components/Headline/Headline.svelte +108 -49
- package/dist/components/Headline/Headline.svelte.d.ts +42 -53
- package/dist/components/Headline/{stories → demo}/graphic.svelte +8 -9
- package/dist/components/Headline/demo/graphic.svelte.d.ts +6 -0
- package/dist/components/HeroHeadline/HeroHeadline.mdx +329 -0
- package/dist/components/HeroHeadline/HeroHeadline.stories.svelte +264 -0
- package/dist/components/HeroHeadline/HeroHeadline.stories.svelte.d.ts +19 -0
- package/dist/components/HeroHeadline/HeroHeadline.svelte +277 -0
- package/dist/components/HeroHeadline/HeroHeadline.svelte.d.ts +84 -0
- package/dist/components/HeroHeadline/{stories → demo}/graphics/crash.svelte +8 -15
- package/dist/components/HeroHeadline/demo/graphics/crash.svelte.d.ts +6 -0
- package/dist/components/HeroHeadline/{stories → demo}/graphics/quakemap.svelte +7 -7
- package/dist/components/HeroHeadline/demo/graphics/quakemap.svelte.d.ts +6 -0
- package/dist/components/InfoBox/InfoBox.mdx +122 -0
- package/dist/components/InfoBox/InfoBox.stories.svelte +86 -38
- package/dist/components/InfoBox/InfoBox.stories.svelte.d.ts +17 -31
- package/dist/components/InfoBox/InfoBox.svelte +69 -21
- package/dist/components/InfoBox/InfoBox.svelte.d.ts +41 -45
- package/dist/components/PaddingReset/PaddingReset.mdx +53 -0
- package/dist/components/PaddingReset/PaddingReset.stories.svelte +33 -33
- package/dist/components/PaddingReset/PaddingReset.stories.svelte.d.ts +17 -21
- package/dist/components/PaddingReset/PaddingReset.svelte +17 -7
- package/dist/components/PaddingReset/PaddingReset.svelte.d.ts +14 -29
- package/dist/components/PaddingReset/shark.jpg +0 -0
- package/dist/components/PhotoPack/PhotoPack.mdx +125 -0
- package/dist/components/PhotoPack/PhotoPack.stories.svelte +69 -108
- package/dist/components/PhotoPack/PhotoPack.stories.svelte.d.ts +17 -31
- package/dist/components/PhotoPack/PhotoPack.svelte +85 -43
- package/dist/components/PhotoPack/PhotoPack.svelte.d.ts +32 -52
- package/dist/components/PhotoPack/utils.d.ts +2 -0
- package/dist/components/PhotoPack/utils.js +17 -0
- package/dist/components/PymChild/PymChild.mdx +33 -0
- package/dist/components/PymChild/PymChild.stories.svelte +8 -17
- package/dist/components/PymChild/PymChild.stories.svelte.d.ts +17 -21
- package/dist/components/PymChild/PymChild.svelte +16 -9
- package/dist/components/PymChild/PymChild.svelte.d.ts +7 -18
- package/dist/components/PymChild/state.svelte.d.ts +6 -0
- package/dist/components/PymChild/state.svelte.js +1 -0
- package/dist/components/ReferralBlock/ReferralBlock.mdx +44 -0
- package/dist/components/ReferralBlock/ReferralBlock.stories.svelte +35 -45
- package/dist/components/ReferralBlock/ReferralBlock.stories.svelte.d.ts +17 -35
- package/dist/components/ReferralBlock/ReferralBlock.svelte +113 -66
- package/dist/components/ReferralBlock/ReferralBlock.svelte.d.ts +36 -41
- package/dist/components/ReutersGraphicsLogo/ReutersGraphicsLogo.mdx +21 -0
- package/dist/components/ReutersGraphicsLogo/ReutersGraphicsLogo.stories.svelte +12 -17
- package/dist/components/ReutersGraphicsLogo/ReutersGraphicsLogo.stories.svelte.d.ts +17 -21
- package/dist/components/ReutersGraphicsLogo/ReutersGraphicsLogo.svelte +15 -3
- package/dist/components/ReutersGraphicsLogo/ReutersGraphicsLogo.svelte.d.ts +11 -20
- package/dist/components/ReutersLogo/ReutersLogo.mdx +19 -0
- package/dist/components/ReutersLogo/ReutersLogo.stories.svelte +12 -20
- package/dist/components/ReutersLogo/ReutersLogo.stories.svelte.d.ts +17 -29
- package/dist/components/ReutersLogo/ReutersLogo.svelte +30 -19
- package/dist/components/ReutersLogo/ReutersLogo.svelte.d.ts +11 -20
- package/dist/components/SEO/SEO.mdx +80 -0
- package/dist/components/SEO/SEO.stories.svelte +18 -36
- package/dist/components/SEO/SEO.stories.svelte.d.ts +16 -22
- package/dist/components/SEO/SEO.svelte +151 -91
- package/dist/components/SEO/SEO.svelte.d.ts +53 -71
- package/dist/components/Scroller/Background.svelte +14 -10
- package/dist/components/Scroller/Background.svelte.d.ts +8 -20
- package/dist/components/Scroller/Embedded/Background.svelte +13 -9
- package/dist/components/Scroller/Embedded/Background.svelte.d.ts +7 -19
- package/dist/components/Scroller/Embedded/Foreground.svelte +16 -11
- package/dist/components/Scroller/Embedded/Foreground.svelte.d.ts +6 -18
- package/dist/components/Scroller/Embedded/index.svelte +18 -5
- package/dist/components/Scroller/Embedded/index.svelte.d.ts +8 -19
- package/dist/components/Scroller/Foreground.svelte +14 -9
- package/dist/components/Scroller/Foreground.svelte.d.ts +5 -17
- package/dist/components/Scroller/Scroller.mdx +279 -0
- package/dist/components/Scroller/Scroller.stories.svelte +107 -100
- package/dist/components/Scroller/Scroller.stories.svelte.d.ts +17 -38
- package/dist/components/Scroller/Scroller.svelte +121 -44
- package/dist/components/Scroller/Scroller.svelte.d.ts +66 -83
- package/dist/components/Scroller/ScrollerBase/index.svelte +267 -0
- package/dist/components/Scroller/ScrollerBase/index.svelte.d.ts +32 -0
- package/dist/components/Scroller/demo/components/ai2svelte/ai-foreground.svelte +118 -0
- package/dist/components/Scroller/demo/components/ai2svelte/ai-foreground.svelte.d.ts +6 -0
- package/dist/components/Scroller/{stories → demo}/components/ai2svelte/ai-scroller-1.svelte +4 -14
- package/dist/components/Scroller/demo/components/ai2svelte/ai-scroller-1.svelte.d.ts +3 -0
- package/dist/components/Scroller/{stories → demo}/components/ai2svelte/ai-scroller-2.svelte +3 -3
- package/dist/components/Scroller/demo/components/ai2svelte/ai-scroller-2.svelte.d.ts +3 -0
- package/dist/components/Scroller/{stories → demo}/components/ai2svelte/ai-scroller-3.svelte +3 -3
- package/dist/components/Scroller/demo/components/ai2svelte/ai-scroller-3.svelte.d.ts +3 -0
- package/dist/components/Scroller/demo/components/ai2svelte/images/Body-issues-key-xs.png +0 -0
- package/dist/components/Scroller/demo/components/basic/InteractiveForeground.svelte +17 -0
- package/dist/components/Scroller/demo/components/basic/InteractiveForeground.svelte.d.ts +6 -0
- package/dist/components/Scroller/demo/components/basic/Step.svelte +16 -0
- package/dist/components/Scroller/demo/components/basic/Step.svelte.d.ts +6 -0
- package/dist/components/SearchInput/SearchInput.mdx +29 -0
- package/dist/components/SearchInput/SearchInput.stories.svelte +20 -15
- package/dist/components/SearchInput/SearchInput.stories.svelte.d.ts +17 -21
- package/dist/components/SearchInput/SearchInput.svelte +31 -20
- package/dist/components/SearchInput/SearchInput.svelte.d.ts +9 -23
- package/dist/components/SearchInput/components/MagnifyingGlass.svelte.d.ts +26 -0
- package/dist/components/SearchInput/components/X.svelte.d.ts +26 -0
- package/dist/components/SimpleTimeline/SimpleTimeline.mdx +119 -0
- package/dist/components/SimpleTimeline/SimpleTimeline.stories.svelte +28 -36
- package/dist/components/SimpleTimeline/SimpleTimeline.stories.svelte.d.ts +17 -29
- package/dist/components/SimpleTimeline/SimpleTimeline.svelte +51 -15
- package/dist/components/SimpleTimeline/SimpleTimeline.svelte.d.ts +34 -44
- package/dist/components/SiteFooter/CompanyLinks.svelte +34 -6
- package/dist/components/SiteFooter/CompanyLinks.svelte.d.ts +11 -24
- package/dist/components/SiteFooter/LegalLinks.svelte +42 -9
- package/dist/components/SiteFooter/LegalLinks.svelte.d.ts +18 -24
- package/dist/components/SiteFooter/QuickLinks.svelte +60 -15
- package/dist/components/SiteFooter/QuickLinks.svelte.d.ts +27 -24
- package/dist/components/SiteFooter/SiteFooter.mdx +45 -0
- package/dist/components/SiteFooter/SiteFooter.stories.svelte +11 -31
- package/dist/components/SiteFooter/SiteFooter.stories.svelte.d.ts +17 -21
- package/dist/components/SiteFooter/SiteFooter.svelte +45 -31
- package/dist/components/SiteFooter/SiteFooter.svelte.d.ts +9 -20
- package/dist/components/SiteFooter/data.json +2 -2
- package/dist/components/SiteFooter/svgs/Facebook.svelte +6 -2
- package/dist/components/SiteFooter/svgs/Facebook.svelte.d.ts +5 -24
- package/dist/components/SiteFooter/svgs/Graphics.svelte.d.ts +22 -21
- package/dist/components/SiteFooter/svgs/Instagram.svelte +6 -2
- package/dist/components/SiteFooter/svgs/Instagram.svelte.d.ts +5 -24
- package/dist/components/SiteFooter/svgs/LinkedIn.svelte +6 -2
- package/dist/components/SiteFooter/svgs/LinkedIn.svelte.d.ts +5 -24
- package/dist/components/SiteFooter/svgs/Pictures.svelte.d.ts +22 -21
- package/dist/components/SiteFooter/svgs/Twitter.svelte +6 -2
- package/dist/components/SiteFooter/svgs/Twitter.svelte.d.ts +5 -24
- package/dist/components/SiteFooter/svgs/Videos.svelte.d.ts +22 -21
- package/dist/components/SiteFooter/svgs/YouTube.svelte +6 -2
- package/dist/components/SiteFooter/svgs/YouTube.svelte.d.ts +5 -24
- package/dist/components/SiteHeader/MobileMenu/index.svelte +45 -12
- package/dist/components/SiteHeader/MobileMenu/index.svelte.d.ts +7 -28
- package/dist/components/SiteHeader/NavBar/DownArrow.svelte +7 -3
- package/dist/components/SiteHeader/NavBar/DownArrow.svelte.d.ts +5 -24
- package/dist/components/SiteHeader/NavBar/NavDropdown/MoreDropdown.svelte +11 -7
- package/dist/components/SiteHeader/NavBar/NavDropdown/MoreDropdown.svelte.d.ts +5 -25
- package/dist/components/SiteHeader/NavBar/NavDropdown/SectionDropdown.svelte +13 -9
- package/dist/components/SiteHeader/NavBar/NavDropdown/SectionDropdown.svelte.d.ts +5 -26
- package/dist/components/SiteHeader/NavBar/NavDropdown/Spinner/index.svelte +1 -0
- package/dist/components/SiteHeader/NavBar/NavDropdown/Spinner/index.svelte.d.ts +22 -21
- package/dist/components/SiteHeader/NavBar/NavDropdown/StoryCard/index.svelte +10 -20
- package/dist/components/SiteHeader/NavBar/NavDropdown/StoryCard/index.svelte.d.ts +4 -24
- package/dist/components/SiteHeader/NavBar/NavDropdown/StoryCard/time.d.ts +2 -1
- package/dist/components/SiteHeader/NavBar/NavDropdown/StoryCard/time.js +36 -45
- package/dist/components/SiteHeader/NavBar/NavDropdown/index.svelte +65 -22
- package/dist/components/SiteHeader/NavBar/NavDropdown/index.svelte.d.ts +7 -28
- package/dist/components/SiteHeader/NavBar/index.svelte +46 -40
- package/dist/components/SiteHeader/NavBar/index.svelte.d.ts +5 -25
- package/dist/components/SiteHeader/NavBar/utils/index.d.ts +1 -1
- package/dist/components/SiteHeader/NavBar/utils/index.js +1 -2
- package/dist/components/SiteHeader/SiteHeader.mdx +33 -0
- package/dist/components/SiteHeader/SiteHeader.stories.svelte +27 -26
- package/dist/components/SiteHeader/SiteHeader.stories.svelte.d.ts +17 -28
- package/dist/components/SiteHeader/SiteHeader.svelte +64 -39
- package/dist/components/SiteHeader/SiteHeader.svelte.d.ts +3 -16
- package/dist/components/SiteHeader/scss/_grids.scss +49 -17
- package/dist/components/SiteHeader/svgs/Close.svelte.d.ts +22 -21
- package/dist/components/SiteHeader/svgs/Menu.svelte +6 -2
- package/dist/components/SiteHeader/svgs/Menu.svelte.d.ts +5 -24
- package/dist/components/SiteHeadline/SiteHeadline.mdx +66 -0
- package/dist/components/SiteHeadline/SiteHeadline.stories.svelte +17 -35
- package/dist/components/SiteHeadline/SiteHeadline.stories.svelte.d.ts +17 -36
- package/dist/components/SiteHeadline/SiteHeadline.svelte +59 -26
- package/dist/components/SiteHeadline/SiteHeadline.svelte.d.ts +31 -54
- package/dist/components/Spinner/Spinner.mdx +25 -0
- package/dist/components/Spinner/Spinner.stories.svelte +17 -25
- package/dist/components/Spinner/Spinner.stories.svelte.d.ts +17 -58
- package/dist/components/Spinner/Spinner.svelte +30 -6
- package/dist/components/Spinner/Spinner.svelte.d.ts +23 -30
- package/dist/components/Table/Table.mdx +177 -0
- package/dist/components/Table/Table.stories.svelte +56 -79
- package/dist/components/Table/Table.stories.svelte.d.ts +17 -27
- package/dist/components/Table/Table.svelte +201 -134
- package/dist/components/Table/Table.svelte.d.ts +50 -94
- package/dist/components/Table/components/LeftArrow.svelte.d.ts +26 -0
- package/dist/components/Table/{Pagination.svelte → components/Pagination.svelte} +48 -21
- package/dist/components/Table/components/Pagination.svelte.d.ts +21 -0
- package/dist/components/Table/components/RightArrow.svelte.d.ts +26 -0
- package/dist/components/Table/{Select.svelte → components/Select.svelte} +25 -13
- package/dist/components/Table/components/Select.svelte.d.ts +16 -0
- package/dist/components/Table/{SortArrow.svelte → components/SortArrow.svelte} +19 -4
- package/dist/components/Table/components/SortArrow.svelte.d.ts +16 -0
- package/dist/components/Table/utils.d.ts +39 -3
- package/dist/components/Table/utils.js +80 -26
- package/dist/components/Theme/@types/component.d.ts +5 -6
- package/dist/components/Theme/Theme.mdx +164 -0
- package/dist/components/Theme/Theme.stories.svelte +55 -57
- package/dist/components/Theme/Theme.stories.svelte.d.ts +17 -30
- package/dist/components/Theme/Theme.svelte +45 -11
- package/dist/components/Theme/Theme.svelte.d.ts +19 -28
- package/dist/components/Theme/demo/ThemedPage.svelte +36 -0
- package/dist/components/Theme/demo/ThemedPage.svelte.d.ts +26 -0
- package/dist/components/Theme/themes/common.d.ts +26 -1
- package/dist/components/Theme/themes/dark.d.ts +12 -1
- package/dist/components/Theme/themes/light.d.ts +12 -1
- package/dist/components/Theme/utils/flatten.d.ts +1 -1
- package/dist/components/Theme/utils/flatten.js +27 -33
- package/dist/components/Theme/utils/merge.d.ts +2 -1
- package/dist/components/Theme/utils/merge.js +16 -15
- package/dist/components/ToolsHeader/ToolsHeader.mdx +23 -0
- package/dist/components/ToolsHeader/ToolsHeader.stories.svelte +10 -16
- package/dist/components/ToolsHeader/ToolsHeader.stories.svelte.d.ts +17 -21
- package/dist/components/ToolsHeader/ToolsHeader.svelte +57 -16
- package/dist/components/ToolsHeader/ToolsHeader.svelte.d.ts +34 -38
- package/dist/components/Video/Video.mdx +155 -0
- package/dist/components/Video/Video.stories.svelte +72 -56
- package/dist/components/Video/Video.stories.svelte.d.ts +17 -21
- package/dist/components/Video/Video.svelte +277 -192
- package/dist/components/Video/Video.svelte.d.ts +53 -77
- package/dist/components/Video/types.d.ts +1 -0
- package/dist/components/Video/types.js +1 -0
- package/dist/components/Video/utils.d.ts +3 -0
- package/dist/components/Video/utils.js +13 -0
- package/dist/components/Visible/Visible.mdx +33 -0
- package/dist/components/Visible/Visible.stories.svelte +18 -22
- package/dist/components/Visible/Visible.stories.svelte.d.ts +17 -21
- package/dist/components/Visible/Visible.svelte +74 -37
- package/dist/components/Visible/Visible.svelte.d.ts +23 -31
- package/dist/docs/contributing/component-guidelines.mdx +19 -48
- package/dist/docs/contributing/quickstart.mdx +2 -12
- package/dist/docs/contributing/writing-component-stories.mdx +5 -6
- package/dist/docs/docs-components/ThemeBuilder/Customiser/Value.jsx +2 -1
- package/dist/docs/docs-components/ThemeBuilder/ThemeBuilder.jsx +1 -1
- package/dist/docs/guides/archieml.mdx +18 -18
- package/dist/docs/guides/graphics-kit.mdx +5 -5
- package/dist/docs/guides/svelte-components.mdx +9 -9
- package/dist/docs/intro.mdx +2 -2
- package/dist/docs/styles/intro.mdx +1 -1
- package/dist/docs/theming/css-variables.mdx +7 -7
- package/dist/docs/utils/css-to-js/index.d.ts +2 -0
- package/dist/docs/utils/css-to-js/index.js +388 -0
- package/dist/docs/utils/parseCss.d.ts +3 -3
- package/dist/docs/utils/parseCss.js +37 -43
- package/dist/index.d.ts +43 -45
- package/dist/index.js +5 -12
- package/dist/journalize.d.ts +19 -0
- package/dist/scss/tokens/text/mixins/_font-family.scss +2 -1
- package/dist/utils/index.d.ts +6 -0
- package/dist/utils/index.js +12 -0
- package/package.json +59 -77
- package/dist/components/Analytics/stories/docs/component.md +0 -11
- package/dist/components/Analytics/stories/docs/environments.md +0 -17
- package/dist/components/Analytics/stories/docs/multipage.md +0 -31
- package/dist/components/Article/stories/docs/component.md +0 -13
- package/dist/components/Article/stories/docs/customWellWidths.md +0 -87
- package/dist/components/BeforeAfter/stories/docs/ariaDescriptions.md +0 -35
- package/dist/components/BeforeAfter/stories/docs/component.md +0 -15
- package/dist/components/BeforeAfter/stories/docs/withOverlays.md +0 -33
- package/dist/components/Block/stories/docs/component.md +0 -15
- package/dist/components/Block/stories/docs/customLayouts.md +0 -13
- package/dist/components/Block/stories/docs/snapWidths.md +0 -50
- package/dist/components/BodyText/stories/docs/component.md +0 -46
- package/dist/components/Byline/stories/docs/component.md +0 -19
- package/dist/components/DatawrapperChart/stories/docs/withChatter.md +0 -5
- package/dist/components/DocumentCloud/stories/docs/component.md +0 -17
- package/dist/components/EmbedPreviewerLink/stories/docs/component.md +0 -11
- package/dist/components/EndNotes/stories/docs/component.md +0 -24
- package/dist/components/FeaturePhoto/stories/docs/archieML.md +0 -37
- package/dist/components/FeaturePhoto/stories/docs/component.md +0 -16
- package/dist/components/FeaturePhoto/stories/docs/missingAltText.md +0 -1
- package/dist/components/GraphicBlock/AriaHidden.svelte +0 -10
- package/dist/components/GraphicBlock/AriaHidden.svelte.d.ts +0 -22
- package/dist/components/GraphicBlock/TextBlock.svelte +0 -11
- package/dist/components/GraphicBlock/TextBlock.svelte.d.ts +0 -21
- package/dist/components/GraphicBlock/stories/ai2svelte/ai-chart.svelte.d.ts +0 -25
- package/dist/components/GraphicBlock/stories/docs/ai2svelte.md +0 -19
- package/dist/components/GraphicBlock/stories/docs/archieML.md +0 -40
- package/dist/components/GraphicBlock/stories/docs/aria.md +0 -56
- package/dist/components/GraphicBlock/stories/docs/component.md +0 -20
- package/dist/components/GraphicBlock/stories/docs/customText.md +0 -14
- package/dist/components/Headline/stories/docs/component.md +0 -13
- package/dist/components/Headline/stories/docs/customHed.md +0 -31
- package/dist/components/Headline/stories/docs/withByline.md +0 -13
- package/dist/components/Headline/stories/docs/withCrownGraphic.md +0 -24
- package/dist/components/Headline/stories/docs/withCrownImage.md +0 -21
- package/dist/components/Headline/stories/docs/withDek.md +0 -11
- package/dist/components/Headline/stories/graphic.svelte.d.ts +0 -25
- package/dist/components/HeroHeadline/Hero.stories.svelte +0 -322
- package/dist/components/HeroHeadline/Hero.stories.svelte.d.ts +0 -42
- package/dist/components/HeroHeadline/Hero.svelte +0 -193
- package/dist/components/HeroHeadline/Hero.svelte.d.ts +0 -75
- package/dist/components/HeroHeadline/stories/docs/backgroundGraphic.md +0 -84
- package/dist/components/HeroHeadline/stories/docs/backgroundVideo.md +0 -51
- package/dist/components/HeroHeadline/stories/docs/component.md +0 -20
- package/dist/components/HeroHeadline/stories/docs/customHed.md +0 -43
- package/dist/components/HeroHeadline/stories/docs/inlineGraphic.md +0 -38
- package/dist/components/HeroHeadline/stories/docs/inlinePhoto.md +0 -34
- package/dist/components/HeroHeadline/stories/docs/inlineVideo.md +0 -34
- package/dist/components/HeroHeadline/stories/docs/transparentHeader.md +0 -17
- package/dist/components/HeroHeadline/stories/graphics/crash.svelte.d.ts +0 -25
- package/dist/components/HeroHeadline/stories/graphics/quakemap.svelte.d.ts +0 -25
- package/dist/components/InfoBox/stories/docs/component.md +0 -17
- package/dist/components/Markdown/Markdown.stories.svelte +0 -28
- package/dist/components/Markdown/Markdown.stories.svelte.d.ts +0 -23
- package/dist/components/Markdown/Markdown.svelte +0 -34
- package/dist/components/Markdown/Markdown.svelte.d.ts +0 -20
- package/dist/components/Markdown/stores.d.ts +0 -23
- package/dist/components/Markdown/stores.js +0 -24
- package/dist/components/Markdown/stories/docs/component.md +0 -39
- package/dist/components/PaddingReset/stories/docs/component.md +0 -35
- package/dist/components/PhotoCarousel/PhotoCarousel.stories.svelte +0 -72
- package/dist/components/PhotoCarousel/PhotoCarousel.stories.svelte.d.ts +0 -29
- package/dist/components/PhotoCarousel/PhotoCarousel.svelte +0 -202
- package/dist/components/PhotoCarousel/PhotoCarousel.svelte.d.ts +0 -78
- package/dist/components/PhotoCarousel/stories/docs/component.md +0 -21
- package/dist/components/PhotoCarousel/stories/docs/withCustom.md +0 -27
- package/dist/components/PhotoCarousel/stories/photos.json +0 -72
- package/dist/components/PhotoPack/stories/docs/archieML.md +0 -63
- package/dist/components/PhotoPack/stories/docs/component.md +0 -45
- package/dist/components/PhotoPack/stories/docs/missingAltText.md +0 -1
- package/dist/components/PymChild/stores.d.ts +0 -1
- package/dist/components/PymChild/stores.js +0 -3
- package/dist/components/PymChild/stories/docs/component.md +0 -28
- package/dist/components/ReferralBlock/stories/docs/collection.md +0 -7
- package/dist/components/ReferralBlock/stories/docs/component.md +0 -15
- package/dist/components/ReutersGraphicsLogo/stories/docs/component.md +0 -11
- package/dist/components/ReutersLogo/stories/docs/component.md +0 -9
- package/dist/components/SEO/stories/docs/archieML.md +0 -36
- package/dist/components/SEO/stories/docs/component.md +0 -26
- package/dist/components/Scroller/stories/components/ai2svelte/ai-scroller-1.svelte.d.ts +0 -25
- package/dist/components/Scroller/stories/components/ai2svelte/ai-scroller-2.svelte.d.ts +0 -25
- package/dist/components/Scroller/stories/components/ai2svelte/ai-scroller-3.svelte.d.ts +0 -25
- package/dist/components/Scroller/stories/components/basic/InteractiveForeground.svelte +0 -13
- package/dist/components/Scroller/stories/components/basic/InteractiveForeground.svelte.d.ts +0 -25
- package/dist/components/Scroller/stories/components/basic/Step.svelte +0 -12
- package/dist/components/Scroller/stories/components/basic/Step.svelte.d.ts +0 -25
- package/dist/components/Scroller/stories/docs/ai2svelte.md +0 -42
- package/dist/components/Scroller/stories/docs/archieML.md +0 -87
- package/dist/components/Scroller/stories/docs/component.md +0 -39
- package/dist/components/Scroller/stories/docs/interactive.md +0 -36
- package/dist/components/SearchInput/MagnifyingGlass.svelte.d.ts +0 -25
- package/dist/components/SearchInput/X.svelte.d.ts +0 -25
- package/dist/components/SearchInput/stories/docs/component.md +0 -17
- package/dist/components/SimpleTimeline/stories/docs/component.md +0 -24
- package/dist/components/SiteFooter/stories/docs/component.md +0 -11
- package/dist/components/SiteFooter/stories/docs/darkTheme.md +0 -11
- package/dist/components/SiteFooter/stories/docs/removeReferrals.md +0 -9
- package/dist/components/SiteHeader/stories/docs/component.md +0 -11
- package/dist/components/SiteHeader/stories/docs/darkTheme.md +0 -11
- package/dist/components/SiteHeadline/stories/docs/archieML.md +0 -26
- package/dist/components/SiteHeadline/stories/docs/component.md +0 -21
- package/dist/components/Spinner/stories/docs/component.md +0 -15
- package/dist/components/Table/LeftArrow.svelte.d.ts +0 -25
- package/dist/components/Table/Pagination.svelte.d.ts +0 -33
- package/dist/components/Table/RightArrow.svelte.d.ts +0 -25
- package/dist/components/Table/Select.svelte.d.ts +0 -28
- package/dist/components/Table/SortArrow.svelte.d.ts +0 -22
- package/dist/components/Table/stories/docs/both.md +0 -13
- package/dist/components/Table/stories/docs/component.md +0 -14
- package/dist/components/Table/stories/docs/filter.md +0 -11
- package/dist/components/Table/stories/docs/format.md +0 -21
- package/dist/components/Table/stories/docs/metadata.md +0 -14
- package/dist/components/Table/stories/docs/paginate.md +0 -14
- package/dist/components/Table/stories/docs/search.md +0 -11
- package/dist/components/Table/stories/docs/sort.md +0 -14
- package/dist/components/Table/stories/docs/style.md +0 -23
- package/dist/components/Table/stories/docs/truncate.md +0 -11
- package/dist/components/Theme/stories/ThemedPage.svelte +0 -43
- package/dist/components/Theme/stories/ThemedPage.svelte.d.ts +0 -25
- package/dist/components/Theme/stories/docs/component.md +0 -15
- package/dist/components/Theme/stories/docs/customise-font.md +0 -52
- package/dist/components/Theme/stories/docs/customise.md +0 -28
- package/dist/components/Theme/stories/docs/gfonts.png +0 -0
- package/dist/components/Theme/stories/docs/inheritance.md +0 -17
- package/dist/components/Theme/stories/docs/pattern.md +0 -40
- package/dist/components/ToolsHeader/stories/docs/component.md +0 -13
- package/dist/components/Video/Controls.svelte +0 -75
- package/dist/components/Video/Controls.svelte.d.ts +0 -47
- package/dist/components/Video/docs.svx +0 -275
- package/dist/components/Video/stories/docs/component.md +0 -15
- package/dist/components/Video/stories/docs/controls.md +0 -38
- package/dist/components/Video/stories/docs/playAndLoop.md +0 -28
- package/dist/components/Video/stories/docs/withSound.md +0 -36
- package/dist/components/Visible/stories/docs/component.md +0 -19
- package/dist/components/Visible/stories/snippets/default.svelte +0 -11
- package/dist/components/Visible/stories/snippets/default.svelte.d.ts +0 -25
- package/dist/docs/contributing/story-recipes/basic-story.mdx +0 -77
- package/dist/docs/contributing/story-recipes/source-code.png +0 -0
- package/dist/docs/contributing/story-recipes/story-with-custom-controls.mdx +0 -46
- package/dist/docs/contributing/story-recipes/story-with-custom-docs.mdx +0 -130
- package/dist/docs/contributing/story-recipes/story-with-media.mdx +0 -50
- package/dist/docs/contributing/writing-docs-stories.mdx +0 -35
- package/dist/docs/utils/withParams.d.ts +0 -15
- package/dist/docs/utils/withParams.js +0 -46
- /package/dist/components/BeforeAfter/{stories → images}/myrne-after.jpg +0 -0
- /package/dist/components/BeforeAfter/{stories → images}/myrne-before.jpg +0 -0
- /package/dist/components/FeaturePhoto/{stories → images}/shark.jpg +0 -0
- /package/dist/components/GraphicBlock/{stories → demo}/imgs/ai-chart-md.png +0 -0
- /package/dist/components/GraphicBlock/{stories → demo}/imgs/ai-chart-sm.png +0 -0
- /package/dist/components/GraphicBlock/{stories → demo}/imgs/ai-chart-xs.png +0 -0
- /package/dist/components/GraphicBlock/{stories → demo}/placeholder.png +0 -0
- /package/dist/components/Headline/{stories → demo}/crown.png +0 -0
- /package/dist/components/Headline/{stories → demo}/graphic-lg.png +0 -0
- /package/dist/components/Headline/{stories → demo}/graphic-md.png +0 -0
- /package/dist/components/Headline/{stories → demo}/graphic-sm.png +0 -0
- /package/dist/components/Headline/{stories → demo}/graphic-xl.png +0 -0
- /package/dist/components/Headline/{stories → demo}/graphic-xs.png +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/eurovis.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/CRASH_1-lg.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/CRASH_1-md.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/CRASH_1-sm.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/CRASH_1-xl.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/CRASH_1-xl_copy.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/CRASH_1-xs.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/quake-map-top-lg.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/quake-map-top-md.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/quake-map-top-sm.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/quake-map-top-xl.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/graphics/quake-map-top-xs.jpeg +0 -0
- /package/dist/components/HeroHeadline/{stories → demo}/polar.jpg +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-1-lg.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-1-md.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-1-sm.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-1-xl.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-1-xs.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-2-lg.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-2-md.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-2-sm.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-2-xl.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-2-xs.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-3-lg.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-3-md.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-3-sm.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-3-xl.png +0 -0
- /package/dist/components/Scroller/{stories → demo}/components/ai2svelte/images/step-3-xs.png +0 -0
- /package/dist/components/SearchInput/{MagnifyingGlass.svelte → components/MagnifyingGlass.svelte} +0 -0
- /package/dist/components/SearchInput/{X.svelte → components/X.svelte} +0 -0
- /package/dist/components/Table/{LeftArrow.svelte → components/LeftArrow.svelte} +0 -0
- /package/dist/components/Table/{RightArrow.svelte → components/RightArrow.svelte} +0 -0
- /package/dist/components/Table/{stories → demo}/homeRuns.json +0 -0
- /package/dist/components/Table/{stories → demo}/pressFreedom.json +0 -0
- /package/dist/components/Table/{stories → demo}/richestWomen.json +0 -0
- /package/dist/components/Video/{stories/videos → demo}/silent-video.mp4 +0 -0
- /package/dist/components/Video/{stories/videos → demo}/sound-video.mp4 +0 -0
|
@@ -1,45 +1,105 @@
|
|
|
1
1
|
<!-- @component `Byline` [Read the docs.](https://reuters-graphics.github.io/graphics-components/?path=/docs/components-text-elements-byline--docs) -->
|
|
2
|
-
<script
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
2
|
+
<script lang="ts">
|
|
3
|
+
import { getAuthorPageUrl } from '../../utils';
|
|
4
|
+
import Block from '../Block/Block.svelte';
|
|
5
|
+
import { apdate } from 'journalize';
|
|
6
|
+
import type { Snippet } from 'svelte';
|
|
7
|
+
|
|
8
|
+
interface Props {
|
|
9
|
+
/**
|
|
10
|
+
* Array of author names, which will be slugified to create links to Reuters author pages
|
|
11
|
+
*/
|
|
12
|
+
authors?: string[];
|
|
13
|
+
/**
|
|
14
|
+
* Publish time as a datetime string.
|
|
15
|
+
*/
|
|
16
|
+
publishTime: string;
|
|
17
|
+
/**
|
|
18
|
+
* Update time as a datetime string.
|
|
19
|
+
*/
|
|
20
|
+
updateTime?: string;
|
|
21
|
+
/**
|
|
22
|
+
* Alignment of the byline.
|
|
23
|
+
*/
|
|
24
|
+
align?: 'left' | 'center';
|
|
25
|
+
/**
|
|
26
|
+
* Add an id to to target with custom CSS.
|
|
27
|
+
* @type {string}
|
|
28
|
+
*/
|
|
29
|
+
id?: string;
|
|
30
|
+
/**
|
|
31
|
+
* Add extra classes to target with custom CSS.
|
|
32
|
+
* @type {string}
|
|
33
|
+
*/
|
|
34
|
+
cls?: string;
|
|
35
|
+
/**
|
|
36
|
+
* Custom function that returns an author page URL.
|
|
37
|
+
*/
|
|
38
|
+
getAuthorPage?: (author: string) => string;
|
|
39
|
+
/**
|
|
40
|
+
* Optional snippet for a custom byline.
|
|
41
|
+
*/
|
|
42
|
+
byline?: Snippet;
|
|
43
|
+
/**
|
|
44
|
+
* Optional snippet for a custom published dateline.
|
|
45
|
+
*/
|
|
46
|
+
published?: Snippet;
|
|
47
|
+
/**
|
|
48
|
+
* Optional snippet for a custom updated dateline.
|
|
49
|
+
*/
|
|
50
|
+
updated?: Snippet;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
let {
|
|
54
|
+
authors = [],
|
|
55
|
+
publishTime,
|
|
56
|
+
updateTime,
|
|
57
|
+
align = 'left',
|
|
58
|
+
id = '',
|
|
59
|
+
cls = '',
|
|
60
|
+
getAuthorPage = getAuthorPageUrl,
|
|
61
|
+
byline,
|
|
62
|
+
published,
|
|
63
|
+
updated,
|
|
64
|
+
}: Props = $props();
|
|
65
|
+
|
|
66
|
+
let alignmentClass = $derived(align === 'left' ? 'text-left' : 'text-center');
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
/* Date validation and formatter functions
|
|
70
|
+
*/
|
|
71
|
+
const isValidDate = (datetime: string) => {
|
|
72
|
+
if (!datetime) return false;
|
|
73
|
+
if (!Date.parse(datetime)) return false;
|
|
74
|
+
return true;
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
const formatTime = (datetime: string) =>
|
|
78
|
+
new Date(datetime).toLocaleTimeString([], {
|
|
79
|
+
hour: '2-digit',
|
|
80
|
+
minute: '2-digit',
|
|
81
|
+
timeZoneName: 'short',
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
const areSameDay = (first: Date, second: Date) =>
|
|
85
|
+
first.getFullYear() === second.getFullYear() &&
|
|
86
|
+
first.getMonth() === second.getMonth() &&
|
|
87
|
+
first.getDate() === second.getDate();
|
|
28
88
|
</script>
|
|
29
89
|
|
|
30
90
|
<Block {id} class="byline-container {alignmentClass} {cls}" width="normal">
|
|
31
91
|
<aside class="article-metadata font-subhed">
|
|
32
92
|
<div class="byline body-caption fmb-1">
|
|
33
|
-
{#if
|
|
93
|
+
{#if byline}
|
|
34
94
|
<!-- Custom byline -->
|
|
35
|
-
|
|
95
|
+
{@render byline()}
|
|
36
96
|
{:else}
|
|
37
97
|
By
|
|
38
98
|
{#if authors.length > 0}
|
|
39
99
|
{#each authors as author, i}
|
|
40
100
|
<a
|
|
41
101
|
class="no-underline whitespace-nowrap text-primary font-bold"
|
|
42
|
-
href=
|
|
102
|
+
href={getAuthorPage(author)}
|
|
43
103
|
rel="author"
|
|
44
104
|
>
|
|
45
105
|
{author.trim()}</a
|
|
@@ -56,16 +116,18 @@ const areSameDay = (first, second) => first.getFullYear() === second.getFullYear
|
|
|
56
116
|
{/if}
|
|
57
117
|
</div>
|
|
58
118
|
<div class="dateline body-caption fmt-0">
|
|
59
|
-
{#if
|
|
119
|
+
{#if published}
|
|
60
120
|
<div class="whitespace-nowrap inline-block">
|
|
61
|
-
<!-- Custom published dateline -->
|
|
62
|
-
<
|
|
121
|
+
<!-- Custom published dateline snippet -->
|
|
122
|
+
<time datetime={publishTime}>
|
|
123
|
+
{@render published()}
|
|
124
|
+
</time>
|
|
63
125
|
</div>
|
|
64
126
|
{:else if isValidDate(publishTime)}
|
|
65
127
|
<div class="whitespace-nowrap inline-block">
|
|
66
128
|
Published
|
|
67
|
-
<time datetime=
|
|
68
|
-
{#if isValidDate(updateTime)}
|
|
129
|
+
<time datetime={publishTime}>
|
|
130
|
+
{#if updateTime && isValidDate(updateTime)}
|
|
69
131
|
{apdate(new Date(publishTime))}
|
|
70
132
|
{:else}
|
|
71
133
|
{apdate(new Date(publishTime))} {formatTime(
|
|
@@ -75,19 +137,23 @@ const areSameDay = (first, second) => first.getFullYear() === second.getFullYear
|
|
|
75
137
|
</time>
|
|
76
138
|
</div>
|
|
77
139
|
{/if}
|
|
78
|
-
{#if
|
|
140
|
+
{#if updated}
|
|
79
141
|
<div class="whitespace-nowrap inline-block">
|
|
80
|
-
<!-- Custom updated dateline -->
|
|
81
|
-
<
|
|
142
|
+
<!-- Custom updated dateline snippet -->
|
|
143
|
+
<time datetime={updateTime}>
|
|
144
|
+
{@render updated()}
|
|
145
|
+
</time>
|
|
82
146
|
</div>
|
|
83
|
-
{:else if isValidDate(publishTime) && isValidDate(updateTime)}
|
|
147
|
+
{:else if isValidDate(publishTime) && isValidDate(updateTime || '')}
|
|
84
148
|
<div class="whitespace-nowrap inline-block">
|
|
85
149
|
Last updated
|
|
86
|
-
<time datetime=
|
|
87
|
-
{#if areSameDay(new Date(publishTime), new Date(updateTime))}
|
|
88
|
-
{formatTime(updateTime)}
|
|
150
|
+
<time datetime={updateTime}>
|
|
151
|
+
{#if areSameDay(new Date(publishTime), new Date(updateTime || new Date()))}
|
|
152
|
+
{formatTime(updateTime || '')}
|
|
89
153
|
{:else}
|
|
90
|
-
{apdate(
|
|
154
|
+
{apdate(
|
|
155
|
+
new Date(updateTime || new Date())
|
|
156
|
+
)} {formatTime(updateTime || '')}
|
|
91
157
|
{/if}
|
|
92
158
|
</time>
|
|
93
159
|
</div>
|
|
@@ -104,7 +170,7 @@ https://utopia.fyi/space/calculator/?c=320,18,1.125,1280,21,1.25,7,3,&s=0.75|0.5
|
|
|
104
170
|
https://utopia.fyi/space/calculator/?c=320,18,1.125,1280,21,1.25,7,3,&s=0.75|0.5|0.25,1.5|2|3|4|6,s-l&g=s,l,xl,12
|
|
105
171
|
*/
|
|
106
172
|
/* Scales by 1.125 */
|
|
107
|
-
.byline
|
|
173
|
+
.byline a:hover {
|
|
108
174
|
text-decoration-line: underline;
|
|
109
175
|
}
|
|
110
176
|
|
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
export type BylineSlots = typeof __propDef.slots;
|
|
46
|
-
/** `Byline` [Read the docs.](https://reuters-graphics.github.io/graphics-components/?path=/docs/components-text-elements-byline--docs) */
|
|
47
|
-
export default class Byline extends SvelteComponent<BylineProps, BylineEvents, BylineSlots> {
|
|
1
|
+
import type { Snippet } from 'svelte';
|
|
2
|
+
interface Props {
|
|
3
|
+
/**
|
|
4
|
+
* Array of author names, which will be slugified to create links to Reuters author pages
|
|
5
|
+
*/
|
|
6
|
+
authors?: string[];
|
|
7
|
+
/**
|
|
8
|
+
* Publish time as a datetime string.
|
|
9
|
+
*/
|
|
10
|
+
publishTime: string;
|
|
11
|
+
/**
|
|
12
|
+
* Update time as a datetime string.
|
|
13
|
+
*/
|
|
14
|
+
updateTime?: string;
|
|
15
|
+
/**
|
|
16
|
+
* Alignment of the byline.
|
|
17
|
+
*/
|
|
18
|
+
align?: 'left' | 'center';
|
|
19
|
+
/**
|
|
20
|
+
* Add an id to to target with custom CSS.
|
|
21
|
+
* @type {string}
|
|
22
|
+
*/
|
|
23
|
+
id?: string;
|
|
24
|
+
/**
|
|
25
|
+
* Add extra classes to target with custom CSS.
|
|
26
|
+
* @type {string}
|
|
27
|
+
*/
|
|
28
|
+
cls?: string;
|
|
29
|
+
/**
|
|
30
|
+
* Custom function that returns an author page URL.
|
|
31
|
+
*/
|
|
32
|
+
getAuthorPage?: (author: string) => string;
|
|
33
|
+
/**
|
|
34
|
+
* Optional snippet for a custom byline.
|
|
35
|
+
*/
|
|
36
|
+
byline?: Snippet;
|
|
37
|
+
/**
|
|
38
|
+
* Optional snippet for a custom published dateline.
|
|
39
|
+
*/
|
|
40
|
+
published?: Snippet;
|
|
41
|
+
/**
|
|
42
|
+
* Optional snippet for a custom updated dateline.
|
|
43
|
+
*/
|
|
44
|
+
updated?: Snippet;
|
|
48
45
|
}
|
|
49
|
-
|
|
46
|
+
/** `Byline` [Read the docs.](https://reuters-graphics.github.io/graphics-components/?path=/docs/components-text-elements-byline--docs) */
|
|
47
|
+
declare const Byline: import("svelte").Component<Props, {}, "">;
|
|
48
|
+
type Byline = ReturnType<typeof Byline>;
|
|
49
|
+
export default Byline;
|
|
@@ -1,3 +1,11 @@
|
|
|
1
|
+
import { Meta, Canvas } from '@storybook/blocks';
|
|
2
|
+
|
|
3
|
+
import * as DatawrapperChartStories from './DatawrapperChart.stories.svelte';
|
|
4
|
+
|
|
5
|
+
<Meta of={DatawrapperChartStories} />
|
|
6
|
+
|
|
7
|
+
# DatawrapperChart
|
|
8
|
+
|
|
1
9
|
Easily add a responsive Datawrapper embed on your page.
|
|
2
10
|
|
|
3
11
|
```svelte
|
|
@@ -23,3 +31,15 @@ You can get this from the published url on Reuters Graphics.
|
|
|
23
31
|
- Inside **Embed code (for developers only)**, find and copy the url inside the `src` prop. (It ends in `media-embed.html`.)
|
|
24
32
|
|
|
25
33
|
**Note:** There is no need to update the url if you update the chart inside Datawrapper. Any changes will be automatically reflected.
|
|
34
|
+
|
|
35
|
+
<Canvas of={DatawrapperChartStories.Demo} />
|
|
36
|
+
|
|
37
|
+
## With chatter
|
|
38
|
+
|
|
39
|
+
By default, Datawrapper will export your chart with the chart chatter like title, description and notes.
|
|
40
|
+
|
|
41
|
+
At the moment, these don't _exactly_ match our styles and can't be made to fit into the article well.
|
|
42
|
+
|
|
43
|
+
Instead, it's often better to remove all the text from your Datawrapper chart before publishing it and add that text back via the component props.
|
|
44
|
+
|
|
45
|
+
<Canvas of={DatawrapperChartStories.WithChatter} />
|
|
@@ -1,49 +1,41 @@
|
|
|
1
|
-
<script
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
withComponentDocs,
|
|
6
|
-
withStoryDocs
|
|
7
|
-
} from "../../lib/docs/utils/withParams.js";
|
|
8
|
-
export const meta = {
|
|
9
|
-
title: "Components/Graphics/DatawrapperChart",
|
|
10
|
-
component: DatawrapperChart,
|
|
11
|
-
...withComponentDocs(componentDocs),
|
|
12
|
-
argTypes: {
|
|
13
|
-
width: {
|
|
14
|
-
control: "select",
|
|
15
|
-
options: ["normal", "wide", "wider", "widest", "fluid"]
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
};
|
|
19
|
-
</script>
|
|
1
|
+
<script module lang="ts">
|
|
2
|
+
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
3
|
+
import DatawrapperChart from './DatawrapperChart.svelte';
|
|
20
4
|
|
|
21
|
-
|
|
22
|
-
|
|
5
|
+
const { Story } = defineMeta({
|
|
6
|
+
title: 'Components/Graphics/DatawrapperChart',
|
|
7
|
+
component: DatawrapperChart,
|
|
8
|
+
tags: ['autodocs'],
|
|
9
|
+
argTypes: {
|
|
10
|
+
width: {
|
|
11
|
+
control: 'select',
|
|
12
|
+
options: ['normal', 'wide', 'wider', 'widest', 'fluid'],
|
|
13
|
+
},
|
|
14
|
+
},
|
|
15
|
+
});
|
|
23
16
|
</script>
|
|
24
17
|
|
|
25
|
-
<Template let:args>
|
|
26
|
-
<DatawrapperChart {...args} />
|
|
27
|
-
</Template>
|
|
28
|
-
|
|
29
18
|
<Story
|
|
30
|
-
name="
|
|
31
|
-
args=
|
|
19
|
+
name="Demo"
|
|
20
|
+
args={{
|
|
32
21
|
src: 'https://reuters.com/graphics/USA-ABORTION/lgpdwggnwvo/media-embed.html',
|
|
33
22
|
id: 'abortion-rights-map',
|
|
34
23
|
ariaLabel: 'map',
|
|
35
24
|
frameTitle: 'Global abortion access',
|
|
36
|
-
}}
|
|
25
|
+
}}
|
|
37
26
|
/>
|
|
38
27
|
|
|
39
|
-
<Story
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
28
|
+
<Story
|
|
29
|
+
name="With chatter"
|
|
30
|
+
tags={['!autodocs']}
|
|
31
|
+
args={{
|
|
32
|
+
frameTitle: 'Global abortion access',
|
|
33
|
+
ariaLabel: 'map',
|
|
34
|
+
id: 'abortion-rights-map',
|
|
35
|
+
src: 'https://reuters.com/graphics/USA-ABORTION/lgvdwemlbpo/media-embed.html',
|
|
36
|
+
title: 'Global abortion access',
|
|
37
|
+
description: 'A map of worldwide access to abortion.',
|
|
38
|
+
notes:
|
|
39
|
+
'Note: Different indicators and additional restrictions, including different gestational limits, apply in some countries. Refer to source for full classification. Current as of May 4, 2022.\n\nSource: Center for Reproductive Rights',
|
|
40
|
+
}}
|
|
41
|
+
/>
|
|
@@ -1,29 +1,19 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
import DatawrapperChart from './DatawrapperChart.svelte';
|
|
2
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
3
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
4
|
+
$$bindings?: Bindings;
|
|
5
|
+
} & Exports;
|
|
6
|
+
(internal: unknown, props: {
|
|
7
|
+
$$events?: Events;
|
|
8
|
+
$$slots?: Slots;
|
|
9
|
+
}): Exports & {
|
|
10
|
+
$set?: any;
|
|
11
|
+
$on?: any;
|
|
8
12
|
};
|
|
9
|
-
|
|
10
|
-
docs: any;
|
|
11
|
-
};
|
|
12
|
-
title: string;
|
|
13
|
-
component: typeof DatawrapperChart;
|
|
14
|
-
};
|
|
15
|
-
declare const __propDef: {
|
|
16
|
-
props: Record<string, never>;
|
|
17
|
-
events: {
|
|
18
|
-
[evt: string]: CustomEvent<any>;
|
|
19
|
-
};
|
|
20
|
-
slots: {};
|
|
21
|
-
exports?: {} | undefined;
|
|
22
|
-
bindings?: string | undefined;
|
|
23
|
-
};
|
|
24
|
-
export type DatawrapperChartProps = typeof __propDef.props;
|
|
25
|
-
export type DatawrapperChartEvents = typeof __propDef.events;
|
|
26
|
-
export type DatawrapperChartSlots = typeof __propDef.slots;
|
|
27
|
-
export default class DatawrapperChart extends SvelteComponent<DatawrapperChartProps, DatawrapperChartEvents, DatawrapperChartSlots> {
|
|
13
|
+
z_$$bindings?: Bindings;
|
|
28
14
|
}
|
|
29
|
-
|
|
15
|
+
declare const DatawrapperChart: $$__sveltets_2_IsomorphicComponent<Record<string, never>, {
|
|
16
|
+
[evt: string]: CustomEvent<any>;
|
|
17
|
+
}, {}, {}, string>;
|
|
18
|
+
type DatawrapperChart = InstanceType<typeof DatawrapperChart>;
|
|
19
|
+
export default DatawrapperChart;
|
|
@@ -1,52 +1,107 @@
|
|
|
1
1
|
<!-- @component `DatawrapperChart` [Read the docs.](https://reuters-graphics.github.io/graphics-components/?path=/docs/components-graphics-datawrapperchart--docs) -->
|
|
2
|
-
<script
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
2
|
+
<script lang="ts">
|
|
3
|
+
import { onMount, onDestroy, type Snippet } from 'svelte';
|
|
4
|
+
import GraphicBlock from '../GraphicBlock/GraphicBlock.svelte';
|
|
5
|
+
import type { ContainerWidth } from '../@types/global';
|
|
6
|
+
|
|
7
|
+
type ScrollingOption = 'auto' | 'yes' | 'no';
|
|
8
|
+
|
|
9
|
+
interface Props {
|
|
10
|
+
/** Title of the graphic */
|
|
11
|
+
title?: string;
|
|
12
|
+
/** Description of the graphic, passed in as a markdown string. */
|
|
13
|
+
description?: string;
|
|
14
|
+
/**
|
|
15
|
+
* iframe title
|
|
16
|
+
*/
|
|
17
|
+
frameTitle: string;
|
|
18
|
+
/**
|
|
19
|
+
* Notes to the graphic, passed in as a markdown string.
|
|
20
|
+
*/
|
|
21
|
+
notes?: string;
|
|
22
|
+
/**
|
|
23
|
+
* iframe aria label
|
|
24
|
+
*/
|
|
25
|
+
ariaLabel: string;
|
|
26
|
+
/*
|
|
27
|
+
* iframe id
|
|
28
|
+
*/
|
|
29
|
+
id: string;
|
|
30
|
+
/**
|
|
31
|
+
* Datawrapper embed URL
|
|
32
|
+
*/
|
|
33
|
+
src: string;
|
|
34
|
+
/** iframe scrolling option */
|
|
35
|
+
scrolling: ScrollingOption;
|
|
36
|
+
/** Width of the chart within the text well. */
|
|
37
|
+
width: ContainerWidth;
|
|
38
|
+
/**
|
|
39
|
+
* Set a different width for the text within the text well, for example,
|
|
40
|
+
* "normal" to keep the title, description and notes inline with the rest
|
|
41
|
+
* of the text well. Can't ever be wider than `width`.
|
|
42
|
+
*/
|
|
43
|
+
textWidth: ContainerWidth;
|
|
44
|
+
/** Custom headline and chatter snippet */
|
|
45
|
+
titleSnippet?: Snippet;
|
|
46
|
+
/** Custom notes and source snippet */
|
|
47
|
+
notesSnippet?: Snippet;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
let {
|
|
51
|
+
title,
|
|
52
|
+
description,
|
|
53
|
+
frameTitle = '',
|
|
54
|
+
notes,
|
|
55
|
+
ariaLabel = '',
|
|
56
|
+
id = '',
|
|
57
|
+
src,
|
|
58
|
+
scrolling = 'no',
|
|
59
|
+
width = 'normal',
|
|
60
|
+
textWidth = 'normal',
|
|
61
|
+
titleSnippet,
|
|
62
|
+
notesSnippet,
|
|
63
|
+
}: Props = $props();
|
|
64
|
+
|
|
65
|
+
let frameElement: HTMLElement;
|
|
66
|
+
|
|
67
|
+
// eslint-disable-next-line
|
|
68
|
+
const frameFiller = (e: any) => {
|
|
69
|
+
if (void 0 !== e.data['datawrapper-height']) {
|
|
70
|
+
const t = [frameElement];
|
|
71
|
+
for (const a in e.data['datawrapper-height']) {
|
|
72
|
+
for (let r = 0; r < t.length; r++) {
|
|
73
|
+
// @ts-ignore OK here
|
|
74
|
+
if (t[r].contentWindow === e.source) {
|
|
75
|
+
t[r].style.height = e.data['datawrapper-height'][a] + 'px';
|
|
76
|
+
}
|
|
22
77
|
}
|
|
23
78
|
}
|
|
24
79
|
}
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
onMount(() => {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
});
|
|
32
|
-
onDestroy(() => {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
});
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
onMount(() => {
|
|
83
|
+
if (typeof window !== 'undefined') {
|
|
84
|
+
window.addEventListener('message', frameFiller);
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
onDestroy(() => {
|
|
88
|
+
if (typeof window !== 'undefined') {
|
|
89
|
+
window.removeEventListener('message', frameFiller);
|
|
90
|
+
}
|
|
91
|
+
});
|
|
37
92
|
</script>
|
|
38
93
|
|
|
39
94
|
<GraphicBlock {width} {textWidth} {title} {description} {notes}>
|
|
40
|
-
{#if
|
|
95
|
+
{#if titleSnippet}
|
|
41
96
|
<!-- Custom headline and chatter slot -->
|
|
42
|
-
|
|
97
|
+
{@render titleSnippet()}
|
|
43
98
|
{/if}
|
|
44
99
|
|
|
45
100
|
<div class="datawrapper-chart">
|
|
46
101
|
<iframe
|
|
47
|
-
bind:this=
|
|
48
|
-
title=
|
|
49
|
-
aria-label=
|
|
102
|
+
bind:this={frameElement}
|
|
103
|
+
title={frameTitle}
|
|
104
|
+
aria-label={ariaLabel}
|
|
50
105
|
{id}
|
|
51
106
|
{src}
|
|
52
107
|
{scrolling}
|
|
@@ -56,8 +111,7 @@ onDestroy(() => {
|
|
|
56
111
|
></iframe>
|
|
57
112
|
</div>
|
|
58
113
|
|
|
59
|
-
{#if
|
|
60
|
-
|
|
61
|
-
<slot name="notes" />
|
|
114
|
+
{#if notesSnippet}
|
|
115
|
+
{@render notesSnippet()}
|
|
62
116
|
{/if}
|
|
63
117
|
</GraphicBlock>
|