@siemens/ix 4.4.0 → 5.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/READMEOSS.html +24 -10
- package/components/index.js +1 -1
- package/components/ix-action-card.js +1 -1
- package/components/ix-application-header.js +1 -1
- package/components/ix-application-switch-modal.js +1 -1
- package/components/ix-application.js +1 -1
- package/components/ix-avatar.js +1 -1
- package/components/ix-blind.js +1 -1
- package/components/ix-breadcrumb-item.js +1 -1
- package/components/ix-breadcrumb.js +1 -1
- package/components/ix-button.js +1 -1
- package/components/ix-card-accordion.js +1 -1
- package/components/ix-card-content.js +1 -1
- package/components/ix-card-list.js +1 -1
- package/components/ix-card-title.js +1 -1
- package/components/ix-card.js +1 -1
- package/components/ix-category-filter.js +1 -1
- package/components/ix-checkbox-group.js +1 -1
- package/components/ix-checkbox.js +1 -1
- package/components/ix-chip.js +1 -1
- package/components/ix-col.js +1 -1
- package/components/ix-content-header.js +1 -1
- package/components/ix-content.js +1 -1
- package/components/ix-css-grid-item.js +1 -1
- package/components/ix-css-grid.js +1 -1
- package/components/ix-custom-field.js +1 -1
- package/components/ix-date-dropdown.js +1 -1
- package/components/ix-date-input.js +1 -1
- package/components/ix-date-picker.js +1 -1
- package/components/ix-date-time-card.js +1 -1
- package/components/{ix-validation-tooltip.d.ts → ix-datetime-input.d.ts} +4 -4
- package/components/ix-datetime-input.js +1 -0
- package/components/ix-datetime-picker.js +1 -1
- package/components/ix-divider.js +1 -1
- package/components/ix-dropdown-button.js +1 -1
- package/components/ix-dropdown-header.js +1 -1
- package/components/ix-dropdown-item.js +1 -1
- package/components/ix-dropdown-quick-actions.js +1 -1
- package/components/ix-dropdown.js +1 -1
- package/components/ix-empty-state.js +1 -1
- package/components/ix-event-list-item.js +1 -1
- package/components/ix-event-list.js +1 -1
- package/components/ix-expanding-search.js +1 -1
- package/components/ix-field-label.js +1 -1
- package/components/ix-field-wrapper.js +1 -1
- package/components/ix-filter-chip.js +1 -1
- package/components/ix-flip-tile-content.js +1 -1
- package/components/ix-flip-tile.js +1 -1
- package/components/ix-group-context-menu.js +1 -1
- package/components/ix-group-item.js +1 -1
- package/components/ix-group.js +1 -1
- package/components/ix-helper-text.js +1 -1
- package/components/ix-icon-button.js +1 -1
- package/components/ix-icon-toggle-button.js +1 -1
- package/components/ix-input.js +1 -1
- package/components/ix-key-value-list.js +1 -1
- package/components/ix-key-value.js +1 -1
- package/components/ix-kpi.js +1 -1
- package/components/ix-layout-auto.js +1 -1
- package/components/ix-layout-grid.js +1 -1
- package/components/ix-link-button.js +1 -1
- package/components/ix-menu-about-item.js +1 -1
- package/components/ix-menu-about-news.js +1 -1
- package/components/ix-menu-about.js +1 -1
- package/components/ix-menu-avatar-item.js +1 -1
- package/components/ix-menu-avatar.js +1 -1
- package/components/ix-menu-category.js +1 -1
- package/components/ix-menu-expand-icon.js +1 -1
- package/components/ix-menu-item.js +1 -1
- package/components/ix-menu-settings-item.js +1 -1
- package/components/ix-menu-settings.js +1 -1
- package/components/ix-menu.js +1 -1
- package/components/ix-message-bar.js +1 -1
- package/components/ix-modal-content.js +1 -1
- package/components/ix-modal-footer.js +1 -1
- package/components/ix-modal-header.js +1 -1
- package/components/ix-modal-loading.js +1 -1
- package/components/ix-modal.js +1 -1
- package/components/ix-number-input.js +1 -1
- package/components/ix-pagination.js +1 -1
- package/components/ix-pane-layout.js +1 -1
- package/components/ix-pane.js +1 -1
- package/components/ix-pill.js +1 -1
- package/components/ix-progress-indicator.js +1 -1
- package/components/ix-push-card.js +1 -1
- package/components/ix-radio-group.js +1 -1
- package/components/ix-radio.js +1 -1
- package/components/{ix-input-group.d.ts → ix-range-field.d.ts} +4 -4
- package/components/ix-range-field.js +1 -0
- package/components/ix-row.js +1 -1
- package/components/ix-select-item.js +1 -1
- package/components/ix-select.js +1 -1
- package/components/ix-slider.js +1 -1
- package/components/ix-spinner.js +1 -1
- package/components/ix-split-button.js +1 -1
- package/components/ix-tab-item.js +1 -1
- package/components/{ix-application-sidebar.d.ts → ix-tab-panel.d.ts} +4 -4
- package/components/ix-tab-panel.js +1 -0
- package/components/{ix-drawer.d.ts → ix-tab-set.d.ts} +4 -4
- package/components/ix-tab-set.js +1 -0
- package/components/ix-tabs.js +1 -1
- package/components/ix-textarea.js +1 -1
- package/components/ix-tile.js +1 -1
- package/components/ix-time-input.js +1 -1
- package/components/ix-time-picker.js +1 -1
- package/components/ix-toast-container.js +1 -1
- package/components/ix-toast.js +1 -1
- package/components/ix-toggle-button.js +1 -1
- package/components/ix-toggle.js +1 -1
- package/components/ix-tooltip.js +1 -1
- package/components/ix-tree-item.js +1 -1
- package/components/ix-tree.js +1 -1
- package/components/ix-typography.js +1 -1
- package/components/ix-upload.js +1 -1
- package/components/ix-workflow-step.js +1 -1
- package/components/ix-workflow-steps.js +1 -1
- package/components/p-4pTtJwcY.js +1 -0
- package/components/p-546lBshK.js +1 -0
- package/components/p-5jph302v.js +1 -0
- package/components/p-B1ZcjHve.js +1 -0
- package/components/{p-CRcg3Wl9.js → p-B1q6Xh9M.js} +1 -1
- package/components/p-B4Yxzuow.js +1 -0
- package/components/p-B5k8YVR0.js +1 -0
- package/components/p-B8RlWbEh.js +1 -0
- package/components/p-BE4QI9tD.js +1 -0
- package/components/p-BL9SR36X.js +1 -0
- package/components/p-BP8g-yqY.js +1 -0
- package/components/p-B_czElDE.js +1 -0
- package/components/p-BcxPyyrm.js +1 -0
- package/components/p-BooU9e46.js +1 -0
- package/components/p-Btv5ReUJ.js +1 -0
- package/components/p-BtvsjuLo.js +1 -0
- package/components/p-BwC_Hmai.js +1 -0
- package/components/p-Bxdy-8CE.js +1 -0
- package/components/p-Bxrgt3H_.js +1 -0
- package/components/p-By6x--zJ.js +1 -0
- package/components/p-Byed_Z2G.js +1 -0
- package/components/p-C-wf4kbs.js +1 -0
- package/components/p-C95SE6lT.js +1 -0
- package/components/p-C9HBQRMb.js +1 -0
- package/components/p-CDKHgTB8.js +1 -0
- package/components/p-CJ3dR7zd.js +1 -0
- package/components/p-CKYjdhXo.js +1 -0
- package/components/p-CQj_gEvY.js +1 -0
- package/components/p-CVmLf9WY.js +1 -0
- package/components/p-CWlPNXA-.js +1 -0
- package/components/p-CWshStHZ.js +1 -0
- package/components/p-CYgb41KQ.js +1 -0
- package/components/p-C_95k0nq.js +1 -0
- package/components/p-CcllZcv2.js +1 -0
- package/components/p-Cf71L4Ol.js +1 -0
- package/components/p-CgOv_MV_.js +1 -0
- package/components/p-CsP_r-y6.js +1 -0
- package/components/p-CuswfnZ5.js +1 -0
- package/components/p-D4RWuUBi.js +1 -0
- package/components/p-D4T7_gkf.js +1 -0
- package/components/p-D5gbubPJ.js +1 -0
- package/components/{p-DSTYytot.js → p-D5rshXh5.js} +1 -1
- package/components/p-D6Wm2E-0.js +1 -0
- package/components/p-D8Wb4thH.js +1 -0
- package/components/p-DN2Mr91y.js +1 -0
- package/components/p-DNIQ2C1K.js +1 -0
- package/components/p-DOCAISxs.js +1 -0
- package/components/p-DQql_9wo.js +1 -0
- package/components/p-DRw2l8Az.js +1 -0
- package/components/p-DSpVcflZ.js +1 -0
- package/components/p-DTcUamMt.js +1 -0
- package/components/p-DUkuP1OH.js +1 -0
- package/components/p-DdMuwGlF.js +1 -0
- package/components/p-DfnCSsMy.js +1 -0
- package/components/p-Djkc69iv.js +1 -0
- package/components/p-Dpk_WgCl.js +1 -0
- package/components/p-DuTDx0c-.js +1 -0
- package/components/p-Dx6rQdpk.js +1 -0
- package/components/p-Dx8kFukG.js +1 -0
- package/components/p-JXbYOM9q.js +1 -0
- package/components/p-JevOq-9X.js +1 -0
- package/components/p-MZOpritx.js +1 -0
- package/components/p-NLlCSNeG.js +1 -0
- package/components/p-VEcjhpT4.js +1 -0
- package/components/p-W0q0WVKl.js +1 -0
- package/components/p-XBJqkmoc.js +1 -0
- package/components/p-XBTykBKS.js +1 -0
- package/components/{p-BJxTLVYT.js → p-_Uc7YwjU.js} +1 -1
- package/components/p-qsIASuyM.js +1 -0
- package/components/p-uIG84RqI.js +1 -0
- package/components/p-wEbi9beJ.js +1 -0
- package/components/p-zs7a2E3b.js +1 -0
- package/components/package.json +1 -1
- package/dist/cjs/{a11y-DldCLr8D.js → a11y-C_6YiIMa.js} +1 -2
- package/dist/cjs/animation-hxDbANsw.js +81 -0
- package/dist/cjs/app-globals-V2Kpy_OQ.js +5 -0
- package/dist/cjs/aria-activedescendant.mixin-_lb0Xz2S.js +85 -0
- package/dist/cjs/{base-button-BvWcXXIH.js → base-button-C-1izOSS.js} +14 -10
- package/dist/cjs/{base-icon-button-DgnV_-qM.js → base-icon-button-BeXf6v9s.js} +3 -3
- package/dist/cjs/component-CYtonfpw.js +143 -0
- package/dist/cjs/{context-CmNuiaNz.js → context-DqdXbKw_.js} +5 -2
- package/dist/cjs/{dropdown-controller-BLOjtc6w.js → dropdown-controller-DeBeUVhj.js} +12 -9
- package/dist/cjs/{floating-ui.dom-CMzYsRR7.js → find-element-DPxOAdgO.js} +101 -0
- package/dist/cjs/focus-proxy-BCuVbpDb.js +48 -0
- package/dist/cjs/focus-trap-_cyPFvFq.js +106 -0
- package/dist/cjs/focus-utilities-yx7wWjEO.js +119 -0
- package/dist/cjs/focus-visible.mixin-BU5Ql7d1.js +42 -0
- package/dist/cjs/{helper-text-util-CX9jWl8m.js → helper-text-util-CvfY1JxE.js} +26 -8
- package/dist/cjs/id.mixin-DINDQztK.js +21 -0
- package/dist/cjs/index-B4J4JK0P.js +17 -0
- package/dist/cjs/{index-Dxeom0qd.js → index-BKQkUbyE.js} +529 -126
- package/dist/cjs/{index-DIYO-Liy.js → index-Dw-NwUuT.js} +2 -4
- package/dist/cjs/{index-BxmN3RtX.js → index-SVeYVn-h.js} +1 -2
- package/dist/cjs/index.cjs.js +266 -47
- package/dist/cjs/inherit-aria-attributes.mixin-Sl7J-OlO.js +36 -0
- package/dist/cjs/{picker-input.util-DJNAVluZ.js → input-picker.mixin-EoIayQV9.js} +25 -1
- package/dist/cjs/{input.fc-BIQRswZt.js → input.fc-CsACCdp7.js} +15 -17
- package/dist/cjs/ix-action-card.cjs.entry.js +39 -19
- package/dist/cjs/ix-application-header.cjs.entry.js +126 -69
- package/dist/cjs/ix-application-switch-modal.cjs.entry.js +9 -13
- package/dist/cjs/ix-application.cjs.entry.js +46 -34
- package/dist/cjs/ix-avatar_2.cjs.entry.js +126 -22
- package/dist/cjs/ix-blind.cjs.entry.js +37 -23
- package/dist/cjs/ix-breadcrumb-item.cjs.entry.js +234 -43
- package/dist/cjs/ix-breadcrumb.cjs.entry.js +85 -68
- package/dist/cjs/ix-button.cjs.entry.js +227 -40
- package/dist/cjs/ix-card-accordion_2.cjs.entry.js +30 -19
- package/dist/cjs/ix-card-list.cjs.entry.js +104 -54
- package/dist/cjs/ix-card_2.cjs.entry.js +17 -17
- package/dist/cjs/ix-category-filter.cjs.entry.js +180 -111
- package/dist/cjs/ix-checkbox-group.cjs.entry.js +52 -27
- package/dist/cjs/ix-checkbox.cjs.entry.js +58 -37
- package/dist/cjs/ix-chip.cjs.entry.js +317 -81
- package/dist/cjs/ix-col_4.cjs.entry.js +1109 -495
- package/dist/cjs/ix-content-header.cjs.entry.js +25 -17
- package/dist/cjs/ix-content.cjs.entry.js +7 -7
- package/dist/cjs/ix-css-grid-item.cjs.entry.js +6 -2
- package/dist/cjs/ix-css-grid.cjs.entry.js +13 -5
- package/dist/cjs/ix-custom-field.cjs.entry.js +41 -12
- package/dist/cjs/ix-date-dropdown.cjs.entry.js +170 -145
- package/dist/cjs/ix-date-input.cjs.entry.js +212 -125
- package/dist/cjs/ix-date-picker.cjs.entry.js +752 -0
- package/dist/cjs/ix-date-time-card.cjs.entry.js +25 -18
- package/dist/cjs/ix-datetime-input.cjs.entry.js +548 -0
- package/dist/cjs/ix-datetime-picker.cjs.entry.js +242 -58
- package/dist/cjs/ix-divider.cjs.entry.js +2 -2
- package/dist/cjs/ix-dropdown-button.cjs.entry.js +155 -38
- package/dist/cjs/ix-dropdown-header.cjs.entry.js +6 -2
- package/dist/cjs/ix-dropdown-quick-actions.cjs.entry.js +2 -2
- package/dist/cjs/ix-dropdown_2.cjs.entry.js +992 -0
- package/dist/cjs/ix-empty-state.cjs.entry.js +32 -6
- package/dist/cjs/ix-event-list-item.cjs.entry.js +38 -27
- package/dist/cjs/ix-event-list.cjs.entry.js +26 -26
- package/dist/cjs/ix-expanding-search.cjs.entry.js +58 -44
- package/dist/cjs/ix-field-label_2.cjs.entry.js +178 -56
- package/dist/cjs/ix-filter-chip_2.cjs.entry.js +85 -37
- package/dist/cjs/ix-flip-tile-content.cjs.entry.js +8 -8
- package/dist/cjs/ix-flip-tile.cjs.entry.js +43 -30
- package/dist/cjs/ix-group-context-menu_2.cjs.entry.js +51 -27
- package/dist/cjs/ix-group.cjs.entry.js +63 -40
- package/dist/cjs/ix-helper-text.cjs.entry.js +43 -16
- package/dist/cjs/ix-icon-button_2.cjs.entry.js +232 -52
- package/dist/cjs/ix-icon-toggle-button.cjs.entry.js +221 -45
- package/dist/cjs/ix-input.cjs.entry.js +128 -56
- package/dist/cjs/ix-key-value-list.cjs.entry.js +6 -6
- package/dist/cjs/ix-key-value.cjs.entry.js +24 -6
- package/dist/cjs/ix-kpi.cjs.entry.js +37 -13
- package/dist/cjs/ix-layout-auto.cjs.entry.js +15 -15
- package/dist/cjs/ix-link-button.cjs.entry.js +19 -15
- package/dist/cjs/ix-menu-about-item.cjs.entry.js +13 -6
- package/dist/cjs/ix-menu-about-news.cjs.entry.js +45 -18
- package/dist/cjs/ix-menu-about.cjs.entry.js +72 -28
- package/dist/cjs/ix-menu-avatar.cjs.entry.js +62 -31
- package/dist/cjs/ix-menu-category.cjs.entry.js +157 -74
- package/dist/cjs/ix-menu-expand-icon.cjs.entry.js +24 -24
- package/dist/cjs/ix-menu-item.cjs.entry.js +100 -51
- package/dist/cjs/ix-menu-settings-item.cjs.entry.js +13 -6
- package/dist/cjs/ix-menu-settings.cjs.entry.js +87 -4
- package/dist/cjs/ix-menu.cjs.entry.js +123 -136
- package/dist/cjs/ix-message-bar.cjs.entry.js +33 -22
- package/dist/cjs/ix-modal-content_2.cjs.entry.js +36 -17
- package/dist/cjs/ix-modal-footer.cjs.entry.js +2 -2
- package/dist/cjs/ix-modal-loading.cjs.entry.js +2 -2
- package/dist/cjs/ix-modal.cjs.entry.js +98 -61
- package/dist/cjs/ix-number-input.cjs.entry.js +211 -131
- package/dist/cjs/ix-pagination.cjs.entry.js +108 -89
- package/dist/cjs/ix-pane-layout.cjs.entry.js +26 -27
- package/dist/cjs/ix-pane.cjs.entry.js +114 -82
- package/dist/cjs/ix-pill_4.cjs.entry.js +746 -0
- package/dist/cjs/ix-progress-indicator.cjs.entry.js +48 -40
- package/dist/cjs/ix-push-card.cjs.entry.js +36 -15
- package/dist/cjs/ix-radio-group.cjs.entry.js +63 -26
- package/dist/cjs/ix-radio.cjs.entry.js +51 -25
- package/dist/cjs/ix-range-field.cjs.entry.js +122 -0
- package/dist/cjs/ix-select.cjs.entry.js +398 -373
- package/dist/cjs/ix-slider.cjs.entry.js +108 -68
- package/dist/cjs/ix-split-button.cjs.entry.js +118 -48
- package/dist/cjs/ix-tab-panel.cjs.entry.js +30 -0
- package/dist/cjs/ix-textarea.cjs.entry.js +135 -48
- package/dist/cjs/ix-tile.cjs.entry.js +12 -12
- package/dist/cjs/ix-time-input.cjs.entry.js +298 -152
- package/dist/cjs/ix-toast-container.cjs.entry.js +14 -54
- package/dist/cjs/ix-toast.cjs.entry.js +47 -31
- package/dist/cjs/ix-toggle-button.cjs.entry.js +200 -27
- package/dist/cjs/ix-toggle.cjs.entry.js +244 -48
- package/dist/cjs/ix-tooltip.cjs.entry.js +76 -52
- package/dist/cjs/ix-tree-item.cjs.entry.js +50 -16
- package/dist/cjs/ix-tree.cjs.entry.js +101 -45
- package/dist/cjs/ix-typography.cjs.entry.js +19 -12
- package/dist/cjs/ix-upload.cjs.entry.js +80 -76
- package/dist/cjs/ix-workflow-step.cjs.entry.js +39 -34
- package/dist/cjs/ix-workflow-steps.cjs.entry.js +20 -15
- package/dist/cjs/{listener-BShKJBRB.js → listener-BafrcTaM.js} +7 -6
- package/dist/cjs/loader.cjs.js +3 -4
- package/dist/cjs/{logical-filter-operator-q-2KOPJs.js → logical-filter-operator-Dv9-d8FB.js} +2 -0
- package/dist/cjs/luxon-datetime-format-masks-DQVILoY7.js +43 -0
- package/dist/cjs/{make-ref-BaH6_YJk.js → make-ref-CHsa3FY7.js} +6 -2
- package/dist/cjs/menu-service-D_QsHUgR.js +63 -0
- package/dist/cjs/modal-_AhJoT78.js +190 -0
- package/dist/cjs/service-CRjXhKel.js +94 -0
- package/dist/cjs/shadow-dom-BG8VqeIu.js +91 -0
- package/dist/cjs/siemens-ix.cjs.js +4 -5
- package/dist/cjs/tab.mixin-DObUK6A4.js +21 -0
- package/dist/cjs/theme-switcher-sbkXOvhB.js +127 -0
- package/dist/cjs/time-picker-constraints-CxGhm1qV.js +79 -0
- package/dist/cjs/{tree.types-BygtRFW3.js → tree.types-Cs9O1Wtf.js} +2 -0
- package/dist/cjs/typed-event-Bw4IfJC0.js +44 -0
- package/dist/cjs/{validation-DF9UXqHB.js → validation-Dier-uPA.js} +32 -9
- package/dist/collection/collection-manifest.json +16 -9
- package/dist/collection/components/action-card/action-card.js +37 -19
- package/dist/collection/components/application/application.js +62 -48
- package/dist/collection/components/application-header/application-header.js +116 -84
- package/dist/collection/components/application-header/application-switch-modal/application-switch-modal.js +5 -7
- package/dist/collection/components/avatar/avatar.css +30 -5
- package/dist/collection/components/avatar/avatar.js +108 -35
- package/dist/collection/components/blind/blind.js +33 -16
- package/dist/collection/components/breadcrumb/breadcrumb.css +7 -2
- package/dist/collection/components/breadcrumb/breadcrumb.js +125 -79
- package/dist/collection/components/breadcrumb/breadcrumb.types.js +1 -0
- package/dist/collection/components/breadcrumb-item/breadcrumb-item.css +66 -90
- package/dist/collection/components/breadcrumb-item/breadcrumb-item.js +131 -69
- package/dist/collection/components/button/base-button.js +13 -9
- package/dist/collection/components/button/button.css +38 -45
- package/dist/collection/components/button/button.js +69 -59
- package/dist/collection/components/card/card.js +15 -16
- package/dist/collection/components/card-accordion/card-accordion.js +27 -17
- package/dist/collection/components/card-content/card-content.js +1 -1
- package/dist/collection/components/card-list/card-list.js +127 -54
- package/dist/collection/components/card-title/card-title.js +1 -1
- package/dist/collection/components/category-filter/category-filter.css +38 -45
- package/dist/collection/components/category-filter/category-filter.js +173 -105
- package/dist/collection/components/category-filter/filter-state.js +2 -4
- package/dist/collection/components/category-filter/input-state.js +2 -0
- package/dist/collection/components/checkbox/checkbox.css +1 -0
- package/dist/collection/components/checkbox/checkbox.js +52 -33
- package/dist/collection/components/checkbox-group/checkbox-group.js +48 -25
- package/dist/collection/components/chip/chip.css +369 -346
- package/dist/collection/components/chip/chip.js +171 -80
- package/dist/collection/components/chip/chip.types.js +18 -0
- package/dist/collection/components/col/col.js +20 -2
- package/dist/collection/components/content/content.js +5 -6
- package/dist/collection/components/content-header/content-header.js +23 -17
- package/dist/collection/components/css-grid/css-grid-item.js +5 -1
- package/dist/collection/components/css-grid/css-grid.js +12 -6
- package/dist/collection/components/custom-field/custom-field.js +38 -11
- package/dist/collection/components/date-dropdown/date-dropdown.css +202 -18
- package/dist/collection/components/date-dropdown/date-dropdown.js +168 -201
- package/dist/collection/components/date-input/date-input.css +4 -4
- package/dist/collection/components/date-input/date-input.js +199 -112
- package/dist/collection/components/date-picker/date-picker.css +66 -25
- package/dist/collection/components/date-picker/date-picker.js +582 -193
- package/dist/collection/components/date-time-card/date-time-card.css +3 -0
- package/dist/collection/components/date-time-card/date-time-card.js +43 -18
- package/dist/collection/components/datetime-input/datetime-input.css +621 -0
- package/dist/collection/components/datetime-input/datetime-input.js +1372 -0
- package/dist/collection/components/datetime-input/datetime-input.types.js +1 -0
- package/dist/collection/components/datetime-picker/datetime-picker.css +2 -10
- package/dist/collection/components/datetime-picker/datetime-picker.js +364 -58
- package/dist/collection/components/divider/divider.js +1 -1
- package/dist/collection/components/dropdown/dropdown-controller.js +12 -9
- package/dist/collection/components/dropdown/dropdown-focus.js +178 -0
- package/dist/collection/components/dropdown/dropdown.css +1 -1
- package/dist/collection/components/dropdown/dropdown.js +809 -201
- package/dist/collection/components/dropdown-button/dropdown-button.css +38 -0
- package/dist/collection/components/dropdown-button/dropdown-button.js +258 -36
- package/dist/collection/components/dropdown-header/dropdown-header.js +5 -1
- package/dist/collection/components/dropdown-item/dropdown-item.css +23 -3
- package/dist/collection/components/dropdown-item/dropdown-item.js +129 -26
- package/dist/collection/components/dropdown-item/dropdown-item.types.js +1 -0
- package/dist/collection/components/dropdown-quick-actions/dropdown-quick-actions.js +1 -1
- package/dist/collection/components/empty-state/empty-state.js +31 -7
- package/dist/collection/components/event-list/event-list.js +25 -26
- package/dist/collection/components/event-list-item/event-list-item.js +35 -26
- package/dist/collection/components/expanding-search/expanding-search.js +56 -42
- package/dist/collection/components/field-label/field-label.css +10 -0
- package/dist/collection/components/field-label/field-label.js +34 -11
- package/dist/collection/components/field-wrapper/field-wrapper.css +1 -2
- package/dist/collection/components/field-wrapper/field-wrapper.js +193 -49
- package/dist/collection/components/field-wrapper/helper-text-util.js +22 -5
- package/dist/collection/components/filter-chip/filter-chip.css +0 -5
- package/dist/collection/components/filter-chip/filter-chip.js +33 -11
- package/dist/collection/components/flip-tile/flip-tile.js +39 -27
- package/dist/collection/components/flip-tile-content/flip-tile-content.js +7 -9
- package/dist/collection/components/group/group-context-menu.js +3 -4
- package/dist/collection/components/group/group.js +60 -38
- package/dist/collection/components/group-item/group-item.js +45 -22
- package/dist/collection/components/helper-text/helper-text.js +37 -12
- package/dist/collection/components/icon-button/base-icon-button.js +1 -1
- package/dist/collection/components/icon-button/icon-button.css +38 -45
- package/dist/collection/components/icon-button/icon-button.js +58 -56
- package/dist/collection/components/icon-toggle-button/icon-toggle-button.css +38 -45
- package/dist/collection/components/icon-toggle-button/icon-toggle-button.js +61 -63
- package/dist/collection/components/input/input.css +4 -8
- package/dist/collection/components/input/input.fc.js +10 -11
- package/dist/collection/components/input/input.js +119 -49
- package/dist/collection/components/input/input.util.js +1 -2
- package/dist/collection/components/input/number-input.css +4 -4
- package/dist/collection/components/input/number-input.js +202 -124
- package/dist/collection/components/input/textarea.css +4 -4
- package/dist/collection/components/input/textarea.js +127 -42
- package/dist/collection/components/ix-playground/ix-playground.js +25 -0
- package/dist/collection/components/key-value/key-value.js +23 -7
- package/dist/collection/components/key-value-list/key-value-list.js +5 -7
- package/dist/collection/components/kpi/kpi.js +35 -13
- package/dist/collection/components/layout-auto/layout-auto.js +14 -15
- package/dist/collection/components/layout-grid/layout-grid.js +14 -16
- package/dist/collection/components/link-button/link-button.js +17 -15
- package/dist/collection/components/menu/menu-expand-icon.css +12 -5
- package/dist/collection/components/menu/menu-expand-icon.js +60 -45
- package/dist/collection/components/menu/menu.js +114 -160
- package/dist/collection/components/menu-about/menu-about.css +63 -3
- package/dist/collection/components/menu-about/menu-about.js +111 -36
- package/dist/collection/components/menu-about-item/menu-about-item.js +18 -14
- package/dist/collection/components/menu-about-news/menu-about-news.js +65 -17
- package/dist/collection/components/menu-avatar/menu-avatar.js +57 -27
- package/dist/collection/components/menu-avatar-item/menu-avatar-item.js +15 -4
- package/dist/collection/components/menu-category/menu-category.js +156 -42
- package/dist/collection/components/menu-item/menu-item.js +94 -46
- package/dist/collection/components/menu-settings/menu-settings.css +0 -3
- package/dist/collection/components/menu-settings/menu-settings.js +111 -36
- package/dist/collection/components/menu-settings-item/menu-settings-item.js +23 -16
- package/dist/collection/components/message-bar/message-bar.js +31 -22
- package/dist/collection/components/modal/modal.css +2 -1
- package/dist/collection/components/modal/modal.js +98 -63
- package/dist/collection/components/modal-content/modal-content.js +1 -1
- package/dist/collection/components/modal-footer/modal-footer.js +1 -1
- package/dist/collection/components/modal-header/modal-header.js +34 -16
- package/dist/collection/components/modal-loading/modal-loading.js +1 -1
- package/dist/collection/components/pagination/pagination.css +38 -45
- package/dist/collection/components/pagination/pagination.js +103 -85
- package/dist/collection/components/pane/pane.js +108 -77
- package/dist/collection/components/pane-layout/pane-layout.js +23 -25
- package/dist/collection/components/pill/pill.css +8 -24
- package/dist/collection/components/pill/pill.js +60 -29
- package/dist/collection/components/progress-indicator/progress-indicator.js +46 -39
- package/dist/collection/components/push-card/push-card.js +35 -16
- package/dist/collection/components/radio/radio.js +47 -23
- package/dist/collection/components/radio-group/radio-group.js +59 -24
- package/dist/collection/components/{input-group/input-group.css → range-field/range-field.css} +26 -39
- package/dist/collection/components/range-field/range-field.js +193 -0
- package/dist/collection/components/row/row.js +1 -1
- package/dist/collection/components/select/select.css +36 -13
- package/dist/collection/components/select/select.js +427 -383
- package/dist/collection/components/select/test/select-controller.js +89 -0
- package/dist/collection/components/select-item/select-item.js +46 -59
- package/dist/collection/components/slider/slider.css +0 -7
- package/dist/collection/components/slider/slider.js +101 -85
- package/dist/collection/components/spinner/spinner.js +14 -15
- package/dist/collection/components/split-button/split-button.css +36 -19
- package/dist/collection/components/split-button/split-button.js +116 -77
- package/dist/collection/components/tab-item/tab-item.css +73 -81
- package/dist/collection/components/tab-item/tab-item.js +279 -93
- package/dist/collection/components/tab-item/tab.mixin.js +40 -0
- package/dist/collection/components/{application-sidebar/application-sidebar.css → tab-panel/tab-panel.css} +3 -11
- package/dist/collection/components/tab-panel/tab-panel.js +67 -0
- package/dist/collection/components/{drawer/drawer.css → tab-set/tab-set.css} +1 -62
- package/dist/collection/components/tab-set/tab-set.js +92 -0
- package/dist/collection/components/tabs/tabs.css +71 -39
- package/dist/collection/components/tabs/tabs.js +261 -416
- package/dist/collection/components/tile/tile.js +11 -12
- package/dist/collection/components/time-input/time-input.css +4 -4
- package/dist/collection/components/time-input/time-input.js +349 -138
- package/dist/collection/components/time-picker/time-picker-column-values.js +25 -0
- package/dist/collection/components/time-picker/time-picker-compute-time.js +64 -0
- package/dist/collection/components/time-picker/time-picker-constraints.js +71 -0
- package/dist/collection/components/time-picker/time-picker-display.js +21 -0
- package/dist/collection/components/time-picker/time-picker-format.js +40 -0
- package/dist/collection/components/time-picker/time-picker-range.js +50 -0
- package/dist/collection/components/time-picker/time-picker-step-focus.js +32 -0
- package/dist/collection/components/time-picker/time-picker.css +17 -4
- package/dist/collection/components/time-picker/time-picker.js +544 -264
- package/dist/collection/components/toast/{styles/toast-container.css → toast-container.css} +6 -8
- package/dist/collection/components/toast/toast-container.js +15 -97
- package/dist/collection/components/toast/toast-utils.js +16 -4
- package/dist/collection/components/toast/toast.js +45 -30
- package/dist/collection/components/toggle/toggle.css +7 -4
- package/dist/collection/components/toggle/toggle.js +85 -44
- package/dist/collection/components/toggle-button/toggle-button.css +38 -45
- package/dist/collection/components/toggle-button/toggle-button.js +41 -46
- package/dist/collection/components/tooltip/tooltip.js +68 -44
- package/dist/collection/components/tree/tree.js +74 -34
- package/dist/collection/components/tree-item/default-tree-item.js +2 -0
- package/dist/collection/components/tree-item/tree-item.css +9 -4
- package/dist/collection/components/tree-item/tree-item.js +70 -15
- package/dist/collection/components/typography/typography.js +18 -13
- package/dist/collection/components/upload/upload.js +110 -75
- package/dist/collection/components/utils/a11y.js +1 -2
- package/dist/collection/components/utils/animation.js +24 -44
- package/dist/collection/components/utils/application-layout/service.js +22 -40
- package/dist/collection/components/utils/context.js +4 -1
- package/dist/collection/components/utils/delegate.js +1 -2
- package/dist/collection/components/utils/dependency-function.js +55 -0
- package/dist/collection/components/utils/event.js +16 -0
- package/dist/collection/components/utils/find-element.js +1 -1
- package/dist/collection/components/utils/focus/detect-keyboard-mode.js +28 -0
- package/dist/collection/components/utils/focus/focus-proxy.js +40 -0
- package/dist/collection/components/utils/focus/focus-trap.js +99 -0
- package/dist/collection/components/utils/focus/focus-utilities.js +117 -0
- package/dist/collection/components/utils/focus.js +9 -6
- package/dist/collection/components/utils/input/index.js +5 -0
- package/dist/collection/components/utils/input/validation.js +31 -8
- package/dist/collection/components/utils/internal/component.js +2 -1
- package/dist/collection/components/utils/internal/index.js +1 -1
- package/dist/collection/components/utils/internal/mixins/accessibility/aria-activedescendant.mixin.js +84 -0
- package/dist/collection/components/utils/internal/mixins/accessibility/inherit-aria-attributes.mixin.js +190 -0
- package/dist/collection/components/utils/internal/mixins/focus-visible.mixin.js +91 -0
- package/dist/collection/components/utils/internal/mixins/id.mixin.js +17 -0
- package/dist/collection/components/utils/internal/mixins/input/input-picker.mixin.js +45 -0
- package/dist/collection/components/utils/internal/mixins/setup.mixin.js +118 -0
- package/dist/collection/components/utils/lazy-list/lazy.js +24 -9
- package/dist/collection/components/utils/listener.js +6 -5
- package/dist/collection/components/utils/luxon-datetime-format-masks.js +38 -0
- package/dist/collection/components/utils/make-ref.js +5 -2
- package/dist/collection/components/utils/menu-service/menu-service.js +17 -37
- package/dist/collection/components/utils/menu-tabs/menu-tabs-utils.js +1 -49
- package/dist/collection/components/utils/modal/index.js +2 -2
- package/dist/collection/components/utils/modal/loading.js +34 -29
- package/dist/collection/components/utils/modal/message.js +133 -106
- package/dist/collection/components/utils/modal/modal.js +11 -8
- package/dist/collection/components/utils/overlay.js +1 -3
- package/dist/collection/components/utils/shadow-dom.js +42 -0
- package/dist/collection/components/{drawer → utils}/test/animejs.mock.js +8 -8
- package/dist/collection/components/utils/theme-switcher.js +85 -133
- package/dist/collection/components/utils/typed-event.js +29 -31
- package/dist/collection/components/workflow-step/workflow-step.js +37 -33
- package/dist/collection/components/workflow-steps/workflow-steps.js +19 -15
- package/dist/collection/public-api.js +4 -0
- package/dist/collection/tests/utils/test/page.js +34 -9
- package/dist/esm/{a11y-DAzBNVe7.js → a11y-B5k8YVR0.js} +1 -2
- package/dist/esm/animation-DNIQ2C1K.js +79 -0
- package/dist/esm/app-globals-DQuL1Twl.js +3 -0
- package/dist/esm/aria-activedescendant.mixin-CM-NUHTW.js +83 -0
- package/dist/esm/{base-button-CV0w47z9.js → base-button-hppF0uUM.js} +14 -10
- package/dist/esm/{base-icon-button-BuHd34qo.js → base-icon-button-_xVULsPr.js} +3 -3
- package/dist/esm/component-Chfbghog.js +139 -0
- package/dist/esm/{context-BniHpAE1.js → context-zqk3Dkv-.js} +5 -2
- package/dist/esm/{dropdown-controller-D3K9vmFp.js → dropdown-controller-D6Wm2E-0.js} +12 -9
- package/dist/esm/{floating-ui.dom-CAqtPJ4-.js → find-element-Bxrgt3H_.js} +100 -1
- package/dist/esm/focus-proxy-BgLEsVE2.js +43 -0
- package/dist/esm/focus-trap-DDLHqzV2.js +102 -0
- package/dist/esm/focus-utilities-DnaItyVQ.js +108 -0
- package/dist/esm/focus-visible.mixin-CoMZ6z5Z.js +40 -0
- package/dist/esm/{helper-text-util-C9sLzo0k.js → helper-text-util-AEl-1QU6.js} +26 -9
- package/dist/esm/id.mixin-CUbYLenp.js +19 -0
- package/dist/esm/{index-BEPo7U1W.js → index-Ca5WUunf.js} +529 -127
- package/dist/esm/{index-BBzEV-f4.js → index-Cl7fhG1I.js} +2 -3
- package/dist/esm/index-XBTykBKS.js +14 -0
- package/dist/esm/{index-BG5XMoOy.js → index-nCVTBc9Y.js} +1 -2
- package/dist/esm/index.js +262 -45
- package/dist/esm/inherit-aria-attributes.mixin-CBuZQFB-.js +34 -0
- package/dist/esm/{picker-input.util-D1uMJUKN.js → input-picker.mixin-Bo_sZpC4.js} +25 -2
- package/dist/esm/{input.fc-C1ytwpkt.js → input.fc-DjE-oOZc.js} +17 -19
- package/dist/esm/ix-action-card.entry.js +39 -19
- package/dist/esm/ix-application-header.entry.js +126 -69
- package/dist/esm/ix-application-switch-modal.entry.js +9 -13
- package/dist/esm/ix-application.entry.js +46 -34
- package/dist/esm/ix-avatar_2.entry.js +126 -22
- package/dist/esm/ix-blind.entry.js +37 -23
- package/dist/esm/ix-breadcrumb-item.entry.js +234 -43
- package/dist/esm/ix-breadcrumb.entry.js +85 -68
- package/dist/esm/ix-button.entry.js +227 -40
- package/dist/esm/ix-card-accordion_2.entry.js +30 -19
- package/dist/esm/ix-card-list.entry.js +104 -54
- package/dist/esm/ix-card_2.entry.js +17 -17
- package/dist/esm/ix-category-filter.entry.js +180 -111
- package/dist/esm/ix-checkbox-group.entry.js +52 -27
- package/dist/esm/ix-checkbox.entry.js +58 -37
- package/dist/esm/ix-chip.entry.js +317 -81
- package/dist/esm/ix-col_4.entry.js +1110 -496
- package/dist/esm/ix-content-header.entry.js +25 -17
- package/dist/esm/ix-content.entry.js +7 -7
- package/dist/esm/ix-css-grid-item.entry.js +6 -2
- package/dist/esm/ix-css-grid.entry.js +13 -5
- package/dist/esm/ix-custom-field.entry.js +41 -12
- package/dist/esm/ix-date-dropdown.entry.js +170 -145
- package/dist/esm/ix-date-input.entry.js +209 -122
- package/dist/esm/ix-date-picker.entry.js +750 -0
- package/dist/esm/ix-date-time-card.entry.js +25 -18
- package/dist/esm/ix-datetime-input.entry.js +546 -0
- package/dist/esm/ix-datetime-picker.entry.js +242 -58
- package/dist/esm/ix-divider.entry.js +2 -2
- package/dist/esm/ix-dropdown-button.entry.js +155 -38
- package/dist/esm/ix-dropdown-header.entry.js +6 -2
- package/dist/esm/ix-dropdown-quick-actions.entry.js +2 -2
- package/dist/esm/ix-dropdown_2.entry.js +989 -0
- package/dist/esm/ix-empty-state.entry.js +32 -6
- package/dist/esm/ix-event-list-item.entry.js +38 -27
- package/dist/esm/ix-event-list.entry.js +27 -27
- package/dist/esm/ix-expanding-search.entry.js +58 -44
- package/dist/esm/ix-field-label_2.entry.js +177 -55
- package/dist/esm/ix-filter-chip_2.entry.js +85 -37
- package/dist/esm/ix-flip-tile-content.entry.js +8 -8
- package/dist/esm/ix-flip-tile.entry.js +43 -30
- package/dist/esm/ix-group-context-menu_2.entry.js +51 -27
- package/dist/esm/ix-group.entry.js +63 -40
- package/dist/esm/ix-helper-text.entry.js +43 -16
- package/dist/esm/ix-icon-button_2.entry.js +232 -52
- package/dist/esm/ix-icon-toggle-button.entry.js +221 -45
- package/dist/esm/ix-input.entry.js +129 -57
- package/dist/esm/ix-key-value-list.entry.js +6 -6
- package/dist/esm/ix-key-value.entry.js +24 -6
- package/dist/esm/ix-kpi.entry.js +37 -13
- package/dist/esm/ix-layout-auto.entry.js +15 -15
- package/dist/esm/ix-link-button.entry.js +19 -15
- package/dist/esm/ix-menu-about-item.entry.js +13 -6
- package/dist/esm/ix-menu-about-news.entry.js +45 -18
- package/dist/esm/ix-menu-about.entry.js +72 -28
- package/dist/esm/ix-menu-avatar.entry.js +62 -31
- package/dist/esm/ix-menu-category.entry.js +157 -74
- package/dist/esm/ix-menu-expand-icon.entry.js +24 -24
- package/dist/esm/ix-menu-item.entry.js +100 -51
- package/dist/esm/ix-menu-settings-item.entry.js +13 -6
- package/dist/esm/ix-menu-settings.entry.js +90 -3
- package/dist/esm/ix-menu.entry.js +123 -136
- package/dist/esm/ix-message-bar.entry.js +33 -22
- package/dist/esm/ix-modal-content_2.entry.js +36 -17
- package/dist/esm/ix-modal-footer.entry.js +2 -2
- package/dist/esm/ix-modal-loading.entry.js +2 -2
- package/dist/esm/ix-modal.entry.js +98 -61
- package/dist/esm/ix-number-input.entry.js +212 -132
- package/dist/esm/ix-pagination.entry.js +108 -89
- package/dist/esm/ix-pane-layout.entry.js +26 -27
- package/dist/esm/ix-pane.entry.js +114 -82
- package/dist/esm/ix-pill_4.entry.js +741 -0
- package/dist/esm/ix-progress-indicator.entry.js +48 -40
- package/dist/esm/ix-push-card.entry.js +36 -15
- package/dist/esm/ix-radio-group.entry.js +63 -26
- package/dist/esm/ix-radio.entry.js +51 -25
- package/dist/esm/ix-range-field.entry.js +120 -0
- package/dist/esm/ix-select.entry.js +398 -373
- package/dist/esm/ix-slider.entry.js +108 -68
- package/dist/esm/ix-split-button.entry.js +118 -48
- package/dist/esm/ix-tab-panel.entry.js +28 -0
- package/dist/esm/ix-textarea.entry.js +136 -49
- package/dist/esm/ix-tile.entry.js +12 -12
- package/dist/esm/ix-time-input.entry.js +295 -149
- package/dist/esm/ix-toast-container.entry.js +14 -54
- package/dist/esm/ix-toast.entry.js +47 -31
- package/dist/esm/ix-toggle-button.entry.js +200 -27
- package/dist/esm/ix-toggle.entry.js +244 -48
- package/dist/esm/ix-tooltip.entry.js +69 -45
- package/dist/esm/ix-tree-item.entry.js +50 -16
- package/dist/esm/ix-tree.entry.js +101 -45
- package/dist/esm/ix-typography.entry.js +19 -12
- package/dist/esm/ix-upload.entry.js +80 -76
- package/dist/esm/ix-workflow-step.entry.js +39 -34
- package/dist/esm/ix-workflow-steps.entry.js +20 -15
- package/dist/esm/{listener-DcAn-vyA.js → listener-Dk6XGheN.js} +7 -6
- package/dist/esm/loader.js +4 -5
- package/dist/esm/{logical-filter-operator-BH3f5fa3.js → logical-filter-operator-C9HBQRMb.js} +2 -0
- package/dist/esm/luxon-datetime-format-masks-CoQiziG8.js +40 -0
- package/dist/esm/{make-ref-bcj7UEIC.js → make-ref-Djkc69iv.js} +6 -3
- package/dist/esm/menu-service-DTIYRV47.js +61 -0
- package/dist/esm/modal-DaGSr1j4.js +181 -0
- package/dist/esm/{rwd.util-pXYAoEyc.js → rwd.util-JJddxCCh.js} +1 -1
- package/dist/esm/service-CEglFEKY.js +92 -0
- package/dist/esm/shadow-dom-BIe8Nw9M.js +85 -0
- package/dist/esm/siemens-ix.js +5 -6
- package/dist/esm/tab.mixin-2hU1i4Yk.js +19 -0
- package/dist/esm/theme-switcher-CRVG13AN.js +124 -0
- package/dist/esm/time-picker-constraints-Bsg2RskF.js +74 -0
- package/dist/esm/{tree.types-DSTYytot.js → tree.types-D5rshXh5.js} +2 -0
- package/dist/esm/typed-event-CWshStHZ.js +42 -0
- package/dist/esm/{validation-CTBekLDe.js → validation-BT5aAuSO.js} +32 -9
- package/dist/siemens-ix/index.esm.js +1 -1
- package/dist/siemens-ix/p-04bbcd53.entry.js +1 -0
- package/dist/siemens-ix/p-077cb0a7.entry.js +1 -0
- package/dist/siemens-ix/p-0de68f63.entry.js +1 -0
- package/dist/siemens-ix/p-12647d5d.entry.js +1 -0
- package/dist/siemens-ix/p-12750b7b.entry.js +1 -0
- package/dist/siemens-ix/p-15aefb52.entry.js +1 -0
- package/dist/siemens-ix/p-1629de03.entry.js +1 -0
- package/dist/siemens-ix/p-1ce32501.entry.js +1 -0
- package/dist/siemens-ix/p-1fa6a663.entry.js +1 -0
- package/dist/siemens-ix/p-2142fab0.entry.js +1 -0
- package/dist/siemens-ix/p-21c0d22c.entry.js +1 -0
- package/dist/siemens-ix/p-222881a1.entry.js +1 -0
- package/dist/siemens-ix/p-232da11d.entry.js +1 -0
- package/dist/siemens-ix/p-23aaf08e.entry.js +1 -0
- package/dist/siemens-ix/p-25c784e4.entry.js +1 -0
- package/dist/siemens-ix/p-280d8b68.entry.js +1 -0
- package/dist/siemens-ix/{p-6aadd69d.entry.js → p-2a735134.entry.js} +1 -1
- package/dist/siemens-ix/p-2afcdc78.entry.js +1 -0
- package/dist/siemens-ix/p-2bef3c58.entry.js +1 -0
- package/dist/siemens-ix/p-2d7e415f.entry.js +1 -0
- package/dist/siemens-ix/p-2d8f3ea3.entry.js +1 -0
- package/dist/siemens-ix/p-2e5e7ccf.entry.js +1 -0
- package/dist/siemens-ix/p-38cb18b4.entry.js +1 -0
- package/dist/siemens-ix/p-3f752a9c.entry.js +1 -0
- package/dist/siemens-ix/p-40a26154.entry.js +1 -0
- package/dist/siemens-ix/p-44a3f1f0.entry.js +1 -0
- package/dist/siemens-ix/p-45552c4c.entry.js +1 -0
- package/dist/siemens-ix/p-48386b43.entry.js +1 -0
- package/dist/siemens-ix/p-4pTtJwcY.js +1 -0
- package/dist/siemens-ix/p-5024bd91.entry.js +1 -0
- package/dist/siemens-ix/p-50b75fdf.entry.js +1 -0
- package/dist/siemens-ix/p-58d349a2.entry.js +1 -0
- package/dist/siemens-ix/p-5a44cb29.entry.js +1 -0
- package/dist/siemens-ix/p-5ae844d7.entry.js +1 -0
- package/dist/siemens-ix/p-5b3f7baa.entry.js +1 -0
- package/dist/siemens-ix/p-5c478e3e.entry.js +1 -0
- package/dist/siemens-ix/p-61a481f3.entry.js +1 -0
- package/dist/siemens-ix/p-65b8ad90.entry.js +1 -0
- package/dist/siemens-ix/p-65bc8a0d.entry.js +1 -0
- package/dist/siemens-ix/p-68eb9150.entry.js +1 -0
- package/dist/siemens-ix/p-69459b73.entry.js +1 -0
- package/dist/siemens-ix/p-6df3d9e4.entry.js +1 -0
- package/dist/siemens-ix/p-6e63af65.entry.js +1 -0
- package/dist/siemens-ix/p-6fb379fb.entry.js +1 -0
- package/dist/siemens-ix/p-756c8779.entry.js +1 -0
- package/dist/siemens-ix/p-782fb465.entry.js +1 -0
- package/dist/siemens-ix/p-7a83e693.entry.js +1 -0
- package/dist/siemens-ix/p-82f44b05.entry.js +1 -0
- package/dist/siemens-ix/p-834330b3.entry.js +1 -0
- package/dist/siemens-ix/p-8493e35e.entry.js +1 -0
- package/dist/siemens-ix/p-84fbdef9.entry.js +1 -0
- package/dist/siemens-ix/p-85ce0a9f.entry.js +1 -0
- package/dist/siemens-ix/p-8937e9b1.entry.js +1 -0
- package/dist/siemens-ix/p-8cfddec2.entry.js +1 -0
- package/dist/siemens-ix/p-8d76c0b0.entry.js +1 -0
- package/dist/siemens-ix/p-9015a4c5.entry.js +1 -0
- package/dist/siemens-ix/p-91b02cb7.entry.js +1 -0
- package/dist/siemens-ix/p-9362c304.entry.js +1 -0
- package/dist/siemens-ix/p-9586a886.entry.js +1 -0
- package/dist/siemens-ix/p-986142f0.entry.js +1 -0
- package/dist/siemens-ix/p-9907d408.entry.js +1 -0
- package/dist/siemens-ix/p-9b8f1bc7.entry.js +1 -0
- package/dist/siemens-ix/p-B5k8YVR0.js +1 -0
- package/dist/siemens-ix/p-BFUINhFM.js +1 -0
- package/dist/siemens-ix/p-BIe8Nw9M.js +1 -0
- package/dist/siemens-ix/p-BL9SR36X.js +1 -0
- package/dist/siemens-ix/p-BZApVtkF.js +1 -0
- package/dist/siemens-ix/p-BgL7Z4IG.js +1 -0
- package/dist/siemens-ix/p-Bxrgt3H_.js +1 -0
- package/dist/siemens-ix/p-C9HBQRMb.js +1 -0
- package/dist/siemens-ix/p-CM-NUHTW.js +1 -0
- package/dist/siemens-ix/p-CUbYLenp.js +1 -0
- package/dist/siemens-ix/p-CWlPNXA-.js +1 -0
- package/dist/siemens-ix/p-CWshStHZ.js +1 -0
- package/dist/siemens-ix/p-Ca5WUunf.js +2 -0
- package/dist/siemens-ix/p-CgOv_MV_.js +1 -0
- package/dist/siemens-ix/p-Cl7fhG1I.js +1 -0
- package/dist/siemens-ix/p-CoQiziG8.js +1 -0
- package/dist/siemens-ix/p-CxGywkh5.js +1 -0
- package/dist/siemens-ix/p-D148LCh1.js +1 -0
- package/dist/siemens-ix/{p-DSTYytot.js → p-D5rshXh5.js} +1 -1
- package/dist/siemens-ix/p-D6Wm2E-0.js +1 -0
- package/dist/siemens-ix/p-DIWED8Ls.js +1 -0
- package/dist/siemens-ix/p-DNIQ2C1K.js +1 -0
- package/dist/siemens-ix/p-DQuL1Twl.js +1 -0
- package/dist/siemens-ix/p-Djkc69iv.js +1 -0
- package/dist/siemens-ix/p-Dl_bUxb7.js +1 -0
- package/dist/siemens-ix/p-DnCbHs-d.js +1 -0
- package/dist/siemens-ix/p-DnaItyVQ.js +1 -0
- package/dist/siemens-ix/p-DuTDx0c-.js +1 -0
- package/dist/siemens-ix/p-Dx6rQdpk.js +1 -0
- package/dist/siemens-ix/p-DzWThpzp.js +1 -0
- package/dist/siemens-ix/p-GLcPX9PU.js +1 -0
- package/dist/siemens-ix/{p-pXYAoEyc.js → p-JJddxCCh.js} +1 -1
- package/dist/siemens-ix/p-XBTykBKS.js +1 -0
- package/dist/siemens-ix/p-Z4IKO1Dx.js +1 -0
- package/dist/siemens-ix/p-a44e8a8f.entry.js +1 -0
- package/dist/siemens-ix/p-a5d60068.entry.js +1 -0
- package/dist/siemens-ix/p-ae5569aa.entry.js +1 -0
- package/dist/siemens-ix/p-afa900f7.entry.js +1 -0
- package/dist/siemens-ix/p-b17053bc.entry.js +1 -0
- package/dist/siemens-ix/p-b1930204.entry.js +1 -0
- package/dist/siemens-ix/{p-d458b450.entry.js → p-b517c2e1.entry.js} +1 -1
- package/dist/siemens-ix/p-b96eabf7.entry.js +1 -0
- package/dist/siemens-ix/p-ba0eaaf5.entry.js +1 -0
- package/dist/siemens-ix/p-bd60b9fe.entry.js +1 -0
- package/dist/siemens-ix/p-bef76eac.entry.js +1 -0
- package/dist/siemens-ix/p-c350c5d0.entry.js +1 -0
- package/dist/siemens-ix/p-c56497da.entry.js +1 -0
- package/dist/siemens-ix/p-c78a5414.entry.js +1 -0
- package/dist/siemens-ix/p-c921c01b.entry.js +1 -0
- package/dist/siemens-ix/p-cb9f8b47.entry.js +1 -0
- package/dist/siemens-ix/p-d34c0c51.entry.js +1 -0
- package/dist/siemens-ix/p-d440cd94.entry.js +1 -0
- package/dist/siemens-ix/{p-2b559d4b.entry.js → p-d798773f.entry.js} +1 -1
- package/dist/siemens-ix/p-d8c99656.entry.js +1 -0
- package/dist/siemens-ix/p-da8840cc.entry.js +1 -0
- package/dist/siemens-ix/p-dd2b271e.entry.js +1 -0
- package/dist/siemens-ix/p-de79c9cf.entry.js +1 -0
- package/dist/siemens-ix/p-dedd5fc0.entry.js +1 -0
- package/dist/siemens-ix/p-df13643b.entry.js +1 -0
- package/dist/siemens-ix/p-df32a25c.entry.js +1 -0
- package/dist/siemens-ix/p-e09fcd95.entry.js +1 -0
- package/dist/siemens-ix/p-e316d8a5.entry.js +1 -0
- package/dist/siemens-ix/p-ea440d84.entry.js +1 -0
- package/dist/siemens-ix/p-ed2aea43.entry.js +1 -0
- package/dist/siemens-ix/p-edb738d9.entry.js +1 -0
- package/dist/siemens-ix/p-f107a580.entry.js +1 -0
- package/dist/siemens-ix/p-f847a799.entry.js +1 -0
- package/dist/siemens-ix/p-fcac86a5.entry.js +1 -0
- package/dist/siemens-ix/p-fpBGwEVT.js +1 -0
- package/dist/siemens-ix/p-jBB3q9qq.js +1 -0
- package/dist/siemens-ix/p-yAf8WIcn.js +1 -0
- package/dist/siemens-ix/siemens-ix-core.css +1 -1
- package/dist/siemens-ix/siemens-ix-standalone.css +1 -0
- package/dist/siemens-ix/siemens-ix.css +285 -988
- package/dist/siemens-ix/siemens-ix.esm.js +1 -1
- package/dist/siemens-ix/theme/classic-dark.css +1 -1
- package/dist/siemens-ix/theme/classic-light.css +1 -1
- package/dist/types/components/application/application.d.ts +8 -5
- package/dist/types/components/application-header/application-header.d.ts +0 -7
- package/dist/types/components/avatar/avatar.d.ts +60 -8
- package/dist/types/components/breadcrumb/breadcrumb.d.ts +29 -9
- package/dist/types/components/breadcrumb/breadcrumb.types.d.ts +9 -0
- package/dist/types/components/breadcrumb-item/breadcrumb-item.d.ts +42 -12
- package/dist/types/components/button/button.d.ts +31 -8
- package/dist/types/components/card-list/card-list.d.ts +8 -0
- package/dist/types/components/checkbox-group/checkbox-group.d.ts +2 -2
- package/dist/types/components/chip/chip.d.ts +48 -4
- package/dist/types/components/chip/chip.types.d.ts +2 -0
- package/dist/types/components/custom-field/custom-field.d.ts +2 -2
- package/dist/types/components/date-dropdown/date-dropdown.d.ts +18 -17
- package/dist/types/components/date-input/date-input.d.ts +18 -5
- package/dist/types/components/date-picker/date-picker.d.ts +62 -10
- package/dist/types/components/date-time-card/date-time-card.d.ts +4 -0
- package/dist/types/components/datetime-input/datetime-input.d.ts +210 -0
- package/dist/types/components/datetime-input/datetime-input.types.d.ts +3 -0
- package/dist/types/components/datetime-picker/datetime-picker.d.ts +32 -0
- package/dist/types/components/dropdown/dropdown-controller.d.ts +3 -2
- package/dist/types/components/dropdown/dropdown-focus.d.ts +20 -0
- package/dist/types/components/dropdown/dropdown.d.ts +109 -14
- package/dist/types/components/dropdown-button/dropdown-button.d.ts +82 -2
- package/dist/types/components/dropdown-item/dropdown-item.d.ts +55 -1
- package/dist/types/components/dropdown-item/dropdown-item.types.d.ts +1 -0
- package/dist/types/components/field-label/field-label.d.ts +3 -2
- package/dist/types/components/field-wrapper/field-wrapper.d.ts +39 -5
- package/dist/types/components/field-wrapper/helper-text-util.d.ts +11 -0
- package/dist/types/components/helper-text/helper-text.d.ts +2 -2
- package/dist/types/components/icon-button/icon-button.d.ts +31 -8
- package/dist/types/components/icon-toggle-button/icon-toggle-button.d.ts +31 -8
- package/dist/types/components/layout-auto/layout-auto.d.ts +2 -2
- package/dist/types/components/menu/menu-expand-icon.d.ts +4 -5
- package/dist/types/components/menu/menu.d.ts +0 -11
- package/dist/types/components/menu-about/menu-about.d.ts +19 -6
- package/dist/types/components/menu-about-item/menu-about-item.d.ts +20 -1
- package/dist/types/components/menu-about-news/menu-about-news.d.ts +22 -1
- package/dist/types/components/menu-category/menu-category.d.ts +23 -4
- package/dist/types/components/menu-item/menu-item.d.ts +2 -0
- package/dist/types/components/menu-settings/menu-settings.d.ts +19 -6
- package/dist/types/components/menu-settings-item/menu-settings-item.d.ts +21 -2
- package/dist/types/components/modal/modal.d.ts +6 -4
- package/dist/types/components/modal-header/modal-header.d.ts +2 -2
- package/dist/types/components/pill/pill.d.ts +16 -2
- package/dist/types/components/range-field/range-field.d.ts +34 -0
- package/dist/types/components/select/select.d.ts +82 -32
- package/dist/types/components/select/test/select-controller.d.ts +15 -0
- package/dist/types/components/select-item/select-item.d.ts +47 -7
- package/dist/types/components/slider/slider.d.ts +0 -6
- package/dist/types/components/split-button/split-button.d.ts +43 -8
- package/dist/types/components/tab-item/tab-item.d.ts +77 -15
- package/dist/types/components/tab-item/tab-item.types.d.ts +2 -1
- package/dist/types/components/tab-item/tab.mixin.d.ts +26 -0
- package/dist/types/components/tab-panel/tab-panel.d.ts +42 -0
- package/dist/types/components/tab-set/tab-set.d.ts +17 -0
- package/dist/types/components/tabs/tabs.d.ts +68 -58
- package/dist/types/components/time-input/time-input.d.ts +43 -6
- package/dist/types/components/time-picker/time-picker-column-values.d.ts +15 -0
- package/dist/types/components/time-picker/time-picker-compute-time.d.ts +6 -0
- package/dist/types/components/time-picker/time-picker-constraints.d.ts +16 -0
- package/dist/types/components/time-picker/time-picker-display.d.ts +6 -0
- package/dist/types/components/time-picker/time-picker-format.d.ts +13 -0
- package/dist/types/components/time-picker/time-picker-range.d.ts +11 -0
- package/dist/types/components/time-picker/time-picker-step-focus.d.ts +7 -0
- package/dist/types/components/time-picker/time-picker.d.ts +51 -9
- package/dist/types/components/time-picker/time-picker.types.d.ts +1 -0
- package/dist/types/components/toast/toast-container.d.ts +3 -11
- package/dist/types/components/toggle/toggle.d.ts +32 -1
- package/dist/types/components/toggle-button/toggle-button.d.ts +31 -6
- package/dist/types/components/tooltip/tooltip.d.ts +1 -1
- package/dist/types/components/tree/tree-model.d.ts +4 -0
- package/dist/types/components/tree-item/tree-item.d.ts +6 -0
- package/dist/types/components/upload/upload.d.ts +10 -4
- package/dist/types/components/utils/dependency-function.d.ts +16 -0
- package/dist/types/components/utils/event.d.ts +8 -0
- package/dist/types/components/utils/focus/detect-keyboard-mode.d.ts +5 -0
- package/dist/types/components/utils/focus/focus-proxy.d.ts +12 -0
- package/dist/types/components/utils/focus/focus-trap.d.ts +12 -0
- package/dist/types/components/utils/focus/focus-utilities.d.ts +32 -0
- package/dist/types/components/utils/input/index.d.ts +6 -2
- package/dist/types/components/utils/input/validation.d.ts +2 -2
- package/dist/types/components/utils/internal/component.d.ts +107 -2
- package/dist/types/components/utils/internal/index.d.ts +2 -1
- package/dist/types/components/utils/internal/mixins/accessibility/aria-activedescendant.mixin.d.ts +30 -0
- package/dist/types/components/utils/internal/mixins/accessibility/inherit-aria-attributes.mixin.d.ts +25 -0
- package/dist/types/components/utils/internal/mixins/focus-visible.mixin.d.ts +33 -0
- package/dist/types/components/utils/internal/mixins/id.mixin.d.ts +22 -0
- package/dist/types/components/utils/internal/mixins/input/input-picker.mixin.d.ts +24 -0
- package/dist/types/components/utils/internal/mixins/setup.mixin.d.ts +31 -0
- package/dist/types/components/utils/luxon-datetime-format-masks.d.ts +13 -0
- package/dist/types/components/utils/make-ref.d.ts +1 -0
- package/dist/types/components/utils/menu-tabs/menu-tabs-utils.d.ts +0 -5
- package/dist/types/components/utils/modal/index.d.ts +2 -2
- package/dist/types/components/utils/modal/loading.d.ts +8 -7
- package/dist/types/components/utils/modal/message.d.ts +27 -27
- package/dist/types/components/utils/modal/modal.d.ts +9 -18
- package/dist/types/components/utils/overlay.d.ts +2 -2
- package/dist/types/components/utils/shadow-dom.d.ts +16 -0
- package/dist/types/components/utils/test/animejs.mock.d.ts +1 -0
- package/dist/types/components/utils/theme-switcher.d.ts +24 -22
- package/dist/types/components.d.ts +1192 -613
- package/dist/types/public-api.d.ts +5 -0
- package/dist/types/tests/utils/test/page.d.ts +7 -1
- package/hydrate/index.js +12689 -6438
- package/hydrate/index.mjs +12689 -6438
- package/package.json +13 -7
- package/scss/_core.scss +3 -45
- package/scss/_standalone.scss +45 -0
- package/scss/components/_table.scss +5 -1
- package/scss/ix-core.scss +0 -2
- package/{dist/collection/components/menu-settings-item/menu-settings-item.css → scss/ix-standalone.scss} +2 -5
- package/scss/legacy/components/_checkboxes.scss +1 -1
- package/scss/legacy/components/_dropdown.scss +1 -1
- package/scss/legacy/components/_forms.scss +1 -1
- package/scss/legacy/components/_modal.scss +1 -1
- package/scss/legacy/components/_radiobuttons.scss +1 -1
- package/scss/legacy/mixins/_fonts.scss +1 -1
- package/scss/mixins/shadow-dom/_focus-visible.scss +12 -0
- package/scss/theme/classic/dark/_index.scss +0 -1
- package/scss/theme/classic/dark/_variables.scss +40 -40
- package/scss/theme/classic/light/_index.scss +0 -1
- package/scss/theme/classic/light/_variables.scss +40 -40
- package/scss/theme/classic/theme.scss +22 -28
- package/scss/theme/core/components/button.scss +29 -29
- package/scss/theme/core/components/chip.scss +4 -4
- package/scss/theme/core/components/link.scss +2 -2
- package/scss/theme/core/components/tab.scss +4 -4
- package/components/ix-application-sidebar.js +0 -1
- package/components/ix-drawer.js +0 -1
- package/components/ix-input-group.js +0 -1
- package/components/ix-validation-tooltip.js +0 -1
- package/components/p-0oJ9dyRQ.js +0 -1
- package/components/p-9tuDiQEH.js +0 -1
- package/components/p-AHG5KaOt.js +0 -1
- package/components/p-B0gQmZW3.js +0 -1
- package/components/p-B81cFxT_.js +0 -1
- package/components/p-BAIdCBnK.js +0 -1
- package/components/p-BH3f5fa3.js +0 -1
- package/components/p-BKNhBo9h.js +0 -1
- package/components/p-BLaucX4x.js +0 -1
- package/components/p-BM_otpzy.js +0 -1
- package/components/p-BWHIcA46.js +0 -1
- package/components/p-BWRJteYa.js +0 -1
- package/components/p-BYACnsyo.js +0 -1
- package/components/p-BbN-BCaw.js +0 -1
- package/components/p-BdCnOrqW.js +0 -1
- package/components/p-BhgW5qDm.js +0 -1
- package/components/p-Bi1VyG64.js +0 -1
- package/components/p-BncjKdXL.js +0 -1
- package/components/p-Bo9ALIy0.js +0 -1
- package/components/p-BvFOMxgl.js +0 -1
- package/components/p-C9SfsAWb.js +0 -1
- package/components/p-CAqtPJ4-.js +0 -1
- package/components/p-CFRrPFxi.js +0 -1
- package/components/p-CMi1hdQj.js +0 -1
- package/components/p-CPz6ThvB.js +0 -1
- package/components/p-CS1HnwQr.js +0 -1
- package/components/p-CYMB75De.js +0 -1
- package/components/p-CZsAGuDS.js +0 -1
- package/components/p-C_3dz2Xl.js +0 -1
- package/components/p-C_6_Rh7K.js +0 -1
- package/components/p-Cce1kE8J.js +0 -1
- package/components/p-CdT1qV2I.js +0 -1
- package/components/p-Cgi0rnuQ.js +0 -1
- package/components/p-ChDWY0o5.js +0 -1
- package/components/p-CjFgf9s9.js +0 -1
- package/components/p-CkBQGLbj.js +0 -1
- package/components/p-ClVzB9MP.js +0 -1
- package/components/p-CsGkJrm6.js +0 -1
- package/components/p-CxWzccPV.js +0 -1
- package/components/p-D3K9vmFp.js +0 -1
- package/components/p-DAzBNVe7.js +0 -1
- package/components/p-DNJriU2G.js +0 -1
- package/components/p-DQgVT_uh.js +0 -1
- package/components/p-DaVdylP8.js +0 -1
- package/components/p-DnKEXwdz.js +0 -1
- package/components/p-DrsekPHj.js +0 -1
- package/components/p-IsTvRVoY.js +0 -1
- package/components/p-LoRL-toz.js +0 -1
- package/components/p-MJm14Xlr.js +0 -1
- package/components/p-VHuL40oZ.js +0 -1
- package/components/p-WUp_O0u4.js +0 -1
- package/components/p-bcj7UEIC.js +0 -1
- package/components/p-gkooEHol.js +0 -1
- package/components/p-mraQmnXA.js +0 -1
- package/components/p-rBthI1EV.js +0 -1
- package/components/p-t0v_1-tY.js +0 -1
- package/components/p-unwtt2da.js +0 -1
- package/components/p-xCBXKXNq.js +0 -1
- package/components/p-xrAJuWDf.js +0 -1
- package/dist/cjs/animation-D5wGQwTg.js +0 -100
- package/dist/cjs/app-globals-Cu3bQGoC.js +0 -8
- package/dist/cjs/find-element-D7yD1Ukn.js +0 -103
- package/dist/cjs/focus-Cl8_98b5.js +0 -67
- package/dist/cjs/ix-application-sidebar.cjs.entry.js +0 -42
- package/dist/cjs/ix-drawer.cjs.entry.js +0 -166
- package/dist/cjs/ix-dropdown-item.cjs.entry.js +0 -63
- package/dist/cjs/ix-dropdown.cjs.entry.js +0 -436
- package/dist/cjs/ix-input-group.cjs.entry.js +0 -129
- package/dist/cjs/ix-menu-settings-B3zMjM3D.js +0 -128
- package/dist/cjs/ix-pill.cjs.entry.js +0 -87
- package/dist/cjs/ix-tab-item_2.cjs.entry.js +0 -495
- package/dist/cjs/ix-time-picker.cjs.entry.js +0 -689
- package/dist/cjs/ix-validation-tooltip.cjs.entry.js +0 -156
- package/dist/cjs/menu-service-CW0vT80Q.js +0 -83
- package/dist/cjs/modal-BPMUkqrW.js +0 -289
- package/dist/cjs/service-DuiJmf7R.js +0 -104
- package/dist/cjs/setup-icNDj1cf.js +0 -31
- package/dist/cjs/shadow-dom-DT01VwcB.js +0 -48
- package/dist/cjs/theme-switcher-BfjZ3MX8.js +0 -175
- package/dist/cjs/typed-event-DxWATHPL.js +0 -46
- package/dist/collection/components/application-sidebar/application-sidebar.js +0 -68
- package/dist/collection/components/application-sidebar/events.js +0 -14
- package/dist/collection/components/drawer/drawer.js +0 -392
- package/dist/collection/components/input-group/input-group.js +0 -152
- package/dist/collection/components/menu-about-item/menu-about-item.css +0 -12
- package/dist/collection/components/menu-category/enter-leave.js +0 -29
- package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js +0 -32
- package/dist/collection/components/validation-tooltip/validation-tooltip.css +0 -225
- package/dist/collection/components/validation-tooltip/validation-tooltip.js +0 -251
- package/dist/esm/animation-BLaucX4x.js +0 -98
- package/dist/esm/app-globals-Ciii0tIL.js +0 -6
- package/dist/esm/find-element-CFRrPFxi.js +0 -100
- package/dist/esm/focus-BAKpVknt.js +0 -65
- package/dist/esm/ix-application-sidebar.entry.js +0 -40
- package/dist/esm/ix-drawer.entry.js +0 -164
- package/dist/esm/ix-dropdown-item.entry.js +0 -61
- package/dist/esm/ix-dropdown.entry.js +0 -434
- package/dist/esm/ix-input-group.entry.js +0 -127
- package/dist/esm/ix-menu-settings-BrtDbSQ1.js +0 -123
- package/dist/esm/ix-pill.entry.js +0 -85
- package/dist/esm/ix-tab-item_2.entry.js +0 -492
- package/dist/esm/ix-time-picker.entry.js +0 -687
- package/dist/esm/ix-validation-tooltip.entry.js +0 -154
- package/dist/esm/menu-service-BMvtckRa.js +0 -81
- package/dist/esm/modal-BJAcx3Qd.js +0 -281
- package/dist/esm/service-Da0kv8hS.js +0 -102
- package/dist/esm/setup-eUHKNfBC.js +0 -28
- package/dist/esm/shadow-dom-i60z1FJC.js +0 -43
- package/dist/esm/theme-switcher-CpQ8JvHL.js +0 -172
- package/dist/esm/typed-event-BdCnOrqW.js +0 -44
- package/dist/siemens-ix/p-01283ae6.entry.js +0 -1
- package/dist/siemens-ix/p-048bcd80.entry.js +0 -1
- package/dist/siemens-ix/p-05d31b79.entry.js +0 -1
- package/dist/siemens-ix/p-086cadf8.entry.js +0 -1
- package/dist/siemens-ix/p-18c9b87e.entry.js +0 -1
- package/dist/siemens-ix/p-1b119c78.entry.js +0 -1
- package/dist/siemens-ix/p-1cdd52bc.entry.js +0 -1
- package/dist/siemens-ix/p-23df8fd9.entry.js +0 -1
- package/dist/siemens-ix/p-2441d048.entry.js +0 -1
- package/dist/siemens-ix/p-24947da1.entry.js +0 -1
- package/dist/siemens-ix/p-2b155e81.entry.js +0 -1
- package/dist/siemens-ix/p-2d817735.entry.js +0 -1
- package/dist/siemens-ix/p-3190954f.entry.js +0 -1
- package/dist/siemens-ix/p-359fd705.entry.js +0 -1
- package/dist/siemens-ix/p-3950fb46.entry.js +0 -1
- package/dist/siemens-ix/p-39bab003.entry.js +0 -1
- package/dist/siemens-ix/p-41e6c15a.entry.js +0 -1
- package/dist/siemens-ix/p-44ceb2c5.entry.js +0 -1
- package/dist/siemens-ix/p-46992171.entry.js +0 -1
- package/dist/siemens-ix/p-48f612e5.entry.js +0 -1
- package/dist/siemens-ix/p-49394ea8.entry.js +0 -1
- package/dist/siemens-ix/p-526f3a49.entry.js +0 -1
- package/dist/siemens-ix/p-52edd3f5.entry.js +0 -1
- package/dist/siemens-ix/p-555ee3b3.entry.js +0 -1
- package/dist/siemens-ix/p-57c72eda.entry.js +0 -1
- package/dist/siemens-ix/p-599176fb.entry.js +0 -1
- package/dist/siemens-ix/p-5a69c9e8.entry.js +0 -1
- package/dist/siemens-ix/p-5d1b7333.entry.js +0 -1
- package/dist/siemens-ix/p-5dca1d52.entry.js +0 -1
- package/dist/siemens-ix/p-5f471e1f.entry.js +0 -1
- package/dist/siemens-ix/p-60f84e32.entry.js +0 -1
- package/dist/siemens-ix/p-62156528.entry.js +0 -1
- package/dist/siemens-ix/p-6525aed2.entry.js +0 -1
- package/dist/siemens-ix/p-67eacb9b.entry.js +0 -1
- package/dist/siemens-ix/p-6e6dd3b2.entry.js +0 -1
- package/dist/siemens-ix/p-772b82bc.entry.js +0 -1
- package/dist/siemens-ix/p-77940c84.entry.js +0 -1
- package/dist/siemens-ix/p-7a50b7bc.entry.js +0 -1
- package/dist/siemens-ix/p-7bd3643e.entry.js +0 -1
- package/dist/siemens-ix/p-7c83069f.entry.js +0 -1
- package/dist/siemens-ix/p-7c9f479c.entry.js +0 -1
- package/dist/siemens-ix/p-80d52f41.entry.js +0 -1
- package/dist/siemens-ix/p-83ebc68a.entry.js +0 -1
- package/dist/siemens-ix/p-87ddae31.entry.js +0 -1
- package/dist/siemens-ix/p-8a49d412.entry.js +0 -1
- package/dist/siemens-ix/p-90afea9d.entry.js +0 -1
- package/dist/siemens-ix/p-91b62848.entry.js +0 -1
- package/dist/siemens-ix/p-9432d8bc.entry.js +0 -1
- package/dist/siemens-ix/p-9502ad09.entry.js +0 -1
- package/dist/siemens-ix/p-957439fa.entry.js +0 -1
- package/dist/siemens-ix/p-963a2b1c.entry.js +0 -1
- package/dist/siemens-ix/p-9987b6aa.entry.js +0 -1
- package/dist/siemens-ix/p-9ab70f63.entry.js +0 -1
- package/dist/siemens-ix/p-9b042e1e.entry.js +0 -1
- package/dist/siemens-ix/p-9cc7b831.entry.js +0 -1
- package/dist/siemens-ix/p-9cd5c8fd.entry.js +0 -1
- package/dist/siemens-ix/p-9d26ab4c.entry.js +0 -1
- package/dist/siemens-ix/p-9f22ba26.entry.js +0 -1
- package/dist/siemens-ix/p-BBzEV-f4.js +0 -1
- package/dist/siemens-ix/p-BEPo7U1W.js +0 -2
- package/dist/siemens-ix/p-BH3f5fa3.js +0 -1
- package/dist/siemens-ix/p-BLaucX4x.js +0 -1
- package/dist/siemens-ix/p-BUNsXW03.js +0 -1
- package/dist/siemens-ix/p-BXpulp6I.js +0 -1
- package/dist/siemens-ix/p-BayAOLV_.js +0 -1
- package/dist/siemens-ix/p-BdCnOrqW.js +0 -1
- package/dist/siemens-ix/p-BhgW5qDm.js +0 -1
- package/dist/siemens-ix/p-BncjKdXL.js +0 -1
- package/dist/siemens-ix/p-BtTxCH_z.js +0 -1
- package/dist/siemens-ix/p-BvFOMxgl.js +0 -1
- package/dist/siemens-ix/p-C6fzB3UQ.js +0 -1
- package/dist/siemens-ix/p-CAqtPJ4-.js +0 -1
- package/dist/siemens-ix/p-CFRrPFxi.js +0 -1
- package/dist/siemens-ix/p-CUWFODSd.js +0 -1
- package/dist/siemens-ix/p-CZsAGuDS.js +0 -1
- package/dist/siemens-ix/p-Cv_GwYyx.js +0 -1
- package/dist/siemens-ix/p-D3K9vmFp.js +0 -1
- package/dist/siemens-ix/p-DAzBNVe7.js +0 -1
- package/dist/siemens-ix/p-DKTq7BLY.js +0 -1
- package/dist/siemens-ix/p-EA1w1TTe.js +0 -1
- package/dist/siemens-ix/p-GJWUiWDT.js +0 -1
- package/dist/siemens-ix/p-Tgy1PBFv.js +0 -1
- package/dist/siemens-ix/p-W85AQR46.js +0 -1
- package/dist/siemens-ix/p-a2651024.entry.js +0 -1
- package/dist/siemens-ix/p-a37cd269.entry.js +0 -1
- package/dist/siemens-ix/p-a41f8be4.entry.js +0 -1
- package/dist/siemens-ix/p-a91f7f14.entry.js +0 -1
- package/dist/siemens-ix/p-aa36835f.entry.js +0 -1
- package/dist/siemens-ix/p-ab9cbf10.entry.js +0 -1
- package/dist/siemens-ix/p-ada8618e.entry.js +0 -1
- package/dist/siemens-ix/p-ae55e8e6.entry.js +0 -1
- package/dist/siemens-ix/p-b2bd816c.entry.js +0 -1
- package/dist/siemens-ix/p-b41a3733.entry.js +0 -1
- package/dist/siemens-ix/p-b6ae81a9.entry.js +0 -1
- package/dist/siemens-ix/p-bafa90ed.entry.js +0 -1
- package/dist/siemens-ix/p-bbcef047.entry.js +0 -1
- package/dist/siemens-ix/p-bcj7UEIC.js +0 -1
- package/dist/siemens-ix/p-c187909f.entry.js +0 -1
- package/dist/siemens-ix/p-c94c1d45.entry.js +0 -1
- package/dist/siemens-ix/p-ced4c721.entry.js +0 -1
- package/dist/siemens-ix/p-d3ad73e1.entry.js +0 -1
- package/dist/siemens-ix/p-d3afd82f.entry.js +0 -1
- package/dist/siemens-ix/p-d7086b5a.entry.js +0 -1
- package/dist/siemens-ix/p-d8bc930c.entry.js +0 -1
- package/dist/siemens-ix/p-daadd1ae.entry.js +0 -1
- package/dist/siemens-ix/p-dd3bb443.entry.js +0 -1
- package/dist/siemens-ix/p-df0fc6d4.entry.js +0 -1
- package/dist/siemens-ix/p-e09125fd.entry.js +0 -1
- package/dist/siemens-ix/p-e1978224.entry.js +0 -1
- package/dist/siemens-ix/p-e1c15a19.entry.js +0 -1
- package/dist/siemens-ix/p-e91b7758.entry.js +0 -1
- package/dist/siemens-ix/p-f75eab15.entry.js +0 -1
- package/dist/siemens-ix/p-f7b73fa9.entry.js +0 -1
- package/dist/siemens-ix/p-f8a078e5.entry.js +0 -1
- package/dist/siemens-ix/p-faa0599d.entry.js +0 -1
- package/dist/siemens-ix/p-fb077c75.entry.js +0 -1
- package/dist/siemens-ix/p-fb52d56c.entry.js +0 -1
- package/dist/siemens-ix/p-fb75665a.entry.js +0 -1
- package/dist/siemens-ix/p-fce55dc2.entry.js +0 -1
- package/dist/siemens-ix/p-fe1c3443.entry.js +0 -1
- package/dist/siemens-ix/p-fe5f2f38.entry.js +0 -1
- package/dist/siemens-ix/p-gkooEHol.js +0 -1
- package/dist/siemens-ix/p-i60z1FJC.js +0 -1
- package/dist/types/components/application-sidebar/application-sidebar.d.ts +0 -7
- package/dist/types/components/application-sidebar/events.d.ts +0 -4
- package/dist/types/components/drawer/drawer.d.ts +0 -62
- package/dist/types/components/drawer/test/animejs.mock.d.ts +0 -0
- package/dist/types/components/input-group/input-group.d.ts +0 -25
- package/dist/types/components/menu-category/enter-leave.d.ts +0 -7
- package/dist/types/components/utils/menu-tabs/menu-tabs-fc.d.ts +0 -8
- package/dist/types/components/validation-tooltip/validation-tooltip.d.ts +0 -46
- /package/scss/{_common-variables.scss → misc/_common-variables.scss} +0 -0
- /package/scss/{_normalize.scss → misc/_normalize.scss} +0 -0
- /package/scss/{_z-index.scss → misc/_z-index.scss} +0 -0
|
@@ -0,0 +1,989 @@
|
|
|
1
|
+
import { M as Mixin, r as registerInstance, c as createEvent, g as getElement, h, H as Host } from './index-Ca5WUunf.js';
|
|
2
|
+
import { f as findElement, i as inline, s as shift, o as offset, a as autoUpdate, b as flip, c as computePosition } from './find-element-Bxrgt3H_.js';
|
|
3
|
+
import { a as addDisposableEventListener } from './disposable-event-listener-CKoABG1h.js';
|
|
4
|
+
import { b as addFocusTrap } from './focus-trap-DDLHqzV2.js';
|
|
5
|
+
import { q as queryElements, b as focusElement, I as IX_FOCUS_VISIBLE_ACTIVE, c as focusFirstDescendant, d as focusLastDescendant, e as focusElementInContext, a as IX_FOCUS_VISIBLE } from './focus-utilities-DnaItyVQ.js';
|
|
6
|
+
import { D as DefaultMixins, r as removeVisibleFocus, h as hasKeyboardMode } from './component-Chfbghog.js';
|
|
7
|
+
import { m as makeRef } from './make-ref-Djkc69iv.js';
|
|
8
|
+
import { r as requestAnimationFrameNoNgZone } from './requestAnimationFrame-BEuV0Xpe.js';
|
|
9
|
+
import { d as dropdownController, h as hasDropdownItemWrapperImplemented } from './dropdown-controller-D6Wm2E-0.js';
|
|
10
|
+
import { T as iconSingleCheck, j as iconChevronRightSmall } from './index-Cl7fhG1I.js';
|
|
11
|
+
import { a as a11yBoolean } from './a11y-B5k8YVR0.js';
|
|
12
|
+
import { C as ComponentIdMixin } from './id.mixin-CUbYLenp.js';
|
|
13
|
+
import { F as FocusVisibleMixin } from './focus-visible.mixin-CoMZ6z5Z.js';
|
|
14
|
+
import './shadow-dom-BIe8Nw9M.js';
|
|
15
|
+
|
|
16
|
+
/*
|
|
17
|
+
* SPDX-FileCopyrightText: 2025 Siemens AG
|
|
18
|
+
*
|
|
19
|
+
* SPDX-License-Identifier: MIT
|
|
20
|
+
*
|
|
21
|
+
* This source code is licensed under the MIT license found in the
|
|
22
|
+
* LICENSE file in the root directory of this source tree.
|
|
23
|
+
*/
|
|
24
|
+
/**
|
|
25
|
+
* Originally based on Ionic's focus-visible utility.
|
|
26
|
+
* Fork of https://github.com/ionic-team/ionic-framework/blob/c37e2a5d9e765cf48d768061c9d453a13b187e13/core/src/utils/focus-trap.ts
|
|
27
|
+
*/
|
|
28
|
+
// TODO: Remove valid elements, all elements with ix-focusable should be considered
|
|
29
|
+
const VALID_FOCUS_ELEMENTS = [
|
|
30
|
+
'ix-dropdown-item',
|
|
31
|
+
'ix-select-item',
|
|
32
|
+
'ix-menu-item',
|
|
33
|
+
'ix-menu-category',
|
|
34
|
+
];
|
|
35
|
+
const QUERY_ARROW_ELEMENTS = VALID_FOCUS_ELEMENTS.map((selector) => `${selector}:not([tabindex^="-"]):not([disabled]):not([hidden])`).join(', ');
|
|
36
|
+
const QUERY_CURRENT_VISIBLE_FOCUS = VALID_FOCUS_ELEMENTS.map((selector) => `${selector}.${IX_FOCUS_VISIBLE_ACTIVE}:not([tabindex^="-"]):not([disabled]):not([hidden])`).join(', ');
|
|
37
|
+
const getIndexOfDropdownItem = (items, item, selector = QUERY_ARROW_ELEMENTS) => {
|
|
38
|
+
if (!item) {
|
|
39
|
+
return -1;
|
|
40
|
+
}
|
|
41
|
+
if (!item.matches(selector)) {
|
|
42
|
+
return -1;
|
|
43
|
+
}
|
|
44
|
+
return items.findIndex((el) => el === item);
|
|
45
|
+
};
|
|
46
|
+
const getNextFocusableDropdownItem = (items, currentItem, selector = QUERY_CURRENT_VISIBLE_FOCUS) => {
|
|
47
|
+
const currentItemIndex = getIndexOfDropdownItem(items, currentItem, selector);
|
|
48
|
+
const nextIndex = currentItemIndex + 1;
|
|
49
|
+
return items[nextIndex >= items.length ? 0 : nextIndex];
|
|
50
|
+
};
|
|
51
|
+
const getPreviousFocusableItem = (items, currentItem, selector = QUERY_CURRENT_VISIBLE_FOCUS) => {
|
|
52
|
+
const currentItemIndex = getIndexOfDropdownItem(items, currentItem, selector);
|
|
53
|
+
const prevIndex = currentItemIndex - 1;
|
|
54
|
+
return items[prevIndex < 0 ? items.length - 1 : prevIndex];
|
|
55
|
+
};
|
|
56
|
+
const focusItem = (item) => {
|
|
57
|
+
requestAnimationFrameNoNgZone(async () => {
|
|
58
|
+
let element = item;
|
|
59
|
+
if (item.matches('ix-menu-category')) {
|
|
60
|
+
element = item.shadowRoot.querySelector('.category-parent');
|
|
61
|
+
}
|
|
62
|
+
if (element) {
|
|
63
|
+
focusElement(element);
|
|
64
|
+
requestAnimationFrameNoNgZone(() => element.scrollIntoView({
|
|
65
|
+
block: 'nearest',
|
|
66
|
+
}));
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
};
|
|
70
|
+
const isTriggerElement = (element) => element.hasAttribute('data-ix-dropdown-trigger');
|
|
71
|
+
const configureKeyboardInteraction = (getItemsHost, options = {}) => {
|
|
72
|
+
const querySelector = options.querySelector ?? QUERY_ARROW_ELEMENTS;
|
|
73
|
+
const activeQuerySelector = options.activeQuerySelector ?? QUERY_CURRENT_VISIBLE_FOCUS;
|
|
74
|
+
const itemTriggerKeys = options.itemTriggerKeys ?? [
|
|
75
|
+
'ArrowRight',
|
|
76
|
+
'Enter',
|
|
77
|
+
' ',
|
|
78
|
+
];
|
|
79
|
+
const getActiveElement = options.getActiveElement ??
|
|
80
|
+
(() => {
|
|
81
|
+
return queryElements(getItemsHost(), activeQuerySelector)[0];
|
|
82
|
+
});
|
|
83
|
+
const setItemActive = options.setItemActive ?? ((item) => focusItem(item));
|
|
84
|
+
const getEventListenerTarget = options.getEventListenerTarget ?? (() => getItemsHost());
|
|
85
|
+
const callback = async (event) => {
|
|
86
|
+
const activeElement = getActiveElement();
|
|
87
|
+
let items = [];
|
|
88
|
+
try {
|
|
89
|
+
// Collect items from slots if they exist
|
|
90
|
+
if (getItemsHost().querySelectorAll('slot').length > 0) {
|
|
91
|
+
const slotElements = Array.from(getItemsHost().querySelectorAll('slot'));
|
|
92
|
+
items = slotElements.flatMap((slot) => Array.from(slot.assignedElements({ flatten: true })).flatMap((el) => {
|
|
93
|
+
// Check if the assigned element itself matches the query
|
|
94
|
+
if (el?.matches(querySelector)) {
|
|
95
|
+
return [el];
|
|
96
|
+
}
|
|
97
|
+
// Otherwise, query its children
|
|
98
|
+
return Array.from(el.querySelectorAll(querySelector));
|
|
99
|
+
}));
|
|
100
|
+
}
|
|
101
|
+
items = [
|
|
102
|
+
...items,
|
|
103
|
+
...Array.from(getItemsHost().querySelectorAll(querySelector)),
|
|
104
|
+
];
|
|
105
|
+
}
|
|
106
|
+
catch (e) {
|
|
107
|
+
}
|
|
108
|
+
if (options.beforeKeydown) {
|
|
109
|
+
options.beforeKeydown(event);
|
|
110
|
+
}
|
|
111
|
+
switch (event.key) {
|
|
112
|
+
case 'ArrowLeft': {
|
|
113
|
+
getItemsHost().dispatchEvent(new CustomEvent('ix-close-submenu', {
|
|
114
|
+
bubbles: true,
|
|
115
|
+
cancelable: true,
|
|
116
|
+
}));
|
|
117
|
+
break;
|
|
118
|
+
}
|
|
119
|
+
case 'ArrowDown': {
|
|
120
|
+
if (event.altKey) {
|
|
121
|
+
// ALT + DOWN opens the dropdown but prevent focus change
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
// Disable movement/scroll with keyboard
|
|
125
|
+
event.preventDefault();
|
|
126
|
+
const nextItem = getNextFocusableDropdownItem(items, activeElement, activeQuerySelector);
|
|
127
|
+
if (nextItem !== undefined) {
|
|
128
|
+
setItemActive(nextItem);
|
|
129
|
+
}
|
|
130
|
+
break;
|
|
131
|
+
}
|
|
132
|
+
case 'ArrowUp': {
|
|
133
|
+
if (event.altKey) {
|
|
134
|
+
// ALT + DOWN opens the dropdown but prevent focus change
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
// Disable movement/scroll with keyboard
|
|
138
|
+
event.preventDefault();
|
|
139
|
+
const prevItem = getPreviousFocusableItem(items, activeElement, activeQuerySelector);
|
|
140
|
+
if (prevItem !== undefined) {
|
|
141
|
+
setItemActive(prevItem);
|
|
142
|
+
}
|
|
143
|
+
break;
|
|
144
|
+
}
|
|
145
|
+
case 'Home': {
|
|
146
|
+
event.preventDefault();
|
|
147
|
+
const firstItem = items[0];
|
|
148
|
+
if (firstItem !== undefined) {
|
|
149
|
+
setItemActive(firstItem);
|
|
150
|
+
}
|
|
151
|
+
break;
|
|
152
|
+
}
|
|
153
|
+
case 'End': {
|
|
154
|
+
event.preventDefault();
|
|
155
|
+
const lastItem = items[items.length - 1];
|
|
156
|
+
if (lastItem !== undefined) {
|
|
157
|
+
setItemActive(lastItem);
|
|
158
|
+
}
|
|
159
|
+
break;
|
|
160
|
+
}
|
|
161
|
+
case 'ArrowRight':
|
|
162
|
+
case ' ':
|
|
163
|
+
case 'Enter': {
|
|
164
|
+
if (activeElement && isTriggerElement(activeElement)) {
|
|
165
|
+
const triggerEvent = new CustomEvent('ix-open-submenu', {
|
|
166
|
+
bubbles: true,
|
|
167
|
+
cancelable: true,
|
|
168
|
+
detail: {
|
|
169
|
+
activeElement: activeElement,
|
|
170
|
+
},
|
|
171
|
+
});
|
|
172
|
+
activeElement.dispatchEvent(triggerEvent);
|
|
173
|
+
return;
|
|
174
|
+
}
|
|
175
|
+
break;
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
if (itemTriggerKeys.includes(event.key)) {
|
|
179
|
+
options.onItemActivation?.(event, activeElement);
|
|
180
|
+
}
|
|
181
|
+
};
|
|
182
|
+
const listenerTarget = getEventListenerTarget();
|
|
183
|
+
listenerTarget.addEventListener('keydown', callback);
|
|
184
|
+
return () => listenerTarget.removeEventListener('keydown', callback);
|
|
185
|
+
};
|
|
186
|
+
|
|
187
|
+
const dropdownCss = () => `:host{background-color:var(--theme-color-2);border-radius:var(--theme-default-border-radius);min-width:0px;z-index:var(--theme-z-index-dropdown);box-shadow:var(--theme-shadow-4);padding:0.25rem 0px}:host *,:host *::after,:host *::before{box-sizing:border-box}:host ::-webkit-scrollbar-button{display:none}@-moz-document url-prefix(){:host *{scrollbar-color:var(--theme-scrollbar-thumb--background) var(--theme-scrollbar-track--background);scrollbar-width:thin}}:host{}:host ::-webkit-scrollbar{width:0.5rem;height:0.5rem}:host{}:host ::-webkit-scrollbar-track{border-radius:5px;background:var(--theme-scrollbar-track--background)}:host ::-webkit-scrollbar-track:hover{background:var(--theme-scrollbar-track--background--hover)}:host{}:host ::-webkit-scrollbar-thumb{border-radius:5px;background:var(--theme-scrollbar-thumb--background)}:host{}:host ::-webkit-scrollbar-thumb:hover{background:var(--theme-scrollbar-thumb--background--hover)}:host ::-webkit-scrollbar-corner{display:none}:host .dropdown-header{display:flex;align-items:center;height:2.5rem;color:var(--theme-menu-header--color);padding:0 1rem}:host(.overflow){max-height:calc(50vh - 3rem);overflow-y:auto}:host(:not(.show)){display:none !important}.dialog{margin:0;border:none;outline:none;padding:0.25rem 0px;min-width:0;max-width:100vw;width:-moz-max-content;width:max-content;height:-moz-fit-content;height:fit-content;background-color:var(--theme-color-2);border-radius:var(--theme-default-border-radius);box-shadow:var(--theme-shadow-4);overflow-x:visible;overflow-y:visible;inset:unset;color-scheme:inherit;color:var(--theme-color-std-text);box-sizing:border-box}.dialog *,.dialog *::after,.dialog *::before{box-sizing:border-box}.dialog .dropdown-container{display:block;position:relative}.dialog .dropdown-header{display:flex;align-items:center;height:2.5rem;color:var(--theme-menu-header--color);padding:0 1rem}.dialog.overflow{max-height:calc(50vh - 3rem);overflow-y:auto}`;
|
|
188
|
+
|
|
189
|
+
let sequenceId = 0;
|
|
190
|
+
const Dropdown = class extends Mixin(...DefaultMixins) {
|
|
191
|
+
constructor(hostRef) {
|
|
192
|
+
super();
|
|
193
|
+
registerInstance(this, hostRef);
|
|
194
|
+
this.showChange = createEvent(this, "showChange", 7);
|
|
195
|
+
this.showChanged = createEvent(this, "showChanged", 7);
|
|
196
|
+
this.experimentalRequestFocus = createEvent(this, "experimentalRequestFocus", 7);
|
|
197
|
+
this.experimentalFocusNextElement = createEvent(this, "experimentalFocusNextElement", 7);
|
|
198
|
+
}
|
|
199
|
+
get hostElement() { return getElement(this); }
|
|
200
|
+
/**
|
|
201
|
+
* Suppress the automatic placement of the dropdown.
|
|
202
|
+
*/
|
|
203
|
+
suppressAutomaticPlacement = false;
|
|
204
|
+
/**
|
|
205
|
+
* Show dropdown
|
|
206
|
+
*/
|
|
207
|
+
show = false;
|
|
208
|
+
/**
|
|
209
|
+
* Define an element that triggers the dropdown.
|
|
210
|
+
* A trigger can either be a string that will be interpreted as id attribute or a DOM element.
|
|
211
|
+
*/
|
|
212
|
+
trigger;
|
|
213
|
+
/**
|
|
214
|
+
* Define an anchor element
|
|
215
|
+
*/
|
|
216
|
+
anchor;
|
|
217
|
+
/**
|
|
218
|
+
* Controls if the dropdown will be closed in response to a click event depending on the position of the event relative to the dropdown.
|
|
219
|
+
* If the dropdown is a child of another one, it will be closed with the parent, regardless of its own close behavior.
|
|
220
|
+
*/
|
|
221
|
+
closeBehavior = 'both';
|
|
222
|
+
/**
|
|
223
|
+
* Placement of the dropdown
|
|
224
|
+
*/
|
|
225
|
+
placement = 'bottom-start';
|
|
226
|
+
/**
|
|
227
|
+
* Position strategy
|
|
228
|
+
*/
|
|
229
|
+
positioningStrategy = 'fixed';
|
|
230
|
+
/**
|
|
231
|
+
* An optional header shown at the top of the dropdown
|
|
232
|
+
*/
|
|
233
|
+
header;
|
|
234
|
+
/**
|
|
235
|
+
* By default the dropdown gets closed if the trigger is not visible anymore (e.g. due to scrolling). Setting this property prevents that behavior.
|
|
236
|
+
*
|
|
237
|
+
* @since 5.0.0
|
|
238
|
+
*/
|
|
239
|
+
suppressTriggerVisibilityCheck = false;
|
|
240
|
+
/**
|
|
241
|
+
* Suppress automatic focus when the dropdown is shown
|
|
242
|
+
*
|
|
243
|
+
* @since 4.3.0
|
|
244
|
+
*/
|
|
245
|
+
disableFocusHandling = false;
|
|
246
|
+
/**
|
|
247
|
+
* Close dropdown when tabbing away, and do not trap focus inside dropdown
|
|
248
|
+
*
|
|
249
|
+
* @since 4.3.0
|
|
250
|
+
*/
|
|
251
|
+
disableFocusTrap = false;
|
|
252
|
+
/**
|
|
253
|
+
* Enable Popover API rendering for top-layer positioning.
|
|
254
|
+
*
|
|
255
|
+
* @default false in v5.x, will default to true in v6.0.0
|
|
256
|
+
* @since 4.3.0
|
|
257
|
+
*/
|
|
258
|
+
enableTopLayer = false;
|
|
259
|
+
/**
|
|
260
|
+
* If true, the dropdown will try to focus checked items first when opened via keyboard, otherwise it will always focus the first focusable item.
|
|
261
|
+
*
|
|
262
|
+
* @since 5.0.0
|
|
263
|
+
*/
|
|
264
|
+
focusCheckedItem = false;
|
|
265
|
+
/**
|
|
266
|
+
* Keys that will open the dropdown when the trigger is focused
|
|
267
|
+
*
|
|
268
|
+
* @internal
|
|
269
|
+
*/
|
|
270
|
+
keyboardActivationKeys = [
|
|
271
|
+
'Home',
|
|
272
|
+
'End',
|
|
273
|
+
'ArrowDown',
|
|
274
|
+
'ArrowUp',
|
|
275
|
+
'Enter',
|
|
276
|
+
' ',
|
|
277
|
+
];
|
|
278
|
+
/**
|
|
279
|
+
* Keys that will open the dropdown when the trigger is focused
|
|
280
|
+
*
|
|
281
|
+
* @internal
|
|
282
|
+
*/
|
|
283
|
+
keyboardItemTriggerKeys = ['Enter', ' '];
|
|
284
|
+
/**
|
|
285
|
+
* Move dropdown along main axis of alignment
|
|
286
|
+
*
|
|
287
|
+
* @internal
|
|
288
|
+
*/
|
|
289
|
+
offset;
|
|
290
|
+
/**
|
|
291
|
+
* @internal
|
|
292
|
+
*/
|
|
293
|
+
overwriteDropdownStyle;
|
|
294
|
+
/**
|
|
295
|
+
* @internal
|
|
296
|
+
* If initialization of this dropdown is expected to be deferred submenu discovery will have to be re-run globally by the controller.
|
|
297
|
+
* This property indicates the need for that to the controller.
|
|
298
|
+
*/
|
|
299
|
+
discoverAllSubmenus = false;
|
|
300
|
+
/** @internal */
|
|
301
|
+
ignoreRelatedSubmenu = false;
|
|
302
|
+
/** @internal */
|
|
303
|
+
suppressOverflowBehavior = false;
|
|
304
|
+
/** @internal */
|
|
305
|
+
focusHost;
|
|
306
|
+
/** @internal */
|
|
307
|
+
focusTrapOptions;
|
|
308
|
+
/** @internal */
|
|
309
|
+
hostRole;
|
|
310
|
+
/**
|
|
311
|
+
* @internal
|
|
312
|
+
* Called instead of the default focus-on-open logic when the dropdown is
|
|
313
|
+
* opened via keyboard. When not set, default behavior is used.
|
|
314
|
+
*/
|
|
315
|
+
callbackFocusElement;
|
|
316
|
+
/**
|
|
317
|
+
* Fire event before visibility of dropdown has changed, preventing event will cancel showing dropdown
|
|
318
|
+
*/
|
|
319
|
+
showChange;
|
|
320
|
+
/**
|
|
321
|
+
* Fire event after visibility of dropdown has changed
|
|
322
|
+
*/
|
|
323
|
+
showChanged;
|
|
324
|
+
fallbackPlacement;
|
|
325
|
+
/**
|
|
326
|
+
* Will be fired only after dropdown changed visibility to "true"
|
|
327
|
+
*
|
|
328
|
+
* @internal
|
|
329
|
+
*/
|
|
330
|
+
experimentalRequestFocus;
|
|
331
|
+
/**
|
|
332
|
+
* @internal
|
|
333
|
+
*/
|
|
334
|
+
experimentalFocusNextElement;
|
|
335
|
+
autoUpdateCleanup;
|
|
336
|
+
dialogRef = makeRef();
|
|
337
|
+
intersectObserverTrigger;
|
|
338
|
+
triggerElement;
|
|
339
|
+
anchorElement;
|
|
340
|
+
forwardQueryElement = null;
|
|
341
|
+
dropdownElementId = `dropdown-${sequenceId++}`;
|
|
342
|
+
assignedSubmenu = [];
|
|
343
|
+
keyboardNavigationCleanup;
|
|
344
|
+
focusUtilities;
|
|
345
|
+
connectedCallback() {
|
|
346
|
+
dropdownController.connected(this);
|
|
347
|
+
if (this.trigger != undefined) {
|
|
348
|
+
this.registerListener(this.trigger);
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
cacheSubmenuId(event) {
|
|
352
|
+
event.stopImmediatePropagation();
|
|
353
|
+
event.preventDefault();
|
|
354
|
+
const { detail } = event;
|
|
355
|
+
if (this.assignedSubmenu.indexOf(detail) === -1) {
|
|
356
|
+
this.assignedSubmenu.push(detail);
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
disconnectedCallback() {
|
|
360
|
+
dropdownController.dismiss(this);
|
|
361
|
+
dropdownController.disconnected(this);
|
|
362
|
+
if (this.autoUpdateCleanup) {
|
|
363
|
+
this.autoUpdateCleanup();
|
|
364
|
+
this.autoUpdateCleanup = undefined;
|
|
365
|
+
}
|
|
366
|
+
}
|
|
367
|
+
getAssignedSubmenuIds() {
|
|
368
|
+
return this.assignedSubmenu;
|
|
369
|
+
}
|
|
370
|
+
isPresent() {
|
|
371
|
+
return this.show;
|
|
372
|
+
}
|
|
373
|
+
present() {
|
|
374
|
+
this.show = true;
|
|
375
|
+
}
|
|
376
|
+
dismiss() {
|
|
377
|
+
this.show = false;
|
|
378
|
+
}
|
|
379
|
+
getId() {
|
|
380
|
+
return this.dropdownElementId;
|
|
381
|
+
}
|
|
382
|
+
willDismiss() {
|
|
383
|
+
const { defaultPrevented } = this.showChange.emit(false);
|
|
384
|
+
return !defaultPrevented;
|
|
385
|
+
}
|
|
386
|
+
willPresent() {
|
|
387
|
+
const { defaultPrevented } = this.showChange.emit(true);
|
|
388
|
+
return !defaultPrevented;
|
|
389
|
+
}
|
|
390
|
+
get dropdownItems() {
|
|
391
|
+
return Array.from(this.hostElement.querySelectorAll('ix-dropdown-item'));
|
|
392
|
+
}
|
|
393
|
+
get slotElement() {
|
|
394
|
+
return this.hostElement.shadowRoot.querySelector('slot');
|
|
395
|
+
}
|
|
396
|
+
disposeClickListener;
|
|
397
|
+
disposeKeyListener;
|
|
398
|
+
toggleController() {
|
|
399
|
+
if (!this.isPresent()) {
|
|
400
|
+
dropdownController.present(this);
|
|
401
|
+
}
|
|
402
|
+
else {
|
|
403
|
+
dropdownController.dismiss(this);
|
|
404
|
+
}
|
|
405
|
+
dropdownController.dismissOthers(this.getId());
|
|
406
|
+
}
|
|
407
|
+
onTriggerClick = (event) => this.handleTriggerClick(event);
|
|
408
|
+
handleTriggerClick(event) {
|
|
409
|
+
if (!event.defaultPrevented) {
|
|
410
|
+
this.toggleController();
|
|
411
|
+
}
|
|
412
|
+
}
|
|
413
|
+
onTriggerKeydown = (event) => this.handleTriggerKeydown(event);
|
|
414
|
+
handleTriggerKeydown(event) {
|
|
415
|
+
const focusFirst = (element) => requestAnimationFrameNoNgZone(async () => {
|
|
416
|
+
let shouldPreventDefault = false;
|
|
417
|
+
if (this.callbackFocusElement) {
|
|
418
|
+
shouldPreventDefault =
|
|
419
|
+
(await this.callbackFocusElement(event)) ?? false;
|
|
420
|
+
}
|
|
421
|
+
if (shouldPreventDefault) {
|
|
422
|
+
return;
|
|
423
|
+
}
|
|
424
|
+
focusFirstDescendant(element, undefined, {
|
|
425
|
+
focusCheckedItem: this.focusCheckedItem,
|
|
426
|
+
});
|
|
427
|
+
});
|
|
428
|
+
const focusLast = (element) => requestAnimationFrameNoNgZone(async () => {
|
|
429
|
+
let shouldPreventDefault = false;
|
|
430
|
+
if (this.callbackFocusElement) {
|
|
431
|
+
shouldPreventDefault =
|
|
432
|
+
(await this.callbackFocusElement(event)) ?? false;
|
|
433
|
+
}
|
|
434
|
+
if (shouldPreventDefault) {
|
|
435
|
+
return;
|
|
436
|
+
}
|
|
437
|
+
focusLastDescendant(element);
|
|
438
|
+
});
|
|
439
|
+
const shouldCloseOnTab = this.disableFocusTrap === true && event.key === 'Tab';
|
|
440
|
+
if ((event.key === 'Escape' || shouldCloseOnTab) && this.show) {
|
|
441
|
+
dropdownController.dismiss(this);
|
|
442
|
+
return;
|
|
443
|
+
}
|
|
444
|
+
if (this.show) {
|
|
445
|
+
return;
|
|
446
|
+
}
|
|
447
|
+
const navigationKeys = this.keyboardActivationKeys ?? [
|
|
448
|
+
'Home',
|
|
449
|
+
'End',
|
|
450
|
+
'ArrowUp',
|
|
451
|
+
'ArrowDown',
|
|
452
|
+
' ',
|
|
453
|
+
'Enter',
|
|
454
|
+
];
|
|
455
|
+
if (!navigationKeys.includes(event.key)) {
|
|
456
|
+
return;
|
|
457
|
+
}
|
|
458
|
+
// If dropdown is not yet shown, try to open it
|
|
459
|
+
if (!this.isAnchorSubmenu()) {
|
|
460
|
+
if (!event.defaultPrevented) {
|
|
461
|
+
this.toggleController();
|
|
462
|
+
}
|
|
463
|
+
if (this.disableFocusHandling) {
|
|
464
|
+
event.stopImmediatePropagation();
|
|
465
|
+
event.preventDefault();
|
|
466
|
+
}
|
|
467
|
+
else {
|
|
468
|
+
// Focus first item for all keys except ArrowUp (which focuses last)
|
|
469
|
+
if (event.altKey) {
|
|
470
|
+
return;
|
|
471
|
+
}
|
|
472
|
+
if (event.key === 'ArrowUp' || event.key === 'End') {
|
|
473
|
+
focusLast(this.hostElement);
|
|
474
|
+
}
|
|
475
|
+
else {
|
|
476
|
+
focusFirst(this.hostElement);
|
|
477
|
+
}
|
|
478
|
+
}
|
|
479
|
+
}
|
|
480
|
+
else if (!this.disableFocusHandling) {
|
|
481
|
+
// Dropdown is already open - handle focus navigation
|
|
482
|
+
if (this.callbackFocusElement) {
|
|
483
|
+
this.callbackFocusElement(event);
|
|
484
|
+
}
|
|
485
|
+
else if (event.key === 'ArrowUp' || event.key === 'End') {
|
|
486
|
+
focusLast(this.hostElement);
|
|
487
|
+
}
|
|
488
|
+
else {
|
|
489
|
+
focusFirst(this.hostElement);
|
|
490
|
+
}
|
|
491
|
+
}
|
|
492
|
+
this.experimentalRequestFocus.emit({
|
|
493
|
+
keyEvent: event,
|
|
494
|
+
});
|
|
495
|
+
// Prevent click listener from also toggling the dropdown, which would close it again
|
|
496
|
+
event.preventDefault();
|
|
497
|
+
}
|
|
498
|
+
addEventListenersFor() {
|
|
499
|
+
if (!this.triggerElement) {
|
|
500
|
+
return;
|
|
501
|
+
}
|
|
502
|
+
if (!this.disposeClickListener) {
|
|
503
|
+
this.disposeClickListener = addDisposableEventListener(this.triggerElement, 'click', this.onTriggerClick);
|
|
504
|
+
}
|
|
505
|
+
if (!this.disposeKeyListener) {
|
|
506
|
+
this.disposeKeyListener = addDisposableEventListener(this.triggerElement, 'keydown', this.onTriggerKeydown);
|
|
507
|
+
}
|
|
508
|
+
this.triggerElement?.setAttribute('data-ix-dropdown-trigger', this.dropdownElementId);
|
|
509
|
+
}
|
|
510
|
+
/** @internal */
|
|
511
|
+
async discoverSubmenu() {
|
|
512
|
+
this.triggerElement?.dispatchEvent(new CustomEvent('ix-assign-sub-menu', {
|
|
513
|
+
bubbles: true,
|
|
514
|
+
composed: true,
|
|
515
|
+
cancelable: true,
|
|
516
|
+
detail: this.dropdownElementId,
|
|
517
|
+
}));
|
|
518
|
+
}
|
|
519
|
+
registerKeyListener() {
|
|
520
|
+
if (!this.triggerElement) {
|
|
521
|
+
return;
|
|
522
|
+
}
|
|
523
|
+
}
|
|
524
|
+
async registerListener(element) {
|
|
525
|
+
this.triggerElement = await this.resolveElement(element);
|
|
526
|
+
if (!this.triggerElement) {
|
|
527
|
+
return;
|
|
528
|
+
}
|
|
529
|
+
this.addEventListenersFor();
|
|
530
|
+
this.discoverSubmenu();
|
|
531
|
+
}
|
|
532
|
+
addObserverForTriggerVisibility() {
|
|
533
|
+
if (this.intersectObserverTrigger) {
|
|
534
|
+
this.intersectObserverTrigger.disconnect();
|
|
535
|
+
}
|
|
536
|
+
if (this.suppressTriggerVisibilityCheck) {
|
|
537
|
+
return;
|
|
538
|
+
}
|
|
539
|
+
if (!this.triggerElement) {
|
|
540
|
+
return;
|
|
541
|
+
}
|
|
542
|
+
this.intersectObserverTrigger = new IntersectionObserver((entries) => {
|
|
543
|
+
entries.forEach((entry) => {
|
|
544
|
+
if (!entry.isIntersecting) {
|
|
545
|
+
dropdownController.dismiss(this);
|
|
546
|
+
return;
|
|
547
|
+
}
|
|
548
|
+
const isTopHidden = entry.intersectionRect.top > entry.boundingClientRect.top;
|
|
549
|
+
const isBottomHidden = entry.intersectionRect.bottom < entry.boundingClientRect.bottom;
|
|
550
|
+
const isLeftHidden = entry.intersectionRect.left > entry.boundingClientRect.left;
|
|
551
|
+
const isRightHidden = entry.intersectionRect.right < entry.boundingClientRect.right;
|
|
552
|
+
this.fallbackPlacement = undefined;
|
|
553
|
+
if (isTopHidden) {
|
|
554
|
+
this.fallbackPlacement = this.createFallbackPlacement('bottom');
|
|
555
|
+
}
|
|
556
|
+
if (isBottomHidden) {
|
|
557
|
+
this.fallbackPlacement = this.createFallbackPlacement('top');
|
|
558
|
+
}
|
|
559
|
+
if (isLeftHidden) {
|
|
560
|
+
this.fallbackPlacement = this.createFallbackPlacement('right');
|
|
561
|
+
}
|
|
562
|
+
if (isRightHidden) {
|
|
563
|
+
this.fallbackPlacement = this.createFallbackPlacement('left');
|
|
564
|
+
}
|
|
565
|
+
});
|
|
566
|
+
}, {
|
|
567
|
+
threshold: [0, 0.5, 1],
|
|
568
|
+
});
|
|
569
|
+
this.intersectObserverTrigger.observe(this.anchorElement);
|
|
570
|
+
}
|
|
571
|
+
createFallbackPlacement(side) {
|
|
572
|
+
const alignment = this.placement.endsWith('-end') ? 'end' : 'start';
|
|
573
|
+
return `${side}-${alignment}`;
|
|
574
|
+
}
|
|
575
|
+
async resolveElement(element) {
|
|
576
|
+
const el = await findElement(element);
|
|
577
|
+
return this.checkForSubmenuAnchor(el);
|
|
578
|
+
}
|
|
579
|
+
async checkForSubmenuAnchor(element) {
|
|
580
|
+
if (!element) {
|
|
581
|
+
return undefined;
|
|
582
|
+
}
|
|
583
|
+
if (hasDropdownItemWrapperImplemented(element)) {
|
|
584
|
+
const dropdownItem = await element.getDropdownItemElement();
|
|
585
|
+
dropdownItem.isSubMenu = true;
|
|
586
|
+
this.hostElement.style.zIndex = `var(--theme-z-index-dropdown)`;
|
|
587
|
+
}
|
|
588
|
+
if (element.tagName === 'IX-DROPDOWN-ITEM') {
|
|
589
|
+
element.isSubMenu = true;
|
|
590
|
+
this.hostElement.style.zIndex = `var(--theme-z-index-dropdown)`;
|
|
591
|
+
}
|
|
592
|
+
return element;
|
|
593
|
+
}
|
|
594
|
+
async resolveAnchorElement() {
|
|
595
|
+
if (this.anchor) {
|
|
596
|
+
this.anchorElement = await this.resolveElement(this.anchor);
|
|
597
|
+
}
|
|
598
|
+
else if (this.trigger) {
|
|
599
|
+
this.anchorElement = await this.resolveElement(this.trigger);
|
|
600
|
+
}
|
|
601
|
+
}
|
|
602
|
+
async changedShow(newShow) {
|
|
603
|
+
if (!newShow) {
|
|
604
|
+
if (this.triggerElement &&
|
|
605
|
+
this.triggerElement.ariaHasPopup === 'menu' &&
|
|
606
|
+
this.triggerElement.tagName === 'IX-DROPDOWN-ITEM') {
|
|
607
|
+
this.triggerElement.ariaExpanded = 'false';
|
|
608
|
+
}
|
|
609
|
+
this.cleanupOnHide();
|
|
610
|
+
if (this.enableTopLayer) {
|
|
611
|
+
await this.hideDialog();
|
|
612
|
+
}
|
|
613
|
+
return;
|
|
614
|
+
}
|
|
615
|
+
await this.resolveAnchorElement();
|
|
616
|
+
this.registerKeyListener();
|
|
617
|
+
if (!this.disableFocusHandling && !this.callbackFocusElement) {
|
|
618
|
+
this.keyboardNavigationCleanup = configureKeyboardInteraction(() => this.forwardQueryElement ?? this.focusHost ?? this.hostElement, {
|
|
619
|
+
getEventListenerTarget: () => this.triggerElement ??
|
|
620
|
+
this.anchorElement,
|
|
621
|
+
onItemActivation: (event, activeElement) => {
|
|
622
|
+
event.preventDefault();
|
|
623
|
+
activeElement?.click();
|
|
624
|
+
},
|
|
625
|
+
itemTriggerKeys: this.keyboardItemTriggerKeys,
|
|
626
|
+
});
|
|
627
|
+
}
|
|
628
|
+
if (!this.disableFocusTrap) {
|
|
629
|
+
addFocusTrap(this.focusHost ?? this.hostElement, this.focusTrapOptions).then((focusTrap) => {
|
|
630
|
+
this.focusUtilities = focusTrap;
|
|
631
|
+
});
|
|
632
|
+
}
|
|
633
|
+
if (this.triggerElement &&
|
|
634
|
+
this.triggerElement.ariaHasPopup === 'menu' &&
|
|
635
|
+
this.triggerElement.tagName === 'IX-DROPDOWN-ITEM') {
|
|
636
|
+
this.triggerElement.ariaExpanded = 'true';
|
|
637
|
+
}
|
|
638
|
+
if (this.enableTopLayer) {
|
|
639
|
+
const popover = await this.dialogRef.waitForCurrent();
|
|
640
|
+
if (!popover) {
|
|
641
|
+
return;
|
|
642
|
+
}
|
|
643
|
+
popover.showPopover();
|
|
644
|
+
}
|
|
645
|
+
this.addObserverForTriggerVisibility();
|
|
646
|
+
this.applyDropdownPosition();
|
|
647
|
+
}
|
|
648
|
+
async emitShowChanged(newShow) {
|
|
649
|
+
requestAnimationFrameNoNgZone(() => this.showChanged.emit(newShow));
|
|
650
|
+
}
|
|
651
|
+
changedTrigger(newTriggerValue, oldTriggerValue) {
|
|
652
|
+
if (newTriggerValue && newTriggerValue !== oldTriggerValue) {
|
|
653
|
+
this.disposeClickListener?.();
|
|
654
|
+
this.disposeClickListener = undefined;
|
|
655
|
+
this.disposeKeyListener?.();
|
|
656
|
+
this.disposeKeyListener = undefined;
|
|
657
|
+
}
|
|
658
|
+
this.registerListener(newTriggerValue);
|
|
659
|
+
}
|
|
660
|
+
applyFallbackPosition(element) {
|
|
661
|
+
requestAnimationFrameNoNgZone(() => {
|
|
662
|
+
const referenceElement = this.hostElement.parentElement || this.hostElement;
|
|
663
|
+
const refRect = referenceElement.getBoundingClientRect();
|
|
664
|
+
const transform = `translate(${Math.round(refRect.left)}px, ${Math.round(refRect.top)}px)`;
|
|
665
|
+
Object.assign(element.style, {
|
|
666
|
+
top: '0',
|
|
667
|
+
left: '0',
|
|
668
|
+
transform,
|
|
669
|
+
});
|
|
670
|
+
});
|
|
671
|
+
}
|
|
672
|
+
async hideDialog() {
|
|
673
|
+
const popover = await this.dialogRef.waitForCurrent();
|
|
674
|
+
if (popover?.matches(':popover-open')) {
|
|
675
|
+
popover.hidePopover();
|
|
676
|
+
}
|
|
677
|
+
}
|
|
678
|
+
cleanupOnHide() {
|
|
679
|
+
this.intersectObserverTrigger?.disconnect();
|
|
680
|
+
this.destroyAutoUpdate();
|
|
681
|
+
this.keyboardNavigationCleanup?.();
|
|
682
|
+
this.focusUtilities?.destroy();
|
|
683
|
+
this.resetForwardQueryElement();
|
|
684
|
+
removeVisibleFocus();
|
|
685
|
+
if (!this.disableFocusTrap && hasKeyboardMode()) {
|
|
686
|
+
// Restore focus to trigger element
|
|
687
|
+
requestAnimationFrameNoNgZone(() => {
|
|
688
|
+
this.triggerElement?.focus();
|
|
689
|
+
});
|
|
690
|
+
}
|
|
691
|
+
}
|
|
692
|
+
destroyAutoUpdate() {
|
|
693
|
+
if (this.autoUpdateCleanup) {
|
|
694
|
+
this.autoUpdateCleanup();
|
|
695
|
+
this.autoUpdateCleanup = undefined;
|
|
696
|
+
}
|
|
697
|
+
}
|
|
698
|
+
isAnchorSubmenu() {
|
|
699
|
+
if (!hasDropdownItemWrapperImplemented(this.anchorElement)) {
|
|
700
|
+
// Is no official dropdown-item, but check if any dropdown-item
|
|
701
|
+
// is placed somewhere up the DOM
|
|
702
|
+
return !!this.anchorElement?.closest('ix-dropdown-item');
|
|
703
|
+
}
|
|
704
|
+
return true;
|
|
705
|
+
}
|
|
706
|
+
async applyDropdownPosition() {
|
|
707
|
+
const targetElement = this.enableTopLayer
|
|
708
|
+
? await this.dialogRef.waitForCurrent()
|
|
709
|
+
: this.hostElement;
|
|
710
|
+
if (!this.show) {
|
|
711
|
+
return;
|
|
712
|
+
}
|
|
713
|
+
if (!targetElement) {
|
|
714
|
+
return;
|
|
715
|
+
}
|
|
716
|
+
if (!this.anchorElement) {
|
|
717
|
+
this.applyFallbackPosition(targetElement);
|
|
718
|
+
return;
|
|
719
|
+
}
|
|
720
|
+
const referenceElement = this.anchorElement;
|
|
721
|
+
const isSubmenu = this.isAnchorSubmenu();
|
|
722
|
+
let strategy = this.positioningStrategy;
|
|
723
|
+
if (this.enableTopLayer) {
|
|
724
|
+
// Popover API only supports fixed positioning
|
|
725
|
+
strategy = 'fixed';
|
|
726
|
+
}
|
|
727
|
+
let positionConfig = {
|
|
728
|
+
strategy,
|
|
729
|
+
middleware: [],
|
|
730
|
+
};
|
|
731
|
+
if (!this.suppressAutomaticPlacement) {
|
|
732
|
+
positionConfig.middleware?.push(flip({ fallbackStrategy: 'initialPlacement' }));
|
|
733
|
+
}
|
|
734
|
+
let placement = this.placement;
|
|
735
|
+
if (this.suppressTriggerVisibilityCheck === false &&
|
|
736
|
+
this.fallbackPlacement) {
|
|
737
|
+
placement = this.fallbackPlacement;
|
|
738
|
+
}
|
|
739
|
+
positionConfig.placement = isSubmenu ? 'right-start' : placement;
|
|
740
|
+
positionConfig.middleware = [
|
|
741
|
+
...(positionConfig.middleware?.filter(Boolean) || []),
|
|
742
|
+
inline(),
|
|
743
|
+
shift(),
|
|
744
|
+
];
|
|
745
|
+
if (this.offset) {
|
|
746
|
+
positionConfig.middleware.push(offset(this.offset));
|
|
747
|
+
}
|
|
748
|
+
this.destroyAutoUpdate();
|
|
749
|
+
this.autoUpdateCleanup = autoUpdate(referenceElement, targetElement, async () => {
|
|
750
|
+
const computeResponse = await computePosition(referenceElement, targetElement, positionConfig);
|
|
751
|
+
this.hostElement.dataset.ixDropdownPlacement =
|
|
752
|
+
computeResponse.placement;
|
|
753
|
+
Object.assign(targetElement.style, {
|
|
754
|
+
top: '0',
|
|
755
|
+
left: '0',
|
|
756
|
+
transform: `translate(${Math.round(computeResponse.x)}px,${Math.round(computeResponse.y)}px)`,
|
|
757
|
+
});
|
|
758
|
+
if (this.overwriteDropdownStyle) {
|
|
759
|
+
const overwriteStyle = await this.overwriteDropdownStyle({
|
|
760
|
+
dropdownRef: targetElement,
|
|
761
|
+
triggerRef: this.triggerElement,
|
|
762
|
+
});
|
|
763
|
+
Object.assign(targetElement.style, overwriteStyle);
|
|
764
|
+
}
|
|
765
|
+
}, {
|
|
766
|
+
ancestorResize: true,
|
|
767
|
+
ancestorScroll: true,
|
|
768
|
+
elementResize: true,
|
|
769
|
+
});
|
|
770
|
+
}
|
|
771
|
+
async componentDidLoad() {
|
|
772
|
+
if (!this.trigger) {
|
|
773
|
+
return;
|
|
774
|
+
}
|
|
775
|
+
this.changedTrigger(this.trigger, undefined);
|
|
776
|
+
}
|
|
777
|
+
async componentDidRender() {
|
|
778
|
+
await this.applyDropdownPosition();
|
|
779
|
+
await this.resolveAnchorElement();
|
|
780
|
+
}
|
|
781
|
+
isTriggerElement(element) {
|
|
782
|
+
const trigger = !!element.hasAttribute('data-ix-dropdown-trigger');
|
|
783
|
+
return trigger;
|
|
784
|
+
}
|
|
785
|
+
onDropdownClick(event) {
|
|
786
|
+
const target = dropdownController.pathIncludesTrigger(event.composedPath());
|
|
787
|
+
if (target) {
|
|
788
|
+
if (target !== this.triggerElement) {
|
|
789
|
+
event.preventDefault();
|
|
790
|
+
}
|
|
791
|
+
if (this.isTriggerElement(target)) {
|
|
792
|
+
if (this.closeBehavior === 'outside') {
|
|
793
|
+
event.preventDefault();
|
|
794
|
+
}
|
|
795
|
+
return;
|
|
796
|
+
}
|
|
797
|
+
}
|
|
798
|
+
if (!event.defaultPrevented &&
|
|
799
|
+
(this.closeBehavior === 'inside' || this.closeBehavior === 'both')) {
|
|
800
|
+
dropdownController.dismissAll([this.getId()], this.ignoreRelatedSubmenu);
|
|
801
|
+
return;
|
|
802
|
+
}
|
|
803
|
+
dropdownController.dismissOthers(this.getId());
|
|
804
|
+
}
|
|
805
|
+
/**
|
|
806
|
+
* Update position of dropdown
|
|
807
|
+
*/
|
|
808
|
+
async updatePosition() {
|
|
809
|
+
this.applyDropdownPosition();
|
|
810
|
+
}
|
|
811
|
+
openSubmenu(event) {
|
|
812
|
+
const submenuIds = this.getAssignedSubmenuIds();
|
|
813
|
+
if (submenuIds.length === 0) {
|
|
814
|
+
return;
|
|
815
|
+
}
|
|
816
|
+
event.detail.activeElement.classList.add('ix-dropdown-submenu-trigger-active');
|
|
817
|
+
dropdownController.present(dropdownController.getDropdownById(submenuIds[0]));
|
|
818
|
+
this.forwardQueryElement = dropdownController.getDropdownById(submenuIds[0]).hostElement;
|
|
819
|
+
requestAnimationFrameNoNgZone(() => {
|
|
820
|
+
focusFirstDescendant(dropdownController.getDropdownById(submenuIds[0]).hostElement);
|
|
821
|
+
});
|
|
822
|
+
}
|
|
823
|
+
closeSubmenu() {
|
|
824
|
+
const parent = dropdownController.getParentDropdownId(this.getId());
|
|
825
|
+
if (parent) {
|
|
826
|
+
const parentDropdown = dropdownController.getDropdownById(parent);
|
|
827
|
+
const activeTriggers = queryElements(parentDropdown?.hostElement, '.ix-dropdown-submenu-trigger-active');
|
|
828
|
+
dropdownController.dismissChildren(parent);
|
|
829
|
+
if (parentDropdown && activeTriggers.length > 0) {
|
|
830
|
+
const activeTrigger = activeTriggers[0];
|
|
831
|
+
activeTrigger.classList.remove('ix-dropdown-submenu-trigger-active');
|
|
832
|
+
parentDropdown.hostElement.resetForwardQueryElement();
|
|
833
|
+
requestAnimationFrameNoNgZone(() => {
|
|
834
|
+
focusElementInContext(activeTrigger, parentDropdown.hostElement);
|
|
835
|
+
});
|
|
836
|
+
}
|
|
837
|
+
}
|
|
838
|
+
}
|
|
839
|
+
/**@internal */
|
|
840
|
+
async resetForwardQueryElement() {
|
|
841
|
+
this.forwardQueryElement = null;
|
|
842
|
+
}
|
|
843
|
+
render() {
|
|
844
|
+
const ariaAttributes = {};
|
|
845
|
+
if (this.triggerElement &&
|
|
846
|
+
this.triggerElement.tagName === 'IX-DROPDOWN-ITEM') {
|
|
847
|
+
ariaAttributes['aria-labelledby'] = this.triggerElement.id;
|
|
848
|
+
ariaAttributes['aria-owns'] = this.triggerElement.id;
|
|
849
|
+
ariaAttributes['role'] = 'menu';
|
|
850
|
+
}
|
|
851
|
+
else if (this.hostRole) {
|
|
852
|
+
ariaAttributes['role'] = this.hostRole;
|
|
853
|
+
}
|
|
854
|
+
return (h(Host, { key: 'e822f0f658533d267365bb69eed0223ecf9dc4eb', ...ariaAttributes, "aria-modal": "true", "data-ix-dropdown": this.dropdownElementId, "data-ix-focus-trap": true, class: {
|
|
855
|
+
'dropdown-menu': true,
|
|
856
|
+
show: this.show,
|
|
857
|
+
// overflow handling not needed when using top-layer
|
|
858
|
+
overflow: !this.suppressOverflowBehavior && !this.enableTopLayer,
|
|
859
|
+
}, style: this.enableTopLayer
|
|
860
|
+
? {}
|
|
861
|
+
: {
|
|
862
|
+
margin: '0',
|
|
863
|
+
minWidth: '0px',
|
|
864
|
+
position: this.positioningStrategy,
|
|
865
|
+
}, onClick: (event) => this.onDropdownClick(event) }, this.enableTopLayer ? (h("dialog", { role: "presentation", ref: this.dialogRef, class: {
|
|
866
|
+
dialog: true,
|
|
867
|
+
overflow: !this.suppressOverflowBehavior,
|
|
868
|
+
}, popover: "manual", tabindex: -1, onClick: (event) => this.onDropdownClick(event) }, h("div", { class: "dropdown-container" }, this.header && h("div", { class: "dropdown-header" }, this.header), this.show && h("slot", null)))) : (h("div", { style: { display: 'contents' }, role: "presentation" }, this.header && h("div", { class: "dropdown-header" }, this.header), this.show && h("slot", null)))));
|
|
869
|
+
}
|
|
870
|
+
static get watchers() { return {
|
|
871
|
+
"show": [{
|
|
872
|
+
"changedShow": 0
|
|
873
|
+
}, {
|
|
874
|
+
"emitShowChanged": 0
|
|
875
|
+
}],
|
|
876
|
+
"trigger": [{
|
|
877
|
+
"changedTrigger": 0
|
|
878
|
+
}]
|
|
879
|
+
}; }
|
|
880
|
+
};
|
|
881
|
+
Dropdown.style = dropdownCss();
|
|
882
|
+
|
|
883
|
+
const dropdownItemCss = () => `:host{--ix-dropdown-item-checked-color:var(--theme-color-primary);display:flex;flex-direction:row;position:relative;height:2.5rem;width:auto;overflow:hidden;cursor:pointer}:host *,:host *::after,:host *::before{box-sizing:border-box}:host ::-webkit-scrollbar-button{display:none}@-moz-document url-prefix(){:host *{scrollbar-color:var(--theme-scrollbar-thumb--background) var(--theme-scrollbar-track--background);scrollbar-width:thin}}:host{}:host ::-webkit-scrollbar{width:0.5rem;height:0.5rem}:host{}:host ::-webkit-scrollbar-track{border-radius:5px;background:var(--theme-scrollbar-track--background)}:host ::-webkit-scrollbar-track:hover{background:var(--theme-scrollbar-track--background--hover)}:host{}:host ::-webkit-scrollbar-thumb{border-radius:5px;background:var(--theme-scrollbar-thumb--background)}:host{}:host ::-webkit-scrollbar-thumb:hover{background:var(--theme-scrollbar-thumb--background--hover)}:host ::-webkit-scrollbar-corner{display:none}:host .dropdown-item{all:unset;display:flex;flex-direction:row;align-items:center;position:relative;height:calc(100% - 2px);border:0.0625rem solid transparent;white-space:nowrap;width:calc(100% - 0.5rem - 1.5rem);padding:0 0.5rem;padding-right:1.5rem}:host .dropdown-item.no-checked-field{width:calc(100% - 1rem - 1.5rem);padding:0 1rem;padding-right:1.5rem}:host .dropdown-item-checked{display:flex;align-items:center;justify-content:center;position:relative;height:100%;width:1rem;min-width:1rem;margin-right:0.5rem;color:var(--ix-dropdown-item-checked-color)}:host .dropdown-item-icon{margin-right:0.5rem;color:var(--theme-color-std-text)}:host .dropdown-item-text{display:block;position:relative;overflow:hidden;text-overflow:ellipsis;white-space:pre}:host .submenu-icon{margin-left:auto}:host(.icon-only) .dropdown-item-icon{margin-right:0px}:host(.icon-only) .dropdown-item-checked{display:none}:host(.icon-only) .dropdown-item{width:calc(100% - 0.5rem - 0.5rem);padding:0 0.5rem;padding-right:0.5rem}:host(.submenu) .dropdown-item{width:calc(100% - 0.5rem - 0.5rem);padding:0 0.5rem;padding-right:0.5rem}:host(:not(.disabled):not(:disabled).hover),:host(:not(.disabled):not(:disabled):hover){background-color:var(--theme-ghost--background--hover)}:host(:not(.disabled):not(:disabled).active),:host(:not(.disabled):not(:disabled):active){background-color:var(--theme-ghost--background--active)}:host(.disabled){pointer-events:none;color:var(--theme-color-weak-text) !important}:host(.disabled) .dropdown-item-icon{color:var(--theme-color-weak-text) !important}:host(:focus-visible){outline:none}:host(:focus-visible) .dropdown-item{border-color:var(--theme-color-focus-bdr)}:host(.ix-focused){outline:none}:host(.ix-focused) .dropdown-item{border-color:var(--theme-color-focus-bdr)}:host(.outline-visible){outline:0.0625rem solid var(--theme-color-focus-bdr);outline-offset:-0.0625rem}:host([hidden]){display:none !important}`;
|
|
884
|
+
|
|
885
|
+
const DropdownItem = class extends Mixin(...DefaultMixins, ComponentIdMixin, FocusVisibleMixin) {
|
|
886
|
+
constructor(hostRef) {
|
|
887
|
+
super();
|
|
888
|
+
registerInstance(this, hostRef);
|
|
889
|
+
this.itemClick = createEvent(this, "itemClick", 7);
|
|
890
|
+
}
|
|
891
|
+
get hostElement() { return getElement(this); }
|
|
892
|
+
/**
|
|
893
|
+
* Label of dropdown item
|
|
894
|
+
*/
|
|
895
|
+
label;
|
|
896
|
+
/**
|
|
897
|
+
* Icon of dropdown item
|
|
898
|
+
*/
|
|
899
|
+
icon;
|
|
900
|
+
/**
|
|
901
|
+
* ARIA label for the icon
|
|
902
|
+
*/
|
|
903
|
+
ariaLabelIcon;
|
|
904
|
+
/**
|
|
905
|
+
* ARIA label for the item's button
|
|
906
|
+
* Will be set as aria-label for the nested HTML button element
|
|
907
|
+
*
|
|
908
|
+
* @since 3.2.0
|
|
909
|
+
*/
|
|
910
|
+
ariaLabelButton;
|
|
911
|
+
/**
|
|
912
|
+
* Display hover state
|
|
913
|
+
*/
|
|
914
|
+
hover = false;
|
|
915
|
+
/**
|
|
916
|
+
* Disable item and remove event listeners
|
|
917
|
+
*/
|
|
918
|
+
disabled = false;
|
|
919
|
+
/**
|
|
920
|
+
* Whether the item is checked or not. If true a checkmark will mark the item as checked.
|
|
921
|
+
*/
|
|
922
|
+
checked = false;
|
|
923
|
+
/**
|
|
924
|
+
* Role of the host surface.
|
|
925
|
+
* Use `option` when the item represents a listbox option (e.g. inside select); use `menuitem` in menus.
|
|
926
|
+
*
|
|
927
|
+
* @since 5.0.0
|
|
928
|
+
*/
|
|
929
|
+
itemRole = 'menuitem';
|
|
930
|
+
/** @internal */
|
|
931
|
+
isSubMenu = false;
|
|
932
|
+
/** @internal */
|
|
933
|
+
suppressChecked = false;
|
|
934
|
+
/** @internal */
|
|
935
|
+
hasVisualFocus = false;
|
|
936
|
+
/** @internal */
|
|
937
|
+
itemClick;
|
|
938
|
+
/** @internal */
|
|
939
|
+
async emitItemClick() {
|
|
940
|
+
this.itemClick.emit(this.hostElement);
|
|
941
|
+
}
|
|
942
|
+
/** @internal */
|
|
943
|
+
async getDropdownItemElement() {
|
|
944
|
+
return this.hostElement;
|
|
945
|
+
}
|
|
946
|
+
isIconOnly() {
|
|
947
|
+
return (this.label === undefined &&
|
|
948
|
+
this.hostElement.innerText === '' &&
|
|
949
|
+
this.icon !== undefined);
|
|
950
|
+
}
|
|
951
|
+
render() {
|
|
952
|
+
const id = this.getHostElementId();
|
|
953
|
+
let submenuAriaAttributes = {};
|
|
954
|
+
if (this.isSubMenu) {
|
|
955
|
+
submenuAriaAttributes = {
|
|
956
|
+
'aria-haspopup': 'menu',
|
|
957
|
+
'aria-expanded': 'false',
|
|
958
|
+
};
|
|
959
|
+
}
|
|
960
|
+
return (h(Host, { key: '7eab5813bffdb69a55c339ef91acfaff1d075683', id: id, role: this.itemRole, "aria-disabled": a11yBoolean(this.disabled), "aria-label": this.hostElement.ariaLabel ?? this.ariaLabelButton, class: {
|
|
961
|
+
hover: this.hover,
|
|
962
|
+
'icon-only': this.isIconOnly(),
|
|
963
|
+
disabled: this.disabled,
|
|
964
|
+
submenu: this.isSubMenu,
|
|
965
|
+
[IX_FOCUS_VISIBLE]: !this.disabled,
|
|
966
|
+
'outline-visible': this.hasVisualFocus,
|
|
967
|
+
}, onClick: () => {
|
|
968
|
+
if (!this.disabled) {
|
|
969
|
+
this.emitItemClick();
|
|
970
|
+
}
|
|
971
|
+
}, onKeyDown: (event) => {
|
|
972
|
+
if (!this.disabled && (event.key === 'Enter' || event.key === ' ')) {
|
|
973
|
+
this.emitItemClick();
|
|
974
|
+
}
|
|
975
|
+
}, ...submenuAriaAttributes }, h("div", { key: 'd3027e3165c38811222d4a82afae6a8f4a85ee29', class: {
|
|
976
|
+
'dropdown-item': true,
|
|
977
|
+
'no-checked-field': this.suppressChecked,
|
|
978
|
+
disabled: this.disabled,
|
|
979
|
+
} }, !this.suppressChecked ? (h("div", { class: "dropdown-item-checked" }, this.checked ? (h("ix-icon", { "aria-hidden": "true", class: "checkmark", name: iconSingleCheck, size: "16" })) : null)) : null, this.icon ? (h("ix-icon", { class: "dropdown-item-icon", name: this.icon, "aria-label": this.ariaLabelIcon })) : null, h("div", { key: 'bc618870c35cf9f4c8da8dbf8e6148c9cdd6ec22', class: "dropdown-item-text" }, this.label, h("slot", { key: '6c65471535c990245af19722ed847cd6b534d419' })), this.isSubMenu ? (h("ix-icon", { name: iconChevronRightSmall, class: 'submenu-icon' })) : null)));
|
|
980
|
+
}
|
|
981
|
+
static get watchers() { return {
|
|
982
|
+
"ixFocusVisible": [{
|
|
983
|
+
"$internal_checkAriaSelected": 0
|
|
984
|
+
}]
|
|
985
|
+
}; }
|
|
986
|
+
};
|
|
987
|
+
DropdownItem.style = dropdownItemCss();
|
|
988
|
+
|
|
989
|
+
export { Dropdown as ix_dropdown, DropdownItem as ix_dropdown_item };
|