@swisspost/design-system-components 10.0.0-next.70 → 10.0.0-next.72
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/cjs/breakpoints-B0Olgvgc.js +206 -0
- package/dist/cjs/component-on-ready-CifOTqw1.js +24 -0
- package/dist/cjs/create-validator-decorator-Bnx17kwi.js +223 -0
- package/dist/cjs/{focusable-ZqET_zrB.js → focusable-COT2uiEV.js} +25 -4
- package/dist/cjs/{index-DPdHkdGf.js → index-ngUOBQot.js} +17 -13
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/cjs/nanoid-CmjyF1Cm.js +20 -0
- package/dist/cjs/one-of-BHyX4vYq.js +27 -0
- package/dist/cjs/{package-Ds_LS1pB.js → package-Bi-tiNRc.js} +1 -1
- package/dist/cjs/pattern-BgBx5zGQ.js +27 -0
- package/dist/cjs/post-accordion_2.cjs.entry.js +18 -24
- package/dist/cjs/post-autocomplete.cjs.entry.js +27 -14
- package/dist/cjs/post-avatar.cjs.entry.js +33 -54
- package/dist/cjs/post-back-to-top.cjs.entry.js +21 -12
- package/dist/cjs/post-banner.cjs.entry.js +9 -14
- package/dist/cjs/post-breadcrumb-item.cjs.entry.js +48 -41
- package/dist/cjs/post-breadcrumbs.cjs.entry.js +106 -105
- package/dist/cjs/post-closebutton_14.cjs.entry.js +257 -288
- package/dist/cjs/post-collapsible_2.cjs.entry.js +57 -40
- package/dist/cjs/post-components.cjs.js +2 -2
- package/dist/cjs/post-date-picker.cjs.entry.js +154 -144
- package/dist/cjs/post-footer.cjs.entry.js +26 -19
- package/dist/cjs/post-linkarea.cjs.entry.js +3 -3
- package/dist/cjs/post-listbox-option.cjs.entry.js +4 -4
- package/dist/cjs/post-listbox.cjs.entry.js +4 -6
- package/dist/cjs/post-login-widget.cjs.entry.js +35 -3
- package/dist/cjs/post-number-input.cjs.entry.js +6 -6
- package/dist/cjs/post-pagination.cjs.entry.js +53 -83
- package/dist/cjs/post-popover-trigger.cjs.entry.js +22 -19
- package/dist/cjs/post-popover.cjs.entry.js +25 -23
- package/dist/cjs/post-progressbar.cjs.entry.js +147 -0
- package/dist/cjs/post-rating.cjs.entry.js +34 -35
- package/dist/cjs/post-stepper-item.cjs.entry.js +3 -3
- package/dist/cjs/post-stepper.cjs.entry.js +49 -38
- package/dist/cjs/post-tab-item.cjs.entry.js +23 -15
- package/dist/cjs/post-tab-panel.cjs.entry.js +23 -16
- package/dist/cjs/post-tabs.cjs.entry.js +24 -30
- package/dist/cjs/post-tooltip-trigger.cjs.entry.js +34 -21
- package/dist/cjs/post-tooltip.cjs.entry.js +19 -16
- package/dist/cjs/required-lRDOdbd6.js +44 -0
- package/dist/cjs/type-shT641Eo.js +30 -0
- package/dist/cjs/url-DRUMqVBq.js +34 -0
- package/dist/collection/collection-manifest.json +1 -0
- package/dist/collection/components/post-accordion/post-accordion.js +11 -8
- package/dist/collection/components/post-accordion-item/post-accordion-item.js +4 -18
- package/dist/collection/components/post-autocomplete/post-autocomplete.js +23 -13
- package/dist/collection/components/post-avatar/avatar-utils.js +2 -2
- package/dist/collection/components/post-avatar/post-avatar.js +29 -72
- package/dist/collection/components/post-back-to-top/post-back-to-top.js +17 -10
- package/dist/collection/components/post-banner/post-banner.js +7 -14
- package/dist/collection/components/post-breadcrumb-item/post-breadcrumb-item.css +1 -1
- package/dist/collection/components/post-breadcrumb-item/post-breadcrumb-item.js +92 -47
- package/dist/collection/components/post-breadcrumb-item/variants.js +1 -0
- package/dist/collection/components/post-breadcrumbs/post-breadcrumbs.css +1 -1
- package/dist/collection/components/post-breadcrumbs/post-breadcrumbs.js +110 -114
- package/dist/collection/components/post-closebutton/post-closebutton.js +24 -27
- package/dist/collection/components/post-collapsible/post-collapsible.js +26 -16
- package/dist/collection/components/post-collapsible-trigger/post-collapsible-trigger.js +34 -30
- package/dist/collection/components/post-date-picker/post-date-picker.css +1 -1
- package/dist/collection/components/post-date-picker/post-date-picker.js +64 -96
- package/dist/collection/components/post-footer/post-footer.js +17 -13
- package/dist/collection/components/post-header/post-header.js +18 -24
- package/dist/collection/components/post-icon/post-icon.js +36 -48
- package/dist/collection/components/post-language-menu/post-language-menu.js +16 -22
- package/dist/collection/components/post-language-menu-item/post-language-menu-item.js +28 -39
- package/dist/collection/components/post-linkarea/post-linkarea.js +2 -2
- package/dist/collection/components/post-listbox/post-listbox.js +3 -5
- package/dist/collection/components/post-listbox-option/post-listbox-option.js +3 -3
- package/dist/collection/components/post-login-widget/post-login-widget.css +1 -0
- package/dist/collection/components/post-login-widget/post-login-widget.js +103 -5
- package/dist/collection/components/post-logo/post-logo.js +16 -13
- package/dist/collection/components/post-mainnavigation/post-mainnavigation.js +17 -13
- package/dist/collection/components/post-megadropdown/post-megadropdown.js +24 -23
- package/dist/collection/components/post-megadropdown-trigger/post-megadropdown-trigger.js +7 -15
- package/dist/collection/components/post-menu/post-menu.js +14 -24
- package/dist/collection/components/post-menu-item/post-menu-item.css +1 -1
- package/dist/collection/components/post-menu-trigger/post-menu-trigger.js +17 -13
- package/dist/collection/components/post-number-input/post-number-input.js +5 -5
- package/dist/collection/components/post-pagination/post-pagination.js +47 -83
- package/dist/collection/components/post-popover/post-popover.js +20 -22
- package/dist/collection/components/post-popover-trigger/post-popover-trigger.js +16 -14
- package/dist/collection/components/post-popovercontainer/post-popovercontainer.css +1 -1
- package/dist/collection/components/post-popovercontainer/post-popovercontainer.js +28 -34
- package/dist/collection/components/post-progressbar/post-progressbar.css +1 -0
- package/dist/collection/components/post-progressbar/post-progressbar.js +136 -0
- package/dist/collection/components/post-rating/post-rating.js +25 -29
- package/dist/collection/components/post-stepper/post-stepper.js +44 -36
- package/dist/collection/components/post-stepper-item/post-stepper-item.js +2 -2
- package/dist/collection/components/post-tab-item/post-tab-item.js +17 -13
- package/dist/collection/components/post-tab-panel/post-tab-panel.js +17 -14
- package/dist/collection/components/post-tabs/post-tabs.js +20 -7
- package/dist/collection/components/post-togglebutton/post-togglebutton.js +5 -3
- package/dist/collection/components/post-tooltip/post-tooltip.js +17 -16
- package/dist/collection/components/post-tooltip-trigger/post-tooltip-trigger.js +30 -19
- package/dist/collection/hydrate-stub/index.stub.js +5 -0
- package/dist/collection/test-setup.js +7 -0
- package/dist/collection/utils/index.js +4 -3
- package/dist/collection/utils/is-value-empty.js +1 -1
- package/dist/collection/utils/locales.js +9 -2
- package/dist/collection/utils/nanoid.js +16 -0
- package/dist/collection/utils/property-decorators/array-of.js +22 -0
- package/dist/collection/utils/property-decorators/bound.js +75 -0
- package/dist/collection/utils/property-decorators/create-validator-decorator.js +211 -0
- package/dist/collection/utils/property-decorators/date.js +21 -0
- package/dist/collection/utils/property-decorators/index.js +9 -0
- package/dist/collection/utils/property-decorators/iso-date.js +21 -0
- package/dist/collection/utils/property-decorators/one-of.js +22 -0
- package/dist/collection/utils/property-decorators/pattern.js +22 -0
- package/dist/collection/utils/property-decorators/required.js +40 -0
- package/dist/collection/utils/property-decorators/type.js +25 -0
- package/dist/collection/utils/property-decorators/url.js +29 -0
- package/dist/component-names.json +1 -0
- package/dist/components/breakpoints.js +1 -0
- package/dist/components/component-on-ready.js +1 -0
- package/dist/components/focusable.js +1 -1
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.js +1 -1
- package/dist/components/nanoid.js +1 -0
- package/dist/components/one-of.js +1 -0
- package/dist/components/package.js +1 -1
- package/dist/components/pattern.js +1 -0
- package/dist/components/post-accordion-item2.js +1 -1
- package/dist/components/post-accordion2.js +1 -1
- package/dist/components/post-autocomplete.js +1 -1
- package/dist/components/post-avatar.js +1 -1
- package/dist/components/post-avatar2.js +1 -0
- package/dist/components/post-back-to-top.js +1 -1
- package/dist/components/post-banner.js +1 -1
- package/dist/components/post-breadcrumb-item.js +1 -1
- package/dist/components/post-breadcrumbs.js +1 -1
- package/dist/components/post-closebutton2.js +1 -1
- package/dist/components/post-collapsible-trigger2.js +1 -1
- package/dist/components/post-collapsible2.js +1 -1
- package/dist/components/post-date-picker.js +1 -1
- package/dist/components/post-footer.js +1 -1
- package/dist/components/post-header.js +1 -1
- package/dist/components/post-icon2.js +1 -1
- package/dist/components/post-language-menu-item.js +1 -1
- package/dist/components/post-language-menu.js +1 -1
- package/dist/components/post-linkarea.js +1 -1
- package/dist/components/post-listbox-option.js +1 -1
- package/dist/components/post-listbox.js +1 -1
- package/dist/components/post-login-widget.js +1 -1
- package/dist/components/post-logo.js +1 -1
- package/dist/components/post-mainnavigation.js +1 -1
- package/dist/components/post-megadropdown-trigger.js +1 -1
- package/dist/components/post-megadropdown.js +1 -1
- package/dist/components/post-menu-item2.js +1 -1
- package/dist/components/post-menu-trigger2.js +1 -1
- package/dist/components/post-menu2.js +1 -1
- package/dist/components/post-number-input.js +1 -1
- package/dist/components/post-pagination.js +1 -1
- package/dist/components/post-popover-trigger.js +1 -1
- package/dist/components/post-popover.js +1 -1
- package/dist/components/post-popovercontainer2.js +1 -1
- package/dist/components/post-progressbar.d.ts +11 -0
- package/dist/components/post-progressbar.js +1 -0
- package/dist/components/post-rating.js +1 -1
- package/dist/components/post-stepper-item.js +1 -1
- package/dist/components/post-stepper.js +1 -1
- package/dist/components/post-tab-item.js +1 -1
- package/dist/components/post-tab-panel.js +1 -1
- package/dist/components/post-tabs.js +1 -1
- package/dist/components/post-togglebutton2.js +1 -1
- package/dist/components/post-tooltip-trigger.js +1 -1
- package/dist/components/post-tooltip.js +1 -1
- package/dist/components/react/index.js +1 -1
- package/dist/components/react/p-4wtxqxXu.js +1 -0
- package/dist/components/react/p-85IGlhtB.js +1 -0
- package/dist/components/react/p-8LXe8Zt_.js +1 -0
- package/dist/components/react/p-B9ZFuYey.js +1 -0
- package/dist/components/react/p-BXqGI600.js +1 -0
- package/dist/components/react/p-BZSAV0-K.js +1 -0
- package/dist/components/react/p-B_WnO-QF.js +1 -0
- package/dist/components/react/p-BaB8wJvk.js +1 -0
- package/dist/components/react/p-Bg9dtyzK.js +1 -0
- package/dist/components/react/p-Bji_4dfL.js +1 -0
- package/dist/components/react/p-Bn66acGG.js +1 -0
- package/dist/components/react/p-BrY4VWTQ.js +1 -0
- package/dist/components/react/p-Bu2JeHDf.js +1 -0
- package/dist/components/react/p-BxoRVIIr.js +1 -0
- package/dist/components/react/p-CX2E_IXB.js +1 -0
- package/dist/components/react/p-Cd1TsNm7.js +1 -0
- package/dist/components/react/p-CkTAQJGd.js +1 -0
- package/dist/components/react/p-ClG-N42b.js +1 -0
- package/dist/components/react/p-D1zw8FxT.js +1 -0
- package/dist/components/react/p-DwuW52g5.js +1 -0
- package/dist/components/react/p-PM7l--ff.js +1 -0
- package/dist/components/react/p-lpWRZjJp.js +1 -0
- package/dist/components/react/post-accordion-item.js +1 -1
- package/dist/components/react/post-accordion.js +1 -1
- package/dist/components/react/post-autocomplete.js +1 -1
- package/dist/components/react/post-avatar.js +1 -1
- package/dist/components/react/post-back-to-top.js +1 -1
- package/dist/components/react/post-banner.js +1 -1
- package/dist/components/react/post-breadcrumb-item.js +1 -1
- package/dist/components/react/post-breadcrumbs.js +1 -1
- package/dist/components/react/post-closebutton.js +1 -1
- package/dist/components/react/post-collapsible-trigger.js +1 -1
- package/dist/components/react/post-collapsible.js +1 -1
- package/dist/components/react/post-date-picker.js +1 -1
- package/dist/components/react/post-footer.js +1 -1
- package/dist/components/react/post-header.js +1 -1
- package/dist/components/react/post-icon.js +1 -1
- package/dist/components/react/post-language-menu-item.js +1 -1
- package/dist/components/react/post-language-menu.js +1 -1
- package/dist/components/react/post-linkarea.js +1 -1
- package/dist/components/react/post-listbox-option.js +1 -1
- package/dist/components/react/post-listbox.js +1 -1
- package/dist/components/react/post-login-widget.js +1 -1
- package/dist/components/react/post-logo.js +1 -1
- package/dist/components/react/post-mainnavigation.js +1 -1
- package/dist/components/react/post-megadropdown-trigger.js +1 -1
- package/dist/components/react/post-megadropdown.js +1 -1
- package/dist/components/react/post-menu-item.js +1 -1
- package/dist/components/react/post-menu-trigger.js +1 -1
- package/dist/components/react/post-menu.js +1 -1
- package/dist/components/react/post-number-input.js +1 -1
- package/dist/components/react/post-pagination.js +1 -1
- package/dist/components/react/post-popover-trigger.js +1 -1
- package/dist/components/react/post-popover.js +1 -1
- package/dist/components/react/post-popovercontainer.js +1 -1
- package/dist/components/react/post-progressbar.d.ts +11 -0
- package/dist/components/react/post-progressbar.js +1 -0
- package/dist/components/react/post-rating.js +1 -1
- package/dist/components/react/post-stepper-item.js +1 -1
- package/dist/components/react/post-stepper.js +1 -1
- package/dist/components/react/post-tab-item.js +1 -1
- package/dist/components/react/post-tab-panel.js +1 -1
- package/dist/components/react/post-tabs.js +1 -1
- package/dist/components/react/post-togglebutton.js +1 -1
- package/dist/components/react/post-tooltip-trigger.js +1 -1
- package/dist/components/react/post-tooltip.js +1 -1
- package/dist/components/required.js +1 -0
- package/dist/components/type.js +1 -0
- package/dist/components/url.js +1 -0
- package/dist/docs.json +307 -72
- package/dist/esm/breakpoints-BQ3HlJPr.js +202 -0
- package/dist/esm/component-on-ready-lpWRZjJp.js +22 -0
- package/dist/esm/create-validator-decorator-D8qwF5Qe.js +218 -0
- package/dist/esm/{focusable-BD_WT2MO.js → focusable-C7afHKmo.js} +25 -5
- package/dist/esm/{index-DmAi35UF.js → index-BbDawWJ5.js} +17 -13
- package/dist/esm/loader.js +3 -3
- package/dist/esm/nanoid-8LXe8Zt_.js +18 -0
- package/dist/esm/one-of-GPr3FflU.js +25 -0
- package/dist/esm/package-ClG-N42b.js +3 -0
- package/dist/esm/pattern-BWPRYpYv.js +25 -0
- package/dist/esm/post-accordion_2.entry.js +17 -23
- package/dist/esm/post-autocomplete.entry.js +27 -14
- package/dist/esm/post-avatar.entry.js +33 -54
- package/dist/esm/post-back-to-top.entry.js +21 -12
- package/dist/esm/post-banner.entry.js +9 -14
- package/dist/esm/post-breadcrumb-item.entry.js +48 -41
- package/dist/esm/post-breadcrumbs.entry.js +106 -105
- package/dist/esm/post-closebutton_14.entry.js +252 -283
- package/dist/esm/post-collapsible_2.entry.js +57 -40
- package/dist/esm/post-components.js +3 -3
- package/dist/esm/post-date-picker.entry.js +151 -141
- package/dist/esm/post-footer.entry.js +21 -14
- package/dist/esm/post-linkarea.entry.js +3 -3
- package/dist/esm/post-listbox-option.entry.js +4 -4
- package/dist/esm/post-listbox.entry.js +4 -6
- package/dist/esm/post-login-widget.entry.js +35 -3
- package/dist/esm/post-number-input.entry.js +5 -5
- package/dist/esm/post-pagination.entry.js +52 -82
- package/dist/esm/post-popover-trigger.entry.js +20 -17
- package/dist/esm/post-popover.entry.js +25 -23
- package/dist/esm/post-progressbar.entry.js +145 -0
- package/dist/esm/post-rating.entry.js +29 -30
- package/dist/esm/post-stepper-item.entry.js +3 -3
- package/dist/esm/post-stepper.entry.js +49 -38
- package/dist/esm/post-tab-item.entry.js +22 -14
- package/dist/esm/post-tab-panel.entry.js +22 -15
- package/dist/esm/post-tabs.entry.js +23 -29
- package/dist/esm/post-tooltip-trigger.entry.js +34 -21
- package/dist/esm/post-tooltip.entry.js +19 -16
- package/dist/esm/required-uK-rZZjy.js +42 -0
- package/dist/esm/type-obmwEgkM.js +28 -0
- package/dist/esm/url-B28ByZCe.js +32 -0
- package/dist/post-components/p-00f55af5.entry.js +1 -0
- package/dist/post-components/p-0288484f.entry.js +1 -0
- package/dist/post-components/p-07cdd022.entry.js +1 -0
- package/dist/post-components/{p-c2e05ba0.entry.js → p-12047216.entry.js} +1 -1
- package/dist/post-components/p-17df4e91.entry.js +1 -0
- package/dist/post-components/p-17e046fa.entry.js +1 -0
- package/dist/post-components/p-29bd31a0.entry.js +1 -0
- package/dist/post-components/p-2c6b4e6a.entry.js +1 -0
- package/dist/post-components/p-3b05e01d.entry.js +1 -0
- package/dist/post-components/p-53fd5230.entry.js +1 -0
- package/dist/post-components/p-5b7e6369.entry.js +1 -0
- package/dist/post-components/p-5f4ca179.entry.js +1 -0
- package/dist/post-components/p-62b6154a.entry.js +1 -0
- package/dist/post-components/{p-77d5e17b.entry.js → p-686a6e22.entry.js} +1 -1
- package/dist/post-components/p-758fc84f.entry.js +1 -0
- package/dist/post-components/{p-570d64dd.entry.js → p-7f929bb9.entry.js} +1 -1
- package/dist/post-components/p-8LXe8Zt_.js +1 -0
- package/dist/post-components/p-9865f72c.entry.js +1 -0
- package/dist/post-components/p-99803d57.entry.js +1 -0
- package/dist/post-components/p-BQ3HlJPr.js +1 -0
- package/dist/post-components/p-BRNqUiXj.js +1 -0
- package/dist/post-components/p-BbDawWJ5.js +2 -0
- package/dist/post-components/p-BrY4VWTQ.js +1 -0
- package/dist/post-components/p-CVsNfXZd.js +1 -0
- package/dist/post-components/p-Ck2qPht6.js +1 -0
- package/dist/post-components/p-ClG-N42b.js +1 -0
- package/dist/post-components/p-D4F0BqBW.js +1 -0
- package/dist/post-components/p-DSNGJB58.js +1 -0
- package/dist/post-components/p-IUnDBhPg.js +1 -0
- package/dist/post-components/p-a0e0a760.entry.js +1 -0
- package/dist/post-components/p-a850652d.entry.js +1 -0
- package/dist/post-components/p-aac1a8ea.entry.js +1 -0
- package/dist/post-components/{p-092f8795.entry.js → p-b3f0f9a2.entry.js} +1 -1
- package/dist/post-components/p-c37dba4b.entry.js +1 -0
- package/dist/post-components/p-d061773b.entry.js +1 -0
- package/dist/post-components/p-e2370e94.entry.js +1 -0
- package/dist/post-components/p-f1ca1d3f.entry.js +1 -0
- package/dist/post-components/p-f2e5f44e.entry.js +1 -0
- package/dist/post-components/p-ff98ada4.entry.js +1 -0
- package/dist/post-components/p-lpWRZjJp.js +1 -0
- package/dist/post-components/post-components.css +2 -2
- package/dist/post-components/post-components.esm.js +1 -1
- package/dist/types/components/post-accordion/post-accordion.d.ts +1 -1
- package/dist/types/components/post-accordion-item/post-accordion-item.d.ts +0 -2
- package/dist/types/components/post-autocomplete/post-autocomplete.d.ts +0 -1
- package/dist/types/components/post-avatar/avatar-utils.d.ts +1 -1
- package/dist/types/components/post-avatar/post-avatar.d.ts +0 -13
- package/dist/types/components/post-back-to-top/post-back-to-top.d.ts +0 -1
- package/dist/types/components/post-banner/post-banner.d.ts +0 -1
- package/dist/types/components/post-breadcrumb-item/post-breadcrumb-item.d.ts +11 -11
- package/dist/types/components/post-breadcrumb-item/variants.d.ts +2 -0
- package/dist/types/components/post-breadcrumbs/post-breadcrumbs.d.ts +20 -26
- package/dist/types/components/post-closebutton/post-closebutton.d.ts +0 -3
- package/dist/types/components/post-collapsible/post-collapsible.d.ts +1 -2
- package/dist/types/components/post-collapsible-trigger/post-collapsible-trigger.d.ts +3 -6
- package/dist/types/components/post-date-picker/post-date-picker.d.ts +0 -12
- package/dist/types/components/post-footer/post-footer.d.ts +0 -1
- package/dist/types/components/post-header/post-header.d.ts +0 -2
- package/dist/types/components/post-icon/post-icon.d.ts +0 -6
- package/dist/types/components/post-language-menu/post-language-menu.d.ts +1 -3
- package/dist/types/components/post-language-menu-item/post-language-menu-item.d.ts +0 -5
- package/dist/types/components/post-login-widget/post-login-widget.d.ts +17 -2
- package/dist/types/components/post-logo/post-logo.d.ts +0 -1
- package/dist/types/components/post-mainnavigation/post-mainnavigation.d.ts +0 -1
- package/dist/types/components/post-megadropdown/post-megadropdown.d.ts +1 -3
- package/dist/types/components/post-megadropdown-trigger/post-megadropdown-trigger.d.ts +0 -2
- package/dist/types/components/post-menu/post-menu.d.ts +1 -4
- package/dist/types/components/post-menu-trigger/post-menu-trigger.d.ts +0 -1
- package/dist/types/components/post-pagination/post-pagination.d.ts +0 -17
- package/dist/types/components/post-popover/post-popover.d.ts +0 -3
- package/dist/types/components/post-popover-trigger/post-popover-trigger.d.ts +0 -1
- package/dist/types/components/post-popovercontainer/post-popovercontainer.d.ts +0 -3
- package/dist/types/components/post-progressbar/post-progressbar.d.ts +23 -0
- package/dist/types/components/post-rating/post-rating.d.ts +0 -4
- package/dist/types/components/post-stepper/post-stepper.d.ts +1 -4
- package/dist/types/components/post-tab-item/post-tab-item.d.ts +0 -1
- package/dist/types/components/post-tab-panel/post-tab-panel.d.ts +0 -1
- package/dist/types/components/post-tooltip/post-tooltip.d.ts +1 -3
- package/dist/types/components/post-tooltip-trigger/post-tooltip-trigger.d.ts +1 -1
- package/dist/types/components.d.ts +119 -29
- package/dist/types/modules.d.ts +2 -0
- package/dist/types/utils/index.d.ts +4 -3
- package/dist/types/utils/nanoid.d.ts +8 -0
- package/dist/types/utils/property-decorators/array-of.d.ts +9 -0
- package/dist/types/utils/property-decorators/bound.d.ts +36 -0
- package/dist/types/utils/property-decorators/create-validator-decorator.d.ts +48 -0
- package/dist/types/utils/property-decorators/date.d.ts +6 -0
- package/dist/types/utils/property-decorators/index.d.ts +9 -0
- package/dist/types/utils/property-decorators/iso-date.d.ts +6 -0
- package/dist/types/utils/property-decorators/one-of.d.ts +8 -0
- package/dist/types/utils/property-decorators/pattern.d.ts +8 -0
- package/dist/types/utils/property-decorators/required.d.ts +17 -0
- package/dist/types/utils/property-decorators/type.d.ts +9 -0
- package/dist/types/utils/property-decorators/url.d.ts +6 -0
- package/hydrate/index.js +1536 -115469
- package/hydrate/index.mjs +1536 -115469
- package/hydrate/index.stub.js +5 -0
- package/package.json +28 -18
- package/dist/cjs/index-YBj3gUJp.js +0 -114540
- package/dist/cjs/index-qCzRmwgB.js +0 -114
- package/dist/cjs/index.browser-BVb9l9T_.js +0 -16
- package/dist/collection/utils/property-checkers/check-array-of.js +0 -8
- package/dist/collection/utils/property-checkers/check-date.js +0 -13
- package/dist/collection/utils/property-checkers/check-iso-date.js +0 -9
- package/dist/collection/utils/property-checkers/check-one-of.js +0 -8
- package/dist/collection/utils/property-checkers/check-pattern.js +0 -8
- package/dist/collection/utils/property-checkers/check-type.js +0 -15
- package/dist/collection/utils/property-checkers/check-url.js +0 -15
- package/dist/collection/utils/property-checkers/constants.js +0 -1
- package/dist/collection/utils/property-checkers/empty-or.js +0 -9
- package/dist/collection/utils/property-checkers/index.js +0 -20
- package/dist/collection/utils/property-checkers/required-and.js +0 -14
- package/dist/components/heading-levels.js +0 -1
- package/dist/components/index.browser.js +0 -1
- package/dist/components/index2.js +0 -1
- package/dist/components/index3.js +0 -6
- package/dist/components/post-breadcrumb-item2.js +0 -1
- package/dist/components/react/p-B076QoO3.js +0 -1
- package/dist/components/react/p-B2BDAeHI.js +0 -1
- package/dist/components/react/p-B2iQay0-.js +0 -1
- package/dist/components/react/p-B_RL4AOE.js +0 -1
- package/dist/components/react/p-BoFDru4R.js +0 -1
- package/dist/components/react/p-BuL0WAoF.js +0 -1
- package/dist/components/react/p-C8b6-YQl.js +0 -1
- package/dist/components/react/p-CJcRbvrI.js +0 -6
- package/dist/components/react/p-Cu9RsvYK.js +0 -1
- package/dist/components/react/p-D6uA8DbL.js +0 -1
- package/dist/components/react/p-DSSN7xW4.js +0 -1
- package/dist/components/react/p-DW7sbg9f.js +0 -1
- package/dist/components/react/p-DgdnwpId.js +0 -1
- package/dist/components/react/p-Dmnnz3fB.js +0 -1
- package/dist/components/react/p-PuHMz_9_.js +0 -1
- package/dist/components/react/p-nA1BKco0.js +0 -1
- package/dist/components/react/p-r4txK0AC.js +0 -1
- package/dist/components/react/p-tpgRP2Dr.js +0 -1
- package/dist/esm/index-CJcRbvrI.js +0 -114535
- package/dist/esm/index-D9bU2pIE.js +0 -104
- package/dist/esm/index.browser-nA1BKco0.js +0 -14
- package/dist/esm/package-DW7sbg9f.js +0 -3
- package/dist/post-components/p-17ccebe6.entry.js +0 -1
- package/dist/post-components/p-1d58bec1.entry.js +0 -1
- package/dist/post-components/p-25c28493.entry.js +0 -1
- package/dist/post-components/p-29ada3d7.entry.js +0 -1
- package/dist/post-components/p-2fcca5ec.entry.js +0 -1
- package/dist/post-components/p-3cefd49e.entry.js +0 -1
- package/dist/post-components/p-3fea238c.entry.js +0 -1
- package/dist/post-components/p-5068ae7e.entry.js +0 -1
- package/dist/post-components/p-521178f5.entry.js +0 -1
- package/dist/post-components/p-534fed55.entry.js +0 -1
- package/dist/post-components/p-5f52cba3.entry.js +0 -1
- package/dist/post-components/p-86697a58.entry.js +0 -1
- package/dist/post-components/p-987bebe8.entry.js +0 -1
- package/dist/post-components/p-9ca5c297.entry.js +0 -1
- package/dist/post-components/p-9ea3066f.entry.js +0 -1
- package/dist/post-components/p-CJcRbvrI.js +0 -6
- package/dist/post-components/p-D9bU2pIE.js +0 -1
- package/dist/post-components/p-DW7sbg9f.js +0 -1
- package/dist/post-components/p-DmAi35UF.js +0 -2
- package/dist/post-components/p-PuHMz_9_.js +0 -1
- package/dist/post-components/p-a6fc33fa.entry.js +0 -1
- package/dist/post-components/p-ac853d6b.entry.js +0 -1
- package/dist/post-components/p-bd09bc20.entry.js +0 -1
- package/dist/post-components/p-c55b537b.entry.js +0 -1
- package/dist/post-components/p-dded4f13.entry.js +0 -1
- package/dist/post-components/p-e6ba44b1.entry.js +0 -1
- package/dist/post-components/p-ead1094e.entry.js +0 -1
- package/dist/post-components/p-f12e59a0.entry.js +0 -1
- package/dist/post-components/p-nA1BKco0.js +0 -1
- package/dist/types/home/runner/work/design-system/design-system/packages/components/.stencil/types/language-tags.d.ts +0 -1
- package/dist/types/utils/property-checkers/check-array-of.d.ts +0 -4
- package/dist/types/utils/property-checkers/check-date.d.ts +0 -3
- package/dist/types/utils/property-checkers/check-iso-date.d.ts +0 -3
- package/dist/types/utils/property-checkers/check-one-of.d.ts +0 -3
- package/dist/types/utils/property-checkers/check-pattern.d.ts +0 -3
- package/dist/types/utils/property-checkers/check-type.d.ts +0 -4
- package/dist/types/utils/property-checkers/check-url.d.ts +0 -3
- package/dist/types/utils/property-checkers/constants.d.ts +0 -1
- package/dist/types/utils/property-checkers/empty-or.d.ts +0 -3
- package/dist/types/utils/property-checkers/index.d.ts +0 -34
- package/dist/types/utils/property-checkers/required-and.d.ts +0 -3
- /package/dist/types/{language-tags.js → test-setup.d.ts} +0 -0
|
@@ -1,107 +1,103 @@
|
|
|
1
|
-
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
|
|
4
|
+
r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else
|
|
6
|
+
for (var i = decorators.length - 1; i >= 0; i--)
|
|
7
|
+
if (d = decorators[i])
|
|
8
|
+
r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
9
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
10
|
+
};
|
|
11
|
+
import { componentOnReady, nanoid, Required, Type, Url } from "../../utils/index";
|
|
2
12
|
import { version } from "../../../../package";
|
|
3
|
-
import {
|
|
13
|
+
import { h, Host } from "@stencil/core";
|
|
14
|
+
import { throttle } from "throttle-debounce";
|
|
4
15
|
export class PostBreadcrumbs {
|
|
5
16
|
constructor() {
|
|
6
|
-
this.
|
|
7
|
-
// Waits for breadcrumbs navigation reference to be available
|
|
8
|
-
this.waitForBreadcrumbsRef = debounce(() => {
|
|
9
|
-
if (this.breadcrumbsNavRef?.clientWidth > 0) {
|
|
10
|
-
this.checkConcatenation();
|
|
11
|
-
}
|
|
12
|
-
else {
|
|
13
|
-
this.waitForBreadcrumbsRef();
|
|
14
|
-
}
|
|
15
|
-
}, 50);
|
|
16
|
-
// Handles resizing to check concatenation
|
|
17
|
-
this.handleResize = () => {
|
|
18
|
-
if (window.innerWidth === this.lastWindowWidth)
|
|
19
|
-
return;
|
|
20
|
-
this.lastWindowWidth = window.innerWidth;
|
|
21
|
-
this.checkConcatenation();
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
validateHomeUrl() {
|
|
25
|
-
checkRequiredAndUrl(this, 'homeUrl');
|
|
17
|
+
this.shouldRenderMenu = false;
|
|
26
18
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
}
|
|
30
|
-
validateTextBreadcrumbs() {
|
|
31
|
-
checkRequiredAndType(this, 'textBreadcrumbs', 'string');
|
|
32
|
-
}
|
|
33
|
-
validateTextMoreItems() {
|
|
34
|
-
checkRequiredAndType(this, 'textMoreItems', 'string');
|
|
19
|
+
componentWillLoad() {
|
|
20
|
+
this.id = this.host.id || `b${nanoid(6)}`;
|
|
35
21
|
}
|
|
36
22
|
componentDidLoad() {
|
|
37
|
-
this.
|
|
38
|
-
this.
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
this.
|
|
23
|
+
this.createMutationObserver();
|
|
24
|
+
this.createResizeObserver();
|
|
25
|
+
}
|
|
26
|
+
disconnectedCallback() {
|
|
27
|
+
this.mutationObserver?.disconnect();
|
|
28
|
+
this.resizeObserver?.disconnect();
|
|
29
|
+
}
|
|
30
|
+
createMutationObserver() {
|
|
31
|
+
this.mutationObserver = new MutationObserver(this.duplicateNavElement.bind(this));
|
|
32
|
+
this.mutationObserver.observe(this.host, {
|
|
33
|
+
childList: true,
|
|
34
|
+
characterData: true,
|
|
35
|
+
subtree: true,
|
|
36
|
+
});
|
|
37
|
+
this.duplicateNavElement();
|
|
38
|
+
}
|
|
39
|
+
createResizeObserver() {
|
|
40
|
+
this.resizeObserver = new ResizeObserver(throttle(50, this.checkOverflow.bind(this)));
|
|
41
|
+
this.resizeObserver.observe(document.body);
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* To measure overflow, we duplicate the entire breadcrumb so an inline version is always available.
|
|
45
|
+
*/
|
|
46
|
+
duplicateNavElement() {
|
|
47
|
+
const shadowRoot = this.host.shadowRoot;
|
|
48
|
+
const nav = shadowRoot?.querySelector('nav');
|
|
49
|
+
if (!shadowRoot || !nav)
|
|
50
|
+
return;
|
|
51
|
+
this.prepareBreadcrumbItemsForClone();
|
|
52
|
+
const clone = nav.cloneNode(true);
|
|
53
|
+
clone.classList.add('invisible');
|
|
54
|
+
shadowRoot.querySelector('nav.invisible')?.remove();
|
|
55
|
+
shadowRoot.append(clone);
|
|
43
56
|
requestAnimationFrame(() => {
|
|
44
|
-
this.
|
|
57
|
+
this.duplicateSlottedElements(clone, 'slot:not([name])');
|
|
58
|
+
this.duplicateSlottedElements(clone, 'slot[name="selected"]');
|
|
59
|
+
this.checkOverflow();
|
|
45
60
|
});
|
|
46
61
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
updateBreadcrumbItems() {
|
|
52
|
-
this.breadcrumbItems = Array.from(this.host.querySelectorAll('post-breadcrumb-item')).map(item => ({
|
|
53
|
-
text: item.textContent || '',
|
|
54
|
-
url: item.getAttribute('url') ?? undefined,
|
|
55
|
-
description: item.getAttribute('description') ?? undefined,
|
|
56
|
-
label: item.getAttribute('label') ?? undefined,
|
|
57
|
-
}));
|
|
58
|
-
this.lastItem = this.breadcrumbItems.at(-1);
|
|
59
|
-
}
|
|
60
|
-
// Determines parent width for concatenation logic
|
|
61
|
-
getParentWidth() {
|
|
62
|
-
let parent = this.host.parentNode;
|
|
63
|
-
while (parent && !(parent instanceof HTMLElement)) {
|
|
64
|
-
parent = parent.parentNode;
|
|
65
|
-
}
|
|
66
|
-
return parent instanceof HTMLElement ? parent.clientWidth : window.innerWidth;
|
|
67
|
-
}
|
|
68
|
-
checkConcatenation() {
|
|
69
|
-
if (!this.breadcrumbsNavRef)
|
|
62
|
+
duplicateSlottedElements(clone, slotSelector) {
|
|
63
|
+
const originalSlot = this.host.shadowRoot?.querySelector(slotSelector);
|
|
64
|
+
const clonedSlot = clone.querySelector(slotSelector);
|
|
65
|
+
if (!originalSlot || !clonedSlot)
|
|
70
66
|
return;
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
67
|
+
originalSlot.assignedElements().forEach(element => {
|
|
68
|
+
const cloned = element.cloneNode(true);
|
|
69
|
+
cloned.dataset.measuring = 'true';
|
|
70
|
+
clonedSlot.before(cloned);
|
|
71
|
+
});
|
|
72
|
+
clonedSlot.remove();
|
|
73
|
+
}
|
|
74
|
+
checkOverflow() {
|
|
75
|
+
const hiddenNav = this.host.shadowRoot?.querySelector('nav.invisible');
|
|
76
|
+
if (!hiddenNav)
|
|
77
|
+
return;
|
|
78
|
+
const breadcrumbItems = Array.from(hiddenNav.querySelectorAll('post-breadcrumb-item'));
|
|
79
|
+
Promise.all(breadcrumbItems.map(item => componentOnReady(item))).then(() => {
|
|
80
|
+
this.shouldRenderMenu = hiddenNav.scrollWidth > hiddenNav.clientWidth;
|
|
81
|
+
this.updateBreadcrumbItemProps();
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
prepareBreadcrumbItemsForClone() {
|
|
85
|
+
this.shouldRenderMenu = false;
|
|
86
|
+
this.updateBreadcrumbItemProps();
|
|
87
|
+
}
|
|
88
|
+
updateBreadcrumbItemProps() {
|
|
89
|
+
const breadcrumbItems = this.host.querySelectorAll('post-breadcrumb-item');
|
|
90
|
+
breadcrumbItems.forEach((item, index) => {
|
|
91
|
+
item.setAttribute('variant', this.shouldRenderMenu ? 'menuitem' : 'listitem');
|
|
92
|
+
item.setAttribute('selected', String(index === breadcrumbItems.length - 1));
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
renderMenu() {
|
|
96
|
+
const menuId = `${this.id}-menu`;
|
|
97
|
+
return (h("div", { role: "listitem" }, h("div", { class: "breadcrumb-item" }, h("post-menu-trigger", { for: menuId }, h("button", null, h("span", { class: "visually-hidden" }, this.textMoreItems), h("span", { "aria-hidden": "true" }, "...")))), h("post-menu", { id: menuId, label: this.textMoreItems, placement: "bottom-start" }, h("slot", null))));
|
|
90
98
|
}
|
|
91
99
|
render() {
|
|
92
|
-
|
|
93
|
-
return (h(Host, { key: '4c0030c6896fa3bbbb26a26668a3b2cf96a110a9', "data-version": version }, h("nav", { key: '80834fa5581243a5cd081626ba743a29a2498502', "aria-label": this.textBreadcrumbs, class: "breadcrumbs-nav", ref: el => (this.breadcrumbsNavRef = el) }, h("ol", { key: '925aff0f9f19ef04e339ead446f5e4d4449b73ec', class: "no-list breadcrumbs-list" }, h("li", { key: '6dd10b7af11f6a63c27dc018dc49cdc8e85f7dcd' }, h("a", { key: '3c6db30d34a5f4d176b6127bc0ccb8fe733846af', href: this.homeUrl, class: "breadcrumb-link" }, h("span", { key: '9a78ed7042859125d32374885c0ce7426e2ff114', class: "visually-hidden" }, this.textHome), h("post-icon", { key: '096eaf22ab0f381de0b4a93a65972718101b2d4e', name: "home", class: "home-icon" }))), this.isConcatenated ? (h("li", { class: "menu-trigger-wrapper" }, h("post-icon", { name: "chevronright", class: "breadcrumb-item-icon" }), h("div", { class: "actual-menu" }, h("post-menu-trigger", { for: "breadcrumb-menu", tabIndex: 0, onKeyDown: e => {
|
|
94
|
-
if (e.key === 'Enter' || e.key === ' ') {
|
|
95
|
-
e.preventDefault();
|
|
96
|
-
this.handleBreadcrumbItemClick();
|
|
97
|
-
}
|
|
98
|
-
} }, h("button", { class: "btn", tabIndex: -1 }, "...")), h("post-menu", { id: "breadcrumb-menu", label: this.textMoreItems }, visibleItems.map(item => (h("post-menu-item", { key: item.url || item.text, class: "breadcrumb-item", onKeyDown: e => {
|
|
99
|
-
if (e.key === 'Enter' || e.key === ' ') {
|
|
100
|
-
const linkElement = e.currentTarget.querySelector('a');
|
|
101
|
-
linkElement?.click();
|
|
102
|
-
e.preventDefault();
|
|
103
|
-
}
|
|
104
|
-
} }, item.url ? (h("a", { href: item.url, "aria-label": item.label, "aria-description": item.description }, item.text)) : (h("span", null, item.text))))))))) : (visibleItems.map(item => (h("li", null, h("post-breadcrumb-item", { url: item.url, label: item.label, description: item.description, key: item.url || item.text }, item.text))))), this.lastItem && (h("li", { key: '57d4678e05401a248e31559eef7562a1608c0d58', "aria-current": "page" }, h("post-breadcrumb-item", { key: 'b1be2e79473288d0755a65a0819eb2a2301a89f2', url: this.lastItem.url, label: this.lastItem.label, description: this.lastItem.description, tabindex: -1 }, this.lastItem.text)))), h("div", { key: '9eaa408234c3497176bfc116ab02f8280ff1cce7', class: "hidden-items" }, h("a", { key: 'c19fab9c610fe33b0fb980e24fe6395ee4bed8c6', href: this.homeUrl, class: "hidden-breadcrumb-item" }, h("span", { key: '9d42d66632535330307f87fdad5ba6e983b4448a', class: "visually-hidden" }, this.textHome), h("post-icon", { key: 'b7cc4122d01930d5736f6eb929a46bcd32c547e4', name: "home", class: "home-icon" })), this.breadcrumbItems.map(item => (h("post-breadcrumb-item", { url: item.url, key: `hidden-${item.url || item.text}`, label: item.label, description: item.description, class: "hidden-breadcrumb-item" }, item.text)))))));
|
|
100
|
+
return (h(Host, { key: '7ad91a47dac5999eba506744321eb59a27970687', "data-version": version }, h("nav", { key: '3d84a12495ccd27df028cae550b319a2191f8721', "aria-label": this.textBreadcrumbs }, h("div", { key: '291436db8b8f171ca070f0b4fb6e24a6fd831e8d', role: "list" }, h("div", { key: 'cd5aeeee11626fde17bf384ebe7f1f1f701f2a86', class: "breadcrumb-item home", role: "listitem" }, h("a", { key: '9583685d73837b3971a575307621cb364c934d4e', href: this.homeUrl }, h("span", { key: '4896caee6c56016ee7e0ded0363bd5ead8f672bc', class: "visually-hidden" }, this.textHome), h("post-icon", { key: '8390117bb7e8527a813e3d306e16312fa1912ce6', "aria-hidden": "true", name: "home" }))), this.shouldRenderMenu ? this.renderMenu() : h("slot", null), h("slot", { key: '314d304f3f1d1cc09af197eea221d26a9bf1c0fe', name: "selected" })))));
|
|
105
101
|
}
|
|
106
102
|
static get is() { return "post-breadcrumbs"; }
|
|
107
103
|
static get encapsulation() { return "shadow"; }
|
|
@@ -129,7 +125,7 @@ export class PostBreadcrumbs {
|
|
|
129
125
|
"optional": false,
|
|
130
126
|
"docs": {
|
|
131
127
|
"tags": [],
|
|
132
|
-
"text": "The URL for the home breadcrumb item."
|
|
128
|
+
"text": "The URL for the root (home) breadcrumb item."
|
|
133
129
|
},
|
|
134
130
|
"getter": false,
|
|
135
131
|
"setter": false,
|
|
@@ -148,7 +144,7 @@ export class PostBreadcrumbs {
|
|
|
148
144
|
"optional": false,
|
|
149
145
|
"docs": {
|
|
150
146
|
"tags": [],
|
|
151
|
-
"text": "
|
|
147
|
+
"text": "An accessible label for the root (home) breadcrumb item."
|
|
152
148
|
},
|
|
153
149
|
"getter": false,
|
|
154
150
|
"setter": false,
|
|
@@ -167,7 +163,7 @@ export class PostBreadcrumbs {
|
|
|
167
163
|
"optional": false,
|
|
168
164
|
"docs": {
|
|
169
165
|
"tags": [],
|
|
170
|
-
"text": "
|
|
166
|
+
"text": "An accessible label for the breadcrumb navigation."
|
|
171
167
|
},
|
|
172
168
|
"getter": false,
|
|
173
169
|
"setter": false,
|
|
@@ -186,7 +182,7 @@ export class PostBreadcrumbs {
|
|
|
186
182
|
"optional": false,
|
|
187
183
|
"docs": {
|
|
188
184
|
"tags": [],
|
|
189
|
-
"text": "
|
|
185
|
+
"text": "An accessible label for the overflow menu that contains collapsed breadcrumb items."
|
|
190
186
|
},
|
|
191
187
|
"getter": false,
|
|
192
188
|
"setter": false,
|
|
@@ -197,25 +193,25 @@ export class PostBreadcrumbs {
|
|
|
197
193
|
}
|
|
198
194
|
static get states() {
|
|
199
195
|
return {
|
|
200
|
-
"
|
|
201
|
-
"
|
|
202
|
-
"lastWindowWidth": {}
|
|
196
|
+
"shouldRenderMenu": {},
|
|
197
|
+
"id": {}
|
|
203
198
|
};
|
|
204
199
|
}
|
|
205
200
|
static get elementRef() { return "host"; }
|
|
206
|
-
static get watchers() {
|
|
207
|
-
return [{
|
|
208
|
-
"propName": "homeUrl",
|
|
209
|
-
"methodName": "validateHomeUrl"
|
|
210
|
-
}, {
|
|
211
|
-
"propName": "textHome",
|
|
212
|
-
"methodName": "validateTextHome"
|
|
213
|
-
}, {
|
|
214
|
-
"propName": "textBreadcrumbs",
|
|
215
|
-
"methodName": "validateTextBreadcrumbs"
|
|
216
|
-
}, {
|
|
217
|
-
"propName": "textMoreItems",
|
|
218
|
-
"methodName": "validateTextMoreItems"
|
|
219
|
-
}];
|
|
220
|
-
}
|
|
221
201
|
}
|
|
202
|
+
__decorate([
|
|
203
|
+
Required(),
|
|
204
|
+
Url()
|
|
205
|
+
], PostBreadcrumbs.prototype, "homeUrl", void 0);
|
|
206
|
+
__decorate([
|
|
207
|
+
Required(),
|
|
208
|
+
Type('string')
|
|
209
|
+
], PostBreadcrumbs.prototype, "textHome", void 0);
|
|
210
|
+
__decorate([
|
|
211
|
+
Required(),
|
|
212
|
+
Type('string')
|
|
213
|
+
], PostBreadcrumbs.prototype, "textBreadcrumbs", void 0);
|
|
214
|
+
__decorate([
|
|
215
|
+
Required(),
|
|
216
|
+
Type('string')
|
|
217
|
+
], PostBreadcrumbs.prototype, "textMoreItems", void 0);
|
|
@@ -1,6 +1,16 @@
|
|
|
1
|
-
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
|
|
4
|
+
r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else
|
|
6
|
+
for (var i = decorators.length - 1; i >= 0; i--)
|
|
7
|
+
if (d = decorators[i])
|
|
8
|
+
r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
9
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
10
|
+
};
|
|
11
|
+
import { OneOf, Required } from "../../utils/index";
|
|
2
12
|
import { version } from "../../../../package";
|
|
3
|
-
import {
|
|
13
|
+
import { h, Host } from "@stencil/core";
|
|
4
14
|
import { BUTTON_TYPES, PLACEMENT, SIZE } from "./types";
|
|
5
15
|
/**
|
|
6
16
|
* @slot default - Slot for placing visually hidden label in the close button.
|
|
@@ -21,15 +31,6 @@ export class PostClosebutton {
|
|
|
21
31
|
*/
|
|
22
32
|
this.size = 'default';
|
|
23
33
|
}
|
|
24
|
-
validateButtonType() {
|
|
25
|
-
checkEmptyOrOneOf(this, 'buttonType', BUTTON_TYPES);
|
|
26
|
-
}
|
|
27
|
-
validatePlacement() {
|
|
28
|
-
checkRequiredAndOneOf(this, 'placement', PLACEMENT);
|
|
29
|
-
}
|
|
30
|
-
validateSize() {
|
|
31
|
-
checkRequiredAndOneOf(this, 'size', SIZE);
|
|
32
|
-
}
|
|
33
34
|
componentDidLoad() {
|
|
34
35
|
this.checkContent();
|
|
35
36
|
}
|
|
@@ -46,15 +47,12 @@ export class PostClosebutton {
|
|
|
46
47
|
}
|
|
47
48
|
}
|
|
48
49
|
checkContent() {
|
|
49
|
-
this.validateButtonType();
|
|
50
|
-
this.validatePlacement();
|
|
51
|
-
this.validateSize();
|
|
52
50
|
if (!this.host.querySelector('.visually-hidden').textContent) {
|
|
53
51
|
console.error(`The \`${this.host.localName}\` component requires content for accessibility.`);
|
|
54
52
|
}
|
|
55
53
|
}
|
|
56
54
|
render() {
|
|
57
|
-
return (h(Host, { key: '
|
|
55
|
+
return (h(Host, { key: 'a685b0c1dbf08de1253d7c232800b28aa445edeb', "data-version": version }, h("button", { key: 'e36535683023bd1cbcf560491a87ddab60f23d1c', type: this.buttonType, class: "btn btn-icon btn-secondary btn-sm" }, h("post-icon", { key: '405d5ca3761bd8ee56bdd9734a2550cbbbd81f0d', "aria-hidden": "true", name: "closex" }), h("span", { key: '2caa490891d922dc69ef4e6ebe8e5de813426d30', class: "visually-hidden" }, h("slot", { key: 'fd38d8c6da378058ea93c5c08f9f96d0b7be7813' })))));
|
|
58
56
|
}
|
|
59
57
|
static get is() { return "post-closebutton"; }
|
|
60
58
|
static get originalStyleUrls() {
|
|
@@ -153,16 +151,15 @@ export class PostClosebutton {
|
|
|
153
151
|
};
|
|
154
152
|
}
|
|
155
153
|
static get elementRef() { return "host"; }
|
|
156
|
-
static get watchers() {
|
|
157
|
-
return [{
|
|
158
|
-
"propName": "buttonType",
|
|
159
|
-
"methodName": "validateButtonType"
|
|
160
|
-
}, {
|
|
161
|
-
"propName": "placement",
|
|
162
|
-
"methodName": "validatePlacement"
|
|
163
|
-
}, {
|
|
164
|
-
"propName": "size",
|
|
165
|
-
"methodName": "validateSize"
|
|
166
|
-
}];
|
|
167
|
-
}
|
|
168
154
|
}
|
|
155
|
+
__decorate([
|
|
156
|
+
OneOf(BUTTON_TYPES)
|
|
157
|
+
], PostClosebutton.prototype, "buttonType", void 0);
|
|
158
|
+
__decorate([
|
|
159
|
+
Required(),
|
|
160
|
+
OneOf(PLACEMENT)
|
|
161
|
+
], PostClosebutton.prototype, "placement", void 0);
|
|
162
|
+
__decorate([
|
|
163
|
+
Required(),
|
|
164
|
+
OneOf(SIZE)
|
|
165
|
+
], PostClosebutton.prototype, "size", void 0);
|
|
@@ -1,7 +1,17 @@
|
|
|
1
|
-
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
|
|
4
|
+
r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else
|
|
6
|
+
for (var i = decorators.length - 1; i >= 0; i--)
|
|
7
|
+
if (d = decorators[i])
|
|
8
|
+
r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
9
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
10
|
+
};
|
|
11
|
+
import { collapse, collapsedKeyframe, expand } from "../../animations/collapse";
|
|
12
|
+
import { Type } from "../../utils/index";
|
|
2
13
|
import { version } from "../../../../package";
|
|
3
|
-
import {
|
|
4
|
-
import { checkEmptyOrType } from "../../utils/index";
|
|
14
|
+
import { Build, h, Host, } from "@stencil/core";
|
|
5
15
|
/**
|
|
6
16
|
* @slot default - Slot for placing content within the collapsible element.
|
|
7
17
|
*/
|
|
@@ -12,14 +22,10 @@ export class PostCollapsible {
|
|
|
12
22
|
*/
|
|
13
23
|
this.collapsed = false;
|
|
14
24
|
}
|
|
15
|
-
collapsedChange() {
|
|
16
|
-
checkEmptyOrType(this, 'collapsed', 'boolean');
|
|
17
|
-
}
|
|
18
25
|
get isExpanded() {
|
|
19
26
|
return !this.collapsed;
|
|
20
27
|
}
|
|
21
28
|
componentDidLoad() {
|
|
22
|
-
this.collapsedChange();
|
|
23
29
|
this.updateTriggers();
|
|
24
30
|
}
|
|
25
31
|
/**
|
|
@@ -46,14 +52,21 @@ export class PostCollapsible {
|
|
|
46
52
|
return isExpanded;
|
|
47
53
|
}
|
|
48
54
|
/**
|
|
49
|
-
* Update all post-collapsible-trigger elements referring to the collapsible
|
|
55
|
+
* Update all post-collapsible-trigger elements referring to or wrapping the collapsible
|
|
50
56
|
*/
|
|
51
57
|
updateTriggers() {
|
|
52
|
-
const triggers =
|
|
58
|
+
const triggers = this.host.id
|
|
59
|
+
? Array.from(document.querySelectorAll(`post-collapsible-trigger[for="${this.host.id}"]`))
|
|
60
|
+
: [];
|
|
61
|
+
// also update an ancestor trigger when the collapsible is nested inside one
|
|
62
|
+
const nestedTrigger = this.host.closest('post-collapsible-trigger');
|
|
63
|
+
if (nestedTrigger && !triggers.includes(nestedTrigger)) {
|
|
64
|
+
triggers.push(nestedTrigger);
|
|
65
|
+
}
|
|
53
66
|
triggers.forEach(trigger => trigger.update());
|
|
54
67
|
}
|
|
55
68
|
render() {
|
|
56
|
-
return (h(Host, { key: '
|
|
69
|
+
return (h(Host, { key: '5683b1c0346d1ed8aa6aa5ef8583654511ff0638', "data-version": version, tabindex: this.collapsed ? -1 : undefined, style: this.collapsed ? collapsedKeyframe : undefined }, h("slot", { key: '3271677498e00e964ee17733aa2871a12e57858c' })));
|
|
57
70
|
}
|
|
58
71
|
static get is() { return "post-collapsible"; }
|
|
59
72
|
static get encapsulation() { return "shadow"; }
|
|
@@ -135,10 +148,7 @@ export class PostCollapsible {
|
|
|
135
148
|
};
|
|
136
149
|
}
|
|
137
150
|
static get elementRef() { return "host"; }
|
|
138
|
-
static get watchers() {
|
|
139
|
-
return [{
|
|
140
|
-
"propName": "collapsed",
|
|
141
|
-
"methodName": "collapsedChange"
|
|
142
|
-
}];
|
|
143
|
-
}
|
|
144
151
|
}
|
|
152
|
+
__decorate([
|
|
153
|
+
Type('boolean')
|
|
154
|
+
], PostCollapsible.prototype, "collapsed", void 0);
|
|
@@ -8,16 +8,10 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
9
9
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
10
10
|
};
|
|
11
|
-
import {
|
|
11
|
+
import { EventFrom, getRoot, Type } from "../../utils/index";
|
|
12
12
|
import { version } from "../../../../package";
|
|
13
|
-
import {
|
|
13
|
+
import { h, Host } from "@stencil/core";
|
|
14
14
|
export class PostCollapsibleTrigger {
|
|
15
|
-
/**
|
|
16
|
-
* Set the "aria-controls" and "aria-expanded" attributes on the trigger to match the state of the controlled post-collapsible
|
|
17
|
-
*/
|
|
18
|
-
validateAriaAttributes() {
|
|
19
|
-
checkRequiredAndType(this, 'for', 'string');
|
|
20
|
-
}
|
|
21
15
|
constructor() {
|
|
22
16
|
this.observer = new MutationObserver(() => this.setTrigger());
|
|
23
17
|
this.handlePostToggle = this.handlePostToggle.bind(this);
|
|
@@ -34,7 +28,10 @@ export class PostCollapsibleTrigger {
|
|
|
34
28
|
this.setTrigger();
|
|
35
29
|
if (!this.trigger)
|
|
36
30
|
console.warn('The post-collapsible-trigger must contain a button.');
|
|
37
|
-
this.
|
|
31
|
+
if (!this.collapsible) {
|
|
32
|
+
const target = this.for ? `with id "${this.for}"` : 'nested inside <post-collapsible-trigger>';
|
|
33
|
+
console.warn(`No post-collapsible found ${target}. Either nest a post-collapsible inside the trigger or set the "for" attribute to the id of the collapsible.`);
|
|
34
|
+
}
|
|
38
35
|
}
|
|
39
36
|
disconnectedCallback() {
|
|
40
37
|
this.observer.disconnect();
|
|
@@ -56,18 +53,21 @@ export class PostCollapsibleTrigger {
|
|
|
56
53
|
}
|
|
57
54
|
}
|
|
58
55
|
updateAriaAttributes() {
|
|
59
|
-
|
|
56
|
+
const collapsible = this.collapsible;
|
|
57
|
+
if (!this.trigger || !collapsible)
|
|
60
58
|
return;
|
|
61
|
-
//
|
|
59
|
+
// a nested collapsible may have no id, but aria-controls needs one to reference
|
|
60
|
+
collapsible.id || (collapsible.id = `collapsible-${crypto.randomUUID()}`);
|
|
61
|
+
const collapsibleId = collapsible.id;
|
|
62
|
+
// add the controlled collapsible's id to the aria-controls list
|
|
62
63
|
const ariaControls = this.trigger.getAttribute('aria-controls');
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
64
|
+
const tokens = ariaControls ? ariaControls.split(/\s+/) : [];
|
|
65
|
+
if (!tokens.includes(collapsibleId)) {
|
|
66
|
+
tokens.push(collapsibleId);
|
|
67
|
+
this.trigger.setAttribute('aria-controls', tokens.join(' '));
|
|
66
68
|
}
|
|
67
|
-
// set
|
|
68
|
-
|
|
69
|
-
const newAriaExpanded = isCollapsed !== undefined ? !isCollapsed : undefined;
|
|
70
|
-
this.trigger.setAttribute('aria-expanded', `${newAriaExpanded}`);
|
|
69
|
+
// set aria-expanded to `true` if expanded, `false` if collapsed (collapsed defaults to false)
|
|
70
|
+
this.trigger.setAttribute('aria-expanded', `${!collapsible.collapsed}`);
|
|
71
71
|
}
|
|
72
72
|
/**
|
|
73
73
|
* Toggle the post-collapsible controlled by the trigger
|
|
@@ -79,7 +79,9 @@ export class PostCollapsibleTrigger {
|
|
|
79
79
|
* Retrieve the post-collapsible controlled by the trigger
|
|
80
80
|
*/
|
|
81
81
|
get collapsible() {
|
|
82
|
-
|
|
82
|
+
// prefer a nested post-collapsible, fall back to an id reference via `for`
|
|
83
|
+
const ref = this.host.querySelector('post-collapsible') ??
|
|
84
|
+
(this.for ? this.root?.getElementById(this.for) ?? null : null);
|
|
83
85
|
if (ref && ref.localName === 'post-collapsible') {
|
|
84
86
|
return ref;
|
|
85
87
|
}
|
|
@@ -89,7 +91,12 @@ export class PostCollapsibleTrigger {
|
|
|
89
91
|
* Find the button and add the proper event listener and ARIA attributes to it
|
|
90
92
|
*/
|
|
91
93
|
setTrigger() {
|
|
92
|
-
|
|
94
|
+
// skip buttons that belong to a nested collapsible's content
|
|
95
|
+
const trigger = Array.from(this.host.querySelectorAll('button')).find(button => {
|
|
96
|
+
const collapsible = button.closest('post-collapsible');
|
|
97
|
+
const isInsidePanel = !!collapsible && this.host.contains(collapsible);
|
|
98
|
+
return !isInsidePanel;
|
|
99
|
+
});
|
|
93
100
|
if (!trigger || (this.trigger && trigger.isEqualNode(this.trigger)))
|
|
94
101
|
return;
|
|
95
102
|
this.trigger = trigger;
|
|
@@ -97,7 +104,7 @@ export class PostCollapsibleTrigger {
|
|
|
97
104
|
this.updateAriaAttributes();
|
|
98
105
|
}
|
|
99
106
|
render() {
|
|
100
|
-
return (h(Host, { key: '
|
|
107
|
+
return (h(Host, { key: '40cfa7d940136d4bce5de0c2b37fca91187110f8', "data-version": version }, h("slot", { key: 'b8853f5be4361e59537b00d6fd60e6e42b7ea64d' })));
|
|
101
108
|
}
|
|
102
109
|
static get is() { return "post-collapsible-trigger"; }
|
|
103
110
|
static get encapsulation() { return "shadow"; }
|
|
@@ -111,11 +118,11 @@ export class PostCollapsibleTrigger {
|
|
|
111
118
|
"resolved": "string",
|
|
112
119
|
"references": {}
|
|
113
120
|
},
|
|
114
|
-
"required":
|
|
115
|
-
"optional":
|
|
121
|
+
"required": false,
|
|
122
|
+
"optional": true,
|
|
116
123
|
"docs": {
|
|
117
124
|
"tags": [],
|
|
118
|
-
"text": "Link the trigger to a post-collapsible
|
|
125
|
+
"text": "Link the trigger to a post-collapsible by its ID.\nIf omitted, a post-collapsible nested directly inside this element is used instead."
|
|
119
126
|
},
|
|
120
127
|
"getter": false,
|
|
121
128
|
"setter": false,
|
|
@@ -146,13 +153,10 @@ export class PostCollapsibleTrigger {
|
|
|
146
153
|
};
|
|
147
154
|
}
|
|
148
155
|
static get elementRef() { return "host"; }
|
|
149
|
-
static get watchers() {
|
|
150
|
-
return [{
|
|
151
|
-
"propName": "for",
|
|
152
|
-
"methodName": "validateAriaAttributes"
|
|
153
|
-
}];
|
|
154
|
-
}
|
|
155
156
|
}
|
|
157
|
+
__decorate([
|
|
158
|
+
Type('string')
|
|
159
|
+
], PostCollapsibleTrigger.prototype, "for", void 0);
|
|
156
160
|
__decorate([
|
|
157
161
|
EventFrom('post-collapsible')
|
|
158
162
|
], PostCollapsibleTrigger.prototype, "handlePostToggle", null);
|