@swisspost/design-system-components 9.0.0-next.11 → 9.0.0-next.13
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/.config/bindings.angular.js +4 -0
- package/dist/cjs/{attribute-observer-10f08c04.js → attribute-observer-6d8b886b.js} +4 -4
- package/dist/cjs/{check-one-of-f4f5d0c0.js → check-one-of-ef931478.js} +2 -1
- package/dist/cjs/{check-type-64af82a9.js → check-type-696d2c51.js} +4 -4
- package/dist/cjs/{check-url-3ffdd2fb.js → check-url-1cf6fb0d.js} +2 -1
- package/dist/cjs/{debounce-1151afe3.js → debounce-158fd76f.js} +2 -1
- package/dist/cjs/fade-72d5ef55.js +14 -0
- package/dist/cjs/{index-5d4e0aed.js → index-bea4ac42.js} +7 -5
- package/dist/cjs/index.cjs.js +27 -27
- package/dist/cjs/{package-5fdfea90.js → package-60e57542.js} +1 -1
- package/dist/cjs/{post-accordion-dabc9271.js → post-accordion-1e495c23.js} +5 -4
- package/dist/cjs/{post-accordion-item-9dadc543.js → post-accordion-item-86b6950a.js} +6 -6
- package/dist/cjs/post-accordion-item.cjs.entry.js +6 -6
- package/dist/cjs/post-accordion.cjs.entry.js +3 -3
- package/dist/cjs/{post-avatar-fddda407.js → post-avatar-067c033b.js} +7 -11
- package/dist/cjs/post-avatar.cjs.entry.js +2 -2
- package/dist/cjs/{post-back-to-top-6dfbcd1b.js → post-back-to-top-7efd1066.js} +8 -7
- package/dist/cjs/post-back-to-top.cjs.entry.js +4 -4
- package/dist/cjs/{post-banner-6df79142.js → post-banner-a6808d7d.js} +11 -6
- package/dist/cjs/post-banner.cjs.entry.js +7 -7
- package/dist/cjs/{post-breadcrumb-b05fb572.js → post-breadcrumb-b33abf67.js} +27 -26
- package/dist/cjs/post-breadcrumb-item_2.cjs.entry.js +6 -6
- package/dist/cjs/post-breadcrumb.cjs.entry.js +4 -4
- package/dist/cjs/post-card-control-7867a104.js +283 -0
- package/dist/cjs/post-card-control.cjs.entry.js +3 -3
- package/dist/cjs/post-closebutton_15.cjs.entry.js +7 -7
- package/dist/cjs/{post-collapsible-trigger-94f1bbd9.js → post-collapsible-trigger-6affdc02.js} +38 -32
- package/dist/cjs/post-collapsible_2.cjs.entry.js +7 -7
- package/dist/cjs/{post-footer-f95510e4.js → post-footer-330e8999.js} +11 -8
- package/dist/cjs/post-footer.cjs.entry.js +2 -2
- package/dist/cjs/{post-menu-item-106036fa.js → post-menu-item-48191dfd.js} +6 -6
- package/dist/cjs/{post-popover-cc55d371.js → post-popover-27f3e9aa.js} +7 -5
- package/dist/cjs/post-popover.cjs.entry.js +3 -3
- package/dist/cjs/{post-rating-4aa3fabb.js → post-rating-28904e91.js} +13 -3
- package/dist/cjs/post-rating.cjs.entry.js +2 -2
- package/dist/cjs/post-tab-header-86b129ab.js +33 -0
- package/dist/cjs/post-tab-header.cjs.entry.js +2 -2
- package/dist/cjs/{post-tab-panel-77162d5b.js → post-tab-panel-94333a7e.js} +2 -2
- package/dist/cjs/post-tab-panel.cjs.entry.js +2 -2
- package/dist/cjs/{post-tabs-ee832221.js → post-tabs-f8581050.js} +21 -16
- package/dist/cjs/post-tabs.cjs.entry.js +3 -3
- package/dist/cjs/{post-tag-8778a125.js → post-tag-3a24c574.js} +3 -3
- package/dist/cjs/post-tag.cjs.entry.js +2 -2
- package/dist/cjs/{post-togglebutton-00632399.js → post-togglebutton-e7d697bf.js} +184 -106
- package/dist/cjs/{post-tooltip-d3dd17b2.js → post-tooltip-8c87dfe3.js} +8 -7
- package/dist/cjs/post-tooltip.cjs.entry.js +7 -7
- package/dist/cjs/{slide-5d51abe8.js → slide-8ae17ee4.js} +4 -4
- package/dist/collection/animations/collapse.js +5 -5
- package/dist/collection/animations/fade.js +6 -2
- package/dist/collection/animations/slide.js +4 -4
- package/dist/collection/components/post-accordion/post-accordion.js +3 -1
- package/dist/collection/components/post-accordion-item/post-accordion-item.js +4 -3
- package/dist/collection/components/post-avatar/post-avatar.js +6 -9
- package/dist/collection/components/post-back-to-top/post-back-to-top.js +5 -3
- package/dist/collection/components/post-banner/post-banner.css +1 -1
- package/dist/collection/components/post-banner/post-banner.js +6 -0
- package/dist/collection/components/post-breadcrumb/post-breadcrumb.js +24 -22
- package/dist/collection/components/post-breadcrumb-item/post-breadcrumb-item.js +4 -3
- package/dist/collection/components/post-card-control/post-card-control.css +1 -1
- package/dist/collection/components/post-card-control/post-card-control.js +43 -31
- package/dist/collection/components/post-closebutton/post-closebutton.js +1 -0
- package/dist/collection/components/post-collapsible/post-collapsible.css +1 -1
- package/dist/collection/components/post-collapsible/post-collapsible.js +9 -2
- package/dist/collection/components/post-collapsible-trigger/post-collapsible-trigger.js +19 -18
- package/dist/collection/components/post-footer/post-footer.js +1 -0
- package/dist/collection/components/post-header/post-header.css +1 -1
- package/dist/collection/components/post-header/post-header.js +9 -8
- package/dist/collection/components/post-icon/post-icon.js +51 -14
- package/dist/collection/components/post-language-option/post-language-option.js +5 -0
- package/dist/collection/components/post-language-switch/post-language-switch.js +2 -1
- package/dist/collection/components/post-list/post-list.js +2 -0
- package/dist/collection/components/post-list-item/post-list-item.js +1 -0
- package/dist/collection/components/post-logo/post-logo.js +2 -1
- package/dist/collection/components/post-mainnavigation/post-mainnavigation.css +1 -1
- package/dist/collection/components/post-mainnavigation/post-mainnavigation.js +6 -0
- package/dist/collection/components/post-megadropdown/post-megadropdown.css +1 -1
- package/dist/collection/components/post-megadropdown/post-megadropdown.js +14 -2
- package/dist/collection/components/post-megadropdown-trigger/post-megadropdown-trigger.js +6 -5
- package/dist/collection/components/post-menu/post-menu.js +42 -29
- package/dist/collection/components/post-menu-trigger/post-menu-trigger.js +13 -11
- package/dist/collection/components/post-popover/post-popover.css +1 -1
- package/dist/collection/components/post-popover/post-popover.js +4 -1
- package/dist/collection/components/post-popovercontainer/post-popovercontainer.css +1 -1
- package/dist/collection/components/post-popovercontainer/post-popovercontainer.js +9 -0
- package/dist/collection/components/post-rating/post-rating.js +12 -1
- package/dist/collection/components/post-tab-header/post-tab-header.css +1 -1
- package/dist/collection/components/post-tab-header/post-tab-header.js +1 -0
- package/dist/collection/components/post-tab-panel/post-tab-panel.js +1 -0
- package/dist/collection/components/post-tabs/post-tabs.css +1 -1
- package/dist/collection/components/post-tabs/post-tabs.js +16 -15
- package/dist/collection/components/post-tag/post-tag.css +1 -1
- package/dist/collection/components/post-tag/post-tag.js +1 -0
- package/dist/collection/components/post-togglebutton/post-togglebutton.js +11 -10
- package/dist/collection/components/post-tooltip/post-tooltip.js +5 -3
- package/dist/collection/utils/attribute-observer.js +4 -4
- package/dist/collection/utils/breakpoints.js +9 -6
- package/dist/collection/utils/component-on-ready.js +4 -4
- package/dist/collection/utils/debounce.js +2 -1
- package/dist/collection/utils/get-focusable-children.js +2 -2
- package/dist/collection/utils/property-checkers/check-one-of.js +2 -1
- package/dist/collection/utils/property-checkers/check-pattern.js +2 -1
- package/dist/collection/utils/property-checkers/check-type.js +4 -4
- package/dist/collection/utils/property-checkers/check-url.js +2 -1
- package/dist/collection/utils/property-checkers/empty-or.js +2 -1
- package/dist/collection/utils/sass-export.js +8 -5
- package/dist/components/attribute-observer.js +4 -4
- package/dist/components/check-one-of.js +2 -1
- package/dist/components/check-type.js +4 -4
- package/dist/components/debounce.js +2 -1
- package/dist/components/fade.js +6 -2
- package/dist/components/index2.js +6 -3
- package/dist/components/package.js +1 -1
- package/dist/components/post-accordion-item2.js +4 -4
- package/dist/components/post-accordion2.js +3 -2
- package/dist/components/post-avatar2.js +6 -10
- package/dist/components/post-back-to-top2.js +5 -4
- package/dist/components/post-banner2.js +7 -2
- package/dist/components/post-breadcrumb-item2.js +4 -4
- package/dist/components/post-breadcrumb2.js +24 -23
- package/dist/components/post-card-control2.js +44 -33
- package/dist/components/post-closebutton2.js +1 -1
- package/dist/components/post-collapsible-trigger2.js +19 -19
- package/dist/components/post-collapsible2.js +15 -9
- package/dist/components/post-footer2.js +10 -7
- package/dist/components/post-header2.js +10 -10
- package/dist/components/post-icon2.js +51 -15
- package/dist/components/post-language-option2.js +5 -1
- package/dist/components/post-language-switch2.js +2 -2
- package/dist/components/post-list-item2.js +1 -1
- package/dist/components/post-list2.js +2 -1
- package/dist/components/post-logo2.js +2 -2
- package/dist/components/post-mainnavigation2.js +7 -2
- package/dist/components/post-megadropdown-trigger2.js +6 -6
- package/dist/components/post-megadropdown2.js +15 -4
- package/dist/components/post-menu-trigger2.js +13 -12
- package/dist/components/post-menu2.js +44 -32
- package/dist/components/post-popover2.js +5 -3
- package/dist/components/post-popovercontainer2.js +10 -2
- package/dist/components/post-rating2.js +12 -2
- package/dist/components/post-tab-header2.js +2 -2
- package/dist/components/post-tab-panel2.js +1 -1
- package/dist/components/post-tabs2.js +19 -14
- package/dist/components/post-tag2.js +2 -2
- package/dist/components/post-togglebutton2.js +11 -11
- package/dist/components/post-tooltip2.js +5 -4
- package/dist/components/slide.js +4 -4
- package/dist/docs.json +3 -8
- package/dist/esm/{attribute-observer-37fa950a.js → attribute-observer-2f203993.js} +4 -4
- package/dist/esm/{check-one-of-6b3ef8eb.js → check-one-of-0d5858c0.js} +2 -1
- package/dist/esm/{check-type-8828dbe4.js → check-type-a6ccc9a3.js} +4 -4
- package/dist/esm/{check-url-a974431e.js → check-url-0bd876f7.js} +2 -1
- package/dist/esm/{debounce-abe98cc2.js → debounce-e54c7131.js} +2 -1
- package/dist/esm/fade-1f3cacf4.js +11 -0
- package/dist/esm/{index-b49c9904.js → index-d1bbbd88.js} +7 -5
- package/dist/esm/index.js +27 -27
- package/dist/esm/package-495dba42.js +3 -0
- package/dist/esm/{post-accordion-25df8744.js → post-accordion-48eb17c3.js} +6 -5
- package/dist/esm/{post-accordion-item-33fb36df.js → post-accordion-item-e0893bb3.js} +7 -7
- package/dist/esm/post-accordion-item.entry.js +6 -6
- package/dist/esm/post-accordion.entry.js +3 -3
- package/dist/esm/{post-avatar-731aafd6.js → post-avatar-20cde806.js} +8 -12
- package/dist/esm/post-avatar.entry.js +2 -2
- package/dist/esm/{post-back-to-top-3a6b6203.js → post-back-to-top-e422c426.js} +9 -8
- package/dist/esm/post-back-to-top.entry.js +4 -4
- package/dist/esm/{post-banner-b2eb796c.js → post-banner-7385397e.js} +12 -7
- package/dist/esm/post-banner.entry.js +7 -7
- package/dist/esm/{post-breadcrumb-0a99384c.js → post-breadcrumb-39203792.js} +28 -27
- package/dist/esm/post-breadcrumb-item_2.entry.js +6 -6
- package/dist/esm/post-breadcrumb.entry.js +4 -4
- package/dist/esm/post-card-control-d2c25c96.js +281 -0
- package/dist/esm/post-card-control.entry.js +3 -3
- package/dist/esm/post-closebutton_15.entry.js +7 -7
- package/dist/esm/{post-collapsible-trigger-7fc4d61c.js → post-collapsible-trigger-2f9ad9a5.js} +39 -33
- package/dist/esm/post-collapsible_2.entry.js +7 -7
- package/dist/esm/{post-footer-97bbd770.js → post-footer-e804a967.js} +12 -9
- package/dist/esm/post-footer.entry.js +2 -2
- package/dist/esm/{post-menu-item-ae066299.js → post-menu-item-f9793958.js} +7 -7
- package/dist/esm/{post-popover-62e33068.js → post-popover-8205412a.js} +8 -6
- package/dist/esm/post-popover.entry.js +3 -3
- package/dist/esm/{post-rating-ee73a51b.js → post-rating-95ecb434.js} +14 -4
- package/dist/esm/post-rating.entry.js +2 -2
- package/dist/esm/post-tab-header-d520b99a.js +31 -0
- package/dist/esm/post-tab-header.entry.js +2 -2
- package/dist/esm/{post-tab-panel-5e35e7df.js → post-tab-panel-8c8d2332.js} +3 -3
- package/dist/esm/post-tab-panel.entry.js +2 -2
- package/dist/esm/{post-tabs-b614a577.js → post-tabs-dd6dfe43.js} +22 -17
- package/dist/esm/post-tabs.entry.js +3 -3
- package/dist/esm/{post-tag-413626e4.js → post-tag-593813a4.js} +4 -4
- package/dist/esm/post-tag.entry.js +2 -2
- package/dist/esm/{post-togglebutton-caf0000b.js → post-togglebutton-120df903.js} +185 -107
- package/dist/esm/{post-tooltip-b0f1b147.js → post-tooltip-a13d6fbb.js} +9 -8
- package/dist/esm/post-tooltip.entry.js +7 -7
- package/dist/esm/{slide-3422b8a3.js → slide-62768431.js} +4 -4
- package/dist/post-components/index.esm.js +1 -1
- package/dist/post-components/p-0b613350.js +1 -0
- package/dist/post-components/p-1fda117c.js +1 -0
- package/dist/post-components/p-20e1b680.js +1 -0
- package/dist/post-components/p-29bc8ddc.entry.js +1 -0
- package/dist/post-components/p-2b4c7ec7.entry.js +1 -0
- package/dist/post-components/p-2f327006.entry.js +1 -0
- package/dist/post-components/p-3632ace7.js +1 -0
- package/dist/post-components/p-3a978ea9.entry.js +1 -0
- package/dist/post-components/{p-cc55b611.js → p-3d4fdde0.js} +1 -1
- package/dist/post-components/p-427132e3.entry.js +1 -0
- package/dist/post-components/p-445dfa96.js +1 -0
- package/dist/post-components/p-4af6dbed.js +1 -0
- package/dist/post-components/p-4c0c13a9.js +1 -0
- package/dist/post-components/{p-d45f8861.js → p-4fc83a1c.js} +2 -2
- package/dist/post-components/p-5384e6f4.js +1 -0
- package/dist/post-components/p-5630677a.entry.js +1 -0
- package/dist/post-components/p-5e5ee06d.entry.js +1 -0
- package/dist/post-components/p-64e3de38.js +1 -0
- package/dist/post-components/p-68c43ef0.entry.js +1 -0
- package/dist/post-components/p-6e39bb59.entry.js +1 -0
- package/dist/post-components/p-6fede961.js +1 -0
- package/dist/post-components/p-72a5ee9b.js +1 -0
- package/dist/post-components/p-72d9d594.entry.js +1 -0
- package/dist/post-components/p-85bf673e.entry.js +1 -0
- package/dist/post-components/p-8decb072.entry.js +1 -0
- package/dist/post-components/p-92f8803c.entry.js +1 -0
- package/dist/post-components/p-9596c7d6.js +1 -0
- package/dist/post-components/p-9748a355.js +1 -0
- package/dist/post-components/p-975b30f5.js +1 -0
- package/dist/post-components/p-9a50697e.entry.js +1 -0
- package/dist/post-components/p-a72cb18c.js +1 -0
- package/dist/post-components/p-aaca7ca7.js +1 -0
- package/dist/post-components/p-ac2189b7.js +1 -0
- package/dist/post-components/p-afe3b28e.js +1 -0
- package/dist/post-components/p-b129c166.js +1 -0
- package/dist/post-components/p-bd49bb7e.entry.js +1 -0
- package/dist/post-components/p-c043686c.entry.js +1 -0
- package/dist/post-components/p-c8544b65.js +1 -0
- package/dist/post-components/p-c9f65844.entry.js +1 -0
- package/dist/post-components/{p-189a07cf.entry.js → p-d6449a93.entry.js} +1 -1
- package/dist/post-components/p-f7c5b0c2.js +1 -0
- package/dist/post-components/post-components.esm.js +1 -1
- package/dist/types/animations/collapse.d.ts +2 -2
- package/dist/types/animations/fade.d.ts +2 -2
- package/dist/types/animations/slide.d.ts +2 -2
- package/dist/types/components/post-icon/post-icon.d.ts +1 -1
- package/dist/types/components/post-tabs/post-tabs.d.ts +1 -1
- package/dist/types/components.d.ts +2 -2
- package/dist/types/home/runner/work/design-system/design-system/packages/components/.stencil/.config/bindings.angular.d.ts +2 -0
- package/dist/types/utils/attribute-observer.d.ts +1 -1
- package/dist/types/utils/component-on-ready.d.ts +1 -1
- package/dist/types/utils/get-focusable-children.d.ts +1 -1
- package/dist/types/utils/sass-export.d.ts +5 -1
- package/loaders/attribute-observer.js +4 -4
- package/loaders/check-one-of.js +2 -1
- package/loaders/check-type.js +4 -4
- package/loaders/debounce.js +2 -1
- package/loaders/fade.js +6 -2
- package/loaders/index2.js +6 -3
- package/loaders/package.js +1 -1
- package/loaders/post-accordion-item2.js +4 -4
- package/loaders/post-accordion.js +3 -2
- package/loaders/post-avatar.js +6 -10
- package/loaders/post-back-to-top.js +5 -4
- package/loaders/post-banner.js +7 -2
- package/loaders/post-breadcrumb-item2.js +4 -4
- package/loaders/post-breadcrumb.js +24 -23
- package/loaders/post-card-control.js +44 -33
- package/loaders/post-closebutton.js +1 -1
- package/loaders/post-collapsible-trigger2.js +19 -19
- package/loaders/post-collapsible2.js +15 -9
- package/loaders/post-footer.js +10 -7
- package/loaders/post-header.js +10 -10
- package/loaders/post-icon2.js +51 -15
- package/loaders/post-language-option.js +5 -1
- package/loaders/post-language-switch.js +2 -2
- package/loaders/post-list-item.js +1 -1
- package/loaders/post-list.js +2 -1
- package/loaders/post-logo.js +2 -2
- package/loaders/post-mainnavigation.js +7 -2
- package/loaders/post-megadropdown-trigger.js +6 -6
- package/loaders/post-megadropdown.js +15 -4
- package/loaders/post-menu-trigger2.js +13 -12
- package/loaders/post-menu2.js +44 -32
- package/loaders/post-popover.js +5 -3
- package/loaders/post-popovercontainer2.js +10 -2
- package/loaders/post-rating.js +12 -2
- package/loaders/post-tab-header.js +2 -2
- package/loaders/post-tab-panel.js +1 -1
- package/loaders/post-tabs.js +19 -14
- package/loaders/post-tag.js +2 -2
- package/loaders/post-togglebutton.js +11 -11
- package/loaders/post-tooltip.js +5 -4
- package/loaders/slide.js +4 -4
- package/package.json +13 -9
- package/dist/cjs/fade-35a3633a.js +0 -10
- package/dist/cjs/post-card-control-97ed732c.js +0 -272
- package/dist/cjs/post-tab-header-1eee4cbf.js +0 -33
- package/dist/esm/fade-7fd71785.js +0 -7
- package/dist/esm/package-cf78d928.js +0 -3
- package/dist/esm/post-card-control-ff272e38.js +0 -270
- package/dist/esm/post-tab-header-dac84177.js +0 -31
- package/dist/post-components/p-012a39b8.js +0 -1
- package/dist/post-components/p-0a74bc53.js +0 -1
- package/dist/post-components/p-0addae0c.entry.js +0 -1
- package/dist/post-components/p-128b11b3.js +0 -1
- package/dist/post-components/p-13ae0f4d.entry.js +0 -1
- package/dist/post-components/p-15173f46.js +0 -1
- package/dist/post-components/p-18b84db7.entry.js +0 -1
- package/dist/post-components/p-2571a1be.entry.js +0 -1
- package/dist/post-components/p-2737eaf5.js +0 -1
- package/dist/post-components/p-2747a945.js +0 -1
- package/dist/post-components/p-32165625.js +0 -1
- package/dist/post-components/p-42ef1d9f.entry.js +0 -1
- package/dist/post-components/p-465e9eee.entry.js +0 -1
- package/dist/post-components/p-515e0f96.js +0 -1
- package/dist/post-components/p-5467b223.js +0 -1
- package/dist/post-components/p-60ea48ce.js +0 -1
- package/dist/post-components/p-61cff5d9.entry.js +0 -1
- package/dist/post-components/p-6adeaa6c.js +0 -1
- package/dist/post-components/p-723ad003.entry.js +0 -1
- package/dist/post-components/p-73863597.js +0 -1
- package/dist/post-components/p-761723b6.js +0 -1
- package/dist/post-components/p-7c966321.js +0 -1
- package/dist/post-components/p-8e808ae6.js +0 -1
- package/dist/post-components/p-92611da2.entry.js +0 -1
- package/dist/post-components/p-990db73a.js +0 -1
- package/dist/post-components/p-99b12d43.entry.js +0 -1
- package/dist/post-components/p-9fbb33c2.entry.js +0 -1
- package/dist/post-components/p-a43a3cdb.js +0 -1
- package/dist/post-components/p-ad770600.entry.js +0 -1
- package/dist/post-components/p-af48ed67.entry.js +0 -1
- package/dist/post-components/p-c4139fb9.js +0 -1
- package/dist/post-components/p-dc11a5d5.entry.js +0 -1
- package/dist/post-components/p-df9ea014.js +0 -1
- package/dist/post-components/p-e1dc7f01.entry.js +0 -1
- package/dist/post-components/p-e533625e.js +0 -1
- package/dist/post-components/p-f0da081f.entry.js +0 -1
- package/dist/post-components/p-f380a026.entry.js +0 -1
- package/dist/post-components/p-fbcc89be.js +0 -1
- /package/dist/post-components/{p-4a3f67ab.js → p-8562c7dc.js} +0 -0
- /package/dist/post-components/{p-611b3c41.js → p-bacd3e2c.js} +0 -0
- /package/dist/post-components/{p-b22656b1.js → p-cb9ab938.js} +0 -0
- /package/dist/post-components/{p-d4f93f2b.js → p-e1baac59.js} +0 -0
package/loaders/slide.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
const easing = 'ease';
|
|
2
2
|
const duration = 500;
|
|
3
3
|
const fill = 'forwards';
|
|
4
|
-
|
|
4
|
+
function slideUp(el, translateSize = '100%') {
|
|
5
5
|
return el.animate([
|
|
6
6
|
{ transform: `translateY(${translateSize})` }, // Starting position (no translation)
|
|
7
7
|
{ transform: 'translateY(0)' }, // End position
|
|
@@ -10,8 +10,8 @@ const slideUp = (el, translateSize = '100%') => {
|
|
|
10
10
|
easing,
|
|
11
11
|
fill,
|
|
12
12
|
});
|
|
13
|
-
}
|
|
14
|
-
|
|
13
|
+
}
|
|
14
|
+
function slideDown(el, translateSize = '100%') {
|
|
15
15
|
return el.animate([
|
|
16
16
|
{ transform: 'translateY(0)' }, // Starting position (no translation)
|
|
17
17
|
{ transform: `translateY(${translateSize})` }, // End position
|
|
@@ -20,6 +20,6 @@ const slideDown = (el, translateSize = '100%') => {
|
|
|
20
20
|
easing,
|
|
21
21
|
fill,
|
|
22
22
|
});
|
|
23
|
-
}
|
|
23
|
+
}
|
|
24
24
|
|
|
25
25
|
export { slideDown as a, slideUp as s };
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@swisspost/design-system-components",
|
|
3
|
-
"version": "9.0.0-next.
|
|
3
|
+
"version": "9.0.0-next.13",
|
|
4
4
|
"description": "A collection of web components built with Stencil JS for the Swiss Post Design System.",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"main": "dist/index.cjs.js",
|
|
@@ -26,36 +26,39 @@
|
|
|
26
26
|
"dependencies": {
|
|
27
27
|
"@floating-ui/dom": "1.6.13",
|
|
28
28
|
"@oddbird/popover-polyfill": "0.3.7",
|
|
29
|
-
"@swisspost/design-system-icons": "9.0.0-next.
|
|
30
|
-
"@swisspost/design-system-styles": "9.0.0-next.
|
|
29
|
+
"@swisspost/design-system-icons": "9.0.0-next.13",
|
|
30
|
+
"@swisspost/design-system-styles": "9.0.0-next.13",
|
|
31
31
|
"ally.js": "1.4.1",
|
|
32
32
|
"long-press-event": "2.5.0",
|
|
33
33
|
"nanoid": "5.0.9"
|
|
34
34
|
},
|
|
35
35
|
"devDependencies": {
|
|
36
|
+
"@eslint/compat": "1.2.5",
|
|
37
|
+
"@eslint/js": "9.18.0",
|
|
36
38
|
"@percy/cli": "1.30.6",
|
|
37
39
|
"@percy/cypress": "3.1.2",
|
|
38
|
-
"@stencil-community/eslint-plugin": "0.
|
|
40
|
+
"@stencil-community/eslint-plugin": "0.9.0",
|
|
39
41
|
"@stencil/angular-output-target": "0.8.4",
|
|
40
42
|
"@stencil/core": "4.19.2",
|
|
41
43
|
"@stencil/react-output-target": "0.5.3",
|
|
42
44
|
"@stencil/sass": "3.0.12",
|
|
43
45
|
"@types/jest": "29.5.14",
|
|
44
46
|
"@types/node": "22.10.5",
|
|
45
|
-
"@typescript-eslint/eslint-plugin": "7.18.0",
|
|
46
47
|
"@typescript-eslint/parser": "7.18.0",
|
|
47
48
|
"bootstrap": "5.3.3",
|
|
48
49
|
"cypress": "13.13.2",
|
|
49
50
|
"cypress-axe": "1.5.0",
|
|
50
51
|
"cypress-storybook": "1.0.0",
|
|
51
|
-
"eslint": "
|
|
52
|
-
"eslint-plugin-react": "7.37.
|
|
52
|
+
"eslint": "9.18.0",
|
|
53
|
+
"eslint-plugin-react": "7.37.4",
|
|
54
|
+
"globals": "15.14.0",
|
|
53
55
|
"rimraf": "6.0.1",
|
|
54
56
|
"rollup-plugin-postcss": "4.0.2",
|
|
55
57
|
"sass": "1.78.0",
|
|
56
58
|
"throttle-debounce": "5.0.2",
|
|
57
59
|
"ts-jest": "29.2.5",
|
|
58
|
-
"typescript": "5.5.4"
|
|
60
|
+
"typescript": "5.5.4",
|
|
61
|
+
"typescript-eslint": "8.20.0"
|
|
59
62
|
},
|
|
60
63
|
"keywords": [
|
|
61
64
|
"components",
|
|
@@ -77,6 +80,7 @@
|
|
|
77
80
|
"e2e:ci": "xvfb-run -a cypress run --browser chrome",
|
|
78
81
|
"e2e:watch": "cypress open",
|
|
79
82
|
"generate": "stencil generate",
|
|
80
|
-
"lint": "eslint
|
|
83
|
+
"lint": "eslint",
|
|
84
|
+
"lint:fix": "eslint --fix"
|
|
81
85
|
}
|
|
82
86
|
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const fadeDuration = 200;
|
|
4
|
-
const fadedOutKeyframe = { opacity: '0' };
|
|
5
|
-
const fadedInKeyframe = { opacity: '1' };
|
|
6
|
-
const fadeIn = (el) => el.animate([fadedOutKeyframe, fadedInKeyframe], { duration: fadeDuration });
|
|
7
|
-
const fadeOut = (el) => el.animate([fadedInKeyframe, fadedOutKeyframe], { duration: fadeDuration });
|
|
8
|
-
|
|
9
|
-
exports.fadeIn = fadeIn;
|
|
10
|
-
exports.fadeOut = fadeOut;
|
|
@@ -1,272 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const index = require('./index-f1b08cdb.js');
|
|
4
|
-
const checkOneOf = require('./check-one-of-f4f5d0c0.js');
|
|
5
|
-
const checkNonEmpty = require('./check-non-empty-eeaa8f77.js');
|
|
6
|
-
const _package = require('./package-5fdfea90.js');
|
|
7
|
-
|
|
8
|
-
const postCardControlCss = "/*!\n * Copyright 2021 by Swiss Post, Information Technology\n */.form-check{display:flex;flex-wrap:wrap;align-items:flex-start;width:fit-content;border-radius:var(--post-device-border-radius-focus)}.form-check-inline{display:inline-flex;vertical-align:top}fieldset>.form-check-inline:not(:last-of-type){margin-right:var(--post-core-dimension-24)}.form-check:has(>input:not(:only-child)){outline-offset:var(--post-device-spacing-padding-2) !important;outline:var(--post-scheme-color-interactive-focus-stroke) none var(--post-device-border-width-focus) !important}.form-check:has(>input:not(:only-child)):is(:focus-visible,:has(:focus-visible),.pretend-focus){outline-style:var(--post-core-border-style-solid) !important}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:has(>input:not(:only-child)):is(:focus-visible,:has(:focus-visible),.pretend-focus){outline-color:Highlight !important}}@supports not selector(:has(:focus-visible)){.form-check:has(>input:not(:only-child)):is(:focus-visible,:focus-within,.pretend-focus){outline-style:var(--post-core-border-style-solid) !important}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:has(>input:not(:only-child)):is(:focus-visible,:focus-within,.pretend-focus){outline-color:Highlight !important}}}.form-check:has(>input:not(:only-child))>input{outline:none !important}.form-check:has(input[type=checkbox]):not(.form-switch){padding-block:var(--post-device-spacing-padding-block-19)}fieldset>.form-check:has(input[type=checkbox]):not(.form-switch):not(:last-of-type){margin-bottom:var(--post-device-spacing-gap-4)}.form-check:has(input[type=checkbox]):not(.form-switch)>input[type=checkbox]~label{padding-block:var(--post-device-spacing-padding-block-20);padding-inline-start:var(--post-device-spacing-gap-inline-12);color:var(--post-scheme-color-interactive-primary-enabled-fg1)}.form-check:has(input[type=checkbox]):not(.form-switch)>input[type=checkbox]:not([disabled])~label{cursor:pointer}.form-check:has(input[type=checkbox]):not(.form-switch)>input[type=checkbox]:not([disabled]):hover~label{color:var(--post-scheme-color-interactive-primary-hover-fg1)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:has(input[type=checkbox]):not(.form-switch)>input[type=checkbox]:not([disabled]):hover~label{color:Highlight}}.form-check:has(input[type=checkbox]):not(.form-switch)>input[type=checkbox][disabled]~label{color:var(--post-scheme-color-interactive-primary-disabled-fg4)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:has(input[type=checkbox]):not(.form-switch)>input[type=checkbox][disabled]~label{color:GrayText}}.form-check.form-switch>input[type=checkbox]~label{color:var(--post-scheme-color-interactive-primary-enabled-fg1)}.form-check.form-switch>input[type=checkbox]:not([disabled])~label{cursor:pointer}.form-check.form-switch>input[type=checkbox]:not([disabled]):hover~label{color:var(--post-scheme-color-interactive-primary-enabled-fg1)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check.form-switch>input[type=checkbox]:not([disabled]):hover~label{color:Highlight}}.form-check.form-switch>input[type=checkbox][disabled]~label{color:var(--post-scheme-color-interactive-primary-disabled-fg1)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check.form-switch>input[type=checkbox][disabled]~label{color:GrayText}}.form-check:has(input[type=radio]){padding-block:var(--post-device-spacing-padding-block-19)}fieldset>.form-check:has(input[type=radio]):not(:last-of-type){margin-bottom:var(--post-device-spacing-gap-4)}.form-check:has(input[type=radio])>input[type=radio]~label{padding-block:var(--post-device-spacing-padding-block-20);padding-inline-start:var(--post-device-spacing-gap-inline-12);color:var(--post-scheme-color-interactive-primary-enabled-fg1)}.form-check:has(input[type=radio])>input[type=radio]:not([disabled])~label{cursor:pointer}.form-check:has(input[type=radio])>input[type=radio]:not([disabled]):hover~label{color:var(--post-scheme-color-interactive-primary-hover-fg1)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:has(input[type=radio])>input[type=radio]:not([disabled]):hover~label{color:Highlight}}.form-check:has(input[type=radio])>input[type=radio][disabled]~label{color:var(--post-scheme-color-interactive-primary-disabled-fg4)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:has(input[type=radio])>input[type=radio][disabled]~label{color:GrayText}}.form-check>label{transition:color 250ms cubic-bezier(0.4, 0, 0.2, 1);flex:1}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check>label{transition:none}}:where(.form-check>input[type=checkbox]){outline-offset:var(--post-device-spacing-padding-2) !important;outline:var(--post-scheme-color-interactive-focus-stroke) none var(--post-device-border-width-focus) !important}:where(.form-check>input[type=checkbox]):is(:focus-visible,:has(:focus-visible),.pretend-focus){outline-style:var(--post-core-border-style-solid) !important}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:where(.form-check>input[type=checkbox]):is(:focus-visible,:has(:focus-visible),.pretend-focus){outline-color:Highlight !important}}@supports not selector(:has(:focus-visible)){:where(.form-check>input[type=checkbox]):is(:focus-visible,:focus-within,.pretend-focus){outline-style:var(--post-core-border-style-solid) !important}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:where(.form-check>input[type=checkbox]):is(:focus-visible,:focus-within,.pretend-focus){outline-color:Highlight !important}}}.form-check:not(.form-switch):has(input[type=checkbox])>input{appearance:none;flex:none;display:inline-flex;margin:var(--post-device-spacing-padding-1);margin-block:calc(var(--post-device-spacing-padding-1) + var(--post-device-spacing-padding-block-18));width:var(--post-device-sizing-interactive-icon-size);height:var(--post-device-sizing-interactive-icon-size);background-color:var(--post-scheme-color-interactive-primary-enabled-bg3);border:var(--post-device-border-width-default) var(--post-core-border-style-solid) var(--post-scheme-color-interactive-primary-enabled-stroke);border-radius:var(--post-core-dimension-2);color:var(--post-scheme-color-interactive-primary-enabled-fg1);vertical-align:top;transition:background-color 250ms cubic-bezier(0.4, 0, 0.2, 1),border-color 250ms cubic-bezier(0.4, 0, 0.2, 1),color 250ms cubic-bezier(0.4, 0, 0.2, 1),box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:not(.form-switch):has(input[type=checkbox])>input{background-color:Field;border-color:FieldText;color:FieldText}}.form-check:not(.form-switch):has(input[type=checkbox])>input:not([disabled]){cursor:pointer}.form-check:not(.form-switch):has(input[type=checkbox])>input::after{display:block;content:\"\";width:100%;height:100%;mask-size:var(--post-device-sizing-interactive-icon-size);mask-repeat:no-repeat;mask-position:center}.form-check:not(.form-switch):has(input[type=checkbox])>input:checked::after,.form-check:not(.form-switch):has(input[type=checkbox])>input:indeterminate::after{background-color:currentColor}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:not(.form-switch):has(input[type=checkbox])>input:checked::after,.form-check:not(.form-switch):has(input[type=checkbox])>input:indeterminate::after{background-color:FieldText}}.form-check:not(.form-switch):has(input[type=checkbox])>input:not([disabled]):hover{background-color:var(--post-scheme-color-interactive-primary-hover-bg3);border-color:var(--post-scheme-color-interactive-primary-hover-stroke);color:var(--post-scheme-color-interactive-primary-hover-fg1)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:not(.form-switch):has(input[type=checkbox])>input:not([disabled]):hover{background-color:Field;border-color:Highlight}.form-check:not(.form-switch):has(input[type=checkbox])>input:not([disabled]):hover:checked::after,.form-check:not(.form-switch):has(input[type=checkbox])>input:not([disabled]):hover:indeterminate::after{background-color:Highlight}}.form-check:not(.form-switch):has(input[type=checkbox])>input:checked::after{mask-image:url(\"data:image/svg+xml,<svg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'><path d='M7.51712 12.1332L4.30712 8.69325C4.02712 8.39325 4.03712 7.91325 4.34712 7.63325C4.64712 7.35325 5.12712 7.36325 5.40712 7.67325L7.31712 9.72325L10.7171 4.57325C10.9471 4.22325 11.4071 4.13325 11.7571 4.36325C12.1071 4.59325 12.1971 5.05325 11.9671 5.40325L7.51712 12.1332Z'/></svg>\")}.form-check:not(.form-switch):has(input[type=checkbox])>input:indeterminate::after{mask-image:url(\"data:image/svg+xml,<svg width='16' height='16' viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'><path d='M11.21 8.5H4.75C4.34 8.5 4 8.16 4 7.75C4 7.34 4.34 7 4.75 7H11.21C11.62 7 11.96 7.34 11.96 7.75C11.96 8.16 11.62 8.5 11.21 8.5Z'/></svg>\")}.form-check:not(.form-switch):has(input[type=checkbox])>input[disabled]{background-color:var(--post-scheme-color-interactive-primary-disabled-bg6);border:var(--post-device-border-width-default) var(--post-core-border-style-dash) var(--post-scheme-color-interactive-primary-disabled-stroke4);color:var(--post-scheme-color-interactive-primary-disabled-fg4)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check:not(.form-switch):has(input[type=checkbox])>input[disabled]{background-color:Field;border-color:GrayText}.form-check:not(.form-switch):has(input[type=checkbox])>input[disabled]:checked::after,.form-check:not(.form-switch):has(input[type=checkbox])>input[disabled]:indeterminate::after{background-color:GrayText}}:where(.form-check>input[type=radio]){outline-offset:var(--post-device-spacing-padding-2) !important;outline:var(--post-scheme-color-interactive-focus-stroke) none var(--post-device-border-width-focus) !important}:where(.form-check>input[type=radio]):is(:focus-visible,:has(:focus-visible),.pretend-focus){outline-style:var(--post-core-border-style-solid) !important}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:where(.form-check>input[type=radio]):is(:focus-visible,:has(:focus-visible),.pretend-focus){outline-color:Highlight !important}}@supports not selector(:has(:focus-visible)){:where(.form-check>input[type=radio]):is(:focus-visible,:focus-within,.pretend-focus){outline-style:var(--post-core-border-style-solid) !important}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:where(.form-check>input[type=radio]):is(:focus-visible,:focus-within,.pretend-focus){outline-color:Highlight !important}}}.form-check>input[type=radio]{appearance:none;flex:none;display:inline-flex;justify-content:center;align-items:center;margin-block:calc(var(--post-device-spacing-padding-1) + var(--post-device-spacing-padding-block-18));margin-inline:var(--post-device-spacing-padding-1);width:var(--post-device-sizing-interactive-icon-size);height:var(--post-device-sizing-interactive-icon-size);background-color:var(--post-scheme-color-interactive-primary-enabled-bg3);border:var(--post-device-border-width-default) var(--post-core-border-style-solid) var(--post-scheme-color-interactive-primary-enabled-stroke);border-radius:var(--post-device-border-radius-round);color:var(--post-scheme-color-interactive-primary-enabled-fg1);vertical-align:top;transition:background-color 250ms cubic-bezier(0.4, 0, 0.2, 1),border-color 250ms cubic-bezier(0.4, 0, 0.2, 1),color 250ms cubic-bezier(0.4, 0, 0.2, 1),box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check>input[type=radio]{background-color:Field;border-color:FieldText;color:FieldText;transition:none}}.form-check>input[type=radio]:not([disabled]){cursor:pointer}.form-check>input[type=radio]::after{display:block;content:\"\";width:var(--post-device-sizing-icon-3);height:var(--post-device-sizing-icon-3);border-radius:inherit}.form-check>input[type=radio]:checked::after{background-color:var(--post-scheme-color-interactive-primary-enabled-fg1)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check>input[type=radio]:checked::after{background-color:FieldText}}.form-check>input[type=radio]:not([disabled]):hover{background-color:var(--post-scheme-color-interactive-primary-hover-bg3);border-color:var(--post-scheme-color-interactive-primary-hover-stroke);color:var(--post-scheme-color-interactive-primary-hover-fg1)}.form-check>input[type=radio]:not([disabled]):hover:checked::after{background-color:var(--post-scheme-color-interactive-primary-hover-fg1)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check>input[type=radio]:not([disabled]):hover{background-color:Field;border-color:Highlight}.form-check>input[type=radio]:not([disabled]):hover:checked::after{background-color:Highlight}}.form-check>input[type=radio][disabled]{background-color:var(--post-scheme-color-interactive-primary-disabled-bg6);border:var(--post-device-border-width-default) var(--post-core-border-style-dash) var(--post-scheme-color-interactive-primary-disabled-stroke4);color:var(--post-scheme-color-interactive-primary-disabled-fg4)}.form-check>input[type=radio][disabled]:checked::after{background-color:var(--post-scheme-color-interactive-primary-disabled-fg4)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.form-check>input[type=radio][disabled]{background-color:Field;border-color:GrayText}.form-check>input[type=radio][disabled]:checked::after{background-color:GrayText}}:host{--post-card-control-bg-context:.bg-yellow, .bg-white, .bg-light, .bg-gray, .bg-warning, .bg-info, .bg-success-background, .bg-warning-background, .bg-error-background, .bg-dark, .bg-black, .bg-primary, .bg-secondary, .bg-success, .bg-error;display:flex;width:100%}:host-context(fieldset):host(:not(:last-child)) .card-control{margin-bottom:var(--post-core-dimension-16)}.card-control{--post-card-control-border-color:hsl(0, 0%, 40%);--post-card-control-bg:#fff;--post-card-control-color:hsl(0, 0%, 20%);--post-card-control-input-border-color:hsl(0, 0%, 20%);--post-card-control-input-bg:#fff;flex-basis:100%;display:grid;grid-template:\"input label icon\" \"input content content\"/min-content auto min-content;align-items:center;gap:0 var(--post-core-dimension-8);margin:0;padding:var(--post-core-dimension-12);background-color:var(--post-card-control-bg);border:var(--post-core-dimension-2) solid var(--post-card-control-border-color);border-radius:4px;color:var(--post-card-control-color) !important;cursor:pointer}.card-control .card-control--input{grid-area:input;margin:var(--post-core-dimension-4) 0;background-color:var(--post-card-control-input-bg) !important;border-color:var(--post-card-control-input-border-color) !important;color:var(--post-card-control-input-border-color) !important;cursor:inherit;transition:none;outline:none !important}.card-control .card-control--input:hover:not([disabled]),.card-control .card-control--input:hover:not([disabled])~label.form-check-label{color:var(--post-contrast-color);background-color:rgba(0,0,0,0)}.card-control .card-control--input:focus,.card-control .card-control--input:focus-visible{box-shadow:none}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.card-control .card-control--input::after{forced-color-adjust:none;border-color:rgba(0,0,0,0)}}.card-control .card-control--label{grid-area:label;margin:var(--post-core-dimension-4) 0;padding:0 !important;color:inherit !important;pointer-events:none;transition:none}.card-control .card-control--label:not(:has(+.card-control--icon)){grid-area:1/label/1/icon}.card-control .card-control--description{grid-area:label;font-size:.75rem}.card-control .card-control--content{grid-area:content}.card-control .card-control--icon{grid-area:icon;width:var(--post-core-dimension-32);height:var(--post-core-dimension-32);pointer-events:none}.card-control .card-control--icon>slot>*{width:100%;height:100%}.card-control:not(.is-disabled).is-checked{--post-card-control-border-color:#000;--post-card-control-bg:#fc0}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.card-control:not(.is-disabled).is-checked{--post-card-control-border-color:FieldText;--post-card-control-bg:SelectedItem;--post-card-control-color:SelectedItemText;--post-card-control-input-border-color:SelectedItemText;--post-card-control-input-bg:SelectedItem}.card-control:not(.is-disabled).is-checked .card-control--input::after{background-color:var(--post-card-control-color) !important}}.card-control:not(.is-disabled).is-invalid{--post-card-control-border-color:#a51728;--post-card-control-color:#a51728;--post-card-control-input-border-color:#a51728}.card-control:not(.is-disabled):hover{--post-card-control-border-color:hsl(0, 0%, 20%);--post-card-control-bg:hsl(0, 0%, 40%);--post-card-control-color:#fff;--post-card-control-input-border-color:#000}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.card-control:not(.is-disabled):hover{--post-card-control-border-color:Highlight;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:Highlight;--post-card-control-input-bg:Field}.card-control:not(.is-disabled):hover .card-control--input::after{color:FieldText}}.card-control.is-focused:where(:has(.card-control--input:focus-visible)){outline-offset:var(--post-core-dimension-2);outline:var(--post-core-dimension-2) solid #1976c8}.card-control.is-disabled{--post-card-control-border-color:hsl(0, 0%, 40%);--post-card-control-bg:transparent;--post-card-control-color:hsl(0, 0%, 40%);--post-card-control-input-border-color:hsl(0, 0%, 40%);--post-card-control-input-bg:transparent;border-style:dashed;cursor:default}.card-control.is-disabled .card-control--input{padding:2px;border-style:dashed}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.card-control{--post-card-control-border-color:FieldText;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:FieldText;--post-card-control-input-bg:Field;outline:var(--post-core-dimension-2) solid Field;outline-offset:calc(var(--post-core-dimension-2)*-2)}.card-control .card-control--input{outline:var(--post-core-dimension-2) solid Field}.card-control .card-control--input[type]{background-color:Field !important}.card-control .card-control--input::after{border-color:Field !important}.card-control .card-control--label,.card-control .card-control--content{background-color:var(--post-card-control-bg) !important}.card-control:not(.is-disabled).is-checked{--post-card-control-border-color:FieldText;--post-card-control-bg:SelectedItem;--post-card-control-color:SelectedItemText;--post-card-control-input-border-color:FieldText}.card-control:not(.is-disabled).is-checked .card-control--input::after{background-color:FieldText !important}.card-control:not(.is-disabled):hover{--post-card-control-border-color:Highlight;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:Highlight}.card-control.is-disabled{--post-card-control-border-color:GrayText;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:GrayText;--post-card-control-input-bg:Field}.card-control.is-disabled .card-control--input{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%' height='100%' fill='none' stroke='GrayText' stroke-width='4px ' stroke-dasharray='2 1.5 4 1.5 4 1.5 4 1.5 2 3.5 4 1.5 4 1.5 4 1.5 2 3.5 4 1.5 4 1.5 4 1.5 2 3.5 4 1.5 4 1.5 4' pathLength='88' /%3e%3c/svg%3e\")}.card-control.is-disabled .card-control--input[type=radio]{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%' height='100%' rx='100' ry='100' fill='none' stroke='GrayText' stroke-width='4px ' stroke-dasharray='4 2' /%3e%3c/svg%3e\")}.card-control.is-disabled.is-checked{--post-card-control-bg:SelectedItem;--post-card-control-color:SelectedItemText;position:relative;background-color:Field}.card-control.is-disabled.is-checked::before{display:block;content:\"\";position:absolute;inset:var(--post-core-dimension-2);background-color:SelectedItem;z-index:1}.card-control.is-disabled.is-checked>*{position:relative;z-index:2}.card-control.is-disabled.is-checked .card-control--input::after{background-color:FieldText !important}}@media (forced-colors: active)and (forced-colors: active),(forced-colors: active)and (-ms-high-contrast: active),(forced-colors: active)and (-ms-high-contrast: white-on-black),(-ms-high-contrast: active)and (forced-colors: active),(-ms-high-contrast: active)and (-ms-high-contrast: active),(-ms-high-contrast: active)and (-ms-high-contrast: white-on-black),(-ms-high-contrast: white-on-black)and (forced-colors: active),(-ms-high-contrast: white-on-black)and (-ms-high-contrast: active),(-ms-high-contrast: white-on-black)and (-ms-high-contrast: white-on-black){.card-control{--post-card-control-border-color:GrayText;--post-card-control-color:GrayText;--post-card-control-input-border-color:GrayText}.card-control.is-checked{--post-card-control-input-bg:field;position:relative}.card-control.is-checked::before{display:block;content:\"\";position:absolute;inset:var(--post-core-dimension-2);border-radius:calc(var(--post-core-dimension-2)*.5);background-color:SelectedItem}.card-control.is-checked>*{position:relative}.card-control.is-checked .card-control--input{outline:var(--post-core-dimension-2) solid Field}}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control{--post-card-control-border-color:#fff;--post-card-control-bg:transparent;--post-card-control-color:#fff;--post-card-control-input-border-color:#fff;--post-card-control-input-bg:transparent}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control:not(.is-disabled).is-checked{--post-card-control-border-color:#fc0;--post-card-control-bg:#fc0;--post-card-control-color:hsl(0, 0%, 20%);--post-card-control-input-border-color:hsl(0, 0%, 20%);--post-card-control-input-bg:#fff}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control:not(.is-disabled).is-invalid{--post-card-control-border-color:#a51728;--post-card-control-bg:#ffdade;--post-card-control-color:#a51728;--post-card-control-input-border-color:#a51728;--post-card-control-input-bg:#fff}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control:not(.is-disabled).is-invalid:where(.is-checked){--post-card-control-bg:#fc0}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control:not(.is-disabled):hover{--post-card-control-border-color:#000;--post-card-control-bg:hsl(0, 0%, 80%);--post-card-control-color:#000;--post-card-control-input-border-color:#000;--post-card-control-input-bg:#fff}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control:not(.is-disabled):hover{--post-card-control-border-color:Highlight;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:Highlight;--post-card-control-input-bg:Field}}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control.is-focused:where(:has(.card-control--input:focus-visible)){outline-color:#fff}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control.is-disabled{--post-card-control-border-color:post.$white-alpha-80;--post-card-control-bg:transparent;--post-card-control-color:post.$white-alpha-80;--post-card-control-input-border-color:post.$white-alpha-80;--post-card-control-input-bg:transparent}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control.is-disabled{--post-card-control-border-color:GrayText;--post-card-control-color:GrayText;--post-card-control-input-border-color:GrayText}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control.is-disabled.is-checked{--post-card-control-input-bg:Field}}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control{--post-card-control-border-color:FieldText;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:FieldText;--post-card-control-input-bg:Field}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control:not(.is-disabled).is-checked{--post-card-control-border-color:FieldText;--post-card-control-bg:SelectedItem;--post-card-control-color:SelectedItemText;--post-card-control-input-border-color:FieldText}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control:not(.is-disabled):hover{--post-card-control-border-color:Highlight;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:Highlight}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control.is-disabled{--post-card-control-border-color:GrayText;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:GrayText;--post-card-control-input-bg:Field}:host-context(:is(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error)) .card-control.is-disabled.is-checked{--post-card-control-bg:SelectedItem;--post-card-control-color:SelectedItemText}}:host(:not([data-context])){display:none}:host([data-context*=fieldset]:not(:last-child)) .card-control{margin-bottom:var(--post-core-dimension-16)}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control{--post-card-control-border-color:#fff;--post-card-control-bg:transparent;--post-card-control-color:#fff;--post-card-control-input-border-color:#fff;--post-card-control-input-bg:transparent}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control:not(.is-disabled).is-checked{--post-card-control-border-color:#fc0;--post-card-control-bg:#fc0;--post-card-control-color:hsl(0, 0%, 20%);--post-card-control-input-border-color:hsl(0, 0%, 20%);--post-card-control-input-bg:#fff}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control:not(.is-disabled).is-invalid{--post-card-control-border-color:#a51728;--post-card-control-bg:#ffdade;--post-card-control-color:#a51728;--post-card-control-input-border-color:#a51728;--post-card-control-input-bg:#fff}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control:not(.is-disabled).is-invalid:where(.is-checked){--post-card-control-bg:#fc0}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control:not(.is-disabled):hover{--post-card-control-border-color:#000;--post-card-control-bg:hsl(0, 0%, 80%);--post-card-control-color:#000;--post-card-control-input-border-color:#000;--post-card-control-input-bg:#fff}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control:not(.is-disabled):hover{--post-card-control-border-color:Highlight;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:Highlight;--post-card-control-input-bg:Field}}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control.is-focused:where(:has(.card-control--input:focus-visible)){outline-color:#fff}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control.is-disabled{--post-card-control-border-color:post.$white-alpha-80;--post-card-control-bg:transparent;--post-card-control-color:post.$white-alpha-80;--post-card-control-input-border-color:post.$white-alpha-80;--post-card-control-input-bg:transparent}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control.is-disabled{--post-card-control-border-color:GrayText;--post-card-control-color:GrayText;--post-card-control-input-border-color:GrayText}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control.is-disabled.is-checked{--post-card-control-input-bg:Field}}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control{--post-card-control-border-color:FieldText;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:FieldText;--post-card-control-input-bg:Field}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control:not(.is-disabled).is-checked{--post-card-control-border-color:FieldText;--post-card-control-bg:SelectedItem;--post-card-control-color:SelectedItemText;--post-card-control-input-border-color:FieldText}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control:not(.is-disabled):hover{--post-card-control-border-color:Highlight;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:Highlight}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control.is-disabled{--post-card-control-border-color:GrayText;--post-card-control-bg:Field;--post-card-control-color:FieldText;--post-card-control-input-border-color:GrayText;--post-card-control-input-bg:Field}:host(:is([data-context*=\".bg-dark\"],[data-context*=\".bg-black\"],[data-context*=\".bg-primary\"],[data-context*=\".bg-secondary\"],[data-context*=\".bg-success\"],[data-context*=\".bg-error\"])) .card-control.is-disabled.is-checked{--post-card-control-bg:SelectedItem;--post-card-control-color:SelectedItemText}}";
|
|
9
|
-
const PostCardControlStyle0 = postCardControlCss;
|
|
10
|
-
|
|
11
|
-
let cardControlIds = 0;
|
|
12
|
-
const PostCardControl = class {
|
|
13
|
-
/**
|
|
14
|
-
* A public method to reset the controls `checked` and `validity` state.
|
|
15
|
-
* The validity state is set to `null`, so it's neither valid nor invalid.
|
|
16
|
-
*/
|
|
17
|
-
async reset() {
|
|
18
|
-
this.validity = null;
|
|
19
|
-
this.controlSetChecked(this.initialChecked);
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* A hidden public method to reset the group controls `checked` state to `false`.
|
|
23
|
-
*/
|
|
24
|
-
async groupReset() {
|
|
25
|
-
if (this.disabled)
|
|
26
|
-
this.control.checked = this.checked = false;
|
|
27
|
-
this.controlSetChecked(false);
|
|
28
|
-
}
|
|
29
|
-
validateControlLabel(label = this.label) {
|
|
30
|
-
checkNonEmpty.checkNonEmpty(label, 'The "post-card-control" element requires its "label" property to be set.');
|
|
31
|
-
}
|
|
32
|
-
validateControlType(type = this.type) {
|
|
33
|
-
checkOneOf.checkOneOf(type, ['checkbox', 'radio'], 'The "post-card-control" element requires its "type" prop to be one of either "checkbox" or "radio".');
|
|
34
|
-
}
|
|
35
|
-
updateControlChecked(checked = this.checked) {
|
|
36
|
-
this.controlSetChecked(checked);
|
|
37
|
-
}
|
|
38
|
-
updateControlDisabled() {
|
|
39
|
-
this.controlSetChecked(this.checked);
|
|
40
|
-
}
|
|
41
|
-
constructor(hostRef) {
|
|
42
|
-
index.registerInstance(this, hostRef);
|
|
43
|
-
this.postInput = index.createEvent(this, "postInput", 7);
|
|
44
|
-
this.postChange = index.createEvent(this, "postChange", 7);
|
|
45
|
-
if (hostRef.$hostElement$["s-ei"]) {
|
|
46
|
-
this.internals = hostRef.$hostElement$["s-ei"];
|
|
47
|
-
}
|
|
48
|
-
else {
|
|
49
|
-
this.internals = hostRef.$hostElement$.attachInternals();
|
|
50
|
-
hostRef.$hostElement$["s-ei"] = this.internals;
|
|
51
|
-
}
|
|
52
|
-
this.EVENT_MAP = {
|
|
53
|
-
input: 'postInput',
|
|
54
|
-
change: 'postChange',
|
|
55
|
-
};
|
|
56
|
-
this.KEYCODES = {
|
|
57
|
-
SPACE: 'Space',
|
|
58
|
-
LEFT: 'ArrowLeft',
|
|
59
|
-
UP: 'ArrowUp',
|
|
60
|
-
RIGHT: 'ArrowRight',
|
|
61
|
-
DOWN: 'ArrowDown',
|
|
62
|
-
};
|
|
63
|
-
this.group = {
|
|
64
|
-
hosts: [],
|
|
65
|
-
members: [],
|
|
66
|
-
first: null,
|
|
67
|
-
last: null,
|
|
68
|
-
checked: null,
|
|
69
|
-
focused: null,
|
|
70
|
-
};
|
|
71
|
-
this.controlId = `PostCardControl_${cardControlIds++}`;
|
|
72
|
-
this.focused = false;
|
|
73
|
-
this.label = undefined;
|
|
74
|
-
this.description = null;
|
|
75
|
-
this.type = undefined;
|
|
76
|
-
this.name = null;
|
|
77
|
-
this.value = null;
|
|
78
|
-
this.checked = false;
|
|
79
|
-
this.disabled = false;
|
|
80
|
-
this.validity = null;
|
|
81
|
-
this.icon = null;
|
|
82
|
-
this.cardClickHandler = this.cardClickHandler.bind(this);
|
|
83
|
-
this.controlClickHandler = this.controlClickHandler.bind(this);
|
|
84
|
-
this.controlChangeHandler = this.controlChangeHandler.bind(this);
|
|
85
|
-
this.controlFocusHandler = this.controlFocusHandler.bind(this);
|
|
86
|
-
this.controlKeyDownHandler = this.controlKeyDownHandler.bind(this);
|
|
87
|
-
}
|
|
88
|
-
cardClickHandler(e) {
|
|
89
|
-
e.stopPropagation();
|
|
90
|
-
// if this was not the clicked element anyway, trigger click on control to change it
|
|
91
|
-
if (e.target !== this.control)
|
|
92
|
-
this.control.click();
|
|
93
|
-
}
|
|
94
|
-
controlClickHandler(e) {
|
|
95
|
-
e.stopPropagation();
|
|
96
|
-
// if control is disabled do nothing
|
|
97
|
-
// else control value will fire a change event, which is handled in the controlChangeHandler method
|
|
98
|
-
if (this.disabled)
|
|
99
|
-
e.preventDefault();
|
|
100
|
-
}
|
|
101
|
-
controlChangeHandler(e) {
|
|
102
|
-
e.stopPropagation();
|
|
103
|
-
this.groupCollectMembers();
|
|
104
|
-
this.controlSetChecked(this.control.checked, e);
|
|
105
|
-
this.groupSetChecked(this.control, e);
|
|
106
|
-
}
|
|
107
|
-
controlFocusHandler() {
|
|
108
|
-
this.focused = this.host === document.activeElement;
|
|
109
|
-
}
|
|
110
|
-
// https://googlechromelabs.github.io/howto-components/howto-radio-group/
|
|
111
|
-
controlKeyDownHandler(e) {
|
|
112
|
-
if (this.type === 'radio') {
|
|
113
|
-
e.stopPropagation();
|
|
114
|
-
if (Object.values(this.KEYCODES).includes(e.code))
|
|
115
|
-
e.preventDefault();
|
|
116
|
-
this.groupCollectMembers();
|
|
117
|
-
switch (e.code) {
|
|
118
|
-
case this.KEYCODES.UP:
|
|
119
|
-
case this.KEYCODES.LEFT:
|
|
120
|
-
this.groupSetChecked(this.groupGetPrev(), e);
|
|
121
|
-
break;
|
|
122
|
-
case this.KEYCODES.DOWN:
|
|
123
|
-
case this.KEYCODES.RIGHT:
|
|
124
|
-
this.groupSetChecked(this.groupGetNext(), e);
|
|
125
|
-
break;
|
|
126
|
-
case this.KEYCODES.SPACE:
|
|
127
|
-
this.groupSetChecked(this.control, e);
|
|
128
|
-
break;
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
controlSetChecked(checked, e) {
|
|
133
|
-
if (!this.control)
|
|
134
|
-
return;
|
|
135
|
-
if (this.disabled) {
|
|
136
|
-
this.internals.setFormValue(null);
|
|
137
|
-
}
|
|
138
|
-
else {
|
|
139
|
-
this.control.checked = this.checked = checked;
|
|
140
|
-
this.internals.setFormValue(this.checked ? this.control.value : null);
|
|
141
|
-
if (e) {
|
|
142
|
-
const isCheckbox = this.type === 'checkbox';
|
|
143
|
-
const isRadioAndChecked = this.type === 'radio' && this.checked;
|
|
144
|
-
// https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox
|
|
145
|
-
// https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/radio
|
|
146
|
-
// if an event parameter is given and a native control would fire an event, emit the corresponding event to the light dom
|
|
147
|
-
if (isCheckbox || isRadioAndChecked)
|
|
148
|
-
this[this.EVENT_MAP[e.type]].emit({ state: this.checked, value: this.value });
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
groupCollectMembers() {
|
|
153
|
-
var _a, _b;
|
|
154
|
-
if (this.type === 'radio' && this.name) {
|
|
155
|
-
this.group.hosts = Array.from(document.querySelectorAll(`post-card-control[type="radio"][name="${this.name}"]`));
|
|
156
|
-
this.group.members = this.group.hosts
|
|
157
|
-
.map(m => m.shadowRoot.querySelector('input[type="radio"]'))
|
|
158
|
-
.filter(m => m !== null);
|
|
159
|
-
if (this.group.members.length > 1) {
|
|
160
|
-
this.group.first = this.group.members[0];
|
|
161
|
-
this.group.last = this.group.members[this.group.members.length - 1];
|
|
162
|
-
this.group.checked = (_a = this.group.members.find(m => m.checked)) !== null && _a !== void 0 ? _a : null;
|
|
163
|
-
this.group.focused =
|
|
164
|
-
(_b = this.group.members.find(m => m.getRootNode().host === document.activeElement)) !== null && _b !== void 0 ? _b : this.group.first;
|
|
165
|
-
const focusableMember = this.group.checked || this.group.focused || this.group.first;
|
|
166
|
-
this.group.members.forEach(m => {
|
|
167
|
-
m.tabIndex = m === focusableMember ? 0 : -1;
|
|
168
|
-
});
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
groupGetPrev() {
|
|
173
|
-
var _a;
|
|
174
|
-
const focusedIndex = this.group.members.findIndex(m => m.id === this.group.focused.id);
|
|
175
|
-
return (_a = this.group.members.find((_m, i) => i === focusedIndex - 1)) !== null && _a !== void 0 ? _a : this.group.last;
|
|
176
|
-
}
|
|
177
|
-
groupGetNext() {
|
|
178
|
-
var _a;
|
|
179
|
-
const focusedIndex = this.group.members.findIndex(m => m.id === this.group.focused.id);
|
|
180
|
-
return (_a = this.group.members.find((_m, i) => i === focusedIndex + 1)) !== null && _a !== void 0 ? _a : this.group.first;
|
|
181
|
-
}
|
|
182
|
-
groupSetChecked(newChecked, e) {
|
|
183
|
-
if (this.group.members.length > 1) {
|
|
184
|
-
const isKeyboardEvent = e.type === 'keydown';
|
|
185
|
-
const newIsAriaDisabled = newChecked.hasAttribute('aria-disabled');
|
|
186
|
-
const newIndex = this.group.members.findIndex(m => m === newChecked);
|
|
187
|
-
if (isKeyboardEvent)
|
|
188
|
-
newChecked.focus();
|
|
189
|
-
// if new is disabled, do not reset/set anything
|
|
190
|
-
if (!newIsAriaDisabled) {
|
|
191
|
-
// reset all group members but the newChecked
|
|
192
|
-
this.group.hosts
|
|
193
|
-
.filter((_h, i) => i !== newIndex)
|
|
194
|
-
.forEach(h => {
|
|
195
|
-
h.groupReset();
|
|
196
|
-
});
|
|
197
|
-
// if method was called by keyboard event, select newChecked
|
|
198
|
-
// else this has already been done by clicking on the newChecked element already
|
|
199
|
-
if (isKeyboardEvent)
|
|
200
|
-
newChecked.click();
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
// remove as soon as all browser support :host-context()
|
|
205
|
-
// https://caniuse.com/?search=%3Ahost-context()
|
|
206
|
-
setHostContext() {
|
|
207
|
-
let bgContext;
|
|
208
|
-
const possibleBgContexts = window
|
|
209
|
-
.getComputedStyle(this.host)
|
|
210
|
-
.getPropertyValue('--post-card-control-bg-context')
|
|
211
|
-
.split(', ');
|
|
212
|
-
let formContext;
|
|
213
|
-
const possibleFromContexts = ['fieldset'];
|
|
214
|
-
let element = this.host;
|
|
215
|
-
while (element && (!bgContext || !formContext)) {
|
|
216
|
-
bgContext = bgContext !== null && bgContext !== void 0 ? bgContext : possibleBgContexts.find(selector => element.matches(selector));
|
|
217
|
-
formContext = formContext !== null && formContext !== void 0 ? formContext : possibleFromContexts.find(selector => element.matches(selector));
|
|
218
|
-
element = element.parentElement;
|
|
219
|
-
}
|
|
220
|
-
const hostContext = [bgContext, formContext].filter(context => !!context).join(' ');
|
|
221
|
-
this.host.setAttribute('data-context', hostContext);
|
|
222
|
-
}
|
|
223
|
-
connectedCallback() {
|
|
224
|
-
this.initialChecked = this.checked;
|
|
225
|
-
}
|
|
226
|
-
componentWillRender() {
|
|
227
|
-
this.hasIcon = Boolean(this.host.querySelector('[slot="icon"]') || this.icon);
|
|
228
|
-
}
|
|
229
|
-
render() {
|
|
230
|
-
return (index.h(index.Host, { key: 'd5a554358103f47b5294dc5f6e21e41a78ec383f', "data-version": _package.version, onClick: this.cardClickHandler }, index.h("div", { key: 'd9bd511744e04792f456ab2e22c0f48ea8f3234b', class: {
|
|
231
|
-
'card-control': true,
|
|
232
|
-
'is-checked': this.checked,
|
|
233
|
-
'is-disabled': this.disabled,
|
|
234
|
-
'is-focused': this.focused,
|
|
235
|
-
'is-valid': this.validity !== null && this.validity !== 'false',
|
|
236
|
-
'is-invalid': this.validity === 'false',
|
|
237
|
-
} }, index.h("input", { key: '37a7bc7d656aa5527037303daacdb8b8ee26b973', ref: el => (this.control = el), id: this.controlId, class: "card-control--input", type: this.type, name: this.name, value: this.value, checked: this.checked, "aria-describedby": `${this.controlId}_content`, "aria-disabled": this.disabled, "aria-invalid": this.validity === 'false', onClick: this.controlClickHandler, onInput: this.controlChangeHandler, onChange: this.controlChangeHandler, onFocus: this.controlFocusHandler, onBlur: this.controlFocusHandler, onKeyDown: this.controlKeyDownHandler }), index.h("label", { key: '9482a54b665dc2f2fe254f2656af9cb57cb0fb4b', id: `${this.controlId}_label`, htmlFor: this.controlId, class: "card-control--label" }, this.label, this.description ? (index.h("div", { class: "card-control--description" }, this.description)) : null), this.hasIcon ? (index.h("div", { class: "card-control--icon" }, index.h("slot", { name: "icon" }, this.icon ? index.h("post-icon", { name: this.icon }) : null))) : null, index.h("div", { key: '1b2a1fdb408ea8dcb4649fd76ae848685474f7b5', id: `${this.controlId}_content`, class: "card-control--content" }, index.h("slot", { key: '5b9f15b75920c0956730686b52959a9b21a64857' })))));
|
|
238
|
-
}
|
|
239
|
-
componentDidRender() {
|
|
240
|
-
this.setHostContext();
|
|
241
|
-
this.groupCollectMembers();
|
|
242
|
-
}
|
|
243
|
-
componentDidLoad() {
|
|
244
|
-
this.validateControlLabel();
|
|
245
|
-
this.validateControlType();
|
|
246
|
-
}
|
|
247
|
-
// https://stenciljs.com/docs/form-associated
|
|
248
|
-
/* eslint-disable @stencil-community/own-methods-must-be-private */
|
|
249
|
-
formAssociatedCallback() {
|
|
250
|
-
this.controlSetChecked(this.checked);
|
|
251
|
-
}
|
|
252
|
-
formDisabledCallback(disabled) {
|
|
253
|
-
this.disabled = disabled;
|
|
254
|
-
}
|
|
255
|
-
formStateRestoreCallback(checked) {
|
|
256
|
-
this.controlSetChecked(checked);
|
|
257
|
-
}
|
|
258
|
-
formResetCallback() {
|
|
259
|
-
this.reset();
|
|
260
|
-
}
|
|
261
|
-
static get formAssociated() { return true; }
|
|
262
|
-
get host() { return index.getElement(this); }
|
|
263
|
-
static get watchers() { return {
|
|
264
|
-
"label": ["validateControlLabel"],
|
|
265
|
-
"type": ["validateControlType"],
|
|
266
|
-
"checked": ["updateControlChecked"],
|
|
267
|
-
"disabled": ["updateControlDisabled"]
|
|
268
|
-
}; }
|
|
269
|
-
};
|
|
270
|
-
PostCardControl.style = PostCardControlStyle0;
|
|
271
|
-
|
|
272
|
-
exports.PostCardControl = PostCardControl;
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const index = require('./index-f1b08cdb.js');
|
|
4
|
-
const _package = require('./package-5fdfea90.js');
|
|
5
|
-
const checkNonEmpty = require('./check-non-empty-eeaa8f77.js');
|
|
6
|
-
const index_browser = require('./index.browser-2f65f583.js');
|
|
7
|
-
|
|
8
|
-
const postTabHeaderCss = ".tab-title[role=tab]{display:inline-block;cursor:pointer;position:relative;box-sizing:border-box;padding:1rem;transition:background-color 100ms;border-right:1px solid rgba(0,0,0,0);border-left:1px solid rgba(0,0,0,0);outline-color:currentColor;opacity:.7;color:var(--post-contrast-color);text-decoration:none;background-color:rgba(0,0,0,0)}.tab-title[role=tab]:focus{background-color:unset;color:var(--post-contrast-color)}.tab-title[role=tab]:hover{opacity:1;background-color:rgba(var(--post-contrast-color-rgb), 0.6);color:var(--post-contrast-color-inverted)}.tab-title[role=tab]:focus-visible{outline:rgba(0,0,0,0);opacity:1;background-color:rgba(var(--post-contrast-color-rgb), 0.6);color:var(--post-contrast-color-inverted);box-shadow:none}.tab-title[role=tab]:focus-visible::after{content:\"\";display:block;position:absolute;top:2px;right:1px;bottom:0;left:1px;box-shadow:0 0 0 1px #fff,0 0 0 2px #333}.tab-title[role=tab].active{z-index:1;border-right-color:#ccc;border-left-color:#ccc;opacity:1;background-color:var(--post-contrast-color-inverted);color:var(--post-contrast-color);font-weight:700}.tab-title[role=tab].active::before{content:\"\";display:block;position:absolute;top:0;right:-1px;left:-1px;height:var(--post-core-dimension-4);background-color:#fc0}:where(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error) .tab-title[role=tab]:hover{background-color:rgba(255,255,255,.2)}:where(.bg-dark,.bg-black,.bg-primary,.bg-secondary,.bg-success,.bg-error) .tab-title[role=tab]:focus-visible{background-color:rgba(255,255,255,.2)}@media (forced-colors: active),(-ms-high-contrast: active),(-ms-high-contrast: white-on-black){.tab-title[role=tab]{opacity:1;border-left-color:Canvas;border-right-color:Canvas;color:LinkText}.tab-title[role=tab]:hover,.tab-title[role=tab]:focus,.tab-title[role=tab]:focus-within,.tab-title[role=tab]:focus-visible{outline:var(--post-core-dimension-2) solid Highlight;outline-offset:calc(var(--post-core-dimension-4)*-1)}.tab-title[role=tab].active{border-left-color:ButtonText;border-right-color:ButtonText;color:Highlight}.tab-title[role=tab].active::before{background-color:Highlight}}/*!\n * Copyright 2021 by Swiss Post, Information Technology\n */:host{display:block}.tab-title{padding:0;overflow:visible;border:0;background:none;color:inherit;font:inherit;-webkit-user-select:none;user-select:none;appearance:button}";
|
|
9
|
-
const PostTabHeaderStyle0 = postTabHeaderCss;
|
|
10
|
-
|
|
11
|
-
const PostTabHeader = class {
|
|
12
|
-
constructor(hostRef) {
|
|
13
|
-
index.registerInstance(this, hostRef);
|
|
14
|
-
this.tabId = undefined;
|
|
15
|
-
this.panel = undefined;
|
|
16
|
-
}
|
|
17
|
-
validateFor(newValue) {
|
|
18
|
-
checkNonEmpty.checkNonEmpty(newValue, 'The "panel" prop is required for the post-tab-header.');
|
|
19
|
-
}
|
|
20
|
-
componentWillLoad() {
|
|
21
|
-
this.tabId = `tab-${this.host.id || index_browser.nanoid(6)}`;
|
|
22
|
-
}
|
|
23
|
-
render() {
|
|
24
|
-
return (index.h(index.Host, { key: '9b12878498f63da83113c081f81a749b4ee47ef4', id: this.tabId, role: "tab", "data-version": _package.version, "aria-selected": "false", tabindex: "-1", class: "tab-title", slot: "tabs" }, index.h("slot", { key: '3a2e7f3657110d707b49af911e9dd3a4ef323e36' })));
|
|
25
|
-
}
|
|
26
|
-
get host() { return index.getElement(this); }
|
|
27
|
-
static get watchers() { return {
|
|
28
|
-
"panel": ["validateFor"]
|
|
29
|
-
}; }
|
|
30
|
-
};
|
|
31
|
-
PostTabHeader.style = PostTabHeaderStyle0;
|
|
32
|
-
|
|
33
|
-
exports.PostTabHeader = PostTabHeader;
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
const fadeDuration = 200;
|
|
2
|
-
const fadedOutKeyframe = { opacity: '0' };
|
|
3
|
-
const fadedInKeyframe = { opacity: '1' };
|
|
4
|
-
const fadeIn = (el) => el.animate([fadedOutKeyframe, fadedInKeyframe], { duration: fadeDuration });
|
|
5
|
-
const fadeOut = (el) => el.animate([fadedInKeyframe, fadedOutKeyframe], { duration: fadeDuration });
|
|
6
|
-
|
|
7
|
-
export { fadeIn as a, fadeOut as f };
|