voyager-ionic-core 7.5.5 → 7.6.1
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/components/action-sheet.js +297 -287
- package/components/alert.js +477 -467
- package/components/animation.js +991 -990
- package/components/backdrop.js +56 -56
- package/components/button-active.js +56 -56
- package/components/button.js +236 -236
- package/components/buttons.js +29 -29
- package/components/capacitor.js +4 -4
- package/components/checkbox.js +172 -170
- package/components/config.js +142 -142
- package/components/cubic-bezier.js +49 -49
- package/components/data.js +1112 -1062
- package/components/dir.js +5 -5
- package/components/focus-visible.js +63 -63
- package/components/form-controller.js +45 -45
- package/components/framework-delegate.js +121 -121
- package/components/gesture-controller.js +182 -182
- package/components/haptic.js +150 -150
- package/components/hardware-back-button.js +48 -48
- package/components/helpers.js +257 -257
- package/components/icon.js +133 -133
- package/components/index.js +95 -95
- package/components/index2.js +163 -163
- package/components/index3.js +417 -417
- package/components/index4.js +257 -259
- package/components/index5.js +0 -22
- package/components/index6.js +3 -3
- package/components/index8.js +58 -58
- package/components/index9.js +171 -171
- package/components/input-shims.js +488 -483
- package/components/input.utils.js +107 -106
- package/components/ion-accordion-group.d.ts +2 -2
- package/components/ion-accordion-group.js +220 -220
- package/components/ion-accordion.d.ts +2 -2
- package/components/ion-accordion.js +326 -326
- package/components/ion-action-sheet.d.ts +2 -2
- package/components/ion-alert.d.ts +2 -2
- package/components/ion-app.d.ts +2 -2
- package/components/ion-app.js +93 -93
- package/components/ion-avatar.d.ts +2 -2
- package/components/ion-avatar.js +23 -23
- package/components/ion-back-button.d.ts +2 -2
- package/components/ion-back-button.js +102 -102
- package/components/ion-backdrop.d.ts +2 -2
- package/components/ion-badge.d.ts +2 -2
- package/components/ion-badge.js +29 -29
- package/components/ion-breadcrumb.d.ts +2 -2
- package/components/ion-breadcrumb.js +111 -111
- package/components/ion-breadcrumbs.d.ts +2 -2
- package/components/ion-breadcrumbs.js +139 -139
- package/components/ion-button.d.ts +2 -2
- package/components/ion-buttons.d.ts +2 -2
- package/components/ion-card-content.d.ts +2 -2
- package/components/ion-card-content.js +27 -27
- package/components/ion-card-header.d.ts +2 -2
- package/components/ion-card-header.js +33 -33
- package/components/ion-card-subtitle.d.ts +2 -2
- package/components/ion-card-subtitle.js +30 -30
- package/components/ion-card-title.d.ts +2 -2
- package/components/ion-card-title.js +30 -30
- package/components/ion-card.d.ts +2 -2
- package/components/ion-card.js +78 -78
- package/components/ion-checkbox.d.ts +2 -2
- package/components/ion-chip.d.ts +2 -2
- package/components/ion-chip.js +41 -41
- package/components/ion-col.d.ts +2 -2
- package/components/ion-col.js +156 -156
- package/components/ion-content.d.ts +2 -2
- package/components/ion-content.js +394 -394
- package/components/ion-datetime-button.d.ts +2 -2
- package/components/ion-datetime-button.js +348 -348
- package/components/ion-datetime.d.ts +2 -2
- package/components/ion-datetime.js +1741 -1709
- package/components/ion-fab-button.d.ts +2 -2
- package/components/ion-fab-button.js +109 -109
- package/components/ion-fab-list.d.ts +2 -2
- package/components/ion-fab-list.js +44 -44
- package/components/ion-fab.d.ts +2 -2
- package/components/ion-fab.js +75 -75
- package/components/ion-footer.d.ts +2 -2
- package/components/ion-footer.js +124 -124
- package/components/ion-grid.d.ts +2 -2
- package/components/ion-grid.js +27 -27
- package/components/ion-header.d.ts +2 -2
- package/components/ion-header.js +298 -298
- package/components/ion-img.d.ts +2 -2
- package/components/ion-img.js +97 -97
- package/components/ion-infinite-scroll-content.d.ts +2 -2
- package/components/ion-infinite-scroll-content.js +49 -49
- package/components/ion-infinite-scroll.d.ts +2 -2
- package/components/ion-infinite-scroll.js +187 -179
- package/components/ion-input.d.ts +2 -2
- package/components/ion-input.js +498 -454
- package/components/ion-item-divider.d.ts +2 -2
- package/components/ion-item-divider.js +34 -34
- package/components/ion-item-group.d.ts +2 -2
- package/components/ion-item-group.js +28 -28
- package/components/ion-item-option.d.ts +2 -2
- package/components/ion-item-option.js +67 -67
- package/components/ion-item-options.d.ts +2 -2
- package/components/ion-item-options.js +50 -50
- package/components/ion-item-sliding.d.ts +2 -2
- package/components/ion-item-sliding.js +404 -404
- package/components/ion-item.d.ts +2 -2
- package/components/ion-label.d.ts +2 -2
- package/components/ion-list-header.d.ts +2 -2
- package/components/ion-list.d.ts +2 -2
- package/components/ion-loading.d.ts +2 -2
- package/components/ion-loading.js +257 -247
- package/components/ion-menu-button.d.ts +2 -2
- package/components/ion-menu-button.js +77 -77
- package/components/ion-menu-toggle.d.ts +2 -2
- package/components/ion-menu-toggle.js +41 -41
- package/components/ion-menu.d.ts +2 -2
- package/components/ion-menu.js +631 -631
- package/components/ion-modal.d.ts +2 -2
- package/components/ion-modal.js +1451 -1441
- package/components/ion-nav-link.d.ts +2 -2
- package/components/ion-nav-link.js +47 -47
- package/components/ion-nav.d.ts +2 -2
- package/components/ion-nav.js +910 -910
- package/components/ion-note.d.ts +2 -2
- package/components/ion-picker-column-internal.d.ts +2 -2
- package/components/ion-picker-column.d.ts +2 -2
- package/components/ion-picker-internal.d.ts +2 -2
- package/components/ion-picker.d.ts +2 -2
- package/components/ion-picker.js +263 -253
- package/components/ion-popover.d.ts +2 -2
- package/components/ion-progress-bar.d.ts +2 -2
- package/components/ion-progress-bar.js +57 -57
- package/components/ion-radio-group.d.ts +2 -2
- package/components/ion-radio.d.ts +2 -2
- package/components/ion-range.d.ts +2 -2
- package/components/ion-range.js +593 -591
- package/components/ion-refresher-content.d.ts +2 -2
- package/components/ion-refresher-content.js +63 -63
- package/components/ion-refresher.d.ts +2 -2
- package/components/ion-refresher.js +747 -747
- package/components/ion-reorder-group.d.ts +2 -2
- package/components/ion-reorder-group.js +259 -259
- package/components/ion-reorder.d.ts +2 -2
- package/components/ion-reorder.js +39 -39
- package/components/ion-ripple-effect.d.ts +2 -2
- package/components/ion-route-redirect.d.ts +2 -2
- package/components/ion-route-redirect.js +34 -34
- package/components/ion-route.d.ts +2 -2
- package/components/ion-route.js +56 -56
- package/components/ion-router-link.d.ts +2 -2
- package/components/ion-router-link.js +45 -45
- package/components/ion-router-outlet.d.ts +2 -2
- package/components/ion-router-outlet.js +193 -193
- package/components/ion-router.d.ts +2 -2
- package/components/ion-router.js +632 -632
- package/components/ion-row.d.ts +2 -2
- package/components/ion-row.js +20 -20
- package/components/ion-searchbar.d.ts +2 -2
- package/components/ion-searchbar.js +402 -400
- package/components/ion-segment-button.d.ts +2 -2
- package/components/ion-segment-button.js +117 -117
- package/components/ion-segment.d.ts +2 -2
- package/components/ion-segment.js +427 -427
- package/components/ion-select-option.d.ts +2 -2
- package/components/ion-select-option.js +27 -27
- package/components/ion-select-popover.d.ts +2 -2
- package/components/ion-select.d.ts +2 -2
- package/components/ion-select.js +778 -763
- package/components/ion-skeleton-text.d.ts +2 -2
- package/components/ion-skeleton-text.js +45 -32
- package/components/ion-spinner.d.ts +2 -2
- package/components/ion-split-pane.d.ts +2 -2
- package/components/ion-split-pane.js +147 -147
- package/components/ion-tab-bar.d.ts +2 -2
- package/components/ion-tab-bar.js +77 -77
- package/components/ion-tab-button.d.ts +2 -2
- package/components/ion-tab-button.js +104 -104
- package/components/ion-tab.d.ts +2 -2
- package/components/ion-tab.js +72 -72
- package/components/ion-tabs.d.ts +2 -2
- package/components/ion-tabs.js +160 -160
- package/components/ion-text.d.ts +2 -2
- package/components/ion-text.js +26 -26
- package/components/ion-textarea.d.ts +2 -2
- package/components/ion-textarea.js +443 -395
- package/components/ion-thumbnail.d.ts +2 -2
- package/components/ion-thumbnail.js +20 -20
- package/components/ion-title.d.ts +2 -2
- package/components/ion-title.js +56 -56
- package/components/ion-toast.d.ts +2 -2
- package/components/ion-toast.js +819 -464
- package/components/ion-toggle.d.ts +2 -2
- package/components/ion-toggle.js +243 -241
- package/components/ion-toolbar.d.ts +2 -2
- package/components/ion-toolbar.js +71 -71
- package/components/ionic-global.js +163 -163
- package/components/ios.transition.js +598 -598
- package/components/item.js +301 -301
- package/components/keyboard-controller.js +128 -128
- package/components/keyboard.js +62 -62
- package/components/keyboard2.js +59 -59
- package/components/label.js +85 -85
- package/components/list-header.js +33 -33
- package/components/list.js +50 -50
- package/components/lock-controller.js +24 -24
- package/components/md.transition.js +44 -44
- package/components/menu-toggle-util.js +2 -2
- package/components/notch-controller.js +120 -120
- package/components/note.js +29 -29
- package/components/overlays.js +496 -495
- package/components/picker-column-internal.js +350 -345
- package/components/picker-column.js +334 -334
- package/components/picker-internal.js +468 -468
- package/components/popover.js +1154 -1144
- package/components/radio-group.js +161 -159
- package/components/radio.js +248 -208
- package/components/ripple-effect.js +81 -81
- package/components/select-popover.js +163 -163
- package/components/spinner.js +182 -182
- package/components/status-tap.js +26 -26
- package/components/swipe-back.js +65 -65
- package/components/theme.js +23 -23
- package/components/watch-options.js +30 -30
- package/css/core.css +66 -8
- package/css/core.css.map +1 -1
- package/css/display.css +44 -0
- package/css/display.css.map +1 -1
- package/css/float-elements.css +44 -0
- package/css/float-elements.css.map +1 -1
- package/css/global.bundle.css +88 -0
- package/css/global.bundle.css.map +1 -1
- package/css/ionic-swiper.css +22 -0
- package/css/ionic-swiper.css.map +1 -1
- package/css/ionic.bundle.css +1 -1
- package/css/ionic.bundle.css.map +1 -1
- package/css/padding.css +44 -0
- package/css/padding.css.map +1 -1
- package/css/structure.css +44 -0
- package/css/structure.css.map +1 -1
- package/css/text-alignment.css +44 -0
- package/css/text-alignment.css.map +1 -1
- package/css/text-transformation.css +44 -0
- package/css/text-transformation.css.map +1 -1
- package/css/typography.css +44 -0
- package/css/typography.css.map +1 -1
- package/css/utils.bundle.css +220 -0
- package/css/utils.bundle.css.map +1 -1
- package/dist/cjs/animation-9b401d39.js +1062 -0
- package/dist/cjs/{app-globals-1d4c1dbf.js → app-globals-7def22c8.js} +1 -1
- package/dist/cjs/button-active-962fe442.js +69 -0
- package/dist/cjs/{capacitor-2ffba62a.js → capacitor-c04564bf.js} +5 -5
- package/dist/cjs/compare-with-utils-df1001d7.js +44 -0
- package/dist/cjs/config-4f60b98a.js +199 -0
- package/dist/cjs/cubic-bezier-f2dccc53.js +92 -0
- package/dist/cjs/data-a5109f09.js +1672 -0
- package/dist/cjs/{dir-f1e0ca26.js → dir-94c21456.js} +5 -5
- package/dist/cjs/focus-visible-7a0ce04f.js +77 -0
- package/dist/cjs/form-controller-7d42a722.js +66 -0
- package/dist/cjs/framework-delegate-1c29b14a.js +144 -0
- package/dist/cjs/gesture-controller-c40c045a.js +197 -0
- package/dist/cjs/haptic-b882e0bb.js +212 -0
- package/dist/cjs/hardware-back-button-76833cac.js +76 -0
- package/dist/cjs/helpers-76bb7efb.js +441 -0
- package/dist/cjs/index-17ab7794.js +243 -0
- package/dist/cjs/index-3b012034.js +308 -0
- package/dist/cjs/{index-c2940dc1.js → index-50dcfe2f.js} +79 -15
- package/dist/cjs/{index-cc7dfb7c.js → index-5915f9b3.js} +3 -3
- package/dist/cjs/index-b4f986cd.js +198 -0
- package/dist/cjs/index-c8d52405.js +10 -0
- package/dist/cjs/index-d1b59ffa.js +459 -0
- package/dist/cjs/{index-da2c7a37.js → index-da15e99c.js} +60 -60
- package/dist/cjs/index.cjs.js +113 -113
- package/dist/cjs/input-shims-a23bb0f4.js +601 -0
- package/dist/cjs/input.utils-3d0166a2.js +138 -0
- package/dist/cjs/ion-accordion_2.cjs.entry.js +488 -488
- package/dist/cjs/ion-action-sheet.cjs.entry.js +260 -250
- package/dist/cjs/ion-alert.cjs.entry.js +442 -432
- package/dist/cjs/ion-app_8.cjs.entry.js +1151 -1151
- package/dist/cjs/ion-avatar_3.cjs.entry.js +29 -29
- package/dist/cjs/ion-back-button.cjs.entry.js +73 -73
- package/dist/cjs/ion-backdrop.cjs.entry.js +40 -40
- package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +194 -194
- package/dist/cjs/ion-button_2.cjs.entry.js +303 -303
- package/dist/cjs/ion-card_5.cjs.entry.js +105 -105
- package/dist/cjs/ion-checkbox.cjs.entry.js +149 -147
- package/dist/cjs/ion-chip.cjs.entry.js +20 -20
- package/dist/cjs/ion-col_3.cjs.entry.js +136 -136
- package/dist/cjs/ion-datetime-button.cjs.entry.js +325 -325
- package/dist/cjs/ion-datetime_3.cjs.entry.js +2204 -2162
- package/dist/cjs/ion-fab_3.cjs.entry.js +150 -150
- package/dist/cjs/ion-img.cjs.entry.js +79 -79
- package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +198 -190
- package/dist/cjs/ion-input.cjs.entry.js +443 -399
- package/dist/cjs/ion-item-option_3.cjs.entry.js +457 -457
- package/dist/cjs/ion-item_8.cjs.entry.js +441 -428
- package/dist/cjs/ion-loading.cjs.entry.js +220 -210
- package/dist/cjs/ion-menu_3.cjs.entry.js +670 -670
- package/dist/cjs/ion-modal.cjs.entry.js +1415 -1405
- package/dist/cjs/ion-nav_2.cjs.entry.js +904 -904
- package/dist/cjs/ion-picker-column-internal.cjs.entry.js +331 -327
- package/dist/cjs/ion-picker-internal.cjs.entry.js +453 -453
- package/dist/cjs/ion-popover.cjs.entry.js +1108 -1098
- package/dist/cjs/ion-progress-bar.cjs.entry.js +40 -40
- package/dist/cjs/ion-radio_2.cjs.entry.js +321 -316
- package/dist/cjs/ion-range.cjs.entry.js +558 -556
- package/dist/cjs/ion-refresher_2.cjs.entry.js +786 -786
- package/dist/cjs/ion-reorder_2.cjs.entry.js +267 -267
- package/dist/cjs/ion-ripple-effect.cjs.entry.js +66 -66
- package/dist/cjs/ion-route_4.cjs.entry.js +693 -693
- package/dist/cjs/ion-searchbar.cjs.entry.js +360 -358
- package/dist/cjs/ion-segment_2.cjs.entry.js +507 -507
- package/dist/cjs/ion-select_3.cjs.entry.js +784 -768
- package/dist/cjs/ion-spinner.cjs.entry.js +46 -46
- package/dist/cjs/ion-split-pane.cjs.entry.js +119 -119
- package/dist/cjs/ion-tab-bar_2.cjs.entry.js +138 -138
- package/dist/cjs/ion-tab_2.cjs.entry.js +187 -187
- package/dist/cjs/ion-text.cjs.entry.js +13 -13
- package/dist/cjs/ion-textarea.cjs.entry.js +401 -353
- package/dist/cjs/ion-toast.cjs.entry.js +771 -419
- package/dist/cjs/ion-toggle.cjs.entry.js +227 -225
- package/dist/cjs/ionic-global-a4edbf03.js +230 -0
- package/dist/cjs/ionic.cjs.js +5 -5
- package/dist/cjs/ios.transition-b5353f3e.js +654 -0
- package/dist/cjs/keyboard-0272231f.js +81 -0
- package/dist/cjs/{keyboard-38f2bb7b.js → keyboard-af1bb365.js} +62 -62
- package/dist/cjs/keyboard-controller-c05e747a.js +167 -0
- package/dist/cjs/loader.cjs.js +4 -4
- package/dist/cjs/lock-controller-6585a42a.js +40 -0
- package/dist/cjs/md.transition-67157dd9.js +59 -0
- package/dist/cjs/notch-controller-9735e7ac.js +155 -0
- package/dist/cjs/overlays-e77cc023.js +716 -0
- package/dist/cjs/spinner-configs-282fd50a.js +147 -0
- package/dist/cjs/status-tap-b5d77c08.js +42 -0
- package/dist/cjs/swipe-back-e37a1a5c.js +81 -0
- package/dist/cjs/theme-d1c573d2.js +48 -0
- package/dist/cjs/watch-options-f5f3e158.js +49 -0
- package/dist/collection/collection-manifest.json +7 -7
- package/dist/collection/components/accordion/accordion.ios.css +44 -0
- package/dist/collection/components/accordion/accordion.js +410 -410
- package/dist/collection/components/accordion/accordion.md.css +22 -0
- package/dist/collection/components/accordion/test/a11y/accordion.e2e.js +31 -31
- package/dist/collection/components/accordion/test/accordion.e2e.js +24 -24
- package/dist/collection/components/accordion/test/accordion.spec.js +195 -0
- package/dist/collection/components/accordion/test/basic/accordion.e2e.js +26 -26
- package/dist/collection/components/accordion/test/multiple/accordion.e2e.js +18 -18
- package/dist/collection/components/accordion/test/nested/accordion.e2e.js +16 -16
- package/dist/collection/components/accordion/test/standalone/accordion.e2e.js +6 -6
- package/dist/collection/components/accordion-group/accordion-group.ios.css +44 -0
- package/dist/collection/components/accordion-group/accordion-group.js +421 -421
- package/dist/collection/components/accordion-group/accordion-group.md.css +66 -0
- package/dist/collection/components/action-sheet/action-sheet.ios.css +44 -0
- package/dist/collection/components/action-sheet/action-sheet.js +739 -729
- package/dist/collection/components/action-sheet/action-sheet.md.css +44 -0
- package/dist/collection/components/action-sheet/animations/ios.enter.js +18 -18
- package/dist/collection/components/action-sheet/animations/ios.leave.js +12 -12
- package/dist/collection/components/action-sheet/animations/md.enter.js +18 -18
- package/dist/collection/components/action-sheet/animations/md.leave.js +12 -12
- package/dist/collection/components/action-sheet/test/a11y/action-sheet.e2e.js +59 -59
- package/dist/collection/components/action-sheet/test/action-sheet-id.spec.js +32 -0
- package/dist/collection/components/action-sheet/test/basic/action-sheet-rendering.e2e.js +33 -33
- package/dist/collection/components/action-sheet/test/basic/action-sheet.e2e.js +74 -74
- package/dist/collection/components/action-sheet/test/basic/action-sheet.spec.js +18 -0
- package/dist/collection/components/action-sheet/test/basic/fixture.js +23 -23
- package/dist/collection/components/action-sheet/test/is-open/action-sheet.e2e.js +25 -25
- package/dist/collection/components/action-sheet/test/translucent/action-sheet.e2e.js +10 -10
- package/dist/collection/components/action-sheet/test/trigger/action-sheet.e2e.js +21 -21
- package/dist/collection/components/alert/alert.ios.css +85 -1
- package/dist/collection/components/alert/alert.js +977 -967
- package/dist/collection/components/alert/alert.md.css +115 -3
- package/dist/collection/components/alert/animations/ios.enter.js +19 -19
- package/dist/collection/components/alert/animations/ios.leave.js +13 -13
- package/dist/collection/components/alert/animations/md.enter.js +19 -19
- package/dist/collection/components/alert/animations/md.leave.js +10 -10
- package/dist/collection/components/alert/test/a11y/alert.e2e.js +116 -116
- package/dist/collection/components/alert/test/alert-id.spec.js +32 -0
- package/dist/collection/components/alert/test/alert.spec.js +37 -0
- package/dist/collection/components/alert/test/basic/alert-tablet.e2e.js +40 -0
- package/dist/collection/components/alert/test/basic/alert.e2e.js +96 -96
- package/dist/collection/components/alert/test/is-open/alert.e2e.js +25 -25
- package/dist/collection/components/alert/test/standalone/alert.e2e.js +9 -9
- package/dist/collection/components/alert/test/trigger/alert.e2e.js +21 -21
- package/dist/collection/components/app/app.js +116 -116
- package/dist/collection/components/app/test/safe-area/app.e2e.js +24 -24
- package/dist/collection/components/avatar/avatar.ios.css +44 -0
- package/dist/collection/components/avatar/avatar.js +17 -17
- package/dist/collection/components/avatar/avatar.md.css +44 -0
- package/dist/collection/components/avatar/test/basic/avatar.e2e.js +12 -12
- package/dist/collection/components/back-button/back-button.ios.css +44 -0
- package/dist/collection/components/back-button/back-button.js +214 -214
- package/dist/collection/components/back-button/back-button.md.css +44 -0
- package/dist/collection/components/back-button/test/a11y/back-button.e2e.js +6 -6
- package/dist/collection/components/back-button/test/back-button.spec.js +86 -0
- package/dist/collection/components/back-button/test/basic/back-button.e2e.js +6 -6
- package/dist/collection/components/back-button/test/toolbar/back-button.e2e.js +6 -6
- package/dist/collection/components/backdrop/backdrop.ios.css +44 -0
- package/dist/collection/components/backdrop/backdrop.js +131 -131
- package/dist/collection/components/backdrop/backdrop.md.css +44 -0
- package/dist/collection/components/badge/badge.ios.css +44 -0
- package/dist/collection/components/badge/badge.js +49 -49
- package/dist/collection/components/badge/badge.md.css +44 -0
- package/dist/collection/components/badge/test/a11y/badge.e2e.js +6 -6
- package/dist/collection/components/badge/test/basic/badge.e2e.js +6 -6
- package/dist/collection/components/breadcrumb/breadcrumb.ios.css +44 -0
- package/dist/collection/components/breadcrumb/breadcrumb.js +395 -395
- package/dist/collection/components/breadcrumb/breadcrumb.md.css +44 -0
- package/dist/collection/components/breadcrumb/test/aria.spec.js +22 -0
- package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +22 -0
- package/dist/collection/components/breadcrumbs/breadcrumbs.js +247 -247
- package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +22 -0
- package/dist/collection/components/breadcrumbs/test/a11y/breadcrumbs.e2e.js +12 -12
- package/dist/collection/components/breadcrumbs/test/basic/breadcrumbs.e2e.js +6 -6
- package/dist/collection/components/breadcrumbs/test/breadcrumbs.spec.js +58 -0
- package/dist/collection/components/breadcrumbs/test/collapsed/breadcrumbs.e2e.js +6 -6
- package/dist/collection/components/breadcrumbs/test/reactive/breadcrumbs.e2e.js +43 -43
- package/dist/collection/components/button/button.ios.css +66 -0
- package/dist/collection/components/button/button.js +541 -541
- package/dist/collection/components/button/button.md.css +44 -0
- package/dist/collection/components/button/test/a11y/button.e2e.js +21 -21
- package/dist/collection/components/button/test/basic/button.e2e.js +32 -32
- package/dist/collection/components/button/test/clear/button.e2e.js +6 -6
- package/dist/collection/components/button/test/expand/button.e2e.js +6 -6
- package/dist/collection/components/button/test/form-reference/button.e2e.js +84 -84
- package/dist/collection/components/button/test/form-reference/button.spec.js +26 -0
- package/dist/collection/components/button/test/icon/button.e2e.js +6 -6
- package/dist/collection/components/button/test/outline/button.e2e.js +6 -6
- package/dist/collection/components/button/test/round/button.e2e.js +6 -6
- package/dist/collection/components/button/test/size/button.e2e.js +22 -22
- package/dist/collection/components/button/test/strong/button.e2e.js +22 -22
- package/dist/collection/components/button/test/wrap/button.e2e.js +73 -73
- package/dist/collection/components/buttons/buttons.ios.css +66 -0
- package/dist/collection/components/buttons/buttons.js +46 -46
- package/dist/collection/components/buttons/buttons.md.css +66 -0
- package/dist/collection/components/buttons/test/a11y/buttons.e2e.js +21 -21
- package/dist/collection/components/card/card.ios.css +44 -0
- package/dist/collection/components/card/card.js +251 -251
- package/dist/collection/components/card/card.md.css +44 -0
- package/dist/collection/components/card/test/a11y/card.e2e.js +6 -6
- package/dist/collection/components/card/test/aria.spec.js +16 -0
- package/dist/collection/components/card/test/basic/card.e2e.js +38 -38
- package/dist/collection/components/card-content/card-content.ios.css +44 -0
- package/dist/collection/components/card-content/card-content.js +21 -21
- package/dist/collection/components/card-content/card-content.md.css +44 -0
- package/dist/collection/components/card-header/card-header.ios.css +44 -0
- package/dist/collection/components/card-header/card-header.js +70 -70
- package/dist/collection/components/card-header/card-header.md.css +44 -0
- package/dist/collection/components/card-header/test/basic/card-header.e2e.js +6 -6
- package/dist/collection/components/card-subtitle/card-subtitle.ios.css +44 -0
- package/dist/collection/components/card-subtitle/card-subtitle.js +50 -50
- package/dist/collection/components/card-subtitle/card-subtitle.md.css +44 -0
- package/dist/collection/components/card-title/card-title.ios.css +44 -0
- package/dist/collection/components/card-title/card-title.js +50 -50
- package/dist/collection/components/card-title/card-title.md.css +44 -0
- package/dist/collection/components/checkbox/checkbox.ios.css +66 -6
- package/dist/collection/components/checkbox/checkbox.js +418 -415
- package/dist/collection/components/checkbox/checkbox.md.css +66 -6
- package/dist/collection/components/checkbox/test/a11y/checkbox.e2e.js +14 -14
- package/dist/collection/components/checkbox/test/basic/checkbox.e2e.js +50 -50
- package/dist/collection/components/checkbox/test/checkbox.spec.js +34 -0
- package/dist/collection/components/checkbox/test/color/checkbox.e2e.js +11 -11
- package/dist/collection/components/checkbox/test/indeterminate/checkbox.e2e.js +6 -6
- package/dist/collection/components/checkbox/test/item/checkbox.e2e.js +29 -29
- package/dist/collection/components/checkbox/test/label/checkbox.e2e.js +75 -75
- package/dist/collection/components/checkbox/test/legacy/basic/checkbox.e2e.js +45 -45
- package/dist/collection/components/checkbox/test/legacy/indeterminate/checkbox.e2e.js +6 -6
- package/dist/collection/components/checkbox/test/states/checkbox.e2e.js +21 -21
- package/dist/collection/components/chip/chip.ios.css +22 -0
- package/dist/collection/components/chip/chip.js +90 -90
- package/dist/collection/components/chip/chip.md.css +22 -0
- package/dist/collection/components/chip/test/a11y/chip.e2e.js +19 -19
- package/dist/collection/components/chip/test/basic/chip.e2e.js +42 -42
- package/dist/collection/components/chip/test/states/chip.e2e.js +14 -14
- package/dist/collection/components/col/col.css +66 -0
- package/dist/collection/components/col/col.js +536 -536
- package/dist/collection/components/content/content.css +22 -0
- package/dist/collection/components/content/content.js +745 -745
- package/dist/collection/components/content/test/basic/content.e2e.js +6 -6
- package/dist/collection/components/content/test/fixed/content.e2e.js +6 -6
- package/dist/collection/components/content/test/fullscreen/content.e2e.js +6 -6
- package/dist/collection/components/content/test/standalone/content.e2e.js +5 -5
- package/dist/collection/components/datetime/datetime.ios.css +45 -0
- package/dist/collection/components/datetime/datetime.js +2264 -2232
- package/dist/collection/components/datetime/datetime.md.css +45 -0
- package/dist/collection/components/datetime/test/a11y/datetime.e2e.js +58 -58
- package/dist/collection/components/datetime/test/a11y/datetime.spec.js +43 -0
- package/dist/collection/components/datetime/test/basic/datetime.e2e.js +241 -241
- package/dist/collection/components/datetime/test/color/datetime.e2e.js +9 -9
- package/dist/collection/components/datetime/test/comparison.spec.js +43 -0
- package/dist/collection/components/datetime/test/custom/datetime.e2e.js +37 -37
- package/dist/collection/components/datetime/test/data.spec.js +456 -0
- package/dist/collection/components/datetime/test/datetime.e2e.js +29 -29
- package/dist/collection/components/datetime/test/disable-dates/datetime.e2e.js +119 -119
- package/dist/collection/components/datetime/test/disabled/datetime.e2e.js +43 -43
- package/dist/collection/components/datetime/test/disabled/datetime.spec.js +33 -0
- package/dist/collection/components/datetime/test/display/datetime.e2e.js +86 -86
- package/dist/collection/components/datetime/test/first-day-of-week/datetime.e2e.js +6 -6
- package/dist/collection/components/datetime/test/format.spec.js +124 -0
- package/dist/collection/components/datetime/test/helpers.spec.js +72 -0
- package/dist/collection/components/datetime/test/highlighted-dates/datetime.e2e.js +76 -76
- package/dist/collection/components/datetime/test/hour-cycle/datetime.e2e.js +21 -21
- package/dist/collection/components/datetime/test/locale/datetime.e2e.js +98 -98
- package/dist/collection/components/datetime/test/manipulation.spec.js +565 -0
- package/dist/collection/components/datetime/test/minmax/datetime.e2e.js +178 -178
- package/dist/collection/components/datetime/test/month-year-picker/datetime.e2e.js +17 -17
- package/dist/collection/components/datetime/test/multiple/datetime.e2e.js +170 -170
- package/dist/collection/components/datetime/test/parse.spec.js +222 -0
- package/dist/collection/components/datetime/test/position/datetime.e2e.js +14 -14
- package/dist/collection/components/datetime/test/prefer-wheel/datetime.e2e.js +263 -263
- package/dist/collection/components/datetime/test/prefer-wheel/datetime.spec.js +27 -0
- package/dist/collection/components/datetime/test/presentation/datetime.e2e.js +137 -137
- package/dist/collection/components/datetime/test/readonly/datetime.e2e.js +86 -86
- package/dist/collection/components/datetime/test/set-value/datetime.e2e.js +40 -40
- package/dist/collection/components/datetime/test/state.spec.js +114 -0
- package/dist/collection/components/datetime/test/time-label/datetime.e2e.js +13 -13
- package/dist/collection/components/datetime/test/values/datetime.e2e.js +77 -77
- package/dist/collection/components/datetime/utils/comparison.js +22 -22
- package/dist/collection/components/datetime/utils/data.js +394 -394
- package/dist/collection/components/datetime/utils/format.js +143 -143
- package/dist/collection/components/datetime/utils/helpers.js +74 -74
- package/dist/collection/components/datetime/utils/manipulation.js +332 -282
- package/dist/collection/components/datetime/utils/parse.js +139 -139
- package/dist/collection/components/datetime/utils/state.js +123 -123
- package/dist/collection/components/datetime-button/datetime-button.css +22 -0
- package/dist/collection/components/datetime-button/datetime-button.js +399 -399
- package/dist/collection/components/datetime-button/test/a11y/datetime-button.e2e.js +11 -11
- package/dist/collection/components/datetime-button/test/basic/datetime-button.e2e.js +123 -123
- package/dist/collection/components/datetime-button/test/disabled/datetime-button.e2e.js +13 -13
- package/dist/collection/components/datetime-button/test/multiple/datetime-button.e2e.js +38 -38
- package/dist/collection/components/datetime-button/test/overlays/datetime-button.e2e.js +102 -102
- package/dist/collection/components/fab/fab.css +88 -0
- package/dist/collection/components/fab/fab.js +179 -179
- package/dist/collection/components/fab/test/basic/fab.e2e.js +50 -50
- package/dist/collection/components/fab/test/custom-size/fab.e2e.js +6 -6
- package/dist/collection/components/fab/test/safe-area/fab.e2e.js +25 -25
- package/dist/collection/components/fab/test/states/fab.e2e.js +6 -6
- package/dist/collection/components/fab/test/translucent/fab.e2e.js +17 -17
- package/dist/collection/components/fab-button/fab-button.ios.css +44 -0
- package/dist/collection/components/fab-button/fab-button.js +374 -374
- package/dist/collection/components/fab-button/fab-button.md.css +44 -0
- package/dist/collection/components/fab-button/test/a11y/fab-button.e2e.js +6 -6
- package/dist/collection/components/fab-list/fab-list.css +44 -0
- package/dist/collection/components/fab-list/fab-list.js +79 -79
- package/dist/collection/components/footer/footer.ios.css +44 -0
- package/dist/collection/components/footer/footer.js +135 -135
- package/dist/collection/components/footer/footer.md.css +44 -0
- package/dist/collection/components/footer/footer.utils.js +25 -25
- package/dist/collection/components/footer/test/basic/footer.e2e.js +18 -18
- package/dist/collection/components/footer/test/fade/footer.e2e.js +10 -10
- package/dist/collection/components/footer/test/scroll-target/footer.e2e.js +15 -15
- package/dist/collection/components/footer/test/with-tabs/footer.e2e.js +6 -6
- package/dist/collection/components/grid/grid.css +66 -0
- package/dist/collection/components/grid/grid.js +44 -44
- package/dist/collection/components/grid/test/basic/grid.e2e.js +6 -6
- package/dist/collection/components/grid/test/offsets/grid.e2e.js +6 -6
- package/dist/collection/components/grid/test/padding/grid.e2e.js +6 -6
- package/dist/collection/components/grid/test/sizes/grid.e2e.js +6 -6
- package/dist/collection/components/header/header.ios.css +44 -0
- package/dist/collection/components/header/header.js +181 -181
- package/dist/collection/components/header/header.md.css +44 -0
- package/dist/collection/components/header/header.utils.js +148 -148
- package/dist/collection/components/header/test/a11y/header.e2e.js +18 -18
- package/dist/collection/components/header/test/basic/header.e2e.js +23 -23
- package/dist/collection/components/header/test/condense/header.e2e.js +25 -25
- package/dist/collection/components/header/test/fade/header.e2e.js +10 -10
- package/dist/collection/components/header/test/scroll-target/header.e2e.js +15 -15
- package/dist/collection/components/icon/test/basic/icon.e2e.js +6 -6
- package/dist/collection/components/icon/test/dir/icon.e2e.js +11 -11
- package/dist/collection/components/img/img.js +177 -177
- package/dist/collection/components/img/test/basic/img.e2e.js +62 -62
- package/dist/collection/components/img/test/draggable/img.e2e.js +10 -10
- package/dist/collection/components/infinite-scroll/infinite-scroll.js +279 -271
- package/dist/collection/components/infinite-scroll/test/basic/infinite-scroll.e2e.js +11 -11
- package/dist/collection/components/infinite-scroll/test/scroll-target/infinite-scroll.e2e.js +11 -11
- package/dist/collection/components/infinite-scroll/test/small-dom-update/infinite-scroll.e2e.js +31 -0
- package/dist/collection/components/infinite-scroll/test/top/infinite-scroll.e2e.js +11 -11
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +44 -0
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +86 -86
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +44 -0
- package/dist/collection/components/infinite-scroll-content/test/infinite-scroll-content.spec.js +37 -0
- package/dist/collection/components/input/input.ios.css +76 -3
- package/dist/collection/components/input/input.js +1250 -1204
- package/dist/collection/components/input/input.md.css +145 -12
- package/dist/collection/components/input/input.utils.js +22 -22
- package/dist/collection/components/input/test/a11y/input.e2e.js +12 -12
- package/dist/collection/components/input/test/basic/input.e2e.js +63 -63
- package/dist/collection/components/input/test/bottom-content/input.e2e.js +89 -89
- package/dist/collection/components/input/test/card/input.e2e.js +6 -6
- package/dist/collection/components/input/test/clear-on-edit/input.e2e.js +45 -25
- package/dist/collection/components/input/test/color/input.e2e.js +88 -88
- package/dist/collection/components/input/test/fill/input.e2e.js +63 -63
- package/dist/collection/components/input/test/highlight/input.e2e.js +52 -52
- package/dist/collection/components/input/test/input.e2e.js +6 -6
- package/dist/collection/components/input/test/input.spec.js +85 -0
- package/dist/collection/components/input/test/item/input.e2e.js +11 -11
- package/dist/collection/components/input/test/item/input.spec.js +24 -0
- package/dist/collection/components/input/test/label-placement/input.e2e.js +104 -104
- package/dist/collection/components/input/test/legacy/a11y/input.e2e.js +15 -15
- package/dist/collection/components/input/test/legacy/basic/input.e2e.js +102 -102
- package/dist/collection/components/input/test/legacy/clear-on-edit/input.e2e.js +44 -44
- package/dist/collection/components/input/test/legacy/input-events.e2e.js +56 -56
- package/dist/collection/components/input/test/legacy/masking/input.e2e.js +15 -15
- package/dist/collection/components/input/test/legacy/spec/input.e2e.js +8 -8
- package/dist/collection/components/input/test/slot/input.e2e.js +51 -0
- package/dist/collection/components/input/test/states/input.e2e.js +11 -11
- package/dist/collection/components/item/item.ios.css +85 -3
- package/dist/collection/components/item/item.js +614 -614
- package/dist/collection/components/item/item.md.css +129 -3
- package/dist/collection/components/item/test/a11y/item.e2e.js +47 -47
- package/dist/collection/components/item/test/a11y/item.spec.js +48 -0
- package/dist/collection/components/item/test/alignment/item.e2e.js +6 -6
- package/dist/collection/components/item/test/basic/item.e2e.js +16 -16
- package/dist/collection/components/item/test/buttons/item.e2e.js +18 -18
- package/dist/collection/components/item/test/colors/item.e2e.js +6 -6
- package/dist/collection/components/item/test/counter/item.e2e.js +34 -34
- package/dist/collection/components/item/test/css-variables/item.e2e.js +6 -6
- package/dist/collection/components/item/test/disabled/item.e2e.js +6 -7
- package/dist/collection/components/item/test/dividers/item.e2e.js +6 -6
- package/dist/collection/components/item/test/groups/item.e2e.js +8 -8
- package/dist/collection/components/item/test/highlight/item.e2e.js +6 -6
- package/dist/collection/components/item/test/icons/item.e2e.js +6 -6
- package/dist/collection/components/item/test/images/item.e2e.js +6 -6
- package/dist/collection/components/item/test/inputs/item.e2e.js +139 -139
- package/dist/collection/components/item/test/legacy/alignment/item.e2e.js +6 -6
- package/dist/collection/components/item/test/legacy/disabled/item.e2e.js +6 -6
- package/dist/collection/components/item/test/legacy/fill/item.e2e.js +6 -6
- package/dist/collection/components/item/test/legacy/form/item.e2e.js +6 -6
- package/dist/collection/components/item/test/lines/item.e2e.js +6 -6
- package/dist/collection/components/item/test/media/item.e2e.js +6 -6
- package/dist/collection/components/item/test/reorder/item.e2e.js +8 -8
- package/dist/collection/components/item/test/slotted-inputs/item.e2e.js +6 -6
- package/dist/collection/components/item/test/states/item.e2e.js +6 -6
- package/dist/collection/components/item-divider/item-divider.ios.css +66 -0
- package/dist/collection/components/item-divider/item-divider.js +71 -71
- package/dist/collection/components/item-divider/item-divider.md.css +66 -0
- package/dist/collection/components/item-divider/test/a11y/item-divider.e2e.js +11 -11
- package/dist/collection/components/item-divider/test/basic/item-divider.e2e.js +25 -25
- package/dist/collection/components/item-divider/test/spec/item-divider.e2e.js +8 -8
- package/dist/collection/components/item-group/item-group.ios.css +44 -0
- package/dist/collection/components/item-group/item-group.js +22 -22
- package/dist/collection/components/item-group/item-group.md.css +44 -0
- package/dist/collection/components/item-option/item-option.ios.css +44 -0
- package/dist/collection/components/item-option/item-option.js +197 -197
- package/dist/collection/components/item-option/item-option.md.css +44 -0
- package/dist/collection/components/item-options/item-options.ios.css +66 -0
- package/dist/collection/components/item-options/item-options.js +110 -110
- package/dist/collection/components/item-options/item-options.md.css +66 -0
- package/dist/collection/components/item-sliding/item-sliding.css +22 -0
- package/dist/collection/components/item-sliding/item-sliding.js +538 -538
- package/dist/collection/components/item-sliding/test/a11y/item-sliding.e2e.js +5 -5
- package/dist/collection/components/item-sliding/test/async/item-sliding.e2e.js +25 -25
- package/dist/collection/components/item-sliding/test/basic/item-sliding.e2e.js +87 -87
- package/dist/collection/components/item-sliding/test/icons/item-sliding.e2e.js +20 -20
- package/dist/collection/components/item-sliding/test/scroll-target/item-sliding.e2e.js +18 -18
- package/dist/collection/components/item-sliding/test/test.utils.js +20 -20
- package/dist/collection/components/label/label.ios.css +80 -3
- package/dist/collection/components/label/label.js +174 -174
- package/dist/collection/components/label/label.md.css +80 -3
- package/dist/collection/components/label/test/a11y/label.e2e.js +21 -21
- package/dist/collection/components/label/test/basic/label.e2e.js +21 -21
- package/dist/collection/components/label/test/color/label.e2e.js +21 -21
- package/dist/collection/components/label/test/headings/label.e2e.js +5 -5
- package/dist/collection/components/list/list.ios.css +66 -0
- package/dist/collection/components/list/list.js +101 -101
- package/dist/collection/components/list/list.md.css +66 -0
- package/dist/collection/components/list/test/a11y/list.e2e.js +6 -6
- package/dist/collection/components/list/test/basic/list.e2e.js +6 -6
- package/dist/collection/components/list/test/inset/list.e2e.js +16 -16
- package/dist/collection/components/list/test/lines/list.e2e.js +40 -40
- package/dist/collection/components/list-header/list-header.ios.css +66 -0
- package/dist/collection/components/list-header/list-header.js +69 -69
- package/dist/collection/components/list-header/list-header.md.css +66 -0
- package/dist/collection/components/list-header/test/a11y/list-header.e2e.js +6 -6
- package/dist/collection/components/list-header/test/basic/list-header.e2e.js +14 -14
- package/dist/collection/components/loading/animations/ios.enter.js +19 -19
- package/dist/collection/components/loading/animations/ios.leave.js +13 -13
- package/dist/collection/components/loading/animations/md.enter.js +19 -19
- package/dist/collection/components/loading/animations/md.leave.js +13 -13
- package/dist/collection/components/loading/loading.ios.css +44 -0
- package/dist/collection/components/loading/loading.js +730 -720
- package/dist/collection/components/loading/loading.md.css +44 -0
- package/dist/collection/components/loading/test/a11y/loading.e2e.js +26 -26
- package/dist/collection/components/loading/test/basic/loading.e2e.js +60 -60
- package/dist/collection/components/loading/test/basic/loading.spec.js +16 -0
- package/dist/collection/components/loading/test/is-open/loading.e2e.js +17 -17
- package/dist/collection/components/loading/test/loading-id.spec.js +32 -0
- package/dist/collection/components/loading/test/loading.spec.js +37 -0
- package/dist/collection/components/loading/test/standalone/loading.e2e.js +13 -13
- package/dist/collection/components/loading/test/trigger/loading.e2e.js +21 -21
- package/dist/collection/components/menu/menu.ios.css +47 -4
- package/dist/collection/components/menu/menu.js +956 -956
- package/dist/collection/components/menu/menu.md.css +47 -4
- package/dist/collection/components/menu/test/a11y/menu.e2e.js +13 -13
- package/dist/collection/components/menu/test/basic/menu.e2e.js +102 -102
- package/dist/collection/components/menu/test/custom/menu.e2e.js +61 -0
- package/dist/collection/components/menu/test/disable/menu.e2e.js +44 -44
- package/dist/collection/components/menu/test/focus-trap/menu.e2e.js +61 -61
- package/dist/collection/components/menu/test/multiple/menu.e2e.js +49 -49
- package/dist/collection/components/menu/test/safe-area/menu.e2e.js +54 -54
- package/dist/collection/components/menu-button/menu-button.ios.css +44 -0
- package/dist/collection/components/menu-button/menu-button.js +173 -173
- package/dist/collection/components/menu-button/menu-button.md.css +44 -0
- package/dist/collection/components/menu-button/test/a11y/menu-button.e2e.js +12 -12
- package/dist/collection/components/menu-button/test/async/menu-button.e2e.js +12 -12
- package/dist/collection/components/menu-button/test/basic/menu-button.e2e.js +6 -6
- package/dist/collection/components/menu-toggle/menu-toggle-util.js +2 -2
- package/dist/collection/components/menu-toggle/menu-toggle.js +93 -93
- package/dist/collection/components/menu-toggle/test/basic/menu-toggle.e2e.js +33 -33
- package/dist/collection/components/modal/animations/ios.enter.js +81 -81
- package/dist/collection/components/modal/animations/ios.leave.js +74 -74
- package/dist/collection/components/modal/animations/md.enter.js +21 -21
- package/dist/collection/components/modal/animations/md.leave.js +15 -15
- package/dist/collection/components/modal/animations/sheet.js +43 -43
- package/dist/collection/components/modal/gestures/sheet.js +289 -289
- package/dist/collection/components/modal/gestures/swipe-to-close.js +248 -247
- package/dist/collection/components/modal/gestures/utils.js +39 -39
- package/dist/collection/components/modal/modal.ios.css +44 -0
- package/dist/collection/components/modal/modal.js +1290 -1280
- package/dist/collection/components/modal/modal.md.css +44 -0
- package/dist/collection/components/modal/test/a11y/modal.e2e.js +12 -12
- package/dist/collection/components/modal/test/a11y/modal.spec.js +22 -0
- package/dist/collection/components/modal/test/basic/modal.e2e.js +110 -110
- package/dist/collection/components/modal/test/basic/modal.spec.js +16 -0
- package/dist/collection/components/modal/test/can-dismiss/modal-card.e2e.js +44 -44
- package/dist/collection/components/modal/test/can-dismiss/modal-sheet.e2e.js +62 -62
- package/dist/collection/components/modal/test/can-dismiss/modal.e2e.js +16 -16
- package/dist/collection/components/modal/test/can-dismiss/modal.spec.js +191 -0
- package/dist/collection/components/modal/test/card/modal-card.e2e.js +69 -69
- package/dist/collection/components/modal/test/card/modal-tablet.e2e.js +67 -67
- package/dist/collection/components/modal/test/card-nav/modal.e2e.js +26 -26
- package/dist/collection/components/modal/test/card-refresher/modal.e2e.js +14 -14
- package/dist/collection/components/modal/test/card-scroll-target/modal.e2e.js +34 -34
- package/dist/collection/components/modal/test/custom/modal.e2e.js +16 -16
- package/dist/collection/components/modal/test/custom-dialog/modal.e2e.js +12 -12
- package/dist/collection/components/modal/test/dark-mode/model.e2e.js +12 -12
- package/dist/collection/components/modal/test/fixtures.js +21 -21
- package/dist/collection/components/modal/test/inline/modal.e2e.js +34 -34
- package/dist/collection/components/modal/test/is-open/modal.e2e.js +17 -17
- package/dist/collection/components/modal/test/modal-id.spec.js +32 -0
- package/dist/collection/components/modal/test/sheet/modal.e2e.js +178 -178
- package/dist/collection/components/modal/test/standalone/modal.e2e.js +12 -12
- package/dist/collection/components/modal/test/trigger/modal.e2e.js +23 -23
- package/dist/collection/components/modal/utils.js +55 -55
- package/dist/collection/components/modal/utils.spec.js +7 -7
- package/dist/collection/components/nav/nav.css +22 -0
- package/dist/collection/components/nav/nav.js +1748 -1748
- package/dist/collection/components/nav/test/basic/nav.e2e.js +58 -58
- package/dist/collection/components/nav/test/modal-navigation/nav.e2e.js +52 -52
- package/dist/collection/components/nav/test/nav-controller.spec.js +749 -0
- package/dist/collection/components/nav/test/nested/nav.e2e.js +54 -54
- package/dist/collection/components/nav/test/routing/nav.e2e.js +75 -75
- package/dist/collection/components/nav/view-controller.js +52 -52
- package/dist/collection/components/nav-link/nav-link-utils.js +16 -16
- package/dist/collection/components/nav-link/nav-link.js +106 -106
- package/dist/collection/components/note/note.ios.css +44 -0
- package/dist/collection/components/note/note.js +49 -49
- package/dist/collection/components/note/note.md.css +44 -0
- package/dist/collection/components/note/test/a11y/note.e2e.js +59 -16
- package/dist/collection/components/note/test/basic/note.e2e.js +33 -33
- package/dist/collection/components/picker/animations/ios.enter.js +18 -18
- package/dist/collection/components/picker/animations/ios.leave.js +14 -14
- package/dist/collection/components/picker/picker.ios.css +44 -0
- package/dist/collection/components/picker/picker.js +782 -772
- package/dist/collection/components/picker/picker.md.css +44 -0
- package/dist/collection/components/picker/test/basic/picker.e2e.js +17 -17
- package/dist/collection/components/picker/test/is-open/picker.e2e.js +17 -17
- package/dist/collection/components/picker/test/picker-id.spec.js +32 -0
- package/dist/collection/components/picker/test/trigger/picker.e2e.js +21 -21
- package/dist/collection/components/picker-column/picker-column.ios.css +44 -0
- package/dist/collection/components/picker-column/picker-column.js +377 -377
- package/dist/collection/components/picker-column/picker-column.md.css +44 -0
- package/dist/collection/components/picker-column/test/picker-column-aria.spec.js +35 -0
- package/dist/collection/components/picker-column/test/picker-column-dynamic.spec.js +29 -0
- package/dist/collection/components/picker-column/test/picker-column.spec.js +17 -0
- package/dist/collection/components/picker-column/test/standalone/picker-column.e2e.js +27 -27
- package/dist/collection/components/picker-column/test/test.utils.js +29 -29
- package/dist/collection/components/picker-column-internal/picker-column-internal.ios.css +33 -3
- package/dist/collection/components/picker-column-internal/picker-column-internal.js +523 -501
- package/dist/collection/components/picker-column-internal/picker-column-internal.md.css +55 -3
- package/dist/collection/components/picker-column-internal/test/basic/picker-column-internal.e2e.js +53 -53
- package/dist/collection/components/picker-column-internal/test/disabled/picker-column-internal.e2e.js +66 -37
- package/dist/collection/components/picker-internal/picker-internal.ios.css +44 -0
- package/dist/collection/components/picker-internal/picker-internal.js +517 -517
- package/dist/collection/components/picker-internal/picker-internal.md.css +44 -0
- package/dist/collection/components/picker-internal/test/a11y/picker-internal.e2e.js +6 -6
- package/dist/collection/components/picker-internal/test/basic/picker-internal.e2e.js +76 -76
- package/dist/collection/components/picker-internal/test/keyboard-entry/picker-internal.e2e.js +39 -39
- package/dist/collection/components/popover/animations/ios.enter.js +79 -79
- package/dist/collection/components/popover/animations/ios.leave.js +28 -28
- package/dist/collection/components/popover/animations/md.enter.js +58 -58
- package/dist/collection/components/popover/animations/md.leave.js +19 -19
- package/dist/collection/components/popover/popover.ios.css +44 -0
- package/dist/collection/components/popover/popover.js +1189 -1179
- package/dist/collection/components/popover/popover.md.css +44 -0
- package/dist/collection/components/popover/test/adjustment/popover.e2e.js +22 -22
- package/dist/collection/components/popover/test/arrow/popover.e2e.js +15 -15
- package/dist/collection/components/popover/test/async/popover.e2e.js +29 -29
- package/dist/collection/components/popover/test/basic/popover.e2e.js +108 -108
- package/dist/collection/components/popover/test/basic/popover.spec.js +16 -0
- package/dist/collection/components/popover/test/dismiss-on-select/popover.e2e.js +26 -26
- package/dist/collection/components/popover/test/fixture.js +16 -16
- package/dist/collection/components/popover/test/inline/popover.e2e.js +18 -18
- package/dist/collection/components/popover/test/is-open/popover.e2e.js +5 -5
- package/dist/collection/components/popover/test/nested/popover.e2e.js +81 -81
- package/dist/collection/components/popover/test/popover-id.spec.js +32 -0
- package/dist/collection/components/popover/test/position/popover.e2e.js +18 -18
- package/dist/collection/components/popover/test/reference/popover.e2e.js +14 -14
- package/dist/collection/components/popover/test/size/popover.e2e.js +29 -29
- package/dist/collection/components/popover/test/standalone/popover.e2e.js +7 -7
- package/dist/collection/components/popover/test/test.utils.js +23 -23
- package/dist/collection/components/popover/test/trigger/popover.e2e.js +35 -35
- package/dist/collection/components/popover/test/util.spec.js +53 -0
- package/dist/collection/components/popover/utils.js +606 -606
- package/dist/collection/components/progress-bar/progress-bar.ios.css +22 -0
- package/dist/collection/components/progress-bar/progress-bar.js +145 -145
- package/dist/collection/components/progress-bar/progress-bar.md.css +22 -0
- package/dist/collection/components/progress-bar/test/basic/progress-bar.e2e.js +6 -6
- package/dist/collection/components/progress-bar/test/buffer/progress-bar.e2e.js +10 -10
- package/dist/collection/components/progress-bar/test/determinate/progress-bar.e2e.js +10 -10
- package/dist/collection/components/radio/radio.ios.css +66 -6
- package/dist/collection/components/radio/radio.js +453 -449
- package/dist/collection/components/radio/radio.md.css +66 -6
- package/dist/collection/components/radio/test/a11y/radio.e2e.js +41 -40
- package/dist/collection/components/radio/test/color/radio.e2e.js +11 -11
- package/dist/collection/components/radio/test/item/radio.e2e.js +37 -37
- package/dist/collection/components/radio/test/label-placement/radio.e2e.js +70 -70
- package/dist/collection/components/radio/test/legacy/a11y/radio.e2e.js +29 -29
- package/dist/collection/components/radio/test/legacy/basic/radio.e2e.js +43 -43
- package/dist/collection/components/radio/test/radio.spec.js +60 -0
- package/dist/collection/components/radio/test/states/radio.e2e.js +21 -21
- package/dist/collection/components/radio-group/radio-group.js +279 -255
- package/dist/collection/components/radio-group/test/basic/radio-group.e2e.js +35 -35
- package/dist/collection/components/radio-group/test/fixtures.js +22 -22
- package/dist/collection/components/radio-group/test/form/radio-group.e2e.js +39 -39
- package/dist/collection/components/radio-group/test/legacy/basic/radio-group.e2e.js +59 -59
- package/dist/collection/components/radio-group/test/legacy/form/radio-group.e2e.js +22 -22
- package/dist/collection/components/radio-group/test/legacy/search/radio-group.e2e.js +27 -27
- package/dist/collection/components/radio-group/test/radio-group-events.e2e.js +42 -42
- package/dist/collection/components/radio-group/test/radio-group.spec.js +69 -0
- package/dist/collection/components/radio-group/test/search/radio-group.e2e.js +23 -23
- package/dist/collection/components/range/range.ios.css +44 -6
- package/dist/collection/components/range/range.js +1001 -998
- package/dist/collection/components/range/range.md.css +44 -6
- package/dist/collection/components/range/test/a11y/range.e2e.js +46 -46
- package/dist/collection/components/range/test/active-bar-start/range.e2e.js +6 -6
- package/dist/collection/components/range/test/basic/range.e2e.js +23 -23
- package/dist/collection/components/range/test/color/range.e2e.js +6 -6
- package/dist/collection/components/range/test/custom/range.e2e.js +6 -6
- package/dist/collection/components/range/test/item/range.e2e.js +28 -28
- package/dist/collection/components/range/test/label/range.e2e.js +99 -99
- package/dist/collection/components/range/test/label/range.spec.js +23 -0
- package/dist/collection/components/range/test/legacy/a11y/range.e2e.js +25 -25
- package/dist/collection/components/range/test/legacy/active-bar-start/range.e2e.js +6 -6
- package/dist/collection/components/range/test/legacy/basic/range.e2e.js +61 -61
- package/dist/collection/components/range/test/legacy/range-events.e2e.js +80 -80
- package/dist/collection/components/range/test/legacy/scroll-target/range.e2e.js +23 -23
- package/dist/collection/components/range/test/range-events.e2e.js +135 -135
- package/dist/collection/components/range/test/range.spec.js +221 -0
- package/dist/collection/components/range/test/scroll-target/range.e2e.js +23 -23
- package/dist/collection/components/range/test/states/range.e2e.js +21 -21
- package/dist/collection/components/refresher/refresher.ios.css +44 -0
- package/dist/collection/components/refresher/refresher.js +806 -806
- package/dist/collection/components/refresher/refresher.md.css +44 -0
- package/dist/collection/components/refresher/refresher.utils.js +148 -148
- package/dist/collection/components/refresher/test/basic/refresher.e2e.js +25 -25
- package/dist/collection/components/refresher/test/scroll-target/refresher.e2e.js +25 -25
- package/dist/collection/components/refresher/test/test.utils.js +5 -5
- package/dist/collection/components/refresher-content/refresher-content.js +131 -131
- package/dist/collection/components/refresher-content/test/refresher-content.spec.js +46 -0
- package/dist/collection/components/reorder/reorder.ios.css +22 -0
- package/dist/collection/components/reorder/reorder.js +37 -37
- package/dist/collection/components/reorder/reorder.md.css +22 -0
- package/dist/collection/components/reorder-group/reorder-group.css +22 -0
- package/dist/collection/components/reorder-group/reorder-group.js +327 -327
- package/dist/collection/components/reorder-group/test/a11y/reorder-group.e2e.js +6 -6
- package/dist/collection/components/reorder-group/test/basic/reorder-group.e2e.js +11 -11
- package/dist/collection/components/reorder-group/test/interactive/reorder-group.e2e.js +21 -21
- package/dist/collection/components/reorder-group/test/nested/reorder-group.e2e.js +21 -21
- package/dist/collection/components/reorder-group/test/scroll-target/reorder-group.e2e.js +21 -21
- package/dist/collection/components/ripple-effect/ripple-effect.css +22 -0
- package/dist/collection/components/ripple-effect/ripple-effect.js +135 -135
- package/dist/collection/components/ripple-effect/test/basic/ripple-effect.e2e.js +48 -48
- package/dist/collection/components/route/route.js +151 -151
- package/dist/collection/components/route-redirect/route-redirect.js +76 -76
- package/dist/collection/components/router/router.js +472 -472
- package/dist/collection/components/router/test/basic/router.e2e.js +55 -55
- package/dist/collection/components/router/test/guards/href/router.e2e.js +51 -51
- package/dist/collection/components/router/test/guards/link/router.e2e.js +51 -51
- package/dist/collection/components/router/test/guards/push/router.e2e.js +51 -51
- package/dist/collection/components/router/test/guards/router.e2e.js +5 -5
- package/dist/collection/components/router/test/guards/test.utils.js +2 -2
- package/dist/collection/components/router/test/matching.spec.js +250 -0
- package/dist/collection/components/router/test/parser.spec.js +133 -0
- package/dist/collection/components/router/test/path.spec.js +218 -0
- package/dist/collection/components/router/test/router.spec.js +55 -0
- package/dist/collection/components/router/utils/debug.js +14 -14
- package/dist/collection/components/router/utils/dom.js +56 -56
- package/dist/collection/components/router/utils/matching.js +150 -150
- package/dist/collection/components/router/utils/parser.js +52 -52
- package/dist/collection/components/router/utils/path.js +66 -66
- package/dist/collection/components/router-link/router-link.css +22 -0
- package/dist/collection/components/router-link/router-link.js +157 -157
- package/dist/collection/components/router-outlet/router-outlet.css +22 -0
- package/dist/collection/components/router-outlet/router-outlet.js +459 -459
- package/dist/collection/components/router-outlet/test/basic/router-outlet.e2e.js +31 -31
- package/dist/collection/components/row/row.css +66 -0
- package/dist/collection/components/row/row.js +15 -15
- package/dist/collection/components/searchbar/searchbar.ios.css +44 -0
- package/dist/collection/components/searchbar/searchbar.js +891 -889
- package/dist/collection/components/searchbar/searchbar.md.css +44 -0
- package/dist/collection/components/searchbar/test/a11y/searchbar.e2e.js +11 -11
- package/dist/collection/components/searchbar/test/basic/searchbar.e2e.js +101 -101
- package/dist/collection/components/searchbar/test/events/searchbar.e2e.js +55 -55
- package/dist/collection/components/searchbar/test/searchbar.spec.js +15 -0
- package/dist/collection/components/segment/segment.ios.css +66 -0
- package/dist/collection/components/segment/segment.js +631 -631
- package/dist/collection/components/segment/segment.md.css +66 -0
- package/dist/collection/components/segment/test/a11y/segment.e2e.js +37 -37
- package/dist/collection/components/segment/test/basic/segment.e2e.js +22 -22
- package/dist/collection/components/segment/test/custom/segment.e2e.js +6 -6
- package/dist/collection/components/segment/test/icon/segment.e2e.js +6 -6
- package/dist/collection/components/segment/test/modes/segment.e2e.js +15 -15
- package/dist/collection/components/segment/test/scrollable/segment.e2e.js +12 -12
- package/dist/collection/components/segment/test/segment-events.e2e.js +97 -97
- package/dist/collection/components/segment/test/segment.spec.js +37 -0
- package/dist/collection/components/segment/test/toolbar/segment.e2e.js +21 -21
- package/dist/collection/components/segment/test/wrap/segment.e2e.js +21 -21
- package/dist/collection/components/segment-button/segment-button.ios.css +44 -0
- package/dist/collection/components/segment-button/segment-button.js +217 -217
- package/dist/collection/components/segment-button/segment-button.md.css +44 -0
- package/dist/collection/components/select/select.ios.css +126 -7
- package/dist/collection/components/select/select.js +1201 -1184
- package/dist/collection/components/select/select.md.css +173 -19
- package/dist/collection/components/select/test/a11y/select.e2e.js +14 -14
- package/dist/collection/components/select/test/async/select.e2e.js +14 -14
- package/dist/collection/components/select/test/basic/select.e2e.js +140 -140
- package/dist/collection/components/select/test/card/select.e2e.js +6 -6
- package/dist/collection/components/select/test/color/select.e2e.js +22 -22
- package/dist/collection/components/select/test/compare-with/select.e2e.js +33 -33
- package/dist/collection/components/select/test/custom/select.e2e.js +19 -19
- package/dist/collection/components/select/test/disabled/select.e2e.js +17 -17
- package/dist/collection/components/select/test/fill/select.e2e.js +63 -63
- package/dist/collection/components/select/test/highlight/select.e2e.js +74 -74
- package/dist/collection/components/select/test/item/select.e2e.js +26 -11
- package/dist/collection/components/select/test/label/select.e2e.js +141 -141
- package/dist/collection/components/select/test/legacy/async/select.e2e.js +8 -8
- package/dist/collection/components/select/test/legacy/basic/select.e2e.js +108 -108
- package/dist/collection/components/select/test/legacy/compare-with/select.e2e.js +33 -33
- package/dist/collection/components/select/test/legacy/custom/custom.e2e.js +5 -5
- package/dist/collection/components/select/test/legacy/single-value/select.e2e.js +8 -8
- package/dist/collection/components/select/test/legacy/spec/select.e2e.js +6 -6
- package/dist/collection/components/select/test/legacy/standalone/select.e2e.js +11 -11
- package/dist/collection/components/select/test/legacy/wrapping/select.e2e.js +17 -17
- package/dist/collection/components/select/test/popover-size/select.e2e.js +63 -63
- package/dist/collection/components/select/test/select.spec.js +59 -0
- package/dist/collection/components/select/test/slot/select.e2e.js +67 -0
- package/dist/collection/components/select/test/states/select.e2e.js +21 -21
- package/dist/collection/components/select/test/toggle-icon/select.e2e.js +14 -14
- package/dist/collection/components/select/test/wrapping/select.e2e.js +16 -16
- package/dist/collection/components/select-option/select-option.js +60 -60
- package/dist/collection/components/select-popover/select-popover.ios.css +66 -0
- package/dist/collection/components/select-popover/select-popover.js +197 -197
- package/dist/collection/components/select-popover/select-popover.md.css +66 -0
- package/dist/collection/components/select-popover/test/basic/select-popover.e2e.js +52 -52
- package/dist/collection/components/select-popover/test/fixtures.js +33 -33
- package/dist/collection/components/skeleton-text/skeleton-text.css +22 -0
- package/dist/collection/components/skeleton-text/skeleton-text.js +87 -48
- package/dist/collection/components/skeleton-text/test/basic/skeleton-text.e2e.js +6 -6
- package/dist/collection/components/skeleton-text/test/custom/skeleton-text.e2e.js +6 -6
- package/dist/collection/components/slides/IonicSlides.js +95 -95
- package/dist/collection/components/spinner/spinner-configs.js +121 -121
- package/dist/collection/components/spinner/spinner.css +22 -0
- package/dist/collection/components/spinner/spinner.js +137 -137
- package/dist/collection/components/spinner/test/basic/spinner.e2e.js +10 -10
- package/dist/collection/components/spinner/test/color/spinner.e2e.js +10 -10
- package/dist/collection/components/spinner/test/resize/spinner.e2e.js +8 -8
- package/dist/collection/components/split-pane/split-pane.ios.css +67 -2
- package/dist/collection/components/split-pane/split-pane.js +225 -225
- package/dist/collection/components/split-pane/split-pane.md.css +67 -2
- package/dist/collection/components/split-pane/test/basic/split-pane.e2e.js +18 -18
- package/dist/collection/components/split-pane/test/multiple/split-pane.e2e.js +23 -23
- package/dist/collection/components/tab/tab.js +170 -170
- package/dist/collection/components/tab-bar/tab-bar.ios.css +66 -0
- package/dist/collection/components/tab-bar/tab-bar.js +177 -177
- package/dist/collection/components/tab-bar/tab-bar.md.css +66 -0
- package/dist/collection/components/tab-bar/test/basic/tab-bar.e2e.js +8 -8
- package/dist/collection/components/tab-bar/test/custom/tab-bar.e2e.js +6 -6
- package/dist/collection/components/tab-bar/test/translucent/tab-bar.e2e.js +14 -14
- package/dist/collection/components/tab-button/tab-button.ios.css +44 -0
- package/dist/collection/components/tab-button/tab-button.js +267 -267
- package/dist/collection/components/tab-button/tab-button.md.css +44 -0
- package/dist/collection/components/tab-button/test/a11y/tab-button.e2e.js +6 -6
- package/dist/collection/components/tab-button/test/basic/tab-button.e2e.js +16 -16
- package/dist/collection/components/tab-button/test/layout/tab-button.e2e.js +26 -26
- package/dist/collection/components/tab-button/test/states/tab-button.e2e.js +26 -26
- package/dist/collection/components/tabs/tabs.css +22 -0
- package/dist/collection/components/tabs/tabs.js +344 -344
- package/dist/collection/components/tabs/test/basic/tabs.e2e.js +24 -24
- package/dist/collection/components/tabs/test/placements/tabs.e2e.js +17 -17
- package/dist/collection/components/text/test/basic/text.e2e.js +11 -11
- package/dist/collection/components/text/text.css +22 -0
- package/dist/collection/components/text/text.js +47 -47
- package/dist/collection/components/textarea/test/a11y/textarea.e2e.js +12 -12
- package/dist/collection/components/textarea/test/autogrow/textarea.e2e.js +31 -31
- package/dist/collection/components/textarea/test/bottom-content/textarea.e2e.js +82 -82
- package/dist/collection/components/textarea/test/card/textarea.e2e.js +6 -6
- package/dist/collection/components/textarea/test/clear-on-edit/textarea.e2e.js +53 -17
- package/dist/collection/components/textarea/test/color/textarea.e2e.js +88 -88
- package/dist/collection/components/textarea/test/cols/textarea.e2e.js +11 -11
- package/dist/collection/components/textarea/test/fill/textarea.e2e.js +63 -63
- package/dist/collection/components/textarea/test/highlight/textarea.e2e.js +52 -52
- package/dist/collection/components/textarea/test/item/textarea.e2e.js +11 -11
- package/dist/collection/components/textarea/test/label-placement/textarea.e2e.js +150 -150
- package/dist/collection/components/textarea/test/legacy/a11y/textarea.e2e.js +15 -15
- package/dist/collection/components/textarea/test/legacy/autogrow/textarea.e2e.js +31 -31
- package/dist/collection/components/textarea/test/legacy/basic/textarea.e2e.js +30 -30
- package/dist/collection/components/textarea/test/legacy/clear-on-edit/textarea.e2e.js +17 -17
- package/dist/collection/components/textarea/test/slot/textarea.e2e.js +51 -0
- package/dist/collection/components/textarea/test/states/textarea.e2e.js +11 -11
- package/dist/collection/components/textarea/test/textarea-events.e2e.js +57 -57
- package/dist/collection/components/textarea/test/textarea.spec.js +59 -0
- package/dist/collection/components/textarea/textarea.ios.css +125 -5
- package/dist/collection/components/textarea/textarea.js +1069 -1019
- package/dist/collection/components/textarea/textarea.md.css +179 -14
- package/dist/collection/components/thumbnail/test/basic/thumbnail.e2e.js +28 -28
- package/dist/collection/components/thumbnail/thumbnail.css +22 -0
- package/dist/collection/components/thumbnail/thumbnail.js +15 -15
- package/dist/collection/components/title/test/a11y/title.e2e.js +17 -17
- package/dist/collection/components/title/test/basic/title.e2e.js +13 -13
- package/dist/collection/components/title/title.ios.css +22 -0
- package/dist/collection/components/title/title.js +119 -119
- package/dist/collection/components/title/title.md.css +22 -0
- package/dist/collection/components/toast/animations/ios.enter.js +21 -20
- package/dist/collection/components/toast/animations/ios.leave.js +18 -18
- package/dist/collection/components/toast/animations/md.enter.js +23 -22
- package/dist/collection/components/toast/animations/md.leave.js +6 -6
- package/dist/collection/components/toast/animations/utils.js +62 -56
- package/dist/collection/components/toast/gestures/swipe-to-dismiss.js +267 -0
- package/dist/collection/components/toast/test/a11y/toast.e2e.js +92 -92
- package/dist/collection/components/toast/test/basic/toast.e2e.js +101 -101
- package/dist/collection/components/toast/test/is-open/toast.e2e.js +17 -17
- package/dist/collection/components/toast/test/layout/toast.e2e.js +9 -9
- package/dist/collection/components/toast/test/position-anchor/toast.e2e.js +37 -37
- package/dist/collection/components/toast/test/standalone/toast.e2e.js +10 -10
- package/dist/collection/components/toast/test/swipe-gesture/toast.e2e.js +84 -0
- package/dist/collection/components/toast/test/toast-config.spec.js +25 -0
- package/dist/collection/components/toast/test/toast-id.spec.js +32 -0
- package/dist/collection/components/toast/test/toast.spec.js +200 -0
- package/dist/collection/components/toast/test/trigger/toast.e2e.js +21 -21
- package/dist/collection/components/toast/toast.ios.css +54 -10
- package/dist/collection/components/toast/toast.js +1065 -952
- package/dist/collection/components/toast/toast.md.css +54 -0
- package/dist/collection/components/toggle/test/a11y/toggle.e2e.js +6 -6
- package/dist/collection/components/toggle/test/color/toggle.e2e.js +11 -11
- package/dist/collection/components/toggle/test/enable-on-off-labels/toggle.e2e.js +27 -27
- package/dist/collection/components/toggle/test/item/toggle.e2e.js +52 -52
- package/dist/collection/components/toggle/test/label/toggle.e2e.js +65 -65
- package/dist/collection/components/toggle/test/legacy/basic/toggle.e2e.js +69 -69
- package/dist/collection/components/toggle/test/legacy/enable-on-off-labels/toggle.e2e.js +23 -23
- package/dist/collection/components/toggle/test/legacy/sizes/toggle.e2e.js +6 -6
- package/dist/collection/components/toggle/test/sizes/toggle.e2e.js +6 -6
- package/dist/collection/components/toggle/test/states/toggle.e2e.js +16 -16
- package/dist/collection/components/toggle/test/toggle.spec.js +67 -0
- package/dist/collection/components/toggle/toggle.ios.css +66 -6
- package/dist/collection/components/toggle/toggle.js +487 -484
- package/dist/collection/components/toggle/toggle.md.css +66 -6
- package/dist/collection/components/toolbar/test/basic/toolbar.e2e.js +7 -7
- package/dist/collection/components/toolbar/test/colors/toolbar.e2e.js +6 -6
- package/dist/collection/components/toolbar/toolbar.ios.css +44 -0
- package/dist/collection/components/toolbar/toolbar.js +100 -100
- package/dist/collection/components/toolbar/toolbar.md.css +44 -0
- package/dist/collection/css/test/a11y/typography.e2e.js +6 -6
- package/dist/collection/global/config.js +51 -51
- package/dist/collection/global/ionic-global.js +54 -54
- package/dist/collection/global/test/config-controller.spec.js +77 -0
- package/dist/collection/utils/animation/animation-utils.js +91 -91
- package/dist/collection/utils/animation/animation.js +905 -904
- package/dist/collection/utils/animation/cubic-bezier.js +49 -49
- package/dist/collection/utils/animation/test/animation.spec.js +447 -0
- package/dist/collection/utils/animation/test/animationbuilder/animation.e2e.js +26 -26
- package/dist/collection/utils/animation/test/basic/animation.e2e.js +12 -12
- package/dist/collection/utils/animation/test/display/animation.e2e.js +18 -18
- package/dist/collection/utils/animation/test/hooks/animation.e2e.js +39 -39
- package/dist/collection/utils/animation/test/multiple/animation.e2e.js +27 -27
- package/dist/collection/utils/browser/index.js +0 -22
- package/dist/collection/utils/config.js +20 -20
- package/dist/collection/utils/content/content.utils.spec.js +121 -121
- package/dist/collection/utils/content/index.js +58 -58
- package/dist/collection/utils/floating-point/floating-point.spec.js +14 -14
- package/dist/collection/utils/floating-point/index.js +5 -5
- package/dist/collection/utils/focus-visible.js +63 -63
- package/dist/collection/utils/forms/compare-with-utils.js +39 -0
- package/dist/collection/utils/forms/form-controller.js +45 -45
- package/dist/collection/utils/forms/index.js +1 -0
- package/dist/collection/utils/forms/notch-controller.js +120 -120
- package/dist/collection/utils/framework-delegate.js +121 -121
- package/dist/collection/utils/gesture/button-active.js +56 -56
- package/dist/collection/utils/gesture/gesture-controller.js +182 -182
- package/dist/collection/utils/gesture/index.js +222 -222
- package/dist/collection/utils/gesture/listener.js +36 -36
- package/dist/collection/utils/gesture/pointer-events.js +113 -113
- package/dist/collection/utils/gesture/recognizers.js +46 -46
- package/dist/collection/utils/gesture/swipe-back.js +65 -65
- package/dist/collection/utils/hardware-back-button.js +48 -48
- package/dist/collection/utils/helpers.js +258 -258
- package/dist/collection/utils/helpers.spec.js +28 -28
- package/dist/collection/utils/input-shims/hacks/common.js +61 -61
- package/dist/collection/utils/input-shims/hacks/hide-caret.js +19 -19
- package/dist/collection/utils/input-shims/hacks/input-blurring.js +47 -47
- package/dist/collection/utils/input-shims/hacks/scroll-assist.js +225 -225
- package/dist/collection/utils/input-shims/hacks/scroll-data.js +29 -29
- package/dist/collection/utils/input-shims/hacks/scroll-padding.js +21 -21
- package/dist/collection/utils/input-shims/hacks/test/scroll-assist.e2e.js +97 -97
- package/dist/collection/utils/input-shims/input-shims.js +87 -81
- package/dist/collection/utils/keyboard/keyboard-controller.js +128 -128
- package/dist/collection/utils/keyboard/keyboard.js +59 -59
- package/dist/collection/utils/keyboard/test/keyboard-controller.spec.js +21 -0
- package/dist/collection/utils/keyboard/test/keyboard.spec.js +214 -0
- package/dist/collection/utils/lock-controller.js +24 -24
- package/dist/collection/utils/logging/index.js +3 -3
- package/dist/collection/utils/media.js +13 -13
- package/dist/collection/utils/menu-controller/animations/base.js +8 -8
- package/dist/collection/utils/menu-controller/animations/overlay.js +21 -21
- package/dist/collection/utils/menu-controller/animations/push.js +20 -20
- package/dist/collection/utils/menu-controller/animations/reveal.js +6 -6
- package/dist/collection/utils/menu-controller/index.js +204 -206
- package/dist/collection/utils/native/capacitor.js +4 -4
- package/dist/collection/utils/native/haptic.js +151 -151
- package/dist/collection/utils/native/keyboard.js +47 -47
- package/dist/collection/utils/native/native-interface.js +15 -15
- package/dist/collection/utils/native/status-bar.js +36 -36
- package/dist/collection/utils/overlays.js +495 -494
- package/dist/collection/utils/platform.js +56 -56
- package/dist/collection/utils/rtl/dir.js +5 -5
- package/dist/collection/utils/rtl/dir.spec.js +17 -17
- package/dist/collection/utils/sanitization/index.js +122 -122
- package/dist/collection/utils/sanitization/test/sanitization.spec.js +43 -0
- package/dist/collection/utils/slot-mutation-controller.js +86 -85
- package/dist/collection/utils/status-tap.js +26 -26
- package/dist/collection/utils/tap-click/index.js +171 -171
- package/dist/collection/utils/tap-click/test/tap-click.e2e.js +12 -12
- package/dist/collection/utils/test/aria.spec.js +79 -0
- package/dist/collection/utils/test/attributes.spec.js +53 -0
- package/dist/collection/utils/test/framework-delegate/framework-delegate.e2e.js +25 -25
- package/dist/collection/utils/test/hardware-back-button.spec.js +53 -0
- package/dist/collection/utils/test/overlays/overlays.e2e.js +137 -137
- package/dist/collection/utils/test/overlays/overlays.spec.js +102 -0
- package/dist/collection/utils/test/platform.spec.js +132 -0
- package/dist/collection/utils/test/platform.utils.js +77 -77
- package/dist/collection/utils/test/playwright/drag-element.js +69 -69
- package/dist/collection/utils/test/playwright/generator.js +48 -25
- package/dist/collection/utils/test/playwright/matchers/index.js +3 -3
- package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEvent.js +21 -21
- package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventDetail.js +28 -28
- package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventTimes.js +22 -22
- package/dist/collection/utils/test/playwright/page/event-spy.js +110 -110
- package/dist/collection/utils/test/playwright/page/utils/goto.js +52 -52
- package/dist/collection/utils/test/playwright/page/utils/locator.js +8 -8
- package/dist/collection/utils/test/playwright/page/utils/set-content.js +44 -35
- package/dist/collection/utils/test/playwright/page/utils/set-ion-viewport.js +19 -19
- package/dist/collection/utils/test/playwright/page/utils/spy-on-event.js +4 -4
- package/dist/collection/utils/test/playwright/page/utils/wait-for-changes.js +48 -48
- package/dist/collection/utils/test/playwright/playwright-page.js +35 -35
- package/dist/collection/utils/test/playwright/viewports/index.js +13 -13
- package/dist/collection/utils/test/press-keys.js +77 -77
- package/dist/collection/utils/test/ready.spec.js +39 -0
- package/dist/collection/utils/test/theme.spec.js +56 -0
- package/dist/collection/utils/theme.js +23 -23
- package/dist/collection/utils/transition/index.js +163 -163
- package/dist/collection/utils/transition/ios.transition.js +598 -598
- package/dist/collection/utils/transition/md.transition.js +44 -44
- package/dist/collection/utils/watch-options.js +30 -30
- package/dist/docs.json +195 -38
- package/dist/esm/animation-dde8cc0d.js +1060 -0
- package/dist/esm/{app-globals-2398e405.js → app-globals-8c62bec2.js} +1 -1
- package/dist/esm/button-active-308d3edd.js +67 -0
- package/dist/esm/capacitor-59395cbd.js +13 -0
- package/dist/esm/compare-with-utils-a96ff2ea.js +41 -0
- package/dist/esm/config-49c88215.js +193 -0
- package/dist/esm/cubic-bezier-fe2083dc.js +90 -0
- package/dist/esm/data-775093f5.js +1625 -0
- package/dist/esm/{dir-912e3e13.js → dir-babeabeb.js} +5 -5
- package/dist/esm/focus-visible-dd40d69f.js +75 -0
- package/dist/esm/form-controller-548aa79c.js +64 -0
- package/dist/esm/framework-delegate-bc1fd82a.js +140 -0
- package/dist/esm/gesture-controller-1bf57181.js +195 -0
- package/dist/esm/haptic-554688a5.js +206 -0
- package/dist/esm/hardware-back-button-b2bc76db.js +71 -0
- package/dist/esm/helpers-ae653409.js +418 -0
- package/dist/esm/index-1193f005.js +306 -0
- package/dist/esm/index-2cf77112.js +457 -0
- package/dist/esm/index-4743453d.js +231 -0
- package/dist/esm/index-82eeb47f.js +196 -0
- package/dist/esm/{index-595d62c9.js → index-9b0d46f4.js} +3 -3
- package/dist/esm/index-a5d50daf.js +7 -0
- package/dist/esm/{index-7c9b1bca.js → index-b7d870cf.js} +79 -15
- package/dist/esm/{index-4392efa5.js → index-b9e742e5.js} +60 -60
- package/dist/esm/index.js +113 -113
- package/dist/esm/input-shims-6539ce13.js +599 -0
- package/dist/esm/input.utils-a5a2d164.js +135 -0
- package/dist/esm/ion-accordion_2.entry.js +488 -488
- package/dist/esm/ion-action-sheet.entry.js +260 -250
- package/dist/esm/ion-alert.entry.js +442 -432
- package/dist/esm/ion-app_8.entry.js +1151 -1151
- package/dist/esm/ion-avatar_3.entry.js +29 -29
- package/dist/esm/ion-back-button.entry.js +73 -73
- package/dist/esm/ion-backdrop.entry.js +40 -40
- package/dist/esm/ion-breadcrumb_2.entry.js +194 -194
- package/dist/esm/ion-button_2.entry.js +303 -303
- package/dist/esm/ion-card_5.entry.js +105 -105
- package/dist/esm/ion-checkbox.entry.js +149 -147
- package/dist/esm/ion-chip.entry.js +20 -20
- package/dist/esm/ion-col_3.entry.js +136 -136
- package/dist/esm/ion-datetime-button.entry.js +325 -325
- package/dist/esm/ion-datetime_3.entry.js +2204 -2162
- package/dist/esm/ion-fab_3.entry.js +150 -150
- package/dist/esm/ion-img.entry.js +79 -79
- package/dist/esm/ion-infinite-scroll_2.entry.js +198 -190
- package/dist/esm/ion-input.entry.js +443 -399
- package/dist/esm/ion-item-option_3.entry.js +457 -457
- package/dist/esm/ion-item_8.entry.js +441 -428
- package/dist/esm/ion-loading.entry.js +220 -210
- package/dist/esm/ion-menu_3.entry.js +670 -670
- package/dist/esm/ion-modal.entry.js +1415 -1405
- package/dist/esm/ion-nav_2.entry.js +904 -904
- package/dist/esm/ion-picker-column-internal.entry.js +331 -327
- package/dist/esm/ion-picker-internal.entry.js +453 -453
- package/dist/esm/ion-popover.entry.js +1108 -1098
- package/dist/esm/ion-progress-bar.entry.js +40 -40
- package/dist/esm/ion-radio_2.entry.js +321 -316
- package/dist/esm/ion-range.entry.js +558 -556
- package/dist/esm/ion-refresher_2.entry.js +786 -786
- package/dist/esm/ion-reorder_2.entry.js +267 -267
- package/dist/esm/ion-ripple-effect.entry.js +66 -66
- package/dist/esm/ion-route_4.entry.js +693 -693
- package/dist/esm/ion-searchbar.entry.js +360 -358
- package/dist/esm/ion-segment_2.entry.js +507 -507
- package/dist/esm/ion-select_3.entry.js +784 -768
- package/dist/esm/ion-spinner.entry.js +46 -46
- package/dist/esm/ion-split-pane.entry.js +119 -119
- package/dist/esm/ion-tab-bar_2.entry.js +138 -138
- package/dist/esm/ion-tab_2.entry.js +187 -187
- package/dist/esm/ion-text.entry.js +13 -13
- package/dist/esm/ion-textarea.entry.js +401 -353
- package/dist/esm/ion-toast.entry.js +771 -419
- package/dist/esm/ion-toggle.entry.js +227 -225
- package/dist/esm/ionic-global-1f99b929.js +224 -0
- package/dist/esm/ionic.js +6 -6
- package/dist/esm/ios.transition-3376ccb2.js +651 -0
- package/dist/esm/keyboard-52278bd7.js +146 -0
- package/dist/esm/keyboard-73175e24.js +79 -0
- package/dist/esm/keyboard-controller-ec5c2bfa.js +165 -0
- package/dist/esm/loader.js +5 -5
- package/dist/esm/lock-controller-316928be.js +38 -0
- package/dist/esm/md.transition-f992779f.js +57 -0
- package/dist/esm/notch-controller-fea7f9c5.js +153 -0
- package/dist/esm/overlays-b33f6bca.js +693 -0
- package/dist/esm/spinner-configs-964f7cf3.js +145 -0
- package/dist/esm/status-tap-16fd8f3d.js +40 -0
- package/dist/esm/swipe-back-18cb49f7.js +79 -0
- package/dist/esm/theme-01f3f29c.js +43 -0
- package/dist/esm/watch-options-c2911ace.js +47 -0
- package/dist/esm-es5/{animation-8aa13916.js → animation-dde8cc0d.js} +1 -1
- package/dist/esm-es5/app-globals-8c62bec2.js +4 -0
- package/dist/esm-es5/{button-active-ce5cba4c.js → button-active-308d3edd.js} +1 -1
- package/dist/esm-es5/{capacitor-b4979570.js → capacitor-59395cbd.js} +1 -1
- package/dist/esm-es5/compare-with-utils-a96ff2ea.js +4 -0
- package/dist/esm-es5/data-775093f5.js +4 -0
- package/dist/esm-es5/{form-controller-64edeaad.js → form-controller-548aa79c.js} +1 -1
- package/dist/esm-es5/{framework-delegate-aa433dea.js → framework-delegate-bc1fd82a.js} +1 -1
- package/dist/esm-es5/{haptic-1243b917.js → haptic-554688a5.js} +1 -1
- package/dist/esm-es5/index-1193f005.js +4 -0
- package/dist/esm-es5/{index-ff313b19.js → index-2cf77112.js} +1 -1
- package/dist/esm-es5/{index-6a0ccabb.js → index-4743453d.js} +1 -1
- package/dist/esm-es5/{index-f0cc4e14.js → index-82eeb47f.js} +1 -1
- package/dist/esm-es5/index-b7d870cf.js +5 -0
- package/dist/esm-es5/{index-4392efa5.js → index-b9e742e5.js} +1 -1
- package/dist/esm-es5/index.js +1 -1
- package/dist/esm-es5/input-shims-6539ce13.js +4 -0
- package/dist/esm-es5/input.utils-a5a2d164.js +4 -0
- package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
- package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
- package/dist/esm-es5/ion-alert.entry.js +1 -1
- package/dist/esm-es5/ion-app_8.entry.js +1 -1
- package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
- package/dist/esm-es5/ion-back-button.entry.js +1 -1
- package/dist/esm-es5/ion-backdrop.entry.js +1 -1
- package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
- package/dist/esm-es5/ion-button_2.entry.js +1 -1
- package/dist/esm-es5/ion-card_5.entry.js +1 -1
- package/dist/esm-es5/ion-checkbox.entry.js +1 -1
- package/dist/esm-es5/ion-chip.entry.js +1 -1
- package/dist/esm-es5/ion-col_3.entry.js +1 -1
- package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
- package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
- package/dist/esm-es5/ion-fab_3.entry.js +1 -1
- package/dist/esm-es5/ion-img.entry.js +1 -1
- package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
- package/dist/esm-es5/ion-input.entry.js +1 -1
- package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
- package/dist/esm-es5/ion-item_8.entry.js +1 -1
- package/dist/esm-es5/ion-loading.entry.js +1 -1
- package/dist/esm-es5/ion-menu_3.entry.js +1 -1
- package/dist/esm-es5/ion-modal.entry.js +1 -1
- package/dist/esm-es5/ion-nav_2.entry.js +1 -1
- package/dist/esm-es5/ion-picker-column-internal.entry.js +1 -1
- package/dist/esm-es5/ion-picker-internal.entry.js +1 -1
- package/dist/esm-es5/ion-popover.entry.js +1 -1
- package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
- package/dist/esm-es5/ion-radio_2.entry.js +1 -1
- package/dist/esm-es5/ion-range.entry.js +1 -1
- package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
- package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
- package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
- package/dist/esm-es5/ion-route_4.entry.js +1 -1
- package/dist/esm-es5/ion-searchbar.entry.js +1 -1
- package/dist/esm-es5/ion-segment_2.entry.js +1 -1
- package/dist/esm-es5/ion-select_3.entry.js +1 -1
- package/dist/esm-es5/ion-spinner.entry.js +1 -1
- package/dist/esm-es5/ion-split-pane.entry.js +1 -1
- package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
- package/dist/esm-es5/ion-tab_2.entry.js +1 -1
- package/dist/esm-es5/ion-text.entry.js +1 -1
- package/dist/esm-es5/ion-textarea.entry.js +1 -1
- package/dist/esm-es5/ion-toast.entry.js +1 -1
- package/dist/esm-es5/ion-toggle.entry.js +1 -1
- package/dist/esm-es5/{ionic-global-40e42e7f.js → ionic-global-1f99b929.js} +1 -1
- package/dist/esm-es5/ionic.js +1 -1
- package/dist/esm-es5/{ios.transition-1651c430.js → ios.transition-3376ccb2.js} +1 -1
- package/dist/esm-es5/{keyboard-b551279d.js → keyboard-52278bd7.js} +1 -1
- package/dist/esm-es5/{keyboard-b063f012.js → keyboard-73175e24.js} +1 -1
- package/dist/esm-es5/{keyboard-controller-0c2dce71.js → keyboard-controller-ec5c2bfa.js} +1 -1
- package/dist/esm-es5/loader.js +1 -1
- package/dist/esm-es5/md.transition-f992779f.js +4 -0
- package/dist/esm-es5/{notch-controller-8c9c0e54.js → notch-controller-fea7f9c5.js} +1 -1
- package/dist/esm-es5/{overlays-6c9feb7e.js → overlays-b33f6bca.js} +1 -1
- package/dist/esm-es5/{status-tap-9ce68758.js → status-tap-16fd8f3d.js} +1 -1
- package/dist/esm-es5/{swipe-back-cd4295f3.js → swipe-back-18cb49f7.js} +1 -1
- package/dist/html.html-data.json +16 -3
- package/dist/ionic/index.esm.js +1 -1
- package/dist/ionic/ionic.esm.js +1 -1
- package/dist/ionic/ionic.js +15 -15
- package/dist/ionic/p-013013a3.js +4 -0
- package/dist/ionic/p-0235067a.js +4 -0
- package/dist/ionic/{p-a0b6d438.js → p-04377cfa.js} +1 -1
- package/dist/ionic/p-043aa6cc.system.entry.js +4 -0
- package/dist/ionic/{p-5d711127.js → p-0509fd34.js} +1 -1
- package/dist/ionic/p-0550f802.entry.js +4 -0
- package/dist/ionic/p-06abe918.system.entry.js +4 -0
- package/dist/ionic/{p-702d85d8.system.js → p-0aa78a8d.system.js} +1 -1
- package/dist/ionic/{p-41477ad9.system.js → p-0bd51c34.system.js} +1 -1
- package/dist/ionic/p-0dfa4ab4.system.entry.js +4 -0
- package/dist/ionic/p-0ebc87b7.system.entry.js +4 -0
- package/dist/ionic/{p-bed722c4.system.entry.js → p-10ec9af7.system.entry.js} +1 -1
- package/dist/ionic/{p-f4cc91f6.entry.js → p-11786dc7.entry.js} +1 -1
- package/dist/ionic/{p-0dc0d9b5.entry.js → p-11a3973f.entry.js} +1 -1
- package/dist/ionic/{p-a545b4f1.system.js → p-1501b945.system.js} +1 -1
- package/dist/ionic/{p-4e6a1efb.system.entry.js → p-158efe8d.system.entry.js} +1 -1
- package/dist/ionic/p-164aa69c.entry.js +4 -0
- package/dist/ionic/p-17d283b9.system.entry.js +4 -0
- package/dist/ionic/p-18cae04f.js +4 -0
- package/dist/ionic/{p-abacb44b.system.entry.js → p-19c379da.system.entry.js} +1 -1
- package/dist/ionic/p-19d9ceb8.system.js +4 -0
- package/dist/ionic/p-1b27ac67.entry.js +4 -0
- package/dist/ionic/{p-b91fe549.entry.js → p-1c249831.entry.js} +1 -1
- package/dist/ionic/{p-b4b4bb29.system.js → p-1cca10d6.system.js} +1 -1
- package/dist/ionic/p-1e4371bd.js +4 -0
- package/dist/ionic/{p-c7b8c2ef.system.entry.js → p-20e0e75d.system.entry.js} +1 -1
- package/dist/ionic/{p-34d2de14.system.entry.js → p-22827063.system.entry.js} +1 -1
- package/dist/ionic/{p-64ed03a3.entry.js → p-26c4bf85.entry.js} +1 -1
- package/dist/ionic/{p-419eb426.js → p-27281edd.js} +1 -1
- package/dist/ionic/{p-965677f1.entry.js → p-2894d5f6.entry.js} +1 -1
- package/dist/ionic/p-290d3fe9.js +5 -0
- package/dist/ionic/p-29d03b3a.js +4 -0
- package/dist/ionic/p-2a583966.entry.js +4 -0
- package/dist/ionic/p-2b7827c7.js +4 -0
- package/dist/ionic/{p-3d7fea9b.system.entry.js → p-2ba9a9bd.system.entry.js} +1 -1
- package/dist/ionic/p-2cf21a15.system.entry.js +4 -0
- package/dist/ionic/p-2df97906.system.entry.js +4 -0
- package/dist/ionic/{p-fa8d4788.system.js → p-31b2326e.system.js} +1 -1
- package/dist/ionic/{p-744973f3.entry.js → p-3313c481.entry.js} +1 -1
- package/dist/ionic/{p-ffb876b0.system.entry.js → p-332ea4d3.system.entry.js} +1 -1
- package/dist/ionic/{p-97e31c0a.system.js → p-3671f1b9.system.js} +1 -1
- package/dist/ionic/p-36d187af.js +4 -0
- package/dist/ionic/p-376a6063.js +4 -0
- package/dist/ionic/p-38531958.system.entry.js +4 -0
- package/dist/ionic/{p-55ed230e.system.js → p-38c337e7.system.js} +1 -1
- package/dist/ionic/p-38f2c6bb.system.js +4 -0
- package/dist/ionic/{p-3bad5c1a.js → p-3a75d7fd.js} +1 -1
- package/dist/ionic/{p-8b29691f.entry.js → p-3dfc522b.entry.js} +1 -1
- package/dist/ionic/{p-3de79805.entry.js → p-3e8d5e53.entry.js} +1 -1
- package/dist/ionic/p-40f68333.system.js +4 -0
- package/dist/ionic/{p-a6d83a03.system.entry.js → p-41208f54.system.entry.js} +1 -1
- package/dist/ionic/{p-b287ab05.js → p-4180a747.js} +1 -1
- package/dist/ionic/{p-b923f3d7.js → p-42f189f4.js} +1 -1
- package/dist/ionic/{p-d7ea6a0d.system.entry.js → p-4489dd20.system.entry.js} +1 -1
- package/dist/ionic/p-44a56556.js +4 -0
- package/dist/ionic/{p-e76a4bc8.entry.js → p-44dc52e5.entry.js} +1 -1
- package/dist/ionic/{p-f5a750e4.system.entry.js → p-4685218a.system.entry.js} +1 -1
- package/dist/ionic/p-469dd571.system.entry.js +4 -0
- package/dist/ionic/{p-5bd4e009.entry.js → p-47bb15a1.entry.js} +1 -1
- package/dist/ionic/{p-664d2b07.system.entry.js → p-4981ea0a.system.entry.js} +1 -1
- package/dist/ionic/{p-cf425ec5.system.entry.js → p-507ddbfe.system.entry.js} +1 -1
- package/dist/ionic/{p-14aca3fb.entry.js → p-529b24fb.entry.js} +1 -1
- package/dist/ionic/p-52cfafe9.system.js +5 -0
- package/dist/ionic/p-53ec4f1c.system.js +4 -0
- package/dist/ionic/{p-c0c81820.system.js → p-5ad1fe3b.system.js} +1 -1
- package/dist/ionic/{p-7cee75c0.entry.js → p-60959b71.entry.js} +1 -1
- package/dist/ionic/p-61e4d3ec.entry.js +4 -0
- package/dist/ionic/{p-1cb5f2f8.system.entry.js → p-648ad047.system.entry.js} +1 -1
- package/dist/ionic/p-66d633fb.js +4 -0
- package/dist/ionic/{p-63f08fe3.entry.js → p-6855f26a.entry.js} +1 -1
- package/dist/ionic/{p-1a8ae7a7.system.entry.js → p-69641343.system.entry.js} +1 -1
- package/dist/ionic/{p-800ef057.js → p-6ab03751.js} +1 -1
- package/dist/ionic/{p-18e01b30.system.entry.js → p-6c277fa2.system.entry.js} +1 -1
- package/dist/ionic/{p-0e23256e.system.entry.js → p-6e0539ea.system.entry.js} +1 -1
- package/dist/ionic/p-6fba0ce1.system.entry.js +4 -0
- package/dist/ionic/{p-4c80afe1.system.entry.js → p-745e3339.system.entry.js} +1 -1
- package/dist/ionic/p-767f1a92.entry.js +4 -0
- package/dist/ionic/{p-8a308596.system.js → p-7798c78a.system.js} +2 -2
- package/dist/ionic/p-7dc892f8.entry.js +4 -0
- package/dist/ionic/{p-6c3d5383.js → p-7fae5c36.js} +1 -1
- package/dist/ionic/{p-48d9faa7.entry.js → p-803efb5d.entry.js} +1 -1
- package/dist/ionic/{p-a8e68fd9.entry.js → p-806a9810.entry.js} +1 -1
- package/dist/ionic/p-84b567a6.entry.js +4 -0
- package/dist/ionic/p-85f48531.entry.js +4 -0
- package/dist/ionic/p-87bb3735.system.js +4 -0
- package/dist/ionic/{p-613d4042.system.js → p-888db766.system.js} +1 -1
- package/dist/ionic/p-88d5fbd3.js +4 -0
- package/dist/ionic/{p-ccdcb022.system.js → p-8985cdb6.system.js} +1 -1
- package/dist/ionic/p-8aa1d0b7.system.js +4 -0
- package/dist/ionic/{p-a9c3699b.system.entry.js → p-8f301ac5.system.entry.js} +1 -1
- package/dist/ionic/{p-174f3446.entry.js → p-928ee57a.entry.js} +1 -1
- package/dist/ionic/p-932f2259.system.entry.js +4 -0
- package/dist/ionic/p-93390f78.entry.js +4 -0
- package/dist/ionic/p-950c05ad.entry.js +4 -0
- package/dist/ionic/{p-3fb57e1b.system.entry.js → p-96d4814f.system.entry.js} +1 -1
- package/dist/ionic/p-97174c1e.js +4 -0
- package/dist/ionic/p-979d4f5c.system.js +4 -0
- package/dist/ionic/p-98f35d98.js +4 -0
- package/dist/ionic/{p-14b4348c.system.js → p-9a68d8ef.system.js} +1 -1
- package/dist/ionic/p-9ba72fdb.system.entry.js +4 -0
- package/dist/ionic/{p-41122cd6.system.js → p-9f94c72e.system.js} +1 -1
- package/dist/ionic/{p-92800752.entry.js → p-9fb45814.entry.js} +1 -1
- package/dist/ionic/p-9fda6824.system.entry.js +4 -0
- package/dist/ionic/{p-1dc91702.entry.js → p-a06501e3.entry.js} +1 -1
- package/dist/ionic/{p-c4042875.system.js → p-a074be82.system.js} +1 -1
- package/dist/ionic/{p-c7d30db9.entry.js → p-a3013394.entry.js} +1 -1
- package/dist/ionic/p-a42ef163.system.entry.js +4 -0
- package/dist/ionic/p-a49931aa.system.js +4 -0
- package/dist/ionic/{p-db5043df.system.entry.js → p-a821750c.system.entry.js} +1 -1
- package/dist/ionic/{p-1d269117.system.entry.js → p-abd5d0d5.system.entry.js} +1 -1
- package/dist/ionic/{p-9209d90c.entry.js → p-ade3cf46.entry.js} +1 -1
- package/dist/ionic/{p-1e86a71b.entry.js → p-ae4b7df8.entry.js} +1 -1
- package/dist/ionic/p-aee39e06.entry.js +4 -0
- package/dist/ionic/{p-09d142b3.system.js → p-afa9f205.system.js} +1 -1
- package/dist/ionic/{p-67e18f02.system.entry.js → p-b7058a0e.system.entry.js} +1 -1
- package/dist/ionic/p-b78e6a44.entry.js +4 -0
- package/dist/ionic/{p-beb64be7.system.entry.js → p-b7a2ffc9.system.entry.js} +1 -1
- package/dist/ionic/{p-0330f0a3.system.entry.js → p-b8a9e195.system.entry.js} +1 -1
- package/dist/ionic/{p-8ad82eb3.entry.js → p-b964aba3.entry.js} +1 -1
- package/dist/ionic/{p-ff5144f3.system.entry.js → p-beeed22c.system.entry.js} +1 -1
- package/dist/ionic/{p-5deff017.entry.js → p-c08fe2c0.entry.js} +1 -1
- package/dist/ionic/p-c1701827.entry.js +4 -0
- package/dist/ionic/{p-b2a74a72.entry.js → p-c5acfeb1.entry.js} +1 -1
- package/dist/ionic/p-c61cc894.js +4 -0
- package/dist/ionic/{p-ab4cff27.system.js → p-cabad15b.system.js} +1 -1
- package/dist/ionic/{p-07d9e9cd.system.entry.js → p-cb8dff22.system.entry.js} +1 -1
- package/dist/ionic/p-cd1b920b.entry.js +4 -0
- package/dist/ionic/p-cd574dfa.js +4 -0
- package/dist/ionic/{p-0492946a.entry.js → p-cf235986.entry.js} +1 -1
- package/dist/ionic/p-cf53213c.entry.js +4 -0
- package/dist/ionic/p-d51674c5.system.js +4 -0
- package/dist/ionic/{p-45da1e68.system.entry.js → p-d93eed83.system.entry.js} +1 -1
- package/dist/ionic/{p-c919498d.entry.js → p-da5e2652.entry.js} +1 -1
- package/dist/ionic/p-dc6d8647.entry.js +4 -0
- package/dist/ionic/p-dc71e4ef.system.entry.js +4 -0
- package/dist/ionic/{p-bba2ce59.system.js → p-ddbb2d5b.system.js} +1 -1
- package/dist/ionic/{p-6e23777e.system.entry.js → p-ddd48faf.system.entry.js} +1 -1
- package/dist/ionic/p-de6f8b28.system.js +4 -0
- package/dist/ionic/p-de756e5c.js +4 -0
- package/dist/ionic/{p-7ab6fc5a.system.entry.js → p-e2903cdc.system.entry.js} +1 -1
- package/dist/ionic/{p-0a794e83.entry.js → p-e33d1ebc.entry.js} +1 -1
- package/dist/ionic/p-ebe8bd8a.entry.js +4 -0
- package/dist/ionic/p-eef72e06.js +4 -0
- package/dist/ionic/{p-5da0eb3e.system.entry.js → p-f0504446.system.entry.js} +1 -1
- package/dist/ionic/p-f434bcf3.system.entry.js +4 -0
- package/dist/ionic/p-f5d2dc9b.js +4 -0
- package/dist/ionic/{p-a936d224.system.js → p-f6e9c227.system.js} +1 -1
- package/dist/ionic/p-f894e0ad.entry.js +4 -0
- package/dist/types/components/accordion/accordion.d.ts +62 -62
- package/dist/types/components/accordion-group/accordion-group-interface.d.ts +3 -3
- package/dist/types/components/accordion-group/accordion-group.d.ts +76 -76
- package/dist/types/components/action-sheet/action-sheet-interface.d.ts +25 -25
- package/dist/types/components/action-sheet/action-sheet.d.ts +149 -149
- package/dist/types/components/action-sheet/test/basic/fixture.d.ts +7 -7
- package/dist/types/components/alert/alert-interface.d.ts +45 -45
- package/dist/types/components/alert/alert.d.ts +181 -181
- package/dist/types/components/app/app.d.ts +15 -15
- package/dist/types/components/avatar/avatar.d.ts +1 -1
- package/dist/types/components/back-button/back-button.d.ts +41 -41
- package/dist/types/components/backdrop/backdrop.d.ts +22 -22
- package/dist/types/components/badge/badge.d.ts +7 -7
- package/dist/types/components/breadcrumb/breadcrumb-interface.d.ts +4 -4
- package/dist/types/components/breadcrumb/breadcrumb.d.ts +87 -87
- package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +39 -39
- package/dist/types/components/button/button.d.ts +121 -121
- package/dist/types/components/buttons/buttons.d.ts +14 -14
- package/dist/types/components/card/card.d.ts +57 -57
- package/dist/types/components/card-content/card-content.d.ts +1 -1
- package/dist/types/components/card-header/card-header.d.ts +13 -13
- package/dist/types/components/card-subtitle/card-subtitle.d.ts +7 -7
- package/dist/types/components/card-title/card-title.d.ts +7 -7
- package/dist/types/components/checkbox/checkbox-interface.d.ts +4 -4
- package/dist/types/components/checkbox/checkbox.d.ts +112 -111
- package/dist/types/components/chip/chip.d.ts +15 -15
- package/dist/types/components/col/col.d.ts +128 -128
- package/dist/types/components/content/content-interface.d.ts +6 -6
- package/dist/types/components/content/content.d.ts +129 -129
- package/dist/types/components/datetime/datetime-interface.d.ts +15 -15
- package/dist/types/components/datetime/datetime.d.ts +407 -407
- package/dist/types/components/datetime/utils/data.d.ts +11 -11
- package/dist/types/components/datetime/utils/manipulation.d.ts +59 -32
- package/dist/types/components/datetime/utils/state.d.ts +8 -8
- package/dist/types/components/datetime-button/datetime-button.d.ts +59 -59
- package/dist/types/components/fab/fab.d.ts +33 -33
- package/dist/types/components/fab-button/fab-button.d.ts +88 -88
- package/dist/types/components/fab-list/fab-list.d.ts +11 -11
- package/dist/types/components/footer/footer.d.ts +27 -27
- package/dist/types/components/grid/grid.d.ts +5 -5
- package/dist/types/components/header/header.d.ts +31 -31
- package/dist/types/components/header/header.utils.d.ts +7 -7
- package/dist/types/components/img/img.d.ts +30 -30
- package/dist/types/components/infinite-scroll/infinite-scroll-interface.d.ts +1 -1
- package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +65 -58
- package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +23 -23
- package/dist/types/components/input/input-interface.d.ts +6 -6
- package/dist/types/components/input/input.d.ts +321 -315
- package/dist/types/components/item/item.d.ts +111 -111
- package/dist/types/components/item-divider/item-divider.d.ts +16 -16
- package/dist/types/components/item-group/item-group.d.ts +1 -1
- package/dist/types/components/item-option/item-option.d.ts +44 -44
- package/dist/types/components/item-options/item-options.d.ts +13 -13
- package/dist/types/components/item-sliding/item-sliding-interface.d.ts +1 -1
- package/dist/types/components/item-sliding/item-sliding.d.ts +75 -75
- package/dist/types/components/label/label.d.ts +30 -30
- package/dist/types/components/list/list.d.ts +17 -17
- package/dist/types/components/list-header/list-header.d.ts +11 -11
- package/dist/types/components/loading/loading-interface.d.ts +16 -16
- package/dist/types/components/loading/loading.d.ts +152 -152
- package/dist/types/components/menu/menu-interface.d.ts +39 -39
- package/dist/types/components/menu/menu.d.ts +140 -140
- package/dist/types/components/menu-button/menu-button.d.ts +30 -30
- package/dist/types/components/menu-toggle/menu-toggle.d.ts +21 -21
- package/dist/types/components/modal/animations/sheet.d.ts +4 -4
- package/dist/types/components/modal/gestures/sheet.d.ts +30 -30
- package/dist/types/components/modal/gestures/swipe-to-close.d.ts +1 -1
- package/dist/types/components/modal/modal-interface.d.ts +27 -27
- package/dist/types/components/modal/modal.d.ts +265 -265
- package/dist/types/components/modal/test/fixtures.d.ts +7 -7
- package/dist/types/components/nav/nav-interface.d.ts +40 -40
- package/dist/types/components/nav/nav.d.ts +247 -247
- package/dist/types/components/nav/view-controller.d.ts +13 -13
- package/dist/types/components/nav-link/nav-link.d.ts +19 -19
- package/dist/types/components/note/note.d.ts +7 -7
- package/dist/types/components/picker/picker-interface.d.ts +43 -43
- package/dist/types/components/picker/picker.d.ts +149 -149
- package/dist/types/components/picker-column/picker-column.d.ts +39 -39
- package/dist/types/components/picker-column-internal/picker-column-internal-interfaces.d.ts +3 -3
- package/dist/types/components/picker-column-internal/picker-column-internal.d.ts +93 -89
- package/dist/types/components/picker-internal/picker-internal-interfaces.d.ts +4 -4
- package/dist/types/components/picker-internal/picker-internal.d.ts +94 -94
- package/dist/types/components/popover/popover-interface.d.ts +26 -26
- package/dist/types/components/popover/popover.d.ts +279 -279
- package/dist/types/components/popover/test/fixture.d.ts +5 -5
- package/dist/types/components/popover/utils.d.ts +25 -25
- package/dist/types/components/progress-bar/progress-bar.d.ts +27 -27
- package/dist/types/components/radio/radio.d.ts +100 -99
- package/dist/types/components/radio-group/radio-group-interface.d.ts +5 -4
- package/dist/types/components/radio-group/radio-group.d.ts +51 -44
- package/dist/types/components/radio-group/test/fixtures.d.ts +5 -5
- package/dist/types/components/range/range-interface.d.ts +7 -7
- package/dist/types/components/range/range.d.ts +193 -192
- package/dist/types/components/refresher/refresher-interface.d.ts +3 -3
- package/dist/types/components/refresher/refresher.d.ts +132 -132
- package/dist/types/components/refresher-content/refresher-content.d.ts +44 -44
- package/dist/types/components/reorder/reorder.d.ts +3 -3
- package/dist/types/components/reorder-group/reorder-group-interface.d.ts +5 -5
- package/dist/types/components/reorder-group/reorder-group.d.ts +53 -53
- package/dist/types/components/ripple-effect/ripple-effect.d.ts +20 -20
- package/dist/types/components/route/route-interface.d.ts +1 -1
- package/dist/types/components/route/route.d.ts +43 -43
- package/dist/types/components/route-redirect/route-redirect.d.ts +33 -33
- package/dist/types/components/router/router.d.ts +74 -73
- package/dist/types/components/router/utils/dom.d.ts +2 -2
- package/dist/types/components/router/utils/interface.d.ts +31 -31
- package/dist/types/components/router/utils/matching.d.ts +6 -6
- package/dist/types/components/router-link/router-link.d.ts +34 -34
- package/dist/types/components/router-outlet/router-outlet.d.ts +41 -41
- package/dist/types/components/row/row.d.ts +1 -1
- package/dist/types/components/searchbar/searchbar-interface.d.ts +6 -6
- package/dist/types/components/searchbar/searchbar.d.ts +235 -233
- package/dist/types/components/segment/segment-interface.d.ts +3 -3
- package/dist/types/components/segment/segment.d.ts +82 -82
- package/dist/types/components/segment-button/segment-button.d.ts +36 -36
- package/dist/types/components/select/select-interface.d.ts +3 -3
- package/dist/types/components/select/select.d.ts +238 -233
- package/dist/types/components/select-option/select-option.d.ts +11 -11
- package/dist/types/components/select-popover/select-popover-interface.d.ts +8 -8
- package/dist/types/components/select-popover/select-popover.d.ts +39 -39
- package/dist/types/components/select-popover/test/fixtures.d.ts +12 -12
- package/dist/types/components/skeleton-text/skeleton-text.d.ts +15 -7
- package/dist/types/components/spinner/spinner-configs.d.ts +96 -96
- package/dist/types/components/spinner/spinner-interface.d.ts +14 -14
- package/dist/types/components/spinner/spinner.d.ts +21 -21
- package/dist/types/components/split-pane/split-pane.d.ts +33 -33
- package/dist/types/components/tab/tab.d.ts +21 -21
- package/dist/types/components/tab-bar/tab-bar-interface.d.ts +4 -4
- package/dist/types/components/tab-bar/tab-bar.d.ts +34 -34
- package/dist/types/components/tab-button/tab-button.d.ts +56 -56
- package/dist/types/components/tabs/tabs-interface.d.ts +4 -4
- package/dist/types/components/tabs/tabs.d.ts +52 -52
- package/dist/types/components/text/text.d.ts +7 -7
- package/dist/types/components/textarea/textarea-interface.d.ts +6 -6
- package/dist/types/components/textarea/textarea.d.ts +275 -269
- package/dist/types/components/thumbnail/thumbnail.d.ts +1 -1
- package/dist/types/components/title/title.d.ts +21 -21
- package/dist/types/components/toast/animations/utils.d.ts +15 -4
- package/dist/types/components/toast/gestures/swipe-to-dismiss.d.ts +9 -0
- package/dist/types/components/toast/toast-interface.d.ts +37 -35
- package/dist/types/components/toast/toast.d.ts +241 -214
- package/dist/types/components/toggle/toggle-interface.d.ts +4 -4
- package/dist/types/components/toggle/toggle.d.ts +117 -116
- package/dist/types/components/toolbar/toolbar.d.ts +11 -11
- package/dist/types/components.d.ts +52 -13
- package/dist/types/global/config.d.ts +6 -6
- package/dist/types/interface.d.ts +1 -5
- package/dist/types/jest.d.ts +5 -0
- package/dist/types/stencil-public-runtime.d.ts +8 -0
- package/dist/types/utils/animation/animation-interface.d.ts +205 -205
- package/dist/types/utils/browser/index.d.ts +17 -8
- package/dist/types/utils/config.d.ts +175 -175
- package/dist/types/utils/element-interface.d.ts +6 -6
- package/dist/types/utils/focus-visible.d.ts +2 -2
- package/dist/types/utils/forms/compare-with-utils.d.ts +18 -0
- package/dist/types/utils/forms/form-controller.d.ts +3 -3
- package/dist/types/utils/forms/index.d.ts +1 -0
- package/dist/types/utils/forms/notch-controller.d.ts +2 -2
- package/dist/types/utils/framework-delegate.d.ts +3 -3
- package/dist/types/utils/gesture/gesture-controller.d.ts +49 -49
- package/dist/types/utils/gesture/index.d.ts +31 -31
- package/dist/types/utils/gesture/listener.d.ts +2 -2
- package/dist/types/utils/gesture/pointer-events.d.ts +12 -12
- package/dist/types/utils/gesture/recognizers.d.ts +4 -4
- package/dist/types/utils/hardware-back-button.d.ts +4 -0
- package/dist/types/utils/helpers.d.ts +8 -8
- package/dist/types/utils/input-shims/hacks/scroll-data.d.ts +4 -4
- package/dist/types/utils/keyboard/keyboard-controller.d.ts +3 -3
- package/dist/types/utils/lock-controller.d.ts +1 -1
- package/dist/types/utils/native/haptic.d.ts +38 -38
- package/dist/types/utils/native/keyboard.d.ts +29 -29
- package/dist/types/utils/native/native-interface.d.ts +15 -15
- package/dist/types/utils/native/status-bar.d.ts +8 -8
- package/dist/types/utils/overlays-interface.d.ts +27 -27
- package/dist/types/utils/overlays.d.ts +29 -28
- package/dist/types/utils/platform.d.ts +16 -16
- package/dist/types/utils/sanitization/index.d.ts +2 -2
- package/dist/types/utils/slot-mutation-controller.d.ts +3 -3
- package/dist/types/utils/test/platform.utils.d.ts +66 -66
- package/dist/types/utils/test/playwright/generator.d.ts +16 -7
- package/dist/types/utils/test/playwright/matchers/index.d.ts +3 -3
- package/dist/types/utils/test/playwright/matchers/toHaveReceivedEvent.d.ts +2 -2
- package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventDetail.d.ts +2 -2
- package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventTimes.d.ts +2 -2
- package/dist/types/utils/test/playwright/page/event-spy.d.ts +15 -15
- package/dist/types/utils/test/playwright/page/utils/goto.d.ts +3 -3
- package/dist/types/utils/test/playwright/page/utils/locator.d.ts +15 -15
- package/dist/types/utils/test/playwright/playwright-declarations.d.ts +92 -92
- package/dist/types/utils/test/playwright/playwright-page.d.ts +3 -3
- package/dist/types/utils/test/playwright/viewports/index.d.ts +12 -12
- package/dist/types/utils/test/press-keys.d.ts +14 -14
- package/dist/types/utils/transition/index.d.ts +6 -6
- package/dist/types/utils/watch-options.d.ts +1 -1
- package/hydrate/index.d.ts +1 -1
- package/hydrate/index.js +30685 -30001
- package/package.json +4 -3
- package/dist/cjs/animation-1083855c.js +0 -1061
- package/dist/cjs/button-active-af897e0e.js +0 -69
- package/dist/cjs/config-d5882735.js +0 -199
- package/dist/cjs/cubic-bezier-6b9222ad.js +0 -92
- package/dist/cjs/data-c8d21093.js +0 -1622
- package/dist/cjs/focus-visible-a7545600.js +0 -77
- package/dist/cjs/form-controller-9343050c.js +0 -66
- package/dist/cjs/framework-delegate-c0873a6f.js +0 -144
- package/dist/cjs/gesture-controller-b46721be.js +0 -197
- package/dist/cjs/haptic-678abc9f.js +0 -212
- package/dist/cjs/hardware-back-button-b67c8e75.js +0 -76
- package/dist/cjs/helpers-ea4ccbcb.js +0 -441
- package/dist/cjs/index-0ee995e4.js +0 -459
- package/dist/cjs/index-306a7476.js +0 -32
- package/dist/cjs/index-573877f3.js +0 -243
- package/dist/cjs/index-9f379eaa.js +0 -198
- package/dist/cjs/index-d7561763.js +0 -310
- package/dist/cjs/input-shims-b0a75a01.js +0 -596
- package/dist/cjs/input.utils-0fe3097c.js +0 -137
- package/dist/cjs/ionic-global-ea2901a3.js +0 -230
- package/dist/cjs/ios.transition-ac909bc8.js +0 -654
- package/dist/cjs/keyboard-controller-50beb83a.js +0 -167
- package/dist/cjs/keyboard-fd7db491.js +0 -81
- package/dist/cjs/lock-controller-4ae2eb59.js +0 -40
- package/dist/cjs/md.transition-907af519.js +0 -59
- package/dist/cjs/notch-controller-f4f6af5d.js +0 -155
- package/dist/cjs/overlays-2ffc5f27.js +0 -714
- package/dist/cjs/spinner-configs-f7b5105b.js +0 -147
- package/dist/cjs/status-tap-3fb2391a.js +0 -42
- package/dist/cjs/swipe-back-7e843e77.js +0 -81
- package/dist/cjs/theme-fbc56b3b.js +0 -48
- package/dist/cjs/watch-options-53bbb124.js +0 -49
- package/dist/collection/components/item/test/text/item.e2e.js +0 -14
- package/dist/esm/animation-8aa13916.js +0 -1059
- package/dist/esm/button-active-ce5cba4c.js +0 -67
- package/dist/esm/capacitor-b4979570.js +0 -13
- package/dist/esm/config-96c9ace3.js +0 -193
- package/dist/esm/cubic-bezier-66542bc5.js +0 -90
- package/dist/esm/data-44d9e816.js +0 -1575
- package/dist/esm/focus-visible-85493433.js +0 -75
- package/dist/esm/form-controller-64edeaad.js +0 -64
- package/dist/esm/framework-delegate-aa433dea.js +0 -140
- package/dist/esm/gesture-controller-0fa396c4.js +0 -195
- package/dist/esm/haptic-1243b917.js +0 -206
- package/dist/esm/hardware-back-button-39299f84.js +0 -71
- package/dist/esm/helpers-3379ba19.js +0 -418
- package/dist/esm/index-0aa6e61f.js +0 -308
- package/dist/esm/index-6a0ccabb.js +0 -231
- package/dist/esm/index-7a14ecec.js +0 -29
- package/dist/esm/index-f0cc4e14.js +0 -196
- package/dist/esm/index-ff313b19.js +0 -457
- package/dist/esm/input-shims-d0c93e5d.js +0 -594
- package/dist/esm/input.utils-ec063df4.js +0 -134
- package/dist/esm/ionic-global-40e42e7f.js +0 -224
- package/dist/esm/ios.transition-1651c430.js +0 -651
- package/dist/esm/keyboard-b063f012.js +0 -79
- package/dist/esm/keyboard-b551279d.js +0 -146
- package/dist/esm/keyboard-controller-0c2dce71.js +0 -165
- package/dist/esm/lock-controller-e8c6c051.js +0 -38
- package/dist/esm/md.transition-66f18369.js +0 -57
- package/dist/esm/notch-controller-8c9c0e54.js +0 -153
- package/dist/esm/overlays-6c9feb7e.js +0 -692
- package/dist/esm/spinner-configs-d09fbbbb.js +0 -145
- package/dist/esm/status-tap-9ce68758.js +0 -40
- package/dist/esm/swipe-back-cd4295f3.js +0 -79
- package/dist/esm/theme-17531cdf.js +0 -43
- package/dist/esm/watch-options-02d8498b.js +0 -47
- package/dist/esm-es5/app-globals-2398e405.js +0 -4
- package/dist/esm-es5/data-44d9e816.js +0 -4
- package/dist/esm-es5/index-0aa6e61f.js +0 -4
- package/dist/esm-es5/index-7c9b1bca.js +0 -5
- package/dist/esm-es5/input-shims-d0c93e5d.js +0 -4
- package/dist/esm-es5/input.utils-ec063df4.js +0 -4
- package/dist/esm-es5/md.transition-66f18369.js +0 -4
- package/dist/ionic/p-0d8e9393.entry.js +0 -4
- package/dist/ionic/p-114a36ed.js +0 -4
- package/dist/ionic/p-17240d90.js +0 -4
- package/dist/ionic/p-1e5165db.system.entry.js +0 -4
- package/dist/ionic/p-1f4f0d59.system.entry.js +0 -4
- package/dist/ionic/p-20cf4994.js +0 -4
- package/dist/ionic/p-236063ec.system.entry.js +0 -4
- package/dist/ionic/p-276afddd.js +0 -4
- package/dist/ionic/p-2e8e0045.js +0 -4
- package/dist/ionic/p-32083c2d.js +0 -4
- package/dist/ionic/p-352c0232.system.entry.js +0 -4
- package/dist/ionic/p-3602001b.system.js +0 -4
- package/dist/ionic/p-3632220b.system.js +0 -4
- package/dist/ionic/p-377c636c.system.entry.js +0 -4
- package/dist/ionic/p-39044fe6.system.entry.js +0 -4
- package/dist/ionic/p-3ce8c3e3.entry.js +0 -4
- package/dist/ionic/p-40903d34.system.js +0 -4
- package/dist/ionic/p-4518e4c0.system.entry.js +0 -4
- package/dist/ionic/p-4794e0ac.system.entry.js +0 -4
- package/dist/ionic/p-4a142496.system.entry.js +0 -4
- package/dist/ionic/p-4cd588b3.system.entry.js +0 -4
- package/dist/ionic/p-4dbac22d.entry.js +0 -4
- package/dist/ionic/p-4ecb5692.entry.js +0 -4
- package/dist/ionic/p-5370e786.js +0 -4
- package/dist/ionic/p-5cfb3feb.system.entry.js +0 -4
- package/dist/ionic/p-63d519fb.entry.js +0 -4
- package/dist/ionic/p-64296b15.entry.js +0 -4
- package/dist/ionic/p-67aab78f.js +0 -4
- package/dist/ionic/p-67ed452a.system.entry.js +0 -4
- package/dist/ionic/p-67eecef4.system.js +0 -4
- package/dist/ionic/p-7176cea3.entry.js +0 -4
- package/dist/ionic/p-73411c1b.entry.js +0 -4
- package/dist/ionic/p-73420380.js +0 -4
- package/dist/ionic/p-77e7a9c8.entry.js +0 -4
- package/dist/ionic/p-81c818e7.js +0 -4
- package/dist/ionic/p-8b1be026.js +0 -4
- package/dist/ionic/p-8cf94fc1.js +0 -4
- package/dist/ionic/p-8e1bded3.entry.js +0 -4
- package/dist/ionic/p-97c65aa5.js +0 -4
- package/dist/ionic/p-9ab6f3e6.system.js +0 -4
- package/dist/ionic/p-9b89cbde.js +0 -4
- package/dist/ionic/p-a5c1e6ce.entry.js +0 -4
- package/dist/ionic/p-af016cd3.entry.js +0 -4
- package/dist/ionic/p-b0cee324.entry.js +0 -4
- package/dist/ionic/p-b1142133.entry.js +0 -4
- package/dist/ionic/p-b17b7c3c.system.entry.js +0 -4
- package/dist/ionic/p-b203659a.system.entry.js +0 -4
- package/dist/ionic/p-b6f8ee31.entry.js +0 -4
- package/dist/ionic/p-b8c3f071.system.js +0 -4
- package/dist/ionic/p-b906c5ca.entry.js +0 -4
- package/dist/ionic/p-b912e055.system.js +0 -4
- package/dist/ionic/p-c224b9a9.js +0 -5
- package/dist/ionic/p-ca5219df.entry.js +0 -4
- package/dist/ionic/p-cc196b34.js +0 -4
- package/dist/ionic/p-d1de1188.js +0 -4
- package/dist/ionic/p-d2597b3e.system.js +0 -5
- package/dist/ionic/p-d3952bd5.system.entry.js +0 -4
- package/dist/ionic/p-dfa756ed.system.js +0 -4
- package/dist/ionic/p-e6b240a0.js +0 -4
- package/dist/ionic/p-e8400078.system.entry.js +0 -4
- package/dist/ionic/p-ed636a74.entry.js +0 -4
- package/dist/ionic/p-f8e620f1.entry.js +0 -4
- package/dist/ionic/p-ff5a10f9.system.js +0 -4
- /package/dist/esm-es5/{config-96c9ace3.js → config-49c88215.js} +0 -0
- /package/dist/esm-es5/{cubic-bezier-66542bc5.js → cubic-bezier-fe2083dc.js} +0 -0
- /package/dist/esm-es5/{dir-912e3e13.js → dir-babeabeb.js} +0 -0
- /package/dist/esm-es5/{focus-visible-85493433.js → focus-visible-dd40d69f.js} +0 -0
- /package/dist/esm-es5/{gesture-controller-0fa396c4.js → gesture-controller-1bf57181.js} +0 -0
- /package/dist/esm-es5/{hardware-back-button-39299f84.js → hardware-back-button-b2bc76db.js} +0 -0
- /package/dist/esm-es5/{helpers-3379ba19.js → helpers-ae653409.js} +0 -0
- /package/dist/esm-es5/{index-595d62c9.js → index-9b0d46f4.js} +0 -0
- /package/dist/esm-es5/{index-7a14ecec.js → index-a5d50daf.js} +0 -0
- /package/dist/esm-es5/{lock-controller-e8c6c051.js → lock-controller-316928be.js} +0 -0
- /package/dist/esm-es5/{spinner-configs-d09fbbbb.js → spinner-configs-964f7cf3.js} +0 -0
- /package/dist/esm-es5/{theme-17531cdf.js → theme-01f3f29c.js} +0 -0
- /package/dist/esm-es5/{watch-options-02d8498b.js → watch-options-c2911ace.js} +0 -0
- /package/dist/ionic/{p-5aac9314.system.js → p-012c3ceb.system.js} +0 -0
- /package/dist/ionic/{p-1b8e1d03.js → p-06fee233.js} +0 -0
- /package/dist/ionic/{p-819ff3b9.system.js → p-08e01816.system.js} +0 -0
- /package/dist/ionic/{p-63eb0acd.js → p-23a9d086.js} +0 -0
- /package/dist/ionic/{p-7c2bac85.js → p-2408c236.js} +0 -0
- /package/dist/ionic/{p-815c2fba.system.js → p-32ad210f.system.js} +0 -0
- /package/dist/ionic/{p-7b021525.js → p-41d5544e.js} +0 -0
- /package/dist/ionic/{p-f10de93b.js → p-459d13d5.js} +0 -0
- /package/dist/ionic/{p-44bc8b45.system.js → p-4609d030.system.js} +0 -0
- /package/dist/ionic/{p-1d072d3d.js → p-47794def.js} +0 -0
- /package/dist/ionic/{p-185e427e.js → p-4b3623da.js} +0 -0
- /package/dist/ionic/{p-772f6c84.system.js → p-4f255d5a.system.js} +0 -0
- /package/dist/ionic/{p-8c15eda7.system.js → p-790220fd.system.js} +0 -0
- /package/dist/ionic/{p-0e94957a.system.js → p-792919fd.system.js} +0 -0
- /package/dist/ionic/{p-b347cfd1.js → p-7b30edcc.js} +0 -0
- /package/dist/ionic/{p-e0b06b65.js → p-bb3615f7.js} +0 -0
- /package/dist/ionic/{p-87411e39.system.js → p-c468af8a.system.js} +0 -0
- /package/dist/ionic/{p-9e852ff1.system.js → p-c7c8429a.system.js} +0 -0
- /package/dist/ionic/{p-53b2a46f.js → p-ccd02320.js} +0 -0
- /package/dist/ionic/{p-76fce40e.js → p-d47265c8.js} +0 -0
- /package/dist/ionic/{p-56dc022e.system.js → p-d8d84afa.system.js} +0 -0
- /package/dist/ionic/{p-c4f2dce7.system.js → p-e673a0a2.system.js} +0 -0
- /package/dist/ionic/{p-c18d6eac.js → p-f0c2a614.js} +0 -0
- /package/dist/ionic/{p-2b89ea1b.system.js → p-f233f1e0.system.js} +0 -0
- /package/dist/ionic/{p-6dbfe5d4.js → p-fb813dab.js} +0 -0
- /package/dist/ionic/{p-479cdbf8.system.js → p-ff4b7e40.system.js} +0 -0
|
@@ -5,32 +5,32 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index$1 = require('./index-
|
|
9
|
-
const focusVisible = require('./focus-visible-
|
|
10
|
-
const helpers = require('./helpers-
|
|
11
|
-
const index = require('./index-
|
|
12
|
-
const dir = require('./dir-
|
|
13
|
-
const theme = require('./theme-
|
|
8
|
+
const index$1 = require('./index-50dcfe2f.js');
|
|
9
|
+
const focusVisible = require('./focus-visible-7a0ce04f.js');
|
|
10
|
+
const helpers = require('./helpers-76bb7efb.js');
|
|
11
|
+
const index = require('./index-5915f9b3.js');
|
|
12
|
+
const dir = require('./dir-94c21456.js');
|
|
13
|
+
const theme = require('./theme-d1c573d2.js');
|
|
14
14
|
const index$2 = require('./index-09471526.js');
|
|
15
|
-
const ionicGlobal = require('./ionic-global-
|
|
16
|
-
const data = require('./data-
|
|
17
|
-
const lockController = require('./lock-controller-
|
|
18
|
-
const overlays = require('./overlays-
|
|
19
|
-
const animation = require('./animation-
|
|
20
|
-
const haptic = require('./haptic-
|
|
21
|
-
require('./index-
|
|
22
|
-
require('./framework-delegate-
|
|
23
|
-
require('./hardware-back-button-
|
|
24
|
-
require('./capacitor-
|
|
15
|
+
const ionicGlobal = require('./ionic-global-a4edbf03.js');
|
|
16
|
+
const data = require('./data-a5109f09.js');
|
|
17
|
+
const lockController = require('./lock-controller-6585a42a.js');
|
|
18
|
+
const overlays = require('./overlays-e77cc023.js');
|
|
19
|
+
const animation = require('./animation-9b401d39.js');
|
|
20
|
+
const haptic = require('./haptic-b882e0bb.js');
|
|
21
|
+
require('./index-c8d52405.js');
|
|
22
|
+
require('./framework-delegate-1c29b14a.js');
|
|
23
|
+
require('./hardware-back-button-76833cac.js');
|
|
24
|
+
require('./capacitor-c04564bf.js');
|
|
25
25
|
|
|
26
26
|
const isYearDisabled = (refYear, minParts, maxParts) => {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
27
|
+
if (minParts && minParts.year > refYear) {
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
if (maxParts && maxParts.year < refYear) {
|
|
31
|
+
return true;
|
|
32
|
+
}
|
|
33
|
+
return false;
|
|
34
34
|
};
|
|
35
35
|
/**
|
|
36
36
|
* Returns true if a given day should
|
|
@@ -38,104 +38,104 @@ const isYearDisabled = (refYear, minParts, maxParts) => {
|
|
|
38
38
|
* or the max/min dates.
|
|
39
39
|
*/
|
|
40
40
|
const isDayDisabled = (refParts, minParts, maxParts, dayValues) => {
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
41
|
+
/**
|
|
42
|
+
* If this is a filler date (i.e. padding)
|
|
43
|
+
* then the date is disabled.
|
|
44
|
+
*/
|
|
45
|
+
if (refParts.day === null) {
|
|
46
|
+
return true;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* If user passed in a list of acceptable day values
|
|
50
|
+
* check to make sure that the date we are looking
|
|
51
|
+
* at is in this array.
|
|
52
|
+
*/
|
|
53
|
+
if (dayValues !== undefined && !dayValues.includes(refParts.day)) {
|
|
54
|
+
return true;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Given a min date, perform the following
|
|
58
|
+
* checks. If any of them are true, then the
|
|
59
|
+
* day should be disabled:
|
|
60
|
+
* 1. Is the current year < the min allowed year?
|
|
61
|
+
* 2. Is the current year === min allowed year,
|
|
62
|
+
* but the current month < the min allowed month?
|
|
63
|
+
* 3. Is the current year === min allowed year, the
|
|
64
|
+
* current month === min allow month, but the current
|
|
65
|
+
* day < the min allowed day?
|
|
66
|
+
*/
|
|
67
|
+
if (minParts && data.isBefore(refParts, minParts)) {
|
|
68
|
+
return true;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Given a max date, perform the following
|
|
72
|
+
* checks. If any of them are true, then the
|
|
73
|
+
* day should be disabled:
|
|
74
|
+
* 1. Is the current year > the max allowed year?
|
|
75
|
+
* 2. Is the current year === max allowed year,
|
|
76
|
+
* but the current month > the max allowed month?
|
|
77
|
+
* 3. Is the current year === max allowed year, the
|
|
78
|
+
* current month === max allow month, but the current
|
|
79
|
+
* day > the max allowed day?
|
|
80
|
+
*/
|
|
81
|
+
if (maxParts && data.isAfter(refParts, maxParts)) {
|
|
82
|
+
return true;
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* If none of these checks
|
|
86
|
+
* passed then the date should
|
|
87
|
+
* be interactive.
|
|
88
|
+
*/
|
|
89
|
+
return false;
|
|
90
90
|
};
|
|
91
91
|
/**
|
|
92
92
|
* Given a locale, a date, the selected date(s), and today's date,
|
|
93
93
|
* generate the state for a given calendar day button.
|
|
94
94
|
*/
|
|
95
95
|
const getCalendarDayState = (locale, refParts, activeParts, todayParts, minParts, maxParts, dayValues) => {
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
96
|
+
/**
|
|
97
|
+
* activeParts signals what day(s) are currently selected in the datetime.
|
|
98
|
+
* If multiple="true", this will be an array, but the logic in this util
|
|
99
|
+
* is the same whether we have one selected day or many because we're only
|
|
100
|
+
* calculating the state for one button. So, we treat a single activeParts value
|
|
101
|
+
* the same as an array of length one.
|
|
102
|
+
*/
|
|
103
|
+
const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
|
|
104
|
+
/**
|
|
105
|
+
* The day button is active if it is selected, or in other words, if refParts
|
|
106
|
+
* matches at least one selected date.
|
|
107
|
+
*/
|
|
108
|
+
const isActive = activePartsArray.find((parts) => data.isSameDay(refParts, parts)) !== undefined;
|
|
109
|
+
const isToday = data.isSameDay(refParts, todayParts);
|
|
110
|
+
const disabled = isDayDisabled(refParts, minParts, maxParts, dayValues);
|
|
111
|
+
/**
|
|
112
|
+
* Note that we always return one object regardless of whether activeParts
|
|
113
|
+
* was an array, since we pare down to one value for isActive.
|
|
114
|
+
*/
|
|
115
|
+
return {
|
|
116
|
+
disabled,
|
|
117
|
+
isActive,
|
|
118
|
+
isToday,
|
|
119
|
+
ariaSelected: isActive ? 'true' : null,
|
|
120
|
+
ariaLabel: data.generateDayAriaLabel(locale, isToday, refParts),
|
|
121
|
+
text: refParts.day != null ? data.getDay(locale, refParts) : null,
|
|
122
|
+
};
|
|
123
123
|
};
|
|
124
124
|
/**
|
|
125
125
|
* Returns `true` if the month is disabled given the
|
|
126
126
|
* current date value and min/max date constraints.
|
|
127
127
|
*/
|
|
128
128
|
const isMonthDisabled = (refParts, { minParts, maxParts, }) => {
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
129
|
+
// If the year is disabled then the month is disabled.
|
|
130
|
+
if (isYearDisabled(refParts.year, minParts, maxParts)) {
|
|
131
|
+
return true;
|
|
132
|
+
}
|
|
133
|
+
// If the date value is before the min date, then the month is disabled.
|
|
134
|
+
// If the date value is after the max date, then the month is disabled.
|
|
135
|
+
if ((minParts && data.isBefore(refParts, minParts)) || (maxParts && data.isAfter(refParts, maxParts))) {
|
|
136
|
+
return true;
|
|
137
|
+
}
|
|
138
|
+
return false;
|
|
139
139
|
};
|
|
140
140
|
/**
|
|
141
141
|
* Given a working date, an optional minimum date range,
|
|
@@ -143,21 +143,21 @@ const isMonthDisabled = (refParts, { minParts, maxParts, }) => {
|
|
|
143
143
|
* previous navigation button is disabled.
|
|
144
144
|
*/
|
|
145
145
|
const isPrevMonthDisabled = (refParts, minParts, maxParts) => {
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
146
|
+
const prevMonth = Object.assign(Object.assign({}, data.getPreviousMonth(refParts)), { day: null });
|
|
147
|
+
return isMonthDisabled(prevMonth, {
|
|
148
|
+
minParts,
|
|
149
|
+
maxParts,
|
|
150
|
+
});
|
|
151
151
|
};
|
|
152
152
|
/**
|
|
153
153
|
* Given a working date and a maximum date range,
|
|
154
154
|
* determine if the next navigation button is disabled.
|
|
155
155
|
*/
|
|
156
156
|
const isNextMonthDisabled = (refParts, maxParts) => {
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
157
|
+
const nextMonth = Object.assign(Object.assign({}, data.getNextMonth(refParts)), { day: null });
|
|
158
|
+
return isMonthDisabled(nextMonth, {
|
|
159
|
+
maxParts,
|
|
160
|
+
});
|
|
161
161
|
};
|
|
162
162
|
/**
|
|
163
163
|
* Given the value of the highlightedDates property
|
|
@@ -165,1618 +165,1650 @@ const isNextMonthDisabled = (refParts, maxParts) => {
|
|
|
165
165
|
* that date, or undefined if none are found.
|
|
166
166
|
*/
|
|
167
167
|
const getHighlightStyles = (highlightedDates, dateIsoString, el) => {
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
}
|
|
178
|
-
else {
|
|
179
|
-
/**
|
|
180
|
-
* Wrap in a try-catch to prevent exceptions in the user's function
|
|
181
|
-
* from interrupting the calendar's rendering.
|
|
182
|
-
*/
|
|
183
|
-
try {
|
|
184
|
-
return highlightedDates(dateIsoString);
|
|
168
|
+
if (Array.isArray(highlightedDates)) {
|
|
169
|
+
const dateStringWithoutTime = dateIsoString.split('T')[0];
|
|
170
|
+
const matchingHighlight = highlightedDates.find((hd) => hd.date === dateStringWithoutTime);
|
|
171
|
+
if (matchingHighlight) {
|
|
172
|
+
return {
|
|
173
|
+
textColor: matchingHighlight.textColor,
|
|
174
|
+
backgroundColor: matchingHighlight.backgroundColor,
|
|
175
|
+
};
|
|
176
|
+
}
|
|
185
177
|
}
|
|
186
|
-
|
|
187
|
-
|
|
178
|
+
else {
|
|
179
|
+
/**
|
|
180
|
+
* Wrap in a try-catch to prevent exceptions in the user's function
|
|
181
|
+
* from interrupting the calendar's rendering.
|
|
182
|
+
*/
|
|
183
|
+
try {
|
|
184
|
+
return highlightedDates(dateIsoString);
|
|
185
|
+
}
|
|
186
|
+
catch (e) {
|
|
187
|
+
index.printIonError('Exception thrown from provided `highlightedDates` callback. Please check your function and try again.', el, e);
|
|
188
|
+
}
|
|
188
189
|
}
|
|
189
|
-
|
|
190
|
-
return undefined;
|
|
190
|
+
return undefined;
|
|
191
191
|
};
|
|
192
192
|
|
|
193
|
-
const datetimeIosCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{position:absolute;visibility:hidden;pointer-events:none}@supports (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{inset-inline-start:-99999px}}@supports not (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}@supports selector(:dir(rtl)){:host(.show-month-and-year:dir(rtl)) .calendar-next-prev,:host(.show-month-and-year:dir(rtl)) .calendar-days-of-week,:host(.show-month-and-year:dir(rtl)) .calendar-body,:host(.show-month-and-year:dir(rtl)) .datetime-time{left:unset;right:unset;right:-99999px}}}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .calendar-action-buttons ion-item ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-light, #ffffff);--background-rgb:var(--ion-color-light-rgb);--title-color:var(--ion-color-step-600, #666666)}:host(.datetime-presentation-date-time:not(.datetime-prefer-wheel)),:host(.datetime-presentation-time-date:not(.datetime-prefer-wheel)),:host(.datetime-presentation-date:not(.datetime-prefer-wheel)){min-height:350px}:host .datetime-header{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:16px;padding-bottom:16px;border-bottom:0.55px solid var(--ion-color-step-200, #cccccc);font-size:min(0.875rem, 22.4px)}:host .datetime-header .datetime-title{color:var(--title-color)}:host .datetime-header .datetime-selected-date{margin-top:10px}:host .calendar-action-buttons ion-item{--padding-start:16px;--background-hover:transparent;--background-activated:transparent;font-size:min(1rem, 25.6px);font-weight:600}:host .calendar-action-buttons ion-item ion-icon,:host .calendar-action-buttons ion-buttons ion-button{color:var(--ion-color-base)}:host .calendar-action-buttons ion-buttons{padding-left:0;padding-right:0;padding-top:8px;padding-bottom:0}:host .calendar-action-buttons ion-buttons ion-button{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host .calendar-days-of-week{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:0;padding-bottom:0;color:var(--ion-color-step-300, #b3b3b3);font-size:min(0.75rem, 19.2px);font-weight:600;line-height:24px;text-transform:uppercase}@supports (border-radius: mod(1px, 1px)){.calendar-days-of-week .day-of-week{width:clamp(20px, calc(mod(min(1rem, 24px), 24px) * 10), 100%);height:24px;overflow:hidden}.calendar-day{border-radius:max(8px, mod(min(1rem, 24px), 24px) * 10)}}@supports ((border-radius: mod(1px, 1px)) and (background: -webkit-named-image(apple-pay-logo-black)) and (not (contain-intrinsic-size: none))) or (not (border-radius: mod(1px, 1px))){.calendar-days-of-week .day-of-week{width:auto;height:auto;overflow:initial}.calendar-day{border-radius:32px}}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;-ms-flex-align:center;align-items:center;height:calc(100% - 16px)}:host .calendar-day-wrapper{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px;padding-top:4px;padding-bottom:4px;height:0;min-height:1rem}:host .calendar-day{width:40px;min-width:40px;height:40px;font-size:min(1.25rem, 32px)}.calendar-day.calendar-day-active{background:rgba(var(--ion-color-base-rgb), 0.2)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-base);font-weight:600}:host .calendar-day.calendar-day-today.calendar-day-active{color:var(--ion-color-contrast)}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:16px;font-size:min(1rem, 25.6px)}:host .datetime-time .time-header{font-weight:600}:host .datetime-buttons{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;border-top:0.55px solid var(--ion-color-step-200, #cccccc)}:host .datetime-buttons ::slotted(ion-buttons),:host .datetime-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between}:host .datetime-action-buttons{width:100%}";
|
|
193
|
+
const datetimeIosCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{position:absolute;visibility:hidden;pointer-events:none}@supports (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{inset-inline-start:-99999px}}@supports not (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}@supports selector(:dir(rtl)){:host(.show-month-and-year:dir(rtl)) .calendar-next-prev,:host(.show-month-and-year:dir(rtl)) .calendar-days-of-week,:host(.show-month-and-year:dir(rtl)) .calendar-body,:host(.show-month-and-year:dir(rtl)) .datetime-time{left:unset;right:unset;right:-99999px}}}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;width:auto}:host .calendar-action-buttons ion-item ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-light, #ffffff);--background-rgb:var(--ion-color-light-rgb);--title-color:var(--ion-color-step-600, #666666)}:host(.datetime-presentation-date-time:not(.datetime-prefer-wheel)),:host(.datetime-presentation-time-date:not(.datetime-prefer-wheel)),:host(.datetime-presentation-date:not(.datetime-prefer-wheel)){min-height:350px}:host .datetime-header{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:16px;padding-bottom:16px;border-bottom:0.55px solid var(--ion-color-step-200, #cccccc);font-size:min(0.875rem, 22.4px)}:host .datetime-header .datetime-title{color:var(--title-color)}:host .datetime-header .datetime-selected-date{margin-top:10px}:host .calendar-action-buttons ion-item{--padding-start:16px;--background-hover:transparent;--background-activated:transparent;font-size:min(1rem, 25.6px);font-weight:600}:host .calendar-action-buttons ion-item ion-icon,:host .calendar-action-buttons ion-buttons ion-button{color:var(--ion-color-base)}:host .calendar-action-buttons ion-buttons{padding-left:0;padding-right:0;padding-top:8px;padding-bottom:0}:host .calendar-action-buttons ion-buttons ion-button{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host .calendar-days-of-week{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:0;padding-bottom:0;color:var(--ion-color-step-300, #b3b3b3);font-size:min(0.75rem, 19.2px);font-weight:600;line-height:24px;text-transform:uppercase}@supports (border-radius: mod(1px, 1px)){.calendar-days-of-week .day-of-week{width:clamp(20px, calc(mod(min(1rem, 24px), 24px) * 10), 100%);height:24px;overflow:hidden}.calendar-day{border-radius:max(8px, mod(min(1rem, 24px), 24px) * 10)}}@supports ((border-radius: mod(1px, 1px)) and (background: -webkit-named-image(apple-pay-logo-black)) and (not (contain-intrinsic-size: none))) or (not (border-radius: mod(1px, 1px))){.calendar-days-of-week .day-of-week{width:auto;height:auto;overflow:initial}.calendar-day{border-radius:32px}}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;-ms-flex-align:center;align-items:center;height:calc(100% - 16px)}:host .calendar-day-wrapper{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px;padding-top:4px;padding-bottom:4px;height:0;min-height:1rem}:host .calendar-day{width:40px;min-width:40px;height:40px;font-size:min(1.25rem, 32px)}.calendar-day.calendar-day-active{background:rgba(var(--ion-color-base-rgb), 0.2)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-base);font-weight:600}:host .calendar-day.calendar-day-today.calendar-day-active{color:var(--ion-color-contrast)}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:16px;font-size:min(1rem, 25.6px)}:host .datetime-time .time-header{font-weight:600}:host .datetime-buttons{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;border-top:0.55px solid var(--ion-color-step-200, #cccccc)}:host .datetime-buttons ::slotted(ion-buttons),:host .datetime-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between}:host .datetime-action-buttons{width:100%}";
|
|
194
194
|
|
|
195
|
-
const datetimeMdCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{position:absolute;visibility:hidden;pointer-events:none}@supports (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{inset-inline-start:-99999px}}@supports not (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}@supports selector(:dir(rtl)){:host(.show-month-and-year:dir(rtl)) .calendar-next-prev,:host(.show-month-and-year:dir(rtl)) .calendar-days-of-week,:host(.show-month-and-year:dir(rtl)) .calendar-body,:host(.show-month-and-year:dir(rtl)) .datetime-time{left:unset;right:unset;right:-99999px}}}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .calendar-action-buttons ion-item ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-step-100, #ffffff);--title-color:var(--ion-color-contrast)}:host .datetime-header{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px;padding-top:20px;padding-bottom:20px;background:var(--ion-color-base);color:var(--title-color)}:host .datetime-header .datetime-title{font-size:0.75rem;text-transform:uppercase}:host .datetime-header .datetime-selected-date{margin-top:30px;font-size:2.125rem}:host .datetime-calendar .calendar-action-buttons ion-item{--padding-start:20px}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--color:var(--ion-color-step-650, #595959)}:host .calendar-days-of-week{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:0px;padding-bottom:0px;color:var(--ion-color-step-500, gray);font-size:0.875rem;line-height:36px}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:4px;padding-bottom:4px;grid-template-rows:repeat(6, 1fr)}:host .calendar-day{width:42px;min-width:42px;height:42px;font-size:0.875rem}:host .calendar-day.calendar-day-today{border:1px solid var(--ion-color-base);color:var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-contrast)}.calendar-day.calendar-day-active{border:1px solid var(--ion-color-base);background:var(--ion-color-base)}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:8px}:host .time-header{color:var(--ion-color-step-650, #595959)}:host(.datetime-presentation-month) .datetime-year,:host(.datetime-presentation-year) .datetime-year,:host(.datetime-presentation-month-year) .datetime-year{margin-top:20px;margin-bottom:20px}:host .datetime-buttons{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:10px;padding-bottom:10px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:end;justify-content:flex-end}";
|
|
195
|
+
const datetimeMdCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{position:absolute;visibility:hidden;pointer-events:none}@supports (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{inset-inline-start:-99999px}}@supports not (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}@supports selector(:dir(rtl)){:host(.show-month-and-year:dir(rtl)) .calendar-next-prev,:host(.show-month-and-year:dir(rtl)) .calendar-days-of-week,:host(.show-month-and-year:dir(rtl)) .calendar-body,:host(.show-month-and-year:dir(rtl)) .datetime-time{left:unset;right:unset;right:-99999px}}}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;width:auto}:host .calendar-action-buttons ion-item ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-step-100, #ffffff);--title-color:var(--ion-color-contrast)}:host .datetime-header{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px;padding-top:20px;padding-bottom:20px;background:var(--ion-color-base);color:var(--title-color)}:host .datetime-header .datetime-title{font-size:0.75rem;text-transform:uppercase}:host .datetime-header .datetime-selected-date{margin-top:30px;font-size:2.125rem}:host .datetime-calendar .calendar-action-buttons ion-item{--padding-start:20px}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--color:var(--ion-color-step-650, #595959)}:host .calendar-days-of-week{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:0px;padding-bottom:0px;color:var(--ion-color-step-500, gray);font-size:0.875rem;line-height:36px}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:4px;padding-bottom:4px;grid-template-rows:repeat(6, 1fr)}:host .calendar-day{width:42px;min-width:42px;height:42px;font-size:0.875rem}:host .calendar-day.calendar-day-today{border:1px solid var(--ion-color-base);color:var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-contrast)}.calendar-day.calendar-day-active{border:1px solid var(--ion-color-base);background:var(--ion-color-base)}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:8px}:host .time-header{color:var(--ion-color-step-650, #595959)}:host(.datetime-presentation-month) .datetime-year,:host(.datetime-presentation-year) .datetime-year,:host(.datetime-presentation-month-year) .datetime-year{margin-top:20px;margin-bottom:20px}:host .datetime-buttons{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:10px;padding-bottom:10px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:end;justify-content:flex-end}";
|
|
196
196
|
|
|
197
197
|
const Datetime = class {
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
198
|
+
constructor(hostRef) {
|
|
199
|
+
index$1.registerInstance(this, hostRef);
|
|
200
|
+
this.ionCancel = index$1.createEvent(this, "ionCancel", 7);
|
|
201
|
+
this.ionChange = index$1.createEvent(this, "ionChange", 7);
|
|
202
|
+
this.ionValueChange = index$1.createEvent(this, "ionValueChange", 7);
|
|
203
|
+
this.ionFocus = index$1.createEvent(this, "ionFocus", 7);
|
|
204
|
+
this.ionBlur = index$1.createEvent(this, "ionBlur", 7);
|
|
205
|
+
this.ionStyle = index$1.createEvent(this, "ionStyle", 7);
|
|
206
|
+
this.ionRender = index$1.createEvent(this, "ionRender", 7);
|
|
207
|
+
this.inputId = `ion-dt-${datetimeIds++}`;
|
|
208
|
+
this.prevPresentation = null;
|
|
209
|
+
this.warnIfIncorrectValueUsage = () => {
|
|
210
|
+
const { multiple, value } = this;
|
|
211
|
+
if (!multiple && Array.isArray(value)) {
|
|
212
|
+
/**
|
|
213
|
+
* We do some processing on the `value` array so
|
|
214
|
+
* that it looks more like an array when logged to
|
|
215
|
+
* the console.
|
|
216
|
+
* Example given ['a', 'b']
|
|
217
|
+
* Default toString() behavior: a,b
|
|
218
|
+
* Custom behavior: ['a', 'b']
|
|
219
|
+
*/
|
|
220
|
+
index.printIonWarning(`ion-datetime was passed an array of values, but multiple="false". This is incorrect usage and may result in unexpected behaviors. To dismiss this warning, pass a string to the "value" property when multiple="false".
|
|
221
221
|
|
|
222
222
|
Value Passed: [${value.map((v) => `'${v}'`).join(', ')}]
|
|
223
223
|
`, this.el);
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
224
|
+
}
|
|
225
|
+
};
|
|
226
|
+
this.setValue = (value) => {
|
|
227
|
+
this.value = value;
|
|
228
|
+
this.ionChange.emit({ value });
|
|
229
|
+
};
|
|
230
|
+
/**
|
|
231
|
+
* Returns the DatetimePart interface
|
|
232
|
+
* to use when rendering an initial set of
|
|
233
|
+
* data. This should be used when rendering an
|
|
234
|
+
* interface in an environment where the `value`
|
|
235
|
+
* may not be set. This function works
|
|
236
|
+
* by returning the first selected date and then
|
|
237
|
+
* falling back to defaultParts if no active date
|
|
238
|
+
* is selected.
|
|
239
|
+
*/
|
|
240
|
+
this.getActivePartsWithFallback = () => {
|
|
241
|
+
var _a;
|
|
242
|
+
const { defaultParts } = this;
|
|
243
|
+
return (_a = this.getActivePart()) !== null && _a !== void 0 ? _a : defaultParts;
|
|
244
|
+
};
|
|
245
|
+
this.getActivePart = () => {
|
|
246
|
+
const { activeParts } = this;
|
|
247
|
+
return Array.isArray(activeParts) ? activeParts[0] : activeParts;
|
|
248
|
+
};
|
|
249
|
+
this.closeParentOverlay = () => {
|
|
250
|
+
const popoverOrModal = this.el.closest('ion-modal, ion-popover');
|
|
251
|
+
if (popoverOrModal) {
|
|
252
|
+
popoverOrModal.dismiss();
|
|
253
|
+
}
|
|
254
|
+
};
|
|
255
|
+
this.setWorkingParts = (parts) => {
|
|
256
|
+
this.workingParts = Object.assign({}, parts);
|
|
257
|
+
};
|
|
258
|
+
this.setActiveParts = (parts, removeDate = false) => {
|
|
259
|
+
/** if the datetime component is in readonly mode,
|
|
260
|
+
* allow browsing of the calendar without changing
|
|
261
|
+
* the set value
|
|
262
|
+
*/
|
|
263
|
+
if (this.readonly) {
|
|
264
|
+
return;
|
|
265
|
+
}
|
|
266
|
+
const { multiple, minParts, maxParts, activeParts } = this;
|
|
267
|
+
/**
|
|
268
|
+
* When setting the active parts, it is possible
|
|
269
|
+
* to set invalid data. For example,
|
|
270
|
+
* when updating January 31 to February,
|
|
271
|
+
* February 31 does not exist. As a result
|
|
272
|
+
* we need to validate the active parts and
|
|
273
|
+
* ensure that we are only setting valid dates.
|
|
274
|
+
* Additionally, we need to update the working parts
|
|
275
|
+
* too in the event that the validated parts are different.
|
|
276
|
+
*/
|
|
277
|
+
const validatedParts = data.validateParts(parts, minParts, maxParts);
|
|
278
|
+
this.setWorkingParts(validatedParts);
|
|
279
|
+
if (multiple) {
|
|
280
|
+
const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
|
|
281
|
+
if (removeDate) {
|
|
282
|
+
this.activeParts = activePartsArray.filter((p) => !data.isSameDay(p, validatedParts));
|
|
283
|
+
}
|
|
284
|
+
else {
|
|
285
|
+
this.activeParts = [...activePartsArray, validatedParts];
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
else {
|
|
289
|
+
this.activeParts = Object.assign({}, validatedParts);
|
|
290
|
+
}
|
|
291
|
+
const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
|
|
292
|
+
if (hasSlottedButtons || this.showDefaultButtons) {
|
|
293
|
+
return;
|
|
294
|
+
}
|
|
295
|
+
this.confirm();
|
|
296
|
+
};
|
|
297
|
+
this.initializeKeyboardListeners = () => {
|
|
298
|
+
const calendarBodyRef = this.calendarBodyRef;
|
|
299
|
+
if (!calendarBodyRef) {
|
|
300
|
+
return;
|
|
301
|
+
}
|
|
302
|
+
const root = this.el.shadowRoot;
|
|
303
|
+
/**
|
|
304
|
+
* Get a reference to the month
|
|
305
|
+
* element we are currently viewing.
|
|
306
|
+
*/
|
|
307
|
+
const currentMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(2)');
|
|
308
|
+
/**
|
|
309
|
+
* When focusing the calendar body, we want to pass focus
|
|
310
|
+
* to the working day, but other days should
|
|
311
|
+
* only be accessible using the arrow keys. Pressing
|
|
312
|
+
* Tab should jump between bodies of selectable content.
|
|
313
|
+
*/
|
|
314
|
+
const checkCalendarBodyFocus = (ev) => {
|
|
315
|
+
var _a;
|
|
316
|
+
const record = ev[0];
|
|
317
|
+
/**
|
|
318
|
+
* If calendar body was already focused
|
|
319
|
+
* when this fired or if the calendar body
|
|
320
|
+
* if not currently focused, we should not re-focus
|
|
321
|
+
* the inner day.
|
|
322
|
+
*/
|
|
323
|
+
if (((_a = record.oldValue) === null || _a === void 0 ? void 0 : _a.includes('ion-focused')) || !calendarBodyRef.classList.contains('ion-focused')) {
|
|
324
|
+
return;
|
|
325
|
+
}
|
|
326
|
+
this.focusWorkingDay(currentMonth);
|
|
327
|
+
};
|
|
328
|
+
const mo = new MutationObserver(checkCalendarBodyFocus);
|
|
329
|
+
mo.observe(calendarBodyRef, { attributeFilter: ['class'], attributeOldValue: true });
|
|
330
|
+
this.destroyKeyboardMO = () => {
|
|
331
|
+
mo === null || mo === void 0 ? void 0 : mo.disconnect();
|
|
332
|
+
};
|
|
333
|
+
/**
|
|
334
|
+
* We must use keydown not keyup as we want
|
|
335
|
+
* to prevent scrolling when using the arrow keys.
|
|
336
|
+
*/
|
|
337
|
+
calendarBodyRef.addEventListener('keydown', (ev) => {
|
|
338
|
+
const activeElement = root.activeElement;
|
|
339
|
+
if (!activeElement || !activeElement.classList.contains('calendar-day')) {
|
|
340
|
+
return;
|
|
341
|
+
}
|
|
342
|
+
const parts = data.getPartsFromCalendarDay(activeElement);
|
|
343
|
+
let partsToFocus;
|
|
344
|
+
switch (ev.key) {
|
|
345
|
+
case 'ArrowDown':
|
|
346
|
+
ev.preventDefault();
|
|
347
|
+
partsToFocus = data.getNextWeek(parts);
|
|
348
|
+
break;
|
|
349
|
+
case 'ArrowUp':
|
|
350
|
+
ev.preventDefault();
|
|
351
|
+
partsToFocus = data.getPreviousWeek(parts);
|
|
352
|
+
break;
|
|
353
|
+
case 'ArrowRight':
|
|
354
|
+
ev.preventDefault();
|
|
355
|
+
partsToFocus = data.getNextDay(parts);
|
|
356
|
+
break;
|
|
357
|
+
case 'ArrowLeft':
|
|
358
|
+
ev.preventDefault();
|
|
359
|
+
partsToFocus = data.getPreviousDay(parts);
|
|
360
|
+
break;
|
|
361
|
+
case 'Home':
|
|
362
|
+
ev.preventDefault();
|
|
363
|
+
partsToFocus = data.getStartOfWeek(parts);
|
|
364
|
+
break;
|
|
365
|
+
case 'End':
|
|
366
|
+
ev.preventDefault();
|
|
367
|
+
partsToFocus = data.getEndOfWeek(parts);
|
|
368
|
+
break;
|
|
369
|
+
case 'PageUp':
|
|
370
|
+
ev.preventDefault();
|
|
371
|
+
partsToFocus = ev.shiftKey ? data.getPreviousYear(parts) : data.getPreviousMonth(parts);
|
|
372
|
+
break;
|
|
373
|
+
case 'PageDown':
|
|
374
|
+
ev.preventDefault();
|
|
375
|
+
partsToFocus = ev.shiftKey ? data.getNextYear(parts) : data.getNextMonth(parts);
|
|
376
|
+
break;
|
|
377
|
+
/**
|
|
378
|
+
* Do not preventDefault here
|
|
379
|
+
* as we do not want to override other
|
|
380
|
+
* browser defaults such as pressing Enter/Space
|
|
381
|
+
* to select a day.
|
|
382
|
+
*/
|
|
383
|
+
default:
|
|
384
|
+
return;
|
|
385
|
+
}
|
|
386
|
+
/**
|
|
387
|
+
* If the day we want to move focus to is
|
|
388
|
+
* disabled, do not do anything.
|
|
389
|
+
*/
|
|
390
|
+
if (isDayDisabled(partsToFocus, this.minParts, this.maxParts)) {
|
|
391
|
+
return;
|
|
392
|
+
}
|
|
393
|
+
this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), partsToFocus));
|
|
394
|
+
/**
|
|
395
|
+
* Give view a chance to re-render
|
|
396
|
+
* then move focus to the new working day
|
|
397
|
+
*/
|
|
398
|
+
requestAnimationFrame(() => this.focusWorkingDay(currentMonth));
|
|
399
|
+
});
|
|
400
|
+
};
|
|
401
|
+
this.focusWorkingDay = (currentMonth) => {
|
|
402
|
+
/**
|
|
403
|
+
* Get the number of padding days so
|
|
404
|
+
* we know how much to offset our next selector by
|
|
405
|
+
* to grab the correct calendar-day element.
|
|
406
|
+
*/
|
|
407
|
+
const padding = currentMonth.querySelectorAll('.calendar-day-padding');
|
|
408
|
+
const { day } = this.workingParts;
|
|
409
|
+
if (day === null) {
|
|
410
|
+
return;
|
|
411
|
+
}
|
|
412
|
+
/**
|
|
413
|
+
* Get the calendar day element
|
|
414
|
+
* and focus it.
|
|
415
|
+
*/
|
|
416
|
+
const dayEl = currentMonth.querySelector(`.calendar-day-wrapper:nth-of-type(${padding.length + day}) .calendar-day`);
|
|
417
|
+
if (dayEl) {
|
|
418
|
+
dayEl.focus();
|
|
419
|
+
}
|
|
420
|
+
};
|
|
421
|
+
this.processMinParts = () => {
|
|
422
|
+
const { min, defaultParts } = this;
|
|
423
|
+
if (min === undefined) {
|
|
424
|
+
this.minParts = undefined;
|
|
425
|
+
return;
|
|
426
|
+
}
|
|
427
|
+
this.minParts = data.parseMinParts(min, defaultParts);
|
|
428
|
+
};
|
|
429
|
+
this.processMaxParts = () => {
|
|
430
|
+
const { max, defaultParts } = this;
|
|
431
|
+
if (max === undefined) {
|
|
432
|
+
this.maxParts = undefined;
|
|
433
|
+
return;
|
|
434
|
+
}
|
|
435
|
+
this.maxParts = data.parseMaxParts(max, defaultParts);
|
|
436
|
+
};
|
|
437
|
+
this.initializeCalendarListener = () => {
|
|
438
|
+
const calendarBodyRef = this.calendarBodyRef;
|
|
439
|
+
if (!calendarBodyRef) {
|
|
440
|
+
return;
|
|
441
|
+
}
|
|
442
|
+
/**
|
|
443
|
+
* For performance reasons, we only render 3
|
|
444
|
+
* months at a time: The current month, the previous
|
|
445
|
+
* month, and the next month. We have a scroll listener
|
|
446
|
+
* on the calendar body to append/prepend new months.
|
|
447
|
+
*
|
|
448
|
+
* We can do this because Stencil is smart enough to not
|
|
449
|
+
* re-create the .calendar-month containers, but rather
|
|
450
|
+
* update the content within those containers.
|
|
451
|
+
*
|
|
452
|
+
* As an added bonus, WebKit has some troubles with
|
|
453
|
+
* scroll-snap-stop: always, so not rendering all of
|
|
454
|
+
* the months in a row allows us to mostly sidestep
|
|
455
|
+
* that issue.
|
|
456
|
+
*/
|
|
457
|
+
const months = calendarBodyRef.querySelectorAll('.calendar-month');
|
|
458
|
+
const startMonth = months[0];
|
|
459
|
+
const workingMonth = months[1];
|
|
460
|
+
const endMonth = months[2];
|
|
461
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
462
|
+
const needsiOSRubberBandFix = mode === 'ios' && typeof navigator !== 'undefined' && navigator.maxTouchPoints > 1;
|
|
463
|
+
/**
|
|
464
|
+
* Before setting up the scroll listener,
|
|
465
|
+
* scroll the middle month into view.
|
|
466
|
+
* scrollIntoView() will scroll entire page
|
|
467
|
+
* if element is not in viewport. Use scrollLeft instead.
|
|
468
|
+
*/
|
|
469
|
+
index$1.writeTask(() => {
|
|
470
|
+
calendarBodyRef.scrollLeft = startMonth.clientWidth * (dir.isRTL(this.el) ? -1 : 1);
|
|
471
|
+
const getChangedMonth = (parts) => {
|
|
472
|
+
const box = calendarBodyRef.getBoundingClientRect();
|
|
473
|
+
/**
|
|
474
|
+
* If the current scroll position is all the way to the left
|
|
475
|
+
* then we have scrolled to the previous month.
|
|
476
|
+
* Otherwise, assume that we have scrolled to the next
|
|
477
|
+
* month. We have a tolerance of 2px to account for
|
|
478
|
+
* sub pixel rendering.
|
|
479
|
+
*
|
|
480
|
+
* Check below the next line ensures that we did not
|
|
481
|
+
* swipe and abort (i.e. we swiped but we are still on the current month).
|
|
482
|
+
*/
|
|
483
|
+
const month = calendarBodyRef.scrollLeft <= 2 ? startMonth : endMonth;
|
|
484
|
+
/**
|
|
485
|
+
* The edge of the month must be lined up with
|
|
486
|
+
* the edge of the calendar body in order for
|
|
487
|
+
* the component to update. Otherwise, it
|
|
488
|
+
* may be the case that the user has paused their
|
|
489
|
+
* swipe or the browser has not finished snapping yet.
|
|
490
|
+
* Rather than check if the x values are equal,
|
|
491
|
+
* we give it a tolerance of 2px to account for
|
|
492
|
+
* sub pixel rendering.
|
|
493
|
+
*/
|
|
494
|
+
const monthBox = month.getBoundingClientRect();
|
|
495
|
+
if (Math.abs(monthBox.x - box.x) > 2)
|
|
496
|
+
return;
|
|
497
|
+
/**
|
|
498
|
+
* If we're force-rendering a month, assume we've
|
|
499
|
+
* scrolled to that and return it.
|
|
500
|
+
*
|
|
501
|
+
* If forceRenderDate is ever used in a context where the
|
|
502
|
+
* forced month is not immediately auto-scrolled to, this
|
|
503
|
+
* should be updated to also check whether `month` has the
|
|
504
|
+
* same month and year as the forced date.
|
|
505
|
+
*/
|
|
506
|
+
const { forceRenderDate } = this;
|
|
507
|
+
if (forceRenderDate !== undefined) {
|
|
508
|
+
return { month: forceRenderDate.month, year: forceRenderDate.year, day: forceRenderDate.day };
|
|
509
|
+
}
|
|
510
|
+
/**
|
|
511
|
+
* From here, we can determine if the start
|
|
512
|
+
* month or the end month was scrolled into view.
|
|
513
|
+
* If no month was changed, then we can return from
|
|
514
|
+
* the scroll callback early.
|
|
515
|
+
*/
|
|
516
|
+
if (month === startMonth) {
|
|
517
|
+
return data.getPreviousMonth(parts);
|
|
518
|
+
}
|
|
519
|
+
else if (month === endMonth) {
|
|
520
|
+
return data.getNextMonth(parts);
|
|
521
|
+
}
|
|
522
|
+
else {
|
|
523
|
+
return;
|
|
524
|
+
}
|
|
525
|
+
};
|
|
526
|
+
const updateActiveMonth = () => {
|
|
527
|
+
if (needsiOSRubberBandFix) {
|
|
528
|
+
calendarBodyRef.style.removeProperty('pointer-events');
|
|
529
|
+
appliediOSRubberBandFix = false;
|
|
530
|
+
}
|
|
531
|
+
/**
|
|
532
|
+
* If the month did not change
|
|
533
|
+
* then we can return early.
|
|
534
|
+
*/
|
|
535
|
+
const newDate = getChangedMonth(this.workingParts);
|
|
536
|
+
if (!newDate)
|
|
537
|
+
return;
|
|
538
|
+
const { month, day, year } = newDate;
|
|
539
|
+
if (isMonthDisabled({ month, year, day: null }, {
|
|
540
|
+
minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
|
|
541
|
+
maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
|
|
542
|
+
})) {
|
|
543
|
+
return;
|
|
544
|
+
}
|
|
545
|
+
/**
|
|
546
|
+
* Prevent scrolling for other browsers
|
|
547
|
+
* to give the DOM time to update and the container
|
|
548
|
+
* time to properly snap.
|
|
549
|
+
*/
|
|
550
|
+
calendarBodyRef.style.setProperty('overflow', 'hidden');
|
|
551
|
+
/**
|
|
552
|
+
* Use a writeTask here to ensure
|
|
553
|
+
* that the state is updated and the
|
|
554
|
+
* correct month is scrolled into view
|
|
555
|
+
* in the same frame. This is not
|
|
556
|
+
* typically a problem on newer devices
|
|
557
|
+
* but older/slower device may have a flicker
|
|
558
|
+
* if we did not do this.
|
|
559
|
+
*/
|
|
560
|
+
index$1.writeTask(() => {
|
|
561
|
+
this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month, day: day, year }));
|
|
562
|
+
calendarBodyRef.scrollLeft = workingMonth.clientWidth * (dir.isRTL(this.el) ? -1 : 1);
|
|
563
|
+
calendarBodyRef.style.removeProperty('overflow');
|
|
564
|
+
if (this.resolveForceDateScrolling) {
|
|
565
|
+
this.resolveForceDateScrolling();
|
|
566
|
+
}
|
|
567
|
+
});
|
|
568
|
+
};
|
|
569
|
+
/**
|
|
570
|
+
* When the container finishes scrolling we
|
|
571
|
+
* need to update the DOM with the selected month.
|
|
572
|
+
*/
|
|
573
|
+
let scrollTimeout;
|
|
574
|
+
/**
|
|
575
|
+
* We do not want to attempt to set pointer-events
|
|
576
|
+
* multiple times within a single swipe gesture as
|
|
577
|
+
* that adds unnecessary work to the main thread.
|
|
578
|
+
*/
|
|
579
|
+
let appliediOSRubberBandFix = false;
|
|
580
|
+
const scrollCallback = () => {
|
|
581
|
+
if (scrollTimeout) {
|
|
582
|
+
clearTimeout(scrollTimeout);
|
|
583
|
+
}
|
|
584
|
+
/**
|
|
585
|
+
* On iOS it is possible to quickly rubber band
|
|
586
|
+
* the scroll area before the scroll timeout has fired.
|
|
587
|
+
* This results in users reaching the end of the scrollable
|
|
588
|
+
* container before the DOM has updated.
|
|
589
|
+
* By setting `pointer-events: none` we can ensure that
|
|
590
|
+
* subsequent swipes do not happen while the container
|
|
591
|
+
* is snapping.
|
|
592
|
+
*/
|
|
593
|
+
if (!appliediOSRubberBandFix && needsiOSRubberBandFix) {
|
|
594
|
+
calendarBodyRef.style.setProperty('pointer-events', 'none');
|
|
595
|
+
appliediOSRubberBandFix = true;
|
|
596
|
+
}
|
|
597
|
+
// Wait ~3 frames
|
|
598
|
+
scrollTimeout = setTimeout(updateActiveMonth, 50);
|
|
599
|
+
};
|
|
600
|
+
calendarBodyRef.addEventListener('scroll', scrollCallback);
|
|
601
|
+
this.destroyCalendarListener = () => {
|
|
602
|
+
calendarBodyRef.removeEventListener('scroll', scrollCallback);
|
|
603
|
+
};
|
|
604
|
+
});
|
|
605
|
+
};
|
|
606
|
+
/**
|
|
607
|
+
* Clean up all listeners except for the overlay
|
|
608
|
+
* listener. This is so that we can re-create the listeners
|
|
609
|
+
* if the datetime has been hidden/presented by a modal or popover.
|
|
610
|
+
*/
|
|
611
|
+
this.destroyInteractionListeners = () => {
|
|
612
|
+
const { destroyCalendarListener, destroyKeyboardMO } = this;
|
|
613
|
+
if (destroyCalendarListener !== undefined) {
|
|
614
|
+
destroyCalendarListener();
|
|
615
|
+
}
|
|
616
|
+
if (destroyKeyboardMO !== undefined) {
|
|
617
|
+
destroyKeyboardMO();
|
|
618
|
+
}
|
|
619
|
+
};
|
|
620
|
+
this.processValue = (value) => {
|
|
621
|
+
const hasValue = value !== null && value !== undefined && (!Array.isArray(value) || value.length > 0);
|
|
622
|
+
const valueToProcess = hasValue ? data.parseDate(value) : this.defaultParts;
|
|
623
|
+
const { minParts, maxParts, workingParts, el } = this;
|
|
624
|
+
this.warnIfIncorrectValueUsage();
|
|
625
|
+
/**
|
|
626
|
+
* Return early if the value wasn't parsed correctly, such as
|
|
627
|
+
* if an improperly formatted date string was provided.
|
|
628
|
+
*/
|
|
629
|
+
if (!valueToProcess) {
|
|
630
|
+
return;
|
|
631
|
+
}
|
|
632
|
+
/**
|
|
633
|
+
* Datetime should only warn of out of bounds values
|
|
634
|
+
* if set by the user. If the `value` is undefined,
|
|
635
|
+
* we will default to today's date which may be out
|
|
636
|
+
* of bounds. In this case, the warning makes it look
|
|
637
|
+
* like the developer did something wrong which is
|
|
638
|
+
* not true.
|
|
639
|
+
*/
|
|
640
|
+
if (hasValue) {
|
|
641
|
+
data.warnIfValueOutOfBounds(valueToProcess, minParts, maxParts);
|
|
642
|
+
}
|
|
643
|
+
/**
|
|
644
|
+
* If there are multiple values, pick an arbitrary one to clamp to. This way,
|
|
645
|
+
* if the values are across months, we always show at least one of them. Note
|
|
646
|
+
* that the values don't necessarily have to be in order.
|
|
647
|
+
*/
|
|
648
|
+
const singleValue = Array.isArray(valueToProcess) ? valueToProcess[0] : valueToProcess;
|
|
649
|
+
const targetValue = data.clampDate(singleValue, minParts, maxParts);
|
|
650
|
+
const { month, day, year, hour, minute } = targetValue;
|
|
651
|
+
const ampm = data.parseAmPm(hour);
|
|
652
|
+
/**
|
|
653
|
+
* Since `activeParts` indicates a value that
|
|
654
|
+
* been explicitly selected either by the
|
|
655
|
+
* user or the app, only update `activeParts`
|
|
656
|
+
* if the `value` property is set.
|
|
657
|
+
*/
|
|
658
|
+
if (hasValue) {
|
|
659
|
+
if (Array.isArray(valueToProcess)) {
|
|
660
|
+
this.activeParts = [...valueToProcess];
|
|
661
|
+
}
|
|
662
|
+
else {
|
|
663
|
+
this.activeParts = {
|
|
664
|
+
month,
|
|
665
|
+
day,
|
|
666
|
+
year,
|
|
667
|
+
hour,
|
|
668
|
+
minute,
|
|
669
|
+
ampm,
|
|
670
|
+
};
|
|
671
|
+
}
|
|
672
|
+
}
|
|
673
|
+
else {
|
|
674
|
+
/**
|
|
675
|
+
* Reset the active parts if the value is not set.
|
|
676
|
+
* This will clear the selected calendar day when
|
|
677
|
+
* performing a clear action or using the reset() method.
|
|
678
|
+
*/
|
|
679
|
+
this.activeParts = [];
|
|
680
|
+
}
|
|
681
|
+
/**
|
|
682
|
+
* Only animate if:
|
|
683
|
+
* 1. We're using grid style (wheel style pickers should just jump to new value)
|
|
684
|
+
* 2. The month and/or year actually changed, and both are defined (otherwise there's nothing to animate to)
|
|
685
|
+
* 3. The calendar body is visible (prevents animation when in collapsed datetime-button, for example)
|
|
686
|
+
* 4. The month/year picker is not open (since you wouldn't see the animation anyway)
|
|
687
|
+
*/
|
|
688
|
+
const didChangeMonth = (month !== undefined && month !== workingParts.month) || (year !== undefined && year !== workingParts.year);
|
|
689
|
+
const bodyIsVisible = el.classList.contains('datetime-ready');
|
|
690
|
+
const { isGridStyle, showMonthAndYear } = this;
|
|
691
|
+
if (isGridStyle && didChangeMonth && bodyIsVisible && !showMonthAndYear) {
|
|
692
|
+
this.animateToDate(targetValue);
|
|
693
|
+
}
|
|
694
|
+
else {
|
|
695
|
+
/**
|
|
696
|
+
* We only need to do this if we didn't just animate to a new month,
|
|
697
|
+
* since that calls prevMonth/nextMonth which calls setWorkingParts for us.
|
|
698
|
+
*/
|
|
699
|
+
this.setWorkingParts({
|
|
700
|
+
month,
|
|
701
|
+
day,
|
|
702
|
+
year,
|
|
703
|
+
hour,
|
|
704
|
+
minute,
|
|
705
|
+
ampm,
|
|
706
|
+
});
|
|
707
|
+
}
|
|
708
|
+
};
|
|
709
|
+
this.animateToDate = async (targetValue) => {
|
|
710
|
+
const { workingParts } = this;
|
|
711
|
+
/**
|
|
712
|
+
* Tell other render functions that we need to force the
|
|
713
|
+
* target month to appear in place of the actual next/prev month.
|
|
714
|
+
* Because this is a State variable, a rerender will be triggered
|
|
715
|
+
* automatically, updating the rendered months.
|
|
716
|
+
*/
|
|
717
|
+
this.forceRenderDate = targetValue;
|
|
718
|
+
/**
|
|
719
|
+
* Flag that we've started scrolling to the forced date.
|
|
720
|
+
* The resolve function will be called by the datetime's
|
|
721
|
+
* scroll listener when it's done updating everything.
|
|
722
|
+
* This is a replacement for making prev/nextMonth async,
|
|
723
|
+
* since the logic we're waiting on is in a listener.
|
|
724
|
+
*/
|
|
725
|
+
const forceDateScrollingPromise = new Promise((resolve) => {
|
|
726
|
+
this.resolveForceDateScrolling = resolve;
|
|
727
|
+
});
|
|
728
|
+
/**
|
|
729
|
+
* Animate smoothly to the forced month. This will also update
|
|
730
|
+
* workingParts and correct the surrounding months for us.
|
|
731
|
+
*/
|
|
732
|
+
const targetMonthIsBefore = data.isBefore(targetValue, workingParts);
|
|
733
|
+
targetMonthIsBefore ? this.prevMonth() : this.nextMonth();
|
|
734
|
+
await forceDateScrollingPromise;
|
|
735
|
+
this.resolveForceDateScrolling = undefined;
|
|
736
|
+
this.forceRenderDate = undefined;
|
|
737
|
+
};
|
|
738
|
+
this.onFocus = () => {
|
|
739
|
+
this.ionFocus.emit();
|
|
740
|
+
};
|
|
741
|
+
this.onBlur = () => {
|
|
742
|
+
this.ionBlur.emit();
|
|
743
|
+
};
|
|
744
|
+
this.hasValue = () => {
|
|
745
|
+
return this.value != null;
|
|
746
|
+
};
|
|
747
|
+
this.nextMonth = () => {
|
|
748
|
+
const calendarBodyRef = this.calendarBodyRef;
|
|
749
|
+
if (!calendarBodyRef) {
|
|
750
|
+
return;
|
|
751
|
+
}
|
|
752
|
+
const nextMonth = calendarBodyRef.querySelector('.calendar-month:last-of-type');
|
|
753
|
+
if (!nextMonth) {
|
|
754
|
+
return;
|
|
755
|
+
}
|
|
756
|
+
const left = nextMonth.offsetWidth * 2;
|
|
757
|
+
calendarBodyRef.scrollTo({
|
|
758
|
+
top: 0,
|
|
759
|
+
left: left * (dir.isRTL(this.el) ? -1 : 1),
|
|
760
|
+
behavior: 'smooth',
|
|
761
|
+
});
|
|
762
|
+
};
|
|
763
|
+
this.prevMonth = () => {
|
|
764
|
+
const calendarBodyRef = this.calendarBodyRef;
|
|
765
|
+
if (!calendarBodyRef) {
|
|
766
|
+
return;
|
|
767
|
+
}
|
|
768
|
+
const prevMonth = calendarBodyRef.querySelector('.calendar-month:first-of-type');
|
|
769
|
+
if (!prevMonth) {
|
|
770
|
+
return;
|
|
771
|
+
}
|
|
772
|
+
calendarBodyRef.scrollTo({
|
|
773
|
+
top: 0,
|
|
774
|
+
left: 0,
|
|
775
|
+
behavior: 'smooth',
|
|
776
|
+
});
|
|
777
|
+
};
|
|
778
|
+
this.toggleMonthAndYearView = () => {
|
|
779
|
+
this.showMonthAndYear = !this.showMonthAndYear;
|
|
780
|
+
};
|
|
781
|
+
this.showMonthAndYear = false;
|
|
782
|
+
this.activeParts = [];
|
|
783
|
+
this.workingParts = {
|
|
784
|
+
month: 5,
|
|
785
|
+
day: 28,
|
|
786
|
+
year: 2021,
|
|
787
|
+
hour: 13,
|
|
788
|
+
minute: 52,
|
|
789
|
+
ampm: 'pm',
|
|
790
|
+
};
|
|
791
|
+
this.isTimePopoverOpen = false;
|
|
792
|
+
this.forceRenderDate = undefined;
|
|
793
|
+
this.color = 'primary';
|
|
794
|
+
this.name = this.inputId;
|
|
795
|
+
this.disabled = false;
|
|
796
|
+
this.readonly = false;
|
|
797
|
+
this.isDateEnabled = undefined;
|
|
798
|
+
this.min = undefined;
|
|
799
|
+
this.max = undefined;
|
|
800
|
+
this.presentation = 'date-time';
|
|
801
|
+
this.cancelText = 'Cancel';
|
|
802
|
+
this.doneText = 'Done';
|
|
803
|
+
this.clearText = 'Clear';
|
|
804
|
+
this.yearValues = undefined;
|
|
805
|
+
this.monthValues = undefined;
|
|
806
|
+
this.dayValues = undefined;
|
|
807
|
+
this.hourValues = undefined;
|
|
808
|
+
this.minuteValues = undefined;
|
|
809
|
+
this.locale = 'default';
|
|
810
|
+
this.firstDayOfWeek = 0;
|
|
811
|
+
this.titleSelectedDatesFormatter = undefined;
|
|
812
|
+
this.multiple = false;
|
|
813
|
+
this.highlightedDates = undefined;
|
|
814
|
+
this.value = undefined;
|
|
815
|
+
this.showDefaultTitle = false;
|
|
816
|
+
this.showDefaultButtons = false;
|
|
817
|
+
this.showClearButton = false;
|
|
818
|
+
this.showDefaultTimeLabel = true;
|
|
819
|
+
this.hourCycle = undefined;
|
|
820
|
+
this.size = 'fixed';
|
|
821
|
+
this.preferWheel = false;
|
|
822
|
+
}
|
|
823
|
+
disabledChanged() {
|
|
824
|
+
this.emitStyle();
|
|
825
|
+
}
|
|
826
|
+
minChanged() {
|
|
827
|
+
this.processMinParts();
|
|
828
|
+
}
|
|
829
|
+
maxChanged() {
|
|
830
|
+
this.processMaxParts();
|
|
831
|
+
}
|
|
832
|
+
get isGridStyle() {
|
|
833
|
+
const { presentation, preferWheel } = this;
|
|
834
|
+
const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
|
|
835
|
+
return hasDatePresentation && !preferWheel;
|
|
836
|
+
}
|
|
837
|
+
yearValuesChanged() {
|
|
838
|
+
this.parsedYearValues = data.convertToArrayOfNumbers(this.yearValues);
|
|
839
|
+
}
|
|
840
|
+
monthValuesChanged() {
|
|
841
|
+
this.parsedMonthValues = data.convertToArrayOfNumbers(this.monthValues);
|
|
842
|
+
}
|
|
843
|
+
dayValuesChanged() {
|
|
844
|
+
this.parsedDayValues = data.convertToArrayOfNumbers(this.dayValues);
|
|
845
|
+
}
|
|
846
|
+
hourValuesChanged() {
|
|
847
|
+
this.parsedHourValues = data.convertToArrayOfNumbers(this.hourValues);
|
|
848
|
+
}
|
|
849
|
+
minuteValuesChanged() {
|
|
850
|
+
this.parsedMinuteValues = data.convertToArrayOfNumbers(this.minuteValues);
|
|
851
|
+
}
|
|
230
852
|
/**
|
|
231
|
-
*
|
|
232
|
-
* to use when rendering an initial set of
|
|
233
|
-
* data. This should be used when rendering an
|
|
234
|
-
* interface in an environment where the `value`
|
|
235
|
-
* may not be set. This function works
|
|
236
|
-
* by returning the first selected date and then
|
|
237
|
-
* falling back to defaultParts if no active date
|
|
238
|
-
* is selected.
|
|
853
|
+
* Update the datetime value when the value changes
|
|
239
854
|
*/
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
};
|
|
245
|
-
this.getActivePart = () => {
|
|
246
|
-
const { activeParts } = this;
|
|
247
|
-
return Array.isArray(activeParts) ? activeParts[0] : activeParts;
|
|
248
|
-
};
|
|
249
|
-
this.closeParentOverlay = () => {
|
|
250
|
-
const popoverOrModal = this.el.closest('ion-modal, ion-popover');
|
|
251
|
-
if (popoverOrModal) {
|
|
252
|
-
popoverOrModal.dismiss();
|
|
253
|
-
}
|
|
254
|
-
};
|
|
255
|
-
this.setWorkingParts = (parts) => {
|
|
256
|
-
this.workingParts = Object.assign({}, parts);
|
|
257
|
-
};
|
|
258
|
-
this.setActiveParts = (parts, removeDate = false) => {
|
|
259
|
-
/** if the datetime component is in readonly mode,
|
|
260
|
-
* allow browsing of the calendar without changing
|
|
261
|
-
* the set value
|
|
262
|
-
*/
|
|
263
|
-
if (this.readonly) {
|
|
264
|
-
return;
|
|
265
|
-
}
|
|
266
|
-
const { multiple, minParts, maxParts, activeParts } = this;
|
|
267
|
-
/**
|
|
268
|
-
* When setting the active parts, it is possible
|
|
269
|
-
* to set invalid data. For example,
|
|
270
|
-
* when updating January 31 to February,
|
|
271
|
-
* February 31 does not exist. As a result
|
|
272
|
-
* we need to validate the active parts and
|
|
273
|
-
* ensure that we are only setting valid dates.
|
|
274
|
-
* Additionally, we need to update the working parts
|
|
275
|
-
* too in the event that the validated parts are different.
|
|
276
|
-
*/
|
|
277
|
-
const validatedParts = data.validateParts(parts, minParts, maxParts);
|
|
278
|
-
this.setWorkingParts(validatedParts);
|
|
279
|
-
if (multiple) {
|
|
280
|
-
const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
|
|
281
|
-
if (removeDate) {
|
|
282
|
-
this.activeParts = activePartsArray.filter((p) => !data.isSameDay(p, validatedParts));
|
|
855
|
+
async valueChanged() {
|
|
856
|
+
const { value } = this;
|
|
857
|
+
if (this.hasValue()) {
|
|
858
|
+
this.processValue(value);
|
|
283
859
|
}
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
}
|
|
295
|
-
this.confirm();
|
|
296
|
-
};
|
|
297
|
-
this.initializeKeyboardListeners = () => {
|
|
298
|
-
const calendarBodyRef = this.calendarBodyRef;
|
|
299
|
-
if (!calendarBodyRef) {
|
|
300
|
-
return;
|
|
301
|
-
}
|
|
302
|
-
const root = this.el.shadowRoot;
|
|
303
|
-
/**
|
|
304
|
-
* Get a reference to the month
|
|
305
|
-
* element we are currently viewing.
|
|
306
|
-
*/
|
|
307
|
-
const currentMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(2)');
|
|
308
|
-
/**
|
|
309
|
-
* When focusing the calendar body, we want to pass focus
|
|
310
|
-
* to the working day, but other days should
|
|
311
|
-
* only be accessible using the arrow keys. Pressing
|
|
312
|
-
* Tab should jump between bodies of selectable content.
|
|
313
|
-
*/
|
|
314
|
-
const checkCalendarBodyFocus = (ev) => {
|
|
315
|
-
var _a;
|
|
316
|
-
const record = ev[0];
|
|
860
|
+
this.emitStyle();
|
|
861
|
+
this.ionValueChange.emit({ value });
|
|
862
|
+
}
|
|
863
|
+
/**
|
|
864
|
+
* Confirms the selected datetime value, updates the
|
|
865
|
+
* `value` property, and optionally closes the popover
|
|
866
|
+
* or modal that the datetime was presented in.
|
|
867
|
+
*/
|
|
868
|
+
async confirm(closeOverlay = false) {
|
|
869
|
+
const { isCalendarPicker, activeParts, preferWheel, workingParts } = this;
|
|
317
870
|
/**
|
|
318
|
-
*
|
|
319
|
-
* when this fired or if the calendar body
|
|
320
|
-
* if not currently focused, we should not re-focus
|
|
321
|
-
* the inner day.
|
|
871
|
+
* We only update the value if the presentation is not a calendar picker.
|
|
322
872
|
*/
|
|
323
|
-
if (
|
|
324
|
-
|
|
873
|
+
if (activeParts !== undefined || !isCalendarPicker) {
|
|
874
|
+
const activePartsIsArray = Array.isArray(activeParts);
|
|
875
|
+
if (activePartsIsArray && activeParts.length === 0) {
|
|
876
|
+
if (preferWheel) {
|
|
877
|
+
/**
|
|
878
|
+
* If the datetime is using a wheel picker, but the
|
|
879
|
+
* active parts are empty, then the user has confirmed the
|
|
880
|
+
* initial value (working parts) presented to them.
|
|
881
|
+
*/
|
|
882
|
+
this.setValue(data.convertDataToISO(workingParts));
|
|
883
|
+
}
|
|
884
|
+
else {
|
|
885
|
+
this.setValue(undefined);
|
|
886
|
+
}
|
|
887
|
+
}
|
|
888
|
+
else {
|
|
889
|
+
this.setValue(data.convertDataToISO(activeParts));
|
|
890
|
+
}
|
|
325
891
|
}
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
const mo = new MutationObserver(checkCalendarBodyFocus);
|
|
329
|
-
mo.observe(calendarBodyRef, { attributeFilter: ['class'], attributeOldValue: true });
|
|
330
|
-
this.destroyKeyboardMO = () => {
|
|
331
|
-
mo === null || mo === void 0 ? void 0 : mo.disconnect();
|
|
332
|
-
};
|
|
333
|
-
/**
|
|
334
|
-
* We must use keydown not keyup as we want
|
|
335
|
-
* to prevent scrolling when using the arrow keys.
|
|
336
|
-
*/
|
|
337
|
-
calendarBodyRef.addEventListener('keydown', (ev) => {
|
|
338
|
-
const activeElement = root.activeElement;
|
|
339
|
-
if (!activeElement || !activeElement.classList.contains('calendar-day')) {
|
|
340
|
-
return;
|
|
892
|
+
if (closeOverlay) {
|
|
893
|
+
this.closeParentOverlay();
|
|
341
894
|
}
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
case 'Home':
|
|
362
|
-
ev.preventDefault();
|
|
363
|
-
partsToFocus = data.getStartOfWeek(parts);
|
|
364
|
-
break;
|
|
365
|
-
case 'End':
|
|
366
|
-
ev.preventDefault();
|
|
367
|
-
partsToFocus = data.getEndOfWeek(parts);
|
|
368
|
-
break;
|
|
369
|
-
case 'PageUp':
|
|
370
|
-
ev.preventDefault();
|
|
371
|
-
partsToFocus = ev.shiftKey ? data.getPreviousYear(parts) : data.getPreviousMonth(parts);
|
|
372
|
-
break;
|
|
373
|
-
case 'PageDown':
|
|
374
|
-
ev.preventDefault();
|
|
375
|
-
partsToFocus = ev.shiftKey ? data.getNextYear(parts) : data.getNextMonth(parts);
|
|
376
|
-
break;
|
|
377
|
-
/**
|
|
378
|
-
* Do not preventDefault here
|
|
379
|
-
* as we do not want to override other
|
|
380
|
-
* browser defaults such as pressing Enter/Space
|
|
381
|
-
* to select a day.
|
|
382
|
-
*/
|
|
383
|
-
default:
|
|
384
|
-
return;
|
|
895
|
+
}
|
|
896
|
+
/**
|
|
897
|
+
* Resets the internal state of the datetime but does not update the value.
|
|
898
|
+
* Passing a valid ISO-8601 string will reset the state of the component to the provided date.
|
|
899
|
+
* If no value is provided, the internal state will be reset to the clamped value of the min, max and today.
|
|
900
|
+
*/
|
|
901
|
+
async reset(startDate) {
|
|
902
|
+
this.processValue(startDate);
|
|
903
|
+
}
|
|
904
|
+
/**
|
|
905
|
+
* Emits the ionCancel event and
|
|
906
|
+
* optionally closes the popover
|
|
907
|
+
* or modal that the datetime was
|
|
908
|
+
* presented in.
|
|
909
|
+
*/
|
|
910
|
+
async cancel(closeOverlay = false) {
|
|
911
|
+
this.ionCancel.emit();
|
|
912
|
+
if (closeOverlay) {
|
|
913
|
+
this.closeParentOverlay();
|
|
385
914
|
}
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
915
|
+
}
|
|
916
|
+
get isCalendarPicker() {
|
|
917
|
+
const { presentation } = this;
|
|
918
|
+
return presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
|
|
919
|
+
}
|
|
920
|
+
connectedCallback() {
|
|
921
|
+
this.clearFocusVisible = focusVisible.startFocusVisible(this.el).destroy;
|
|
922
|
+
}
|
|
923
|
+
disconnectedCallback() {
|
|
924
|
+
if (this.clearFocusVisible) {
|
|
925
|
+
this.clearFocusVisible();
|
|
926
|
+
this.clearFocusVisible = undefined;
|
|
392
927
|
}
|
|
393
|
-
|
|
928
|
+
}
|
|
929
|
+
initializeListeners() {
|
|
930
|
+
this.initializeCalendarListener();
|
|
931
|
+
this.initializeKeyboardListeners();
|
|
932
|
+
}
|
|
933
|
+
componentDidLoad() {
|
|
394
934
|
/**
|
|
395
|
-
*
|
|
396
|
-
*
|
|
935
|
+
* If a scrollable element is hidden using `display: none`,
|
|
936
|
+
* it will not have a scroll height meaning we cannot scroll elements
|
|
937
|
+
* into view. As a result, we will need to wait for the datetime to become
|
|
938
|
+
* visible if used inside of a modal or a popover otherwise the scrollable
|
|
939
|
+
* areas will not have the correct values snapped into place.
|
|
397
940
|
*/
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
/**
|
|
403
|
-
* Get the number of padding days so
|
|
404
|
-
* we know how much to offset our next selector by
|
|
405
|
-
* to grab the correct calendar-day element.
|
|
406
|
-
*/
|
|
407
|
-
const padding = currentMonth.querySelectorAll('.calendar-day-padding');
|
|
408
|
-
const { day } = this.workingParts;
|
|
409
|
-
if (day === null) {
|
|
410
|
-
return;
|
|
411
|
-
}
|
|
412
|
-
/**
|
|
413
|
-
* Get the calendar day element
|
|
414
|
-
* and focus it.
|
|
415
|
-
*/
|
|
416
|
-
const dayEl = currentMonth.querySelector(`.calendar-day-wrapper:nth-of-type(${padding.length + day}) .calendar-day`);
|
|
417
|
-
if (dayEl) {
|
|
418
|
-
dayEl.focus();
|
|
419
|
-
}
|
|
420
|
-
};
|
|
421
|
-
this.processMinParts = () => {
|
|
422
|
-
const { min, defaultParts } = this;
|
|
423
|
-
if (min === undefined) {
|
|
424
|
-
this.minParts = undefined;
|
|
425
|
-
return;
|
|
426
|
-
}
|
|
427
|
-
this.minParts = data.parseMinParts(min, defaultParts);
|
|
428
|
-
};
|
|
429
|
-
this.processMaxParts = () => {
|
|
430
|
-
const { max, defaultParts } = this;
|
|
431
|
-
if (max === undefined) {
|
|
432
|
-
this.maxParts = undefined;
|
|
433
|
-
return;
|
|
434
|
-
}
|
|
435
|
-
this.maxParts = data.parseMaxParts(max, defaultParts);
|
|
436
|
-
};
|
|
437
|
-
this.initializeCalendarListener = () => {
|
|
438
|
-
const calendarBodyRef = this.calendarBodyRef;
|
|
439
|
-
if (!calendarBodyRef) {
|
|
440
|
-
return;
|
|
441
|
-
}
|
|
442
|
-
/**
|
|
443
|
-
* For performance reasons, we only render 3
|
|
444
|
-
* months at a time: The current month, the previous
|
|
445
|
-
* month, and the next month. We have a scroll listener
|
|
446
|
-
* on the calendar body to append/prepend new months.
|
|
447
|
-
*
|
|
448
|
-
* We can do this because Stencil is smart enough to not
|
|
449
|
-
* re-create the .calendar-month containers, but rather
|
|
450
|
-
* update the content within those containers.
|
|
451
|
-
*
|
|
452
|
-
* As an added bonus, WebKit has some troubles with
|
|
453
|
-
* scroll-snap-stop: always, so not rendering all of
|
|
454
|
-
* the months in a row allows us to mostly sidestep
|
|
455
|
-
* that issue.
|
|
456
|
-
*/
|
|
457
|
-
const months = calendarBodyRef.querySelectorAll('.calendar-month');
|
|
458
|
-
const startMonth = months[0];
|
|
459
|
-
const workingMonth = months[1];
|
|
460
|
-
const endMonth = months[2];
|
|
461
|
-
const mode = ionicGlobal.getIonMode(this);
|
|
462
|
-
const needsiOSRubberBandFix = mode === 'ios' && typeof navigator !== 'undefined' && navigator.maxTouchPoints > 1;
|
|
463
|
-
/**
|
|
464
|
-
* Before setting up the scroll listener,
|
|
465
|
-
* scroll the middle month into view.
|
|
466
|
-
* scrollIntoView() will scroll entire page
|
|
467
|
-
* if element is not in viewport. Use scrollLeft instead.
|
|
468
|
-
*/
|
|
469
|
-
index$1.writeTask(() => {
|
|
470
|
-
calendarBodyRef.scrollLeft = startMonth.clientWidth * (dir.isRTL(this.el) ? -1 : 1);
|
|
471
|
-
const getChangedMonth = (parts) => {
|
|
472
|
-
const box = calendarBodyRef.getBoundingClientRect();
|
|
473
|
-
/**
|
|
474
|
-
* If the current scroll position is all the way to the left
|
|
475
|
-
* then we have scrolled to the previous month.
|
|
476
|
-
* Otherwise, assume that we have scrolled to the next
|
|
477
|
-
* month. We have a tolerance of 2px to account for
|
|
478
|
-
* sub pixel rendering.
|
|
479
|
-
*
|
|
480
|
-
* Check below the next line ensures that we did not
|
|
481
|
-
* swipe and abort (i.e. we swiped but we are still on the current month).
|
|
482
|
-
*/
|
|
483
|
-
const month = calendarBodyRef.scrollLeft <= 2 ? startMonth : endMonth;
|
|
484
|
-
/**
|
|
485
|
-
* The edge of the month must be lined up with
|
|
486
|
-
* the edge of the calendar body in order for
|
|
487
|
-
* the component to update. Otherwise, it
|
|
488
|
-
* may be the case that the user has paused their
|
|
489
|
-
* swipe or the browser has not finished snapping yet.
|
|
490
|
-
* Rather than check if the x values are equal,
|
|
491
|
-
* we give it a tolerance of 2px to account for
|
|
492
|
-
* sub pixel rendering.
|
|
493
|
-
*/
|
|
494
|
-
const monthBox = month.getBoundingClientRect();
|
|
495
|
-
if (Math.abs(monthBox.x - box.x) > 2)
|
|
496
|
-
return;
|
|
497
|
-
/**
|
|
498
|
-
* If we're force-rendering a month, assume we've
|
|
499
|
-
* scrolled to that and return it.
|
|
500
|
-
*
|
|
501
|
-
* If forceRenderDate is ever used in a context where the
|
|
502
|
-
* forced month is not immediately auto-scrolled to, this
|
|
503
|
-
* should be updated to also check whether `month` has the
|
|
504
|
-
* same month and year as the forced date.
|
|
505
|
-
*/
|
|
506
|
-
const { forceRenderDate } = this;
|
|
507
|
-
if (forceRenderDate !== undefined) {
|
|
508
|
-
return { month: forceRenderDate.month, year: forceRenderDate.year, day: forceRenderDate.day };
|
|
509
|
-
}
|
|
510
|
-
/**
|
|
511
|
-
* From here, we can determine if the start
|
|
512
|
-
* month or the end month was scrolled into view.
|
|
513
|
-
* If no month was changed, then we can return from
|
|
514
|
-
* the scroll callback early.
|
|
515
|
-
*/
|
|
516
|
-
if (month === startMonth) {
|
|
517
|
-
return data.getPreviousMonth(parts);
|
|
518
|
-
}
|
|
519
|
-
else if (month === endMonth) {
|
|
520
|
-
return data.getNextMonth(parts);
|
|
521
|
-
}
|
|
522
|
-
else {
|
|
523
|
-
return;
|
|
524
|
-
}
|
|
525
|
-
};
|
|
526
|
-
const updateActiveMonth = () => {
|
|
527
|
-
if (needsiOSRubberBandFix) {
|
|
528
|
-
calendarBodyRef.style.removeProperty('pointer-events');
|
|
529
|
-
appliediOSRubberBandFix = false;
|
|
530
|
-
}
|
|
531
|
-
/**
|
|
532
|
-
* If the month did not change
|
|
533
|
-
* then we can return early.
|
|
534
|
-
*/
|
|
535
|
-
const newDate = getChangedMonth(this.workingParts);
|
|
536
|
-
if (!newDate)
|
|
537
|
-
return;
|
|
538
|
-
const { month, day, year } = newDate;
|
|
539
|
-
if (isMonthDisabled({ month, year, day: null }, {
|
|
540
|
-
minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
|
|
541
|
-
maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
|
|
542
|
-
})) {
|
|
543
|
-
return;
|
|
544
|
-
}
|
|
545
|
-
/**
|
|
546
|
-
* Prevent scrolling for other browsers
|
|
547
|
-
* to give the DOM time to update and the container
|
|
548
|
-
* time to properly snap.
|
|
549
|
-
*/
|
|
550
|
-
calendarBodyRef.style.setProperty('overflow', 'hidden');
|
|
551
|
-
/**
|
|
552
|
-
* Use a writeTask here to ensure
|
|
553
|
-
* that the state is updated and the
|
|
554
|
-
* correct month is scrolled into view
|
|
555
|
-
* in the same frame. This is not
|
|
556
|
-
* typically a problem on newer devices
|
|
557
|
-
* but older/slower device may have a flicker
|
|
558
|
-
* if we did not do this.
|
|
559
|
-
*/
|
|
560
|
-
index$1.writeTask(() => {
|
|
561
|
-
this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month, day: day, year }));
|
|
562
|
-
calendarBodyRef.scrollLeft = workingMonth.clientWidth * (dir.isRTL(this.el) ? -1 : 1);
|
|
563
|
-
calendarBodyRef.style.removeProperty('overflow');
|
|
564
|
-
if (this.resolveForceDateScrolling) {
|
|
565
|
-
this.resolveForceDateScrolling();
|
|
941
|
+
const visibleCallback = (entries) => {
|
|
942
|
+
const ev = entries[0];
|
|
943
|
+
if (!ev.isIntersecting) {
|
|
944
|
+
return;
|
|
566
945
|
}
|
|
567
|
-
|
|
946
|
+
this.initializeListeners();
|
|
947
|
+
/**
|
|
948
|
+
* TODO FW-2793: Datetime needs a frame to ensure that it
|
|
949
|
+
* can properly scroll contents into view. As a result
|
|
950
|
+
* we hide the scrollable content until after that frame
|
|
951
|
+
* so users do not see the content quickly shifting. The downside
|
|
952
|
+
* is that the content will pop into view a frame after. Maybe there
|
|
953
|
+
* is a better way to handle this?
|
|
954
|
+
*/
|
|
955
|
+
index$1.writeTask(() => {
|
|
956
|
+
this.el.classList.add('datetime-ready');
|
|
957
|
+
});
|
|
568
958
|
};
|
|
959
|
+
const visibleIO = new IntersectionObserver(visibleCallback, { threshold: 0.01 });
|
|
569
960
|
/**
|
|
570
|
-
*
|
|
571
|
-
*
|
|
961
|
+
* Use raf to avoid a race condition between the component loading and
|
|
962
|
+
* its display animation starting (such as when shown in a modal). This
|
|
963
|
+
* could cause the datetime to start at a visibility of 0, erroneously
|
|
964
|
+
* triggering the `hiddenIO` observer below.
|
|
572
965
|
*/
|
|
573
|
-
|
|
966
|
+
helpers.raf(() => visibleIO === null || visibleIO === void 0 ? void 0 : visibleIO.observe(this.el));
|
|
574
967
|
/**
|
|
575
|
-
* We
|
|
576
|
-
*
|
|
577
|
-
*
|
|
968
|
+
* We need to clean up listeners when the datetime is hidden
|
|
969
|
+
* in a popover/modal so that we can properly scroll containers
|
|
970
|
+
* back into view if they are re-presented. When the datetime is hidden
|
|
971
|
+
* the scroll areas have scroll widths/heights of 0px, so any snapping
|
|
972
|
+
* we did originally has been lost.
|
|
578
973
|
*/
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
}
|
|
597
|
-
// Wait ~3 frames
|
|
598
|
-
scrollTimeout = setTimeout(updateActiveMonth, 50);
|
|
599
|
-
};
|
|
600
|
-
calendarBodyRef.addEventListener('scroll', scrollCallback);
|
|
601
|
-
this.destroyCalendarListener = () => {
|
|
602
|
-
calendarBodyRef.removeEventListener('scroll', scrollCallback);
|
|
974
|
+
const hiddenCallback = (entries) => {
|
|
975
|
+
const ev = entries[0];
|
|
976
|
+
if (ev.isIntersecting) {
|
|
977
|
+
return;
|
|
978
|
+
}
|
|
979
|
+
this.destroyInteractionListeners();
|
|
980
|
+
/**
|
|
981
|
+
* When datetime is hidden, we need to make sure that
|
|
982
|
+
* the month/year picker is closed. Otherwise,
|
|
983
|
+
* it will be open when the datetime re-appears
|
|
984
|
+
* and the scroll area of the calendar grid will be 0.
|
|
985
|
+
* As a result, the wrong month will be shown.
|
|
986
|
+
*/
|
|
987
|
+
this.showMonthAndYear = false;
|
|
988
|
+
index$1.writeTask(() => {
|
|
989
|
+
this.el.classList.remove('datetime-ready');
|
|
990
|
+
});
|
|
603
991
|
};
|
|
604
|
-
|
|
605
|
-
|
|
992
|
+
const hiddenIO = new IntersectionObserver(hiddenCallback, { threshold: 0 });
|
|
993
|
+
helpers.raf(() => hiddenIO === null || hiddenIO === void 0 ? void 0 : hiddenIO.observe(this.el));
|
|
994
|
+
/**
|
|
995
|
+
* Datetime uses Ionic components that emit
|
|
996
|
+
* ionFocus and ionBlur. These events are
|
|
997
|
+
* composed meaning they will cross
|
|
998
|
+
* the shadow dom boundary. We need to
|
|
999
|
+
* stop propagation on these events otherwise
|
|
1000
|
+
* developers will see 2 ionFocus or 2 ionBlur
|
|
1001
|
+
* events at a time.
|
|
1002
|
+
*/
|
|
1003
|
+
const root = helpers.getElementRoot(this.el);
|
|
1004
|
+
root.addEventListener('ionFocus', (ev) => ev.stopPropagation());
|
|
1005
|
+
root.addEventListener('ionBlur', (ev) => ev.stopPropagation());
|
|
1006
|
+
}
|
|
606
1007
|
/**
|
|
607
|
-
*
|
|
608
|
-
*
|
|
609
|
-
* if the datetime has been hidden/presented by a modal or popover.
|
|
1008
|
+
* When the presentation is changed, all calendar content is recreated,
|
|
1009
|
+
* so we need to re-init behavior with the new elements.
|
|
610
1010
|
*/
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
if (destroyCalendarListener !== undefined) {
|
|
614
|
-
destroyCalendarListener();
|
|
615
|
-
}
|
|
616
|
-
if (destroyKeyboardMO !== undefined) {
|
|
617
|
-
destroyKeyboardMO();
|
|
618
|
-
}
|
|
619
|
-
};
|
|
620
|
-
this.processValue = (value) => {
|
|
621
|
-
const hasValue = value !== null && value !== undefined && (!Array.isArray(value) || value.length > 0);
|
|
622
|
-
const valueToProcess = hasValue ? data.parseDate(value) : this.defaultParts;
|
|
623
|
-
const { minParts, maxParts, workingParts, el } = this;
|
|
624
|
-
this.warnIfIncorrectValueUsage();
|
|
625
|
-
/**
|
|
626
|
-
* Return early if the value wasn't parsed correctly, such as
|
|
627
|
-
* if an improperly formatted date string was provided.
|
|
628
|
-
*/
|
|
629
|
-
if (!valueToProcess) {
|
|
630
|
-
return;
|
|
631
|
-
}
|
|
632
|
-
/**
|
|
633
|
-
* Datetime should only warn of out of bounds values
|
|
634
|
-
* if set by the user. If the `value` is undefined,
|
|
635
|
-
* we will default to today's date which may be out
|
|
636
|
-
* of bounds. In this case, the warning makes it look
|
|
637
|
-
* like the developer did something wrong which is
|
|
638
|
-
* not true.
|
|
639
|
-
*/
|
|
640
|
-
if (hasValue) {
|
|
641
|
-
data.warnIfValueOutOfBounds(valueToProcess, minParts, maxParts);
|
|
642
|
-
}
|
|
643
|
-
/**
|
|
644
|
-
* If there are multiple values, pick an arbitrary one to clamp to. This way,
|
|
645
|
-
* if the values are across months, we always show at least one of them. Note
|
|
646
|
-
* that the values don't necessarily have to be in order.
|
|
647
|
-
*/
|
|
648
|
-
const singleValue = Array.isArray(valueToProcess) ? valueToProcess[0] : valueToProcess;
|
|
649
|
-
const targetValue = data.clampDate(singleValue, minParts, maxParts);
|
|
650
|
-
const { month, day, year, hour, minute } = targetValue;
|
|
651
|
-
const ampm = data.parseAmPm(hour);
|
|
652
|
-
/**
|
|
653
|
-
* Since `activeParts` indicates a value that
|
|
654
|
-
* been explicitly selected either by the
|
|
655
|
-
* user or the app, only update `activeParts`
|
|
656
|
-
* if the `value` property is set.
|
|
657
|
-
*/
|
|
658
|
-
if (hasValue) {
|
|
659
|
-
if (Array.isArray(valueToProcess)) {
|
|
660
|
-
this.activeParts = [...valueToProcess];
|
|
661
|
-
}
|
|
662
|
-
else {
|
|
663
|
-
this.activeParts = {
|
|
664
|
-
month,
|
|
665
|
-
day,
|
|
666
|
-
year,
|
|
667
|
-
hour,
|
|
668
|
-
minute,
|
|
669
|
-
ampm,
|
|
670
|
-
};
|
|
671
|
-
}
|
|
672
|
-
}
|
|
673
|
-
else {
|
|
1011
|
+
componentDidRender() {
|
|
1012
|
+
const { presentation, prevPresentation, calendarBodyRef, minParts, preferWheel, forceRenderDate } = this;
|
|
674
1013
|
/**
|
|
675
|
-
*
|
|
676
|
-
*
|
|
677
|
-
*
|
|
1014
|
+
* TODO(FW-2165)
|
|
1015
|
+
* Remove this when https://bugs.webkit.org/show_bug.cgi?id=235960 is fixed.
|
|
1016
|
+
* When using `min`, we add `scroll-snap-align: none`
|
|
1017
|
+
* to the disabled month so that users cannot scroll to it.
|
|
1018
|
+
* This triggers a bug in WebKit where the scroll position is reset.
|
|
1019
|
+
* Since the month change logic is handled by a scroll listener,
|
|
1020
|
+
* this causes the month to change leading to `scroll-snap-align`
|
|
1021
|
+
* changing again, thus changing the scroll position again and causing
|
|
1022
|
+
* an infinite loop.
|
|
1023
|
+
* This issue only applies to the calendar grid, so we can disable
|
|
1024
|
+
* it if the calendar grid is not being used.
|
|
678
1025
|
*/
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
1026
|
+
const hasCalendarGrid = !preferWheel && ['date-time', 'time-date', 'date'].includes(presentation);
|
|
1027
|
+
if (minParts !== undefined && hasCalendarGrid && calendarBodyRef) {
|
|
1028
|
+
const workingMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(1)');
|
|
1029
|
+
/**
|
|
1030
|
+
* We need to make sure the datetime is not in the process
|
|
1031
|
+
* of scrolling to a new datetime value if the value
|
|
1032
|
+
* is updated programmatically.
|
|
1033
|
+
* Otherwise, the datetime will appear to not scroll at all because
|
|
1034
|
+
* we are resetting the scroll position to the center of the view.
|
|
1035
|
+
* Prior to the datetime's value being updated programmatically,
|
|
1036
|
+
* the calendarBodyRef is scrolled such that the middle month is centered
|
|
1037
|
+
* in the view. The below code updates the scroll position so the middle
|
|
1038
|
+
* month is also centered in the view. Since the scroll position did not change,
|
|
1039
|
+
* the scroll callback in this file does not fire,
|
|
1040
|
+
* and the resolveForceDateScrolling promise never resolves.
|
|
1041
|
+
*/
|
|
1042
|
+
if (workingMonth && forceRenderDate === undefined) {
|
|
1043
|
+
calendarBodyRef.scrollLeft = workingMonth.clientWidth * (dir.isRTL(this.el) ? -1 : 1);
|
|
1044
|
+
}
|
|
1045
|
+
}
|
|
1046
|
+
if (prevPresentation === null) {
|
|
1047
|
+
this.prevPresentation = presentation;
|
|
1048
|
+
return;
|
|
1049
|
+
}
|
|
1050
|
+
if (presentation === prevPresentation) {
|
|
1051
|
+
return;
|
|
1052
|
+
}
|
|
1053
|
+
this.prevPresentation = presentation;
|
|
1054
|
+
this.destroyInteractionListeners();
|
|
1055
|
+
this.initializeListeners();
|
|
695
1056
|
/**
|
|
696
|
-
*
|
|
697
|
-
*
|
|
1057
|
+
* The month/year picker from the date interface
|
|
1058
|
+
* should be closed as it is not available in non-date
|
|
1059
|
+
* interfaces.
|
|
698
1060
|
*/
|
|
699
|
-
this.
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
year,
|
|
703
|
-
hour,
|
|
704
|
-
minute,
|
|
705
|
-
ampm,
|
|
1061
|
+
this.showMonthAndYear = false;
|
|
1062
|
+
helpers.raf(() => {
|
|
1063
|
+
this.ionRender.emit();
|
|
706
1064
|
});
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
this.forceRenderDate = targetValue;
|
|
718
|
-
/**
|
|
719
|
-
* Flag that we've started scrolling to the forced date.
|
|
720
|
-
* The resolve function will be called by the datetime's
|
|
721
|
-
* scroll listener when it's done updating everything.
|
|
722
|
-
* This is a replacement for making prev/nextMonth async,
|
|
723
|
-
* since the logic we're waiting on is in a listener.
|
|
724
|
-
*/
|
|
725
|
-
const forceDateScrollingPromise = new Promise((resolve) => {
|
|
726
|
-
this.resolveForceDateScrolling = resolve;
|
|
727
|
-
});
|
|
728
|
-
/**
|
|
729
|
-
* Animate smoothly to the forced month. This will also update
|
|
730
|
-
* workingParts and correct the surrounding months for us.
|
|
731
|
-
*/
|
|
732
|
-
const targetMonthIsBefore = data.isBefore(targetValue, workingParts);
|
|
733
|
-
targetMonthIsBefore ? this.prevMonth() : this.nextMonth();
|
|
734
|
-
await forceDateScrollingPromise;
|
|
735
|
-
this.resolveForceDateScrolling = undefined;
|
|
736
|
-
this.forceRenderDate = undefined;
|
|
737
|
-
};
|
|
738
|
-
this.onFocus = () => {
|
|
739
|
-
this.ionFocus.emit();
|
|
740
|
-
};
|
|
741
|
-
this.onBlur = () => {
|
|
742
|
-
this.ionBlur.emit();
|
|
743
|
-
};
|
|
744
|
-
this.hasValue = () => {
|
|
745
|
-
return this.value != null;
|
|
746
|
-
};
|
|
747
|
-
this.nextMonth = () => {
|
|
748
|
-
const calendarBodyRef = this.calendarBodyRef;
|
|
749
|
-
if (!calendarBodyRef) {
|
|
750
|
-
return;
|
|
751
|
-
}
|
|
752
|
-
const nextMonth = calendarBodyRef.querySelector('.calendar-month:last-of-type');
|
|
753
|
-
if (!nextMonth) {
|
|
754
|
-
return;
|
|
755
|
-
}
|
|
756
|
-
const left = nextMonth.offsetWidth * 2;
|
|
757
|
-
calendarBodyRef.scrollTo({
|
|
758
|
-
top: 0,
|
|
759
|
-
left: left * (dir.isRTL(this.el) ? -1 : 1),
|
|
760
|
-
behavior: 'smooth',
|
|
761
|
-
});
|
|
762
|
-
};
|
|
763
|
-
this.prevMonth = () => {
|
|
764
|
-
const calendarBodyRef = this.calendarBodyRef;
|
|
765
|
-
if (!calendarBodyRef) {
|
|
766
|
-
return;
|
|
767
|
-
}
|
|
768
|
-
const prevMonth = calendarBodyRef.querySelector('.calendar-month:first-of-type');
|
|
769
|
-
if (!prevMonth) {
|
|
770
|
-
return;
|
|
771
|
-
}
|
|
772
|
-
calendarBodyRef.scrollTo({
|
|
773
|
-
top: 0,
|
|
774
|
-
left: 0,
|
|
775
|
-
behavior: 'smooth',
|
|
776
|
-
});
|
|
777
|
-
};
|
|
778
|
-
this.toggleMonthAndYearView = () => {
|
|
779
|
-
this.showMonthAndYear = !this.showMonthAndYear;
|
|
780
|
-
};
|
|
781
|
-
this.showMonthAndYear = false;
|
|
782
|
-
this.activeParts = [];
|
|
783
|
-
this.workingParts = {
|
|
784
|
-
month: 5,
|
|
785
|
-
day: 28,
|
|
786
|
-
year: 2021,
|
|
787
|
-
hour: 13,
|
|
788
|
-
minute: 52,
|
|
789
|
-
ampm: 'pm',
|
|
790
|
-
};
|
|
791
|
-
this.isTimePopoverOpen = false;
|
|
792
|
-
this.forceRenderDate = undefined;
|
|
793
|
-
this.color = 'primary';
|
|
794
|
-
this.name = this.inputId;
|
|
795
|
-
this.disabled = false;
|
|
796
|
-
this.readonly = false;
|
|
797
|
-
this.isDateEnabled = undefined;
|
|
798
|
-
this.min = undefined;
|
|
799
|
-
this.max = undefined;
|
|
800
|
-
this.presentation = 'date-time';
|
|
801
|
-
this.cancelText = 'Cancel';
|
|
802
|
-
this.doneText = 'Done';
|
|
803
|
-
this.clearText = 'Clear';
|
|
804
|
-
this.yearValues = undefined;
|
|
805
|
-
this.monthValues = undefined;
|
|
806
|
-
this.dayValues = undefined;
|
|
807
|
-
this.hourValues = undefined;
|
|
808
|
-
this.minuteValues = undefined;
|
|
809
|
-
this.locale = 'default';
|
|
810
|
-
this.firstDayOfWeek = 0;
|
|
811
|
-
this.titleSelectedDatesFormatter = undefined;
|
|
812
|
-
this.multiple = false;
|
|
813
|
-
this.highlightedDates = undefined;
|
|
814
|
-
this.value = undefined;
|
|
815
|
-
this.showDefaultTitle = false;
|
|
816
|
-
this.showDefaultButtons = false;
|
|
817
|
-
this.showClearButton = false;
|
|
818
|
-
this.showDefaultTimeLabel = true;
|
|
819
|
-
this.hourCycle = undefined;
|
|
820
|
-
this.size = 'fixed';
|
|
821
|
-
this.preferWheel = false;
|
|
822
|
-
}
|
|
823
|
-
disabledChanged() {
|
|
824
|
-
this.emitStyle();
|
|
825
|
-
}
|
|
826
|
-
minChanged() {
|
|
827
|
-
this.processMinParts();
|
|
828
|
-
}
|
|
829
|
-
maxChanged() {
|
|
830
|
-
this.processMaxParts();
|
|
831
|
-
}
|
|
832
|
-
get isGridStyle() {
|
|
833
|
-
const { presentation, preferWheel } = this;
|
|
834
|
-
const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
|
|
835
|
-
return hasDatePresentation && !preferWheel;
|
|
836
|
-
}
|
|
837
|
-
yearValuesChanged() {
|
|
838
|
-
this.parsedYearValues = data.convertToArrayOfNumbers(this.yearValues);
|
|
839
|
-
}
|
|
840
|
-
monthValuesChanged() {
|
|
841
|
-
this.parsedMonthValues = data.convertToArrayOfNumbers(this.monthValues);
|
|
842
|
-
}
|
|
843
|
-
dayValuesChanged() {
|
|
844
|
-
this.parsedDayValues = data.convertToArrayOfNumbers(this.dayValues);
|
|
845
|
-
}
|
|
846
|
-
hourValuesChanged() {
|
|
847
|
-
this.parsedHourValues = data.convertToArrayOfNumbers(this.hourValues);
|
|
848
|
-
}
|
|
849
|
-
minuteValuesChanged() {
|
|
850
|
-
this.parsedMinuteValues = data.convertToArrayOfNumbers(this.minuteValues);
|
|
851
|
-
}
|
|
852
|
-
/**
|
|
853
|
-
* Update the datetime value when the value changes
|
|
854
|
-
*/
|
|
855
|
-
async valueChanged() {
|
|
856
|
-
const { value } = this;
|
|
857
|
-
if (this.hasValue()) {
|
|
858
|
-
this.processValue(value);
|
|
859
|
-
}
|
|
860
|
-
this.emitStyle();
|
|
861
|
-
this.ionValueChange.emit({ value });
|
|
862
|
-
}
|
|
863
|
-
/**
|
|
864
|
-
* Confirms the selected datetime value, updates the
|
|
865
|
-
* `value` property, and optionally closes the popover
|
|
866
|
-
* or modal that the datetime was presented in.
|
|
867
|
-
*/
|
|
868
|
-
async confirm(closeOverlay = false) {
|
|
869
|
-
const { isCalendarPicker, activeParts } = this;
|
|
870
|
-
/**
|
|
871
|
-
* We only update the value if the presentation is not a calendar picker.
|
|
872
|
-
*/
|
|
873
|
-
if (activeParts !== undefined || !isCalendarPicker) {
|
|
874
|
-
const activePartsIsArray = Array.isArray(activeParts);
|
|
875
|
-
if (activePartsIsArray && activeParts.length === 0) {
|
|
876
|
-
this.setValue(undefined);
|
|
877
|
-
}
|
|
878
|
-
else {
|
|
879
|
-
this.setValue(data.convertDataToISO(activeParts));
|
|
880
|
-
}
|
|
881
|
-
}
|
|
882
|
-
if (closeOverlay) {
|
|
883
|
-
this.closeParentOverlay();
|
|
884
|
-
}
|
|
885
|
-
}
|
|
886
|
-
/**
|
|
887
|
-
* Resets the internal state of the datetime but does not update the value.
|
|
888
|
-
* Passing a valid ISO-8601 string will reset the state of the component to the provided date.
|
|
889
|
-
* If no value is provided, the internal state will be reset to the clamped value of the min, max and today.
|
|
890
|
-
*/
|
|
891
|
-
async reset(startDate) {
|
|
892
|
-
this.processValue(startDate);
|
|
893
|
-
}
|
|
894
|
-
/**
|
|
895
|
-
* Emits the ionCancel event and
|
|
896
|
-
* optionally closes the popover
|
|
897
|
-
* or modal that the datetime was
|
|
898
|
-
* presented in.
|
|
899
|
-
*/
|
|
900
|
-
async cancel(closeOverlay = false) {
|
|
901
|
-
this.ionCancel.emit();
|
|
902
|
-
if (closeOverlay) {
|
|
903
|
-
this.closeParentOverlay();
|
|
904
|
-
}
|
|
905
|
-
}
|
|
906
|
-
get isCalendarPicker() {
|
|
907
|
-
const { presentation } = this;
|
|
908
|
-
return presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
|
|
909
|
-
}
|
|
910
|
-
connectedCallback() {
|
|
911
|
-
this.clearFocusVisible = focusVisible.startFocusVisible(this.el).destroy;
|
|
912
|
-
}
|
|
913
|
-
disconnectedCallback() {
|
|
914
|
-
if (this.clearFocusVisible) {
|
|
915
|
-
this.clearFocusVisible();
|
|
916
|
-
this.clearFocusVisible = undefined;
|
|
917
|
-
}
|
|
918
|
-
}
|
|
919
|
-
initializeListeners() {
|
|
920
|
-
this.initializeCalendarListener();
|
|
921
|
-
this.initializeKeyboardListeners();
|
|
922
|
-
}
|
|
923
|
-
componentDidLoad() {
|
|
924
|
-
/**
|
|
925
|
-
* If a scrollable element is hidden using `display: none`,
|
|
926
|
-
* it will not have a scroll height meaning we cannot scroll elements
|
|
927
|
-
* into view. As a result, we will need to wait for the datetime to become
|
|
928
|
-
* visible if used inside of a modal or a popover otherwise the scrollable
|
|
929
|
-
* areas will not have the correct values snapped into place.
|
|
930
|
-
*/
|
|
931
|
-
const visibleCallback = (entries) => {
|
|
932
|
-
const ev = entries[0];
|
|
933
|
-
if (!ev.isIntersecting) {
|
|
934
|
-
return;
|
|
935
|
-
}
|
|
936
|
-
this.initializeListeners();
|
|
937
|
-
/**
|
|
938
|
-
* TODO FW-2793: Datetime needs a frame to ensure that it
|
|
939
|
-
* can properly scroll contents into view. As a result
|
|
940
|
-
* we hide the scrollable content until after that frame
|
|
941
|
-
* so users do not see the content quickly shifting. The downside
|
|
942
|
-
* is that the content will pop into view a frame after. Maybe there
|
|
943
|
-
* is a better way to handle this?
|
|
944
|
-
*/
|
|
945
|
-
index$1.writeTask(() => {
|
|
946
|
-
this.el.classList.add('datetime-ready');
|
|
947
|
-
});
|
|
948
|
-
};
|
|
949
|
-
const visibleIO = new IntersectionObserver(visibleCallback, { threshold: 0.01 });
|
|
950
|
-
/**
|
|
951
|
-
* Use raf to avoid a race condition between the component loading and
|
|
952
|
-
* its display animation starting (such as when shown in a modal). This
|
|
953
|
-
* could cause the datetime to start at a visibility of 0, erroneously
|
|
954
|
-
* triggering the `hiddenIO` observer below.
|
|
955
|
-
*/
|
|
956
|
-
helpers.raf(() => visibleIO === null || visibleIO === void 0 ? void 0 : visibleIO.observe(this.el));
|
|
957
|
-
/**
|
|
958
|
-
* We need to clean up listeners when the datetime is hidden
|
|
959
|
-
* in a popover/modal so that we can properly scroll containers
|
|
960
|
-
* back into view if they are re-presented. When the datetime is hidden
|
|
961
|
-
* the scroll areas have scroll widths/heights of 0px, so any snapping
|
|
962
|
-
* we did originally has been lost.
|
|
963
|
-
*/
|
|
964
|
-
const hiddenCallback = (entries) => {
|
|
965
|
-
const ev = entries[0];
|
|
966
|
-
if (ev.isIntersecting) {
|
|
967
|
-
return;
|
|
968
|
-
}
|
|
969
|
-
this.destroyInteractionListeners();
|
|
970
|
-
/**
|
|
971
|
-
* When datetime is hidden, we need to make sure that
|
|
972
|
-
* the month/year picker is closed. Otherwise,
|
|
973
|
-
* it will be open when the datetime re-appears
|
|
974
|
-
* and the scroll area of the calendar grid will be 0.
|
|
975
|
-
* As a result, the wrong month will be shown.
|
|
976
|
-
*/
|
|
977
|
-
this.showMonthAndYear = false;
|
|
978
|
-
index$1.writeTask(() => {
|
|
979
|
-
this.el.classList.remove('datetime-ready');
|
|
980
|
-
});
|
|
981
|
-
};
|
|
982
|
-
const hiddenIO = new IntersectionObserver(hiddenCallback, { threshold: 0 });
|
|
983
|
-
helpers.raf(() => hiddenIO === null || hiddenIO === void 0 ? void 0 : hiddenIO.observe(this.el));
|
|
984
|
-
/**
|
|
985
|
-
* Datetime uses Ionic components that emit
|
|
986
|
-
* ionFocus and ionBlur. These events are
|
|
987
|
-
* composed meaning they will cross
|
|
988
|
-
* the shadow dom boundary. We need to
|
|
989
|
-
* stop propagation on these events otherwise
|
|
990
|
-
* developers will see 2 ionFocus or 2 ionBlur
|
|
991
|
-
* events at a time.
|
|
992
|
-
*/
|
|
993
|
-
const root = helpers.getElementRoot(this.el);
|
|
994
|
-
root.addEventListener('ionFocus', (ev) => ev.stopPropagation());
|
|
995
|
-
root.addEventListener('ionBlur', (ev) => ev.stopPropagation());
|
|
996
|
-
}
|
|
997
|
-
/**
|
|
998
|
-
* When the presentation is changed, all calendar content is recreated,
|
|
999
|
-
* so we need to re-init behavior with the new elements.
|
|
1000
|
-
*/
|
|
1001
|
-
componentDidRender() {
|
|
1002
|
-
const { presentation, prevPresentation, calendarBodyRef, minParts, preferWheel } = this;
|
|
1003
|
-
/**
|
|
1004
|
-
* TODO(FW-2165)
|
|
1005
|
-
* Remove this when https://bugs.webkit.org/show_bug.cgi?id=235960 is fixed.
|
|
1006
|
-
* When using `min`, we add `scroll-snap-align: none`
|
|
1007
|
-
* to the disabled month so that users cannot scroll to it.
|
|
1008
|
-
* This triggers a bug in WebKit where the scroll position is reset.
|
|
1009
|
-
* Since the month change logic is handled by a scroll listener,
|
|
1010
|
-
* this causes the month to change leading to `scroll-snap-align`
|
|
1011
|
-
* changing again, thus changing the scroll position again and causing
|
|
1012
|
-
* an infinite loop.
|
|
1013
|
-
* This issue only applies to the calendar grid, so we can disable
|
|
1014
|
-
* it if the calendar grid is not being used.
|
|
1015
|
-
*/
|
|
1016
|
-
const hasCalendarGrid = !preferWheel && ['date-time', 'time-date', 'date'].includes(presentation);
|
|
1017
|
-
if (minParts !== undefined && hasCalendarGrid && calendarBodyRef) {
|
|
1018
|
-
const workingMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(1)');
|
|
1019
|
-
if (workingMonth) {
|
|
1020
|
-
calendarBodyRef.scrollLeft = workingMonth.clientWidth * (dir.isRTL(this.el) ? -1 : 1);
|
|
1021
|
-
}
|
|
1022
|
-
}
|
|
1023
|
-
if (prevPresentation === null) {
|
|
1024
|
-
this.prevPresentation = presentation;
|
|
1025
|
-
return;
|
|
1026
|
-
}
|
|
1027
|
-
if (presentation === prevPresentation) {
|
|
1028
|
-
return;
|
|
1029
|
-
}
|
|
1030
|
-
this.prevPresentation = presentation;
|
|
1031
|
-
this.destroyInteractionListeners();
|
|
1032
|
-
this.initializeListeners();
|
|
1033
|
-
/**
|
|
1034
|
-
* The month/year picker from the date interface
|
|
1035
|
-
* should be closed as it is not available in non-date
|
|
1036
|
-
* interfaces.
|
|
1037
|
-
*/
|
|
1038
|
-
this.showMonthAndYear = false;
|
|
1039
|
-
helpers.raf(() => {
|
|
1040
|
-
this.ionRender.emit();
|
|
1041
|
-
});
|
|
1042
|
-
}
|
|
1043
|
-
componentWillLoad() {
|
|
1044
|
-
const { el, highlightedDates, multiple, presentation, preferWheel } = this;
|
|
1045
|
-
if (multiple) {
|
|
1046
|
-
if (presentation !== 'date') {
|
|
1047
|
-
index.printIonWarning('Multiple date selection is only supported for presentation="date".', el);
|
|
1048
|
-
}
|
|
1049
|
-
if (preferWheel) {
|
|
1050
|
-
index.printIonWarning('Multiple date selection is not supported with preferWheel="true".', el);
|
|
1051
|
-
}
|
|
1052
|
-
}
|
|
1053
|
-
if (highlightedDates !== undefined) {
|
|
1054
|
-
if (presentation !== 'date' && presentation !== 'date-time' && presentation !== 'time-date') {
|
|
1055
|
-
index.printIonWarning('The highlightedDates property is only supported with the date, date-time, and time-date presentations.', el);
|
|
1056
|
-
}
|
|
1057
|
-
if (preferWheel) {
|
|
1058
|
-
index.printIonWarning('The highlightedDates property is not supported with preferWheel="true".', el);
|
|
1059
|
-
}
|
|
1060
|
-
}
|
|
1061
|
-
const hourValues = (this.parsedHourValues = data.convertToArrayOfNumbers(this.hourValues));
|
|
1062
|
-
const minuteValues = (this.parsedMinuteValues = data.convertToArrayOfNumbers(this.minuteValues));
|
|
1063
|
-
const monthValues = (this.parsedMonthValues = data.convertToArrayOfNumbers(this.monthValues));
|
|
1064
|
-
const yearValues = (this.parsedYearValues = data.convertToArrayOfNumbers(this.yearValues));
|
|
1065
|
-
const dayValues = (this.parsedDayValues = data.convertToArrayOfNumbers(this.dayValues));
|
|
1066
|
-
const todayParts = (this.todayParts = data.parseDate(data.getToday()));
|
|
1067
|
-
this.defaultParts = data.getClosestValidDate(todayParts, monthValues, dayValues, yearValues, hourValues, minuteValues);
|
|
1068
|
-
this.processMinParts();
|
|
1069
|
-
this.processMaxParts();
|
|
1070
|
-
this.processValue(this.value);
|
|
1071
|
-
this.emitStyle();
|
|
1072
|
-
}
|
|
1073
|
-
emitStyle() {
|
|
1074
|
-
this.ionStyle.emit({
|
|
1075
|
-
interactive: true,
|
|
1076
|
-
datetime: true,
|
|
1077
|
-
'interactive-disabled': this.disabled,
|
|
1078
|
-
});
|
|
1079
|
-
}
|
|
1080
|
-
/**
|
|
1081
|
-
* Universal render methods
|
|
1082
|
-
* These are pieces of datetime that
|
|
1083
|
-
* are rendered independently of presentation.
|
|
1084
|
-
*/
|
|
1085
|
-
renderFooter() {
|
|
1086
|
-
const { disabled, readonly, showDefaultButtons, showClearButton } = this;
|
|
1087
|
-
/**
|
|
1088
|
-
* The cancel, clear, and confirm buttons
|
|
1089
|
-
* should not be interactive if the datetime
|
|
1090
|
-
* is disabled or readonly.
|
|
1091
|
-
*/
|
|
1092
|
-
const isButtonDisabled = disabled || readonly;
|
|
1093
|
-
const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
|
|
1094
|
-
if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
|
|
1095
|
-
return;
|
|
1096
|
-
}
|
|
1097
|
-
const clearButtonClick = () => {
|
|
1098
|
-
this.reset();
|
|
1099
|
-
this.setValue(undefined);
|
|
1100
|
-
};
|
|
1101
|
-
/**
|
|
1102
|
-
* By default we render two buttons:
|
|
1103
|
-
* Cancel - Dismisses the datetime and
|
|
1104
|
-
* does not update the `value` prop.
|
|
1105
|
-
* OK - Dismisses the datetime and
|
|
1106
|
-
* updates the `value` prop.
|
|
1107
|
-
*/
|
|
1108
|
-
return (index$1.h("div", { class: "datetime-footer" }, index$1.h("div", { class: "datetime-buttons" }, index$1.h("div", { class: {
|
|
1109
|
-
['datetime-action-buttons']: true,
|
|
1110
|
-
['has-clear-button']: this.showClearButton,
|
|
1111
|
-
} }, index$1.h("slot", { name: "buttons" }, index$1.h("ion-buttons", null, showDefaultButtons && (index$1.h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true), disabled: isButtonDisabled }, this.cancelText)), index$1.h("div", { class: "datetime-action-buttons-container" }, showClearButton && (index$1.h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick(), disabled: isButtonDisabled }, this.clearText)), showDefaultButtons && (index$1.h("ion-button", { id: "confirm-button", color: this.color, onClick: () => this.confirm(true), disabled: isButtonDisabled }, this.doneText)))))))));
|
|
1112
|
-
}
|
|
1113
|
-
/**
|
|
1114
|
-
* Wheel picker render methods
|
|
1115
|
-
*/
|
|
1116
|
-
renderWheelPicker(forcePresentation = this.presentation) {
|
|
1117
|
-
/**
|
|
1118
|
-
* If presentation="time-date" we switch the
|
|
1119
|
-
* order of the render array here instead of
|
|
1120
|
-
* manually reordering each date/time picker
|
|
1121
|
-
* column with CSS. This allows for additional
|
|
1122
|
-
* flexibility if we need to render subsets
|
|
1123
|
-
* of the date/time data or do additional ordering
|
|
1124
|
-
* within the child render functions.
|
|
1125
|
-
*/
|
|
1126
|
-
const renderArray = forcePresentation === 'time-date'
|
|
1127
|
-
? [this.renderTimePickerColumns(forcePresentation), this.renderDatePickerColumns(forcePresentation)]
|
|
1128
|
-
: [this.renderDatePickerColumns(forcePresentation), this.renderTimePickerColumns(forcePresentation)];
|
|
1129
|
-
return index$1.h("ion-picker-internal", null, renderArray);
|
|
1130
|
-
}
|
|
1131
|
-
renderDatePickerColumns(forcePresentation) {
|
|
1132
|
-
return forcePresentation === 'date-time' || forcePresentation === 'time-date'
|
|
1133
|
-
? this.renderCombinedDatePickerColumn()
|
|
1134
|
-
: this.renderIndividualDatePickerColumns(forcePresentation);
|
|
1135
|
-
}
|
|
1136
|
-
renderCombinedDatePickerColumn() {
|
|
1137
|
-
const { defaultParts, workingParts, locale, minParts, maxParts, todayParts, isDateEnabled } = this;
|
|
1138
|
-
const activePart = this.getActivePartsWithFallback();
|
|
1139
|
-
/**
|
|
1140
|
-
* By default, generate a range of 3 months:
|
|
1141
|
-
* Previous month, current month, and next month
|
|
1142
|
-
*/
|
|
1143
|
-
const monthsToRender = data.generateMonths(workingParts);
|
|
1144
|
-
const lastMonth = monthsToRender[monthsToRender.length - 1];
|
|
1145
|
-
/**
|
|
1146
|
-
* Ensure that users can select the entire window of dates.
|
|
1147
|
-
*/
|
|
1148
|
-
monthsToRender[0].day = 1;
|
|
1149
|
-
lastMonth.day = data.getNumDaysInMonth(lastMonth.month, lastMonth.year);
|
|
1150
|
-
/**
|
|
1151
|
-
* Narrow the dates rendered based on min/max dates (if any).
|
|
1152
|
-
* The `min` date is used if the min is after the generated min month.
|
|
1153
|
-
* The `max` date is used if the max is before the generated max month.
|
|
1154
|
-
* This ensures that the sliding window always stays at 3 months
|
|
1155
|
-
* but still allows future dates to be lazily rendered based on any min/max
|
|
1156
|
-
* constraints.
|
|
1157
|
-
*/
|
|
1158
|
-
const min = minParts !== undefined && data.isAfter(minParts, monthsToRender[0]) ? minParts : monthsToRender[0];
|
|
1159
|
-
const max = maxParts !== undefined && data.isBefore(maxParts, lastMonth) ? maxParts : lastMonth;
|
|
1160
|
-
const result = data.getCombinedDateColumnData(locale, todayParts, min, max, this.parsedDayValues, this.parsedMonthValues);
|
|
1161
|
-
let items = result.items;
|
|
1162
|
-
const parts = result.parts;
|
|
1163
|
-
if (isDateEnabled) {
|
|
1164
|
-
items = items.map((itemObject, index$1) => {
|
|
1165
|
-
const referenceParts = parts[index$1];
|
|
1166
|
-
let disabled;
|
|
1167
|
-
try {
|
|
1168
|
-
/**
|
|
1169
|
-
* The `isDateEnabled` implementation is try-catch wrapped
|
|
1170
|
-
* to prevent exceptions in the user's function from
|
|
1171
|
-
* interrupting the calendar rendering.
|
|
1172
|
-
*/
|
|
1173
|
-
disabled = !isDateEnabled(data.convertDataToISO(referenceParts));
|
|
1065
|
+
}
|
|
1066
|
+
componentWillLoad() {
|
|
1067
|
+
const { el, highlightedDates, multiple, presentation, preferWheel } = this;
|
|
1068
|
+
if (multiple) {
|
|
1069
|
+
if (presentation !== 'date') {
|
|
1070
|
+
index.printIonWarning('Multiple date selection is only supported for presentation="date".', el);
|
|
1071
|
+
}
|
|
1072
|
+
if (preferWheel) {
|
|
1073
|
+
index.printIonWarning('Multiple date selection is not supported with preferWheel="true".', el);
|
|
1074
|
+
}
|
|
1174
1075
|
}
|
|
1175
|
-
|
|
1176
|
-
|
|
1076
|
+
if (highlightedDates !== undefined) {
|
|
1077
|
+
if (presentation !== 'date' && presentation !== 'date-time' && presentation !== 'time-date') {
|
|
1078
|
+
index.printIonWarning('The highlightedDates property is only supported with the date, date-time, and time-date presentations.', el);
|
|
1079
|
+
}
|
|
1080
|
+
if (preferWheel) {
|
|
1081
|
+
index.printIonWarning('The highlightedDates property is not supported with preferWheel="true".', el);
|
|
1082
|
+
}
|
|
1177
1083
|
}
|
|
1178
|
-
|
|
1179
|
-
|
|
1084
|
+
const hourValues = (this.parsedHourValues = data.convertToArrayOfNumbers(this.hourValues));
|
|
1085
|
+
const minuteValues = (this.parsedMinuteValues = data.convertToArrayOfNumbers(this.minuteValues));
|
|
1086
|
+
const monthValues = (this.parsedMonthValues = data.convertToArrayOfNumbers(this.monthValues));
|
|
1087
|
+
const yearValues = (this.parsedYearValues = data.convertToArrayOfNumbers(this.yearValues));
|
|
1088
|
+
const dayValues = (this.parsedDayValues = data.convertToArrayOfNumbers(this.dayValues));
|
|
1089
|
+
const todayParts = (this.todayParts = data.parseDate(data.getToday()));
|
|
1090
|
+
this.processMinParts();
|
|
1091
|
+
this.processMaxParts();
|
|
1092
|
+
this.defaultParts = data.getClosestValidDate({
|
|
1093
|
+
refParts: todayParts,
|
|
1094
|
+
monthValues,
|
|
1095
|
+
dayValues,
|
|
1096
|
+
yearValues,
|
|
1097
|
+
hourValues,
|
|
1098
|
+
minuteValues,
|
|
1099
|
+
minParts: this.minParts,
|
|
1100
|
+
maxParts: this.maxParts,
|
|
1101
|
+
});
|
|
1102
|
+
this.processValue(this.value);
|
|
1103
|
+
this.emitStyle();
|
|
1104
|
+
}
|
|
1105
|
+
emitStyle() {
|
|
1106
|
+
this.ionStyle.emit({
|
|
1107
|
+
interactive: true,
|
|
1108
|
+
datetime: true,
|
|
1109
|
+
'interactive-disabled': this.disabled,
|
|
1110
|
+
});
|
|
1180
1111
|
}
|
|
1181
1112
|
/**
|
|
1182
|
-
*
|
|
1183
|
-
*
|
|
1113
|
+
* Universal render methods
|
|
1114
|
+
* These are pieces of datetime that
|
|
1115
|
+
* are rendered independently of presentation.
|
|
1184
1116
|
*/
|
|
1185
|
-
|
|
1186
|
-
|
|
1187
|
-
|
|
1188
|
-
|
|
1189
|
-
|
|
1190
|
-
|
|
1191
|
-
|
|
1192
|
-
|
|
1193
|
-
|
|
1194
|
-
|
|
1117
|
+
renderFooter() {
|
|
1118
|
+
const { disabled, readonly, showDefaultButtons, showClearButton } = this;
|
|
1119
|
+
/**
|
|
1120
|
+
* The cancel, clear, and confirm buttons
|
|
1121
|
+
* should not be interactive if the datetime
|
|
1122
|
+
* is disabled or readonly.
|
|
1123
|
+
*/
|
|
1124
|
+
const isButtonDisabled = disabled || readonly;
|
|
1125
|
+
const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
|
|
1126
|
+
if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
|
|
1127
|
+
return;
|
|
1195
1128
|
}
|
|
1196
|
-
const
|
|
1197
|
-
|
|
1198
|
-
|
|
1199
|
-
this.setActiveParts(Object.assign(Object.assign({}, activePart), findPart));
|
|
1200
|
-
// We can re-attach the scroll listener after
|
|
1201
|
-
// the working parts have been updated.
|
|
1202
|
-
this.initializeCalendarListener();
|
|
1203
|
-
ev.stopPropagation();
|
|
1204
|
-
} }));
|
|
1205
|
-
}
|
|
1206
|
-
renderIndividualDatePickerColumns(forcePresentation) {
|
|
1207
|
-
const { workingParts, isDateEnabled } = this;
|
|
1208
|
-
const shouldRenderMonths = forcePresentation !== 'year' && forcePresentation !== 'time';
|
|
1209
|
-
const months = shouldRenderMonths
|
|
1210
|
-
? data.getMonthColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedMonthValues)
|
|
1211
|
-
: [];
|
|
1212
|
-
const shouldRenderDays = forcePresentation === 'date';
|
|
1213
|
-
let days = shouldRenderDays
|
|
1214
|
-
? data.getDayColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedDayValues)
|
|
1215
|
-
: [];
|
|
1216
|
-
if (isDateEnabled) {
|
|
1217
|
-
days = days.map((dayObject) => {
|
|
1218
|
-
const { value } = dayObject;
|
|
1219
|
-
const valueNum = typeof value === 'string' ? parseInt(value) : value;
|
|
1220
|
-
const referenceParts = {
|
|
1221
|
-
month: workingParts.month,
|
|
1222
|
-
day: valueNum,
|
|
1223
|
-
year: workingParts.year,
|
|
1129
|
+
const clearButtonClick = () => {
|
|
1130
|
+
this.reset();
|
|
1131
|
+
this.setValue(undefined);
|
|
1224
1132
|
};
|
|
1225
|
-
|
|
1226
|
-
|
|
1227
|
-
|
|
1228
|
-
|
|
1229
|
-
|
|
1230
|
-
|
|
1231
|
-
|
|
1232
|
-
|
|
1233
|
-
|
|
1234
|
-
|
|
1235
|
-
|
|
1236
|
-
}
|
|
1237
|
-
return Object.assign(Object.assign({}, dayObject), { disabled });
|
|
1238
|
-
});
|
|
1133
|
+
/**
|
|
1134
|
+
* By default we render two buttons:
|
|
1135
|
+
* Cancel - Dismisses the datetime and
|
|
1136
|
+
* does not update the `value` prop.
|
|
1137
|
+
* OK - Dismisses the datetime and
|
|
1138
|
+
* updates the `value` prop.
|
|
1139
|
+
*/
|
|
1140
|
+
return (index$1.h("div", { class: "datetime-footer" }, index$1.h("div", { class: "datetime-buttons" }, index$1.h("div", { class: {
|
|
1141
|
+
['datetime-action-buttons']: true,
|
|
1142
|
+
['has-clear-button']: this.showClearButton,
|
|
1143
|
+
} }, index$1.h("slot", { name: "buttons" }, index$1.h("ion-buttons", null, showDefaultButtons && (index$1.h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true), disabled: isButtonDisabled }, this.cancelText)), index$1.h("div", { class: "datetime-action-buttons-container" }, showClearButton && (index$1.h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick(), disabled: isButtonDisabled }, this.clearText)), showDefaultButtons && (index$1.h("ion-button", { id: "confirm-button", color: this.color, onClick: () => this.confirm(true), disabled: isButtonDisabled }, this.doneText)))))))));
|
|
1239
1144
|
}
|
|
1240
|
-
const shouldRenderYears = forcePresentation !== 'month' && forcePresentation !== 'time';
|
|
1241
|
-
const years = shouldRenderYears
|
|
1242
|
-
? data.getYearColumnData(this.locale, this.defaultParts, this.minParts, this.maxParts, this.parsedYearValues)
|
|
1243
|
-
: [];
|
|
1244
1145
|
/**
|
|
1245
|
-
*
|
|
1146
|
+
* Wheel picker render methods
|
|
1246
1147
|
*/
|
|
1247
|
-
|
|
1248
|
-
|
|
1249
|
-
|
|
1250
|
-
|
|
1251
|
-
|
|
1252
|
-
|
|
1253
|
-
|
|
1254
|
-
|
|
1148
|
+
renderWheelPicker(forcePresentation = this.presentation) {
|
|
1149
|
+
/**
|
|
1150
|
+
* If presentation="time-date" we switch the
|
|
1151
|
+
* order of the render array here instead of
|
|
1152
|
+
* manually reordering each date/time picker
|
|
1153
|
+
* column with CSS. This allows for additional
|
|
1154
|
+
* flexibility if we need to render subsets
|
|
1155
|
+
* of the date/time data or do additional ordering
|
|
1156
|
+
* within the child render functions.
|
|
1157
|
+
*/
|
|
1158
|
+
const renderArray = forcePresentation === 'time-date'
|
|
1159
|
+
? [this.renderTimePickerColumns(forcePresentation), this.renderDatePickerColumns(forcePresentation)]
|
|
1160
|
+
: [this.renderDatePickerColumns(forcePresentation), this.renderTimePickerColumns(forcePresentation)];
|
|
1161
|
+
return index$1.h("ion-picker-internal", null, renderArray);
|
|
1255
1162
|
}
|
|
1256
|
-
|
|
1257
|
-
|
|
1258
|
-
|
|
1259
|
-
|
|
1260
|
-
|
|
1261
|
-
|
|
1262
|
-
|
|
1263
|
-
|
|
1264
|
-
|
|
1265
|
-
|
|
1266
|
-
|
|
1267
|
-
|
|
1268
|
-
|
|
1269
|
-
|
|
1270
|
-
|
|
1271
|
-
|
|
1272
|
-
|
|
1273
|
-
|
|
1274
|
-
|
|
1275
|
-
|
|
1276
|
-
|
|
1277
|
-
|
|
1278
|
-
|
|
1279
|
-
|
|
1280
|
-
|
|
1281
|
-
|
|
1282
|
-
|
|
1283
|
-
|
|
1284
|
-
|
|
1285
|
-
|
|
1286
|
-
|
|
1287
|
-
|
|
1288
|
-
|
|
1289
|
-
|
|
1290
|
-
|
|
1291
|
-
|
|
1292
|
-
|
|
1293
|
-
|
|
1294
|
-
|
|
1295
|
-
|
|
1296
|
-
|
|
1297
|
-
|
|
1298
|
-
|
|
1299
|
-
|
|
1300
|
-
|
|
1301
|
-
|
|
1302
|
-
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
// the working parts have been updated.
|
|
1306
|
-
this.initializeCalendarListener();
|
|
1307
|
-
ev.stopPropagation();
|
|
1308
|
-
} }));
|
|
1309
|
-
}
|
|
1310
|
-
renderYearPickerColumn(years) {
|
|
1311
|
-
if (years.length === 0) {
|
|
1312
|
-
return [];
|
|
1313
|
-
}
|
|
1314
|
-
const { workingParts } = this;
|
|
1315
|
-
const activePart = this.getActivePartsWithFallback();
|
|
1316
|
-
return (index$1.h("ion-picker-column-internal", { class: "year-column", color: this.color, items: years, value: workingParts.year, onIonChange: (ev) => {
|
|
1317
|
-
// TODO(FW-1823) Remove this when iOS 14 support is dropped.
|
|
1318
|
-
// Due to a Safari 14 issue we need to destroy
|
|
1319
|
-
// the scroll listener before we update state
|
|
1320
|
-
// and trigger a re-render.
|
|
1321
|
-
if (this.destroyCalendarListener) {
|
|
1322
|
-
this.destroyCalendarListener();
|
|
1163
|
+
renderDatePickerColumns(forcePresentation) {
|
|
1164
|
+
return forcePresentation === 'date-time' || forcePresentation === 'time-date'
|
|
1165
|
+
? this.renderCombinedDatePickerColumn()
|
|
1166
|
+
: this.renderIndividualDatePickerColumns(forcePresentation);
|
|
1167
|
+
}
|
|
1168
|
+
renderCombinedDatePickerColumn() {
|
|
1169
|
+
const { defaultParts, disabled, workingParts, locale, minParts, maxParts, todayParts, isDateEnabled } = this;
|
|
1170
|
+
const activePart = this.getActivePartsWithFallback();
|
|
1171
|
+
/**
|
|
1172
|
+
* By default, generate a range of 3 months:
|
|
1173
|
+
* Previous month, current month, and next month
|
|
1174
|
+
*/
|
|
1175
|
+
const monthsToRender = data.generateMonths(workingParts);
|
|
1176
|
+
const lastMonth = monthsToRender[monthsToRender.length - 1];
|
|
1177
|
+
/**
|
|
1178
|
+
* Ensure that users can select the entire window of dates.
|
|
1179
|
+
*/
|
|
1180
|
+
monthsToRender[0].day = 1;
|
|
1181
|
+
lastMonth.day = data.getNumDaysInMonth(lastMonth.month, lastMonth.year);
|
|
1182
|
+
/**
|
|
1183
|
+
* Narrow the dates rendered based on min/max dates (if any).
|
|
1184
|
+
* The `min` date is used if the min is after the generated min month.
|
|
1185
|
+
* The `max` date is used if the max is before the generated max month.
|
|
1186
|
+
* This ensures that the sliding window always stays at 3 months
|
|
1187
|
+
* but still allows future dates to be lazily rendered based on any min/max
|
|
1188
|
+
* constraints.
|
|
1189
|
+
*/
|
|
1190
|
+
const min = minParts !== undefined && data.isAfter(minParts, monthsToRender[0]) ? minParts : monthsToRender[0];
|
|
1191
|
+
const max = maxParts !== undefined && data.isBefore(maxParts, lastMonth) ? maxParts : lastMonth;
|
|
1192
|
+
const result = data.getCombinedDateColumnData(locale, todayParts, min, max, this.parsedDayValues, this.parsedMonthValues);
|
|
1193
|
+
let items = result.items;
|
|
1194
|
+
const parts = result.parts;
|
|
1195
|
+
if (isDateEnabled) {
|
|
1196
|
+
items = items.map((itemObject, index$1) => {
|
|
1197
|
+
const referenceParts = parts[index$1];
|
|
1198
|
+
let disabled;
|
|
1199
|
+
try {
|
|
1200
|
+
/**
|
|
1201
|
+
* The `isDateEnabled` implementation is try-catch wrapped
|
|
1202
|
+
* to prevent exceptions in the user's function from
|
|
1203
|
+
* interrupting the calendar rendering.
|
|
1204
|
+
*/
|
|
1205
|
+
disabled = !isDateEnabled(data.convertDataToISO(referenceParts));
|
|
1206
|
+
}
|
|
1207
|
+
catch (e) {
|
|
1208
|
+
index.printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
|
|
1209
|
+
}
|
|
1210
|
+
return Object.assign(Object.assign({}, itemObject), { disabled });
|
|
1211
|
+
});
|
|
1323
1212
|
}
|
|
1324
|
-
|
|
1325
|
-
|
|
1326
|
-
|
|
1327
|
-
|
|
1328
|
-
|
|
1329
|
-
|
|
1330
|
-
|
|
1331
|
-
|
|
1332
|
-
|
|
1333
|
-
|
|
1334
|
-
|
|
1213
|
+
/**
|
|
1214
|
+
* If we have selected a day already, then default the column
|
|
1215
|
+
* to that value. Otherwise, set it to the default date.
|
|
1216
|
+
*/
|
|
1217
|
+
const todayString = workingParts.day !== null
|
|
1218
|
+
? `${workingParts.year}-${workingParts.month}-${workingParts.day}`
|
|
1219
|
+
: `${defaultParts.year}-${defaultParts.month}-${defaultParts.day}`;
|
|
1220
|
+
return (index$1.h("ion-picker-column-internal", { class: "date-column", color: this.color, disabled: disabled, items: items, value: todayString, onIonChange: (ev) => {
|
|
1221
|
+
// TODO(FW-1823) Remove this when iOS 14 support is dropped.
|
|
1222
|
+
// Due to a Safari 14 issue we need to destroy
|
|
1223
|
+
// the scroll listener before we update state
|
|
1224
|
+
// and trigger a re-render.
|
|
1225
|
+
if (this.destroyCalendarListener) {
|
|
1226
|
+
this.destroyCalendarListener();
|
|
1227
|
+
}
|
|
1228
|
+
const { value } = ev.detail;
|
|
1229
|
+
const findPart = parts.find(({ month, day, year }) => value === `${year}-${month}-${day}`);
|
|
1230
|
+
this.setWorkingParts(Object.assign(Object.assign({}, workingParts), findPart));
|
|
1231
|
+
this.setActiveParts(Object.assign(Object.assign({}, activePart), findPart));
|
|
1232
|
+
// We can re-attach the scroll listener after
|
|
1233
|
+
// the working parts have been updated.
|
|
1234
|
+
this.initializeCalendarListener();
|
|
1235
|
+
ev.stopPropagation();
|
|
1236
|
+
} }));
|
|
1335
1237
|
}
|
|
1336
|
-
|
|
1337
|
-
|
|
1338
|
-
|
|
1339
|
-
|
|
1340
|
-
|
|
1341
|
-
|
|
1342
|
-
|
|
1343
|
-
|
|
1344
|
-
|
|
1345
|
-
|
|
1346
|
-
|
|
1347
|
-
|
|
1348
|
-
|
|
1349
|
-
|
|
1350
|
-
|
|
1351
|
-
|
|
1352
|
-
|
|
1353
|
-
|
|
1354
|
-
|
|
1355
|
-
|
|
1356
|
-
|
|
1357
|
-
|
|
1358
|
-
|
|
1359
|
-
|
|
1360
|
-
|
|
1361
|
-
|
|
1362
|
-
|
|
1363
|
-
|
|
1364
|
-
|
|
1365
|
-
|
|
1366
|
-
|
|
1367
|
-
|
|
1368
|
-
|
|
1369
|
-
|
|
1370
|
-
|
|
1371
|
-
|
|
1372
|
-
|
|
1373
|
-
|
|
1374
|
-
} }));
|
|
1375
|
-
}
|
|
1376
|
-
renderDayPeriodPickerColumn(dayPeriodData) {
|
|
1377
|
-
const { workingParts } = this;
|
|
1378
|
-
if (dayPeriodData.length === 0) {
|
|
1379
|
-
return [];
|
|
1380
|
-
}
|
|
1381
|
-
const activePart = this.getActivePartsWithFallback();
|
|
1382
|
-
const isDayPeriodRTL = data.isLocaleDayPeriodRTL(this.locale);
|
|
1383
|
-
return (index$1.h("ion-picker-column-internal", { style: isDayPeriodRTL ? { order: '-1' } : {}, color: this.color, value: activePart.ampm, items: dayPeriodData, onIonChange: (ev) => {
|
|
1384
|
-
const hour = data.calculateHourFromAMPM(workingParts, ev.detail.value);
|
|
1385
|
-
this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm: ev.detail.value, hour }));
|
|
1386
|
-
this.setActiveParts(Object.assign(Object.assign({}, activePart), { ampm: ev.detail.value, hour }));
|
|
1387
|
-
ev.stopPropagation();
|
|
1388
|
-
} }));
|
|
1389
|
-
}
|
|
1390
|
-
renderWheelView(forcePresentation) {
|
|
1391
|
-
const { locale } = this;
|
|
1392
|
-
const showMonthFirst = data.isMonthFirstLocale(locale);
|
|
1393
|
-
const columnOrder = showMonthFirst ? 'month-first' : 'year-first';
|
|
1394
|
-
return (index$1.h("div", { class: {
|
|
1395
|
-
[`wheel-order-${columnOrder}`]: true,
|
|
1396
|
-
} }, this.renderWheelPicker(forcePresentation)));
|
|
1397
|
-
}
|
|
1398
|
-
/**
|
|
1399
|
-
* Grid Render Methods
|
|
1400
|
-
*/
|
|
1401
|
-
renderCalendarHeader(mode) {
|
|
1402
|
-
const { disabled } = this;
|
|
1403
|
-
const expandedIcon = mode === 'ios' ? index$2.chevronDown : index$2.caretUpSharp;
|
|
1404
|
-
const collapsedIcon = mode === 'ios' ? index$2.chevronForward : index$2.caretDownSharp;
|
|
1405
|
-
const prevMonthDisabled = disabled || isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
|
|
1406
|
-
const nextMonthDisabled = disabled || isNextMonthDisabled(this.workingParts, this.maxParts);
|
|
1407
|
-
// don't use the inheritAttributes util because it removes dir from the host, and we still need that
|
|
1408
|
-
const hostDir = this.el.getAttribute('dir') || undefined;
|
|
1409
|
-
return (index$1.h("div", { class: "calendar-header" }, index$1.h("div", { class: "calendar-action-buttons" }, index$1.h("div", { class: "calendar-month-year" }, index$1.h("ion-item", { part: "month-year-button", ref: (el) => (this.monthYearToggleItemRef = el), button: true, "aria-label": "Show year picker", detail: false, lines: "none", disabled: disabled, onClick: () => {
|
|
1410
|
-
var _a;
|
|
1411
|
-
this.toggleMonthAndYearView();
|
|
1238
|
+
renderIndividualDatePickerColumns(forcePresentation) {
|
|
1239
|
+
const { workingParts, isDateEnabled } = this;
|
|
1240
|
+
const shouldRenderMonths = forcePresentation !== 'year' && forcePresentation !== 'time';
|
|
1241
|
+
const months = shouldRenderMonths
|
|
1242
|
+
? data.getMonthColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedMonthValues)
|
|
1243
|
+
: [];
|
|
1244
|
+
const shouldRenderDays = forcePresentation === 'date';
|
|
1245
|
+
let days = shouldRenderDays
|
|
1246
|
+
? data.getDayColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedDayValues)
|
|
1247
|
+
: [];
|
|
1248
|
+
if (isDateEnabled) {
|
|
1249
|
+
days = days.map((dayObject) => {
|
|
1250
|
+
const { value } = dayObject;
|
|
1251
|
+
const valueNum = typeof value === 'string' ? parseInt(value) : value;
|
|
1252
|
+
const referenceParts = {
|
|
1253
|
+
month: workingParts.month,
|
|
1254
|
+
day: valueNum,
|
|
1255
|
+
year: workingParts.year,
|
|
1256
|
+
};
|
|
1257
|
+
let disabled;
|
|
1258
|
+
try {
|
|
1259
|
+
/**
|
|
1260
|
+
* The `isDateEnabled` implementation is try-catch wrapped
|
|
1261
|
+
* to prevent exceptions in the user's function from
|
|
1262
|
+
* interrupting the calendar rendering.
|
|
1263
|
+
*/
|
|
1264
|
+
disabled = !isDateEnabled(data.convertDataToISO(referenceParts));
|
|
1265
|
+
}
|
|
1266
|
+
catch (e) {
|
|
1267
|
+
index.printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
|
|
1268
|
+
}
|
|
1269
|
+
return Object.assign(Object.assign({}, dayObject), { disabled });
|
|
1270
|
+
});
|
|
1271
|
+
}
|
|
1272
|
+
const shouldRenderYears = forcePresentation !== 'month' && forcePresentation !== 'time';
|
|
1273
|
+
const years = shouldRenderYears
|
|
1274
|
+
? data.getYearColumnData(this.locale, this.defaultParts, this.minParts, this.maxParts, this.parsedYearValues)
|
|
1275
|
+
: [];
|
|
1412
1276
|
/**
|
|
1413
|
-
*
|
|
1414
|
-
*
|
|
1415
|
-
* Currently there is not a way to set the aria-label on the inner button
|
|
1416
|
-
* on the `ion-item` and have it be reactive to changes. This is a workaround
|
|
1417
|
-
* until we either refactor `ion-item` to a button or Stencil adds a way to
|
|
1418
|
-
* have reactive props for built-in properties, such as `aria-label`.
|
|
1277
|
+
* Certain locales show the day before the month.
|
|
1419
1278
|
*/
|
|
1420
|
-
const {
|
|
1421
|
-
|
|
1422
|
-
|
|
1423
|
-
|
|
1424
|
-
|
|
1425
|
-
|
|
1426
|
-
|
|
1279
|
+
const showMonthFirst = data.isMonthFirstLocale(this.locale, { month: 'numeric', day: 'numeric' });
|
|
1280
|
+
let renderArray = [];
|
|
1281
|
+
if (showMonthFirst) {
|
|
1282
|
+
renderArray = [
|
|
1283
|
+
this.renderMonthPickerColumn(months),
|
|
1284
|
+
this.renderDayPickerColumn(days),
|
|
1285
|
+
this.renderYearPickerColumn(years),
|
|
1286
|
+
];
|
|
1427
1287
|
}
|
|
1428
|
-
|
|
1429
|
-
|
|
1430
|
-
|
|
1431
|
-
|
|
1432
|
-
|
|
1433
|
-
|
|
1434
|
-
const yearAllowed = this.parsedYearValues === undefined || this.parsedYearValues.includes(year);
|
|
1435
|
-
const monthAllowed = this.parsedMonthValues === undefined || this.parsedMonthValues.includes(month);
|
|
1436
|
-
const isCalMonthDisabled = !yearAllowed || !monthAllowed;
|
|
1437
|
-
const isDatetimeDisabled = disabled || readonly;
|
|
1438
|
-
const swipeDisabled = disabled ||
|
|
1439
|
-
isMonthDisabled({
|
|
1440
|
-
month,
|
|
1441
|
-
year,
|
|
1442
|
-
day: null,
|
|
1443
|
-
}, {
|
|
1444
|
-
// The day is not used when checking if a month is disabled.
|
|
1445
|
-
// Users should be able to access the min or max month, even if the
|
|
1446
|
-
// min/max date is out of bounds (e.g. min is set to Feb 15, Feb should not be disabled).
|
|
1447
|
-
minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
|
|
1448
|
-
maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
|
|
1449
|
-
});
|
|
1450
|
-
// The working month should never have swipe disabled.
|
|
1451
|
-
// Otherwise the CSS scroll snap will not work and the user
|
|
1452
|
-
// can free-scroll the calendar.
|
|
1453
|
-
const isWorkingMonth = this.workingParts.month === month && this.workingParts.year === year;
|
|
1454
|
-
const activePart = this.getActivePartsWithFallback();
|
|
1455
|
-
return (index$1.h("div", { "aria-hidden": !isWorkingMonth ? 'true' : null, class: {
|
|
1456
|
-
'calendar-month': true,
|
|
1457
|
-
// Prevents scroll snap swipe gestures for months outside of the min/max bounds
|
|
1458
|
-
'calendar-month-disabled': !isWorkingMonth && swipeDisabled,
|
|
1459
|
-
} }, index$1.h("div", { class: "calendar-month-grid" }, data.getDaysOfMonth(month, year, this.firstDayOfWeek % 7).map((dateObject, index$2) => {
|
|
1460
|
-
const { day, dayOfWeek } = dateObject;
|
|
1461
|
-
const { el, highlightedDates, isDateEnabled, multiple } = this;
|
|
1462
|
-
const referenceParts = { month, day, year };
|
|
1463
|
-
const isCalendarPadding = day === null;
|
|
1464
|
-
const { isActive, isToday, ariaLabel, ariaSelected, disabled: isDayDisabled, text, } = getCalendarDayState(this.locale, referenceParts, this.activeParts, this.todayParts, this.minParts, this.maxParts, this.parsedDayValues);
|
|
1465
|
-
const dateIsoString = data.convertDataToISO(referenceParts);
|
|
1466
|
-
let isCalDayDisabled = isCalMonthDisabled || isDayDisabled;
|
|
1467
|
-
if (!isCalDayDisabled && isDateEnabled !== undefined) {
|
|
1468
|
-
try {
|
|
1469
|
-
/**
|
|
1470
|
-
* The `isDateEnabled` implementation is try-catch wrapped
|
|
1471
|
-
* to prevent exceptions in the user's function from
|
|
1472
|
-
* interrupting the calendar rendering.
|
|
1473
|
-
*/
|
|
1474
|
-
isCalDayDisabled = !isDateEnabled(dateIsoString);
|
|
1288
|
+
else {
|
|
1289
|
+
renderArray = [
|
|
1290
|
+
this.renderDayPickerColumn(days),
|
|
1291
|
+
this.renderMonthPickerColumn(months),
|
|
1292
|
+
this.renderYearPickerColumn(years),
|
|
1293
|
+
];
|
|
1475
1294
|
}
|
|
1476
|
-
|
|
1477
|
-
|
|
1295
|
+
return renderArray;
|
|
1296
|
+
}
|
|
1297
|
+
renderDayPickerColumn(days) {
|
|
1298
|
+
var _a;
|
|
1299
|
+
if (days.length === 0) {
|
|
1300
|
+
return [];
|
|
1478
1301
|
}
|
|
1479
|
-
|
|
1480
|
-
|
|
1481
|
-
|
|
1482
|
-
|
|
1483
|
-
|
|
1484
|
-
|
|
1485
|
-
|
|
1486
|
-
|
|
1487
|
-
|
|
1488
|
-
|
|
1489
|
-
|
|
1490
|
-
|
|
1491
|
-
|
|
1492
|
-
|
|
1493
|
-
|
|
1494
|
-
|
|
1495
|
-
|
|
1496
|
-
|
|
1497
|
-
|
|
1498
|
-
|
|
1499
|
-
|
|
1500
|
-
}
|
|
1501
|
-
return (index$1.h("div", { class: "calendar-day-wrapper" }, index$1.h("button", {
|
|
1502
|
-
// We need to use !important for the inline styles here because
|
|
1503
|
-
// otherwise the CSS shadow parts will override these styles.
|
|
1504
|
-
// See https://github.com/WICG/webcomponents/issues/847
|
|
1505
|
-
// Both the CSS shadow parts and highlightedDates styles are
|
|
1506
|
-
// provided by the developer, but highlightedDates styles should
|
|
1507
|
-
// always take priority.
|
|
1508
|
-
ref: (el) => {
|
|
1509
|
-
if (el) {
|
|
1510
|
-
el.style.setProperty('color', `${dateStyle ? dateStyle.textColor : ''}`, 'important');
|
|
1511
|
-
el.style.setProperty('background-color', `${dateStyle ? dateStyle.backgroundColor : ''}`, 'important');
|
|
1512
|
-
}
|
|
1513
|
-
}, tabindex: "-1", "data-day": day, "data-month": month, "data-year": year, "data-index": index$2, "data-day-of-week": dayOfWeek, disabled: isButtonDisabled, class: {
|
|
1514
|
-
'calendar-day-padding': isCalendarPadding,
|
|
1515
|
-
'calendar-day': true,
|
|
1516
|
-
'calendar-day-active': isActive,
|
|
1517
|
-
'calendar-day-constrained': isCalDayConstrained,
|
|
1518
|
-
'calendar-day-today': isToday,
|
|
1519
|
-
}, part: dateParts, "aria-hidden": isCalendarPadding ? 'true' : null, "aria-selected": ariaSelected, "aria-label": ariaLabel, onClick: () => {
|
|
1520
|
-
if (isCalendarPadding) {
|
|
1521
|
-
return;
|
|
1522
|
-
}
|
|
1523
|
-
this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month,
|
|
1524
|
-
day,
|
|
1525
|
-
year }));
|
|
1526
|
-
// multiple only needs date info, so we can wipe out other fields like time
|
|
1527
|
-
if (multiple) {
|
|
1528
|
-
this.setActiveParts({
|
|
1529
|
-
month,
|
|
1530
|
-
day,
|
|
1531
|
-
year,
|
|
1532
|
-
}, isActive);
|
|
1533
|
-
}
|
|
1534
|
-
else {
|
|
1535
|
-
this.setActiveParts(Object.assign(Object.assign({}, activePart), { month,
|
|
1536
|
-
day,
|
|
1537
|
-
year }));
|
|
1538
|
-
}
|
|
1302
|
+
const { disabled, workingParts } = this;
|
|
1303
|
+
const activePart = this.getActivePartsWithFallback();
|
|
1304
|
+
return (index$1.h("ion-picker-column-internal", { class: "day-column", color: this.color, disabled: disabled, items: days, value: (_a = (workingParts.day !== null ? workingParts.day : this.defaultParts.day)) !== null && _a !== void 0 ? _a : undefined, onIonChange: (ev) => {
|
|
1305
|
+
// TODO(FW-1823) Remove this when iOS 14 support is dropped.
|
|
1306
|
+
// Due to a Safari 14 issue we need to destroy
|
|
1307
|
+
// the scroll listener before we update state
|
|
1308
|
+
// and trigger a re-render.
|
|
1309
|
+
if (this.destroyCalendarListener) {
|
|
1310
|
+
this.destroyCalendarListener();
|
|
1311
|
+
}
|
|
1312
|
+
this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { day: ev.detail.value }));
|
|
1313
|
+
this.setActiveParts(Object.assign(Object.assign({}, activePart), { day: ev.detail.value }));
|
|
1314
|
+
// We can re-attach the scroll listener after
|
|
1315
|
+
// the working parts have been updated.
|
|
1316
|
+
this.initializeCalendarListener();
|
|
1317
|
+
ev.stopPropagation();
|
|
1318
|
+
} }));
|
|
1319
|
+
}
|
|
1320
|
+
renderMonthPickerColumn(months) {
|
|
1321
|
+
if (months.length === 0) {
|
|
1322
|
+
return [];
|
|
1539
1323
|
}
|
|
1540
|
-
|
|
1541
|
-
|
|
1542
|
-
|
|
1543
|
-
|
|
1544
|
-
|
|
1545
|
-
|
|
1546
|
-
|
|
1547
|
-
|
|
1548
|
-
|
|
1549
|
-
|
|
1550
|
-
|
|
1551
|
-
|
|
1552
|
-
|
|
1553
|
-
|
|
1554
|
-
|
|
1555
|
-
|
|
1556
|
-
|
|
1557
|
-
|
|
1558
|
-
|
|
1559
|
-
|
|
1560
|
-
|
|
1561
|
-
const activePart = this.getActivePartsWithFallback();
|
|
1562
|
-
return [
|
|
1563
|
-
index$1.h("div", { class: "time-header" }, this.renderTimeLabel()),
|
|
1564
|
-
index$1.h("button", { class: {
|
|
1565
|
-
'time-body': true,
|
|
1566
|
-
'time-body-active': isTimePopoverOpen,
|
|
1567
|
-
}, part: `time-button${isTimePopoverOpen ? ' active' : ''}`, "aria-expanded": "false", "aria-haspopup": "true", disabled: disabled, onClick: async (ev) => {
|
|
1568
|
-
const { popoverRef } = this;
|
|
1569
|
-
if (popoverRef) {
|
|
1570
|
-
this.isTimePopoverOpen = true;
|
|
1571
|
-
popoverRef.present(new CustomEvent('ionShadowTarget', {
|
|
1572
|
-
detail: {
|
|
1573
|
-
ionShadowTarget: ev.target,
|
|
1574
|
-
},
|
|
1575
|
-
}));
|
|
1576
|
-
await popoverRef.onWillDismiss();
|
|
1577
|
-
this.isTimePopoverOpen = false;
|
|
1578
|
-
}
|
|
1579
|
-
} }, data.getLocalizedTime(locale, activePart, computedHourCycle)),
|
|
1580
|
-
index$1.h("ion-popover", { alignment: "center", translucent: true, overlayIndex: 1, arrow: false, onWillPresent: (ev) => {
|
|
1581
|
-
/**
|
|
1582
|
-
* Intersection Observers do not consistently fire between Blink and Webkit
|
|
1583
|
-
* when toggling the visibility of the popover and trying to scroll the picker
|
|
1584
|
-
* column to the correct time value.
|
|
1585
|
-
*
|
|
1586
|
-
* This will correctly scroll the element position to the correct time value,
|
|
1587
|
-
* before the popover is fully presented.
|
|
1588
|
-
*/
|
|
1589
|
-
const cols = ev.target.querySelectorAll('ion-picker-column-internal');
|
|
1590
|
-
// TODO (FW-615): Potentially remove this when intersection observers are fixed in picker column
|
|
1591
|
-
cols.forEach((col) => col.scrollActiveItemIntoView());
|
|
1592
|
-
}, style: {
|
|
1593
|
-
'--offset-y': '-10px',
|
|
1594
|
-
'--min-width': 'fit-content',
|
|
1595
|
-
},
|
|
1596
|
-
// Allow native browser keyboard events to support up/down/home/end key
|
|
1597
|
-
// navigation within the time picker.
|
|
1598
|
-
keyboardEvents: true, ref: (el) => (this.popoverRef = el) }, this.renderWheelPicker('time')),
|
|
1599
|
-
];
|
|
1600
|
-
}
|
|
1601
|
-
getHeaderSelectedDateText() {
|
|
1602
|
-
const { activeParts, multiple, titleSelectedDatesFormatter } = this;
|
|
1603
|
-
const isArray = Array.isArray(activeParts);
|
|
1604
|
-
let headerText;
|
|
1605
|
-
if (multiple && isArray && activeParts.length !== 1) {
|
|
1606
|
-
headerText = `${activeParts.length} days`; // default/fallback for multiple selection
|
|
1607
|
-
if (titleSelectedDatesFormatter !== undefined) {
|
|
1608
|
-
try {
|
|
1609
|
-
headerText = titleSelectedDatesFormatter(data.convertDataToISO(activeParts));
|
|
1324
|
+
const { disabled, workingParts } = this;
|
|
1325
|
+
const activePart = this.getActivePartsWithFallback();
|
|
1326
|
+
return (index$1.h("ion-picker-column-internal", { class: "month-column", color: this.color, disabled: disabled, items: months, value: workingParts.month, onIonChange: (ev) => {
|
|
1327
|
+
// TODO(FW-1823) Remove this when iOS 14 support is dropped.
|
|
1328
|
+
// Due to a Safari 14 issue we need to destroy
|
|
1329
|
+
// the scroll listener before we update state
|
|
1330
|
+
// and trigger a re-render.
|
|
1331
|
+
if (this.destroyCalendarListener) {
|
|
1332
|
+
this.destroyCalendarListener();
|
|
1333
|
+
}
|
|
1334
|
+
this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { month: ev.detail.value }));
|
|
1335
|
+
this.setActiveParts(Object.assign(Object.assign({}, activePart), { month: ev.detail.value }));
|
|
1336
|
+
// We can re-attach the scroll listener after
|
|
1337
|
+
// the working parts have been updated.
|
|
1338
|
+
this.initializeCalendarListener();
|
|
1339
|
+
ev.stopPropagation();
|
|
1340
|
+
} }));
|
|
1341
|
+
}
|
|
1342
|
+
renderYearPickerColumn(years) {
|
|
1343
|
+
if (years.length === 0) {
|
|
1344
|
+
return [];
|
|
1610
1345
|
}
|
|
1611
|
-
|
|
1612
|
-
|
|
1346
|
+
const { disabled, workingParts } = this;
|
|
1347
|
+
const activePart = this.getActivePartsWithFallback();
|
|
1348
|
+
return (index$1.h("ion-picker-column-internal", { class: "year-column", color: this.color, disabled: disabled, items: years, value: workingParts.year, onIonChange: (ev) => {
|
|
1349
|
+
// TODO(FW-1823) Remove this when iOS 14 support is dropped.
|
|
1350
|
+
// Due to a Safari 14 issue we need to destroy
|
|
1351
|
+
// the scroll listener before we update state
|
|
1352
|
+
// and trigger a re-render.
|
|
1353
|
+
if (this.destroyCalendarListener) {
|
|
1354
|
+
this.destroyCalendarListener();
|
|
1355
|
+
}
|
|
1356
|
+
this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { year: ev.detail.value }));
|
|
1357
|
+
this.setActiveParts(Object.assign(Object.assign({}, activePart), { year: ev.detail.value }));
|
|
1358
|
+
// We can re-attach the scroll listener after
|
|
1359
|
+
// the working parts have been updated.
|
|
1360
|
+
this.initializeCalendarListener();
|
|
1361
|
+
ev.stopPropagation();
|
|
1362
|
+
} }));
|
|
1363
|
+
}
|
|
1364
|
+
renderTimePickerColumns(forcePresentation) {
|
|
1365
|
+
if (['date', 'month', 'month-year', 'year'].includes(forcePresentation)) {
|
|
1366
|
+
return [];
|
|
1613
1367
|
}
|
|
1614
|
-
|
|
1368
|
+
/**
|
|
1369
|
+
* If a user has not selected a date,
|
|
1370
|
+
* then we should show all times. If the
|
|
1371
|
+
* user has selected a date (even if it has
|
|
1372
|
+
* not been confirmed yet), we should apply
|
|
1373
|
+
* the max and min restrictions so that the
|
|
1374
|
+
* time picker shows values that are
|
|
1375
|
+
* appropriate for the selected date.
|
|
1376
|
+
*/
|
|
1377
|
+
const activePart = this.getActivePart();
|
|
1378
|
+
const userHasSelectedDate = activePart !== undefined;
|
|
1379
|
+
const { hoursData, minutesData, dayPeriodData } = data.getTimeColumnsData(this.locale, this.workingParts, this.hourCycle, userHasSelectedDate ? this.minParts : undefined, userHasSelectedDate ? this.maxParts : undefined, this.parsedHourValues, this.parsedMinuteValues);
|
|
1380
|
+
return [
|
|
1381
|
+
this.renderHourPickerColumn(hoursData),
|
|
1382
|
+
this.renderMinutePickerColumn(minutesData),
|
|
1383
|
+
this.renderDayPeriodPickerColumn(dayPeriodData),
|
|
1384
|
+
];
|
|
1385
|
+
}
|
|
1386
|
+
renderHourPickerColumn(hoursData) {
|
|
1387
|
+
const { disabled, workingParts } = this;
|
|
1388
|
+
if (hoursData.length === 0)
|
|
1389
|
+
return [];
|
|
1390
|
+
const activePart = this.getActivePartsWithFallback();
|
|
1391
|
+
return (index$1.h("ion-picker-column-internal", { color: this.color, disabled: disabled, value: activePart.hour, items: hoursData, numericInput: true, onIonChange: (ev) => {
|
|
1392
|
+
this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { hour: ev.detail.value }));
|
|
1393
|
+
this.setActiveParts(Object.assign(Object.assign({}, activePart), { hour: ev.detail.value }));
|
|
1394
|
+
ev.stopPropagation();
|
|
1395
|
+
} }));
|
|
1396
|
+
}
|
|
1397
|
+
renderMinutePickerColumn(minutesData) {
|
|
1398
|
+
const { disabled, workingParts } = this;
|
|
1399
|
+
if (minutesData.length === 0)
|
|
1400
|
+
return [];
|
|
1401
|
+
const activePart = this.getActivePartsWithFallback();
|
|
1402
|
+
return (index$1.h("ion-picker-column-internal", { color: this.color, disabled: disabled, value: activePart.minute, items: minutesData, numericInput: true, onIonChange: (ev) => {
|
|
1403
|
+
this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { minute: ev.detail.value }));
|
|
1404
|
+
this.setActiveParts(Object.assign(Object.assign({}, activePart), { minute: ev.detail.value }));
|
|
1405
|
+
ev.stopPropagation();
|
|
1406
|
+
} }));
|
|
1407
|
+
}
|
|
1408
|
+
renderDayPeriodPickerColumn(dayPeriodData) {
|
|
1409
|
+
const { disabled, workingParts } = this;
|
|
1410
|
+
if (dayPeriodData.length === 0) {
|
|
1411
|
+
return [];
|
|
1412
|
+
}
|
|
1413
|
+
const activePart = this.getActivePartsWithFallback();
|
|
1414
|
+
const isDayPeriodRTL = data.isLocaleDayPeriodRTL(this.locale);
|
|
1415
|
+
return (index$1.h("ion-picker-column-internal", { style: isDayPeriodRTL ? { order: '-1' } : {}, color: this.color, disabled: disabled, value: activePart.ampm, items: dayPeriodData, onIonChange: (ev) => {
|
|
1416
|
+
const hour = data.calculateHourFromAMPM(workingParts, ev.detail.value);
|
|
1417
|
+
this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm: ev.detail.value, hour }));
|
|
1418
|
+
this.setActiveParts(Object.assign(Object.assign({}, activePart), { ampm: ev.detail.value, hour }));
|
|
1419
|
+
ev.stopPropagation();
|
|
1420
|
+
} }));
|
|
1421
|
+
}
|
|
1422
|
+
renderWheelView(forcePresentation) {
|
|
1423
|
+
const { locale } = this;
|
|
1424
|
+
const showMonthFirst = data.isMonthFirstLocale(locale);
|
|
1425
|
+
const columnOrder = showMonthFirst ? 'month-first' : 'year-first';
|
|
1426
|
+
return (index$1.h("div", { class: {
|
|
1427
|
+
[`wheel-order-${columnOrder}`]: true,
|
|
1428
|
+
} }, this.renderWheelPicker(forcePresentation)));
|
|
1615
1429
|
}
|
|
1616
|
-
else {
|
|
1617
|
-
// for exactly 1 day selected (multiple set or not), show a formatted version of that
|
|
1618
|
-
headerText = data.getMonthAndDay(this.locale, this.getActivePartsWithFallback());
|
|
1619
|
-
}
|
|
1620
|
-
return headerText;
|
|
1621
|
-
}
|
|
1622
|
-
renderHeader(showExpandedHeader = true) {
|
|
1623
|
-
const hasSlottedTitle = this.el.querySelector('[slot="title"]') !== null;
|
|
1624
|
-
if (!hasSlottedTitle && !this.showDefaultTitle) {
|
|
1625
|
-
return;
|
|
1626
|
-
}
|
|
1627
|
-
return (index$1.h("div", { class: "datetime-header" }, index$1.h("div", { class: "datetime-title" }, index$1.h("slot", { name: "title" }, "Select Date")), showExpandedHeader && index$1.h("div", { class: "datetime-selected-date" }, this.getHeaderSelectedDateText())));
|
|
1628
|
-
}
|
|
1629
|
-
/**
|
|
1630
|
-
* Render time picker inside of datetime.
|
|
1631
|
-
* Do not pass color prop to segment on
|
|
1632
|
-
* iOS mode. MD segment has been customized and
|
|
1633
|
-
* should take on the color prop, but iOS
|
|
1634
|
-
* should just be the default segment.
|
|
1635
|
-
*/
|
|
1636
|
-
renderTime() {
|
|
1637
|
-
const { presentation } = this;
|
|
1638
|
-
const timeOnlyPresentation = presentation === 'time';
|
|
1639
|
-
return (index$1.h("div", { class: "datetime-time" }, timeOnlyPresentation ? this.renderWheelPicker() : this.renderTimeOverlay()));
|
|
1640
|
-
}
|
|
1641
|
-
/**
|
|
1642
|
-
* Renders the month/year picker that is
|
|
1643
|
-
* displayed on the calendar grid.
|
|
1644
|
-
* The .datetime-year class has additional
|
|
1645
|
-
* styles that let us show/hide the
|
|
1646
|
-
* picker when the user clicks on the
|
|
1647
|
-
* toggle in the calendar header.
|
|
1648
|
-
*/
|
|
1649
|
-
renderCalendarViewMonthYearPicker() {
|
|
1650
|
-
return index$1.h("div", { class: "datetime-year" }, this.renderWheelView('month-year'));
|
|
1651
|
-
}
|
|
1652
|
-
/**
|
|
1653
|
-
* Render entry point
|
|
1654
|
-
* All presentation types are rendered from here.
|
|
1655
|
-
*/
|
|
1656
|
-
renderDatetime(mode) {
|
|
1657
|
-
const { presentation, preferWheel } = this;
|
|
1658
1430
|
/**
|
|
1659
|
-
*
|
|
1660
|
-
* If preferWheel is true then we should show a wheel picker instead.
|
|
1431
|
+
* Grid Render Methods
|
|
1661
1432
|
*/
|
|
1662
|
-
|
|
1663
|
-
|
|
1664
|
-
|
|
1433
|
+
renderCalendarHeader(mode) {
|
|
1434
|
+
const { disabled } = this;
|
|
1435
|
+
const expandedIcon = mode === 'ios' ? index$2.chevronDown : index$2.caretUpSharp;
|
|
1436
|
+
const collapsedIcon = mode === 'ios' ? index$2.chevronForward : index$2.caretDownSharp;
|
|
1437
|
+
const prevMonthDisabled = disabled || isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
|
|
1438
|
+
const nextMonthDisabled = disabled || isNextMonthDisabled(this.workingParts, this.maxParts);
|
|
1439
|
+
// don't use the inheritAttributes util because it removes dir from the host, and we still need that
|
|
1440
|
+
const hostDir = this.el.getAttribute('dir') || undefined;
|
|
1441
|
+
return (index$1.h("div", { class: "calendar-header" }, index$1.h("div", { class: "calendar-action-buttons" }, index$1.h("div", { class: "calendar-month-year" }, index$1.h("ion-item", { part: "month-year-button", ref: (el) => (this.monthYearToggleItemRef = el), button: true, "aria-label": "Show year picker", detail: false, lines: "none", disabled: disabled, onClick: () => {
|
|
1442
|
+
var _a;
|
|
1443
|
+
this.toggleMonthAndYearView();
|
|
1444
|
+
/**
|
|
1445
|
+
* TODO: FW-3547
|
|
1446
|
+
*
|
|
1447
|
+
* Currently there is not a way to set the aria-label on the inner button
|
|
1448
|
+
* on the `ion-item` and have it be reactive to changes. This is a workaround
|
|
1449
|
+
* until we either refactor `ion-item` to a button or Stencil adds a way to
|
|
1450
|
+
* have reactive props for built-in properties, such as `aria-label`.
|
|
1451
|
+
*/
|
|
1452
|
+
const { monthYearToggleItemRef } = this;
|
|
1453
|
+
if (monthYearToggleItemRef) {
|
|
1454
|
+
const btn = (_a = monthYearToggleItemRef.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.item-native');
|
|
1455
|
+
if (btn) {
|
|
1456
|
+
const monthYearAriaLabel = this.showMonthAndYear ? 'Hide year picker' : 'Show year picker';
|
|
1457
|
+
btn.setAttribute('aria-label', monthYearAriaLabel);
|
|
1458
|
+
}
|
|
1459
|
+
}
|
|
1460
|
+
} }, index$1.h("ion-label", null, data.getMonthAndYear(this.locale, this.workingParts), index$1.h("ion-icon", { "aria-hidden": "true", icon: this.showMonthAndYear ? expandedIcon : collapsedIcon, lazy: false, flipRtl: true })))), index$1.h("div", { class: "calendar-next-prev" }, index$1.h("ion-buttons", null, index$1.h("ion-button", { "aria-label": "Previous month", disabled: prevMonthDisabled, onClick: () => this.prevMonth() }, index$1.h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: index$2.chevronBack, lazy: false, flipRtl: true })), index$1.h("ion-button", { "aria-label": "Next month", disabled: nextMonthDisabled, onClick: () => this.nextMonth() }, index$1.h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: index$2.chevronForward, lazy: false, flipRtl: true }))))), index$1.h("div", { class: "calendar-days-of-week", "aria-hidden": "true" }, data.getDaysOfWeek(this.locale, mode, this.firstDayOfWeek % 7).map((d) => {
|
|
1461
|
+
return index$1.h("div", { class: "day-of-week" }, d);
|
|
1462
|
+
}))));
|
|
1665
1463
|
}
|
|
1666
|
-
|
|
1667
|
-
|
|
1668
|
-
|
|
1669
|
-
|
|
1670
|
-
|
|
1671
|
-
|
|
1672
|
-
|
|
1673
|
-
|
|
1674
|
-
|
|
1675
|
-
|
|
1676
|
-
|
|
1677
|
-
|
|
1678
|
-
|
|
1679
|
-
|
|
1680
|
-
|
|
1681
|
-
|
|
1682
|
-
|
|
1683
|
-
|
|
1684
|
-
|
|
1685
|
-
|
|
1686
|
-
|
|
1687
|
-
|
|
1688
|
-
|
|
1689
|
-
|
|
1464
|
+
renderMonth(month, year) {
|
|
1465
|
+
const { disabled, readonly } = this;
|
|
1466
|
+
const yearAllowed = this.parsedYearValues === undefined || this.parsedYearValues.includes(year);
|
|
1467
|
+
const monthAllowed = this.parsedMonthValues === undefined || this.parsedMonthValues.includes(month);
|
|
1468
|
+
const isCalMonthDisabled = !yearAllowed || !monthAllowed;
|
|
1469
|
+
const isDatetimeDisabled = disabled || readonly;
|
|
1470
|
+
const swipeDisabled = disabled ||
|
|
1471
|
+
isMonthDisabled({
|
|
1472
|
+
month,
|
|
1473
|
+
year,
|
|
1474
|
+
day: null,
|
|
1475
|
+
}, {
|
|
1476
|
+
// The day is not used when checking if a month is disabled.
|
|
1477
|
+
// Users should be able to access the min or max month, even if the
|
|
1478
|
+
// min/max date is out of bounds (e.g. min is set to Feb 15, Feb should not be disabled).
|
|
1479
|
+
minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
|
|
1480
|
+
maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
|
|
1481
|
+
});
|
|
1482
|
+
// The working month should never have swipe disabled.
|
|
1483
|
+
// Otherwise the CSS scroll snap will not work and the user
|
|
1484
|
+
// can free-scroll the calendar.
|
|
1485
|
+
const isWorkingMonth = this.workingParts.month === month && this.workingParts.year === year;
|
|
1486
|
+
const activePart = this.getActivePartsWithFallback();
|
|
1487
|
+
return (index$1.h("div", { "aria-hidden": !isWorkingMonth ? 'true' : null, class: {
|
|
1488
|
+
'calendar-month': true,
|
|
1489
|
+
// Prevents scroll snap swipe gestures for months outside of the min/max bounds
|
|
1490
|
+
'calendar-month-disabled': !isWorkingMonth && swipeDisabled,
|
|
1491
|
+
} }, index$1.h("div", { class: "calendar-month-grid" }, data.getDaysOfMonth(month, year, this.firstDayOfWeek % 7).map((dateObject, index$2) => {
|
|
1492
|
+
const { day, dayOfWeek } = dateObject;
|
|
1493
|
+
const { el, highlightedDates, isDateEnabled, multiple } = this;
|
|
1494
|
+
const referenceParts = { month, day, year };
|
|
1495
|
+
const isCalendarPadding = day === null;
|
|
1496
|
+
const { isActive, isToday, ariaLabel, ariaSelected, disabled: isDayDisabled, text, } = getCalendarDayState(this.locale, referenceParts, this.activeParts, this.todayParts, this.minParts, this.maxParts, this.parsedDayValues);
|
|
1497
|
+
const dateIsoString = data.convertDataToISO(referenceParts);
|
|
1498
|
+
let isCalDayDisabled = isCalMonthDisabled || isDayDisabled;
|
|
1499
|
+
if (!isCalDayDisabled && isDateEnabled !== undefined) {
|
|
1500
|
+
try {
|
|
1501
|
+
/**
|
|
1502
|
+
* The `isDateEnabled` implementation is try-catch wrapped
|
|
1503
|
+
* to prevent exceptions in the user's function from
|
|
1504
|
+
* interrupting the calendar rendering.
|
|
1505
|
+
*/
|
|
1506
|
+
isCalDayDisabled = !isDateEnabled(dateIsoString);
|
|
1507
|
+
}
|
|
1508
|
+
catch (e) {
|
|
1509
|
+
index.printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', el, e);
|
|
1510
|
+
}
|
|
1511
|
+
}
|
|
1512
|
+
/**
|
|
1513
|
+
* Some days are constrained through max & min or allowed dates
|
|
1514
|
+
* and also disabled because the component is readonly or disabled.
|
|
1515
|
+
* These need to be displayed differently.
|
|
1516
|
+
*/
|
|
1517
|
+
const isCalDayConstrained = isCalDayDisabled && isDatetimeDisabled;
|
|
1518
|
+
const isButtonDisabled = isCalDayDisabled || isDatetimeDisabled;
|
|
1519
|
+
let dateStyle = undefined;
|
|
1520
|
+
/**
|
|
1521
|
+
* Custom highlight styles should not override the style for selected dates,
|
|
1522
|
+
* nor apply to "filler days" at the start of the grid.
|
|
1523
|
+
*/
|
|
1524
|
+
if (highlightedDates !== undefined && !isActive && day !== null) {
|
|
1525
|
+
dateStyle = getHighlightStyles(highlightedDates, dateIsoString, el);
|
|
1526
|
+
}
|
|
1527
|
+
let dateParts = undefined;
|
|
1528
|
+
// "Filler days" at the beginning of the grid should not get the calendar day
|
|
1529
|
+
// CSS parts added to them
|
|
1530
|
+
if (!isCalendarPadding) {
|
|
1531
|
+
dateParts = `calendar-day${isActive ? ' active' : ''}${isToday ? ' today' : ''}${isCalDayDisabled ? ' disabled' : ''}`;
|
|
1532
|
+
}
|
|
1533
|
+
return (index$1.h("div", { class: "calendar-day-wrapper" }, index$1.h("button", {
|
|
1534
|
+
// We need to use !important for the inline styles here because
|
|
1535
|
+
// otherwise the CSS shadow parts will override these styles.
|
|
1536
|
+
// See https://github.com/WICG/webcomponents/issues/847
|
|
1537
|
+
// Both the CSS shadow parts and highlightedDates styles are
|
|
1538
|
+
// provided by the developer, but highlightedDates styles should
|
|
1539
|
+
// always take priority.
|
|
1540
|
+
ref: (el) => {
|
|
1541
|
+
if (el) {
|
|
1542
|
+
el.style.setProperty('color', `${dateStyle ? dateStyle.textColor : ''}`, 'important');
|
|
1543
|
+
el.style.setProperty('background-color', `${dateStyle ? dateStyle.backgroundColor : ''}`, 'important');
|
|
1544
|
+
}
|
|
1545
|
+
}, tabindex: "-1", "data-day": day, "data-month": month, "data-year": year, "data-index": index$2, "data-day-of-week": dayOfWeek, disabled: isButtonDisabled, class: {
|
|
1546
|
+
'calendar-day-padding': isCalendarPadding,
|
|
1547
|
+
'calendar-day': true,
|
|
1548
|
+
'calendar-day-active': isActive,
|
|
1549
|
+
'calendar-day-constrained': isCalDayConstrained,
|
|
1550
|
+
'calendar-day-today': isToday,
|
|
1551
|
+
}, part: dateParts, "aria-hidden": isCalendarPadding ? 'true' : null, "aria-selected": ariaSelected, "aria-label": ariaLabel, onClick: () => {
|
|
1552
|
+
if (isCalendarPadding) {
|
|
1553
|
+
return;
|
|
1554
|
+
}
|
|
1555
|
+
this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month,
|
|
1556
|
+
day,
|
|
1557
|
+
year }));
|
|
1558
|
+
// multiple only needs date info, so we can wipe out other fields like time
|
|
1559
|
+
if (multiple) {
|
|
1560
|
+
this.setActiveParts({
|
|
1561
|
+
month,
|
|
1562
|
+
day,
|
|
1563
|
+
year,
|
|
1564
|
+
}, isActive);
|
|
1565
|
+
}
|
|
1566
|
+
else {
|
|
1567
|
+
this.setActiveParts(Object.assign(Object.assign({}, activePart), { month,
|
|
1568
|
+
day,
|
|
1569
|
+
year }));
|
|
1570
|
+
}
|
|
1571
|
+
}
|
|
1572
|
+
}, text)));
|
|
1573
|
+
}))));
|
|
1574
|
+
}
|
|
1575
|
+
renderCalendarBody() {
|
|
1576
|
+
return (index$1.h("div", { class: "calendar-body ion-focusable", ref: (el) => (this.calendarBodyRef = el), tabindex: "0" }, data.generateMonths(this.workingParts, this.forceRenderDate).map(({ month, year }) => {
|
|
1577
|
+
return this.renderMonth(month, year);
|
|
1578
|
+
})));
|
|
1579
|
+
}
|
|
1580
|
+
renderCalendar(mode) {
|
|
1581
|
+
return (index$1.h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(mode), this.renderCalendarBody()));
|
|
1582
|
+
}
|
|
1583
|
+
renderTimeLabel() {
|
|
1584
|
+
const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
|
|
1585
|
+
if (!hasSlottedTimeLabel && !this.showDefaultTimeLabel) {
|
|
1586
|
+
return;
|
|
1587
|
+
}
|
|
1588
|
+
return index$1.h("slot", { name: "time-label" }, "Time");
|
|
1589
|
+
}
|
|
1590
|
+
renderTimeOverlay() {
|
|
1591
|
+
const { disabled, hourCycle, isTimePopoverOpen, locale } = this;
|
|
1592
|
+
const computedHourCycle = data.getHourCycle(locale, hourCycle);
|
|
1593
|
+
const activePart = this.getActivePartsWithFallback();
|
|
1690
1594
|
return [
|
|
1691
|
-
|
|
1692
|
-
|
|
1693
|
-
|
|
1694
|
-
|
|
1595
|
+
index$1.h("div", { class: "time-header" }, this.renderTimeLabel()),
|
|
1596
|
+
index$1.h("button", { class: {
|
|
1597
|
+
'time-body': true,
|
|
1598
|
+
'time-body-active': isTimePopoverOpen,
|
|
1599
|
+
}, part: `time-button${isTimePopoverOpen ? ' active' : ''}`, "aria-expanded": "false", "aria-haspopup": "true", disabled: disabled, onClick: async (ev) => {
|
|
1600
|
+
const { popoverRef } = this;
|
|
1601
|
+
if (popoverRef) {
|
|
1602
|
+
this.isTimePopoverOpen = true;
|
|
1603
|
+
popoverRef.present(new CustomEvent('ionShadowTarget', {
|
|
1604
|
+
detail: {
|
|
1605
|
+
ionShadowTarget: ev.target,
|
|
1606
|
+
},
|
|
1607
|
+
}));
|
|
1608
|
+
await popoverRef.onWillDismiss();
|
|
1609
|
+
this.isTimePopoverOpen = false;
|
|
1610
|
+
}
|
|
1611
|
+
} }, data.getLocalizedTime(locale, activePart, computedHourCycle)),
|
|
1612
|
+
index$1.h("ion-popover", { alignment: "center", translucent: true, overlayIndex: 1, arrow: false, onWillPresent: (ev) => {
|
|
1613
|
+
/**
|
|
1614
|
+
* Intersection Observers do not consistently fire between Blink and Webkit
|
|
1615
|
+
* when toggling the visibility of the popover and trying to scroll the picker
|
|
1616
|
+
* column to the correct time value.
|
|
1617
|
+
*
|
|
1618
|
+
* This will correctly scroll the element position to the correct time value,
|
|
1619
|
+
* before the popover is fully presented.
|
|
1620
|
+
*/
|
|
1621
|
+
const cols = ev.target.querySelectorAll('ion-picker-column-internal');
|
|
1622
|
+
// TODO (FW-615): Potentially remove this when intersection observers are fixed in picker column
|
|
1623
|
+
cols.forEach((col) => col.scrollActiveItemIntoView());
|
|
1624
|
+
}, style: {
|
|
1625
|
+
'--offset-y': '-10px',
|
|
1626
|
+
'--min-width': 'fit-content',
|
|
1627
|
+
},
|
|
1628
|
+
// Allow native browser keyboard events to support up/down/home/end key
|
|
1629
|
+
// navigation within the time picker.
|
|
1630
|
+
keyboardEvents: true, ref: (el) => (this.popoverRef = el) }, this.renderWheelPicker('time')),
|
|
1695
1631
|
];
|
|
1696
1632
|
}
|
|
1697
|
-
|
|
1698
|
-
|
|
1699
|
-
|
|
1700
|
-
|
|
1701
|
-
|
|
1702
|
-
|
|
1703
|
-
|
|
1704
|
-
|
|
1705
|
-
|
|
1706
|
-
|
|
1707
|
-
|
|
1708
|
-
|
|
1709
|
-
|
|
1710
|
-
|
|
1711
|
-
|
|
1712
|
-
|
|
1713
|
-
|
|
1714
|
-
|
|
1715
|
-
|
|
1716
|
-
|
|
1717
|
-
|
|
1718
|
-
|
|
1719
|
-
|
|
1720
|
-
|
|
1721
|
-
|
|
1722
|
-
|
|
1723
|
-
|
|
1724
|
-
|
|
1725
|
-
|
|
1726
|
-
|
|
1727
|
-
|
|
1728
|
-
|
|
1729
|
-
|
|
1730
|
-
|
|
1633
|
+
getHeaderSelectedDateText() {
|
|
1634
|
+
const { activeParts, multiple, titleSelectedDatesFormatter } = this;
|
|
1635
|
+
const isArray = Array.isArray(activeParts);
|
|
1636
|
+
let headerText;
|
|
1637
|
+
if (multiple && isArray && activeParts.length !== 1) {
|
|
1638
|
+
headerText = `${activeParts.length} days`; // default/fallback for multiple selection
|
|
1639
|
+
if (titleSelectedDatesFormatter !== undefined) {
|
|
1640
|
+
try {
|
|
1641
|
+
headerText = titleSelectedDatesFormatter(data.convertDataToISO(activeParts));
|
|
1642
|
+
}
|
|
1643
|
+
catch (e) {
|
|
1644
|
+
index.printIonError('Exception in provided `titleSelectedDatesFormatter`: ', e);
|
|
1645
|
+
}
|
|
1646
|
+
}
|
|
1647
|
+
}
|
|
1648
|
+
else {
|
|
1649
|
+
// for exactly 1 day selected (multiple set or not), show a formatted version of that
|
|
1650
|
+
headerText = data.getMonthAndDay(this.locale, this.getActivePartsWithFallback());
|
|
1651
|
+
}
|
|
1652
|
+
return headerText;
|
|
1653
|
+
}
|
|
1654
|
+
renderHeader(showExpandedHeader = true) {
|
|
1655
|
+
const hasSlottedTitle = this.el.querySelector('[slot="title"]') !== null;
|
|
1656
|
+
if (!hasSlottedTitle && !this.showDefaultTitle) {
|
|
1657
|
+
return;
|
|
1658
|
+
}
|
|
1659
|
+
return (index$1.h("div", { class: "datetime-header" }, index$1.h("div", { class: "datetime-title" }, index$1.h("slot", { name: "title" }, "Select Date")), showExpandedHeader && index$1.h("div", { class: "datetime-selected-date" }, this.getHeaderSelectedDateText())));
|
|
1660
|
+
}
|
|
1661
|
+
/**
|
|
1662
|
+
* Render time picker inside of datetime.
|
|
1663
|
+
* Do not pass color prop to segment on
|
|
1664
|
+
* iOS mode. MD segment has been customized and
|
|
1665
|
+
* should take on the color prop, but iOS
|
|
1666
|
+
* should just be the default segment.
|
|
1667
|
+
*/
|
|
1668
|
+
renderTime() {
|
|
1669
|
+
const { presentation } = this;
|
|
1670
|
+
const timeOnlyPresentation = presentation === 'time';
|
|
1671
|
+
return (index$1.h("div", { class: "datetime-time" }, timeOnlyPresentation ? this.renderWheelPicker() : this.renderTimeOverlay()));
|
|
1672
|
+
}
|
|
1673
|
+
/**
|
|
1674
|
+
* Renders the month/year picker that is
|
|
1675
|
+
* displayed on the calendar grid.
|
|
1676
|
+
* The .datetime-year class has additional
|
|
1677
|
+
* styles that let us show/hide the
|
|
1678
|
+
* picker when the user clicks on the
|
|
1679
|
+
* toggle in the calendar header.
|
|
1680
|
+
*/
|
|
1681
|
+
renderCalendarViewMonthYearPicker() {
|
|
1682
|
+
return index$1.h("div", { class: "datetime-year" }, this.renderWheelView('month-year'));
|
|
1683
|
+
}
|
|
1684
|
+
/**
|
|
1685
|
+
* Render entry point
|
|
1686
|
+
* All presentation types are rendered from here.
|
|
1687
|
+
*/
|
|
1688
|
+
renderDatetime(mode) {
|
|
1689
|
+
const { presentation, preferWheel } = this;
|
|
1690
|
+
/**
|
|
1691
|
+
* Certain presentation types have separate grid and wheel displays.
|
|
1692
|
+
* If preferWheel is true then we should show a wheel picker instead.
|
|
1693
|
+
*/
|
|
1694
|
+
const hasWheelVariant = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
|
|
1695
|
+
if (preferWheel && hasWheelVariant) {
|
|
1696
|
+
return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
|
|
1697
|
+
}
|
|
1698
|
+
switch (presentation) {
|
|
1699
|
+
case 'date-time':
|
|
1700
|
+
return [
|
|
1701
|
+
this.renderHeader(),
|
|
1702
|
+
this.renderCalendar(mode),
|
|
1703
|
+
this.renderCalendarViewMonthYearPicker(),
|
|
1704
|
+
this.renderTime(),
|
|
1705
|
+
this.renderFooter(),
|
|
1706
|
+
];
|
|
1707
|
+
case 'time-date':
|
|
1708
|
+
return [
|
|
1709
|
+
this.renderHeader(),
|
|
1710
|
+
this.renderTime(),
|
|
1711
|
+
this.renderCalendar(mode),
|
|
1712
|
+
this.renderCalendarViewMonthYearPicker(),
|
|
1713
|
+
this.renderFooter(),
|
|
1714
|
+
];
|
|
1715
|
+
case 'time':
|
|
1716
|
+
return [this.renderHeader(false), this.renderTime(), this.renderFooter()];
|
|
1717
|
+
case 'month':
|
|
1718
|
+
case 'month-year':
|
|
1719
|
+
case 'year':
|
|
1720
|
+
return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
|
|
1721
|
+
default:
|
|
1722
|
+
return [
|
|
1723
|
+
this.renderHeader(),
|
|
1724
|
+
this.renderCalendar(mode),
|
|
1725
|
+
this.renderCalendarViewMonthYearPicker(),
|
|
1726
|
+
this.renderFooter(),
|
|
1727
|
+
];
|
|
1728
|
+
}
|
|
1729
|
+
}
|
|
1730
|
+
render() {
|
|
1731
|
+
const { name, value, disabled, el, color, readonly, showMonthAndYear, preferWheel, presentation, size, isGridStyle, } = this;
|
|
1732
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1733
|
+
const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
|
|
1734
|
+
const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
|
|
1735
|
+
const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
|
|
1736
|
+
const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
|
|
1737
|
+
const hasWheelVariant = hasDatePresentation && preferWheel;
|
|
1738
|
+
helpers.renderHiddenInput(true, el, name, data.formatValue(value), disabled);
|
|
1739
|
+
return (index$1.h(index$1.Host, { "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, theme.createColorClasses(color, {
|
|
1740
|
+
[mode]: true,
|
|
1741
|
+
['datetime-readonly']: readonly,
|
|
1742
|
+
['datetime-disabled']: disabled,
|
|
1743
|
+
'show-month-and-year': shouldShowMonthAndYear,
|
|
1744
|
+
'month-year-picker-open': monthYearPickerOpen,
|
|
1745
|
+
[`datetime-presentation-${presentation}`]: true,
|
|
1746
|
+
[`datetime-size-${size}`]: true,
|
|
1747
|
+
[`datetime-prefer-wheel`]: hasWheelVariant,
|
|
1748
|
+
[`datetime-grid`]: isGridStyle,
|
|
1749
|
+
})) }, this.renderDatetime(mode)));
|
|
1750
|
+
}
|
|
1751
|
+
get el() { return index$1.getElement(this); }
|
|
1752
|
+
static get watchers() { return {
|
|
1753
|
+
"disabled": ["disabledChanged"],
|
|
1754
|
+
"min": ["minChanged"],
|
|
1755
|
+
"max": ["maxChanged"],
|
|
1756
|
+
"yearValues": ["yearValuesChanged"],
|
|
1757
|
+
"monthValues": ["monthValuesChanged"],
|
|
1758
|
+
"dayValues": ["dayValuesChanged"],
|
|
1759
|
+
"hourValues": ["hourValuesChanged"],
|
|
1760
|
+
"minuteValues": ["minuteValuesChanged"],
|
|
1761
|
+
"value": ["valueChanged"]
|
|
1762
|
+
}; }
|
|
1731
1763
|
};
|
|
1732
1764
|
let datetimeIds = 0;
|
|
1733
1765
|
Datetime.style = {
|
|
1734
|
-
|
|
1735
|
-
|
|
1766
|
+
ios: datetimeIosCss,
|
|
1767
|
+
md: datetimeMdCss
|
|
1736
1768
|
};
|
|
1737
1769
|
|
|
1738
1770
|
/**
|
|
1739
1771
|
* iOS Picker Enter Animation
|
|
1740
1772
|
*/
|
|
1741
1773
|
const iosEnterAnimation = (baseEl) => {
|
|
1742
|
-
|
|
1743
|
-
|
|
1744
|
-
|
|
1745
|
-
|
|
1746
|
-
|
|
1747
|
-
|
|
1748
|
-
|
|
1749
|
-
|
|
1750
|
-
|
|
1751
|
-
|
|
1752
|
-
|
|
1753
|
-
|
|
1754
|
-
|
|
1755
|
-
|
|
1756
|
-
|
|
1757
|
-
|
|
1758
|
-
|
|
1759
|
-
|
|
1774
|
+
const baseAnimation = animation.createAnimation();
|
|
1775
|
+
const backdropAnimation = animation.createAnimation();
|
|
1776
|
+
const wrapperAnimation = animation.createAnimation();
|
|
1777
|
+
backdropAnimation
|
|
1778
|
+
.addElement(baseEl.querySelector('ion-backdrop'))
|
|
1779
|
+
.fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
|
|
1780
|
+
.beforeStyles({
|
|
1781
|
+
'pointer-events': 'none',
|
|
1782
|
+
})
|
|
1783
|
+
.afterClearStyles(['pointer-events']);
|
|
1784
|
+
wrapperAnimation
|
|
1785
|
+
.addElement(baseEl.querySelector('.picker-wrapper'))
|
|
1786
|
+
.fromTo('transform', 'translateY(100%)', 'translateY(0%)');
|
|
1787
|
+
return baseAnimation
|
|
1788
|
+
.addElement(baseEl)
|
|
1789
|
+
.easing('cubic-bezier(.36,.66,.04,1)')
|
|
1790
|
+
.duration(400)
|
|
1791
|
+
.addAnimation([backdropAnimation, wrapperAnimation]);
|
|
1760
1792
|
};
|
|
1761
1793
|
|
|
1762
1794
|
/**
|
|
1763
1795
|
* iOS Picker Leave Animation
|
|
1764
1796
|
*/
|
|
1765
1797
|
const iosLeaveAnimation = (baseEl) => {
|
|
1766
|
-
|
|
1767
|
-
|
|
1768
|
-
|
|
1769
|
-
|
|
1770
|
-
|
|
1771
|
-
|
|
1772
|
-
|
|
1773
|
-
|
|
1774
|
-
|
|
1775
|
-
|
|
1776
|
-
|
|
1777
|
-
|
|
1778
|
-
|
|
1779
|
-
|
|
1798
|
+
const baseAnimation = animation.createAnimation();
|
|
1799
|
+
const backdropAnimation = animation.createAnimation();
|
|
1800
|
+
const wrapperAnimation = animation.createAnimation();
|
|
1801
|
+
backdropAnimation
|
|
1802
|
+
.addElement(baseEl.querySelector('ion-backdrop'))
|
|
1803
|
+
.fromTo('opacity', 'var(--backdrop-opacity)', 0.01);
|
|
1804
|
+
wrapperAnimation
|
|
1805
|
+
.addElement(baseEl.querySelector('.picker-wrapper'))
|
|
1806
|
+
.fromTo('transform', 'translateY(0%)', 'translateY(100%)');
|
|
1807
|
+
return baseAnimation
|
|
1808
|
+
.addElement(baseEl)
|
|
1809
|
+
.easing('cubic-bezier(.36,.66,.04,1)')
|
|
1810
|
+
.duration(400)
|
|
1811
|
+
.addAnimation([backdropAnimation, wrapperAnimation]);
|
|
1780
1812
|
};
|
|
1781
1813
|
|
|
1782
1814
|
const pickerIosCss = ".sc-ion-picker-ios-h{--border-radius:0;--border-style:solid;--min-width:auto;--width:100%;--max-width:500px;--min-height:auto;--max-height:auto;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;top:0;display:block;position:absolute;width:100%;height:100%;outline:none;font-family:var(--ion-font-family, inherit);contain:strict;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1001}@supports (inset-inline-start: 0){.sc-ion-picker-ios-h{inset-inline-start:0}}@supports not (inset-inline-start: 0){.sc-ion-picker-ios-h{left:0}[dir=rtl].sc-ion-picker-ios-h,[dir=rtl] .sc-ion-picker-ios-h{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.sc-ion-picker-ios-h:dir(rtl){left:unset;right:unset;right:0}}}.overlay-hidden.sc-ion-picker-ios-h{display:none}.picker-wrapper.sc-ion-picker-ios{border-radius:var(--border-radius);left:0;right:0;bottom:0;-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:auto;margin-bottom:auto;-webkit-transform:translate3d(0, 100%, 0);transform:translate3d(0, 100%, 0);display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;overflow:hidden;z-index:10}.picker-toolbar.sc-ion-picker-ios{width:100%;background:transparent;contain:strict;z-index:1}.picker-button.sc-ion-picker-ios{border:0;font-family:inherit}.picker-button.sc-ion-picker-ios:active,.picker-button.sc-ion-picker-ios:focus{outline:none}.picker-columns.sc-ion-picker-ios{display:-ms-flexbox;display:flex;position:relative;-ms-flex-pack:center;justify-content:center;margin-bottom:var(--ion-safe-area-bottom, 0);contain:strict;overflow:hidden}.picker-above-highlight.sc-ion-picker-ios,.picker-below-highlight.sc-ion-picker-ios{display:none;pointer-events:none}.sc-ion-picker-ios-h{--background:var(--ion-background-color, #fff);--border-width:1px 0 0;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, #c8c7cc)));--height:260px;--backdrop-opacity:var(--ion-backdrop-opacity, 0.26);color:var(--ion-item-color, var(--ion-text-color, #000))}.picker-toolbar.sc-ion-picker-ios{display:-ms-flexbox;display:flex;height:44px;border-bottom:0.55px solid var(--border-color)}.picker-toolbar-button.sc-ion-picker-ios{-ms-flex:1;flex:1;text-align:end}.picker-toolbar-button.sc-ion-picker-ios:last-child .picker-button.sc-ion-picker-ios{font-weight:600}.picker-toolbar-button.sc-ion-picker-ios:first-child{font-weight:normal;text-align:start}.picker-button.sc-ion-picker-ios,.picker-button.ion-activated.sc-ion-picker-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-padding-start:1em;padding-inline-start:1em;-webkit-padding-end:1em;padding-inline-end:1em;padding-top:0;padding-bottom:0;height:44px;background:transparent;color:var(--ion-color-primary, #3880ff);font-size:16px}.picker-columns.sc-ion-picker-ios{height:215px;-webkit-perspective:1000px;perspective:1000px}.picker-above-highlight.sc-ion-picker-ios{top:0;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);display:block;position:absolute;width:100%;height:81px;border-bottom:1px solid var(--border-color);background:-webkit-gradient(linear, left top, left bottom, color-stop(20%, var(--background, var(--ion-background-color, #fff))), to(rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8)));background:linear-gradient(to bottom, var(--background, var(--ion-background-color, #fff)) 20%, rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8) 100%);z-index:10}@supports (inset-inline-start: 0){.picker-above-highlight.sc-ion-picker-ios{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-above-highlight.sc-ion-picker-ios{left:0}[dir=rtl].sc-ion-picker-ios-h .picker-above-highlight.sc-ion-picker-ios,[dir=rtl] .sc-ion-picker-ios-h .picker-above-highlight.sc-ion-picker-ios{left:unset;right:unset;right:0}[dir=rtl].sc-ion-picker-ios .picker-above-highlight.sc-ion-picker-ios{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-above-highlight.sc-ion-picker-ios:dir(rtl){left:unset;right:unset;right:0}}}.picker-below-highlight.sc-ion-picker-ios{top:115px;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);display:block;position:absolute;width:100%;height:119px;border-top:1px solid var(--border-color);background:-webkit-gradient(linear, left bottom, left top, color-stop(30%, var(--background, var(--ion-background-color, #fff))), to(rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8)));background:linear-gradient(to top, var(--background, var(--ion-background-color, #fff)) 30%, rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8) 100%);z-index:11}@supports (inset-inline-start: 0){.picker-below-highlight.sc-ion-picker-ios{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-below-highlight.sc-ion-picker-ios{left:0}[dir=rtl].sc-ion-picker-ios-h .picker-below-highlight.sc-ion-picker-ios,[dir=rtl] .sc-ion-picker-ios-h .picker-below-highlight.sc-ion-picker-ios{left:unset;right:unset;right:0}[dir=rtl].sc-ion-picker-ios .picker-below-highlight.sc-ion-picker-ios{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-below-highlight.sc-ion-picker-ios:dir(rtl){left:unset;right:unset;right:0}}}";
|
|
@@ -1784,195 +1816,205 @@ const pickerIosCss = ".sc-ion-picker-ios-h{--border-radius:0;--border-style:soli
|
|
|
1784
1816
|
const pickerMdCss = ".sc-ion-picker-md-h{--border-radius:0;--border-style:solid;--min-width:auto;--width:100%;--max-width:500px;--min-height:auto;--max-height:auto;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;top:0;display:block;position:absolute;width:100%;height:100%;outline:none;font-family:var(--ion-font-family, inherit);contain:strict;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1001}@supports (inset-inline-start: 0){.sc-ion-picker-md-h{inset-inline-start:0}}@supports not (inset-inline-start: 0){.sc-ion-picker-md-h{left:0}[dir=rtl].sc-ion-picker-md-h,[dir=rtl] .sc-ion-picker-md-h{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.sc-ion-picker-md-h:dir(rtl){left:unset;right:unset;right:0}}}.overlay-hidden.sc-ion-picker-md-h{display:none}.picker-wrapper.sc-ion-picker-md{border-radius:var(--border-radius);left:0;right:0;bottom:0;-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:auto;margin-bottom:auto;-webkit-transform:translate3d(0, 100%, 0);transform:translate3d(0, 100%, 0);display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;overflow:hidden;z-index:10}.picker-toolbar.sc-ion-picker-md{width:100%;background:transparent;contain:strict;z-index:1}.picker-button.sc-ion-picker-md{border:0;font-family:inherit}.picker-button.sc-ion-picker-md:active,.picker-button.sc-ion-picker-md:focus{outline:none}.picker-columns.sc-ion-picker-md{display:-ms-flexbox;display:flex;position:relative;-ms-flex-pack:center;justify-content:center;margin-bottom:var(--ion-safe-area-bottom, 0);contain:strict;overflow:hidden}.picker-above-highlight.sc-ion-picker-md,.picker-below-highlight.sc-ion-picker-md{display:none;pointer-events:none}.sc-ion-picker-md-h{--background:var(--ion-background-color, #fff);--border-width:0.55px 0 0;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));--height:260px;--backdrop-opacity:var(--ion-backdrop-opacity, 0.26);color:var(--ion-item-color, var(--ion-text-color, #000))}.picker-toolbar.sc-ion-picker-md{display:-ms-flexbox;display:flex;-ms-flex-pack:end;justify-content:flex-end;height:44px}.picker-button.sc-ion-picker-md,.picker-button.ion-activated.sc-ion-picker-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-padding-start:1.1em;padding-inline-start:1.1em;-webkit-padding-end:1.1em;padding-inline-end:1.1em;padding-top:0;padding-bottom:0;height:44px;background:transparent;color:var(--ion-color-primary, #3880ff);font-size:14px;font-weight:500;text-transform:uppercase;-webkit-box-shadow:none;box-shadow:none}.picker-columns.sc-ion-picker-md{height:216px;-webkit-perspective:1800px;perspective:1800px}.picker-above-highlight.sc-ion-picker-md{top:0;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);position:absolute;width:100%;height:81px;border-bottom:1px solid var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));background:-webkit-gradient(linear, left top, left bottom, color-stop(20%, var(--ion-background-color, #fff)), to(rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8)));background:linear-gradient(to bottom, var(--ion-background-color, #fff) 20%, rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8) 100%);z-index:10}@supports (inset-inline-start: 0){.picker-above-highlight.sc-ion-picker-md{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-above-highlight.sc-ion-picker-md{left:0}[dir=rtl].sc-ion-picker-md-h .picker-above-highlight.sc-ion-picker-md,[dir=rtl] .sc-ion-picker-md-h .picker-above-highlight.sc-ion-picker-md{left:unset;right:unset;right:0}[dir=rtl].sc-ion-picker-md .picker-above-highlight.sc-ion-picker-md{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-above-highlight.sc-ion-picker-md:dir(rtl){left:unset;right:unset;right:0}}}.picker-below-highlight.sc-ion-picker-md{top:115px;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);position:absolute;width:100%;height:119px;border-top:1px solid var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));background:-webkit-gradient(linear, left bottom, left top, color-stop(30%, var(--ion-background-color, #fff)), to(rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8)));background:linear-gradient(to top, var(--ion-background-color, #fff) 30%, rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8) 100%);z-index:11}@supports (inset-inline-start: 0){.picker-below-highlight.sc-ion-picker-md{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-below-highlight.sc-ion-picker-md{left:0}[dir=rtl].sc-ion-picker-md-h .picker-below-highlight.sc-ion-picker-md,[dir=rtl] .sc-ion-picker-md-h .picker-below-highlight.sc-ion-picker-md{left:unset;right:unset;right:0}[dir=rtl].sc-ion-picker-md .picker-below-highlight.sc-ion-picker-md{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-below-highlight.sc-ion-picker-md:dir(rtl){left:unset;right:unset;right:0}}}";
|
|
1785
1817
|
|
|
1786
1818
|
const Picker = class {
|
|
1787
|
-
|
|
1788
|
-
|
|
1789
|
-
|
|
1790
|
-
|
|
1791
|
-
|
|
1792
|
-
|
|
1793
|
-
|
|
1794
|
-
|
|
1795
|
-
|
|
1796
|
-
|
|
1797
|
-
|
|
1798
|
-
|
|
1799
|
-
|
|
1800
|
-
|
|
1801
|
-
|
|
1802
|
-
|
|
1803
|
-
|
|
1804
|
-
|
|
1805
|
-
|
|
1806
|
-
|
|
1807
|
-
|
|
1808
|
-
|
|
1809
|
-
|
|
1810
|
-
|
|
1811
|
-
|
|
1812
|
-
|
|
1813
|
-
|
|
1814
|
-
|
|
1815
|
-
|
|
1816
|
-
|
|
1817
|
-
|
|
1818
|
-
|
|
1819
|
-
|
|
1820
|
-
|
|
1821
|
-
|
|
1822
|
-
|
|
1823
|
-
|
|
1824
|
-
|
|
1825
|
-
|
|
1826
|
-
|
|
1827
|
-
|
|
1828
|
-
|
|
1829
|
-
|
|
1830
|
-
|
|
1831
|
-
|
|
1832
|
-
|
|
1833
|
-
|
|
1834
|
-
|
|
1835
|
-
|
|
1836
|
-
|
|
1837
|
-
|
|
1838
|
-
|
|
1839
|
-
|
|
1840
|
-
|
|
1841
|
-
|
|
1842
|
-
|
|
1843
|
-
|
|
1844
|
-
|
|
1845
|
-
|
|
1846
|
-
|
|
1847
|
-
|
|
1848
|
-
|
|
1849
|
-
|
|
1850
|
-
|
|
1851
|
-
|
|
1852
|
-
|
|
1819
|
+
constructor(hostRef) {
|
|
1820
|
+
index$1.registerInstance(this, hostRef);
|
|
1821
|
+
this.didPresent = index$1.createEvent(this, "ionPickerDidPresent", 7);
|
|
1822
|
+
this.willPresent = index$1.createEvent(this, "ionPickerWillPresent", 7);
|
|
1823
|
+
this.willDismiss = index$1.createEvent(this, "ionPickerWillDismiss", 7);
|
|
1824
|
+
this.didDismiss = index$1.createEvent(this, "ionPickerDidDismiss", 7);
|
|
1825
|
+
this.didPresentShorthand = index$1.createEvent(this, "didPresent", 7);
|
|
1826
|
+
this.willPresentShorthand = index$1.createEvent(this, "willPresent", 7);
|
|
1827
|
+
this.willDismissShorthand = index$1.createEvent(this, "willDismiss", 7);
|
|
1828
|
+
this.didDismissShorthand = index$1.createEvent(this, "didDismiss", 7);
|
|
1829
|
+
this.delegateController = overlays.createDelegateController(this);
|
|
1830
|
+
this.lockController = lockController.createLockController();
|
|
1831
|
+
this.triggerController = overlays.createTriggerController();
|
|
1832
|
+
this.onBackdropTap = () => {
|
|
1833
|
+
this.dismiss(undefined, overlays.BACKDROP);
|
|
1834
|
+
};
|
|
1835
|
+
this.dispatchCancelHandler = (ev) => {
|
|
1836
|
+
const role = ev.detail.role;
|
|
1837
|
+
if (overlays.isCancel(role)) {
|
|
1838
|
+
const cancelButton = this.buttons.find((b) => b.role === 'cancel');
|
|
1839
|
+
this.callButtonHandler(cancelButton);
|
|
1840
|
+
}
|
|
1841
|
+
};
|
|
1842
|
+
this.presented = false;
|
|
1843
|
+
this.overlayIndex = undefined;
|
|
1844
|
+
this.delegate = undefined;
|
|
1845
|
+
this.hasController = false;
|
|
1846
|
+
this.keyboardClose = true;
|
|
1847
|
+
this.enterAnimation = undefined;
|
|
1848
|
+
this.leaveAnimation = undefined;
|
|
1849
|
+
this.buttons = [];
|
|
1850
|
+
this.columns = [];
|
|
1851
|
+
this.cssClass = undefined;
|
|
1852
|
+
this.duration = 0;
|
|
1853
|
+
this.showBackdrop = true;
|
|
1854
|
+
this.backdropDismiss = true;
|
|
1855
|
+
this.animated = true;
|
|
1856
|
+
this.htmlAttributes = undefined;
|
|
1857
|
+
this.isOpen = false;
|
|
1858
|
+
this.trigger = undefined;
|
|
1859
|
+
}
|
|
1860
|
+
onIsOpenChange(newValue, oldValue) {
|
|
1861
|
+
if (newValue === true && oldValue === false) {
|
|
1862
|
+
this.present();
|
|
1863
|
+
}
|
|
1864
|
+
else if (newValue === false && oldValue === true) {
|
|
1865
|
+
this.dismiss();
|
|
1866
|
+
}
|
|
1867
|
+
}
|
|
1868
|
+
triggerChanged() {
|
|
1869
|
+
const { trigger, el, triggerController } = this;
|
|
1870
|
+
if (trigger) {
|
|
1871
|
+
triggerController.addClickListener(el, trigger);
|
|
1872
|
+
}
|
|
1873
|
+
}
|
|
1874
|
+
connectedCallback() {
|
|
1875
|
+
overlays.prepareOverlay(this.el);
|
|
1876
|
+
this.triggerChanged();
|
|
1877
|
+
}
|
|
1878
|
+
disconnectedCallback() {
|
|
1879
|
+
this.triggerController.removeClickListener();
|
|
1880
|
+
}
|
|
1881
|
+
componentWillLoad() {
|
|
1882
|
+
overlays.setOverlayId(this.el);
|
|
1883
|
+
}
|
|
1884
|
+
componentDidLoad() {
|
|
1885
|
+
/**
|
|
1886
|
+
* If picker was rendered with isOpen="true"
|
|
1887
|
+
* then we should open picker immediately.
|
|
1888
|
+
*/
|
|
1889
|
+
if (this.isOpen === true) {
|
|
1890
|
+
helpers.raf(() => this.present());
|
|
1891
|
+
}
|
|
1892
|
+
/**
|
|
1893
|
+
* When binding values in frameworks such as Angular
|
|
1894
|
+
* it is possible for the value to be set after the Web Component
|
|
1895
|
+
* initializes but before the value watcher is set up in Stencil.
|
|
1896
|
+
* As a result, the watcher callback may not be fired.
|
|
1897
|
+
* We work around this by manually calling the watcher
|
|
1898
|
+
* callback when the component has loaded and the watcher
|
|
1899
|
+
* is configured.
|
|
1900
|
+
*/
|
|
1901
|
+
this.triggerChanged();
|
|
1902
|
+
}
|
|
1853
1903
|
/**
|
|
1854
|
-
*
|
|
1855
|
-
* then we should open picker immediately.
|
|
1904
|
+
* Present the picker overlay after it has been created.
|
|
1856
1905
|
*/
|
|
1857
|
-
|
|
1858
|
-
|
|
1859
|
-
|
|
1860
|
-
|
|
1861
|
-
|
|
1862
|
-
|
|
1863
|
-
|
|
1864
|
-
|
|
1865
|
-
|
|
1866
|
-
|
|
1867
|
-
|
|
1868
|
-
|
|
1869
|
-
|
|
1870
|
-
|
|
1871
|
-
|
|
1872
|
-
|
|
1873
|
-
|
|
1874
|
-
|
|
1875
|
-
|
|
1876
|
-
|
|
1877
|
-
|
|
1878
|
-
|
|
1879
|
-
|
|
1880
|
-
|
|
1881
|
-
|
|
1882
|
-
|
|
1883
|
-
|
|
1884
|
-
|
|
1885
|
-
|
|
1886
|
-
}
|
|
1887
|
-
|
|
1888
|
-
|
|
1889
|
-
|
|
1890
|
-
|
|
1891
|
-
|
|
1892
|
-
|
|
1893
|
-
|
|
1894
|
-
|
|
1895
|
-
|
|
1896
|
-
|
|
1897
|
-
|
|
1898
|
-
|
|
1899
|
-
|
|
1900
|
-
|
|
1901
|
-
|
|
1902
|
-
|
|
1903
|
-
|
|
1904
|
-
|
|
1905
|
-
|
|
1906
|
-
|
|
1907
|
-
|
|
1908
|
-
|
|
1909
|
-
|
|
1910
|
-
|
|
1911
|
-
|
|
1912
|
-
|
|
1913
|
-
|
|
1914
|
-
|
|
1915
|
-
|
|
1916
|
-
|
|
1917
|
-
|
|
1918
|
-
|
|
1919
|
-
|
|
1920
|
-
|
|
1921
|
-
|
|
1922
|
-
|
|
1923
|
-
|
|
1924
|
-
|
|
1925
|
-
|
|
1926
|
-
|
|
1927
|
-
|
|
1928
|
-
|
|
1929
|
-
|
|
1930
|
-
|
|
1931
|
-
|
|
1932
|
-
|
|
1933
|
-
|
|
1934
|
-
|
|
1935
|
-
|
|
1936
|
-
|
|
1937
|
-
|
|
1938
|
-
|
|
1939
|
-
|
|
1940
|
-
|
|
1941
|
-
|
|
1942
|
-
|
|
1943
|
-
|
|
1944
|
-
|
|
1945
|
-
|
|
1946
|
-
|
|
1947
|
-
|
|
1948
|
-
|
|
1949
|
-
|
|
1950
|
-
|
|
1951
|
-
|
|
1952
|
-
|
|
1953
|
-
|
|
1954
|
-
|
|
1955
|
-
|
|
1956
|
-
[`picker-${mode}`]: true, 'overlay-hidden': true }, theme.getClassMap(this.cssClass)), onIonBackdropTap: this.onBackdropTap, onIonPickerWillDismiss: this.dispatchCancelHandler }), index$1.h("ion-backdrop", { visible: this.showBackdrop, tappable: this.backdropDismiss }), index$1.h("div", { tabindex: "0" }), index$1.h("div", { class: "picker-wrapper ion-overlay-wrapper", role: "dialog" }, index$1.h("div", { class: "picker-toolbar" }, this.buttons.map((b) => (index$1.h("div", { class: buttonWrapperClass(b) }, index$1.h("button", { type: "button", onClick: () => this.buttonClick(b), class: buttonClass(b) }, b.text))))), index$1.h("div", { class: "picker-columns" }, index$1.h("div", { class: "picker-above-highlight" }), this.presented && this.columns.map((c) => index$1.h("ion-picker-column", { col: c })), index$1.h("div", { class: "picker-below-highlight" }))), index$1.h("div", { tabindex: "0" })));
|
|
1957
|
-
}
|
|
1958
|
-
get el() { return index$1.getElement(this); }
|
|
1959
|
-
static get watchers() { return {
|
|
1960
|
-
"isOpen": ["onIsOpenChange"],
|
|
1961
|
-
"trigger": ["triggerChanged"]
|
|
1962
|
-
}; }
|
|
1906
|
+
async present() {
|
|
1907
|
+
const unlock = await this.lockController.lock();
|
|
1908
|
+
await this.delegateController.attachViewToDom();
|
|
1909
|
+
await overlays.present(this, 'pickerEnter', iosEnterAnimation, iosEnterAnimation, undefined);
|
|
1910
|
+
if (this.duration > 0) {
|
|
1911
|
+
this.durationTimeout = setTimeout(() => this.dismiss(), this.duration);
|
|
1912
|
+
}
|
|
1913
|
+
unlock();
|
|
1914
|
+
}
|
|
1915
|
+
/**
|
|
1916
|
+
* Dismiss the picker overlay after it has been presented.
|
|
1917
|
+
*
|
|
1918
|
+
* @param data Any data to emit in the dismiss events.
|
|
1919
|
+
* @param role The role of the element that is dismissing the picker.
|
|
1920
|
+
* This can be useful in a button handler for determining which button was
|
|
1921
|
+
* clicked to dismiss the picker.
|
|
1922
|
+
* Some examples include: ``"cancel"`, `"destructive"`, "selected"`, and `"backdrop"`.
|
|
1923
|
+
*/
|
|
1924
|
+
async dismiss(data, role) {
|
|
1925
|
+
const unlock = await this.lockController.lock();
|
|
1926
|
+
if (this.durationTimeout) {
|
|
1927
|
+
clearTimeout(this.durationTimeout);
|
|
1928
|
+
}
|
|
1929
|
+
const dismissed = await overlays.dismiss(this, data, role, 'pickerLeave', iosLeaveAnimation, iosLeaveAnimation);
|
|
1930
|
+
if (dismissed) {
|
|
1931
|
+
this.delegateController.removeViewFromDom();
|
|
1932
|
+
}
|
|
1933
|
+
unlock();
|
|
1934
|
+
return dismissed;
|
|
1935
|
+
}
|
|
1936
|
+
/**
|
|
1937
|
+
* Returns a promise that resolves when the picker did dismiss.
|
|
1938
|
+
*/
|
|
1939
|
+
onDidDismiss() {
|
|
1940
|
+
return overlays.eventMethod(this.el, 'ionPickerDidDismiss');
|
|
1941
|
+
}
|
|
1942
|
+
/**
|
|
1943
|
+
* Returns a promise that resolves when the picker will dismiss.
|
|
1944
|
+
*/
|
|
1945
|
+
onWillDismiss() {
|
|
1946
|
+
return overlays.eventMethod(this.el, 'ionPickerWillDismiss');
|
|
1947
|
+
}
|
|
1948
|
+
/**
|
|
1949
|
+
* Get the column that matches the specified name.
|
|
1950
|
+
*
|
|
1951
|
+
* @param name The name of the column.
|
|
1952
|
+
*/
|
|
1953
|
+
getColumn(name) {
|
|
1954
|
+
return Promise.resolve(this.columns.find((column) => column.name === name));
|
|
1955
|
+
}
|
|
1956
|
+
async buttonClick(button) {
|
|
1957
|
+
const role = button.role;
|
|
1958
|
+
if (overlays.isCancel(role)) {
|
|
1959
|
+
return this.dismiss(undefined, role);
|
|
1960
|
+
}
|
|
1961
|
+
const shouldDismiss = await this.callButtonHandler(button);
|
|
1962
|
+
if (shouldDismiss) {
|
|
1963
|
+
return this.dismiss(this.getSelected(), button.role);
|
|
1964
|
+
}
|
|
1965
|
+
return Promise.resolve();
|
|
1966
|
+
}
|
|
1967
|
+
async callButtonHandler(button) {
|
|
1968
|
+
if (button) {
|
|
1969
|
+
// a handler has been provided, execute it
|
|
1970
|
+
// pass the handler the values from the inputs
|
|
1971
|
+
const rtn = await overlays.safeCall(button.handler, this.getSelected());
|
|
1972
|
+
if (rtn === false) {
|
|
1973
|
+
// if the return value of the handler is false then do not dismiss
|
|
1974
|
+
return false;
|
|
1975
|
+
}
|
|
1976
|
+
}
|
|
1977
|
+
return true;
|
|
1978
|
+
}
|
|
1979
|
+
getSelected() {
|
|
1980
|
+
const selected = {};
|
|
1981
|
+
this.columns.forEach((col, index) => {
|
|
1982
|
+
const selectedColumn = col.selectedIndex !== undefined ? col.options[col.selectedIndex] : undefined;
|
|
1983
|
+
selected[col.name] = {
|
|
1984
|
+
text: selectedColumn ? selectedColumn.text : undefined,
|
|
1985
|
+
value: selectedColumn ? selectedColumn.value : undefined,
|
|
1986
|
+
columnIndex: index,
|
|
1987
|
+
};
|
|
1988
|
+
});
|
|
1989
|
+
return selected;
|
|
1990
|
+
}
|
|
1991
|
+
render() {
|
|
1992
|
+
const { htmlAttributes } = this;
|
|
1993
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1994
|
+
return (index$1.h(index$1.Host, Object.assign({ "aria-modal": "true", tabindex: "-1" }, htmlAttributes, { style: {
|
|
1995
|
+
zIndex: `${20000 + this.overlayIndex}`,
|
|
1996
|
+
}, class: Object.assign({ [mode]: true,
|
|
1997
|
+
// Used internally for styling
|
|
1998
|
+
[`picker-${mode}`]: true, 'overlay-hidden': true }, theme.getClassMap(this.cssClass)), onIonBackdropTap: this.onBackdropTap, onIonPickerWillDismiss: this.dispatchCancelHandler }), index$1.h("ion-backdrop", { visible: this.showBackdrop, tappable: this.backdropDismiss }), index$1.h("div", { tabindex: "0" }), index$1.h("div", { class: "picker-wrapper ion-overlay-wrapper", role: "dialog" }, index$1.h("div", { class: "picker-toolbar" }, this.buttons.map((b) => (index$1.h("div", { class: buttonWrapperClass(b) }, index$1.h("button", { type: "button", onClick: () => this.buttonClick(b), class: buttonClass(b) }, b.text))))), index$1.h("div", { class: "picker-columns" }, index$1.h("div", { class: "picker-above-highlight" }), this.presented && this.columns.map((c) => index$1.h("ion-picker-column", { col: c })), index$1.h("div", { class: "picker-below-highlight" }))), index$1.h("div", { tabindex: "0" })));
|
|
1999
|
+
}
|
|
2000
|
+
get el() { return index$1.getElement(this); }
|
|
2001
|
+
static get watchers() { return {
|
|
2002
|
+
"isOpen": ["onIsOpenChange"],
|
|
2003
|
+
"trigger": ["triggerChanged"]
|
|
2004
|
+
}; }
|
|
1963
2005
|
};
|
|
1964
2006
|
const buttonWrapperClass = (button) => {
|
|
1965
|
-
|
|
1966
|
-
|
|
1967
|
-
|
|
1968
|
-
|
|
2007
|
+
return {
|
|
2008
|
+
[`picker-toolbar-${button.role}`]: button.role !== undefined,
|
|
2009
|
+
'picker-toolbar-button': true,
|
|
2010
|
+
};
|
|
1969
2011
|
};
|
|
1970
2012
|
const buttonClass = (button) => {
|
|
1971
|
-
|
|
2013
|
+
return Object.assign({ 'picker-button': true, 'ion-activatable': true }, theme.getClassMap(button.cssClass));
|
|
1972
2014
|
};
|
|
1973
2015
|
Picker.style = {
|
|
1974
|
-
|
|
1975
|
-
|
|
2016
|
+
ios: pickerIosCss,
|
|
2017
|
+
md: pickerMdCss
|
|
1976
2018
|
};
|
|
1977
2019
|
|
|
1978
2020
|
const pickerColumnIosCss = ".picker-col{display:-ms-flexbox;display:flex;position:relative;-ms-flex:1;flex:1;-ms-flex-pack:center;justify-content:center;height:100%;-webkit-box-sizing:content-box;box-sizing:content-box;contain:content}.picker-opts{position:relative;-ms-flex:1;flex:1;max-width:100%}.picker-opt{top:0;display:block;position:absolute;width:100%;border:0;text-align:center;text-overflow:ellipsis;white-space:nowrap;contain:strict;overflow:hidden;will-change:transform}@supports (inset-inline-start: 0){.picker-opt{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-opt{left:0}:host-context([dir=rtl]) .picker-opt{left:unset;right:unset;right:0}[dir=rtl] .picker-opt{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-opt:dir(rtl){left:unset;right:unset;right:0}}}.picker-opt.picker-opt-disabled{pointer-events:none}.picker-opt-disabled{opacity:0}.picker-opts-left{-ms-flex-pack:start;justify-content:flex-start}.picker-opts-right{-ms-flex-pack:end;justify-content:flex-end}.picker-opt:active,.picker-opt:focus{outline:none}.picker-prefix{position:relative;-ms-flex:1;flex:1;text-align:end;white-space:nowrap}.picker-suffix{position:relative;-ms-flex:1;flex:1;text-align:start;white-space:nowrap}.picker-col{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px;padding-top:0;padding-bottom:0;-webkit-transform-style:preserve-3d;transform-style:preserve-3d}.picker-prefix,.picker-suffix,.picker-opts{top:77px;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;color:inherit;font-size:20px;line-height:42px;pointer-events:none}.picker-opt{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-transform-origin:center center;transform-origin:center center;height:46px;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;background:transparent;color:inherit;font-size:20px;line-height:42px;-webkit-backface-visibility:hidden;backface-visibility:hidden;pointer-events:auto}:host-context([dir=rtl]) .picker-opt{-webkit-transform-origin:calc(100% - center) center;transform-origin:calc(100% - center) center}[dir=rtl] .picker-opt{-webkit-transform-origin:calc(100% - center) center;transform-origin:calc(100% - center) center}@supports selector(:dir(rtl)){.picker-opt:dir(rtl){-webkit-transform-origin:calc(100% - center) center;transform-origin:calc(100% - center) center}}";
|
|
@@ -1980,350 +2022,350 @@ const pickerColumnIosCss = ".picker-col{display:-ms-flexbox;display:flex;positio
|
|
|
1980
2022
|
const pickerColumnMdCss = ".picker-col{display:-ms-flexbox;display:flex;position:relative;-ms-flex:1;flex:1;-ms-flex-pack:center;justify-content:center;height:100%;-webkit-box-sizing:content-box;box-sizing:content-box;contain:content}.picker-opts{position:relative;-ms-flex:1;flex:1;max-width:100%}.picker-opt{top:0;display:block;position:absolute;width:100%;border:0;text-align:center;text-overflow:ellipsis;white-space:nowrap;contain:strict;overflow:hidden;will-change:transform}@supports (inset-inline-start: 0){.picker-opt{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-opt{left:0}:host-context([dir=rtl]) .picker-opt{left:unset;right:unset;right:0}[dir=rtl] .picker-opt{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-opt:dir(rtl){left:unset;right:unset;right:0}}}.picker-opt.picker-opt-disabled{pointer-events:none}.picker-opt-disabled{opacity:0}.picker-opts-left{-ms-flex-pack:start;justify-content:flex-start}.picker-opts-right{-ms-flex-pack:end;justify-content:flex-end}.picker-opt:active,.picker-opt:focus{outline:none}.picker-prefix{position:relative;-ms-flex:1;flex:1;text-align:end;white-space:nowrap}.picker-suffix{position:relative;-ms-flex:1;flex:1;text-align:start;white-space:nowrap}.picker-col{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:0;padding-bottom:0;-webkit-transform-style:preserve-3d;transform-style:preserve-3d}.picker-prefix,.picker-suffix,.picker-opts{top:77px;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;color:inherit;font-size:22px;line-height:42px;pointer-events:none}.picker-opt{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;height:43px;-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;background:transparent;color:inherit;font-size:22px;line-height:42px;-webkit-backface-visibility:hidden;backface-visibility:hidden;pointer-events:auto}.picker-prefix,.picker-suffix,.picker-opt.picker-opt-selected{color:var(--ion-color-primary, #3880ff)}";
|
|
1981
2023
|
|
|
1982
2024
|
const PickerColumnCmp = class {
|
|
1983
|
-
|
|
1984
|
-
|
|
1985
|
-
|
|
1986
|
-
|
|
1987
|
-
|
|
1988
|
-
|
|
1989
|
-
|
|
1990
|
-
|
|
1991
|
-
|
|
1992
|
-
|
|
1993
|
-
|
|
1994
|
-
|
|
1995
|
-
|
|
1996
|
-
|
|
1997
|
-
|
|
1998
|
-
|
|
1999
|
-
|
|
2000
|
-
|
|
2001
|
-
|
|
2002
|
-
|
|
2003
|
-
|
|
2004
|
-
|
|
2005
|
-
|
|
2006
|
-
|
|
2007
|
-
|
|
2008
|
-
|
|
2009
|
-
|
|
2010
|
-
|
|
2011
|
-
|
|
2012
|
-
}
|
|
2013
|
-
this.rotateFactor = pickerRotateFactor;
|
|
2014
|
-
this.scaleFactor = pickerScaleFactor;
|
|
2015
|
-
this.gesture = (await Promise.resolve().then(function () { return require('./index-0ee995e4.js'); })).createGesture({
|
|
2016
|
-
el: this.el,
|
|
2017
|
-
gestureName: 'picker-swipe',
|
|
2018
|
-
gesturePriority: 100,
|
|
2019
|
-
threshold: 0,
|
|
2020
|
-
passive: false,
|
|
2021
|
-
onStart: (ev) => this.onStart(ev),
|
|
2022
|
-
onMove: (ev) => this.onMove(ev),
|
|
2023
|
-
onEnd: (ev) => this.onEnd(ev),
|
|
2024
|
-
});
|
|
2025
|
-
this.gesture.enable();
|
|
2026
|
-
// Options have not been initialized yet
|
|
2027
|
-
// Animation must be disabled through the `noAnimate` flag
|
|
2028
|
-
// Otherwise, the options will render
|
|
2029
|
-
// at the top of the column and transition down
|
|
2030
|
-
this.tmrId = setTimeout(() => {
|
|
2031
|
-
this.noAnimate = false;
|
|
2032
|
-
// After initialization, `refresh()` will be called
|
|
2033
|
-
// At this point, animation will be enabled. The options will
|
|
2034
|
-
// animate as they are being selected.
|
|
2035
|
-
this.refresh(true);
|
|
2036
|
-
}, 250);
|
|
2037
|
-
}
|
|
2038
|
-
componentDidLoad() {
|
|
2039
|
-
this.onDomChange();
|
|
2040
|
-
}
|
|
2041
|
-
componentDidUpdate() {
|
|
2042
|
-
// Options may have changed since last update.
|
|
2043
|
-
if (this.colDidChange) {
|
|
2044
|
-
// Animation must be disabled through the `onDomChange` parameter.
|
|
2045
|
-
// Otherwise, the recently added options will render
|
|
2046
|
-
// at the top of the column and transition down
|
|
2047
|
-
this.onDomChange(true, false);
|
|
2048
|
-
this.colDidChange = false;
|
|
2049
|
-
}
|
|
2050
|
-
}
|
|
2051
|
-
disconnectedCallback() {
|
|
2052
|
-
if (this.rafId !== undefined)
|
|
2053
|
-
cancelAnimationFrame(this.rafId);
|
|
2054
|
-
if (this.tmrId)
|
|
2055
|
-
clearTimeout(this.tmrId);
|
|
2056
|
-
if (this.gesture) {
|
|
2057
|
-
this.gesture.destroy();
|
|
2058
|
-
this.gesture = undefined;
|
|
2059
|
-
}
|
|
2060
|
-
}
|
|
2061
|
-
emitColChange() {
|
|
2062
|
-
this.ionPickerColChange.emit(this.col);
|
|
2063
|
-
}
|
|
2064
|
-
setSelected(selectedIndex, duration) {
|
|
2065
|
-
// if there is a selected index, then figure out it's y position
|
|
2066
|
-
// if there isn't a selected index, then just use the top y position
|
|
2067
|
-
const y = selectedIndex > -1 ? -(selectedIndex * this.optHeight) : 0;
|
|
2068
|
-
this.velocity = 0;
|
|
2069
|
-
// set what y position we're at
|
|
2070
|
-
if (this.rafId !== undefined)
|
|
2071
|
-
cancelAnimationFrame(this.rafId);
|
|
2072
|
-
this.update(y, duration, true);
|
|
2073
|
-
this.emitColChange();
|
|
2074
|
-
}
|
|
2075
|
-
update(y, duration, saveY) {
|
|
2076
|
-
if (!this.optsEl) {
|
|
2077
|
-
return;
|
|
2078
|
-
}
|
|
2079
|
-
// ensure we've got a good round number :)
|
|
2080
|
-
let translateY = 0;
|
|
2081
|
-
let translateZ = 0;
|
|
2082
|
-
const { col, rotateFactor } = this;
|
|
2083
|
-
const prevSelected = col.selectedIndex;
|
|
2084
|
-
const selectedIndex = (col.selectedIndex = this.indexForY(-y));
|
|
2085
|
-
const durationStr = duration === 0 ? '' : duration + 'ms';
|
|
2086
|
-
const scaleStr = `scale(${this.scaleFactor})`;
|
|
2087
|
-
const children = this.optsEl.children;
|
|
2088
|
-
for (let i = 0; i < children.length; i++) {
|
|
2089
|
-
const button = children[i];
|
|
2090
|
-
const opt = col.options[i];
|
|
2091
|
-
const optOffset = i * this.optHeight + y;
|
|
2092
|
-
let transform = '';
|
|
2093
|
-
if (rotateFactor !== 0) {
|
|
2094
|
-
const rotateX = optOffset * rotateFactor;
|
|
2095
|
-
if (Math.abs(rotateX) <= 90) {
|
|
2096
|
-
translateY = 0;
|
|
2097
|
-
translateZ = 90;
|
|
2098
|
-
transform = `rotateX(${rotateX}deg) `;
|
|
2025
|
+
constructor(hostRef) {
|
|
2026
|
+
index$1.registerInstance(this, hostRef);
|
|
2027
|
+
this.ionPickerColChange = index$1.createEvent(this, "ionPickerColChange", 7);
|
|
2028
|
+
this.optHeight = 0;
|
|
2029
|
+
this.rotateFactor = 0;
|
|
2030
|
+
this.scaleFactor = 1;
|
|
2031
|
+
this.velocity = 0;
|
|
2032
|
+
this.y = 0;
|
|
2033
|
+
this.noAnimate = true;
|
|
2034
|
+
// `colDidChange` is a flag that gets set when the column is changed
|
|
2035
|
+
// dynamically. When this flag is set, the column will refresh
|
|
2036
|
+
// after the component re-renders to incorporate the new column data.
|
|
2037
|
+
// This is necessary because `this.refresh` queries for the option elements,
|
|
2038
|
+
// so it needs to wait for the latest elements to be available in the DOM.
|
|
2039
|
+
// Ex: column is created with 3 options. User updates the column data
|
|
2040
|
+
// to have 5 options. The column will still think it only has 3 options.
|
|
2041
|
+
this.colDidChange = false;
|
|
2042
|
+
this.col = undefined;
|
|
2043
|
+
}
|
|
2044
|
+
colChanged() {
|
|
2045
|
+
this.colDidChange = true;
|
|
2046
|
+
}
|
|
2047
|
+
async connectedCallback() {
|
|
2048
|
+
let pickerRotateFactor = 0;
|
|
2049
|
+
let pickerScaleFactor = 0.81;
|
|
2050
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
2051
|
+
if (mode === 'ios') {
|
|
2052
|
+
pickerRotateFactor = -0.46;
|
|
2053
|
+
pickerScaleFactor = 1;
|
|
2099
2054
|
}
|
|
2100
|
-
|
|
2101
|
-
|
|
2055
|
+
this.rotateFactor = pickerRotateFactor;
|
|
2056
|
+
this.scaleFactor = pickerScaleFactor;
|
|
2057
|
+
this.gesture = (await Promise.resolve().then(function () { return require('./index-d1b59ffa.js'); })).createGesture({
|
|
2058
|
+
el: this.el,
|
|
2059
|
+
gestureName: 'picker-swipe',
|
|
2060
|
+
gesturePriority: 100,
|
|
2061
|
+
threshold: 0,
|
|
2062
|
+
passive: false,
|
|
2063
|
+
onStart: (ev) => this.onStart(ev),
|
|
2064
|
+
onMove: (ev) => this.onMove(ev),
|
|
2065
|
+
onEnd: (ev) => this.onEnd(ev),
|
|
2066
|
+
});
|
|
2067
|
+
this.gesture.enable();
|
|
2068
|
+
// Options have not been initialized yet
|
|
2069
|
+
// Animation must be disabled through the `noAnimate` flag
|
|
2070
|
+
// Otherwise, the options will render
|
|
2071
|
+
// at the top of the column and transition down
|
|
2072
|
+
this.tmrId = setTimeout(() => {
|
|
2073
|
+
this.noAnimate = false;
|
|
2074
|
+
// After initialization, `refresh()` will be called
|
|
2075
|
+
// At this point, animation will be enabled. The options will
|
|
2076
|
+
// animate as they are being selected.
|
|
2077
|
+
this.refresh(true);
|
|
2078
|
+
}, 250);
|
|
2079
|
+
}
|
|
2080
|
+
componentDidLoad() {
|
|
2081
|
+
this.onDomChange();
|
|
2082
|
+
}
|
|
2083
|
+
componentDidUpdate() {
|
|
2084
|
+
// Options may have changed since last update.
|
|
2085
|
+
if (this.colDidChange) {
|
|
2086
|
+
// Animation must be disabled through the `onDomChange` parameter.
|
|
2087
|
+
// Otherwise, the recently added options will render
|
|
2088
|
+
// at the top of the column and transition down
|
|
2089
|
+
this.onDomChange(true, false);
|
|
2090
|
+
this.colDidChange = false;
|
|
2102
2091
|
}
|
|
2103
|
-
|
|
2104
|
-
|
|
2105
|
-
|
|
2106
|
-
|
|
2107
|
-
|
|
2108
|
-
|
|
2109
|
-
|
|
2110
|
-
|
|
2111
|
-
|
|
2112
|
-
|
|
2113
|
-
|
|
2114
|
-
|
|
2115
|
-
|
|
2116
|
-
|
|
2117
|
-
|
|
2118
|
-
|
|
2119
|
-
|
|
2120
|
-
|
|
2121
|
-
}
|
|
2122
|
-
// Update transform
|
|
2123
|
-
if (transform !== opt.transform) {
|
|
2124
|
-
opt.transform = transform;
|
|
2125
|
-
}
|
|
2126
|
-
button.style.transform = transform;
|
|
2127
|
-
/**
|
|
2128
|
-
* Ensure that the select column
|
|
2129
|
-
* item has the selected class
|
|
2130
|
-
*/
|
|
2131
|
-
opt.selected = selected;
|
|
2132
|
-
if (selected) {
|
|
2133
|
-
button.classList.add(PICKER_OPT_SELECTED);
|
|
2134
|
-
}
|
|
2135
|
-
else {
|
|
2136
|
-
button.classList.remove(PICKER_OPT_SELECTED);
|
|
2137
|
-
}
|
|
2138
|
-
}
|
|
2139
|
-
this.col.prevSelected = prevSelected;
|
|
2140
|
-
if (saveY) {
|
|
2141
|
-
this.y = y;
|
|
2142
|
-
}
|
|
2143
|
-
if (this.lastIndex !== selectedIndex) {
|
|
2144
|
-
// have not set a last index yet
|
|
2145
|
-
haptic.hapticSelectionChanged();
|
|
2146
|
-
this.lastIndex = selectedIndex;
|
|
2147
|
-
}
|
|
2148
|
-
}
|
|
2149
|
-
decelerate() {
|
|
2150
|
-
if (this.velocity !== 0) {
|
|
2151
|
-
// still decelerating
|
|
2152
|
-
this.velocity *= DECELERATION_FRICTION;
|
|
2153
|
-
// do not let it go slower than a velocity of 1
|
|
2154
|
-
this.velocity = this.velocity > 0 ? Math.max(this.velocity, 1) : Math.min(this.velocity, -1);
|
|
2155
|
-
let y = this.y + this.velocity;
|
|
2156
|
-
if (y > this.minY) {
|
|
2157
|
-
// whoops, it's trying to scroll up farther than the options we have!
|
|
2158
|
-
y = this.minY;
|
|
2159
|
-
this.velocity = 0;
|
|
2160
|
-
}
|
|
2161
|
-
else if (y < this.maxY) {
|
|
2162
|
-
// gahh, it's trying to scroll down farther than we can!
|
|
2163
|
-
y = this.maxY;
|
|
2164
|
-
this.velocity = 0;
|
|
2165
|
-
}
|
|
2166
|
-
this.update(y, 0, true);
|
|
2167
|
-
const notLockedIn = Math.round(y) % this.optHeight !== 0 || Math.abs(this.velocity) > 1;
|
|
2168
|
-
if (notLockedIn) {
|
|
2169
|
-
// isn't locked in yet, keep decelerating until it is
|
|
2170
|
-
this.rafId = requestAnimationFrame(() => this.decelerate());
|
|
2171
|
-
}
|
|
2172
|
-
else {
|
|
2092
|
+
}
|
|
2093
|
+
disconnectedCallback() {
|
|
2094
|
+
if (this.rafId !== undefined)
|
|
2095
|
+
cancelAnimationFrame(this.rafId);
|
|
2096
|
+
if (this.tmrId)
|
|
2097
|
+
clearTimeout(this.tmrId);
|
|
2098
|
+
if (this.gesture) {
|
|
2099
|
+
this.gesture.destroy();
|
|
2100
|
+
this.gesture = undefined;
|
|
2101
|
+
}
|
|
2102
|
+
}
|
|
2103
|
+
emitColChange() {
|
|
2104
|
+
this.ionPickerColChange.emit(this.col);
|
|
2105
|
+
}
|
|
2106
|
+
setSelected(selectedIndex, duration) {
|
|
2107
|
+
// if there is a selected index, then figure out it's y position
|
|
2108
|
+
// if there isn't a selected index, then just use the top y position
|
|
2109
|
+
const y = selectedIndex > -1 ? -(selectedIndex * this.optHeight) : 0;
|
|
2173
2110
|
this.velocity = 0;
|
|
2111
|
+
// set what y position we're at
|
|
2112
|
+
if (this.rafId !== undefined)
|
|
2113
|
+
cancelAnimationFrame(this.rafId);
|
|
2114
|
+
this.update(y, duration, true);
|
|
2174
2115
|
this.emitColChange();
|
|
2175
|
-
haptic.hapticSelectionEnd();
|
|
2176
|
-
}
|
|
2177
|
-
}
|
|
2178
|
-
else if (this.y % this.optHeight !== 0) {
|
|
2179
|
-
// needs to still get locked into a position so options line up
|
|
2180
|
-
const currentPos = Math.abs(this.y % this.optHeight);
|
|
2181
|
-
// create a velocity in the direction it needs to scroll
|
|
2182
|
-
this.velocity = currentPos > this.optHeight / 2 ? 1 : -1;
|
|
2183
|
-
this.decelerate();
|
|
2184
|
-
}
|
|
2185
|
-
}
|
|
2186
|
-
indexForY(y) {
|
|
2187
|
-
return Math.min(Math.max(Math.abs(Math.round(y / this.optHeight)), 0), this.col.options.length - 1);
|
|
2188
|
-
}
|
|
2189
|
-
onStart(detail) {
|
|
2190
|
-
// We have to prevent default in order to block scrolling under the picker
|
|
2191
|
-
// but we DO NOT have to stop propagation, since we still want
|
|
2192
|
-
// some "click" events to capture
|
|
2193
|
-
if (detail.event.cancelable) {
|
|
2194
|
-
detail.event.preventDefault();
|
|
2195
|
-
}
|
|
2196
|
-
detail.event.stopPropagation();
|
|
2197
|
-
haptic.hapticSelectionStart();
|
|
2198
|
-
// reset everything
|
|
2199
|
-
if (this.rafId !== undefined)
|
|
2200
|
-
cancelAnimationFrame(this.rafId);
|
|
2201
|
-
const options = this.col.options;
|
|
2202
|
-
let minY = options.length - 1;
|
|
2203
|
-
let maxY = 0;
|
|
2204
|
-
for (let i = 0; i < options.length; i++) {
|
|
2205
|
-
if (!options[i].disabled) {
|
|
2206
|
-
minY = Math.min(minY, i);
|
|
2207
|
-
maxY = Math.max(maxY, i);
|
|
2208
|
-
}
|
|
2209
|
-
}
|
|
2210
|
-
this.minY = -(minY * this.optHeight);
|
|
2211
|
-
this.maxY = -(maxY * this.optHeight);
|
|
2212
|
-
}
|
|
2213
|
-
onMove(detail) {
|
|
2214
|
-
if (detail.event.cancelable) {
|
|
2215
|
-
detail.event.preventDefault();
|
|
2216
|
-
}
|
|
2217
|
-
detail.event.stopPropagation();
|
|
2218
|
-
// update the scroll position relative to pointer start position
|
|
2219
|
-
let y = this.y + detail.deltaY;
|
|
2220
|
-
if (y > this.minY) {
|
|
2221
|
-
// scrolling up higher than scroll area
|
|
2222
|
-
y = Math.pow(y, 0.8);
|
|
2223
|
-
this.bounceFrom = y;
|
|
2224
|
-
}
|
|
2225
|
-
else if (y < this.maxY) {
|
|
2226
|
-
// scrolling down below scroll area
|
|
2227
|
-
y += Math.pow(this.maxY - y, 0.9);
|
|
2228
|
-
this.bounceFrom = y;
|
|
2229
2116
|
}
|
|
2230
|
-
|
|
2231
|
-
|
|
2232
|
-
|
|
2233
|
-
|
|
2234
|
-
|
|
2235
|
-
|
|
2236
|
-
|
|
2237
|
-
|
|
2238
|
-
|
|
2239
|
-
|
|
2240
|
-
|
|
2241
|
-
|
|
2242
|
-
|
|
2243
|
-
|
|
2244
|
-
|
|
2245
|
-
|
|
2246
|
-
|
|
2247
|
-
|
|
2248
|
-
|
|
2249
|
-
|
|
2250
|
-
|
|
2251
|
-
|
|
2252
|
-
|
|
2253
|
-
|
|
2117
|
+
update(y, duration, saveY) {
|
|
2118
|
+
if (!this.optsEl) {
|
|
2119
|
+
return;
|
|
2120
|
+
}
|
|
2121
|
+
// ensure we've got a good round number :)
|
|
2122
|
+
let translateY = 0;
|
|
2123
|
+
let translateZ = 0;
|
|
2124
|
+
const { col, rotateFactor } = this;
|
|
2125
|
+
const prevSelected = col.selectedIndex;
|
|
2126
|
+
const selectedIndex = (col.selectedIndex = this.indexForY(-y));
|
|
2127
|
+
const durationStr = duration === 0 ? '' : duration + 'ms';
|
|
2128
|
+
const scaleStr = `scale(${this.scaleFactor})`;
|
|
2129
|
+
const children = this.optsEl.children;
|
|
2130
|
+
for (let i = 0; i < children.length; i++) {
|
|
2131
|
+
const button = children[i];
|
|
2132
|
+
const opt = col.options[i];
|
|
2133
|
+
const optOffset = i * this.optHeight + y;
|
|
2134
|
+
let transform = '';
|
|
2135
|
+
if (rotateFactor !== 0) {
|
|
2136
|
+
const rotateX = optOffset * rotateFactor;
|
|
2137
|
+
if (Math.abs(rotateX) <= 90) {
|
|
2138
|
+
translateY = 0;
|
|
2139
|
+
translateZ = 90;
|
|
2140
|
+
transform = `rotateX(${rotateX}deg) `;
|
|
2141
|
+
}
|
|
2142
|
+
else {
|
|
2143
|
+
translateY = -9999;
|
|
2144
|
+
}
|
|
2145
|
+
}
|
|
2146
|
+
else {
|
|
2147
|
+
translateZ = 0;
|
|
2148
|
+
translateY = optOffset;
|
|
2149
|
+
}
|
|
2150
|
+
const selected = selectedIndex === i;
|
|
2151
|
+
transform += `translate3d(0px,${translateY}px,${translateZ}px) `;
|
|
2152
|
+
if (this.scaleFactor !== 1 && !selected) {
|
|
2153
|
+
transform += scaleStr;
|
|
2154
|
+
}
|
|
2155
|
+
// Update transition duration
|
|
2156
|
+
if (this.noAnimate) {
|
|
2157
|
+
opt.duration = 0;
|
|
2158
|
+
button.style.transitionDuration = '';
|
|
2159
|
+
}
|
|
2160
|
+
else if (duration !== opt.duration) {
|
|
2161
|
+
opt.duration = duration;
|
|
2162
|
+
button.style.transitionDuration = durationStr;
|
|
2163
|
+
}
|
|
2164
|
+
// Update transform
|
|
2165
|
+
if (transform !== opt.transform) {
|
|
2166
|
+
opt.transform = transform;
|
|
2167
|
+
}
|
|
2168
|
+
button.style.transform = transform;
|
|
2169
|
+
/**
|
|
2170
|
+
* Ensure that the select column
|
|
2171
|
+
* item has the selected class
|
|
2172
|
+
*/
|
|
2173
|
+
opt.selected = selected;
|
|
2174
|
+
if (selected) {
|
|
2175
|
+
button.classList.add(PICKER_OPT_SELECTED);
|
|
2176
|
+
}
|
|
2177
|
+
else {
|
|
2178
|
+
button.classList.remove(PICKER_OPT_SELECTED);
|
|
2179
|
+
}
|
|
2180
|
+
}
|
|
2181
|
+
this.col.prevSelected = prevSelected;
|
|
2182
|
+
if (saveY) {
|
|
2183
|
+
this.y = y;
|
|
2184
|
+
}
|
|
2185
|
+
if (this.lastIndex !== selectedIndex) {
|
|
2186
|
+
// have not set a last index yet
|
|
2187
|
+
haptic.hapticSelectionChanged();
|
|
2188
|
+
this.lastIndex = selectedIndex;
|
|
2189
|
+
}
|
|
2254
2190
|
}
|
|
2255
|
-
|
|
2256
|
-
|
|
2257
|
-
|
|
2258
|
-
|
|
2259
|
-
|
|
2260
|
-
|
|
2261
|
-
|
|
2191
|
+
decelerate() {
|
|
2192
|
+
if (this.velocity !== 0) {
|
|
2193
|
+
// still decelerating
|
|
2194
|
+
this.velocity *= DECELERATION_FRICTION;
|
|
2195
|
+
// do not let it go slower than a velocity of 1
|
|
2196
|
+
this.velocity = this.velocity > 0 ? Math.max(this.velocity, 1) : Math.min(this.velocity, -1);
|
|
2197
|
+
let y = this.y + this.velocity;
|
|
2198
|
+
if (y > this.minY) {
|
|
2199
|
+
// whoops, it's trying to scroll up farther than the options we have!
|
|
2200
|
+
y = this.minY;
|
|
2201
|
+
this.velocity = 0;
|
|
2202
|
+
}
|
|
2203
|
+
else if (y < this.maxY) {
|
|
2204
|
+
// gahh, it's trying to scroll down farther than we can!
|
|
2205
|
+
y = this.maxY;
|
|
2206
|
+
this.velocity = 0;
|
|
2207
|
+
}
|
|
2208
|
+
this.update(y, 0, true);
|
|
2209
|
+
const notLockedIn = Math.round(y) % this.optHeight !== 0 || Math.abs(this.velocity) > 1;
|
|
2210
|
+
if (notLockedIn) {
|
|
2211
|
+
// isn't locked in yet, keep decelerating until it is
|
|
2212
|
+
this.rafId = requestAnimationFrame(() => this.decelerate());
|
|
2213
|
+
}
|
|
2214
|
+
else {
|
|
2215
|
+
this.velocity = 0;
|
|
2216
|
+
this.emitColChange();
|
|
2217
|
+
haptic.hapticSelectionEnd();
|
|
2218
|
+
}
|
|
2262
2219
|
}
|
|
2263
|
-
else if (
|
|
2264
|
-
|
|
2220
|
+
else if (this.y % this.optHeight !== 0) {
|
|
2221
|
+
// needs to still get locked into a position so options line up
|
|
2222
|
+
const currentPos = Math.abs(this.y % this.optHeight);
|
|
2223
|
+
// create a velocity in the direction it needs to scroll
|
|
2224
|
+
this.velocity = currentPos > this.optHeight / 2 ? 1 : -1;
|
|
2225
|
+
this.decelerate();
|
|
2265
2226
|
}
|
|
2266
|
-
}
|
|
2267
|
-
this.decelerate();
|
|
2268
|
-
}
|
|
2269
|
-
}
|
|
2270
|
-
refresh(forceRefresh, animated) {
|
|
2271
|
-
var _a;
|
|
2272
|
-
let min = this.col.options.length - 1;
|
|
2273
|
-
let max = 0;
|
|
2274
|
-
const options = this.col.options;
|
|
2275
|
-
for (let i = 0; i < options.length; i++) {
|
|
2276
|
-
if (!options[i].disabled) {
|
|
2277
|
-
min = Math.min(min, i);
|
|
2278
|
-
max = Math.max(max, i);
|
|
2279
|
-
}
|
|
2280
2227
|
}
|
|
2281
|
-
|
|
2282
|
-
|
|
2283
|
-
|
|
2284
|
-
|
|
2285
|
-
|
|
2286
|
-
|
|
2287
|
-
|
|
2288
|
-
|
|
2289
|
-
|
|
2290
|
-
|
|
2291
|
-
|
|
2292
|
-
|
|
2293
|
-
|
|
2294
|
-
|
|
2295
|
-
|
|
2296
|
-
|
|
2297
|
-
|
|
2298
|
-
|
|
2299
|
-
|
|
2300
|
-
|
|
2301
|
-
|
|
2302
|
-
|
|
2303
|
-
|
|
2304
|
-
|
|
2305
|
-
|
|
2306
|
-
|
|
2307
|
-
|
|
2308
|
-
|
|
2309
|
-
|
|
2310
|
-
|
|
2311
|
-
|
|
2312
|
-
|
|
2313
|
-
|
|
2314
|
-
|
|
2315
|
-
|
|
2316
|
-
|
|
2317
|
-
|
|
2318
|
-
|
|
2228
|
+
indexForY(y) {
|
|
2229
|
+
return Math.min(Math.max(Math.abs(Math.round(y / this.optHeight)), 0), this.col.options.length - 1);
|
|
2230
|
+
}
|
|
2231
|
+
onStart(detail) {
|
|
2232
|
+
// We have to prevent default in order to block scrolling under the picker
|
|
2233
|
+
// but we DO NOT have to stop propagation, since we still want
|
|
2234
|
+
// some "click" events to capture
|
|
2235
|
+
if (detail.event.cancelable) {
|
|
2236
|
+
detail.event.preventDefault();
|
|
2237
|
+
}
|
|
2238
|
+
detail.event.stopPropagation();
|
|
2239
|
+
haptic.hapticSelectionStart();
|
|
2240
|
+
// reset everything
|
|
2241
|
+
if (this.rafId !== undefined)
|
|
2242
|
+
cancelAnimationFrame(this.rafId);
|
|
2243
|
+
const options = this.col.options;
|
|
2244
|
+
let minY = options.length - 1;
|
|
2245
|
+
let maxY = 0;
|
|
2246
|
+
for (let i = 0; i < options.length; i++) {
|
|
2247
|
+
if (!options[i].disabled) {
|
|
2248
|
+
minY = Math.min(minY, i);
|
|
2249
|
+
maxY = Math.max(maxY, i);
|
|
2250
|
+
}
|
|
2251
|
+
}
|
|
2252
|
+
this.minY = -(minY * this.optHeight);
|
|
2253
|
+
this.maxY = -(maxY * this.optHeight);
|
|
2254
|
+
}
|
|
2255
|
+
onMove(detail) {
|
|
2256
|
+
if (detail.event.cancelable) {
|
|
2257
|
+
detail.event.preventDefault();
|
|
2258
|
+
}
|
|
2259
|
+
detail.event.stopPropagation();
|
|
2260
|
+
// update the scroll position relative to pointer start position
|
|
2261
|
+
let y = this.y + detail.deltaY;
|
|
2262
|
+
if (y > this.minY) {
|
|
2263
|
+
// scrolling up higher than scroll area
|
|
2264
|
+
y = Math.pow(y, 0.8);
|
|
2265
|
+
this.bounceFrom = y;
|
|
2266
|
+
}
|
|
2267
|
+
else if (y < this.maxY) {
|
|
2268
|
+
// scrolling down below scroll area
|
|
2269
|
+
y += Math.pow(this.maxY - y, 0.9);
|
|
2270
|
+
this.bounceFrom = y;
|
|
2271
|
+
}
|
|
2272
|
+
else {
|
|
2273
|
+
this.bounceFrom = 0;
|
|
2274
|
+
}
|
|
2275
|
+
this.update(y, 0, false);
|
|
2276
|
+
}
|
|
2277
|
+
onEnd(detail) {
|
|
2278
|
+
if (this.bounceFrom > 0) {
|
|
2279
|
+
// bounce back up
|
|
2280
|
+
this.update(this.minY, 100, true);
|
|
2281
|
+
this.emitColChange();
|
|
2282
|
+
return;
|
|
2283
|
+
}
|
|
2284
|
+
else if (this.bounceFrom < 0) {
|
|
2285
|
+
// bounce back down
|
|
2286
|
+
this.update(this.maxY, 100, true);
|
|
2287
|
+
this.emitColChange();
|
|
2288
|
+
return;
|
|
2289
|
+
}
|
|
2290
|
+
this.velocity = helpers.clamp(-MAX_PICKER_SPEED, detail.velocityY * 23, MAX_PICKER_SPEED);
|
|
2291
|
+
if (this.velocity === 0 && detail.deltaY === 0) {
|
|
2292
|
+
const opt = detail.event.target.closest('.picker-opt');
|
|
2293
|
+
if (opt === null || opt === void 0 ? void 0 : opt.hasAttribute('opt-index')) {
|
|
2294
|
+
this.setSelected(parseInt(opt.getAttribute('opt-index'), 10), TRANSITION_DURATION);
|
|
2295
|
+
}
|
|
2296
|
+
}
|
|
2297
|
+
else {
|
|
2298
|
+
this.y += detail.deltaY;
|
|
2299
|
+
if (Math.abs(detail.velocityY) < 0.05) {
|
|
2300
|
+
const isScrollingUp = detail.deltaY > 0;
|
|
2301
|
+
const optHeightFraction = (Math.abs(this.y) % this.optHeight) / this.optHeight;
|
|
2302
|
+
if (isScrollingUp && optHeightFraction > 0.5) {
|
|
2303
|
+
this.velocity = Math.abs(this.velocity) * -1;
|
|
2304
|
+
}
|
|
2305
|
+
else if (!isScrollingUp && optHeightFraction <= 0.5) {
|
|
2306
|
+
this.velocity = Math.abs(this.velocity);
|
|
2307
|
+
}
|
|
2308
|
+
}
|
|
2309
|
+
this.decelerate();
|
|
2310
|
+
}
|
|
2311
|
+
}
|
|
2312
|
+
refresh(forceRefresh, animated) {
|
|
2313
|
+
var _a;
|
|
2314
|
+
let min = this.col.options.length - 1;
|
|
2315
|
+
let max = 0;
|
|
2316
|
+
const options = this.col.options;
|
|
2317
|
+
for (let i = 0; i < options.length; i++) {
|
|
2318
|
+
if (!options[i].disabled) {
|
|
2319
|
+
min = Math.min(min, i);
|
|
2320
|
+
max = Math.max(max, i);
|
|
2321
|
+
}
|
|
2322
|
+
}
|
|
2323
|
+
/**
|
|
2324
|
+
* Only update selected value if column has a
|
|
2325
|
+
* velocity of 0. If it does not, then the
|
|
2326
|
+
* column is animating might land on
|
|
2327
|
+
* a value different than the value at
|
|
2328
|
+
* selectedIndex
|
|
2329
|
+
*/
|
|
2330
|
+
if (this.velocity !== 0) {
|
|
2331
|
+
return;
|
|
2332
|
+
}
|
|
2333
|
+
const selectedIndex = helpers.clamp(min, (_a = this.col.selectedIndex) !== null && _a !== void 0 ? _a : 0, max);
|
|
2334
|
+
if (this.col.prevSelected !== selectedIndex || forceRefresh) {
|
|
2335
|
+
const y = selectedIndex * this.optHeight * -1;
|
|
2336
|
+
const duration = animated ? TRANSITION_DURATION : 0;
|
|
2337
|
+
this.velocity = 0;
|
|
2338
|
+
this.update(y, duration, true);
|
|
2339
|
+
}
|
|
2340
|
+
}
|
|
2341
|
+
onDomChange(forceRefresh, animated) {
|
|
2342
|
+
const colEl = this.optsEl;
|
|
2343
|
+
if (colEl) {
|
|
2344
|
+
// DOM READ
|
|
2345
|
+
// We perfom a DOM read over a rendered item, this needs to happen after the first render or after the the column has changed
|
|
2346
|
+
this.optHeight = colEl.firstElementChild ? colEl.firstElementChild.clientHeight : 0;
|
|
2347
|
+
}
|
|
2348
|
+
this.refresh(forceRefresh, animated);
|
|
2349
|
+
}
|
|
2350
|
+
render() {
|
|
2351
|
+
const col = this.col;
|
|
2352
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
2353
|
+
return (index$1.h(index$1.Host, { class: Object.assign({ [mode]: true, 'picker-col': true, 'picker-opts-left': this.col.align === 'left', 'picker-opts-right': this.col.align === 'right' }, theme.getClassMap(col.cssClass)), style: {
|
|
2354
|
+
'max-width': this.col.columnWidth,
|
|
2355
|
+
} }, col.prefix && (index$1.h("div", { class: "picker-prefix", style: { width: col.prefixWidth } }, col.prefix)), index$1.h("div", { class: "picker-opts", style: { maxWidth: col.optionsWidth }, ref: (el) => (this.optsEl = el) }, col.options.map((o, index) => (index$1.h("button", { "aria-label": o.ariaLabel, class: { 'picker-opt': true, 'picker-opt-disabled': !!o.disabled }, "opt-index": index }, o.text)))), col.suffix && (index$1.h("div", { class: "picker-suffix", style: { width: col.suffixWidth } }, col.suffix))));
|
|
2356
|
+
}
|
|
2357
|
+
get el() { return index$1.getElement(this); }
|
|
2358
|
+
static get watchers() { return {
|
|
2359
|
+
"col": ["colChanged"]
|
|
2360
|
+
}; }
|
|
2319
2361
|
};
|
|
2320
2362
|
const PICKER_OPT_SELECTED = 'picker-opt-selected';
|
|
2321
2363
|
const DECELERATION_FRICTION = 0.97;
|
|
2322
2364
|
const MAX_PICKER_SPEED = 90;
|
|
2323
2365
|
const TRANSITION_DURATION = 150;
|
|
2324
2366
|
PickerColumnCmp.style = {
|
|
2325
|
-
|
|
2326
|
-
|
|
2367
|
+
ios: pickerColumnIosCss,
|
|
2368
|
+
md: pickerColumnMdCss
|
|
2327
2369
|
};
|
|
2328
2370
|
|
|
2329
2371
|
exports.ion_datetime = Datetime;
|