@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
|
@@ -16,19 +16,19 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
16
16
|
r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
17
17
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
18
18
|
};
|
|
19
|
-
import { h, Host, } from "@stencil/core";
|
|
19
|
+
import { h, Host, Mixin, } from "@stencil/core";
|
|
20
20
|
import { DateTime } from "luxon";
|
|
21
|
+
import { DefaultMixins } from "../utils/internal/component";
|
|
22
|
+
import { hasKeyboardMode } from "../utils/internal/mixins/setup.mixin";
|
|
21
23
|
import { OnListener } from "../utils/listener";
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
milliseconds: /\bS\b|SSS|u|uu|uuu/,
|
|
31
|
-
};
|
|
24
|
+
import { closestPassShadow } from "../utils/shadow-dom";
|
|
25
|
+
import { buildTimePickerColumnNumberArrays } from "./time-picker-column-values";
|
|
26
|
+
import { computeTimeWithRawUnitValue } from "./time-picker-compute-time";
|
|
27
|
+
import { getTimePickerConstraintBounds, hasActiveTimePickerConstraints, isWithinTimePickerConstraints, timeOfDayRangeIntersectsInclusiveBounds, } from "./time-picker-constraints";
|
|
28
|
+
import { formatTimePickerUnitValue, getTimePickerColumnSeparator, } from "./time-picker-display";
|
|
29
|
+
import { isFormat12Hour, LUXON_FORMAT_PATTERNS } from "./time-picker-format";
|
|
30
|
+
import { isSelectableForUnitWithinBounds } from "./time-picker-range";
|
|
31
|
+
import { findNextSelectableRingValue } from "./time-picker-step-focus";
|
|
32
32
|
const HOUR_INTERVAL_DEFAULT = 1;
|
|
33
33
|
const MINUTE_INTERVAL_DEFAULT = 1;
|
|
34
34
|
const SECOND_INTERVAL_DEFAULT = 1;
|
|
@@ -41,90 +41,17 @@ const FORMATTED_TIME_EMPTY = {
|
|
|
41
41
|
second: '',
|
|
42
42
|
millisecond: '',
|
|
43
43
|
};
|
|
44
|
-
export class TimePicker {
|
|
44
|
+
export class TimePicker extends Mixin(...DefaultMixins) {
|
|
45
45
|
constructor() {
|
|
46
|
-
|
|
47
|
-
* Format of time string.
|
|
48
|
-
* See {@link https://moment.github.io/luxon/#/formatting?id=table-of-tokens} for all available tokens.
|
|
49
|
-
* Note: Formats that combine date and time (like f or F) are not supported. Timestamp tokens x and X are not supported either.
|
|
50
|
-
*/
|
|
51
|
-
this.format = 'TT';
|
|
52
|
-
/**
|
|
53
|
-
* Corner style.
|
|
54
|
-
*/
|
|
55
|
-
this.corners = 'rounded';
|
|
56
|
-
/**
|
|
57
|
-
* Embedded style (for use in other components).
|
|
58
|
-
*/
|
|
59
|
-
this.embedded = false;
|
|
60
|
-
/**
|
|
61
|
-
* @internal Temporary prop needed until datetime-picker is reworked for new design.
|
|
62
|
-
*/
|
|
63
|
-
this.dateTimePickerAppearance = false;
|
|
64
|
-
/**
|
|
65
|
-
* Hides the header of the picker.
|
|
66
|
-
*
|
|
67
|
-
* @since 3.2.0
|
|
68
|
-
*/
|
|
69
|
-
this.hideHeader = false;
|
|
70
|
-
/**
|
|
71
|
-
* Interval for hour selection.
|
|
72
|
-
*
|
|
73
|
-
* @since 3.2.0
|
|
74
|
-
*/
|
|
75
|
-
this.hourInterval = HOUR_INTERVAL_DEFAULT;
|
|
76
|
-
/**
|
|
77
|
-
* Interval for minute selection.
|
|
78
|
-
*
|
|
79
|
-
* @since 3.2.0
|
|
80
|
-
*/
|
|
81
|
-
this.minuteInterval = MINUTE_INTERVAL_DEFAULT;
|
|
82
|
-
/**
|
|
83
|
-
* Interval for second selection.
|
|
84
|
-
*
|
|
85
|
-
* @since 3.2.0
|
|
86
|
-
*/
|
|
87
|
-
this.secondInterval = SECOND_INTERVAL_DEFAULT;
|
|
88
|
-
/**
|
|
89
|
-
* Interval for millisecond selection.
|
|
90
|
-
*
|
|
91
|
-
* @since 3.2.0
|
|
92
|
-
*/
|
|
93
|
-
this.millisecondInterval = MILLISECOND_INTERVAL_DEFAULT;
|
|
94
|
-
/**
|
|
95
|
-
* Text of the time confirm button.
|
|
96
|
-
*/
|
|
97
|
-
this.i18nConfirmTime = CONFIRM_BUTTON_DEFAULT;
|
|
98
|
-
/**
|
|
99
|
-
* Text for the top header.
|
|
100
|
-
*/
|
|
101
|
-
this.i18nHeader = HEADER_DEFAULT;
|
|
102
|
-
/**
|
|
103
|
-
* Text for the hour column header.
|
|
104
|
-
*/
|
|
105
|
-
this.i18nHourColumnHeader = 'hr';
|
|
106
|
-
/**
|
|
107
|
-
* Text for the minute column header.
|
|
108
|
-
*/
|
|
109
|
-
// eslint-disable-next-line @stencil-community/decorators-style
|
|
110
|
-
this.i18nMinuteColumnHeader = 'min';
|
|
111
|
-
/**
|
|
112
|
-
* Text for the second column header.
|
|
113
|
-
*/
|
|
114
|
-
// eslint-disable-next-line @stencil-community/decorators-style
|
|
115
|
-
this.i18nSecondColumnHeader = 'sec';
|
|
116
|
-
/**
|
|
117
|
-
* Text for the millisecond column header.
|
|
118
|
-
*/
|
|
119
|
-
// eslint-disable-next-line @stencil-community/decorators-style
|
|
120
|
-
this.i18nMillisecondColumnHeader = 'ms';
|
|
121
|
-
this.formattedTime = FORMATTED_TIME_EMPTY;
|
|
122
|
-
this.timePickerDescriptors = [];
|
|
123
|
-
this.isUnitFocused = false;
|
|
124
|
-
this.focusedUnit = 'hour';
|
|
125
|
-
this.focusedValue = 0;
|
|
126
|
-
this.focusScrollAlignment = 'start';
|
|
46
|
+
super();
|
|
127
47
|
}
|
|
48
|
+
hostElement;
|
|
49
|
+
/**
|
|
50
|
+
* Format of time string.
|
|
51
|
+
* See {@link https://moment.github.io/luxon/#/formatting?id=table-of-tokens} for all available tokens.
|
|
52
|
+
* Note: Formats that combine date and time (like f or F) are not supported. Timestamp tokens x and X are not supported either.
|
|
53
|
+
*/
|
|
54
|
+
format = 'TT';
|
|
128
55
|
watchFormatIntervalPropHandler(newValue) {
|
|
129
56
|
if (!newValue) {
|
|
130
57
|
return;
|
|
@@ -132,6 +59,30 @@ export class TimePicker {
|
|
|
132
59
|
this.initPicker();
|
|
133
60
|
this.updateScrollPositions();
|
|
134
61
|
}
|
|
62
|
+
/**
|
|
63
|
+
* Corner style.
|
|
64
|
+
*/
|
|
65
|
+
corners = 'rounded';
|
|
66
|
+
/**
|
|
67
|
+
* Embedded style (for use in other components).
|
|
68
|
+
*/
|
|
69
|
+
embedded = false;
|
|
70
|
+
/**
|
|
71
|
+
* @internal Temporary prop needed until datetime-picker is reworked for new design.
|
|
72
|
+
*/
|
|
73
|
+
dateTimePickerAppearance = false;
|
|
74
|
+
/**
|
|
75
|
+
* Hides the header of the picker.
|
|
76
|
+
*
|
|
77
|
+
* @since 3.2.0
|
|
78
|
+
*/
|
|
79
|
+
hideHeader = false;
|
|
80
|
+
/**
|
|
81
|
+
* Interval for hour selection.
|
|
82
|
+
*
|
|
83
|
+
* @since 3.2.0
|
|
84
|
+
*/
|
|
85
|
+
hourInterval = HOUR_INTERVAL_DEFAULT;
|
|
135
86
|
watchHourIntervalPropHandler(newValue) {
|
|
136
87
|
if (Number.isInteger(newValue) &&
|
|
137
88
|
newValue >= 0 &&
|
|
@@ -142,6 +93,12 @@ export class TimePicker {
|
|
|
142
93
|
this.printIntervalError('hour', newValue);
|
|
143
94
|
this.hourInterval = HOUR_INTERVAL_DEFAULT;
|
|
144
95
|
}
|
|
96
|
+
/**
|
|
97
|
+
* Interval for minute selection.
|
|
98
|
+
*
|
|
99
|
+
* @since 3.2.0
|
|
100
|
+
*/
|
|
101
|
+
minuteInterval = MINUTE_INTERVAL_DEFAULT;
|
|
145
102
|
watchMinuteIntervalPropHandler(newValue) {
|
|
146
103
|
if (newValue >= 0 && newValue <= 59) {
|
|
147
104
|
this.setTimePickerDescriptors();
|
|
@@ -150,6 +107,12 @@ export class TimePicker {
|
|
|
150
107
|
this.printIntervalError('minute', newValue);
|
|
151
108
|
this.minuteInterval = MINUTE_INTERVAL_DEFAULT;
|
|
152
109
|
}
|
|
110
|
+
/**
|
|
111
|
+
* Interval for second selection.
|
|
112
|
+
*
|
|
113
|
+
* @since 3.2.0
|
|
114
|
+
*/
|
|
115
|
+
secondInterval = SECOND_INTERVAL_DEFAULT;
|
|
153
116
|
watchSecondIntervalPropHandler(newValue) {
|
|
154
117
|
if (newValue >= 0 && newValue <= 59) {
|
|
155
118
|
this.setTimePickerDescriptors();
|
|
@@ -158,6 +121,12 @@ export class TimePicker {
|
|
|
158
121
|
this.printIntervalError('second', newValue);
|
|
159
122
|
this.secondInterval = SECOND_INTERVAL_DEFAULT;
|
|
160
123
|
}
|
|
124
|
+
/**
|
|
125
|
+
* Interval for millisecond selection.
|
|
126
|
+
*
|
|
127
|
+
* @since 3.2.0
|
|
128
|
+
*/
|
|
129
|
+
millisecondInterval = MILLISECOND_INTERVAL_DEFAULT;
|
|
161
130
|
watchMillisecondIntervalPropHandler(newValue) {
|
|
162
131
|
if (newValue >= 0 && newValue <= 999) {
|
|
163
132
|
this.setTimePickerDescriptors();
|
|
@@ -169,13 +138,79 @@ export class TimePicker {
|
|
|
169
138
|
printIntervalError(intervalName, value) {
|
|
170
139
|
console.error(`Value ${value} is not valid for ${intervalName}-interval. Falling back to default.`);
|
|
171
140
|
}
|
|
141
|
+
warnIfConstraintTimeInvalid(prop, value, omitUnparsableWarning) {
|
|
142
|
+
const trimmed = value?.trim();
|
|
143
|
+
if (!trimmed) {
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
const parsed = DateTime.fromFormat(trimmed, this.format);
|
|
147
|
+
if (parsed.isValid) {
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
if (omitUnparsableWarning) {
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
const detail = [parsed.invalidReason, parsed.invalidExplanation]
|
|
154
|
+
.filter(Boolean)
|
|
155
|
+
.join(': ');
|
|
156
|
+
console.warn(`[ix-time-picker] ${prop}="${trimmed}" does not match format "${this.format}". ` +
|
|
157
|
+
'The constraint is ignored until the value matches `format`.' +
|
|
158
|
+
(detail ? ` (${detail})` : ''));
|
|
159
|
+
}
|
|
160
|
+
warnIfConstraintRangeInverted(minValue, maxValue) {
|
|
161
|
+
const minTrimmed = minValue?.trim();
|
|
162
|
+
const maxTrimmed = maxValue?.trim();
|
|
163
|
+
if (!minTrimmed || !maxTrimmed) {
|
|
164
|
+
return;
|
|
165
|
+
}
|
|
166
|
+
const minParsed = DateTime.fromFormat(minTrimmed, this.format);
|
|
167
|
+
const maxParsed = DateTime.fromFormat(maxTrimmed, this.format);
|
|
168
|
+
if (!minParsed.isValid || !maxParsed.isValid) {
|
|
169
|
+
return;
|
|
170
|
+
}
|
|
171
|
+
if (minParsed > maxParsed) {
|
|
172
|
+
console.warn(`[ix-time-picker] minTime="${minTrimmed}" is later than maxTime="${maxTrimmed}" for format "${this.format}". ` +
|
|
173
|
+
'Both constraints are ignored.');
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
warnConstraintTimesIfInvalid(options) {
|
|
177
|
+
const omit = options?.omitUnparsableConstraintWarnings ?? false;
|
|
178
|
+
this.warnIfConstraintTimeInvalid('minTime', this.minTime, omit);
|
|
179
|
+
this.warnIfConstraintTimeInvalid('maxTime', this.maxTime, omit);
|
|
180
|
+
this.warnIfConstraintRangeInverted(this.minTime, this.maxTime);
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* Selected time value.
|
|
184
|
+
* Format has to match the `format` property.
|
|
185
|
+
*/
|
|
186
|
+
time;
|
|
172
187
|
watchTimePropHandler(newValue) {
|
|
188
|
+
if (newValue === undefined || newValue === '') {
|
|
189
|
+
this._time = this.getDefaultTime();
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
173
192
|
const timeFormat = DateTime.fromFormat(newValue, this.format);
|
|
174
193
|
if (!timeFormat.isValid) {
|
|
175
194
|
throw new Error('Format is not supported or not correct');
|
|
176
195
|
}
|
|
177
196
|
this._time = timeFormat;
|
|
178
197
|
}
|
|
198
|
+
/** Earliest selectable time (`format` tokens). Invalid non-empty values are ignored.
|
|
199
|
+
*
|
|
200
|
+
* @since 5.0.0 */
|
|
201
|
+
minTime;
|
|
202
|
+
/** Latest selectable time (`format` tokens). Invalid non-empty values are ignored.
|
|
203
|
+
*
|
|
204
|
+
* @since 5.0.0 */
|
|
205
|
+
maxTime;
|
|
206
|
+
watchMinTimePropHandler() {
|
|
207
|
+
this.warnConstraintTimesIfInvalid();
|
|
208
|
+
this.syncKeyboardFocusWithConstraints();
|
|
209
|
+
}
|
|
210
|
+
watchMaxTimePropHandler() {
|
|
211
|
+
this.warnConstraintTimesIfInvalid();
|
|
212
|
+
this.syncKeyboardFocusWithConstraints();
|
|
213
|
+
}
|
|
179
214
|
/**
|
|
180
215
|
* Get default time value
|
|
181
216
|
* @returns DateTime.now() for empty state (no selection)
|
|
@@ -183,27 +218,72 @@ export class TimePicker {
|
|
|
183
218
|
getDefaultTime() {
|
|
184
219
|
return DateTime.now();
|
|
185
220
|
}
|
|
221
|
+
/**
|
|
222
|
+
* Text of the time confirm button.
|
|
223
|
+
*/
|
|
224
|
+
i18nConfirmTime = CONFIRM_BUTTON_DEFAULT;
|
|
225
|
+
/**
|
|
226
|
+
* Text for the top header.
|
|
227
|
+
*/
|
|
228
|
+
i18nHeader = HEADER_DEFAULT;
|
|
229
|
+
/**
|
|
230
|
+
* Text for the hour column header.
|
|
231
|
+
*/
|
|
232
|
+
i18nHourColumnHeader = 'hr';
|
|
233
|
+
/**
|
|
234
|
+
* Text for the minute column header.
|
|
235
|
+
*/
|
|
236
|
+
// eslint-disable-next-line @stencil-community/decorators-style
|
|
237
|
+
i18nMinuteColumnHeader = 'min';
|
|
238
|
+
/**
|
|
239
|
+
* Text for the second column header.
|
|
240
|
+
*/
|
|
241
|
+
// eslint-disable-next-line @stencil-community/decorators-style
|
|
242
|
+
i18nSecondColumnHeader = 'sec';
|
|
243
|
+
/**
|
|
244
|
+
* Text for the millisecond column header.
|
|
245
|
+
*/
|
|
246
|
+
// eslint-disable-next-line @stencil-community/decorators-style
|
|
247
|
+
i18nMillisecondColumnHeader = 'ms';
|
|
248
|
+
/**
|
|
249
|
+
* Time event. Emitted when the user confirms the selected time.
|
|
250
|
+
*/
|
|
251
|
+
timeSelect;
|
|
252
|
+
/**
|
|
253
|
+
* Time change event. Emitted when the selected time changes while interacting with the picker.
|
|
254
|
+
*/
|
|
255
|
+
timeChange;
|
|
186
256
|
/**
|
|
187
257
|
* Get the current time based on the wanted format
|
|
188
258
|
*/
|
|
189
259
|
async getCurrentTime() {
|
|
190
|
-
|
|
191
|
-
return (_a = this._time) === null || _a === void 0 ? void 0 : _a.toFormat(this.format);
|
|
260
|
+
return this._time?.toFormat(this.format);
|
|
192
261
|
}
|
|
262
|
+
_time;
|
|
193
263
|
onTimeChange() {
|
|
194
264
|
const formattedTimeOld = this.formattedTime;
|
|
195
265
|
this.setTimeRef();
|
|
196
266
|
this.formattedTime = this.getFormattedTime();
|
|
197
267
|
this.updateScrollPositions(formattedTimeOld);
|
|
198
268
|
}
|
|
269
|
+
timeRef;
|
|
270
|
+
formattedTime = FORMATTED_TIME_EMPTY;
|
|
271
|
+
timePickerDescriptors = [];
|
|
272
|
+
isUnitFocused = false;
|
|
273
|
+
focusedUnit = 'hour';
|
|
274
|
+
focusedValue = 0;
|
|
275
|
+
visibilityObserver;
|
|
276
|
+
focusScrollAlignment = 'start';
|
|
199
277
|
componentWillLoad() {
|
|
200
278
|
this.initPicker();
|
|
201
279
|
}
|
|
202
280
|
initPicker() {
|
|
203
281
|
let parsedTime;
|
|
282
|
+
let timePropDoesNotMatchFormat = false;
|
|
204
283
|
if (this.time) {
|
|
205
284
|
parsedTime = DateTime.fromFormat(this.time, this.format);
|
|
206
285
|
if (!parsedTime.isValid) {
|
|
286
|
+
timePropDoesNotMatchFormat = true;
|
|
207
287
|
console.error(`Invalid time format. The configured format does not match the format of the passed time. ${parsedTime.invalidReason}: ${parsedTime.invalidExplanation}`);
|
|
208
288
|
parsedTime = this.getDefaultTime();
|
|
209
289
|
}
|
|
@@ -213,28 +293,40 @@ export class TimePicker {
|
|
|
213
293
|
}
|
|
214
294
|
this._time = parsedTime;
|
|
215
295
|
this.setTimeRef();
|
|
296
|
+
this.formattedTime = this.getFormattedTime();
|
|
216
297
|
this.setTimePickerDescriptors();
|
|
217
298
|
this.setInitialFocusedValueAndUnit();
|
|
218
299
|
this.watchHourIntervalPropHandler(this.hourInterval);
|
|
219
300
|
this.watchMinuteIntervalPropHandler(this.minuteInterval);
|
|
220
301
|
this.watchSecondIntervalPropHandler(this.secondInterval);
|
|
221
302
|
this.watchMillisecondIntervalPropHandler(this.millisecondInterval);
|
|
303
|
+
this.warnConstraintTimesIfInvalid({
|
|
304
|
+
omitUnparsableConstraintWarnings: timePropDoesNotMatchFormat,
|
|
305
|
+
});
|
|
222
306
|
}
|
|
223
307
|
componentDidLoad() {
|
|
308
|
+
super.componentDidLoad?.();
|
|
224
309
|
this.updateScrollPositions();
|
|
225
310
|
this.setupVisibilityObserver();
|
|
226
311
|
}
|
|
227
312
|
componentDidRender() {
|
|
228
|
-
if (this.isUnitFocused) {
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
313
|
+
if (!this.isUnitFocused) {
|
|
314
|
+
return;
|
|
315
|
+
}
|
|
316
|
+
const elementContainer = this.getElementContainer(this.focusedUnit, this.focusedValue);
|
|
317
|
+
const elementList = this.getElementList(this.focusedUnit);
|
|
318
|
+
if (!elementContainer) {
|
|
319
|
+
return;
|
|
320
|
+
}
|
|
321
|
+
if (hasKeyboardMode()) {
|
|
322
|
+
const active = this.hostElement.shadowRoot?.activeElement;
|
|
323
|
+
if (active !== elementContainer) {
|
|
232
324
|
elementContainer.focus({ preventScroll: true });
|
|
233
|
-
if (!this.isElementVisible(elementContainer, elementList)) {
|
|
234
|
-
this.scrollElementIntoView(elementContainer, elementList, this.focusScrollAlignment);
|
|
235
|
-
}
|
|
236
325
|
}
|
|
237
326
|
}
|
|
327
|
+
if (!this.isElementVisible(elementContainer, elementList)) {
|
|
328
|
+
this.scrollElementIntoView(elementContainer, elementList, this.focusScrollAlignment);
|
|
329
|
+
}
|
|
238
330
|
}
|
|
239
331
|
disconnectedCallback() {
|
|
240
332
|
if (this.visibilityObserver) {
|
|
@@ -245,44 +337,29 @@ export class TimePicker {
|
|
|
245
337
|
if (!this.isUnitFocused) {
|
|
246
338
|
return;
|
|
247
339
|
}
|
|
248
|
-
let newValue = this.focusedValue;
|
|
249
340
|
let shouldPreventDefault = true;
|
|
250
|
-
let newValueInterval;
|
|
251
|
-
switch (this.focusedUnit) {
|
|
252
|
-
case 'hour':
|
|
253
|
-
newValueInterval = this.hourInterval;
|
|
254
|
-
break;
|
|
255
|
-
case 'minute':
|
|
256
|
-
newValueInterval = this.minuteInterval;
|
|
257
|
-
break;
|
|
258
|
-
case 'second':
|
|
259
|
-
newValueInterval = this.secondInterval;
|
|
260
|
-
break;
|
|
261
|
-
case 'millisecond':
|
|
262
|
-
newValueInterval = this.millisecondInterval;
|
|
263
|
-
break;
|
|
264
|
-
}
|
|
265
341
|
switch (event.key) {
|
|
266
342
|
case 'Tab':
|
|
267
343
|
shouldPreventDefault = false;
|
|
268
344
|
this.isUnitFocused = false;
|
|
269
345
|
break;
|
|
270
346
|
case 'ArrowUp':
|
|
271
|
-
newValue -= newValueInterval;
|
|
272
347
|
this.focusScrollAlignment = 'start';
|
|
273
|
-
this.
|
|
274
|
-
this.updateDescriptorFocusedValue(this.focusedUnit, this.focusedValue);
|
|
348
|
+
this.stepFocusedValue(-1);
|
|
275
349
|
break;
|
|
276
350
|
case 'ArrowDown':
|
|
277
|
-
newValue += newValueInterval;
|
|
278
351
|
this.focusScrollAlignment = 'end';
|
|
279
|
-
this.
|
|
280
|
-
this.updateDescriptorFocusedValue(this.focusedUnit, this.focusedValue);
|
|
352
|
+
this.stepFocusedValue(1);
|
|
281
353
|
break;
|
|
282
354
|
case 'Enter':
|
|
283
|
-
case ' ':
|
|
284
|
-
this.
|
|
355
|
+
case ' ': {
|
|
356
|
+
const { bounds } = this.getUnitSelectionContext();
|
|
357
|
+
const base = this.buildCandidateBaseBeforeUnit(this.focusedUnit);
|
|
358
|
+
if (this.canSelectUnitValue(this.focusedUnit, this.focusedValue, bounds, base)) {
|
|
359
|
+
this.select(this.focusedUnit, this.focusedValue);
|
|
360
|
+
}
|
|
285
361
|
break;
|
|
362
|
+
}
|
|
286
363
|
default:
|
|
287
364
|
return;
|
|
288
365
|
}
|
|
@@ -291,17 +368,22 @@ export class TimePicker {
|
|
|
291
368
|
}
|
|
292
369
|
}
|
|
293
370
|
onUnitCellBlur(unit, event) {
|
|
294
|
-
var _a;
|
|
295
371
|
const relatedTarget = event.relatedTarget;
|
|
372
|
+
const relatedUnit = relatedTarget?.dataset?.elementContainerId?.split('-')[0];
|
|
373
|
+
const movingWithinSameColumn = relatedUnit === unit;
|
|
296
374
|
// Check if column lost focus to scroll back to selected value
|
|
297
|
-
if (relatedTarget) {
|
|
298
|
-
const relatedUnit = (_a = relatedTarget.dataset.elementContainerId) === null || _a === void 0 ? void 0 : _a.split('-')[0];
|
|
375
|
+
if (relatedTarget && !movingWithinSameColumn) {
|
|
299
376
|
if (relatedUnit !== unit) {
|
|
300
377
|
this.elementListScrollToTop(unit, Number(this.formattedTime[unit]), 'smooth');
|
|
301
378
|
}
|
|
302
379
|
}
|
|
380
|
+
// Still within this column (e.g. roving focus between cells)
|
|
381
|
+
if (movingWithinSameColumn) {
|
|
382
|
+
return;
|
|
383
|
+
}
|
|
303
384
|
this.isUnitFocused = false;
|
|
304
|
-
const focusedValue =
|
|
385
|
+
const focusedValue = this.resolvePreservedFocusedValueOnColumnBlur(unit);
|
|
386
|
+
this.focusedValue = focusedValue;
|
|
305
387
|
this.updateDescriptorFocusedValue(unit, focusedValue);
|
|
306
388
|
}
|
|
307
389
|
onUnitCellFocus(unit, value) {
|
|
@@ -311,12 +393,10 @@ export class TimePicker {
|
|
|
311
393
|
this.updateDescriptorFocusedValue(unit, value);
|
|
312
394
|
}
|
|
313
395
|
getElementList(unit) {
|
|
314
|
-
|
|
315
|
-
return (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`[data-element-list-id="${unit}"]`);
|
|
396
|
+
return this.hostElement.shadowRoot?.querySelector(`[data-element-list-id="${unit}"]`);
|
|
316
397
|
}
|
|
317
398
|
getElementContainer(unit, number) {
|
|
318
|
-
|
|
319
|
-
return (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`[data-element-container-id="${unit}-${number}"]`);
|
|
399
|
+
return this.hostElement.shadowRoot?.querySelector(`[data-element-container-id="${unit}-${number}"]`);
|
|
320
400
|
}
|
|
321
401
|
isElementVisible(element, container) {
|
|
322
402
|
const elementRect = element.getBoundingClientRect();
|
|
@@ -337,42 +417,21 @@ export class TimePicker {
|
|
|
337
417
|
elementRect.top - containerRect.top - SCROLL_BUFFER;
|
|
338
418
|
}
|
|
339
419
|
}
|
|
340
|
-
updateFocusedValue(value) {
|
|
341
|
-
const numberArray = this.getNumberArrayForUnit(this.focusedUnit);
|
|
342
|
-
const maxValue = numberArray[numberArray.length - 1];
|
|
343
|
-
const minValue = numberArray[0];
|
|
344
|
-
if (value > maxValue) {
|
|
345
|
-
value = minValue;
|
|
346
|
-
this.focusScrollAlignment = 'start';
|
|
347
|
-
}
|
|
348
|
-
else if (value < minValue) {
|
|
349
|
-
value = maxValue;
|
|
350
|
-
this.focusScrollAlignment = 'end';
|
|
351
|
-
}
|
|
352
|
-
this.focusedValue = value;
|
|
353
|
-
}
|
|
354
420
|
setInitialFocusedValueAndUnit() {
|
|
355
421
|
const firstVisibleDescriptor = this.timePickerDescriptors.find((descriptor) => !descriptor.hidden);
|
|
356
422
|
if (!firstVisibleDescriptor) {
|
|
357
423
|
return;
|
|
358
424
|
}
|
|
359
|
-
|
|
360
|
-
const isValidSelection = firstVisibleDescriptor.numberArray.includes(selectedValue);
|
|
361
|
-
this.focusedValue = isValidSelection
|
|
362
|
-
? selectedValue
|
|
363
|
-
: firstVisibleDescriptor.numberArray[0];
|
|
425
|
+
this.focusedValue = this.getConstrainedFocusedValueForUnit(firstVisibleDescriptor.unit, firstVisibleDescriptor.numberArray);
|
|
364
426
|
this.focusedUnit = firstVisibleDescriptor.unit;
|
|
365
427
|
}
|
|
366
428
|
setupVisibilityObserver() {
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
dropdownElement = dropdownElement.parentElement;
|
|
370
|
-
}
|
|
371
|
-
if (!dropdownElement) {
|
|
429
|
+
const dropdown = closestPassShadow(this.hostElement, 'ix-dropdown');
|
|
430
|
+
if (!dropdown) {
|
|
372
431
|
return;
|
|
373
432
|
}
|
|
374
433
|
this.visibilityObserver = new MutationObserver((mutations) => this.mutationObserverCallback(mutations));
|
|
375
|
-
this.visibilityObserver.observe(
|
|
434
|
+
this.visibilityObserver.observe(dropdown, {
|
|
376
435
|
attributes: true,
|
|
377
436
|
attributeFilter: ['class', 'style'],
|
|
378
437
|
});
|
|
@@ -402,8 +461,7 @@ export class TimePicker {
|
|
|
402
461
|
}
|
|
403
462
|
}
|
|
404
463
|
areElementsRendered() {
|
|
405
|
-
|
|
406
|
-
const elementLists = (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('.element-list');
|
|
464
|
+
const elementLists = this.hostElement.shadowRoot?.querySelectorAll('.element-list');
|
|
407
465
|
if (!elementLists || elementLists.length === 0) {
|
|
408
466
|
return false;
|
|
409
467
|
}
|
|
@@ -422,33 +480,6 @@ export class TimePicker {
|
|
|
422
480
|
millisecond: this._time.toFormat('S'),
|
|
423
481
|
};
|
|
424
482
|
}
|
|
425
|
-
timeUpdate(unit, value) {
|
|
426
|
-
let maxValue = DateTime.now().endOf('day').get(unit);
|
|
427
|
-
if (unit === 'hour') {
|
|
428
|
-
if (this.timeRef === 'PM') {
|
|
429
|
-
// 12 PM should remain 12, other PM hours add 12
|
|
430
|
-
value = value === 12 ? 12 : value + 12;
|
|
431
|
-
}
|
|
432
|
-
else if (this.timeRef === 'AM') {
|
|
433
|
-
// 12 AM should be 0, other AM hours remain as is
|
|
434
|
-
value = value === 12 ? 0 : value;
|
|
435
|
-
maxValue = 12;
|
|
436
|
-
}
|
|
437
|
-
}
|
|
438
|
-
if (value > maxValue) {
|
|
439
|
-
value = maxValue;
|
|
440
|
-
}
|
|
441
|
-
else if (value < 0) {
|
|
442
|
-
value = 0;
|
|
443
|
-
}
|
|
444
|
-
if (!this._time) {
|
|
445
|
-
this._time = DateTime.now().startOf('day');
|
|
446
|
-
}
|
|
447
|
-
this._time = this._time.set({
|
|
448
|
-
[unit]: value,
|
|
449
|
-
});
|
|
450
|
-
return value;
|
|
451
|
-
}
|
|
452
483
|
changeTimeReference(newTimeRef) {
|
|
453
484
|
if (this.timeRef === newTimeRef) {
|
|
454
485
|
return;
|
|
@@ -456,6 +487,8 @@ export class TimePicker {
|
|
|
456
487
|
if (!this._time) {
|
|
457
488
|
this._time = DateTime.now().startOf('day');
|
|
458
489
|
}
|
|
490
|
+
const previousTime = this._time;
|
|
491
|
+
const previousRef = this.timeRef;
|
|
459
492
|
this.timeRef = newTimeRef;
|
|
460
493
|
const currentHour = this._time.hour;
|
|
461
494
|
if (newTimeRef === 'PM' && currentHour < 12) {
|
|
@@ -464,83 +497,256 @@ export class TimePicker {
|
|
|
464
497
|
else if (newTimeRef === 'AM' && currentHour >= 12) {
|
|
465
498
|
this._time = this._time.minus({ hours: 12 });
|
|
466
499
|
}
|
|
500
|
+
if (!this.isWithinTimeConstraints(this._time)) {
|
|
501
|
+
this._time = previousTime;
|
|
502
|
+
this.timeRef = previousRef;
|
|
503
|
+
return;
|
|
504
|
+
}
|
|
467
505
|
this.timeChange.emit(this._time.toFormat(this.format));
|
|
468
506
|
}
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
507
|
+
/** `_time` or “now” (constraints, AM/PM, confirm). */
|
|
508
|
+
referenceOrNow() {
|
|
509
|
+
return this._time ?? DateTime.now();
|
|
510
|
+
}
|
|
511
|
+
setTimeRef() {
|
|
512
|
+
const uses12HourFormat = isFormat12Hour(this.format);
|
|
513
|
+
if (!uses12HourFormat) {
|
|
514
|
+
this.timeRef = undefined;
|
|
515
|
+
return;
|
|
516
|
+
}
|
|
517
|
+
const clock = this.referenceOrNow();
|
|
518
|
+
this.timeRef = clock.hour >= 12 ? 'PM' : 'AM';
|
|
519
|
+
}
|
|
520
|
+
getConstraintBounds(referenceClock) {
|
|
521
|
+
const baseDay = (referenceClock ?? this.referenceOrNow()).startOf('day');
|
|
522
|
+
return getTimePickerConstraintBounds(this.minTime, this.maxTime, this.format, baseDay);
|
|
523
|
+
}
|
|
524
|
+
/** Bounds and `selectionBase` from {@link referenceOrNow}. */
|
|
525
|
+
getUnitSelectionContext() {
|
|
526
|
+
const referenceClock = this.referenceOrNow();
|
|
527
|
+
return {
|
|
528
|
+
bounds: this.getConstraintBounds(referenceClock),
|
|
529
|
+
selectionBase: this._time ?? referenceClock.startOf('day'),
|
|
530
|
+
};
|
|
531
|
+
}
|
|
532
|
+
isWithinTimeConstraints(candidate) {
|
|
533
|
+
const { min, max } = this.getConstraintBounds();
|
|
534
|
+
return isWithinTimePickerConstraints(candidate, min, max);
|
|
535
|
+
}
|
|
536
|
+
canSelectUnitValue(unit, rawValue, bounds, selectionBase) {
|
|
537
|
+
const base = selectionBase ?? this._time ?? DateTime.now().startOf('day');
|
|
538
|
+
const effectiveBounds = bounds ?? this.getConstraintBounds();
|
|
539
|
+
if (unit === 'hour' &&
|
|
540
|
+
hasActiveTimePickerConstraints(effectiveBounds.min, effectiveBounds.max)) {
|
|
541
|
+
const dayStart = base.startOf('day');
|
|
542
|
+
const hourStart = computeTimeWithRawUnitValue(dayStart, 'hour', rawValue, this.timeRef);
|
|
543
|
+
if (!hourStart) {
|
|
544
|
+
return false;
|
|
545
|
+
}
|
|
546
|
+
const hourEnd = hourStart.set({
|
|
547
|
+
minute: 59,
|
|
548
|
+
second: 59,
|
|
549
|
+
millisecond: 999,
|
|
550
|
+
});
|
|
551
|
+
return timeOfDayRangeIntersectsInclusiveBounds(hourStart, hourEnd, effectiveBounds.min, effectiveBounds.max);
|
|
552
|
+
}
|
|
553
|
+
const candidate = computeTimeWithRawUnitValue(base, unit, rawValue, this.timeRef);
|
|
554
|
+
if (!candidate) {
|
|
555
|
+
return false;
|
|
556
|
+
}
|
|
557
|
+
if (bounds) {
|
|
558
|
+
return this.isSelectableForUnitWithinBounds(unit, candidate, bounds);
|
|
559
|
+
}
|
|
560
|
+
return this.isWithinTimeConstraints(candidate);
|
|
561
|
+
}
|
|
562
|
+
isSelectableForUnitWithinBounds(unit, candidate, bounds) {
|
|
563
|
+
return isSelectableForUnitWithinBounds(unit, candidate, bounds);
|
|
564
|
+
}
|
|
565
|
+
/** Provisional `unit` for cross-column base: roving cell, earlier descriptors, else displayed digits. */
|
|
566
|
+
getProvisionalRawValue(unit) {
|
|
567
|
+
if (this.focusedUnit === unit) {
|
|
568
|
+
return this.focusedValue;
|
|
569
|
+
}
|
|
570
|
+
const order = this.timePickerDescriptors.map((d) => d.unit);
|
|
571
|
+
const iFocused = order.indexOf(this.focusedUnit);
|
|
572
|
+
const iUnit = order.indexOf(unit);
|
|
573
|
+
if (iUnit !== -1 && iFocused !== -1 && iUnit < iFocused) {
|
|
574
|
+
const d = this.timePickerDescriptors.find((x) => x.unit === unit);
|
|
575
|
+
if (d) {
|
|
576
|
+
return d.focusedValue;
|
|
477
577
|
}
|
|
478
|
-
|
|
479
|
-
|
|
578
|
+
}
|
|
579
|
+
const raw = this.formattedTime?.[unit];
|
|
580
|
+
if (raw === '' || raw === undefined) {
|
|
581
|
+
return 0;
|
|
582
|
+
}
|
|
583
|
+
return Number(raw);
|
|
584
|
+
}
|
|
585
|
+
/** Base time for `canSelect`/`select` on `targetUnit`: committed hour; mid-columns via {@link getProvisionalRawValue}. */
|
|
586
|
+
buildCandidateBaseBeforeUnit(targetUnit) {
|
|
587
|
+
const { selectionBase } = this.getUnitSelectionContext();
|
|
588
|
+
const order = this.timePickerDescriptors.map((d) => d.unit);
|
|
589
|
+
const targetIndex = order.indexOf(targetUnit);
|
|
590
|
+
if (targetIndex <= 0) {
|
|
591
|
+
return selectionBase;
|
|
592
|
+
}
|
|
593
|
+
let base = this._time ?? selectionBase;
|
|
594
|
+
for (let i = 1; i < targetIndex; i++) {
|
|
595
|
+
const unit = order[i];
|
|
596
|
+
if (unit === undefined) {
|
|
597
|
+
continue;
|
|
598
|
+
}
|
|
599
|
+
const raw = this.getProvisionalRawValue(unit);
|
|
600
|
+
const next = computeTimeWithRawUnitValue(base, unit, raw, this.timeRef);
|
|
601
|
+
if (next) {
|
|
602
|
+
base = next;
|
|
480
603
|
}
|
|
481
604
|
}
|
|
482
|
-
|
|
483
|
-
// Case-sensitive matching to distinguish between 'h' and 'H'
|
|
484
|
-
return /h|a|t/.test(cleanFormat);
|
|
605
|
+
return base;
|
|
485
606
|
}
|
|
486
|
-
|
|
487
|
-
const
|
|
488
|
-
|
|
489
|
-
|
|
607
|
+
getConstrainedFocusedValueForUnitWithBase(unit, numberArray, baseBeforeUnit) {
|
|
608
|
+
const { bounds } = this.getUnitSelectionContext();
|
|
609
|
+
const pickFirstSelectable = () => {
|
|
610
|
+
const found = numberArray.find((n) => this.canSelectUnitValue(unit, n, bounds, baseBeforeUnit));
|
|
611
|
+
return found ?? null;
|
|
612
|
+
};
|
|
613
|
+
const selected = Number(this.formattedTime[unit]);
|
|
614
|
+
if (!numberArray.includes(selected)) {
|
|
615
|
+
return pickFirstSelectable() ?? numberArray[0];
|
|
490
616
|
}
|
|
491
|
-
|
|
492
|
-
|
|
617
|
+
if (this.canSelectUnitValue(unit, selected, bounds, baseBeforeUnit)) {
|
|
618
|
+
return selected;
|
|
493
619
|
}
|
|
620
|
+
return pickFirstSelectable() ?? numberArray[0];
|
|
494
621
|
}
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
return numberArray.includes(selectedValue) ? selectedValue : numberArray[0];
|
|
622
|
+
getConstrainedFocusedValueForUnit(unit, numberArray) {
|
|
623
|
+
return this.getConstrainedFocusedValueForUnitWithBase(unit, numberArray, this.buildCandidateBaseBeforeUnit(unit));
|
|
498
624
|
}
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
if (
|
|
505
|
-
|
|
625
|
+
resolvePreservedFocusedValueOnColumnBlur(unit) {
|
|
626
|
+
const arr = this.getNumberArrayForUnit(unit);
|
|
627
|
+
const { bounds } = this.getUnitSelectionContext();
|
|
628
|
+
const base = this.buildCandidateBaseBeforeUnit(unit);
|
|
629
|
+
const current = this.focusedValue;
|
|
630
|
+
if (arr.includes(current) &&
|
|
631
|
+
this.canSelectUnitValue(unit, current, bounds, base)) {
|
|
632
|
+
return current;
|
|
506
633
|
}
|
|
507
|
-
|
|
508
|
-
|
|
634
|
+
return this.getConstrainedFocusedValueForUnit(unit, arr);
|
|
635
|
+
}
|
|
636
|
+
syncKeyboardFocusWithConstraints() {
|
|
637
|
+
if (!this.timePickerDescriptors.length) {
|
|
638
|
+
return;
|
|
639
|
+
}
|
|
640
|
+
for (const d of this.timePickerDescriptors) {
|
|
641
|
+
const next = this.getConstrainedFocusedValueForUnit(d.unit, d.numberArray);
|
|
642
|
+
if (next !== d.focusedValue) {
|
|
643
|
+
this.updateDescriptorFocusedValue(d.unit, next);
|
|
644
|
+
}
|
|
509
645
|
}
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
646
|
+
const arr = this.getNumberArrayForUnit(this.focusedUnit);
|
|
647
|
+
if (arr.length) {
|
|
648
|
+
const nextFocused = this.getConstrainedFocusedValueForUnit(this.focusedUnit, arr);
|
|
649
|
+
if (nextFocused !== this.focusedValue) {
|
|
650
|
+
this.focusedValue = nextFocused;
|
|
651
|
+
}
|
|
652
|
+
}
|
|
653
|
+
}
|
|
654
|
+
findFirstSelectableInUnit(unit) {
|
|
655
|
+
const arr = this.getNumberArrayForUnit(unit);
|
|
656
|
+
const { bounds } = this.getUnitSelectionContext();
|
|
657
|
+
const base = this.buildCandidateBaseBeforeUnit(unit);
|
|
658
|
+
const found = arr.find((n) => this.canSelectUnitValue(unit, n, bounds, base));
|
|
659
|
+
return found ?? null;
|
|
660
|
+
}
|
|
661
|
+
getColumnTabStopValue(unit) {
|
|
662
|
+
const d = this.timePickerDescriptors.find((x) => x.unit === unit);
|
|
663
|
+
const arr = d?.numberArray ?? [];
|
|
664
|
+
if (!d || !arr.length) {
|
|
665
|
+
return null;
|
|
666
|
+
}
|
|
667
|
+
const { bounds } = this.getUnitSelectionContext();
|
|
668
|
+
const base = this.buildCandidateBaseBeforeUnit(unit);
|
|
669
|
+
const candidate = d.focusedValue;
|
|
670
|
+
if (arr.includes(candidate) &&
|
|
671
|
+
this.canSelectUnitValue(unit, candidate, bounds, base)) {
|
|
672
|
+
return candidate;
|
|
673
|
+
}
|
|
674
|
+
return this.findFirstSelectableInUnit(unit);
|
|
675
|
+
}
|
|
676
|
+
stepFocusedValue(direction) {
|
|
677
|
+
const unit = this.focusedUnit;
|
|
678
|
+
const arr = this.getNumberArrayForUnit(unit);
|
|
679
|
+
const { bounds } = this.getUnitSelectionContext();
|
|
680
|
+
const base = this.buildCandidateBaseBeforeUnit(unit);
|
|
681
|
+
const next = findNextSelectableRingValue(arr, this.focusedValue, direction, (candidate) => this.canSelectUnitValue(unit, candidate, bounds, base));
|
|
682
|
+
if (next === null) {
|
|
683
|
+
return;
|
|
684
|
+
}
|
|
685
|
+
this.focusedValue = next;
|
|
686
|
+
this.updateDescriptorFocusedValue(unit, next);
|
|
687
|
+
}
|
|
688
|
+
isConfirmDisabled() {
|
|
689
|
+
const referenceClock = this.referenceOrNow();
|
|
690
|
+
const { min, max } = this.getConstraintBounds(referenceClock);
|
|
691
|
+
if (!hasActiveTimePickerConstraints(min, max)) {
|
|
692
|
+
return false;
|
|
693
|
+
}
|
|
694
|
+
return !isWithinTimePickerConstraints(referenceClock, min, max);
|
|
695
|
+
}
|
|
696
|
+
setTimePickerDescriptors() {
|
|
697
|
+
const { hourNumbers, minuteNumbers, secondNumbers, millisecondsNumbers } = buildTimePickerColumnNumberArrays({
|
|
698
|
+
hourInterval: this.hourInterval,
|
|
699
|
+
minuteInterval: this.minuteInterval,
|
|
700
|
+
secondInterval: this.secondInterval,
|
|
701
|
+
millisecondInterval: this.millisecondInterval,
|
|
702
|
+
}, this.timeRef);
|
|
703
|
+
const { selectionBase } = this.getUnitSelectionContext();
|
|
704
|
+
const columns = [
|
|
514
705
|
{
|
|
515
706
|
unit: 'hour',
|
|
516
707
|
header: this.i18nHourColumnHeader,
|
|
517
708
|
hidden: !LUXON_FORMAT_PATTERNS.hours.test(this.format),
|
|
518
709
|
numberArray: hourNumbers,
|
|
519
|
-
focusedValue: this.getInitialFocusedValueForUnit('hour', hourNumbers),
|
|
520
710
|
},
|
|
521
711
|
{
|
|
522
712
|
unit: 'minute',
|
|
523
713
|
header: this.i18nMinuteColumnHeader,
|
|
524
714
|
hidden: !LUXON_FORMAT_PATTERNS.minutes.test(this.format),
|
|
525
715
|
numberArray: minuteNumbers,
|
|
526
|
-
focusedValue: this.getInitialFocusedValueForUnit('minute', minuteNumbers),
|
|
527
716
|
},
|
|
528
717
|
{
|
|
529
718
|
unit: 'second',
|
|
530
719
|
header: this.i18nSecondColumnHeader,
|
|
531
720
|
hidden: !LUXON_FORMAT_PATTERNS.seconds.test(this.format),
|
|
532
721
|
numberArray: secondNumbers,
|
|
533
|
-
focusedValue: this.getInitialFocusedValueForUnit('second', secondNumbers),
|
|
534
722
|
},
|
|
535
723
|
{
|
|
536
724
|
unit: 'millisecond',
|
|
537
725
|
header: this.i18nMillisecondColumnHeader,
|
|
538
726
|
hidden: !LUXON_FORMAT_PATTERNS.milliseconds.test(this.format),
|
|
539
727
|
numberArray: millisecondsNumbers,
|
|
540
|
-
focusedValue: this.getInitialFocusedValueForUnit('millisecond', millisecondsNumbers),
|
|
541
728
|
},
|
|
542
729
|
];
|
|
543
|
-
|
|
730
|
+
let base = selectionBase;
|
|
731
|
+
const descriptors = [];
|
|
732
|
+
for (const col of columns) {
|
|
733
|
+
if (col.hidden) {
|
|
734
|
+
continue;
|
|
735
|
+
}
|
|
736
|
+
const focusedValue = this.getConstrainedFocusedValueForUnitWithBase(col.unit, col.numberArray, base);
|
|
737
|
+
descriptors.push({
|
|
738
|
+
unit: col.unit,
|
|
739
|
+
header: col.header,
|
|
740
|
+
hidden: false,
|
|
741
|
+
numberArray: col.numberArray,
|
|
742
|
+
focusedValue,
|
|
743
|
+
});
|
|
744
|
+
const next = computeTimeWithRawUnitValue(base, col.unit, focusedValue, this.timeRef);
|
|
745
|
+
if (next) {
|
|
746
|
+
base = next;
|
|
747
|
+
}
|
|
748
|
+
}
|
|
749
|
+
this.timePickerDescriptors = descriptors;
|
|
544
750
|
}
|
|
545
751
|
getNumberArrayForUnit(unit) {
|
|
546
752
|
const descriptor = this.timePickerDescriptors.find((descriptor) => descriptor.unit === unit);
|
|
@@ -549,12 +755,40 @@ export class TimePicker {
|
|
|
549
755
|
isSelected(unit, number) {
|
|
550
756
|
return this.formattedTime[unit] === String(number);
|
|
551
757
|
}
|
|
758
|
+
/** Roving tabindex: one tab stop per column; active column only the focused cell has `tabindex=0`. */
|
|
759
|
+
getUnitCellTabIndex(unit, number) {
|
|
760
|
+
const { bounds } = this.getUnitSelectionContext();
|
|
761
|
+
const base = this.buildCandidateBaseBeforeUnit(unit);
|
|
762
|
+
const cellIsSelectable = this.canSelectUnitValue(unit, number, bounds, base);
|
|
763
|
+
if (!cellIsSelectable) {
|
|
764
|
+
return -1;
|
|
765
|
+
}
|
|
766
|
+
if (this.isUnitFocused && this.focusedUnit === unit) {
|
|
767
|
+
return this.focusedValue === number ? 0 : -1;
|
|
768
|
+
}
|
|
769
|
+
const stop = this.getColumnTabStopValue(unit);
|
|
770
|
+
if (stop === null) {
|
|
771
|
+
return -1;
|
|
772
|
+
}
|
|
773
|
+
return stop === number ? 0 : -1;
|
|
774
|
+
}
|
|
552
775
|
select(unit, number) {
|
|
553
776
|
if (this.isSelected(unit, number)) {
|
|
554
777
|
return;
|
|
555
778
|
}
|
|
556
|
-
|
|
557
|
-
this.
|
|
779
|
+
const { bounds } = this.getUnitSelectionContext();
|
|
780
|
+
const base = this.buildCandidateBaseBeforeUnit(unit);
|
|
781
|
+
if (!this.canSelectUnitValue(unit, number, bounds, base)) {
|
|
782
|
+
return;
|
|
783
|
+
}
|
|
784
|
+
const candidate = computeTimeWithRawUnitValue(base, unit, number, this.timeRef);
|
|
785
|
+
if (!candidate) {
|
|
786
|
+
return;
|
|
787
|
+
}
|
|
788
|
+
if (this._time && candidate.toMillis() === this._time.toMillis()) {
|
|
789
|
+
return;
|
|
790
|
+
}
|
|
791
|
+
this._time = candidate;
|
|
558
792
|
this.elementListScrollToTop(unit, number, 'smooth');
|
|
559
793
|
this.timeChange.emit(this._time.toFormat(this.format));
|
|
560
794
|
}
|
|
@@ -563,7 +797,10 @@ export class TimePicker {
|
|
|
563
797
|
if (descriptorIndex !== -1) {
|
|
564
798
|
this.timePickerDescriptors = [
|
|
565
799
|
...this.timePickerDescriptors.slice(0, descriptorIndex),
|
|
566
|
-
|
|
800
|
+
{
|
|
801
|
+
...this.timePickerDescriptors[descriptorIndex],
|
|
802
|
+
focusedValue: value,
|
|
803
|
+
},
|
|
567
804
|
...this.timePickerDescriptors.slice(descriptorIndex + 1),
|
|
568
805
|
];
|
|
569
806
|
}
|
|
@@ -604,52 +841,45 @@ export class TimePicker {
|
|
|
604
841
|
}
|
|
605
842
|
}
|
|
606
843
|
formatUnitValue(unit, value) {
|
|
607
|
-
|
|
608
|
-
return value.toString().padStart(3, '0');
|
|
609
|
-
}
|
|
610
|
-
return value < 10 ? `0${value}` : value.toString();
|
|
844
|
+
return formatTimePickerUnitValue(unit, value);
|
|
611
845
|
}
|
|
612
846
|
getColumnSeparator(currentIndex) {
|
|
613
|
-
|
|
614
|
-
const nextUnit = this.timePickerDescriptors[currentIndex + 1].unit;
|
|
615
|
-
return nextUnit === 'millisecond' ? '.' : ':';
|
|
616
|
-
}
|
|
617
|
-
return ':';
|
|
618
|
-
}
|
|
619
|
-
getElementContainerTabIndex(number, descriptorUnit) {
|
|
620
|
-
const descriptor = this.timePickerDescriptors.find((d) => d.unit === descriptorUnit);
|
|
621
|
-
if (number === (descriptor === null || descriptor === void 0 ? void 0 : descriptor.focusedValue)) {
|
|
622
|
-
return '0';
|
|
623
|
-
}
|
|
624
|
-
return '-1';
|
|
847
|
+
return getTimePickerColumnSeparator(currentIndex, this.timePickerDescriptors);
|
|
625
848
|
}
|
|
626
849
|
render() {
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
850
|
+
const { bounds } = this.getUnitSelectionContext();
|
|
851
|
+
return (h(Host, { key: '148f502158a23cb3653c1f062a69cff199e93fdc' }, h("ix-date-time-card", { key: '5612a12cfb0a8b3c55c3491fcae620d63fa0bbd7', embedded: this.embedded, timePickerAppearance: true, corners: this.corners, hasFooter: !this.dateTimePickerAppearance, hideHeader: this.hideHeader }, h("div", { key: '80c1720b837cc3cef4fb4590f68dfe1ab23b8370', class: "header", slot: "header" }, h("ix-typography", { key: '087b23019ec2213c3a23b0c1c08da2328af144be', format: "body" }, this.i18nHeader)), h("div", { key: '1c4c0a0ca82ae0633fbecd5ed9453493c7b9cf98', class: "clock" }, this.timePickerDescriptors.map((descriptor, index) => {
|
|
852
|
+
return (h("div", { class: "flex" }, h("div", { class: { columns: true, hidden: descriptor.hidden }, hidden: descriptor.hidden }, h("div", { class: "column-header", title: descriptor.header }, descriptor.header), h("div", { role: "listbox", "aria-label": descriptor.header, "data-element-list-id": descriptor.unit, class: "element-list", tabindex: -1 }, descriptor.numberArray.map((number) => {
|
|
853
|
+
const cellTabIndex = this.getUnitCellTabIndex(descriptor.unit, number);
|
|
854
|
+
const disabled = !this.canSelectUnitValue(descriptor.unit, number, bounds, this.buildCandidateBaseBeforeUnit(descriptor.unit));
|
|
855
|
+
const selected = this.isSelected(descriptor.unit, number);
|
|
856
|
+
return (h("button", { role: "option", "aria-selected": selected ? 'true' : 'false', "data-element-container-id": `${descriptor.unit}-${number}`, class: {
|
|
857
|
+
selected,
|
|
858
|
+
'element-container': true,
|
|
859
|
+
disabled,
|
|
860
|
+
}, disabled: disabled, onClick: () => {
|
|
861
|
+
this.select(descriptor.unit, number);
|
|
862
|
+
}, onFocus: () => this.onUnitCellFocus(descriptor.unit, number), onBlur: (e) => this.onUnitCellBlur(descriptor.unit, e), "aria-label": `${descriptor.header}: ${number}`, tabindex: cellTabIndex }, this.formatUnitValue(descriptor.unit, number)));
|
|
863
|
+
}), h("div", { class: "element-list-padding" }))), index !== this.timePickerDescriptors.length - 1 && (h("div", { class: {
|
|
864
|
+
'column-separator': true,
|
|
865
|
+
hidden: descriptor.hidden,
|
|
866
|
+
} }, this.getColumnSeparator(index)))));
|
|
867
|
+
}), this.timeRef && (h("div", { key: 'aee3e153f67ba1365ff56d36a72d1d5561d30e2a', class: "flex" }, h("div", { key: 'd18821a7a032522e161fdd1e74a5812d2111a6ae', class: "column-separator" }), h("div", { key: '57db4e6409de2fbf5d13647304af280866845695', class: "columns" }, h("div", { key: 'd60b46a2bc28606c7708eb3dbccee6fe76df8cc5', class: "column-header", title: "AM/PM" }), h("div", { key: '2d33c518b011e25fb334cd8e1f1efa9b79cd35ff', role: "listbox", "aria-label": "AM/PM", class: "element-list", tabindex: -1 }, h("button", { key: '0ee352467596e646e3afc588ccaa80cad649c551', role: "option", "aria-selected": this.timeRef === 'AM' ? 'true' : 'false', "data-am-pm-id": "AM", class: {
|
|
638
868
|
selected: this.timeRef === 'AM',
|
|
639
869
|
'element-container': true,
|
|
640
|
-
}, onClick: () => this.changeTimeReference('AM'), tabindex: "0", "aria-label": "AM" }, "AM"), h("button", { key: '
|
|
870
|
+
}, onClick: () => this.changeTimeReference('AM'), tabindex: "0", "aria-label": "AM" }, "AM"), h("button", { key: '3c207b5fb9f759a101ce7d1959f93cbfda487274', role: "option", "aria-selected": this.timeRef === 'PM' ? 'true' : 'false', "data-am-pm-id": "PM", class: {
|
|
641
871
|
selected: this.timeRef === 'PM',
|
|
642
872
|
'element-container': true,
|
|
643
|
-
}, onClick: () => this.changeTimeReference('PM'), tabindex: "0", "aria-label": "PM" }, "PM")))))), h("div", { key: '
|
|
873
|
+
}, onClick: () => this.changeTimeReference('PM'), tabindex: "0", "aria-label": "PM" }, "PM")))))), h("div", { key: 'fc56aa00e3d0280045272303181d49fbcf473bc6', class: {
|
|
644
874
|
footer: true,
|
|
645
875
|
'footer--compact': this.timePickerDescriptors.length <= 2,
|
|
646
|
-
}, slot: "footer" }, h("ix-button", { key: '
|
|
647
|
-
|
|
648
|
-
this.timeSelect.emit((_a = this._time) === null || _a === void 0 ? void 0 : _a.toFormat(this.format));
|
|
876
|
+
}, slot: "footer" }, h("ix-button", { key: '1c2361d8241d53b5f902f203b43a8bf768f8d1af', class: "confirm-button", disabled: this.isConfirmDisabled(), onClick: () => {
|
|
877
|
+
this.timeSelect.emit(this._time?.toFormat(this.format));
|
|
649
878
|
} }, this.i18nConfirmTime)))));
|
|
650
879
|
}
|
|
651
880
|
static get is() { return "ix-time-picker"; }
|
|
652
881
|
static get encapsulation() { return "shadow"; }
|
|
882
|
+
static get delegatesFocus() { return true; }
|
|
653
883
|
static get originalStyleUrls() {
|
|
654
884
|
return {
|
|
655
885
|
"$": ["time-picker.scss"]
|
|
@@ -886,6 +1116,50 @@ export class TimePicker {
|
|
|
886
1116
|
"reflect": false,
|
|
887
1117
|
"attribute": "time"
|
|
888
1118
|
},
|
|
1119
|
+
"minTime": {
|
|
1120
|
+
"type": "string",
|
|
1121
|
+
"mutable": false,
|
|
1122
|
+
"complexType": {
|
|
1123
|
+
"original": "string",
|
|
1124
|
+
"resolved": "string | undefined",
|
|
1125
|
+
"references": {}
|
|
1126
|
+
},
|
|
1127
|
+
"required": false,
|
|
1128
|
+
"optional": true,
|
|
1129
|
+
"docs": {
|
|
1130
|
+
"tags": [{
|
|
1131
|
+
"name": "since",
|
|
1132
|
+
"text": "5.0.0"
|
|
1133
|
+
}],
|
|
1134
|
+
"text": "Earliest selectable time (`format` tokens). Invalid non-empty values are ignored."
|
|
1135
|
+
},
|
|
1136
|
+
"getter": false,
|
|
1137
|
+
"setter": false,
|
|
1138
|
+
"reflect": false,
|
|
1139
|
+
"attribute": "min-time"
|
|
1140
|
+
},
|
|
1141
|
+
"maxTime": {
|
|
1142
|
+
"type": "string",
|
|
1143
|
+
"mutable": false,
|
|
1144
|
+
"complexType": {
|
|
1145
|
+
"original": "string",
|
|
1146
|
+
"resolved": "string | undefined",
|
|
1147
|
+
"references": {}
|
|
1148
|
+
},
|
|
1149
|
+
"required": false,
|
|
1150
|
+
"optional": true,
|
|
1151
|
+
"docs": {
|
|
1152
|
+
"tags": [{
|
|
1153
|
+
"name": "since",
|
|
1154
|
+
"text": "5.0.0"
|
|
1155
|
+
}],
|
|
1156
|
+
"text": "Latest selectable time (`format` tokens). Invalid non-empty values are ignored."
|
|
1157
|
+
},
|
|
1158
|
+
"getter": false,
|
|
1159
|
+
"setter": false,
|
|
1160
|
+
"reflect": false,
|
|
1161
|
+
"attribute": "max-time"
|
|
1162
|
+
},
|
|
889
1163
|
"i18nConfirmTime": {
|
|
890
1164
|
"type": "string",
|
|
891
1165
|
"mutable": false,
|
|
@@ -943,7 +1217,7 @@ export class TimePicker {
|
|
|
943
1217
|
"getter": false,
|
|
944
1218
|
"setter": false,
|
|
945
1219
|
"reflect": false,
|
|
946
|
-
"attribute": "i18n-column-header",
|
|
1220
|
+
"attribute": "i18n-hour-column-header",
|
|
947
1221
|
"defaultValue": "'hr'"
|
|
948
1222
|
},
|
|
949
1223
|
"i18nMinuteColumnHeader": {
|
|
@@ -1093,6 +1367,12 @@ export class TimePicker {
|
|
|
1093
1367
|
}, {
|
|
1094
1368
|
"propName": "time",
|
|
1095
1369
|
"methodName": "watchTimePropHandler"
|
|
1370
|
+
}, {
|
|
1371
|
+
"propName": "minTime",
|
|
1372
|
+
"methodName": "watchMinTimePropHandler"
|
|
1373
|
+
}, {
|
|
1374
|
+
"propName": "maxTime",
|
|
1375
|
+
"methodName": "watchMaxTimePropHandler"
|
|
1096
1376
|
}, {
|
|
1097
1377
|
"propName": "_time",
|
|
1098
1378
|
"methodName": "onTimeChange"
|