@reykjavik/hanna-react 0.10.55 → 0.10.56
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/AccordionList.jsx +61 -0
- package/ActionCards.jsx +15 -0
- package/Alert.jsx +123 -0
- package/ArticleCarousel/_ArticleCarouselCard.d.ts +1 -1
- package/ArticleCarousel/_ArticleCarouselCard.jsx +32 -0
- package/ArticleCarousel.jsx +13 -0
- package/ArticleMeta.jsx +42 -0
- package/Attention.jsx +9 -0
- package/BasicTable.jsx +35 -0
- package/Bling.jsx +49 -0
- package/BlockBreak.jsx +11 -0
- package/BlockQuote.jsx +9 -0
- package/BreadCrumbs.jsx +36 -0
- package/ButtonBack.jsx +9 -0
- package/ButtonBar.jsx +23 -0
- package/ButtonPrimary.jsx +9 -0
- package/ButtonSecondary.jsx +9 -0
- package/ButtonTertiary.jsx +20 -0
- package/CHANGELOG.md +13 -5
- package/Carousel.jsx +9 -0
- package/CarouselStepper.jsx +9 -0
- package/CenterColumn.jsx +14 -0
- package/Checkbox.jsx +9 -0
- package/CheckboxButtonsGroup.jsx +19 -0
- package/CheckboxGroup.jsx +12 -0
- package/CityBlock.jsx +23 -0
- package/ContactBubble.jsx +192 -0
- package/ContentArticle.jsx +29 -0
- package/ContentImage.jsx +18 -0
- package/Datepicker.jsx +92 -0
- package/ExtraLinks.jsx +47 -0
- package/FeatureList.jsx +28 -0
- package/FieldGroup.jsx +15 -0
- package/FileInput.jsx +185 -0
- package/Foonote.jsx +12 -0
- package/FooterBadges.jsx +21 -0
- package/FooterInfo.jsx +19 -0
- package/Footnote.jsx +8 -0
- package/Form.jsx +17 -0
- package/FormField.jsx +121 -0
- package/Gallery/_GalleryItem.jsx +59 -0
- package/Gallery/_GalleryModal.jsx +86 -0
- package/Gallery/_GalleryModalContext.js +8 -0
- package/Gallery/_GalleryModalItem.jsx +29 -0
- package/Gallery.jsx +56 -0
- package/GridBlocks.jsx +40 -0
- package/Heading.jsx +24 -0
- package/HeroBlock.jsx +27 -0
- package/IframeBlock.jsx +31 -0
- package/Illustration.jsx +13 -0
- package/ImageCards.jsx +28 -0
- package/InfoBlock.jsx +23 -0
- package/InfoHero.jsx +93 -0
- package/IslandBlock.jsx +21 -0
- package/IslandPageBlock.jsx +21 -0
- package/LabeledTextBlock.jsx +21 -0
- package/Layout.jsx +69 -0
- package/MainMenu/_Auxiliary.jsx +26 -0
- package/MainMenu/_PrimaryPanel.jsx +37 -0
- package/MainMenu.d.ts +1 -1
- package/MainMenu.jsx +178 -0
- package/MiniMetrics.jsx +16 -0
- package/Modal.jsx +21 -0
- package/NameCard.jsx +92 -0
- package/NameCards.jsx +14 -0
- package/NewsHero.jsx +93 -0
- package/PageFilter.jsx +21 -0
- package/PageHeading.jsx +19 -0
- package/ProcessOverview.jsx +25 -0
- package/PullQuote.jsx +9 -0
- package/RadioButtonsGroup.jsx +19 -0
- package/RadioGroup.jsx +12 -0
- package/RelatedLinks.jsx +35 -0
- package/RowBlock.jsx +16 -0
- package/RowBlockColumn.jsx +18 -0
- package/SearchInput.jsx +63 -0
- package/SearchResults/_SearchResultsItem.jsx +24 -0
- package/SearchResults.jsx +146 -0
- package/SeenEffect.jsx +24 -0
- package/Selectbox.jsx +74 -0
- package/ShareButtons.jsx +82 -0
- package/Sharpie.jsx +27 -0
- package/SiteSearchAutocomplete.jsx +89 -0
- package/SiteSearchCurtain.jsx +65 -0
- package/SiteSearchInput.d.ts +1 -1
- package/SiteSearchInput.jsx +70 -0
- package/Skeleton.jsx +35 -0
- package/SubHeading.jsx +20 -0
- package/Tabs.jsx +122 -0
- package/TagPill.jsx +53 -0
- package/TextBlock.jsx +22 -0
- package/TextButton.jsx +14 -0
- package/TextInput.jsx +63 -0
- package/VSpacer.jsx +46 -0
- package/VerticalTabsTOC.jsx +96 -0
- package/WizardLayout.jsx +44 -0
- package/WizardLayoutClose.jsx +9 -0
- package/WizardStepper.jsx +34 -0
- package/_abstract/Button.jsx +56 -0
- package/_abstract/CardList.jsx +46 -0
- package/_abstract/Image.jsx +34 -0
- package/_abstract/Link.jsx +31 -0
- package/_abstract/TogglerGroup.jsx +36 -0
- package/_abstract/TogglerGroupField.jsx +27 -0
- package/_abstract/TogglerInput.jsx +40 -0
- package/_abstract/_AbstractCarousel.jsx +161 -0
- package/_abstract/_Blings.jsx +19 -0
- package/_abstract/_Block.jsx +32 -0
- package/_abstract/_Quote.jsx +18 -0
- package/_abstract/breakOnNL.jsx +13 -0
- package/assets.js +51 -0
- package/constants.js +25 -0
- package/esm/AccordionList.d.ts +17 -0
- package/esm/AccordionList.jsx +33 -0
- package/esm/ActionCards.d.ts +5 -0
- package/esm/ActionCards.jsx +10 -0
- package/esm/Alert.d.ts +49 -0
- package/esm/Alert.jsx +94 -0
- package/esm/ArticleCarousel/_ArticleCarouselCard.d.ts +27 -0
- package/esm/ArticleCarousel/_ArticleCarouselCard.jsx +25 -0
- package/esm/ArticleCarousel.d.ts +12 -0
- package/esm/ArticleCarousel.jsx +8 -0
- package/esm/ArticleMeta.d.ts +9 -0
- package/esm/ArticleMeta.jsx +17 -0
- package/esm/Attention.d.ts +7 -0
- package/esm/Attention.jsx +4 -0
- package/esm/BasicTable.d.ts +12 -0
- package/esm/BasicTable.jsx +30 -0
- package/esm/Bling.d.ts +81 -0
- package/esm/Bling.jsx +44 -0
- package/esm/BlockBreak.d.ts +2 -0
- package/esm/BlockBreak.jsx +6 -0
- package/esm/BlockQuote.d.ts +4 -0
- package/esm/BlockQuote.jsx +4 -0
- package/esm/BreadCrumbs.d.ts +11 -0
- package/esm/BreadCrumbs.jsx +31 -0
- package/esm/ButtonBack.d.ts +7 -0
- package/esm/ButtonBack.jsx +4 -0
- package/esm/ButtonBar.d.ts +16 -0
- package/esm/ButtonBar.jsx +16 -0
- package/esm/ButtonPrimary.d.ts +7 -0
- package/esm/ButtonPrimary.jsx +4 -0
- package/esm/ButtonSecondary.d.ts +7 -0
- package/esm/ButtonSecondary.jsx +4 -0
- package/esm/ButtonTertiary.d.ts +12 -0
- package/esm/ButtonTertiary.jsx +15 -0
- package/esm/Carousel.d.ts +4 -0
- package/esm/Carousel.jsx +4 -0
- package/esm/CarouselStepper.d.ts +4 -0
- package/esm/CarouselStepper.jsx +4 -0
- package/esm/CenterColumn.d.ts +7 -0
- package/esm/CenterColumn.jsx +9 -0
- package/esm/Checkbox.d.ts +4 -0
- package/esm/Checkbox.jsx +4 -0
- package/esm/CheckboxButtonsGroup.d.ts +11 -0
- package/esm/CheckboxButtonsGroup.jsx +14 -0
- package/esm/CheckboxGroup.d.ts +9 -0
- package/esm/CheckboxGroup.jsx +7 -0
- package/esm/CityBlock.d.ts +23 -0
- package/esm/CityBlock.jsx +18 -0
- package/esm/ContactBubble.d.ts +58 -0
- package/esm/ContactBubble.jsx +162 -0
- package/esm/ContentArticle.d.ts +15 -0
- package/esm/ContentArticle.jsx +24 -0
- package/esm/ContentImage.d.ts +8 -0
- package/esm/ContentImage.jsx +13 -0
- package/esm/Datepicker.d.ts +39 -0
- package/esm/Datepicker.jsx +64 -0
- package/esm/ExtraLinks.d.ts +18 -0
- package/esm/ExtraLinks.jsx +42 -0
- package/esm/FeatureList.d.ts +12 -0
- package/esm/FeatureList.jsx +23 -0
- package/esm/FieldGroup.d.ts +9 -0
- package/esm/FieldGroup.jsx +10 -0
- package/esm/FileInput.d.ts +17 -0
- package/esm/FileInput.jsx +157 -0
- package/esm/Foonote.d.ts +12 -0
- package/esm/Foonote.jsx +7 -0
- package/esm/FooterBadges.d.ts +9 -0
- package/esm/FooterBadges.jsx +16 -0
- package/esm/FooterInfo.d.ts +18 -0
- package/esm/FooterInfo.jsx +14 -0
- package/esm/Footnote.d.ts +6 -0
- package/esm/Footnote.jsx +3 -0
- package/esm/Form.d.ts +7 -0
- package/esm/Form.jsx +12 -0
- package/esm/FormField.d.ts +65 -0
- package/esm/FormField.jsx +93 -0
- package/esm/Gallery/_GalleryItem.d.ts +8 -0
- package/esm/Gallery/_GalleryItem.jsx +31 -0
- package/esm/Gallery/_GalleryModal.d.ts +6 -0
- package/esm/Gallery/_GalleryModal.jsx +58 -0
- package/esm/Gallery/_GalleryModalContext.d.ts +9 -0
- package/esm/Gallery/_GalleryModalContext.js +3 -0
- package/esm/Gallery/_GalleryModalItem.d.ts +3 -0
- package/esm/Gallery/_GalleryModalItem.jsx +24 -0
- package/esm/Gallery.d.ts +17 -0
- package/esm/Gallery.jsx +28 -0
- package/esm/GridBlocks.d.ts +26 -0
- package/esm/GridBlocks.jsx +35 -0
- package/esm/Heading.d.ts +16 -0
- package/esm/Heading.jsx +19 -0
- package/esm/HeroBlock.d.ts +19 -0
- package/esm/HeroBlock.jsx +22 -0
- package/esm/IframeBlock.d.ts +23 -0
- package/esm/IframeBlock.jsx +26 -0
- package/esm/Illustration.d.ts +13 -0
- package/esm/Illustration.jsx +8 -0
- package/esm/ImageCards.d.ts +8 -0
- package/esm/ImageCards.jsx +23 -0
- package/esm/InfoBlock.d.ts +17 -0
- package/esm/InfoBlock.jsx +18 -0
- package/esm/InfoHero.d.ts +17 -0
- package/esm/InfoHero.jsx +88 -0
- package/esm/IslandBlock.d.ts +25 -0
- package/esm/IslandBlock.jsx +16 -0
- package/esm/IslandPageBlock.d.ts +24 -0
- package/esm/IslandPageBlock.jsx +16 -0
- package/esm/LabeledTextBlock.d.ts +11 -0
- package/esm/LabeledTextBlock.jsx +16 -0
- package/esm/Layout.d.ts +33 -0
- package/esm/Layout.jsx +63 -0
- package/esm/MainMenu/_Auxiliary.d.ts +6 -0
- package/esm/MainMenu/_Auxiliary.jsx +19 -0
- package/esm/MainMenu/_PrimaryPanel.d.ts +13 -0
- package/esm/MainMenu/_PrimaryPanel.jsx +30 -0
- package/esm/MainMenu.d.ts +48 -0
- package/esm/MainMenu.jsx +149 -0
- package/esm/MiniMetrics.d.ts +8 -0
- package/esm/MiniMetrics.jsx +11 -0
- package/esm/Modal.d.ts +10 -0
- package/esm/Modal.jsx +16 -0
- package/esm/NameCard.d.ts +64 -0
- package/esm/NameCard.jsx +87 -0
- package/esm/NameCards.d.ts +6 -0
- package/esm/NameCards.jsx +9 -0
- package/esm/NewsHero.d.ts +14 -0
- package/esm/NewsHero.jsx +88 -0
- package/esm/PageFilter.d.ts +17 -0
- package/esm/PageFilter.jsx +16 -0
- package/esm/PageHeading.d.ts +10 -0
- package/esm/PageHeading.jsx +14 -0
- package/esm/ProcessOverview.d.ts +13 -0
- package/esm/ProcessOverview.jsx +20 -0
- package/esm/PullQuote.d.ts +4 -0
- package/esm/PullQuote.jsx +4 -0
- package/esm/RadioButtonsGroup.d.ts +11 -0
- package/esm/RadioButtonsGroup.jsx +14 -0
- package/esm/RadioGroup.d.ts +13 -0
- package/esm/RadioGroup.jsx +7 -0
- package/esm/RelatedLinks.d.ts +20 -0
- package/esm/RelatedLinks.jsx +30 -0
- package/esm/RowBlock.d.ts +12 -0
- package/esm/RowBlock.jsx +11 -0
- package/esm/RowBlockColumn.d.ts +8 -0
- package/esm/RowBlockColumn.jsx +13 -0
- package/esm/SearchInput.d.ts +18 -0
- package/esm/SearchInput.jsx +35 -0
- package/esm/SearchResults/_SearchResultsItem.d.ts +18 -0
- package/esm/SearchResults/_SearchResultsItem.jsx +19 -0
- package/esm/SearchResults.d.ts +33 -0
- package/esm/SearchResults.jsx +118 -0
- package/esm/SeenEffect.d.ts +4 -0
- package/esm/SeenEffect.jsx +19 -0
- package/esm/Selectbox.d.ts +8 -0
- package/esm/Selectbox.jsx +46 -0
- package/esm/ShareButtons.d.ts +9 -0
- package/esm/ShareButtons.jsx +57 -0
- package/esm/Sharpie.d.ts +23 -0
- package/esm/Sharpie.jsx +22 -0
- package/esm/SiteSearchAutocomplete.d.ts +40 -0
- package/esm/SiteSearchAutocomplete.jsx +60 -0
- package/esm/SiteSearchCurtain.d.ts +6 -0
- package/esm/SiteSearchCurtain.jsx +37 -0
- package/esm/SiteSearchInput.d.ts +24 -0
- package/esm/SiteSearchInput.jsx +42 -0
- package/esm/Skeleton.d.ts +25 -0
- package/esm/Skeleton.jsx +30 -0
- package/esm/SubHeading.d.ts +10 -0
- package/esm/SubHeading.jsx +15 -0
- package/esm/Tabs.d.ts +35 -0
- package/esm/Tabs.jsx +94 -0
- package/esm/TagPill.d.ts +27 -0
- package/esm/TagPill.jsx +48 -0
- package/esm/TextBlock.d.ts +15 -0
- package/esm/TextBlock.jsx +17 -0
- package/esm/TextButton.d.ts +9 -0
- package/esm/TextButton.jsx +9 -0
- package/esm/TextInput.d.ts +16 -0
- package/esm/TextInput.jsx +35 -0
- package/esm/VSpacer.d.ts +24 -0
- package/esm/VSpacer.jsx +41 -0
- package/esm/VerticalTabsTOC.d.ts +14 -0
- package/esm/VerticalTabsTOC.jsx +68 -0
- package/esm/WizardLayout.d.ts +15 -0
- package/esm/WizardLayout.jsx +39 -0
- package/esm/WizardLayoutClose.d.ts +3 -0
- package/esm/WizardLayoutClose.jsx +4 -0
- package/esm/WizardStepper.d.ts +36 -0
- package/esm/WizardStepper.jsx +29 -0
- package/esm/_abstract/Button.d.ts +40 -0
- package/esm/_abstract/Button.jsx +51 -0
- package/esm/_abstract/CardList.d.ts +29 -0
- package/esm/_abstract/CardList.jsx +39 -0
- package/esm/_abstract/Image.d.ts +32 -0
- package/esm/_abstract/Image.jsx +29 -0
- package/esm/_abstract/Link.d.ts +27 -0
- package/esm/_abstract/Link.jsx +24 -0
- package/esm/_abstract/TogglerGroup.d.ts +31 -0
- package/esm/_abstract/TogglerGroup.jsx +31 -0
- package/esm/_abstract/TogglerGroupField.d.ts +17 -0
- package/esm/_abstract/TogglerGroupField.jsx +22 -0
- package/esm/_abstract/TogglerInput.d.ts +22 -0
- package/esm/_abstract/TogglerInput.jsx +35 -0
- package/esm/_abstract/_AbstractCarousel.d.ts +25 -0
- package/esm/_abstract/_AbstractCarousel.jsx +133 -0
- package/esm/_abstract/_Blings.d.ts +11 -0
- package/esm/_abstract/_Blings.jsx +14 -0
- package/esm/_abstract/_Block.d.ts +22 -0
- package/esm/_abstract/_Block.jsx +27 -0
- package/esm/_abstract/_Quote.d.ts +9 -0
- package/esm/_abstract/_Quote.jsx +11 -0
- package/esm/_abstract/breakOnNL.d.ts +2 -0
- package/esm/_abstract/breakOnNL.jsx +8 -0
- package/esm/assets.d.ts +42 -0
- package/esm/assets.js +56 -0
- package/esm/constants.d.ts +39 -0
- package/esm/constants.js +22 -0
- package/esm/focus-visible.d.ts +1 -0
- package/esm/focus-visible.js +1 -0
- package/esm/package.json +1 -0
- package/esm/utils/env.d.ts +1 -0
- package/esm/utils/env.js +8 -0
- package/esm/utils/seenEffect.d.ts +28 -0
- package/esm/utils/seenEffect.js +73 -0
- package/esm/utils/useFormatMonitor.d.ts +38 -0
- package/esm/utils/useFormatMonitor.js +41 -0
- package/esm/utils/useGetSVGtext.d.ts +6 -0
- package/esm/utils/useGetSVGtext.js +19 -0
- package/esm/utils/useMenuToggling.d.ts +8 -0
- package/esm/utils/useMenuToggling.js +62 -0
- package/esm/utils/useScrollbarWidthCSSVar.d.ts +1 -0
- package/esm/utils/useScrollbarWidthCSSVar.js +3 -0
- package/esm/utils.d.ts +2 -0
- package/esm/utils.js +2 -0
- package/focus-visible.js +3 -0
- package/package.json +183 -184
- package/utils/env.js +14 -0
- package/utils/seenEffect.js +81 -0
- package/utils/useFormatMonitor.js +44 -0
- package/utils/useGetSVGtext.js +23 -0
- package/utils/useMenuToggling.js +66 -0
- package/utils/useScrollbarWidthCSSVar.js +10 -0
- package/utils.js +18 -0
- package/AccordionList.cjs +0 -91
- package/AccordionList.mjs +0 -69
- package/ActionCards.cjs +0 -57
- package/ActionCards.mjs +0 -35
- package/Alert.cjs +0 -159
- package/Alert.mjs +0 -139
- package/ArticleCarousel/_ArticleCarouselCard.cjs +0 -75
- package/ArticleCarousel/_ArticleCarouselCard.mjs +0 -51
- package/ArticleCarousel.cjs +0 -43
- package/ArticleCarousel.mjs +0 -21
- package/ArticleMeta.cjs +0 -46
- package/ArticleMeta.mjs +0 -22
- package/Attention.cjs +0 -33
- package/Attention.mjs +0 -9
- package/BasicTable.cjs +0 -72
- package/BasicTable.mjs +0 -50
- package/Bling.cjs +0 -76
- package/Bling.mjs +0 -52
- package/BlockBreak.cjs +0 -32
- package/BlockBreak.mjs +0 -8
- package/BlockQuote.cjs +0 -47
- package/BlockQuote.mjs +0 -25
- package/BreadCrumbs.cjs +0 -67
- package/BreadCrumbs.mjs +0 -43
- package/ButtonBack.cjs +0 -47
- package/ButtonBack.mjs +0 -25
- package/ButtonBar.cjs +0 -45
- package/ButtonBar.mjs +0 -18
- package/ButtonPrimary.cjs +0 -47
- package/ButtonPrimary.mjs +0 -25
- package/ButtonSecondary.cjs +0 -47
- package/ButtonSecondary.mjs +0 -25
- package/ButtonTertiary.cjs +0 -64
- package/ButtonTertiary.mjs +0 -42
- package/Carousel.cjs +0 -52
- package/Carousel.mjs +0 -30
- package/CarouselStepper.cjs +0 -51
- package/CarouselStepper.mjs +0 -29
- package/CenterColumn.cjs +0 -40
- package/CenterColumn.mjs +0 -16
- package/Checkbox.cjs +0 -52
- package/Checkbox.mjs +0 -30
- package/CheckboxButtonsGroup.cjs +0 -65
- package/CheckboxButtonsGroup.mjs +0 -43
- package/CheckboxGroup.cjs +0 -55
- package/CheckboxGroup.mjs +0 -33
- package/CityBlock.cjs +0 -49
- package/CityBlock.mjs +0 -25
- package/ContactBubble.cjs +0 -200
- package/ContactBubble.mjs +0 -173
- package/ContentArticle.cjs +0 -63
- package/ContentArticle.mjs +0 -41
- package/ContentImage.cjs +0 -58
- package/ContentImage.mjs +0 -36
- package/Datepicker.cjs +0 -164
- package/Datepicker.mjs +0 -142
- package/ExtraLinks.cjs +0 -96
- package/ExtraLinks.mjs +0 -74
- package/FeatureList.cjs +0 -53
- package/FeatureList.mjs +0 -29
- package/FieldGroup.cjs +0 -40
- package/FieldGroup.mjs +0 -16
- package/FileInput.cjs +0 -256
- package/FileInput.mjs +0 -234
- package/Foonote.cjs +0 -30
- package/Foonote.mjs +0 -6
- package/FooterBadges.cjs +0 -49
- package/FooterBadges.mjs +0 -25
- package/FooterInfo.cjs +0 -47
- package/FooterInfo.mjs +0 -23
- package/Footnote.cjs +0 -32
- package/Footnote.mjs +0 -8
- package/Form.cjs +0 -56
- package/Form.mjs +0 -34
- package/FormField.cjs +0 -153
- package/FormField.mjs +0 -131
- package/Gallery/_GalleryItem.cjs +0 -83
- package/Gallery/_GalleryItem.mjs +0 -61
- package/Gallery/_GalleryModal.cjs +0 -104
- package/Gallery/_GalleryModal.mjs +0 -82
- package/Gallery/_GalleryModalContext.cjs +0 -30
- package/Gallery/_GalleryModalContext.mjs +0 -6
- package/Gallery/_GalleryModalItem.cjs +0 -59
- package/Gallery/_GalleryModalItem.mjs +0 -36
- package/Gallery.cjs +0 -79
- package/Gallery.mjs +0 -57
- package/GridBlocks.cjs +0 -81
- package/GridBlocks.mjs +0 -59
- package/Heading.cjs +0 -45
- package/Heading.mjs +0 -21
- package/HeroBlock.cjs +0 -74
- package/HeroBlock.mjs +0 -52
- package/IframeBlock.cjs +0 -48
- package/IframeBlock.mjs +0 -24
- package/Illustration.cjs +0 -51
- package/Illustration.mjs +0 -31
- package/ImageCards.cjs +0 -72
- package/ImageCards.mjs +0 -52
- package/InfoBlock.cjs +0 -51
- package/InfoBlock.mjs +0 -27
- package/InfoHero.cjs +0 -150
- package/InfoHero.mjs +0 -128
- package/IslandBlock.cjs +0 -63
- package/IslandBlock.mjs +0 -41
- package/IslandPageBlock.cjs +0 -49
- package/IslandPageBlock.mjs +0 -25
- package/LabeledTextBlock.cjs +0 -60
- package/LabeledTextBlock.mjs +0 -38
- package/Layout.cjs +0 -113
- package/Layout.mjs +0 -87
- package/MainMenu/_Auxiliary.cjs +0 -54
- package/MainMenu/_Auxiliary.mjs +0 -28
- package/MainMenu/_PrimaryPanel.cjs +0 -74
- package/MainMenu/_PrimaryPanel.mjs +0 -48
- package/MainMenu.cjs +0 -209
- package/MainMenu.mjs +0 -187
- package/MiniMetrics.cjs +0 -56
- package/MiniMetrics.mjs +0 -34
- package/Modal.cjs +0 -70
- package/Modal.mjs +0 -48
- package/NameCard.cjs +0 -115
- package/NameCard.mjs +0 -91
- package/NameCards.cjs +0 -52
- package/NameCards.mjs +0 -30
- package/NewsHero.cjs +0 -136
- package/NewsHero.mjs +0 -114
- package/PageFilter.cjs +0 -48
- package/PageFilter.mjs +0 -24
- package/PageHeading.cjs +0 -42
- package/PageHeading.mjs +0 -18
- package/ProcessOverview.cjs +0 -52
- package/ProcessOverview.mjs +0 -28
- package/PullQuote.cjs +0 -47
- package/PullQuote.mjs +0 -25
- package/RadioButtonsGroup.cjs +0 -64
- package/RadioButtonsGroup.mjs +0 -42
- package/RadioGroup.cjs +0 -58
- package/RadioGroup.mjs +0 -36
- package/RelatedLinks.cjs +0 -61
- package/RelatedLinks.mjs +0 -37
- package/RowBlock.cjs +0 -39
- package/RowBlock.mjs +0 -15
- package/RowBlockColumn.cjs +0 -40
- package/RowBlockColumn.mjs +0 -16
- package/SearchInput.cjs +0 -136
- package/SearchInput.mjs +0 -114
- package/SearchResults/_SearchResultsItem.cjs +0 -54
- package/SearchResults/_SearchResultsItem.mjs +0 -30
- package/SearchResults.cjs +0 -172
- package/SearchResults.mjs +0 -150
- package/SeenEffect.cjs +0 -66
- package/SeenEffect.mjs +0 -44
- package/Selectbox.cjs +0 -144
- package/Selectbox.mjs +0 -122
- package/ShareButtons.cjs +0 -101
- package/ShareButtons.mjs +0 -83
- package/Sharpie.cjs +0 -51
- package/Sharpie.mjs +0 -27
- package/SiteSearchAutocomplete.cjs +0 -150
- package/SiteSearchAutocomplete.mjs +0 -126
- package/SiteSearchCurtain.cjs +0 -78
- package/SiteSearchCurtain.mjs +0 -56
- package/SiteSearchInput.cjs +0 -119
- package/SiteSearchInput.mjs +0 -97
- package/Skeleton.cjs +0 -63
- package/Skeleton.mjs +0 -39
- package/SubHeading.cjs +0 -43
- package/SubHeading.mjs +0 -19
- package/Tabs.cjs +0 -166
- package/Tabs.mjs +0 -144
- package/TagPill.cjs +0 -113
- package/TagPill.mjs +0 -91
- package/TextBlock.cjs +0 -45
- package/TextBlock.mjs +0 -21
- package/TextButton.cjs +0 -55
- package/TextButton.mjs +0 -33
- package/TextInput.cjs +0 -136
- package/TextInput.mjs +0 -114
- package/VSpacer.cjs +0 -70
- package/VSpacer.mjs +0 -46
- package/VerticalTabsTOC.cjs +0 -123
- package/VerticalTabsTOC.mjs +0 -101
- package/WizardLayout.cjs +0 -79
- package/WizardLayout.mjs +0 -55
- package/WizardLayoutClose.cjs +0 -47
- package/WizardLayoutClose.mjs +0 -25
- package/WizardStepper.cjs +0 -55
- package/WizardStepper.mjs +0 -31
- package/_abstract/Button.cjs +0 -114
- package/_abstract/Button.mjs +0 -92
- package/_abstract/CardList.cjs +0 -100
- package/_abstract/CardList.mjs +0 -76
- package/_abstract/Image.cjs +0 -75
- package/_abstract/Image.mjs +0 -51
- package/_abstract/Link.cjs +0 -37
- package/_abstract/Link.mjs +0 -10
- package/_abstract/TogglerGroup.cjs +0 -92
- package/_abstract/TogglerGroup.mjs +0 -70
- package/_abstract/TogglerGroupField.cjs +0 -121
- package/_abstract/TogglerGroupField.mjs +0 -99
- package/_abstract/TogglerInput.cjs +0 -105
- package/_abstract/TogglerInput.mjs +0 -83
- package/_abstract/_AbstractCarousel.cjs +0 -170
- package/_abstract/_AbstractCarousel.mjs +0 -152
- package/_abstract/_Blings.cjs +0 -47
- package/_abstract/_Blings.mjs +0 -23
- package/_abstract/_Block.cjs +0 -73
- package/_abstract/_Block.mjs +0 -51
- package/_abstract/_Quote.cjs +0 -43
- package/_abstract/_Quote.mjs +0 -17
- package/_abstract/breakOnNL.cjs +0 -30
- package/_abstract/breakOnNL.mjs +0 -6
- package/assets.cjs +0 -77
- package/assets.mjs +0 -53
- package/constants.cjs +0 -49
- package/constants.mjs +0 -24
- package/focus-visible.cjs +0 -1
- package/focus-visible.mjs +0 -1
- package/utils/config.cjs +0 -27
- package/utils/config.d.ts +0 -2
- package/utils/config.mjs +0 -4
- package/utils/detectEdgeScroll.cjs +0 -95
- package/utils/detectEdgeScroll.d.ts +0 -52
- package/utils/detectEdgeScroll.mjs +0 -71
- package/utils/env.cjs +0 -31
- package/utils/env.mjs +0 -5
- package/utils/seenEffect.cjs +0 -93
- package/utils/seenEffect.mjs +0 -65
- package/utils/useFormatMonitor.cjs +0 -29
- package/utils/useFormatMonitor.mjs +0 -6
- package/utils/useGetSVGtext.cjs +0 -44
- package/utils/useGetSVGtext.mjs +0 -21
- package/utils/useMenuToggling.cjs +0 -83
- package/utils/useMenuToggling.mjs +0 -60
- package/utils/useScrollbarWidthCSSVar.cjs +0 -32
- package/utils/useScrollbarWidthCSSVar.mjs +0 -6
- package/utils.cjs +0 -18
- package/utils.mjs +0 -2
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { BemPropsModifier } from '@hugsmidjan/react/types';
|
|
2
|
+
export declare type TogglerInputProps = {
|
|
3
|
+
label: string | JSX.Element;
|
|
4
|
+
children?: undefined;
|
|
5
|
+
Wrapper?: 'div' | 'li';
|
|
6
|
+
invalid?: boolean;
|
|
7
|
+
/** Hidden label prefix text to indicate that the field is required.
|
|
8
|
+
*
|
|
9
|
+
* If your field is required but should not say so in its label
|
|
10
|
+
* then set this prop to `false`
|
|
11
|
+
*
|
|
12
|
+
* Default: `"Þarf að fylla út"`
|
|
13
|
+
* */
|
|
14
|
+
reqText?: string | false;
|
|
15
|
+
errorMessage?: string | JSX.Element;
|
|
16
|
+
} & BemPropsModifier & Omit<JSX.IntrinsicElements['input'], 'type'>;
|
|
17
|
+
declare type _TogglerInputProps = {
|
|
18
|
+
bem: string;
|
|
19
|
+
type: 'radio' | 'checkbox';
|
|
20
|
+
};
|
|
21
|
+
declare const TogglerInput: (props: TogglerInputProps & _TogglerInputProps) => JSX.Element;
|
|
22
|
+
export default TogglerInput;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import React from 'react';
|
|
13
|
+
import { useDomid } from '@hugsmidjan/react/hooks';
|
|
14
|
+
import getBemClass from '@hugsmidjan/react/utils/getBemClass';
|
|
15
|
+
const TogglerInput = (props) => {
|
|
16
|
+
const { bem, modifier, className, label, invalid, errorMessage, Wrapper = 'div', required, reqText, type, id } = props, inputProps = __rest(props, ["bem", "modifier", "className", "label", "invalid", "errorMessage", "Wrapper", "required", "reqText", "type", "id"]);
|
|
17
|
+
const domid = useDomid(id);
|
|
18
|
+
const errorId = errorMessage && 'error' + domid;
|
|
19
|
+
const reqStar = required && reqText !== false && (<abbr className={bem + '__label__reqstar'}
|
|
20
|
+
// TODO: add mo-better i18n thinking
|
|
21
|
+
title={(reqText || 'Þarf að haka í') + ': '}>
|
|
22
|
+
*
|
|
23
|
+
</abbr>);
|
|
24
|
+
return (<Wrapper className={getBemClass(bem, modifier, className)}>
|
|
25
|
+
<input className={bem + '__input'} type={type} id={domid} aria-invalid={invalid || !!errorMessage || undefined} aria-describedby={errorId} {...inputProps}/>{' '}
|
|
26
|
+
<label className={bem + '__label'} htmlFor={domid}>
|
|
27
|
+
{' '}
|
|
28
|
+
{reqStar} {label}{' '}
|
|
29
|
+
</label>
|
|
30
|
+
{errorMessage && (<div className={bem + '__error'} id={errorId}>
|
|
31
|
+
{errorMessage}
|
|
32
|
+
</div>)}
|
|
33
|
+
</Wrapper>);
|
|
34
|
+
};
|
|
35
|
+
export default TogglerInput;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { ReactElement } from 'react';
|
|
2
|
+
import { SSRSupport } from '@hugsmidjan/react/hooks';
|
|
3
|
+
import { BemProps } from '@hugsmidjan/react/types';
|
|
4
|
+
import { SeenProp } from '../utils/seenEffect';
|
|
5
|
+
export declare type CarouselProps<I extends Record<string, unknown> = {}, P extends Record<string, unknown> | undefined = {}> = {
|
|
6
|
+
className?: string;
|
|
7
|
+
ssr?: SSRSupport;
|
|
8
|
+
/** @deprecated Ingored because never used (Will be removed in v0.11) */
|
|
9
|
+
scrollRight?: boolean;
|
|
10
|
+
} & ({
|
|
11
|
+
children?: never;
|
|
12
|
+
items: Array<I>;
|
|
13
|
+
Component: (props: P extends undefined ? I : I & P) => ReactElement | null;
|
|
14
|
+
ComponentProps?: P;
|
|
15
|
+
} | {
|
|
16
|
+
children: Array<ReactElement>;
|
|
17
|
+
items?: never;
|
|
18
|
+
Component?: never;
|
|
19
|
+
ComponentProps?: never;
|
|
20
|
+
}) & SeenProp;
|
|
21
|
+
declare type AbstractCarouselProps<I extends Record<string, unknown> = {}, P extends Record<string, unknown> | undefined = {}> = CarouselProps<I, P> & BemProps & {
|
|
22
|
+
title?: string;
|
|
23
|
+
};
|
|
24
|
+
declare const AbstractCarousel: <I extends Record<string, unknown> = {}, P extends Record<string, unknown> | undefined = {}>(props: AbstractCarouselProps<I, P>) => JSX.Element | null;
|
|
25
|
+
export default AbstractCarousel;
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import React, { useEffect, useRef, useState, } from 'react';
|
|
2
|
+
import A from '@hugsmidjan/qj/A';
|
|
3
|
+
import focusElm from '@hugsmidjan/qj/focusElm';
|
|
4
|
+
import throttle from '@hugsmidjan/qj/throttle';
|
|
5
|
+
import { useIsBrowserSide } from '@hugsmidjan/react/hooks';
|
|
6
|
+
import getBemClass from '@hugsmidjan/react/utils/getBemClass';
|
|
7
|
+
import { notNully } from '@reykjavik/hanna-utils';
|
|
8
|
+
import CarouselStepper from '../CarouselStepper';
|
|
9
|
+
import { useSeenEffect } from '../utils/seenEffect';
|
|
10
|
+
const WHEEL_AMPLIFIER = 3;
|
|
11
|
+
const WHEEL_HIJACK_TIMEOUT_MS = 667;
|
|
12
|
+
const scrollXBy = (elm, deltaX) => {
|
|
13
|
+
const left = elm.scrollLeft + deltaX;
|
|
14
|
+
elm.scrollTo(left, elm.scrollTop);
|
|
15
|
+
// NOTE 1: using elm.scrollTo({ left, behavior: 'smooth' }); seems to be too much
|
|
16
|
+
// as `behavior: 'smooth'` starts some weird interactions with the browser's
|
|
17
|
+
// `scroll-snap-type` behavior.
|
|
18
|
+
//
|
|
19
|
+
// NOTE 2: Both Chrome and Safari tend to snap hard to the nearest list item
|
|
20
|
+
// while Firefox is more smooth. Haven't found a way around that.
|
|
21
|
+
};
|
|
22
|
+
const exitWheelHijack = (elm) => () => {
|
|
23
|
+
elm.style.scrollSnapType = '';
|
|
24
|
+
const lastElmOffset = elm.lastElementChild
|
|
25
|
+
? elm.lastElementChild.offsetLeft
|
|
26
|
+
: 0;
|
|
27
|
+
// trigger one last scroll event, to make sure the element's
|
|
28
|
+
// `style.scrollSnapType`'s behavior kicks in.
|
|
29
|
+
// Otherwise the list may stay stuck in an over-scrolled state —
|
|
30
|
+
// off to the right.
|
|
31
|
+
scrollXBy(elm, Math.min(0, lastElmOffset - elm.scrollLeft));
|
|
32
|
+
};
|
|
33
|
+
const handleMouseWheel = (e) => {
|
|
34
|
+
const elm = e.currentTarget;
|
|
35
|
+
if (e.deltaX || elm.$hasXDeltaed) {
|
|
36
|
+
elm.$hasXDeltaed = true;
|
|
37
|
+
exitWheelHijack(elm);
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
if (e.deltaY && !e.deltaX) {
|
|
41
|
+
if (e.deltaY < 0) {
|
|
42
|
+
// Stop scroll-capture when list is at left-edge
|
|
43
|
+
if (elm.scrollLeft < 50) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
// Stop scroll-capture when list is beyond left edge of last list item
|
|
49
|
+
if (elm.scrollLeft >
|
|
50
|
+
(elm.lastElementChild ? elm.lastElementChild.offsetLeft : 0)) {
|
|
51
|
+
exitWheelHijack(elm);
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
e.preventDefault();
|
|
56
|
+
e.stopImmediatePropagation();
|
|
57
|
+
// Disable `scroll-snap-style` because otherwise
|
|
58
|
+
// small-scale elm.scrollTo() calls have no effect
|
|
59
|
+
elm.style.scrollSnapType = 'initial';
|
|
60
|
+
scrollXBy(elm, e.deltaY * WHEEL_AMPLIFIER);
|
|
61
|
+
clearTimeout(elm.$timeout);
|
|
62
|
+
elm.$timeout = setTimeout(exitWheelHijack(elm), WHEEL_HIJACK_TIMEOUT_MS);
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
const handleMouseLeave = (e) => {
|
|
66
|
+
const elm = e.currentTarget;
|
|
67
|
+
exitWheelHijack(elm);
|
|
68
|
+
elm.$hasXDeltaed = undefined;
|
|
69
|
+
};
|
|
70
|
+
const AbstractCarousel = (props) => {
|
|
71
|
+
const { title, items = [], Component, ComponentProps, bem = 'Carousel', modifier, ssr, startSeen, } = props;
|
|
72
|
+
const children = props.children && props.children.filter(notNully);
|
|
73
|
+
const [leftOffset, setLeftOffset] = useState();
|
|
74
|
+
const itemCount = (children || items).length;
|
|
75
|
+
const listRef = useRef(null);
|
|
76
|
+
const [activeItem, setActiveItem] = useState(0);
|
|
77
|
+
const isBrowser = useIsBrowserSide(ssr);
|
|
78
|
+
// update on activeItem state change
|
|
79
|
+
useEffect(() => {
|
|
80
|
+
const listElm = listRef.current;
|
|
81
|
+
if (!listElm) {
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
const calcLeftOffset = () => {
|
|
85
|
+
var _a;
|
|
86
|
+
setLeftOffset((_a = listElm.parentElement) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect().left);
|
|
87
|
+
scrollXBy(listElm, 0);
|
|
88
|
+
};
|
|
89
|
+
const calcActiveItem = throttle(() => {
|
|
90
|
+
const { scrollLeft, children } = listElm;
|
|
91
|
+
// using Array#find as forEachUntil
|
|
92
|
+
A(children).find((item, i) => {
|
|
93
|
+
if (scrollLeft <= item.offsetLeft + item.offsetWidth / 2) {
|
|
94
|
+
setActiveItem(i);
|
|
95
|
+
return true;
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
}, 300, true);
|
|
99
|
+
calcLeftOffset();
|
|
100
|
+
listElm.addEventListener('wheel', handleMouseWheel);
|
|
101
|
+
listElm.addEventListener('scroll', calcActiveItem, { passive: true });
|
|
102
|
+
window.addEventListener('resize', calcLeftOffset, { passive: true });
|
|
103
|
+
return () => {
|
|
104
|
+
listElm.removeEventListener('wheel', handleMouseWheel);
|
|
105
|
+
listElm.removeEventListener('scroll', calcActiveItem);
|
|
106
|
+
window.removeEventListener('resize', calcLeftOffset);
|
|
107
|
+
};
|
|
108
|
+
}, []);
|
|
109
|
+
const scrollToItem = (newActive) => {
|
|
110
|
+
setActiveItem(newActive);
|
|
111
|
+
const listElm = listRef.current;
|
|
112
|
+
const newItem = listElm.children[newActive];
|
|
113
|
+
listElm.scrollTo(newItem ? newItem.offsetLeft : 0, 0);
|
|
114
|
+
setTimeout(() => focusElm(newItem), 500);
|
|
115
|
+
};
|
|
116
|
+
const [outerRef] = useSeenEffect(startSeen);
|
|
117
|
+
if (!itemCount) {
|
|
118
|
+
return null;
|
|
119
|
+
}
|
|
120
|
+
return (<div className={getBemClass(bem, modifier, props.className)} ref={outerRef} data-sprinkled={isBrowser}>
|
|
121
|
+
{title && <h2 className={bem + '__title'}>{title}</h2>}
|
|
122
|
+
<div className={bem + '__itemlist'} style={leftOffset
|
|
123
|
+
? { '--Carousel--leftOffset': `${leftOffset}px` }
|
|
124
|
+
: undefined} data-scroll-snapping={leftOffset ? 'true' : undefined} onMouseLeave={handleMouseLeave} ref={listRef}>
|
|
125
|
+
{children ||
|
|
126
|
+
items.map((item, i) => (
|
|
127
|
+
// @ts-expect-error (Can't be arsed...)
|
|
128
|
+
<Component key={i} {...ComponentProps} {...item}/>))}
|
|
129
|
+
</div>
|
|
130
|
+
{isBrowser && (<CarouselStepper itemCount={itemCount} setCurrent={scrollToItem} current={activeItem}/>)}
|
|
131
|
+
</div>);
|
|
132
|
+
};
|
|
133
|
+
export default AbstractCarousel;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { BlingType } from '@reykjavik/hanna-utils/assets';
|
|
2
|
+
import { BlingProps } from '../Bling';
|
|
3
|
+
export declare type BlingComboProps = Array<Omit<BlingProps, 'type' | 'blingUrl'> & {
|
|
4
|
+
type: BlingType;
|
|
5
|
+
}>;
|
|
6
|
+
declare type BlingsProps = {
|
|
7
|
+
blings: BlingComboProps;
|
|
8
|
+
mirror?: boolean;
|
|
9
|
+
};
|
|
10
|
+
declare const Blings: (props: BlingsProps) => JSX.Element;
|
|
11
|
+
export default Blings;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import Bling from '../Bling';
|
|
3
|
+
const inverseAlignments = {
|
|
4
|
+
left: 'right',
|
|
5
|
+
'left-ish': 'right-ish',
|
|
6
|
+
'left-center': 'right-center',
|
|
7
|
+
'right-center': 'left-center',
|
|
8
|
+
'right-ish': 'left-ish',
|
|
9
|
+
right: 'left',
|
|
10
|
+
};
|
|
11
|
+
const Blings = (props) => (<>
|
|
12
|
+
{props.blings.map(({ type, align, vertical, color, overlay, parent }, i) => (<Bling key={type + '-' + i} type={type} align={props.mirror ? inverseAlignments[align || 'left'] : align} vertical={vertical} color={color} overlay={overlay} parent={parent}/>))}
|
|
13
|
+
</>);
|
|
14
|
+
export default Blings;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { BemPropsModifier } from '@hugsmidjan/react/types';
|
|
2
|
+
import { SeenProp } from '../utils/seenEffect';
|
|
3
|
+
import { ButtonProps } from './Button';
|
|
4
|
+
import { ImageProps } from './Image';
|
|
5
|
+
export declare type BlockItem = {
|
|
6
|
+
title: string;
|
|
7
|
+
summary?: string | JSX.Element;
|
|
8
|
+
buttons?: Array<ButtonProps>;
|
|
9
|
+
};
|
|
10
|
+
export declare type ContentImageBlock = {
|
|
11
|
+
content: BlockItem;
|
|
12
|
+
image: ImageProps;
|
|
13
|
+
} & SeenProp;
|
|
14
|
+
export declare type ContentBlock = {
|
|
15
|
+
content: Array<BlockItem>;
|
|
16
|
+
image?: undefined;
|
|
17
|
+
} & SeenProp;
|
|
18
|
+
export declare type BlockProps = BemPropsModifier & (ContentBlock | ContentImageBlock);
|
|
19
|
+
declare const Block: (props: BlockProps & {
|
|
20
|
+
bem: string;
|
|
21
|
+
}) => JSX.Element;
|
|
22
|
+
export default Block;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import getBemClass from '@hugsmidjan/react/utils/getBemClass';
|
|
3
|
+
import { useSeenEffect } from '../utils/seenEffect';
|
|
4
|
+
import Button from './Button';
|
|
5
|
+
import Image from './Image';
|
|
6
|
+
const Block = (props) => {
|
|
7
|
+
const { image, modifier, bem, content, startSeen } = props;
|
|
8
|
+
const [ref] = useSeenEffect(startSeen);
|
|
9
|
+
const contentItems = Array.isArray(content) ? content : [content];
|
|
10
|
+
return (<div className={getBemClass(bem, modifier)} ref={ref}>
|
|
11
|
+
{contentItems.map(({ title, summary, buttons = [] }, i) => {
|
|
12
|
+
const hasSummary = summary && (typeof summary !== 'string' || !!summary.trim());
|
|
13
|
+
return (<div key={i} className={`${bem}__content`}>
|
|
14
|
+
<h2 className={`${bem}__title`}>{title}</h2>
|
|
15
|
+
{hasSummary && <div className={`${bem}__summary`}>{summary}</div>}
|
|
16
|
+
{buttons.length > 0 && (<div className={`${bem}__buttons`}>
|
|
17
|
+
{' '}
|
|
18
|
+
{buttons.map((buttonProps, i) => (<>
|
|
19
|
+
<Button bem={`${bem}__button`} key={i} {...buttonProps}/>{' '}
|
|
20
|
+
</>))}
|
|
21
|
+
</div>)}
|
|
22
|
+
</div>);
|
|
23
|
+
})}
|
|
24
|
+
{image && <Image className={`${bem}__image`} {...image}/>}
|
|
25
|
+
</div>);
|
|
26
|
+
};
|
|
27
|
+
export default Block;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Link } from './Link';
|
|
3
|
+
export const _Quote = (props) => {
|
|
4
|
+
const { bem, children, by, byHref } = props;
|
|
5
|
+
return (<figure className={bem}>
|
|
6
|
+
<blockquote className={bem + '__quote'}>{children}</blockquote>
|
|
7
|
+
{by && (<figcaption className={bem + '__by'}>
|
|
8
|
+
{byHref ? (<Link href={byHref}>{by}</Link>) : typeof by === 'string' ? (<span>{by}</span>) : (by)}
|
|
9
|
+
</figcaption>)}
|
|
10
|
+
</figure>);
|
|
11
|
+
};
|
package/esm/assets.d.ts
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import type { BlingType, Efnistakn, Formheimur, Illustration } from '@reykjavik/hanna-utils/assets';
|
|
2
|
+
import { blingTypes, efnistakn, getAssetUrl, getBlingUrl, getEfnistaknUrl, getFormheimurUrl, getIllustrationUrl, illustrations } from '@reykjavik/hanna-utils/assets';
|
|
3
|
+
export type {
|
|
4
|
+
/** @deprecated Instead `import type { BlingType } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
5
|
+
BlingType,
|
|
6
|
+
/** @deprecated Instead `import type { Efnistakn } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
7
|
+
Efnistakn,
|
|
8
|
+
/** @deprecated Instead `import type { Formheimur } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
9
|
+
Formheimur,
|
|
10
|
+
/** @deprecated Instead `import type { Illustration } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
11
|
+
Illustration, };
|
|
12
|
+
export {
|
|
13
|
+
/** @deprecated Instead `import type { blingTypes } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
14
|
+
blingTypes,
|
|
15
|
+
/** @deprecated Instead `import type { efnistakn } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
16
|
+
efnistakn,
|
|
17
|
+
/** @deprecated Instead `import type { getAssetUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
18
|
+
getAssetUrl,
|
|
19
|
+
/** @deprecated Instead `import type { getBlingUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
20
|
+
getBlingUrl,
|
|
21
|
+
/** @deprecated Instead `import type { getEfnistaknUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
22
|
+
getEfnistaknUrl,
|
|
23
|
+
/** @deprecated Instead `import type { getFormheimurUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
24
|
+
getFormheimurUrl,
|
|
25
|
+
/** @deprecated Instead `import type { getIllustrationUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
26
|
+
getIllustrationUrl,
|
|
27
|
+
/** @deprecated Instead `import type { illustrations } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
28
|
+
illustrations, };
|
|
29
|
+
/** @deprecated Use `getCssBundleUrl` from '@reykjavik/hanna-css' instead (Will be reomved in v0.11) */
|
|
30
|
+
export declare const getCssBundleUrl: (cssTokens: string | Array<string>, version?: string | undefined) => string;
|
|
31
|
+
/** @deprecated (Will be removed in v0.11) */
|
|
32
|
+
export declare const efnistakn_menu: readonly ["menu/borgarstjori", "menu/borgarstjorn", "menu/bygg_framkv", "menu/fjarmal", "menu/fundargerdir", "menu/itrottir_aftreying", "menu/log_reglugerdir", "menu/mannaudur", "menu/menning", "menu/rad_nefndir", "menu/skipulag", "menu/skolar_fristund", "menu/svid_deildir", "menu/umhverfi_samgongur", "menu/velferd_fjolskylda"];
|
|
33
|
+
/** @deprecated (Will be removed in v0.11) */
|
|
34
|
+
export declare type Efnistakn_Menu = typeof efnistakn_menu[number];
|
|
35
|
+
/** @deprecated (Will be removed in v0.11) */
|
|
36
|
+
export declare const auxiliary_menu_images: Array<Illustration>;
|
|
37
|
+
/** @deprecated Instead `import type { AuxilaryPanelIllustration } from '@reykjavik/hanna-react/MainMenu';` (Will be removed in v0.11) */
|
|
38
|
+
export declare type Auxilary_MenuImages = typeof auxiliary_menu_images[number];
|
|
39
|
+
/** @deprecated Instead `import type { BlingType } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
40
|
+
export declare type BlingTypes = BlingType;
|
|
41
|
+
/** @deprecated Instead `import type { Illustration } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
42
|
+
export declare type Illustrations = Illustration;
|
package/esm/assets.js
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { getCssBundleUrl as _getCssBundleUrl } from '@reykjavik/hanna-css';
|
|
2
|
+
import { blingTypes, efnistakn, getAssetUrl, getBlingUrl, getEfnistaknUrl, getFormheimurUrl, getIllustrationUrl, illustrations, } from '@reykjavik/hanna-utils/assets';
|
|
3
|
+
export {
|
|
4
|
+
/** @deprecated Instead `import type { blingTypes } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
5
|
+
blingTypes,
|
|
6
|
+
/** @deprecated Instead `import type { efnistakn } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
7
|
+
efnistakn,
|
|
8
|
+
/** @deprecated Instead `import type { getAssetUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
9
|
+
getAssetUrl,
|
|
10
|
+
/** @deprecated Instead `import type { getBlingUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
11
|
+
getBlingUrl,
|
|
12
|
+
/** @deprecated Instead `import type { getEfnistaknUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
13
|
+
getEfnistaknUrl,
|
|
14
|
+
/** @deprecated Instead `import type { getFormheimurUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
15
|
+
getFormheimurUrl,
|
|
16
|
+
/** @deprecated Instead `import type { getIllustrationUrl } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
17
|
+
getIllustrationUrl,
|
|
18
|
+
/** @deprecated Instead `import type { illustrations } from '@reykjavik/hanna-utils/assets';` (Will be removed in v0.11) */
|
|
19
|
+
illustrations, };
|
|
20
|
+
/** @deprecated Use `getCssBundleUrl` from '@reykjavik/hanna-css' instead (Will be reomved in v0.11) */
|
|
21
|
+
export const getCssBundleUrl = (cssTokens,
|
|
22
|
+
/** If you want to pin your CSS files to a specific version */
|
|
23
|
+
version) => _getCssBundleUrl(cssTokens, { version });
|
|
24
|
+
// ---------------------------------------------------------------------------
|
|
25
|
+
// Based on "https://styles.reykjavik.is/assets/efnistakn/menu/files.json"
|
|
26
|
+
/** @deprecated (Will be removed in v0.11) */
|
|
27
|
+
export const efnistakn_menu = [
|
|
28
|
+
'menu/borgarstjori',
|
|
29
|
+
'menu/borgarstjorn',
|
|
30
|
+
'menu/bygg_framkv',
|
|
31
|
+
'menu/fjarmal',
|
|
32
|
+
'menu/fundargerdir',
|
|
33
|
+
'menu/itrottir_aftreying',
|
|
34
|
+
'menu/log_reglugerdir',
|
|
35
|
+
'menu/mannaudur',
|
|
36
|
+
'menu/menning',
|
|
37
|
+
'menu/rad_nefndir',
|
|
38
|
+
'menu/skipulag',
|
|
39
|
+
'menu/skolar_fristund',
|
|
40
|
+
'menu/svid_deildir',
|
|
41
|
+
'menu/umhverfi_samgongur',
|
|
42
|
+
'menu/velferd_fjolskylda',
|
|
43
|
+
];
|
|
44
|
+
// ---------------------------------------------------------------------------
|
|
45
|
+
/** @deprecated (Will be removed in v0.11) */
|
|
46
|
+
export const auxiliary_menu_images = [
|
|
47
|
+
'hanna-veitiggi',
|
|
48
|
+
'hanna-vandro',
|
|
49
|
+
'hanna-hugsi',
|
|
50
|
+
'hanna-hissa',
|
|
51
|
+
'hanna-hahaha',
|
|
52
|
+
'hanna-hae',
|
|
53
|
+
'hanna-god_spurning',
|
|
54
|
+
'hanna-gjuggiborg',
|
|
55
|
+
'hanna-benda',
|
|
56
|
+
];
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/** @depcrecated import `colorFamilies` from `@reykjavik/hanna-css` instead (Will be removed in v0.11) */
|
|
2
|
+
export declare const colorFamilies: readonly ["esja", "faxafloi", "nautholsvik", "heidmork", "ellidaardalur", "blafjoll", "sund", "rokkur", "suld"] & {
|
|
3
|
+
readonly esja: "esja";
|
|
4
|
+
readonly faxafloi: "faxafloi";
|
|
5
|
+
readonly nautholsvik: "nautholsvik";
|
|
6
|
+
readonly heidmork: "heidmork";
|
|
7
|
+
readonly ellidaardalur: "ellidaardalur";
|
|
8
|
+
readonly blafjoll: "blafjoll";
|
|
9
|
+
readonly sund: "sund";
|
|
10
|
+
readonly rokkur: "rokkur";
|
|
11
|
+
readonly suld: "suld";
|
|
12
|
+
} & {
|
|
13
|
+
/** @deprecated This is a typo (Will be removed in v0.11) */
|
|
14
|
+
ellidarardalur: string;
|
|
15
|
+
};
|
|
16
|
+
/** @depcrecated import type `ColorFamily` from `@reykjavik/hanna-css` instead (Will be removed in v0.11) */
|
|
17
|
+
export type { ColorFamily } from '@reykjavik/hanna-css';
|
|
18
|
+
/** @depcrecated import `colorThemes` from `@reykjavik/hanna-css` instead (Will be removed in v0.11) */
|
|
19
|
+
export declare const themeOptions: readonly ["trustworthy", "dependable", "friendly", "lively", "colorful"] & {
|
|
20
|
+
readonly trustworthy: "trustworthy";
|
|
21
|
+
readonly dependable: "dependable";
|
|
22
|
+
readonly friendly: "friendly";
|
|
23
|
+
readonly lively: "lively";
|
|
24
|
+
readonly colorful: "colorful";
|
|
25
|
+
};
|
|
26
|
+
/** @depcrecated import type `HannaColorTheme` from `@reykjavik/hanna-css` instead (Will be removed in v0.11) */
|
|
27
|
+
export type { HannaColorTheme as ThemeOption } from '@reykjavik/hanna-css';
|
|
28
|
+
export declare type Alignment = 'right' | 'left';
|
|
29
|
+
export declare const aligns: Record<string, true | undefined>;
|
|
30
|
+
export declare type ComponentLayoutProps<Align extends string = 'right'> = {
|
|
31
|
+
wide?: undefined;
|
|
32
|
+
align?: undefined;
|
|
33
|
+
} | {
|
|
34
|
+
wide: boolean;
|
|
35
|
+
align?: undefined;
|
|
36
|
+
} | {
|
|
37
|
+
wide?: undefined;
|
|
38
|
+
align: Align;
|
|
39
|
+
};
|
package/esm/constants.js
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { colorFamilies as _colorFamilies, colorThemes } from '@reykjavik/hanna-css';
|
|
2
|
+
/** @depcrecated import `colorFamilies` from `@reykjavik/hanna-css` instead (Will be removed in v0.11) */
|
|
3
|
+
export const colorFamilies = Object.assign([
|
|
4
|
+
'esja',
|
|
5
|
+
'faxafloi',
|
|
6
|
+
'nautholsvik',
|
|
7
|
+
'heidmork',
|
|
8
|
+
'ellidaardalur',
|
|
9
|
+
'blafjoll',
|
|
10
|
+
'sund',
|
|
11
|
+
'rokkur',
|
|
12
|
+
'suld',
|
|
13
|
+
], _colorFamilies, {
|
|
14
|
+
/** @deprecated This is a typo (Will be removed in v0.11) */
|
|
15
|
+
ellidarardalur: 'ellidaardalur',
|
|
16
|
+
});
|
|
17
|
+
/** @depcrecated import `colorThemes` from `@reykjavik/hanna-css` instead (Will be removed in v0.11) */
|
|
18
|
+
export const themeOptions = Object.assign(['trustworthy', 'dependable', 'friendly', 'lively', 'colorful'], colorThemes);
|
|
19
|
+
export const aligns = {
|
|
20
|
+
right: true,
|
|
21
|
+
left: true,
|
|
22
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import '@reykjavik/hanna-utils/focus-visible';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import '@reykjavik/hanna-utils/focus-visible';
|
package/esm/package.json
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"type":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const isPreact: true | undefined;
|
package/esm/utils/env.js
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export const isPreact =
|
|
3
|
+
// imported from 'preact'
|
|
4
|
+
'h' in React ||
|
|
5
|
+
// imported from 'preact/compat' (has all of `react-dom` bundled)
|
|
6
|
+
('hydrate' in React && 'render' in React) ||
|
|
7
|
+
// `undefined` instead of `false` for nicer prop usage
|
|
8
|
+
undefined;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { RefObject } from 'react';
|
|
2
|
+
export declare const DATA_ATTR_NAME = "is-seen";
|
|
3
|
+
export declare const getObserver: {
|
|
4
|
+
(target: Element, callback?: ((target: Element) => void) | undefined): (() => void) | undefined;
|
|
5
|
+
DATA_ATTR_NAME: string;
|
|
6
|
+
};
|
|
7
|
+
export declare const seenEffectOptOut: (target: Element, setFlag?: boolean) => void;
|
|
8
|
+
declare const effects: {
|
|
9
|
+
readonly fadein: 1;
|
|
10
|
+
readonly fadeup: 1;
|
|
11
|
+
readonly fadeleft: 1;
|
|
12
|
+
};
|
|
13
|
+
export declare type SeenEffectType = keyof typeof effects;
|
|
14
|
+
export declare type EffectProp = {
|
|
15
|
+
/** Should the component appear instantly, and not transition-in once seen */
|
|
16
|
+
effectType?: SeenEffectType;
|
|
17
|
+
};
|
|
18
|
+
/** Asserts that a prop value is a SeenEffectType and returns undefined otherwise */
|
|
19
|
+
export declare const assertEffectType: (maybeType?: string | undefined) => SeenEffectType | undefined;
|
|
20
|
+
export declare const getEffectAttr: (maybeType?: string | undefined) => {
|
|
21
|
+
'data-seen-effect': string;
|
|
22
|
+
};
|
|
23
|
+
export declare type SeenProp = {
|
|
24
|
+
/** Should the component appear instantly, and not transition-in once seen */
|
|
25
|
+
startSeen?: boolean;
|
|
26
|
+
};
|
|
27
|
+
export declare const useSeenEffect: <E extends Element = HTMLDivElement>(startSeen?: boolean | undefined, customRef?: RefObject<E> | undefined) => [RefObject<E> | undefined, true | undefined];
|
|
28
|
+
export {};
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { useEffect, useRef, useState } from 'react';
|
|
2
|
+
export const DATA_ATTR_NAME = 'is-seen';
|
|
3
|
+
const STACKING_DELAY = 400; // ms
|
|
4
|
+
const dataAttr = 'data-' + DATA_ATTR_NAME;
|
|
5
|
+
const inTargetSourceOrder = (a, b) => a.target.compareDocumentPosition(b.target) & Node.DOCUMENT_POSITION_PRECEDING ? 1 : -1;
|
|
6
|
+
const options = {
|
|
7
|
+
// root: window
|
|
8
|
+
rootMargin: '-100px 0px 0px 0px',
|
|
9
|
+
threshold: 0, // 0
|
|
10
|
+
};
|
|
11
|
+
let observer;
|
|
12
|
+
export const getObserver = (target, callback) => {
|
|
13
|
+
if (target.hasAttribute(dataAttr)) {
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
|
17
|
+
if (!observer) {
|
|
18
|
+
observer = new IntersectionObserver((entries, observer) => entries
|
|
19
|
+
.filter((e) => e.isIntersecting)
|
|
20
|
+
.sort(inTargetSourceOrder)
|
|
21
|
+
.forEach(({ target }, i) => {
|
|
22
|
+
setTimeout(() => {
|
|
23
|
+
target.setAttribute(dataAttr, 'true');
|
|
24
|
+
callback && callback(target);
|
|
25
|
+
observer.unobserve(target);
|
|
26
|
+
}, STACKING_DELAY * i);
|
|
27
|
+
}), options);
|
|
28
|
+
}
|
|
29
|
+
if (target.matches('[' + dataAttr + '] *')) {
|
|
30
|
+
// opt out if target is contained by another "seen-effect" element
|
|
31
|
+
target.setAttribute(dataAttr, '');
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
target.setAttribute(dataAttr, 'false');
|
|
35
|
+
observer.observe(target);
|
|
36
|
+
return () => observer.unobserve(target);
|
|
37
|
+
};
|
|
38
|
+
export const seenEffectOptOut = (target, setFlag = true) => {
|
|
39
|
+
setFlag ? target.setAttribute(dataAttr, '') : target.removeAttribute(dataAttr);
|
|
40
|
+
};
|
|
41
|
+
getObserver.DATA_ATTR_NAME = DATA_ATTR_NAME;
|
|
42
|
+
// ---------------------------------------------------------------------------
|
|
43
|
+
// ---------------------------------------------------------------------------
|
|
44
|
+
const effects = {
|
|
45
|
+
fadein: 1,
|
|
46
|
+
fadeup: 1,
|
|
47
|
+
fadeleft: 1,
|
|
48
|
+
};
|
|
49
|
+
/** Asserts that a prop value is a SeenEffectType and returns undefined otherwise */
|
|
50
|
+
export const assertEffectType = (maybeType) => maybeType && maybeType in effects ? maybeType : undefined;
|
|
51
|
+
export const getEffectAttr = (maybeType) => ({
|
|
52
|
+
'data-seen-effect': assertEffectType(maybeType) || '',
|
|
53
|
+
});
|
|
54
|
+
export const useSeenEffect = (
|
|
55
|
+
/** Should the component appear instantly, and not transition-in once seen */
|
|
56
|
+
startSeen,
|
|
57
|
+
/** Bring Your Own RefObject */
|
|
58
|
+
customRef) => {
|
|
59
|
+
const localRef = useRef(null);
|
|
60
|
+
const [isSeen, setSeen] = useState(startSeen || undefined);
|
|
61
|
+
const ref = !startSeen && (customRef || localRef);
|
|
62
|
+
useEffect(() => {
|
|
63
|
+
setSeen(startSeen || undefined);
|
|
64
|
+
if (ref && ref.current) {
|
|
65
|
+
// NOTE: Given that `ref` is defined, then
|
|
66
|
+
// `startSeen` is implicily `false | undefined` at
|
|
67
|
+
// this point.
|
|
68
|
+
seenEffectOptOut(ref.current, false);
|
|
69
|
+
return getObserver(ref.current, () => setSeen(true));
|
|
70
|
+
}
|
|
71
|
+
}, [ref, startSeen]);
|
|
72
|
+
return [ref || undefined, isSeen];
|
|
73
|
+
};
|