@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
|
@@ -17,134 +17,207 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
17
17
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
18
18
|
};
|
|
19
19
|
import { iconChevronDownSmall, iconChevronUpSmall, iconClear, iconPlus, } from "@siemens/ix-icons/icons";
|
|
20
|
-
import { h, Host, } from "@stencil/core";
|
|
20
|
+
import { h, Host, Mixin, } from "@stencil/core";
|
|
21
21
|
import { a11yBoolean } from "../utils/a11y";
|
|
22
|
-
import {
|
|
22
|
+
import { FocusProxy, PROXY_LIST_ID_SUFFIX, PROXY_LISTITEM_ID_SUFFIX, updateFocusProxyList, } from "../utils/focus/focus-proxy";
|
|
23
|
+
import { IX_FOCUS_VISIBLE_ACTIVE, queryElements, } from "../utils/focus/focus-utilities";
|
|
23
24
|
import { HookValidationLifecycle, } from "../utils/input";
|
|
24
|
-
import {
|
|
25
|
+
import { DefaultMixins } from "../utils/internal/component";
|
|
26
|
+
import { AriaActiveDescendantMixin, } from "../utils/internal/mixins/accessibility/aria-activedescendant.mixin";
|
|
27
|
+
import { ComponentIdMixin, } from "../utils/internal/mixins/id.mixin";
|
|
25
28
|
import { makeRef } from "../utils/make-ref";
|
|
26
|
-
import { createMutationObserver } from "../utils/mutation-observer";
|
|
27
29
|
import { requestAnimationFrameNoNgZone } from "../utils/requestAnimationFrame";
|
|
30
|
+
let selectId = 0;
|
|
28
31
|
/**
|
|
29
32
|
* @form-ready
|
|
30
33
|
*/
|
|
31
|
-
export class Select {
|
|
34
|
+
export class Select extends Mixin(...DefaultMixins, ComponentIdMixin, AriaActiveDescendantMixin) {
|
|
32
35
|
constructor() {
|
|
33
|
-
|
|
34
|
-
* A Boolean attribute indicating that an option with a non-empty string value must be selected
|
|
35
|
-
*/
|
|
36
|
-
this.required = false;
|
|
37
|
-
/**
|
|
38
|
-
* ARIA label for the clear icon button
|
|
39
|
-
* Will be set as aria-label on the nested HTML button element
|
|
40
|
-
*
|
|
41
|
-
* @since 3.2.0
|
|
42
|
-
*/
|
|
43
|
-
this.ariaLabelClearIconButton = 'Clear selection';
|
|
44
|
-
/**
|
|
45
|
-
* Current selected value.
|
|
46
|
-
* This corresponds to the value property of ix-select-items
|
|
47
|
-
*/
|
|
48
|
-
this.value = '';
|
|
49
|
-
/**
|
|
50
|
-
* Show clear button
|
|
51
|
-
*/
|
|
52
|
-
this.allowClear = false;
|
|
53
|
-
/**
|
|
54
|
-
* Selection mode
|
|
55
|
-
*/
|
|
56
|
-
this.mode = 'single';
|
|
57
|
-
/**
|
|
58
|
-
* Select is extendable
|
|
59
|
-
*/
|
|
60
|
-
this.editable = false;
|
|
61
|
-
/**
|
|
62
|
-
* If true the select will be in disabled state
|
|
63
|
-
*/
|
|
64
|
-
this.disabled = false;
|
|
65
|
-
/**
|
|
66
|
-
* If true the select will be in readonly mode
|
|
67
|
-
*/
|
|
68
|
-
this.readonly = false;
|
|
69
|
-
/**
|
|
70
|
-
* Input field placeholder
|
|
71
|
-
*/
|
|
72
|
-
this.i18nPlaceholder = 'Select an option';
|
|
73
|
-
/**
|
|
74
|
-
* Input field placeholder for editable select
|
|
75
|
-
*/
|
|
76
|
-
this.i18nPlaceholderEditable = 'Type of select option';
|
|
77
|
-
/**
|
|
78
|
-
* Select list header
|
|
79
|
-
*/
|
|
80
|
-
this.i18nSelectListHeader = 'Select an option';
|
|
81
|
-
/**
|
|
82
|
-
* Information inside of dropdown if no items where found with current filter text
|
|
83
|
-
*/
|
|
84
|
-
this.i18nNoMatches = 'No matches';
|
|
85
|
-
/**
|
|
86
|
-
* Chip label for all selected items in multiple mode.
|
|
87
|
-
*/
|
|
88
|
-
this.i18nAllSelected = 'All';
|
|
89
|
-
/**
|
|
90
|
-
* Hide list header
|
|
91
|
-
*/
|
|
92
|
-
this.hideListHeader = false;
|
|
93
|
-
/**
|
|
94
|
-
* Show "all" chip when all items are selected in multiple mode
|
|
95
|
-
*/
|
|
96
|
-
this.collapseMultipleSelection = false;
|
|
97
|
-
/**
|
|
98
|
-
* Enable Popover API rendering for dropdown.
|
|
99
|
-
*
|
|
100
|
-
* @default false
|
|
101
|
-
* @since 4.3.0
|
|
102
|
-
*/
|
|
103
|
-
this.enableTopLayer = false;
|
|
104
|
-
this.dropdownShow = false;
|
|
105
|
-
this.selectedLabels = [];
|
|
106
|
-
this.isDropdownEmpty = false;
|
|
107
|
-
this.inputFilterText = '';
|
|
108
|
-
this.inputValue = '';
|
|
109
|
-
this.isInvalid = false;
|
|
110
|
-
this.isValid = false;
|
|
111
|
-
this.isInfo = false;
|
|
112
|
-
this.isWarning = false;
|
|
113
|
-
this.dropdownWrapperRef = makeRef();
|
|
114
|
-
this.dropdownAnchorRef = makeRef();
|
|
115
|
-
this.inputRef = makeRef();
|
|
116
|
-
this.touched = false;
|
|
117
|
-
this.itemObserver = createMutationObserver(() => {
|
|
118
|
-
if (!this.arrowFocusController) {
|
|
119
|
-
return;
|
|
120
|
-
}
|
|
121
|
-
this.arrowFocusController.items = this.visibleNonShadowItems;
|
|
122
|
-
});
|
|
123
|
-
this.focusControllerCallbackBind = this.focusDropdownItem.bind(this);
|
|
36
|
+
super();
|
|
124
37
|
}
|
|
38
|
+
hostElement;
|
|
39
|
+
formInternals;
|
|
40
|
+
/**
|
|
41
|
+
* A string that represents the element's name attribute,
|
|
42
|
+
* containing a name that identifies the element when submitting the form.
|
|
43
|
+
*/
|
|
44
|
+
name;
|
|
45
|
+
/**
|
|
46
|
+
* A Boolean attribute indicating that an option with a non-empty string value must be selected
|
|
47
|
+
*/
|
|
48
|
+
required = false;
|
|
49
|
+
/**
|
|
50
|
+
* Label for the select component
|
|
51
|
+
*/
|
|
52
|
+
label;
|
|
53
|
+
/**
|
|
54
|
+
* ARIA label for the clear icon button
|
|
55
|
+
* Will be set as aria-label on the nested HTML button element
|
|
56
|
+
*
|
|
57
|
+
* @since 3.2.0
|
|
58
|
+
*/
|
|
59
|
+
ariaLabelClearIconButton = 'Clear selection';
|
|
60
|
+
/**
|
|
61
|
+
* ARIA label for the add item
|
|
62
|
+
*
|
|
63
|
+
* @since TODO: Define
|
|
64
|
+
*/
|
|
65
|
+
ariaLabelAddItem = 'Add item';
|
|
66
|
+
/**
|
|
67
|
+
* Warning text for the select component
|
|
68
|
+
**/
|
|
69
|
+
warningText;
|
|
70
|
+
/**
|
|
71
|
+
* Info text for the select component
|
|
72
|
+
**/
|
|
73
|
+
infoText;
|
|
74
|
+
/**
|
|
75
|
+
* Error text for the select component
|
|
76
|
+
**/
|
|
77
|
+
invalidText;
|
|
78
|
+
/**
|
|
79
|
+
* Valid text for the select component
|
|
80
|
+
**/
|
|
81
|
+
validText;
|
|
82
|
+
/**
|
|
83
|
+
* Helper text for the select component
|
|
84
|
+
**/
|
|
85
|
+
helperText;
|
|
86
|
+
/**
|
|
87
|
+
* Show helper, error, info, warning text as tooltip
|
|
88
|
+
*/
|
|
89
|
+
showTextAsTooltip;
|
|
90
|
+
/**
|
|
91
|
+
* Current selected value.
|
|
92
|
+
* This corresponds to the value property of ix-select-items
|
|
93
|
+
*/
|
|
94
|
+
value = '';
|
|
95
|
+
/**
|
|
96
|
+
* Show clear button
|
|
97
|
+
*/
|
|
98
|
+
allowClear = false;
|
|
99
|
+
/**
|
|
100
|
+
* Selection mode
|
|
101
|
+
*/
|
|
102
|
+
mode = 'single';
|
|
103
|
+
/**
|
|
104
|
+
* Select is extendable
|
|
105
|
+
*/
|
|
106
|
+
editable = false;
|
|
107
|
+
/**
|
|
108
|
+
* If true the select will be in disabled state
|
|
109
|
+
*/
|
|
110
|
+
disabled = false;
|
|
111
|
+
/**
|
|
112
|
+
* If true the select will be in readonly mode
|
|
113
|
+
*/
|
|
114
|
+
readonly = false;
|
|
115
|
+
/**
|
|
116
|
+
* Input field placeholder
|
|
117
|
+
*/
|
|
118
|
+
i18nPlaceholder = 'Select an option';
|
|
119
|
+
/**
|
|
120
|
+
* Input field placeholder for editable select
|
|
121
|
+
*/
|
|
122
|
+
i18nPlaceholderEditable = 'Type of select option';
|
|
123
|
+
/**
|
|
124
|
+
* Select list header
|
|
125
|
+
*/
|
|
126
|
+
i18nSelectListHeader = 'Select an option';
|
|
127
|
+
/**
|
|
128
|
+
* Information inside of dropdown if no items where found with current filter text
|
|
129
|
+
*/
|
|
130
|
+
i18nNoMatches = 'No matches';
|
|
131
|
+
/**
|
|
132
|
+
* Chip label for all selected items in multiple mode.
|
|
133
|
+
*/
|
|
134
|
+
i18nAllSelected = 'All';
|
|
135
|
+
/**
|
|
136
|
+
* Prefix for the accessible name of the close control on a selected chip in multiple mode.
|
|
137
|
+
* The chip label or value is appended (e.g. "Remove Item 1").
|
|
138
|
+
*
|
|
139
|
+
* @since 5.0.0
|
|
140
|
+
*/
|
|
141
|
+
i18nRemoveSelectedItem = 'Remove';
|
|
142
|
+
/**
|
|
143
|
+
* Hide list header
|
|
144
|
+
*/
|
|
145
|
+
hideListHeader = false;
|
|
146
|
+
/**
|
|
147
|
+
* The width of the dropdown element with value and unit (e.g. "200px" or "12.5rem").
|
|
148
|
+
*/
|
|
149
|
+
dropdownWidth;
|
|
150
|
+
/**
|
|
151
|
+
* The maximum width of the dropdown element with value and unit (e.g. "200px" or "12.5rem").
|
|
152
|
+
* By default the maximum width of the dropdown element is set to 100%.
|
|
153
|
+
*/
|
|
154
|
+
dropdownMaxWidth;
|
|
155
|
+
/**
|
|
156
|
+
* Show "all" chip when all items are selected in multiple mode
|
|
157
|
+
*/
|
|
158
|
+
collapseMultipleSelection = false;
|
|
159
|
+
/**
|
|
160
|
+
* Enable Popover API rendering for dropdown.
|
|
161
|
+
*
|
|
162
|
+
* @default false
|
|
163
|
+
* @since 4.3.0
|
|
164
|
+
*/
|
|
165
|
+
enableTopLayer = false;
|
|
166
|
+
/**
|
|
167
|
+
* Value changed
|
|
168
|
+
*/
|
|
169
|
+
valueChange;
|
|
170
|
+
/**
|
|
171
|
+
* Event dispatched whenever the text input changes.
|
|
172
|
+
*/
|
|
173
|
+
inputChange;
|
|
174
|
+
/**
|
|
175
|
+
* Item added to selection
|
|
176
|
+
*/
|
|
177
|
+
addItem;
|
|
178
|
+
/**
|
|
179
|
+
* Blur input
|
|
180
|
+
*/
|
|
181
|
+
ixBlur;
|
|
182
|
+
dropdownShow = false;
|
|
183
|
+
selectedLabels = [];
|
|
184
|
+
isDropdownEmpty = false;
|
|
185
|
+
inputFilterText = '';
|
|
186
|
+
inputValue = '';
|
|
187
|
+
hasInputFocus = false;
|
|
188
|
+
dropdownItemsVisualFocused = false;
|
|
189
|
+
isInvalid = false;
|
|
190
|
+
isValid = false;
|
|
191
|
+
isInfo = false;
|
|
192
|
+
isWarning = false;
|
|
193
|
+
hostId = `ix-select-${selectId++}`;
|
|
194
|
+
dropdownWrapperRef = makeRef();
|
|
195
|
+
dropdownAnchorRef = makeRef();
|
|
196
|
+
inputRef = makeRef();
|
|
197
|
+
dropdownRef = makeRef();
|
|
198
|
+
proxyListObserver = null;
|
|
199
|
+
inputElement;
|
|
200
|
+
touched = false;
|
|
125
201
|
get nonShadowItems() {
|
|
126
202
|
return Array.from(this.hostElement.querySelectorAll('ix-select-item'));
|
|
127
203
|
}
|
|
128
|
-
get visibleNonShadowItems() {
|
|
129
|
-
return this.nonShadowItems.filter((item) => !item.classList.contains('display-none'));
|
|
130
|
-
}
|
|
131
204
|
get shadowItems() {
|
|
132
205
|
return Array.from(this.hostElement.shadowRoot.querySelectorAll('ix-select-item'));
|
|
133
206
|
}
|
|
134
|
-
get
|
|
135
|
-
return this.
|
|
207
|
+
get focusableItems() {
|
|
208
|
+
return Array.from(this.hostElement.querySelectorAll('ix-select-item:not([disabled]):not([hidden]), ix-dropdown-item:not([disabled]):not([hidden])'));
|
|
209
|
+
}
|
|
210
|
+
get allFocusableItems() {
|
|
211
|
+
return Array.from(this.hostElement.querySelectorAll('ix-select-item, ix-dropdown-item'));
|
|
136
212
|
}
|
|
137
213
|
get items() {
|
|
138
214
|
return [...this.nonShadowItems, ...this.shadowItems];
|
|
139
215
|
}
|
|
140
|
-
get visibleItems() {
|
|
141
|
-
return this.items.filter((item) => !item.classList.contains('display-none'));
|
|
142
|
-
}
|
|
143
216
|
get selectedItems() {
|
|
144
217
|
return this.items.filter((item) => item.selected);
|
|
145
218
|
}
|
|
146
|
-
get
|
|
147
|
-
return this.hostElement.
|
|
219
|
+
get addItemElement() {
|
|
220
|
+
return this.hostElement.querySelector('ix-dropdown-item.add-item');
|
|
148
221
|
}
|
|
149
222
|
get isSingleMode() {
|
|
150
223
|
return this.mode === 'single';
|
|
@@ -153,33 +226,12 @@ export class Select {
|
|
|
153
226
|
return this.mode === 'multiple';
|
|
154
227
|
}
|
|
155
228
|
get isEveryDropdownItemHidden() {
|
|
156
|
-
return this.items.every((item) => item.
|
|
229
|
+
return this.items.every((item) => item.hidden === true);
|
|
157
230
|
}
|
|
158
231
|
watchValue(value) {
|
|
159
232
|
this.value = value;
|
|
160
233
|
this.updateSelection();
|
|
161
234
|
}
|
|
162
|
-
watchDropdownShow(show) {
|
|
163
|
-
if (show && this.dropdownElement) {
|
|
164
|
-
this.itemObserver.observe(this.dropdownElement, {
|
|
165
|
-
childList: true,
|
|
166
|
-
subtree: true,
|
|
167
|
-
});
|
|
168
|
-
}
|
|
169
|
-
else {
|
|
170
|
-
this.cleanupResources();
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
cleanupResources() {
|
|
174
|
-
var _a, _b;
|
|
175
|
-
(_a = this.arrowFocusController) === null || _a === void 0 ? void 0 : _a.disconnect();
|
|
176
|
-
this.arrowFocusController = undefined;
|
|
177
|
-
(_b = this.itemObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
|
|
178
|
-
}
|
|
179
|
-
onItemClicked(event) {
|
|
180
|
-
const newId = event.detail;
|
|
181
|
-
this.itemClick(newId);
|
|
182
|
-
}
|
|
183
235
|
updateFormInternalValue(value) {
|
|
184
236
|
if (Array.isArray(value)) {
|
|
185
237
|
this.formInternals.setFormValue(value.join(','));
|
|
@@ -198,20 +250,6 @@ export class Select {
|
|
|
198
250
|
}
|
|
199
251
|
return !!this.value;
|
|
200
252
|
}
|
|
201
|
-
focusDropdownItem(index) {
|
|
202
|
-
var _a, _b;
|
|
203
|
-
this.navigationItem = undefined;
|
|
204
|
-
if (index < this.visibleNonShadowItems.length) {
|
|
205
|
-
const nestedDropdownItem = (_b = (_a = this.visibleNonShadowItems[index]) === null || _a === void 0 ? void 0 : _a.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('ix-dropdown-item');
|
|
206
|
-
if (!nestedDropdownItem) {
|
|
207
|
-
return;
|
|
208
|
-
}
|
|
209
|
-
requestAnimationFrameNoNgZone(() => {
|
|
210
|
-
var _a, _b;
|
|
211
|
-
(_b = (_a = nestedDropdownItem === null || nestedDropdownItem === void 0 ? void 0 : nestedDropdownItem.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('button')) === null || _b === void 0 ? void 0 : _b.focus();
|
|
212
|
-
});
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
253
|
itemClick(newId) {
|
|
216
254
|
const oldValue = this.value;
|
|
217
255
|
const value = this.toggleValue(newId);
|
|
@@ -224,15 +262,10 @@ export class Select {
|
|
|
224
262
|
this.updateSelection();
|
|
225
263
|
if (this.isMultipleMode && this.inputFilterText) {
|
|
226
264
|
this.clearInput();
|
|
227
|
-
this.
|
|
228
|
-
if (this.arrowFocusController) {
|
|
229
|
-
this.arrowFocusController.items = this.visibleNonShadowItems;
|
|
230
|
-
}
|
|
231
|
-
this.navigationItem = undefined;
|
|
265
|
+
this.removeHiddenAttributeFromItems();
|
|
232
266
|
}
|
|
233
267
|
}
|
|
234
268
|
emitAddItem(value) {
|
|
235
|
-
var _a;
|
|
236
269
|
if (value === undefined || value.trim() === '') {
|
|
237
270
|
return false;
|
|
238
271
|
}
|
|
@@ -243,9 +276,11 @@ export class Select {
|
|
|
243
276
|
const newItem = document.createElement('ix-select-item');
|
|
244
277
|
newItem.value = value;
|
|
245
278
|
newItem.label = value;
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
279
|
+
this.addItemElement?.before(newItem);
|
|
280
|
+
requestAnimationFrameNoNgZone(() => {
|
|
281
|
+
this.clearInput();
|
|
282
|
+
this.itemClick(value);
|
|
283
|
+
});
|
|
249
284
|
return false;
|
|
250
285
|
}
|
|
251
286
|
toggleValue(itemValue) {
|
|
@@ -267,7 +302,6 @@ export class Select {
|
|
|
267
302
|
}
|
|
268
303
|
}
|
|
269
304
|
updateSelection() {
|
|
270
|
-
var _a, _b;
|
|
271
305
|
let ids = [];
|
|
272
306
|
if (this.value) {
|
|
273
307
|
ids = Array.isArray(this.value) ? [...this.value] : [this.value];
|
|
@@ -282,12 +316,12 @@ export class Select {
|
|
|
282
316
|
}
|
|
283
317
|
});
|
|
284
318
|
});
|
|
285
|
-
this.selectedLabels = this.selectedItems.map((item) => item.label);
|
|
319
|
+
this.selectedLabels = this.selectedItems.map((item) => item.label ?? item.value);
|
|
286
320
|
if (this.dropdownShow && this.inputFilterText) {
|
|
287
321
|
return;
|
|
288
322
|
}
|
|
289
|
-
if (
|
|
290
|
-
this.inputValue =
|
|
323
|
+
if (this.selectedLabels?.length && this.isSingleMode) {
|
|
324
|
+
this.inputValue = this.selectedLabels[0] ?? '';
|
|
291
325
|
}
|
|
292
326
|
else {
|
|
293
327
|
this.inputValue = '';
|
|
@@ -302,209 +336,128 @@ export class Select {
|
|
|
302
336
|
this.updateFormInternalValue(value);
|
|
303
337
|
return false;
|
|
304
338
|
}
|
|
339
|
+
createAddItemElement() {
|
|
340
|
+
const onAddItemButtonClick = () => {
|
|
341
|
+
this.emitAddItem(this.inputFilterText);
|
|
342
|
+
};
|
|
343
|
+
const createElement = () => {
|
|
344
|
+
const addItemElement = document.createElement('ix-dropdown-item');
|
|
345
|
+
addItemElement.hidden = true;
|
|
346
|
+
addItemElement.setAttribute('data-testid', 'add-item');
|
|
347
|
+
addItemElement.icon = iconPlus;
|
|
348
|
+
addItemElement.classList.add('add-item');
|
|
349
|
+
addItemElement.addEventListener('click', onAddItemButtonClick);
|
|
350
|
+
addItemElement.style.order = Number.MAX_SAFE_INTEGER.toString();
|
|
351
|
+
addItemElement.ariaHidden = 'true';
|
|
352
|
+
addItemElement.role = 'presentation';
|
|
353
|
+
return addItemElement;
|
|
354
|
+
};
|
|
355
|
+
const isRendered = this.hostElement.querySelector('.add-item');
|
|
356
|
+
if (!isRendered) {
|
|
357
|
+
this.hostElement.appendChild(createElement());
|
|
358
|
+
}
|
|
359
|
+
}
|
|
305
360
|
componentDidLoad() {
|
|
306
|
-
|
|
307
|
-
(_a = this.inputElement) === null || _a === void 0 ? void 0 : _a.addEventListener('input', () => {
|
|
308
|
-
var _a;
|
|
361
|
+
this.inputElement?.addEventListener('input', () => {
|
|
309
362
|
this.dropdownShow = true;
|
|
310
|
-
this.inputChange.emit(
|
|
363
|
+
this.inputChange.emit(this.inputElement?.value);
|
|
364
|
+
});
|
|
365
|
+
this.createAddItemElement();
|
|
366
|
+
this.proxyListObserver = new MutationObserver(() => {
|
|
367
|
+
this.updateAriaProxyListbox();
|
|
368
|
+
});
|
|
369
|
+
this.proxyListObserver.observe(this.hostElement, {
|
|
370
|
+
attributes: true,
|
|
371
|
+
attributeFilter: ['aria-selected'],
|
|
372
|
+
subtree: true,
|
|
373
|
+
childList: true,
|
|
311
374
|
});
|
|
312
375
|
}
|
|
313
376
|
componentWillLoad() {
|
|
314
377
|
this.updateSelection();
|
|
315
378
|
this.updateFormInternalValue(this.value);
|
|
316
379
|
}
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
!this.dropdownElement) {
|
|
321
|
-
return;
|
|
322
|
-
}
|
|
323
|
-
this.arrowFocusController = new ArrowFocusController(this.visibleNonShadowItems, this.dropdownElement, this.focusControllerCallbackBind);
|
|
324
|
-
this.arrowFocusController.wrap =
|
|
325
|
-
!this.isAddItemVisible() && !this.visibleShadowItems.length;
|
|
380
|
+
disconnectedCallback() {
|
|
381
|
+
super.disconnectedCallback();
|
|
382
|
+
this.proxyListObserver?.disconnect();
|
|
326
383
|
}
|
|
327
384
|
onLabelChange(event) {
|
|
328
385
|
event.preventDefault();
|
|
329
386
|
event.stopImmediatePropagation();
|
|
330
387
|
this.updateSelection();
|
|
331
388
|
}
|
|
332
|
-
disconnectedCallback() {
|
|
333
|
-
this.cleanupResources();
|
|
334
|
-
}
|
|
335
389
|
itemExists(item) {
|
|
336
390
|
return this.items.find((i) => i.label === item);
|
|
337
391
|
}
|
|
392
|
+
getActiveVisualFocusedItem() {
|
|
393
|
+
const elements = queryElements(this.hostElement, `.${IX_FOCUS_VISIBLE_ACTIVE}`);
|
|
394
|
+
if (elements.length > 0) {
|
|
395
|
+
return elements[0];
|
|
396
|
+
}
|
|
397
|
+
return null;
|
|
398
|
+
}
|
|
338
399
|
dropdownVisibilityChanged(event) {
|
|
339
|
-
var _a, _b;
|
|
340
400
|
this.dropdownShow = event.detail;
|
|
341
401
|
if (event.detail) {
|
|
342
|
-
|
|
343
|
-
(
|
|
344
|
-
|
|
402
|
+
this.inputElement?.focus();
|
|
403
|
+
if (this.hasValue()) {
|
|
404
|
+
this.inputElement?.select();
|
|
405
|
+
}
|
|
406
|
+
if (!this.inputFilterText) {
|
|
407
|
+
this.removeHiddenAttributeFromItems();
|
|
408
|
+
}
|
|
345
409
|
this.isDropdownEmpty = this.isEveryDropdownItemHidden;
|
|
410
|
+
this.checkVisibilityOfProxyList();
|
|
346
411
|
}
|
|
347
412
|
else {
|
|
348
|
-
this.navigationItem = undefined;
|
|
349
413
|
this.updateSelection();
|
|
350
414
|
this.inputFilterText = '';
|
|
415
|
+
this.dropdownItemsVisualFocused = false;
|
|
416
|
+
this.inputElement?.setAttribute('aria-activedescendant', '');
|
|
351
417
|
}
|
|
352
418
|
}
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
await this.onArrowNavigation(event, event.code);
|
|
356
|
-
}
|
|
357
|
-
if (!this.dropdownShow) {
|
|
358
|
-
return;
|
|
359
|
-
}
|
|
360
|
-
if (event.code === 'Enter' || event.code === 'NumpadEnter') {
|
|
361
|
-
await this.onEnterNavigation(event.target);
|
|
362
|
-
}
|
|
363
|
-
if (event.code === 'Escape') {
|
|
364
|
-
this.dropdownShow = false;
|
|
365
|
-
}
|
|
366
|
-
}
|
|
367
|
-
async onEnterNavigation(el) {
|
|
368
|
-
if (this.isMultipleMode) {
|
|
369
|
-
return;
|
|
370
|
-
}
|
|
371
|
-
const itemLabel = el === null || el === void 0 ? void 0 : el.label;
|
|
372
|
-
const item = this.itemExists(this.inputFilterText);
|
|
373
|
-
if (item) {
|
|
374
|
-
this.itemClick(item.value);
|
|
375
|
-
}
|
|
376
|
-
else if (this.editable && !this.itemExists(itemLabel)) {
|
|
377
|
-
const defaultPrevented = this.emitAddItem(this.inputFilterText);
|
|
378
|
-
if (defaultPrevented) {
|
|
379
|
-
return;
|
|
380
|
-
}
|
|
381
|
-
}
|
|
382
|
-
this.dropdownShow = false;
|
|
383
|
-
this.updateSelection();
|
|
384
|
-
}
|
|
385
|
-
async onArrowNavigation(event, key) {
|
|
386
|
-
var _a;
|
|
387
|
-
if (event.defaultPrevented) {
|
|
388
|
-
return;
|
|
389
|
-
}
|
|
390
|
-
event.preventDefault();
|
|
391
|
-
event.stopPropagation();
|
|
392
|
-
this.dropdownShow = true;
|
|
393
|
-
if (!this.navigationItem && document.activeElement === this.hostElement) {
|
|
394
|
-
if (this.visibleItems.length) {
|
|
395
|
-
this.applyFocusTo(this.visibleItems.shift());
|
|
396
|
-
}
|
|
397
|
-
else if (this.isAddItemVisible()) {
|
|
398
|
-
this.focusAddItemButton();
|
|
399
|
-
}
|
|
400
|
-
return;
|
|
401
|
-
}
|
|
402
|
-
const moveUp = key === 'ArrowUp';
|
|
403
|
-
const indexNonShadow = document.activeElement
|
|
404
|
-
? this.visibleNonShadowItems.indexOf(document.activeElement)
|
|
405
|
-
: -1;
|
|
406
|
-
// Slotted select items
|
|
407
|
-
if (indexNonShadow === 0) {
|
|
408
|
-
if (!this.visibleShadowItems.length && this.isAddItemVisible()) {
|
|
409
|
-
this.focusAddItemButton();
|
|
410
|
-
}
|
|
411
|
-
else {
|
|
412
|
-
this.applyFocusTo(this.visibleShadowItems.pop());
|
|
413
|
-
}
|
|
414
|
-
return;
|
|
415
|
-
}
|
|
416
|
-
else if (indexNonShadow !== -1 &&
|
|
417
|
-
indexNonShadow === this.visibleNonShadowItems.length - 1) {
|
|
418
|
-
if (this.visibleShadowItems.length) {
|
|
419
|
-
this.applyFocusTo(this.visibleShadowItems.shift());
|
|
420
|
-
}
|
|
421
|
-
else if (this.isAddItemVisible()) {
|
|
422
|
-
this.focusAddItemButton();
|
|
423
|
-
}
|
|
424
|
-
return;
|
|
425
|
-
}
|
|
426
|
-
if (!this.navigationItem) {
|
|
427
|
-
return;
|
|
428
|
-
}
|
|
429
|
-
if (this.isAddItemVisible() &&
|
|
430
|
-
((_a = this.addItemElement) === null || _a === void 0 ? void 0 : _a.contains(await this.navigationItem.getDropdownItemElement()))) {
|
|
431
|
-
if (moveUp) {
|
|
432
|
-
this.applyFocusTo(this.visibleItems.pop());
|
|
433
|
-
}
|
|
434
|
-
else if (this.visibleItems.length) {
|
|
435
|
-
this.applyFocusTo(this.visibleItems.shift());
|
|
436
|
-
}
|
|
437
|
-
return;
|
|
438
|
-
}
|
|
439
|
-
// Custom select items
|
|
440
|
-
const indexShadow = this.visibleShadowItems.indexOf(this.navigationItem);
|
|
441
|
-
if (moveUp) {
|
|
442
|
-
if (indexShadow === 0) {
|
|
443
|
-
if (this.visibleNonShadowItems.length) {
|
|
444
|
-
this.applyFocusTo(this.visibleNonShadowItems.pop());
|
|
445
|
-
}
|
|
446
|
-
else if (this.isAddItemVisible()) {
|
|
447
|
-
this.focusAddItemButton();
|
|
448
|
-
}
|
|
449
|
-
}
|
|
450
|
-
else {
|
|
451
|
-
this.applyFocusTo(this.visibleShadowItems[indexShadow - 1]);
|
|
452
|
-
}
|
|
453
|
-
}
|
|
454
|
-
else {
|
|
455
|
-
if (indexShadow === this.visibleShadowItems.length - 1) {
|
|
456
|
-
if (this.isAddItemVisible()) {
|
|
457
|
-
this.focusAddItemButton();
|
|
458
|
-
}
|
|
459
|
-
else {
|
|
460
|
-
this.applyFocusTo(this.visibleItems.shift());
|
|
461
|
-
}
|
|
462
|
-
}
|
|
463
|
-
else {
|
|
464
|
-
this.applyFocusTo(this.visibleShadowItems[indexShadow + 1]);
|
|
465
|
-
}
|
|
466
|
-
}
|
|
467
|
-
}
|
|
468
|
-
applyFocusTo(element) {
|
|
469
|
-
if (!element) {
|
|
470
|
-
return;
|
|
471
|
-
}
|
|
472
|
-
this.navigationItem = element;
|
|
473
|
-
setTimeout(() => {
|
|
474
|
-
var _a, _b, _c, _d;
|
|
475
|
-
(_d = (_c = (_b = (_a = element.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('ix-dropdown-item')) === null || _b === void 0 ? void 0 : _b.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('button')) === null || _d === void 0 ? void 0 : _d.focus();
|
|
476
|
-
});
|
|
477
|
-
}
|
|
478
|
-
focusAddItemButton() {
|
|
479
|
-
var _a, _b;
|
|
480
|
-
if (this.addItemButton) {
|
|
481
|
-
(_b = (_a = this.addItemButton.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('button')) === null || _b === void 0 ? void 0 : _b.focus();
|
|
482
|
-
this.navigationItem = this.addItemElement;
|
|
483
|
-
}
|
|
484
|
-
}
|
|
485
|
-
filterItemsWithTypeahead() {
|
|
486
|
-
var _a, _b;
|
|
487
|
-
this.inputFilterText = (_b = (_a = this.inputElement) === null || _a === void 0 ? void 0 : _a.value.trim()) !== null && _b !== void 0 ? _b : '';
|
|
419
|
+
setItemFilter() {
|
|
420
|
+
this.inputFilterText = this.inputElement?.value.trim() ?? '';
|
|
488
421
|
if (this.inputFilterText) {
|
|
489
422
|
this.items.forEach((item) => {
|
|
490
|
-
|
|
491
|
-
item.
|
|
492
|
-
if (
|
|
493
|
-
|
|
423
|
+
const proxyItem = this.hostElement.shadowRoot?.getElementById(`${item.id}-${PROXY_LISTITEM_ID_SUFFIX}`);
|
|
424
|
+
item.hidden = false;
|
|
425
|
+
if (proxyItem) {
|
|
426
|
+
proxyItem.hidden = false;
|
|
427
|
+
proxyItem.setAttribute('aria-hidden', 'false');
|
|
428
|
+
}
|
|
429
|
+
if (!item.label
|
|
430
|
+
?.toLowerCase()
|
|
431
|
+
.includes(this.inputFilterText.toLowerCase())) {
|
|
432
|
+
item.hidden = true;
|
|
433
|
+
if (proxyItem) {
|
|
434
|
+
proxyItem.hidden = true;
|
|
435
|
+
proxyItem.setAttribute('aria-hidden', 'true');
|
|
436
|
+
}
|
|
494
437
|
}
|
|
495
438
|
});
|
|
496
439
|
}
|
|
497
440
|
else {
|
|
498
|
-
this.
|
|
499
|
-
}
|
|
500
|
-
if (this.arrowFocusController) {
|
|
501
|
-
this.arrowFocusController.items = this.visibleNonShadowItems;
|
|
441
|
+
this.removeHiddenAttributeFromItems();
|
|
502
442
|
}
|
|
503
443
|
this.isDropdownEmpty = this.isEveryDropdownItemHidden;
|
|
444
|
+
this.checkVisibilityOfProxyList();
|
|
445
|
+
}
|
|
446
|
+
checkVisibilityOfProxyList() {
|
|
447
|
+
const proxyList = this.hostElement?.shadowRoot?.getElementById(`${this.hostId}-${PROXY_LIST_ID_SUFFIX}`);
|
|
448
|
+
if (!proxyList) {
|
|
449
|
+
return;
|
|
450
|
+
}
|
|
451
|
+
proxyList.hidden = this.isDropdownEmpty;
|
|
504
452
|
}
|
|
505
|
-
|
|
453
|
+
removeHiddenAttributeFromItems() {
|
|
506
454
|
this.items.forEach((item) => {
|
|
507
|
-
item.
|
|
455
|
+
item.hidden = false;
|
|
456
|
+
const proxyItem = this.hostElement.shadowRoot?.getElementById(`${item.id}-${PROXY_LISTITEM_ID_SUFFIX}`);
|
|
457
|
+
if (proxyItem) {
|
|
458
|
+
proxyItem.hidden = false;
|
|
459
|
+
proxyItem.setAttribute('aria-hidden', 'false');
|
|
460
|
+
}
|
|
508
461
|
});
|
|
509
462
|
}
|
|
510
463
|
clearInput() {
|
|
@@ -524,6 +477,7 @@ export class Select {
|
|
|
524
477
|
onInputBlur(event) {
|
|
525
478
|
this.ixBlur.emit();
|
|
526
479
|
this.touched = true;
|
|
480
|
+
this.hasInputFocus = false;
|
|
527
481
|
if (this.editable) {
|
|
528
482
|
return;
|
|
529
483
|
}
|
|
@@ -535,6 +489,9 @@ export class Select {
|
|
|
535
489
|
target.value = this.selectedLabels.toString();
|
|
536
490
|
}
|
|
537
491
|
}
|
|
492
|
+
onInputFocus() {
|
|
493
|
+
this.hasInputFocus = true;
|
|
494
|
+
}
|
|
538
495
|
placeholderValue() {
|
|
539
496
|
if (this.disabled) {
|
|
540
497
|
return '';
|
|
@@ -556,18 +513,24 @@ export class Select {
|
|
|
556
513
|
return (this.selectedItems.length === this.items.length &&
|
|
557
514
|
this.collapseMultipleSelection);
|
|
558
515
|
}
|
|
516
|
+
getRemoveChipAriaLabel(item) {
|
|
517
|
+
const name = (item.label ?? item.value)?.toString().trim();
|
|
518
|
+
if (!name) {
|
|
519
|
+
return this.i18nRemoveSelectedItem;
|
|
520
|
+
}
|
|
521
|
+
return `${this.i18nRemoveSelectedItem} ${name}`;
|
|
522
|
+
}
|
|
559
523
|
renderAllChip() {
|
|
560
|
-
return (h("ix-filter-chip", { disabled: this.disabled || this.readonly, ariaLabelCloseIconButton: this.i18nAllSelected
|
|
524
|
+
return (h("ix-filter-chip", { disabled: this.disabled || this.readonly, ariaLabelCloseIconButton: `${this.i18nRemoveSelectedItem} ${this.i18nAllSelected}`, onCloseClick: (e) => {
|
|
561
525
|
e.preventDefault();
|
|
562
526
|
e.stopPropagation();
|
|
563
527
|
this.clear();
|
|
564
528
|
} }, `${this.i18nAllSelected} (${this.selectedItems.length})`));
|
|
565
529
|
}
|
|
566
530
|
renderChip(item) {
|
|
567
|
-
return (h("ix-filter-chip", { disabled: this.disabled || this.readonly, key: item.value, onCloseClick: (
|
|
568
|
-
e.preventDefault();
|
|
569
|
-
e.stopPropagation();
|
|
531
|
+
return (h("ix-filter-chip", { disabled: this.disabled || this.readonly, key: item.value, ariaLabelCloseIconButton: this.getRemoveChipAriaLabel(item), onCloseClick: () => {
|
|
570
532
|
this.itemClick(item.value);
|
|
533
|
+
this.inputElement?.focus();
|
|
571
534
|
} }, item.label));
|
|
572
535
|
}
|
|
573
536
|
onValidationChange({ isInvalid, isInvalidByRequired, isValid, isInfo, isWarning, }) {
|
|
@@ -607,50 +570,101 @@ export class Select {
|
|
|
607
570
|
isTouched() {
|
|
608
571
|
return Promise.resolve(this.touched);
|
|
609
572
|
}
|
|
573
|
+
getControllingAriaElement() {
|
|
574
|
+
return this.inputRef.waitForCurrent();
|
|
575
|
+
}
|
|
576
|
+
isAriaActiveDescendantActive() {
|
|
577
|
+
return this.dropdownShow;
|
|
578
|
+
}
|
|
579
|
+
getAriaActiveDescendantProxyItemId() {
|
|
580
|
+
return 'proxy-listbox-item';
|
|
581
|
+
}
|
|
582
|
+
componentWillRender() {
|
|
583
|
+
if (this.addItemElement) {
|
|
584
|
+
this.addItemElement.hidden = !this.isAddItemVisible();
|
|
585
|
+
this.addItemElement.label = this.inputFilterText;
|
|
586
|
+
}
|
|
587
|
+
this.updateAriaProxyListbox();
|
|
588
|
+
}
|
|
589
|
+
updateAriaProxyListbox() {
|
|
590
|
+
const ariaActiveDescendantHelper = this.hostElement.shadowRoot?.getElementById(`${this.hostId}-proxy-listbox`);
|
|
591
|
+
if (this.focusableItems.length === 0) {
|
|
592
|
+
return;
|
|
593
|
+
}
|
|
594
|
+
updateFocusProxyList(ariaActiveDescendantHelper, this.focusableItems, (item, proxyElement) => {
|
|
595
|
+
const isSelectItem = item.tagName === 'IX-SELECT-ITEM';
|
|
596
|
+
const ariaLabel = item.getAttribute('aria-label') ||
|
|
597
|
+
item.label ||
|
|
598
|
+
(isSelectItem ? item.value : '') ||
|
|
599
|
+
'';
|
|
600
|
+
const selected = isSelectItem
|
|
601
|
+
? item.selected
|
|
602
|
+
: item.checked;
|
|
603
|
+
proxyElement.role = 'option';
|
|
604
|
+
proxyElement.innerText = item.label ?? '';
|
|
605
|
+
proxyElement.ariaLabel = ariaLabel;
|
|
606
|
+
proxyElement.ariaSelected = a11yBoolean(!!selected);
|
|
607
|
+
// Forward clicks from the proxy element to the actual dropdown item
|
|
608
|
+
proxyElement.addEventListener('click', (event) => {
|
|
609
|
+
event.stopPropagation();
|
|
610
|
+
event.preventDefault();
|
|
611
|
+
item.click();
|
|
612
|
+
});
|
|
613
|
+
if (this.addItemElement === item) {
|
|
614
|
+
proxyElement.ariaLabel = `${this.ariaLabelAddItem}: ${item.label}`;
|
|
615
|
+
}
|
|
616
|
+
// Bad for building playwright selectors but necessary to ensure that assistive technologies
|
|
617
|
+
// can announce the items in the dropdown with their respective aria-labels
|
|
618
|
+
item.ariaHidden = 'true';
|
|
619
|
+
});
|
|
620
|
+
}
|
|
610
621
|
render() {
|
|
611
|
-
|
|
612
|
-
return (h(Host, { key: '44a92192a5bb2243e52b5dedfc6513b75e1762e6', "aria-disabled": a11yBoolean(this.disabled), class: {
|
|
622
|
+
return (h(Host, { key: 'cf11caa1c57e34844d376a74d5c534184d322380', id: this.getHostElementId(), class: {
|
|
613
623
|
readonly: this.readonly,
|
|
614
624
|
disabled: this.disabled,
|
|
615
|
-
|
|
625
|
+
'show-focus-outline': this.hasInputFocus && !this.dropdownItemsVisualFocused,
|
|
626
|
+
}, tabIndex: this.disabled ? -1 : 0 }, h("ix-field-wrapper", { key: 'b21d0e4a1e7f914893e9e2c1f4aff7e89ab4c066', required: this.required, label: this.label, helperText: this.helperText, invalidText: this.invalidText, infoText: this.infoText, warningText: this.warningText, validText: this.validText, showTextAsTooltip: this.showTextAsTooltip, isInvalid: this.isInvalid, isValid: this.isValid, isInfo: this.isInfo, isWarning: this.isWarning, controlRef: this.inputRef }, h("div", { key: '4f94efb21c4f1949ce6dad3ec8ba2664da2b3d9d', class: {
|
|
616
627
|
select: true,
|
|
617
628
|
disabled: this.disabled,
|
|
618
629
|
readonly: this.readonly,
|
|
619
630
|
}, ref: (ref) => {
|
|
620
631
|
this.dropdownAnchorRef(ref);
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
} }, h("div", { key: '3d64b588c5bf162777e6c76f7fbd252a6856f968', class: "input-container" }, h("div", { key: 'fc187195af89682f29494d779fabbb7fbf53c1d4', class: "chips" }, this.isMultipleMode &&
|
|
632
|
+
this.dropdownWrapperRef(ref);
|
|
633
|
+
} }, h("div", { key: '24d3ce5cab8107f69347917beca581dd71d6ba3a', class: "input-container" }, h("div", { key: '01adbf419c634fb8ccae19bc2dd4aa18a90553ae', class: "chips" }, this.isMultipleMode &&
|
|
624
634
|
this.items.length !== 0 &&
|
|
625
635
|
(this.shouldDisplayAllChip()
|
|
626
636
|
? this.renderAllChip()
|
|
627
|
-
:
|
|
628
|
-
'allow-clear': this.allowClear && !!
|
|
629
|
-
}, placeholder: this.placeholderValue(), value:
|
|
637
|
+
: this.selectedItems?.map((item) => this.renderChip(item))), h("div", { key: '9a8a9b3e4c57776d737e66fc836addaba9950cd3', class: "trigger" }, h("input", { key: '5f50f19cb0c6ab190535b2952d5e757548355124', id: `${this.hostId}-input`, role: "combobox", "aria-controls": `${this.hostId}-proxy-listbox`, "aria-expanded": a11yBoolean(this.dropdownShow), "aria-autocomplete": "list", "aria-disabled": a11yBoolean(this.disabled), autocomplete: "off", "data-testid": "input", disabled: this.disabled, readOnly: this.readonly, required: this.required, type: "text", class: {
|
|
638
|
+
'allow-clear': this.allowClear && !!this.selectedLabels?.length,
|
|
639
|
+
}, placeholder: this.placeholderValue(), value: this.inputValue ?? '', ref: (ref) => {
|
|
630
640
|
this.inputElement = ref;
|
|
631
641
|
this.inputRef(ref);
|
|
632
|
-
}, onBlur: (e) => this.onInputBlur(e),
|
|
633
|
-
this.navigationItem = undefined;
|
|
634
|
-
}, onInput: () => this.filterItemsWithTypeahead(), onKeyDown: (e) => this.onKeyDown(e) }), this.allowClear &&
|
|
642
|
+
}, onFocus: () => this.onInputFocus(), onBlur: (e) => this.onInputBlur(e), onInput: () => this.setItemFilter() }), this.allowClear &&
|
|
635
643
|
!this.disabled &&
|
|
636
644
|
!this.readonly &&
|
|
637
|
-
(
|
|
645
|
+
(this.selectedLabels?.length || this.inputFilterText) ? (h("ix-icon-button", { key: "clear", class: "clear", icon: iconClear, variant: "subtle-tertiary", oval: true, size: "16", onClick: (e) => {
|
|
638
646
|
e.preventDefault();
|
|
639
647
|
e.stopPropagation();
|
|
640
648
|
this.clear();
|
|
641
|
-
}, "aria-label": this.ariaLabelClearIconButton })) : null, this.disabled || this.readonly ? null : (h("ix-icon-button", { "
|
|
642
|
-
? iconChevronUpSmall
|
|
643
|
-
: iconChevronDownSmall, variant: "subtle-tertiary", ref: (ref) => {
|
|
644
|
-
if (this.editable)
|
|
645
|
-
this.dropdownWrapperRef(ref);
|
|
646
|
-
}, "aria-label": (_e = this.ariaLabelChevronDownIconButton) !== null && _e !== void 0 ? _e : (this.dropdownShow
|
|
649
|
+
}, "aria-label": this.ariaLabelClearIconButton })) : null, this.disabled || this.readonly ? null : (h("ix-icon-button", { "aria-label": this.dropdownShow
|
|
647
650
|
? 'Close select dropdown'
|
|
648
|
-
: 'Open select dropdown'
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
651
|
+
: 'Open select dropdown', "aria-hidden": "true", ref: (ref) => {
|
|
652
|
+
const element = ref;
|
|
653
|
+
// VDOM issue if tabIndex is provided via property <ix-icon-button tabIndex={-1}>
|
|
654
|
+
// the tabindex will be '0' after expanding the dropdown
|
|
655
|
+
element.tabIndex = -1;
|
|
656
|
+
element.ariaHidden = 'true';
|
|
657
|
+
}, "data-select-dropdown": true, key: "dropdown", class: { 'dropdown-visible': this.dropdownShow }, icon: this.dropdownShow
|
|
658
|
+
? iconChevronUpSmall
|
|
659
|
+
: iconChevronDownSmall, variant: "subtle-tertiary" }))))))), h("ix-dropdown", { key: '187d36c8fd120fffa047648a4ff8e8e9e1a444e3', id: `${this.hostId}-listbox`, keyboardActivationKeys: ['ArrowUp', 'ArrowDown'], keyboardItemTriggerKeys: ['Enter'], disableFocusTrap: true, focusHost: this.hostElement, ref: this.dropdownRef, show: this.dropdownShow, closeBehavior: this.isMultipleMode ? 'outside' : 'both', hidden: this.disabled || this.readonly, anchor: this.dropdownAnchorRef.waitForCurrent(), trigger: this.dropdownWrapperRef.waitForCurrent(), onShowChange: (event) => {
|
|
660
|
+
if ((this.disabled || this.readonly) && event.detail) {
|
|
661
|
+
event.preventDefault();
|
|
662
|
+
}
|
|
663
|
+
}, onShowChanged: (e) => this.dropdownVisibilityChanged(e), placement: "bottom-start", enableTopLayer: this.enableTopLayer, overwriteDropdownStyle: async () => {
|
|
652
664
|
const styleOverwrites = {};
|
|
653
|
-
const minWidth =
|
|
665
|
+
const minWidth = this.hostElement.shadowRoot
|
|
666
|
+
?.querySelector('.select')
|
|
667
|
+
?.getBoundingClientRect().width;
|
|
654
668
|
if (minWidth) {
|
|
655
669
|
styleOverwrites.minWidth = `${minWidth}px`;
|
|
656
670
|
}
|
|
@@ -661,23 +675,40 @@ export class Select {
|
|
|
661
675
|
styleOverwrites.maxWidth = `min(${this.dropdownMaxWidth}, 100%)`;
|
|
662
676
|
}
|
|
663
677
|
return styleOverwrites;
|
|
664
|
-
}
|
|
678
|
+
}, onClick: (event) => {
|
|
679
|
+
const target = event.target;
|
|
680
|
+
const isTargetElement = target.tagName === 'IX-DROPDOWN-ITEM' ||
|
|
681
|
+
target.tagName === 'IX-SELECT-ITEM';
|
|
682
|
+
if (!isTargetElement) {
|
|
683
|
+
return;
|
|
684
|
+
}
|
|
685
|
+
const activeVisualFocusedItem = this.getActiveVisualFocusedItem();
|
|
686
|
+
const item = activeVisualFocusedItem ?? target;
|
|
687
|
+
if (!item) {
|
|
688
|
+
return;
|
|
689
|
+
}
|
|
690
|
+
event.stopPropagation();
|
|
691
|
+
if (!item.classList.contains('add-item')) {
|
|
692
|
+
this.itemClick(item.value);
|
|
693
|
+
this.setItemFilter();
|
|
694
|
+
}
|
|
695
|
+
if (this.isSingleMode) {
|
|
696
|
+
this.dropdownShow = false;
|
|
697
|
+
}
|
|
698
|
+
} }, h("div", { key: 'c2e65bc3e1df99c75ca482ea229c5e35d13c45ed', "aria-hidden": "true", class: {
|
|
665
699
|
'select-list-header': true,
|
|
666
700
|
hidden: this.hideListHeader || this.isDropdownEmpty,
|
|
667
|
-
}, title: this.i18nSelectListHeader, onClick: (e) => e.preventDefault() }, this.i18nSelectListHeader), h("slot", { key: '
|
|
701
|
+
}, title: this.i18nSelectListHeader, onClick: (e) => e.preventDefault() }, this.i18nSelectListHeader), h("slot", { key: '404e34ea75f438e875cebc94fd87cc8aa0c217c5', onSlotchange: () => {
|
|
668
702
|
this.updateSelection();
|
|
669
|
-
} }), h(
|
|
670
|
-
'
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
this.emitAddItem(this.inputFilterText);
|
|
675
|
-
}, onFocus: () => (this.navigationItem = this.addItemElement), ref: (ref) => {
|
|
676
|
-
this.addItemElement = ref;
|
|
677
|
-
} })) : null, this.isDropdownEmpty && !this.editable ? (h("div", { class: "select-list-header" }, this.i18nNoMatches)) : (''))));
|
|
703
|
+
} }), h(FocusProxy, { key: '18274eb400e5947dce03156c500b0392d0a6d1b7', hostId: this.hostId, otherProps: {
|
|
704
|
+
'aria-hidden': a11yBoolean(!this.dropdownShow),
|
|
705
|
+
'aria-multiselectable': a11yBoolean(this.isMultipleMode),
|
|
706
|
+
hidden: this.disabled || this.readonly,
|
|
707
|
+
} }), this.isDropdownEmpty && !this.editable && (h("div", { key: '800629d019d4ba79cff9f91f904d47aef41d7c25', class: "select-list-header" }, this.i18nNoMatches)))));
|
|
678
708
|
}
|
|
679
709
|
static get is() { return "ix-select"; }
|
|
680
710
|
static get encapsulation() { return "shadow"; }
|
|
711
|
+
static get delegatesFocus() { return true; }
|
|
681
712
|
static get formAssociated() { return true; }
|
|
682
713
|
static get originalStyleUrls() {
|
|
683
714
|
return {
|
|
@@ -749,7 +780,7 @@ export class Select {
|
|
|
749
780
|
"reflect": false,
|
|
750
781
|
"attribute": "label"
|
|
751
782
|
},
|
|
752
|
-
"
|
|
783
|
+
"ariaLabelClearIconButton": {
|
|
753
784
|
"type": "string",
|
|
754
785
|
"mutable": false,
|
|
755
786
|
"complexType": {
|
|
@@ -764,35 +795,36 @@ export class Select {
|
|
|
764
795
|
"name": "since",
|
|
765
796
|
"text": "3.2.0"
|
|
766
797
|
}],
|
|
767
|
-
"text": "ARIA label for the
|
|
798
|
+
"text": "ARIA label for the clear icon button\nWill be set as aria-label on the nested HTML button element"
|
|
768
799
|
},
|
|
769
800
|
"getter": false,
|
|
770
801
|
"setter": false,
|
|
771
802
|
"reflect": false,
|
|
772
|
-
"attribute": "aria-label-
|
|
803
|
+
"attribute": "aria-label-clear-icon-button",
|
|
804
|
+
"defaultValue": "'Clear selection'"
|
|
773
805
|
},
|
|
774
|
-
"
|
|
806
|
+
"ariaLabelAddItem": {
|
|
775
807
|
"type": "string",
|
|
776
808
|
"mutable": false,
|
|
777
809
|
"complexType": {
|
|
778
810
|
"original": "string",
|
|
779
|
-
"resolved": "string
|
|
811
|
+
"resolved": "string",
|
|
780
812
|
"references": {}
|
|
781
813
|
},
|
|
782
814
|
"required": false,
|
|
783
|
-
"optional":
|
|
815
|
+
"optional": false,
|
|
784
816
|
"docs": {
|
|
785
817
|
"tags": [{
|
|
786
818
|
"name": "since",
|
|
787
|
-
"text": "
|
|
819
|
+
"text": "TODO: Define"
|
|
788
820
|
}],
|
|
789
|
-
"text": "ARIA label for the
|
|
821
|
+
"text": "ARIA label for the add item"
|
|
790
822
|
},
|
|
791
823
|
"getter": false,
|
|
792
824
|
"setter": false,
|
|
793
825
|
"reflect": false,
|
|
794
|
-
"attribute": "aria-label-
|
|
795
|
-
"defaultValue": "'
|
|
826
|
+
"attribute": "aria-label-add-item",
|
|
827
|
+
"defaultValue": "'Add item'"
|
|
796
828
|
},
|
|
797
829
|
"warningText": {
|
|
798
830
|
"type": "string",
|
|
@@ -1128,6 +1160,29 @@ export class Select {
|
|
|
1128
1160
|
"attribute": "i18n-all-selected",
|
|
1129
1161
|
"defaultValue": "'All'"
|
|
1130
1162
|
},
|
|
1163
|
+
"i18nRemoveSelectedItem": {
|
|
1164
|
+
"type": "string",
|
|
1165
|
+
"mutable": false,
|
|
1166
|
+
"complexType": {
|
|
1167
|
+
"original": "string",
|
|
1168
|
+
"resolved": "string",
|
|
1169
|
+
"references": {}
|
|
1170
|
+
},
|
|
1171
|
+
"required": false,
|
|
1172
|
+
"optional": false,
|
|
1173
|
+
"docs": {
|
|
1174
|
+
"tags": [{
|
|
1175
|
+
"name": "since",
|
|
1176
|
+
"text": "5.0.0"
|
|
1177
|
+
}],
|
|
1178
|
+
"text": "Prefix for the accessible name of the close control on a selected chip in multiple mode.\nThe chip label or value is appended (e.g. \"Remove Item 1\")."
|
|
1179
|
+
},
|
|
1180
|
+
"getter": false,
|
|
1181
|
+
"setter": false,
|
|
1182
|
+
"reflect": false,
|
|
1183
|
+
"attribute": "i18n-remove-selected-item",
|
|
1184
|
+
"defaultValue": "'Remove'"
|
|
1185
|
+
},
|
|
1131
1186
|
"hideListHeader": {
|
|
1132
1187
|
"type": "boolean",
|
|
1133
1188
|
"mutable": false,
|
|
@@ -1239,9 +1294,10 @@ export class Select {
|
|
|
1239
1294
|
"dropdownShow": {},
|
|
1240
1295
|
"selectedLabels": {},
|
|
1241
1296
|
"isDropdownEmpty": {},
|
|
1242
|
-
"navigationItem": {},
|
|
1243
1297
|
"inputFilterText": {},
|
|
1244
1298
|
"inputValue": {},
|
|
1299
|
+
"hasInputFocus": {},
|
|
1300
|
+
"dropdownItemsVisualFocused": {},
|
|
1245
1301
|
"isInvalid": {},
|
|
1246
1302
|
"isValid": {},
|
|
1247
1303
|
"isInfo": {},
|
|
@@ -1422,19 +1478,10 @@ export class Select {
|
|
|
1422
1478
|
return [{
|
|
1423
1479
|
"propName": "value",
|
|
1424
1480
|
"methodName": "watchValue"
|
|
1425
|
-
}, {
|
|
1426
|
-
"propName": "dropdownShow",
|
|
1427
|
-
"methodName": "watchDropdownShow"
|
|
1428
1481
|
}];
|
|
1429
1482
|
}
|
|
1430
1483
|
static get listeners() {
|
|
1431
1484
|
return [{
|
|
1432
|
-
"name": "itemClick",
|
|
1433
|
-
"method": "onItemClicked",
|
|
1434
|
-
"target": undefined,
|
|
1435
|
-
"capture": false,
|
|
1436
|
-
"passive": false
|
|
1437
|
-
}, {
|
|
1438
1485
|
"name": "ix-select-item:valueChange",
|
|
1439
1486
|
"method": "onLabelChange",
|
|
1440
1487
|
"target": undefined,
|
|
@@ -1450,9 +1497,6 @@ export class Select {
|
|
|
1450
1497
|
}
|
|
1451
1498
|
static get attachInternalsMemberName() { return "formInternals"; }
|
|
1452
1499
|
}
|
|
1453
|
-
__decorate([
|
|
1454
|
-
OnListener('keydown', (self) => self.dropdownShow)
|
|
1455
|
-
], Select.prototype, "onKeyDown", null);
|
|
1456
1500
|
__decorate([
|
|
1457
1501
|
HookValidationLifecycle()
|
|
1458
1502
|
], Select.prototype, "onValidationChange", null);
|