@postenbring/hedwig-react 0.0.81 → 0.0.83
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/accordion/accordion-content.d.ts +6 -2
- package/dist/accordion/accordion-content.d.ts.map +1 -0
- package/dist/accordion/accordion-header.d.ts +6 -2
- package/dist/accordion/accordion-header.d.ts.map +1 -0
- package/dist/accordion/accordion-item.d.ts +24 -3
- package/dist/accordion/accordion-item.d.ts.map +1 -0
- package/dist/accordion/accordion.d.ts +44 -2
- package/dist/accordion/accordion.d.ts.map +1 -0
- package/dist/accordion/accordion.js +102 -4
- package/dist/accordion/accordion.js.map +1 -1
- package/dist/accordion/accordion.mjs +5 -1
- package/dist/accordion/context.d.ts +7 -2
- package/dist/accordion/context.d.ts.map +1 -0
- package/dist/accordion/index.d.ts +9 -9
- package/dist/accordion/index.d.ts.map +1 -0
- package/dist/accordion/index.js +52 -53
- package/dist/accordion/index.js.map +1 -1
- package/dist/accordion/index.mjs +7 -7
- package/dist/badge/badge.d.ts +21 -5
- package/dist/badge/badge.d.ts.map +1 -0
- package/dist/badge/index.d.ts +3 -6
- package/dist/badge/index.d.ts.map +1 -0
- package/dist/box/box.d.ts +50 -4
- package/dist/box/box.d.ts.map +1 -0
- package/dist/box/box.js +15 -14
- package/dist/box/box.js.map +1 -1
- package/dist/box/box.mjs +1 -1
- package/dist/box/index.d.ts +3 -4
- package/dist/box/index.d.ts.map +1 -0
- package/dist/box/index.js +16 -19
- package/dist/box/index.js.map +1 -1
- package/dist/box/index.mjs +4 -5
- package/dist/breadcrumbs/breadcrumbs.d.ts +33 -2
- package/dist/breadcrumbs/breadcrumbs.d.ts.map +1 -0
- package/dist/breadcrumbs/index.d.ts +3 -2
- package/dist/breadcrumbs/index.d.ts.map +1 -0
- package/dist/button/button.d.ts +33 -3
- package/dist/button/button.d.ts.map +1 -0
- package/dist/button/index.d.ts +3 -3
- package/dist/button/index.d.ts.map +1 -0
- package/dist/card/card.d.ts +69 -12
- package/dist/card/card.d.ts.map +1 -0
- package/dist/card/card.js +17 -6
- package/dist/card/card.js.map +1 -1
- package/dist/card/card.mjs +1 -1
- package/dist/card/index.d.ts +3 -12
- package/dist/card/index.d.ts.map +1 -0
- package/dist/card/index.js +18 -19
- package/dist/card/index.js.map +1 -1
- package/dist/card/index.mjs +4 -5
- package/dist/{chunk-6R7AXKBR.mjs → chunk-35TXKAUH.mjs} +2 -2
- package/dist/chunk-35TXKAUH.mjs.map +1 -0
- package/dist/{chunk-XC3UHH2U.mjs → chunk-3WVRY6CC.mjs} +4 -4
- package/dist/{chunk-XC3UHH2U.mjs.map → chunk-3WVRY6CC.mjs.map} +1 -1
- package/dist/{chunk-67TP3E2D.mjs → chunk-6FBPKLWB.mjs} +3 -3
- package/dist/chunk-6FBPKLWB.mjs.map +1 -0
- package/dist/chunk-7YWW46R3.mjs +1 -0
- package/dist/{chunk-ENKVTAJB.mjs → chunk-AJWSQEDP.mjs} +18 -17
- package/dist/chunk-AJWSQEDP.mjs.map +1 -0
- package/dist/chunk-ARHJZUZG.mjs +1 -0
- package/dist/{chunk-4WQWU5TL.mjs → chunk-AXQCREUJ.mjs} +2 -2
- package/dist/chunk-AXQCREUJ.mjs.map +1 -0
- package/dist/chunk-BCFV6VOE.mjs +1 -0
- package/dist/{chunk-F2C3KZFX.mjs → chunk-BVPSZ3JI.mjs} +2 -2
- package/dist/chunk-BVPSZ3JI.mjs.map +1 -0
- package/dist/{chunk-7JRS4WEB.mjs → chunk-C34HEQXO.mjs} +33 -29
- package/dist/chunk-C34HEQXO.mjs.map +1 -0
- package/dist/chunk-CYDWEPFL.mjs +1 -0
- package/dist/{chunk-PLXB3TNA.mjs → chunk-D7QPJIUZ.mjs} +5 -5
- package/dist/{chunk-PLXB3TNA.mjs.map → chunk-D7QPJIUZ.mjs.map} +1 -1
- package/dist/{chunk-GSJPTZT3.mjs → chunk-FC4CEI2V.mjs} +34 -19
- package/dist/chunk-FC4CEI2V.mjs.map +1 -0
- package/dist/chunk-FYFJ75NX.mjs +1 -0
- package/dist/chunk-FYFJ75NX.mjs.map +1 -0
- package/dist/chunk-G65EYZFQ.mjs +1 -0
- package/dist/chunk-G65EYZFQ.mjs.map +1 -0
- package/dist/chunk-H3E546OT.mjs +1 -0
- package/dist/chunk-H3E546OT.mjs.map +1 -0
- package/dist/chunk-HQVL3ZJ2.mjs +1 -0
- package/dist/chunk-HQVL3ZJ2.mjs.map +1 -0
- package/dist/{chunk-KPGSRU4I.mjs → chunk-M3Y3XOGC.mjs} +13 -1
- package/dist/chunk-M3Y3XOGC.mjs.map +1 -0
- package/dist/{chunk-CIHZDFSQ.mjs → chunk-NU6OSFAU.mjs} +20 -9
- package/dist/chunk-NU6OSFAU.mjs.map +1 -0
- package/dist/{chunk-XUWZ4HGD.mjs → chunk-OGZ2NBMH.mjs} +49 -46
- package/dist/chunk-OGZ2NBMH.mjs.map +1 -0
- package/dist/{chunk-3MQKXNZ6.mjs → chunk-QZZIOBF4.mjs} +13 -1
- package/dist/chunk-QZZIOBF4.mjs.map +1 -0
- package/dist/chunk-RC76SXBP.mjs +1 -0
- package/dist/chunk-RC76SXBP.mjs.map +1 -0
- package/dist/{chunk-TQDUBRCZ.mjs → chunk-SQ63E7KM.mjs} +24 -22
- package/dist/chunk-SQ63E7KM.mjs.map +1 -0
- package/dist/{chunk-DEX36MFK.mjs → chunk-TDXU2IC6.mjs} +3 -4
- package/dist/chunk-TDXU2IC6.mjs.map +1 -0
- package/dist/{chunk-ES6ISHOV.mjs → chunk-UP3M3NEZ.mjs} +14 -13
- package/dist/{chunk-ES6ISHOV.mjs.map → chunk-UP3M3NEZ.mjs.map} +1 -1
- package/dist/chunk-ZKMFJZSH.mjs +1 -0
- package/dist/chunk-ZKMFJZSH.mjs.map +1 -0
- package/dist/description-list/description-list.d.ts +42 -2
- package/dist/description-list/description-list.d.ts.map +1 -0
- package/dist/description-list/index.d.ts +3 -2
- package/dist/description-list/index.d.ts.map +1 -0
- package/dist/footer/footer.d.ts +67 -7
- package/dist/footer/footer.d.ts.map +1 -0
- package/dist/footer/footer.js +79 -76
- package/dist/footer/footer.js.map +1 -1
- package/dist/footer/footer.mjs +4 -4
- package/dist/footer/index.d.ts +3 -7
- package/dist/footer/index.d.ts.map +1 -0
- package/dist/footer/index.js +80 -84
- package/dist/footer/index.js.map +1 -1
- package/dist/footer/index.mjs +7 -8
- package/dist/form/checkbox/checkbox.d.ts +28 -2
- package/dist/form/checkbox/checkbox.d.ts.map +1 -0
- package/dist/form/checkbox/index.d.ts +3 -2
- package/dist/form/checkbox/index.d.ts.map +1 -0
- package/dist/form/date-picker/date-picker.d.ts +33 -2
- package/dist/form/date-picker/date-picker.d.ts.map +1 -0
- package/dist/form/date-picker/date-picker.js +1 -1
- package/dist/form/date-picker/date-picker.js.map +1 -1
- package/dist/form/date-picker/date-picker.mjs +2 -2
- package/dist/form/date-picker/index.d.ts +3 -2
- package/dist/form/date-picker/index.d.ts.map +1 -0
- package/dist/form/date-picker/index.js +1 -1
- package/dist/form/date-picker/index.js.map +1 -1
- package/dist/form/date-picker/index.mjs +2 -2
- package/dist/form/error-message/error-message.d.ts +8 -2
- package/dist/form/error-message/error-message.d.ts.map +1 -0
- package/dist/form/error-message/index.d.ts +3 -2
- package/dist/form/error-message/index.d.ts.map +1 -0
- package/dist/form/fieldset/fieldset.d.ts +22 -3
- package/dist/form/fieldset/fieldset.d.ts.map +1 -0
- package/dist/form/fieldset/index.d.ts +3 -3
- package/dist/form/fieldset/index.d.ts.map +1 -0
- package/dist/form/index.d.ts +9 -20
- package/dist/form/index.d.ts.map +1 -0
- package/dist/form/index.js +1 -1
- package/dist/form/index.js.map +1 -1
- package/dist/form/index.mjs +2 -2
- package/dist/form/input/index.d.ts +3 -2
- package/dist/form/input/index.d.ts.map +1 -0
- package/dist/form/input/input.d.ts +5 -2
- package/dist/form/input/input.d.ts.map +1 -0
- package/dist/form/input-group/index.d.ts +3 -2
- package/dist/form/input-group/index.d.ts.map +1 -0
- package/dist/form/input-group/input-group.d.ts +27 -2
- package/dist/form/input-group/input-group.d.ts.map +1 -0
- package/dist/form/radiobutton/index.d.ts +5 -5
- package/dist/form/radiobutton/index.d.ts.map +1 -0
- package/dist/form/radiobutton/radiobutton.d.ts +17 -2
- package/dist/form/radiobutton/radiobutton.d.ts.map +1 -0
- package/dist/form/radiobutton/radiogroup.d.ts +24 -3
- package/dist/form/radiobutton/radiogroup.d.ts.map +1 -0
- package/dist/form/select/index.d.ts +3 -2
- package/dist/form/select/index.d.ts.map +1 -0
- package/dist/form/select/select.d.ts +9 -2
- package/dist/form/select/select.d.ts.map +1 -0
- package/dist/form/textarea/index.d.ts +3 -2
- package/dist/form/textarea/index.d.ts.map +1 -0
- package/dist/form/textarea/textarea.d.ts +5 -2
- package/dist/form/textarea/textarea.d.ts.map +1 -0
- package/dist/help-text/help-text.d.ts +51 -1
- package/dist/help-text/help-text.d.ts.map +1 -0
- package/dist/help-text/help-text.js +17 -20
- package/dist/help-text/help-text.js.map +1 -1
- package/dist/help-text/help-text.mjs +3 -3
- package/dist/help-text/index.d.ts +3 -1
- package/dist/help-text/index.d.ts.map +1 -0
- package/dist/help-text/index.js +17 -20
- package/dist/help-text/index.js.map +1 -1
- package/dist/help-text/index.mjs +3 -3
- package/dist/index-no-css.d.ts +26 -128
- package/dist/index-no-css.d.ts.map +1 -0
- package/dist/index-no-css.js +385 -398
- package/dist/index-no-css.js.map +1 -1
- package/dist/index-no-css.mjs +70 -68
- package/dist/index.d.ts +11 -128
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +385 -398
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +70 -68
- package/dist/index.mjs.map +1 -1
- package/dist/layout/container/container.d.ts +23 -2
- package/dist/layout/container/container.d.ts.map +1 -0
- package/dist/layout/grid/grid.d.ts +101 -4
- package/dist/layout/grid/grid.d.ts.map +1 -0
- package/dist/layout/grid/grid.js +11 -10
- package/dist/layout/grid/grid.js.map +1 -1
- package/dist/layout/grid/grid.mjs +1 -1
- package/dist/layout/grid/index.d.ts +3 -4
- package/dist/layout/grid/index.d.ts.map +1 -0
- package/dist/layout/grid/index.js +12 -15
- package/dist/layout/grid/index.js.map +1 -1
- package/dist/layout/grid/index.mjs +4 -5
- package/dist/layout/index.d.ts +4 -10
- package/dist/layout/index.d.ts.map +1 -0
- package/dist/layout/index.js +12 -15
- package/dist/layout/index.js.map +1 -1
- package/dist/layout/index.mjs +4 -5
- package/dist/layout/responsive.d.ts +10 -2
- package/dist/layout/responsive.d.ts.map +1 -0
- package/dist/layout/spacing.d.ts +33 -3
- package/dist/layout/spacing.d.ts.map +1 -0
- package/dist/layout/stack/index.d.ts +3 -4
- package/dist/layout/stack/index.d.ts.map +1 -0
- package/dist/layout/stack/stack.d.ts +62 -4
- package/dist/layout/stack/stack.d.ts.map +1 -0
- package/dist/link/index.d.ts +3 -2
- package/dist/link/index.d.ts.map +1 -0
- package/dist/link/link.d.ts +20 -2
- package/dist/link/link.d.ts.map +1 -0
- package/dist/list/index.d.ts +5 -5
- package/dist/list/index.d.ts.map +1 -0
- package/dist/list/link-list.d.ts +12 -2
- package/dist/list/link-list.d.ts.map +1 -0
- package/dist/list/list.d.ts +40 -3
- package/dist/list/list.d.ts.map +1 -0
- package/dist/message/index.d.ts +3 -3
- package/dist/message/index.d.ts.map +1 -0
- package/dist/message/index.js +36 -38
- package/dist/message/index.js.map +1 -1
- package/dist/message/index.mjs +5 -6
- package/dist/message/message.d.ts +36 -4
- package/dist/message/message.d.ts.map +1 -0
- package/dist/message/message.js +35 -32
- package/dist/message/message.js.map +1 -1
- package/dist/message/message.mjs +2 -2
- package/dist/modal/index.d.ts +3 -5
- package/dist/modal/index.d.ts.map +1 -0
- package/dist/modal/index.js +61 -63
- package/dist/modal/index.js.map +1 -1
- package/dist/modal/index.mjs +6 -7
- package/dist/modal/modal.d.ts +81 -5
- package/dist/modal/modal.d.ts.map +1 -0
- package/dist/modal/modal.js +60 -56
- package/dist/modal/modal.js.map +1 -1
- package/dist/modal/modal.mjs +3 -3
- package/dist/navbar/icons.d.ts +3 -2
- package/dist/navbar/icons.d.ts.map +1 -0
- package/dist/navbar/index.d.ts +4 -13
- package/dist/navbar/index.d.ts.map +1 -0
- package/dist/navbar/index.js +145 -146
- package/dist/navbar/index.js.map +1 -1
- package/dist/navbar/index.mjs +6 -7
- package/dist/navbar/navbar-expandable-menu.d.ts +35 -7
- package/dist/navbar/navbar-expandable-menu.d.ts.map +1 -0
- package/dist/navbar/navbar-expandable-menu.js +1 -1
- package/dist/navbar/navbar-expandable-menu.js.map +1 -1
- package/dist/navbar/navbar-expandable-menu.mjs +2 -2
- package/dist/navbar/navbar.d.ts +130 -9
- package/dist/navbar/navbar.d.ts.map +1 -0
- package/dist/navbar/navbar.js +237 -28
- package/dist/navbar/navbar.js.map +1 -1
- package/dist/navbar/navbar.mjs +4 -1
- package/dist/show-more/index.d.ts +5 -4
- package/dist/show-more/index.d.ts.map +1 -0
- package/dist/show-more/index.js +3 -3
- package/dist/show-more/index.js.map +1 -1
- package/dist/show-more/index.mjs +2 -2
- package/dist/show-more/show-more.d.ts +42 -2
- package/dist/show-more/show-more.d.ts.map +1 -0
- package/dist/skeleton/index.d.ts +3 -2
- package/dist/skeleton/index.d.ts.map +1 -0
- package/dist/skeleton/skeleton.d.ts +67 -2
- package/dist/skeleton/skeleton.d.ts.map +1 -0
- package/dist/step-indicator/index.d.ts +3 -1
- package/dist/step-indicator/index.d.ts.map +1 -0
- package/dist/step-indicator/step-indicator.d.ts +36 -1
- package/dist/step-indicator/step-indicator.d.ts.map +1 -0
- package/dist/styled-html/index.d.ts +3 -2
- package/dist/styled-html/index.d.ts.map +1 -0
- package/dist/styled-html/styled-html.d.ts +36 -2
- package/dist/styled-html/styled-html.d.ts.map +1 -0
- package/dist/table/index.d.ts +3 -1
- package/dist/table/index.d.ts.map +1 -0
- package/dist/table/table.d.ts +25 -1
- package/dist/table/table.d.ts.map +1 -0
- package/dist/tabs/context.d.ts +8 -3
- package/dist/tabs/context.d.ts.map +1 -0
- package/dist/tabs/index.d.ts +7 -10
- package/dist/tabs/index.d.ts.map +1 -0
- package/dist/tabs/index.js +35 -38
- package/dist/tabs/index.js.map +1 -1
- package/dist/tabs/index.mjs +6 -6
- package/dist/tabs/tabs-content.d.ts +26 -4
- package/dist/tabs/tabs-content.d.ts.map +1 -0
- package/dist/tabs/tabs-list.d.ts +21 -4
- package/dist/tabs/tabs-list.d.ts.map +1 -0
- package/dist/tabs/tabs-list.js +1 -1
- package/dist/tabs/tabs-list.js.map +1 -1
- package/dist/tabs/tabs-list.mjs +2 -2
- package/dist/tabs/tabs.d.ts +26 -2
- package/dist/tabs/tabs.d.ts.map +1 -0
- package/dist/tabs/tabs.js +205 -8
- package/dist/tabs/tabs.js.map +1 -1
- package/dist/tabs/tabs.mjs +4 -1
- package/dist/text/index.d.ts +4 -2
- package/dist/text/index.d.ts.map +1 -0
- package/dist/text/text.d.ts +58 -2
- package/dist/text/text.d.ts.map +1 -0
- package/dist/utils/auto-animate-height.d.ts +33 -0
- package/dist/utils/auto-animate-height.d.ts.map +1 -0
- package/dist/{utilities → utils}/auto-animate-height.js +3 -3
- package/dist/utils/auto-animate-height.js.map +1 -0
- package/dist/utils/auto-animate-height.mjs +9 -0
- package/dist/utils/auto-animate-height.mjs.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/{utilities → utils}/index.js +81 -11
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/index.mjs +19 -0
- package/dist/utils/index.mjs.map +1 -0
- package/dist/utils/utils.d.ts +24 -0
- package/dist/utils/utils.d.ts.map +1 -0
- package/dist/{utils.js → utils/utils.js} +1 -3
- package/dist/utils/utils.js.map +1 -0
- package/dist/utils/utils.mjs +14 -0
- package/dist/utils/utils.mjs.map +1 -0
- package/dist/warning-banner/index.d.ts +3 -2
- package/dist/warning-banner/index.d.ts.map +1 -0
- package/dist/warning-banner/index.js +16 -19
- package/dist/warning-banner/index.js.map +1 -1
- package/dist/warning-banner/index.mjs +3 -3
- package/dist/warning-banner/warning-banner.d.ts +8 -2
- package/dist/warning-banner/warning-banner.d.ts.map +1 -0
- package/dist/warning-banner/warning-banner.js +16 -19
- package/dist/warning-banner/warning-banner.js.map +1 -1
- package/dist/warning-banner/warning-banner.mjs +3 -3
- package/package.json +12 -8
- package/src/accordion/accordion-content.tsx +31 -0
- package/src/accordion/accordion-header.tsx +36 -0
- package/src/accordion/accordion-item.tsx +62 -0
- package/src/accordion/accordion.stories.tsx +154 -0
- package/src/accordion/accordion.tsx +68 -0
- package/src/accordion/context.ts +8 -0
- package/src/accordion/index.tsx +9 -0
- package/src/badge/badge.stories.tsx +44 -0
- package/src/badge/badge.tsx +63 -0
- package/src/badge/index.tsx +3 -0
- package/src/box/box.stories.tsx +112 -0
- package/src/box/box.tsx +122 -0
- package/src/box/index.tsx +3 -0
- package/src/breadcrumbs/breadcrumbs.stories.tsx +50 -0
- package/src/breadcrumbs/breadcrumbs.tsx +47 -0
- package/src/breadcrumbs/index.tsx +3 -0
- package/src/button/button.stories.tsx +104 -0
- package/src/button/button.tsx +87 -0
- package/src/button/index.tsx +3 -0
- package/src/card/card.stories.tsx +82 -0
- package/src/card/card.tsx +222 -0
- package/src/card/index.tsx +14 -0
- package/src/description-list/description-list.stories.tsx +95 -0
- package/src/description-list/description-list.tsx +61 -0
- package/src/description-list/index.tsx +2 -0
- package/src/footer/footer.tsx +169 -0
- package/src/footer/index.tsx +9 -0
- package/src/form/checkbox/checkbox.stories.tsx +104 -0
- package/src/form/checkbox/checkbox.tsx +82 -0
- package/src/form/checkbox/index.tsx +2 -0
- package/src/form/date-picker/date-picker.stories.tsx +27 -0
- package/src/form/date-picker/date-picker.tsx +85 -0
- package/src/form/date-picker/index.tsx +2 -0
- package/src/form/error-message/error-message.stories.tsx +19 -0
- package/src/form/error-message/error-message.tsx +25 -0
- package/src/form/error-message/index.tsx +2 -0
- package/src/form/fieldset/fieldset.stories.tsx +86 -0
- package/src/form/fieldset/fieldset.tsx +64 -0
- package/src/form/fieldset/index.tsx +2 -0
- package/src/form/index.tsx +8 -0
- package/src/form/input/index.tsx +2 -0
- package/src/form/input/input.stories.tsx +166 -0
- package/src/form/input/input.tsx +30 -0
- package/src/form/input-group/index.tsx +2 -0
- package/src/form/input-group/input-group.tsx +106 -0
- package/src/form/radiobutton/index.tsx +4 -0
- package/src/form/radiobutton/radiobutton.stories.tsx +93 -0
- package/src/form/radiobutton/radiobutton.tsx +85 -0
- package/src/form/radiobutton/radiogroup.stories.tsx +39 -0
- package/src/form/radiobutton/radiogroup.tsx +52 -0
- package/src/form/select/index.tsx +2 -0
- package/src/form/select/select.stories.tsx +93 -0
- package/src/form/select/select.tsx +33 -0
- package/src/form/textarea/index.tsx +2 -0
- package/src/form/textarea/textarea.stories.tsx +106 -0
- package/src/form/textarea/textarea.tsx +33 -0
- package/src/help-text/help-text.tsx +98 -0
- package/src/help-text/index.ts +2 -0
- package/src/index-no-css.tsx +25 -0
- package/src/index.tsx +11 -0
- package/src/layout/container/container.stories.tsx +62 -0
- package/src/layout/container/container.tsx +47 -0
- package/src/layout/grid/grid.tsx +163 -0
- package/src/layout/grid/index.tsx +3 -0
- package/src/layout/index.tsx +3 -0
- package/src/layout/responsive.ts +26 -0
- package/src/layout/spacing.ts +37 -0
- package/src/layout/stack/index.tsx +2 -0
- package/src/layout/stack/stack.tsx +128 -0
- package/src/link/index.tsx +3 -0
- package/src/link/link.stories.tsx +64 -0
- package/src/link/link.tsx +46 -0
- package/src/list/index.tsx +5 -0
- package/src/list/link-list.stories.tsx +38 -0
- package/src/list/link-list.tsx +26 -0
- package/src/list/list.stories.tsx +71 -0
- package/src/list/list.tsx +65 -0
- package/src/message/index.tsx +2 -0
- package/src/message/message.stories.tsx +93 -0
- package/src/message/message.tsx +89 -0
- package/src/modal/index.tsx +3 -0
- package/src/modal/modal.stories.tsx +147 -0
- package/src/modal/modal.tsx +199 -0
- package/src/navbar/icons.tsx +21 -0
- package/src/navbar/index.tsx +18 -0
- package/src/navbar/navbar-expandable-menu.tsx +176 -0
- package/src/navbar/navbar.stories.tsx +99 -0
- package/src/navbar/navbar.tsx +264 -0
- package/src/show-more/index.ts +5 -0
- package/src/show-more/show-more.stories.tsx +119 -0
- package/src/show-more/show-more.tsx +66 -0
- package/src/skeleton/index.ts +2 -0
- package/src/skeleton/skeleton.stories.tsx +152 -0
- package/src/skeleton/skeleton.tsx +114 -0
- package/src/step-indicator/index.ts +2 -0
- package/src/step-indicator/step-indicator.stories.tsx +50 -0
- package/src/step-indicator/step-indicator.tsx +116 -0
- package/src/styled-html/index.ts +2 -0
- package/src/styled-html/styled-html.stories.tsx +189 -0
- package/src/styled-html/styled-html.tsx +59 -0
- package/src/table/index.ts +2 -0
- package/src/table/table.tsx +59 -0
- package/src/tabs/context.ts +18 -0
- package/src/tabs/index.tsx +7 -0
- package/src/tabs/tabs-content.tsx +62 -0
- package/src/tabs/tabs-list.tsx +129 -0
- package/src/tabs/tabs.stories.tsx +138 -0
- package/src/tabs/tabs.tsx +50 -0
- package/src/text/index.tsx +4 -0
- package/src/text/text.stories.tsx +112 -0
- package/src/text/text.tsx +129 -0
- package/src/utils/auto-animate-height.tsx +139 -0
- package/src/utils/index.ts +4 -0
- package/src/utils/utils.ts +110 -0
- package/src/warning-banner/index.tsx +2 -0
- package/src/warning-banner/warning-banner.stories.tsx +43 -0
- package/src/warning-banner/warning-banner.tsx +79 -0
- package/dist/_tsup-dts-rollup.d.mts +0 -2600
- package/dist/_tsup-dts-rollup.d.ts +0 -2600
- package/dist/accordion/accordion-content.d.mts +0 -2
- package/dist/accordion/accordion-header.d.mts +0 -2
- package/dist/accordion/accordion-item.d.mts +0 -3
- package/dist/accordion/accordion.d.mts +0 -2
- package/dist/accordion/context.d.mts +0 -2
- package/dist/accordion/index.d.mts +0 -9
- package/dist/badge/badge.d.mts +0 -5
- package/dist/badge/index.d.mts +0 -6
- package/dist/box/box.d.mts +0 -4
- package/dist/box/index.d.mts +0 -4
- package/dist/breadcrumbs/breadcrumbs.d.mts +0 -2
- package/dist/breadcrumbs/index.d.mts +0 -2
- package/dist/button/button.d.mts +0 -3
- package/dist/button/index.d.mts +0 -3
- package/dist/card/card.d.mts +0 -12
- package/dist/card/index.d.mts +0 -12
- package/dist/chunk-3MQKXNZ6.mjs.map +0 -1
- package/dist/chunk-3NDUE23B.mjs +0 -19
- package/dist/chunk-3NDUE23B.mjs.map +0 -1
- package/dist/chunk-3NL3TOZF.mjs +0 -13
- package/dist/chunk-3NL3TOZF.mjs.map +0 -1
- package/dist/chunk-3ZFEUABU.mjs +0 -23
- package/dist/chunk-3ZFEUABU.mjs.map +0 -1
- package/dist/chunk-4WQWU5TL.mjs.map +0 -1
- package/dist/chunk-67TP3E2D.mjs.map +0 -1
- package/dist/chunk-6R7AXKBR.mjs.map +0 -1
- package/dist/chunk-722MZPXO.mjs +0 -13
- package/dist/chunk-722MZPXO.mjs.map +0 -1
- package/dist/chunk-7JRS4WEB.mjs.map +0 -1
- package/dist/chunk-CIHZDFSQ.mjs.map +0 -1
- package/dist/chunk-CYEYGPRH.mjs +0 -17
- package/dist/chunk-CYEYGPRH.mjs.map +0 -1
- package/dist/chunk-DEX36MFK.mjs.map +0 -1
- package/dist/chunk-DZNH5JHY.mjs +0 -1
- package/dist/chunk-ENKVTAJB.mjs.map +0 -1
- package/dist/chunk-F2C3KZFX.mjs.map +0 -1
- package/dist/chunk-GSJPTZT3.mjs.map +0 -1
- package/dist/chunk-IJAX6APL.mjs +0 -23
- package/dist/chunk-IJAX6APL.mjs.map +0 -1
- package/dist/chunk-IKJJWKXM.mjs +0 -15
- package/dist/chunk-IKJJWKXM.mjs.map +0 -1
- package/dist/chunk-KPGSRU4I.mjs.map +0 -1
- package/dist/chunk-PT5H3QV6.mjs +0 -29
- package/dist/chunk-PT5H3QV6.mjs.map +0 -1
- package/dist/chunk-TQDUBRCZ.mjs.map +0 -1
- package/dist/chunk-V6UKKHKD.mjs +0 -33
- package/dist/chunk-V6UKKHKD.mjs.map +0 -1
- package/dist/chunk-XUWZ4HGD.mjs.map +0 -1
- package/dist/description-list/description-list.d.mts +0 -2
- package/dist/description-list/index.d.mts +0 -2
- package/dist/footer/footer.d.mts +0 -7
- package/dist/footer/index.d.mts +0 -7
- package/dist/form/checkbox/checkbox.d.mts +0 -2
- package/dist/form/checkbox/index.d.mts +0 -2
- package/dist/form/date-picker/date-picker.d.mts +0 -2
- package/dist/form/date-picker/index.d.mts +0 -2
- package/dist/form/error-message/error-message.d.mts +0 -2
- package/dist/form/error-message/index.d.mts +0 -2
- package/dist/form/fieldset/fieldset.d.mts +0 -3
- package/dist/form/fieldset/index.d.mts +0 -3
- package/dist/form/index.d.mts +0 -20
- package/dist/form/input/index.d.mts +0 -2
- package/dist/form/input/input.d.mts +0 -2
- package/dist/form/input-group/index.d.mts +0 -2
- package/dist/form/input-group/input-group.d.mts +0 -2
- package/dist/form/radiobutton/index.d.mts +0 -5
- package/dist/form/radiobutton/radiobutton.d.mts +0 -2
- package/dist/form/radiobutton/radiogroup.d.mts +0 -3
- package/dist/form/select/index.d.mts +0 -2
- package/dist/form/select/select.d.mts +0 -2
- package/dist/form/textarea/index.d.mts +0 -2
- package/dist/form/textarea/textarea.d.mts +0 -2
- package/dist/help-text/help-text.d.mts +0 -1
- package/dist/help-text/index.d.mts +0 -1
- package/dist/index-no-css.d.mts +0 -128
- package/dist/index.d.mts +0 -128
- package/dist/layout/container/container.d.mts +0 -2
- package/dist/layout/grid/grid.d.mts +0 -4
- package/dist/layout/grid/index.d.mts +0 -4
- package/dist/layout/index.d.mts +0 -10
- package/dist/layout/responsive.d.mts +0 -2
- package/dist/layout/spacing.d.mts +0 -3
- package/dist/layout/stack/index.d.mts +0 -4
- package/dist/layout/stack/stack.d.mts +0 -4
- package/dist/link/index.d.mts +0 -2
- package/dist/link/link.d.mts +0 -2
- package/dist/list/index.d.mts +0 -5
- package/dist/list/link-list.d.mts +0 -2
- package/dist/list/list.d.mts +0 -3
- package/dist/message/index.d.mts +0 -3
- package/dist/message/message.d.mts +0 -4
- package/dist/modal/index.d.mts +0 -5
- package/dist/modal/modal.d.mts +0 -5
- package/dist/navbar/icons.d.mts +0 -2
- package/dist/navbar/index.d.mts +0 -13
- package/dist/navbar/navbar-expandable-menu.d.mts +0 -7
- package/dist/navbar/navbar.d.mts +0 -9
- package/dist/show-more/index.d.mts +0 -4
- package/dist/show-more/show-more.d.mts +0 -2
- package/dist/skeleton/index.d.mts +0 -2
- package/dist/skeleton/skeleton.d.mts +0 -2
- package/dist/step-indicator/index.d.mts +0 -1
- package/dist/step-indicator/step-indicator.d.mts +0 -1
- package/dist/styled-html/index.d.mts +0 -2
- package/dist/styled-html/styled-html.d.mts +0 -2
- package/dist/table/index.d.mts +0 -1
- package/dist/table/table.d.mts +0 -1
- package/dist/tabs/context.d.mts +0 -3
- package/dist/tabs/index.d.mts +0 -10
- package/dist/tabs/tabs-content.d.mts +0 -4
- package/dist/tabs/tabs-list.d.mts +0 -4
- package/dist/tabs/tabs.d.mts +0 -2
- package/dist/text/index.d.mts +0 -2
- package/dist/text/text.d.mts +0 -2
- package/dist/utilities/auto-animate-height.d.mts +0 -2
- package/dist/utilities/auto-animate-height.d.ts +0 -2
- package/dist/utilities/auto-animate-height.js.map +0 -1
- package/dist/utilities/auto-animate-height.mjs +0 -9
- package/dist/utilities/index.d.mts +0 -2
- package/dist/utilities/index.d.ts +0 -2
- package/dist/utilities/index.js.map +0 -1
- package/dist/utilities/index.mjs +0 -10
- package/dist/utils.d.mts +0 -5
- package/dist/utils.d.ts +0 -5
- package/dist/utils.js.map +0 -1
- package/dist/utils.mjs +0 -16
- package/dist/warning-banner/index.d.mts +0 -2
- package/dist/warning-banner/warning-banner.d.mts +0 -2
- /package/dist/{chunk-DZNH5JHY.mjs.map → chunk-7YWW46R3.mjs.map} +0 -0
- /package/dist/{utilities/auto-animate-height.mjs.map → chunk-ARHJZUZG.mjs.map} +0 -0
- /package/dist/{utilities/index.mjs.map → chunk-BCFV6VOE.mjs.map} +0 -0
- /package/dist/{utils.mjs.map → chunk-CYDWEPFL.mjs.map} +0 -0
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-unsafe-assignment -- Typings for the differnt html elements */
|
|
2
|
+
/* eslint-disable @typescript-eslint/no-explicit-any -- Typings for the differnt html elements */
|
|
3
|
+
|
|
4
|
+
import { clsx } from "@postenbring/hedwig-css/typed-classname";
|
|
5
|
+
import { Slot } from "@radix-ui/react-slot";
|
|
6
|
+
import { forwardRef } from "react";
|
|
7
|
+
|
|
8
|
+
interface DimensionsFromWidthAndHeight {
|
|
9
|
+
height?: number | string;
|
|
10
|
+
width?: number | string;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
interface SkeletonPropsInner extends React.HTMLAttributes<HTMLDivElement> {
|
|
14
|
+
/**
|
|
15
|
+
* The visual style of the Skeleton
|
|
16
|
+
*/
|
|
17
|
+
variant?: "text" | "circle" | "rectangle" | "rounded";
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* Whether to show animation or not
|
|
21
|
+
* In the future the animation effect might become configurable
|
|
22
|
+
*
|
|
23
|
+
* default true
|
|
24
|
+
*/
|
|
25
|
+
animation?: boolean;
|
|
26
|
+
|
|
27
|
+
children?: React.ReactNode;
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Change the default rendered element for the one passed as a child, merging their props and behavior.
|
|
31
|
+
*
|
|
32
|
+
* @default false
|
|
33
|
+
*/
|
|
34
|
+
asChild?: boolean;
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Convienence prop to change the rendered element.
|
|
38
|
+
*
|
|
39
|
+
* Use {@link SkeletonProps.asChild} if you need more control of the rendered element.
|
|
40
|
+
*/
|
|
41
|
+
as?: "h1" | "h2" | "h3" | "h4" | "h5" | "h6" | "span" | "div" | "label" | "p";
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export type SkeletonProps = SkeletonPropsInner & DimensionsFromWidthAndHeight;
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Make skeleton loading states as placeholders for your content while waiting for data to load.
|
|
48
|
+
*
|
|
49
|
+
* **Note**
|
|
50
|
+
*
|
|
51
|
+
* Consider if this is really needed. The best experience is to avoid loading states altogether.
|
|
52
|
+
* If your loading takes under 1 second, it better to not show anything at all.
|
|
53
|
+
*
|
|
54
|
+
* - Make your backend faster
|
|
55
|
+
* - Preload/prefetch data
|
|
56
|
+
* - Avoid data loading waterfalls
|
|
57
|
+
* - Use optimistic ui when doing mutations
|
|
58
|
+
*
|
|
59
|
+
* **Usage**
|
|
60
|
+
*
|
|
61
|
+
* ```tsx
|
|
62
|
+
* <Skeleton variant="circle" width="2rem" height="2rem" />
|
|
63
|
+
* <Skeleton variant="text" />
|
|
64
|
+
* <Skeleton variant="text" width="80%" />
|
|
65
|
+
* <Skeleton variant="text">Uses content to determine width</Skeleton>
|
|
66
|
+
* <Skeleton variant="rectangle" width="300px" height="400px" />
|
|
67
|
+
* ```
|
|
68
|
+
*
|
|
69
|
+
* Remember to set `aria-hidden` on top level components you use that are not the `Skeleton` component.
|
|
70
|
+
*
|
|
71
|
+
* The `Skeleton` component does this for it self, but if you are using other components higher up in the tree, it might cause problems with screen readers
|
|
72
|
+
*
|
|
73
|
+
* **References**
|
|
74
|
+
* - https://aksel.nav.no/komponenter/core/skeleton
|
|
75
|
+
* - https://chakra-ui.com/docs/components/skeleton
|
|
76
|
+
* - https://mui.com/material-ui/react-skeleton/
|
|
77
|
+
*/
|
|
78
|
+
export const Skeleton = forwardRef<HTMLDivElement, SkeletonProps>(
|
|
79
|
+
(
|
|
80
|
+
{
|
|
81
|
+
as: Tag = "div",
|
|
82
|
+
asChild,
|
|
83
|
+
children,
|
|
84
|
+
animation = true,
|
|
85
|
+
variant = "text",
|
|
86
|
+
width,
|
|
87
|
+
height,
|
|
88
|
+
className,
|
|
89
|
+
style,
|
|
90
|
+
...rest
|
|
91
|
+
},
|
|
92
|
+
ref,
|
|
93
|
+
) => {
|
|
94
|
+
const Component = asChild ? Slot : Tag;
|
|
95
|
+
return (
|
|
96
|
+
<Component
|
|
97
|
+
className={clsx(
|
|
98
|
+
"hds-skeleton",
|
|
99
|
+
`hds-skeleton--${variant}`,
|
|
100
|
+
!animation && `hds-skeleton--no-animation`,
|
|
101
|
+
className as undefined,
|
|
102
|
+
)}
|
|
103
|
+
style={{ ...style, width, height }}
|
|
104
|
+
aria-hidden
|
|
105
|
+
{...{ inert: "true" }}
|
|
106
|
+
ref={ref as any}
|
|
107
|
+
{...(rest as any)}
|
|
108
|
+
>
|
|
109
|
+
{children}
|
|
110
|
+
</Component>
|
|
111
|
+
);
|
|
112
|
+
},
|
|
113
|
+
);
|
|
114
|
+
Skeleton.displayName = "Skeleton";
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/* eslint-disable import/no-extraneous-dependencies -- storybook story */
|
|
2
|
+
import type { Meta, StoryObj } from "@storybook/react";
|
|
3
|
+
import { Badge } from "../badge";
|
|
4
|
+
import { StepIndicator } from ".";
|
|
5
|
+
|
|
6
|
+
const meta: Meta<typeof StepIndicator> = {
|
|
7
|
+
title: "Step indicator",
|
|
8
|
+
component: StepIndicator,
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export default meta;
|
|
12
|
+
|
|
13
|
+
type Story = StoryObj<typeof StepIndicator>;
|
|
14
|
+
|
|
15
|
+
export const Default: Story = {
|
|
16
|
+
args: {
|
|
17
|
+
label: "Progress name",
|
|
18
|
+
totalSteps: 5,
|
|
19
|
+
activeStep: 2,
|
|
20
|
+
},
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
export const Title: Story = {
|
|
24
|
+
args: {
|
|
25
|
+
activeStep: 2,
|
|
26
|
+
label: "Pakke til utlandet",
|
|
27
|
+
lang: "no",
|
|
28
|
+
totalSteps: 5,
|
|
29
|
+
title: "Hvem sender pakken?",
|
|
30
|
+
titleAs: "h2",
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
export const WithBadgeInLabel: Story = {
|
|
35
|
+
args: {
|
|
36
|
+
activeStep: 2,
|
|
37
|
+
label: (
|
|
38
|
+
<>
|
|
39
|
+
Norgespakke™ liten
|
|
40
|
+
<Badge size="smaller" style={{ marginLeft: "var(--hds-spacing-12)" }}>
|
|
41
|
+
73,-
|
|
42
|
+
</Badge>
|
|
43
|
+
</>
|
|
44
|
+
),
|
|
45
|
+
lang: "no",
|
|
46
|
+
totalSteps: 5,
|
|
47
|
+
title: "Størrelse og vekt",
|
|
48
|
+
titleAs: "h2",
|
|
49
|
+
},
|
|
50
|
+
};
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { clsx } from "@postenbring/hedwig-css/typed-classname";
|
|
2
|
+
import { forwardRef } from "react";
|
|
3
|
+
|
|
4
|
+
type TitleProps =
|
|
5
|
+
| {
|
|
6
|
+
/**
|
|
7
|
+
* Optional title of the active step to be shown underneath the step indicator
|
|
8
|
+
*
|
|
9
|
+
* Use `titleAs` to set the correct heading level
|
|
10
|
+
*/
|
|
11
|
+
title: React.ReactNode;
|
|
12
|
+
titleAs: "h1" | "h2" | "h3" | "h4" | "h5" | "h6";
|
|
13
|
+
}
|
|
14
|
+
| {
|
|
15
|
+
title?: undefined;
|
|
16
|
+
titleAs?: undefined;
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
interface StepIndicatorProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
20
|
+
/*
|
|
21
|
+
* 1-indexed number of the active step
|
|
22
|
+
*/
|
|
23
|
+
activeStep: number;
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* 1-indexed number of steps
|
|
27
|
+
*/
|
|
28
|
+
totalSteps: number;
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Label on the left side above the steps
|
|
32
|
+
*/
|
|
33
|
+
label: React.ReactNode;
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Language for the "step x of y" label, default is "en"
|
|
37
|
+
*/
|
|
38
|
+
lang?: "no" | "en" | "da" | "sv";
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Indicate a step in a process.
|
|
43
|
+
*
|
|
44
|
+
* It does not handle step content or navigation, only the visual indication of the active step.
|
|
45
|
+
*/
|
|
46
|
+
export const StepIndicator = forwardRef<HTMLDivElement, StepIndicatorProps & TitleProps>(
|
|
47
|
+
(
|
|
48
|
+
{
|
|
49
|
+
activeStep,
|
|
50
|
+
totalSteps,
|
|
51
|
+
className,
|
|
52
|
+
label,
|
|
53
|
+
lang = "en",
|
|
54
|
+
title,
|
|
55
|
+
titleAs: TitleComponent,
|
|
56
|
+
...rest
|
|
57
|
+
},
|
|
58
|
+
ref,
|
|
59
|
+
) => {
|
|
60
|
+
return (
|
|
61
|
+
<div
|
|
62
|
+
ref={ref}
|
|
63
|
+
className={clsx("hds-step-indicator", className as undefined)}
|
|
64
|
+
lang={lang}
|
|
65
|
+
{...rest}
|
|
66
|
+
>
|
|
67
|
+
<div className={clsx("hds-step-indicator__header")}>
|
|
68
|
+
<span className={clsx("hds-step-indicator__left-label")}>{label}</span>
|
|
69
|
+
<span>{stepLabelTranslations[lang](activeStep, totalSteps)}</span>
|
|
70
|
+
</div>
|
|
71
|
+
|
|
72
|
+
<div className={clsx("hds-step-indicator__steps")}>
|
|
73
|
+
{Array.from({ length: totalSteps }, (_, i) => (
|
|
74
|
+
<div
|
|
75
|
+
className={clsx("hds-step-indicator__step")}
|
|
76
|
+
data-state={getStepState(i + 1, activeStep)}
|
|
77
|
+
key={i}
|
|
78
|
+
/>
|
|
79
|
+
))}
|
|
80
|
+
</div>
|
|
81
|
+
|
|
82
|
+
{title ? (
|
|
83
|
+
<TitleComponent className={clsx("hds-step-indicator__title")}>{title}</TitleComponent>
|
|
84
|
+
) : null}
|
|
85
|
+
</div>
|
|
86
|
+
);
|
|
87
|
+
},
|
|
88
|
+
);
|
|
89
|
+
StepIndicator.displayName = "StepIndicator";
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Translated texts for the `step x of y` label.
|
|
93
|
+
*/
|
|
94
|
+
const stepLabelTranslations: Record<
|
|
95
|
+
"no" | "en" | "da" | "sv",
|
|
96
|
+
(activeStep: number, totalSteps: number) => string
|
|
97
|
+
> = {
|
|
98
|
+
no: (activeStep: number, totalSteps: number) => `steg ${activeStep} av ${totalSteps}`,
|
|
99
|
+
en: (activeStep: number, totalSteps: number) => `step ${activeStep} of ${totalSteps}`,
|
|
100
|
+
da: (activeStep: number, totalSteps: number) => `trin ${activeStep} af ${totalSteps}`,
|
|
101
|
+
sv: (activeStep: number, totalSteps: number) => `steg ${activeStep} av ${totalSteps}`,
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
/**
|
|
105
|
+
* Determine the state of a step.
|
|
106
|
+
* 1-indexed
|
|
107
|
+
*/
|
|
108
|
+
function getStepState(renderedStep: number, activeStep: number) {
|
|
109
|
+
if (renderedStep < activeStep) {
|
|
110
|
+
return "previous";
|
|
111
|
+
}
|
|
112
|
+
if (renderedStep === activeStep) {
|
|
113
|
+
return "active";
|
|
114
|
+
}
|
|
115
|
+
return "next";
|
|
116
|
+
}
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
/* eslint-disable import/no-extraneous-dependencies -- storybook story */
|
|
2
|
+
import type { Meta, StoryObj } from "@storybook/react";
|
|
3
|
+
import { StyledHtml } from ".";
|
|
4
|
+
|
|
5
|
+
const meta: Meta<typeof StyledHtml> = {
|
|
6
|
+
title: "Styled Html",
|
|
7
|
+
component: StyledHtml,
|
|
8
|
+
args: {
|
|
9
|
+
children: (
|
|
10
|
+
<>
|
|
11
|
+
<h1>Hello</h1>
|
|
12
|
+
<h2>Hello</h2>
|
|
13
|
+
|
|
14
|
+
<a href="https://www.postenbring.no">Postenbring</a>
|
|
15
|
+
|
|
16
|
+
<ul>
|
|
17
|
+
<li>Hei</li>
|
|
18
|
+
<li>Hallo</li>
|
|
19
|
+
<li>Hello</li>
|
|
20
|
+
</ul>
|
|
21
|
+
|
|
22
|
+
<ol>
|
|
23
|
+
<li>En</li>
|
|
24
|
+
<li>To</li>
|
|
25
|
+
<li>Tre</li>
|
|
26
|
+
</ol>
|
|
27
|
+
</>
|
|
28
|
+
),
|
|
29
|
+
},
|
|
30
|
+
argTypes: {
|
|
31
|
+
size: {
|
|
32
|
+
defaultValue: "default",
|
|
33
|
+
options: ["default", "small"],
|
|
34
|
+
control: {
|
|
35
|
+
type: "radio",
|
|
36
|
+
},
|
|
37
|
+
darkmode: {
|
|
38
|
+
defaultValue: false,
|
|
39
|
+
options: [true, false],
|
|
40
|
+
control: {
|
|
41
|
+
type: "radio",
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
},
|
|
45
|
+
},
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
export default meta;
|
|
49
|
+
|
|
50
|
+
type Story = StoryObj<typeof StyledHtml>;
|
|
51
|
+
export const Default: Story = {
|
|
52
|
+
args: {},
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
export const Darkmode: Story = {
|
|
56
|
+
args: {
|
|
57
|
+
darkmode: true,
|
|
58
|
+
},
|
|
59
|
+
parameters: {
|
|
60
|
+
backgrounds: { default: "dark" },
|
|
61
|
+
},
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
export const Small: Story = {
|
|
65
|
+
args: {
|
|
66
|
+
size: "small",
|
|
67
|
+
},
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
export const DarkmodeSmall: Story = {
|
|
71
|
+
args: {
|
|
72
|
+
darkmode: true,
|
|
73
|
+
size: "small",
|
|
74
|
+
},
|
|
75
|
+
parameters: {
|
|
76
|
+
backgrounds: { default: "dark" },
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
export const ArticleContent: Story = {
|
|
81
|
+
render: () => (
|
|
82
|
+
<StyledHtml>
|
|
83
|
+
<p>
|
|
84
|
+
Pakkeboksene er selvbetjente, og er plassert slik at de er mulig å bruke hele døgnet. Du
|
|
85
|
+
trenger bare mobilen din og Posten-appen for å åpne lukene.
|
|
86
|
+
</p>
|
|
87
|
+
|
|
88
|
+
<p>
|
|
89
|
+
Akkurat nå er det satt ut pakkebokser over 1800 steder i landet, og fremover vil det komme
|
|
90
|
+
enda flere.
|
|
91
|
+
</p>
|
|
92
|
+
|
|
93
|
+
<p>
|
|
94
|
+
<a href="/motta/fleksibelt/pakkeboks" title="Les mer og finn Pakkeboks">
|
|
95
|
+
Her kan du finne din nærmeste Pakkeboks
|
|
96
|
+
</a>
|
|
97
|
+
</p>
|
|
98
|
+
|
|
99
|
+
<h1 className="hds-text-h3">Slik bruker du Pakkeboks:</h1>
|
|
100
|
+
|
|
101
|
+
<p>
|
|
102
|
+
For å bruke pakkeboksene må du
|
|
103
|
+
<a href="/posten-app" target="_blank" title="Last ned Posten-appen">
|
|
104
|
+
laste ned Posten-appen
|
|
105
|
+
</a>
|
|
106
|
+
på mobilen din. Med appen kan du:
|
|
107
|
+
</p>
|
|
108
|
+
|
|
109
|
+
<ul>
|
|
110
|
+
<li>Åpne luke for å hente pakke</li>
|
|
111
|
+
<li>Reservere og åpne luke når du skal sende pakke</li>
|
|
112
|
+
<li>Velge om du vil ha pakker kun levert i de midterste lukene</li>
|
|
113
|
+
<li>Dele pakkene dine med andre, slik at de kan hente eller sende dem for deg</li>
|
|
114
|
+
</ul>
|
|
115
|
+
|
|
116
|
+
<h2>Hente pakker</h2>
|
|
117
|
+
|
|
118
|
+
<p>
|
|
119
|
+
Du får varsel i Posten-appen når du har en pakke som skal hentes i Pakkeboks. Slik gjør du:
|
|
120
|
+
</p>
|
|
121
|
+
|
|
122
|
+
<ul>
|
|
123
|
+
<li>Stå ved pakkeboksen og åpne appen. Husk å ha på Bluetooth</li>
|
|
124
|
+
<li>Appen kobler til riktig boks, og viser hvilken luke pakken din er i</li>
|
|
125
|
+
<li>Trykk på Åpne luke, og ta ut pakken din.</li>
|
|
126
|
+
<li>Steng luken og lukk appen</li>
|
|
127
|
+
</ul>
|
|
128
|
+
|
|
129
|
+
<h2>Velge høyde på luke</h2>
|
|
130
|
+
|
|
131
|
+
<p>Slik velger du at du vil ha pakkene kun i midterste luker:</p>
|
|
132
|
+
|
|
133
|
+
<ul>
|
|
134
|
+
<li>Du må ha nyeste versjon av Posten-appen</li>
|
|
135
|
+
<li>Åpne appen, og trykk på «Profil»</li>
|
|
136
|
+
<li>Velg «Levering i Pakkeboks», deretter «Luker på midten»</li>
|
|
137
|
+
<li>Lagre valget ditt</li>
|
|
138
|
+
</ul>
|
|
139
|
+
|
|
140
|
+
<h2>Sende fra Pakkeboks</h2>
|
|
141
|
+
|
|
142
|
+
<p>
|
|
143
|
+
Nå kan du bruke Posten-appen for å reservere luker i pakkeboksen når du skal sende{" "}
|
|
144
|
+
<a
|
|
145
|
+
href="/sende/i-norge/norgespakke/norgespakke-0-5-kg"
|
|
146
|
+
target="_blank"
|
|
147
|
+
title="Les mer om Norgespakke™ liten"
|
|
148
|
+
>
|
|
149
|
+
Norgespakke™ liten
|
|
150
|
+
</a>
|
|
151
|
+
.
|
|
152
|
+
</p>
|
|
153
|
+
|
|
154
|
+
<p>Slik reserverer du luke for å sende pakke:</p>
|
|
155
|
+
|
|
156
|
+
<ul>
|
|
157
|
+
<li>
|
|
158
|
+
Du må ha Posten-appen for å bestille sending og holde av en luke i pakkeboksen
|
|
159
|
+
</li>
|
|
160
|
+
<li>Velg Norgespakke™ liten, og følg stegene for kjøp av frakt</li>
|
|
161
|
+
<li>Velg innlevering på Posten, og fullfør kjøpet</li>
|
|
162
|
+
<li>
|
|
163
|
+
Du trenger ikke reservere luke rett etter kjøp, dette kan du gjøre innenfor 2 timer før du
|
|
164
|
+
skal sende pakken
|
|
165
|
+
</li>
|
|
166
|
+
<li>Pakken din blir hentet senest neste virkedag</li>
|
|
167
|
+
</ul>
|
|
168
|
+
|
|
169
|
+
<h2>Returnere fra Pakkeboks</h2>
|
|
170
|
+
|
|
171
|
+
<ul>
|
|
172
|
+
<li>
|
|
173
|
+
Du må ha <a href="https://www.posten.no/posten-app">Posten-appen</a> for å
|
|
174
|
+
reservere en luke.
|
|
175
|
+
</li>
|
|
176
|
+
<li>Velg retur i appen og følg stegene videre</li>
|
|
177
|
+
<li>Fest adresselappen for retur midt på pakken med strekkoden godt synlig</li>
|
|
178
|
+
<li>Luken holdes av i to timer fra du reserverer den.</li>
|
|
179
|
+
<li>Du kan reservere en luke når som helst</li>
|
|
180
|
+
</ul>
|
|
181
|
+
|
|
182
|
+
<p>Er det noe du lurer på?</p>
|
|
183
|
+
|
|
184
|
+
<p>
|
|
185
|
+
Se flere <a href="/kundeservice/pakkeboks-hjelp">spørsmål og svar om Pakkeboks</a>.
|
|
186
|
+
</p>
|
|
187
|
+
</StyledHtml>
|
|
188
|
+
),
|
|
189
|
+
};
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { forwardRef } from "react";
|
|
2
|
+
import { clsx } from "@postenbring/hedwig-css/typed-classname";
|
|
3
|
+
import { Slot } from "@radix-ui/react-slot";
|
|
4
|
+
|
|
5
|
+
export interface StyledHtmlProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
6
|
+
children?: React.ReactNode;
|
|
7
|
+
size?: "default" | "small";
|
|
8
|
+
darkmode?: boolean;
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Change the default rendered element for the one passed as a child, merging their props and behavior.
|
|
12
|
+
*
|
|
13
|
+
* @default false
|
|
14
|
+
*/
|
|
15
|
+
asChild?: boolean;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* A component for displaying dynamic content that you want to apply hedwig styling to.
|
|
20
|
+
* the styling depends on the semantic html elements you use inside the component.
|
|
21
|
+
*
|
|
22
|
+
* Useful when you have dynamic content that you want styled with hedwig, like content from a CMS.
|
|
23
|
+
*
|
|
24
|
+
* Previously known as `hw-wysiwyg` in hedwig legacy. In tailwind this kind of component it is known as `prose`.
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```tsx
|
|
28
|
+
* <StyledHtml>
|
|
29
|
+
* <h1>Heading 1</h1>
|
|
30
|
+
* <h2>Heading 2</h2>
|
|
31
|
+
* <a href="https://www.postenbring.no">Postenbring</a>
|
|
32
|
+
* <ul>
|
|
33
|
+
* <li>Hei</li>
|
|
34
|
+
* <li>Hallo</li>
|
|
35
|
+
* <li>Hello</li>
|
|
36
|
+
* </ul>
|
|
37
|
+
* </StyledHtml>
|
|
38
|
+
* ```
|
|
39
|
+
*/
|
|
40
|
+
export const StyledHtml = forwardRef<HTMLDivElement, StyledHtmlProps>(
|
|
41
|
+
({ asChild, children, size, darkmode = false, className, ...rest }, ref) => {
|
|
42
|
+
const Component = asChild ? Slot : "div";
|
|
43
|
+
return (
|
|
44
|
+
<Component
|
|
45
|
+
className={clsx(
|
|
46
|
+
`hds-styled-html`,
|
|
47
|
+
size === "small" && "hds-styled-html--small",
|
|
48
|
+
darkmode && "hds-styled-html--darkmode",
|
|
49
|
+
className as undefined,
|
|
50
|
+
)}
|
|
51
|
+
ref={ref}
|
|
52
|
+
{...rest}
|
|
53
|
+
>
|
|
54
|
+
{children}
|
|
55
|
+
</Component>
|
|
56
|
+
);
|
|
57
|
+
},
|
|
58
|
+
);
|
|
59
|
+
StyledHtml.displayName = "StyledHtml";
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { clsx } from "@postenbring/hedwig-css/typed-classname";
|
|
2
|
+
import { forwardRef, useId } from "react";
|
|
3
|
+
|
|
4
|
+
interface TableProps extends React.HTMLAttributes<HTMLTableElement> {
|
|
5
|
+
className?: string;
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Size of the table
|
|
9
|
+
*
|
|
10
|
+
* Use `compressed` for a more compact table, or `mobile-compressed` for a compact table on mobile screens only.
|
|
11
|
+
*/
|
|
12
|
+
size?: "default" | "compressed" | "mobile-compressed";
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* The table caption
|
|
16
|
+
*
|
|
17
|
+
* You can also set this by passing `<caption>` as a first child of the table
|
|
18
|
+
*/
|
|
19
|
+
caption?: React.ReactNode;
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Optional description of the table displayed underneath the table
|
|
23
|
+
*
|
|
24
|
+
* Ensures the `aria-describedby` attribute is set on the table, making it accessible for screen readers.
|
|
25
|
+
*/
|
|
26
|
+
description?: React.ReactNode;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export const Table = forwardRef<HTMLTableElement, TableProps>(
|
|
30
|
+
({ children, className, size, caption, description, ...rest }, ref) => {
|
|
31
|
+
const descriptionId = useId();
|
|
32
|
+
return (
|
|
33
|
+
<>
|
|
34
|
+
<table
|
|
35
|
+
aria-describedby={description ? descriptionId : undefined}
|
|
36
|
+
ref={ref}
|
|
37
|
+
className={clsx(
|
|
38
|
+
"hds-table",
|
|
39
|
+
{
|
|
40
|
+
"hds-table--compressed": size === "compressed",
|
|
41
|
+
"hds-table--mobile-compressed": size === "mobile-compressed",
|
|
42
|
+
},
|
|
43
|
+
className as undefined,
|
|
44
|
+
)}
|
|
45
|
+
{...rest}
|
|
46
|
+
>
|
|
47
|
+
{caption ? <caption>{caption}</caption> : null}
|
|
48
|
+
{children}
|
|
49
|
+
</table>
|
|
50
|
+
{description ? (
|
|
51
|
+
<p className={clsx("hds-table-description")} id={descriptionId}>
|
|
52
|
+
{description}
|
|
53
|
+
</p>
|
|
54
|
+
) : null}
|
|
55
|
+
</>
|
|
56
|
+
);
|
|
57
|
+
},
|
|
58
|
+
);
|
|
59
|
+
Table.displayName = "Table";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { createContext, useContext } from "react";
|
|
2
|
+
|
|
3
|
+
export interface TabsContextProps {
|
|
4
|
+
activeTabId: string;
|
|
5
|
+
toggleActiveTabId: (tabId: string) => void;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export const TabsContext = createContext<TabsContextProps | null>(null);
|
|
9
|
+
|
|
10
|
+
export function useTabsContext() {
|
|
11
|
+
const context = useContext(TabsContext);
|
|
12
|
+
if (!context) {
|
|
13
|
+
throw new Error(
|
|
14
|
+
"Tabs context required. Did you use `<Tabs.List />`, `<Tabs.Tab />`, or `<Tabs.Content />` outside of <Tabs/>?",
|
|
15
|
+
);
|
|
16
|
+
}
|
|
17
|
+
return context;
|
|
18
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import type { HTMLAttributes, ReactElement } from "react";
|
|
2
|
+
import { forwardRef } from "react";
|
|
3
|
+
import { clsx } from "@postenbring/hedwig-css/typed-classname";
|
|
4
|
+
import { Slot } from "@radix-ui/react-slot";
|
|
5
|
+
import { useTabsContext } from "./context";
|
|
6
|
+
|
|
7
|
+
export interface TabsContentsProps extends HTMLAttributes<HTMLDivElement> {
|
|
8
|
+
children: ReactElement<TabsContentProps> | ReactElement<TabsContentProps>[];
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Change the default rendered element for the one passed as a child, merging their props and behavior.
|
|
12
|
+
*
|
|
13
|
+
* @default false
|
|
14
|
+
*/
|
|
15
|
+
asChild?: boolean;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export const TabsContents = forwardRef<HTMLDivElement, TabsContentsProps>(
|
|
19
|
+
({ asChild, children, ...rest }, ref) => {
|
|
20
|
+
const Component = asChild ? Slot : "div";
|
|
21
|
+
return (
|
|
22
|
+
<Component ref={ref} className={clsx("hds-tabs__contents")} {...rest}>
|
|
23
|
+
{children}
|
|
24
|
+
</Component>
|
|
25
|
+
);
|
|
26
|
+
},
|
|
27
|
+
);
|
|
28
|
+
TabsContents.displayName = "Tabs.Contents";
|
|
29
|
+
|
|
30
|
+
export interface TabsContentProps extends HTMLAttributes<HTMLElement> {
|
|
31
|
+
children: ReactElement<HTMLElement> | ReactElement<HTMLElement>[] | string;
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Content for the referenced tabId
|
|
35
|
+
*/
|
|
36
|
+
forTabId: string;
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Change the default rendered element for the one passed as a child, merging their props and behavior.
|
|
40
|
+
*
|
|
41
|
+
* @default false
|
|
42
|
+
*/
|
|
43
|
+
asChild?: boolean;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
export const TabsContent = forwardRef<HTMLDivElement, TabsContentProps>(
|
|
47
|
+
({ asChild, forTabId, children, ...rest }, ref) => {
|
|
48
|
+
const context = useTabsContext();
|
|
49
|
+
const Component = asChild ? Slot : "div";
|
|
50
|
+
|
|
51
|
+
if (context.activeTabId === forTabId) {
|
|
52
|
+
return (
|
|
53
|
+
<Component {...rest} ref={ref}>
|
|
54
|
+
{children}
|
|
55
|
+
</Component>
|
|
56
|
+
);
|
|
57
|
+
}
|
|
58
|
+
return null;
|
|
59
|
+
},
|
|
60
|
+
);
|
|
61
|
+
|
|
62
|
+
TabsContent.displayName = "Tabs.Content";
|