voyager-ionic-core 7.5.1 → 7.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1918) hide show
  1. package/components/action-sheet.js +299 -289
  2. package/components/alert.js +477 -467
  3. package/components/animation.js +992 -976
  4. package/components/backdrop.js +56 -56
  5. package/components/button-active.js +56 -56
  6. package/components/button.js +236 -236
  7. package/components/buttons.js +29 -29
  8. package/components/capacitor.js +4 -4
  9. package/components/checkbox.js +172 -170
  10. package/components/config.js +142 -142
  11. package/components/cubic-bezier.js +49 -49
  12. package/components/data.js +1055 -1055
  13. package/components/dir.js +5 -5
  14. package/components/focus-visible.js +63 -63
  15. package/components/form-controller.js +45 -49
  16. package/components/framework-delegate.js +121 -121
  17. package/components/gesture-controller.js +182 -182
  18. package/components/haptic.js +150 -150
  19. package/components/hardware-back-button.js +48 -48
  20. package/components/helpers.js +257 -257
  21. package/components/icon.js +133 -133
  22. package/components/index.js +95 -95
  23. package/components/index2.js +163 -163
  24. package/components/index3.js +417 -417
  25. package/components/index4.js +257 -259
  26. package/components/index5.js +0 -22
  27. package/components/index6.js +3 -3
  28. package/components/index8.js +58 -59
  29. package/components/index9.js +171 -171
  30. package/components/input-shims.js +488 -475
  31. package/components/input.utils.js +107 -106
  32. package/components/ion-accordion-group.d.ts +2 -2
  33. package/components/ion-accordion-group.js +223 -213
  34. package/components/ion-accordion.d.ts +2 -2
  35. package/components/ion-accordion.js +326 -326
  36. package/components/ion-action-sheet.d.ts +2 -2
  37. package/components/ion-alert.d.ts +2 -2
  38. package/components/ion-app.d.ts +2 -2
  39. package/components/ion-app.js +93 -93
  40. package/components/ion-avatar.d.ts +2 -2
  41. package/components/ion-avatar.js +23 -23
  42. package/components/ion-back-button.d.ts +2 -2
  43. package/components/ion-back-button.js +102 -102
  44. package/components/ion-backdrop.d.ts +2 -2
  45. package/components/ion-badge.d.ts +2 -2
  46. package/components/ion-badge.js +29 -29
  47. package/components/ion-breadcrumb.d.ts +2 -2
  48. package/components/ion-breadcrumb.js +111 -111
  49. package/components/ion-breadcrumbs.d.ts +2 -2
  50. package/components/ion-breadcrumbs.js +139 -139
  51. package/components/ion-button.d.ts +2 -2
  52. package/components/ion-buttons.d.ts +2 -2
  53. package/components/ion-card-content.d.ts +2 -2
  54. package/components/ion-card-content.js +27 -27
  55. package/components/ion-card-header.d.ts +2 -2
  56. package/components/ion-card-header.js +33 -33
  57. package/components/ion-card-subtitle.d.ts +2 -2
  58. package/components/ion-card-subtitle.js +30 -30
  59. package/components/ion-card-title.d.ts +2 -2
  60. package/components/ion-card-title.js +30 -30
  61. package/components/ion-card.d.ts +2 -2
  62. package/components/ion-card.js +78 -78
  63. package/components/ion-checkbox.d.ts +2 -2
  64. package/components/ion-chip.d.ts +2 -2
  65. package/components/ion-chip.js +41 -41
  66. package/components/ion-col.d.ts +2 -2
  67. package/components/ion-col.js +156 -156
  68. package/components/ion-content.d.ts +2 -2
  69. package/components/ion-content.js +394 -394
  70. package/components/ion-datetime-button.d.ts +2 -2
  71. package/components/ion-datetime-button.js +348 -348
  72. package/components/ion-datetime.d.ts +2 -2
  73. package/components/ion-datetime.js +1722 -1684
  74. package/components/ion-fab-button.d.ts +2 -2
  75. package/components/ion-fab-button.js +109 -109
  76. package/components/ion-fab-list.d.ts +2 -2
  77. package/components/ion-fab-list.js +45 -45
  78. package/components/ion-fab.d.ts +2 -2
  79. package/components/ion-fab.js +76 -76
  80. package/components/ion-footer.d.ts +2 -2
  81. package/components/ion-footer.js +124 -124
  82. package/components/ion-grid.d.ts +2 -2
  83. package/components/ion-grid.js +27 -27
  84. package/components/ion-header.d.ts +2 -2
  85. package/components/ion-header.js +299 -299
  86. package/components/ion-img.d.ts +2 -2
  87. package/components/ion-img.js +97 -97
  88. package/components/ion-infinite-scroll-content.d.ts +2 -2
  89. package/components/ion-infinite-scroll-content.js +49 -49
  90. package/components/ion-infinite-scroll.d.ts +2 -2
  91. package/components/ion-infinite-scroll.js +187 -179
  92. package/components/ion-input.d.ts +2 -2
  93. package/components/ion-input.js +482 -450
  94. package/components/ion-item-divider.d.ts +2 -2
  95. package/components/ion-item-divider.js +36 -36
  96. package/components/ion-item-group.d.ts +2 -2
  97. package/components/ion-item-group.js +28 -28
  98. package/components/ion-item-option.d.ts +2 -2
  99. package/components/ion-item-option.js +69 -69
  100. package/components/ion-item-options.d.ts +2 -2
  101. package/components/ion-item-options.js +50 -50
  102. package/components/ion-item-sliding.d.ts +2 -2
  103. package/components/ion-item-sliding.js +404 -404
  104. package/components/ion-item.d.ts +2 -2
  105. package/components/ion-label.d.ts +2 -2
  106. package/components/ion-list-header.d.ts +2 -2
  107. package/components/ion-list.d.ts +2 -2
  108. package/components/ion-loading.d.ts +2 -2
  109. package/components/ion-loading.js +257 -247
  110. package/components/ion-menu-button.d.ts +2 -2
  111. package/components/ion-menu-button.js +77 -77
  112. package/components/ion-menu-toggle.d.ts +2 -2
  113. package/components/ion-menu-toggle.js +41 -41
  114. package/components/ion-menu.d.ts +2 -2
  115. package/components/ion-menu.js +631 -619
  116. package/components/ion-modal.d.ts +2 -2
  117. package/components/ion-modal.js +1451 -1441
  118. package/components/ion-nav-link.d.ts +2 -2
  119. package/components/ion-nav-link.js +47 -47
  120. package/components/ion-nav.d.ts +2 -2
  121. package/components/ion-nav.js +910 -910
  122. package/components/ion-note.d.ts +2 -2
  123. package/components/ion-picker-column-internal.d.ts +2 -2
  124. package/components/ion-picker-column.d.ts +2 -2
  125. package/components/ion-picker-internal.d.ts +2 -2
  126. package/components/ion-picker.d.ts +2 -2
  127. package/components/ion-picker.js +263 -253
  128. package/components/ion-popover.d.ts +2 -2
  129. package/components/ion-progress-bar.d.ts +2 -2
  130. package/components/ion-progress-bar.js +57 -57
  131. package/components/ion-radio-group.d.ts +2 -2
  132. package/components/ion-radio.d.ts +2 -2
  133. package/components/ion-range.d.ts +2 -2
  134. package/components/ion-range.js +593 -591
  135. package/components/ion-refresher-content.d.ts +2 -2
  136. package/components/ion-refresher-content.js +63 -63
  137. package/components/ion-refresher.d.ts +2 -2
  138. package/components/ion-refresher.js +747 -740
  139. package/components/ion-reorder-group.d.ts +2 -2
  140. package/components/ion-reorder-group.js +259 -259
  141. package/components/ion-reorder.d.ts +2 -2
  142. package/components/ion-reorder.js +41 -41
  143. package/components/ion-ripple-effect.d.ts +2 -2
  144. package/components/ion-route-redirect.d.ts +2 -2
  145. package/components/ion-route-redirect.js +34 -34
  146. package/components/ion-route.d.ts +2 -2
  147. package/components/ion-route.js +56 -56
  148. package/components/ion-router-link.d.ts +2 -2
  149. package/components/ion-router-link.js +45 -45
  150. package/components/ion-router-outlet.d.ts +2 -2
  151. package/components/ion-router-outlet.js +193 -193
  152. package/components/ion-router.d.ts +2 -2
  153. package/components/ion-router.js +632 -632
  154. package/components/ion-row.d.ts +2 -2
  155. package/components/ion-row.js +20 -20
  156. package/components/ion-searchbar.d.ts +2 -2
  157. package/components/ion-searchbar.js +406 -397
  158. package/components/ion-segment-button.d.ts +2 -2
  159. package/components/ion-segment-button.js +117 -117
  160. package/components/ion-segment.d.ts +2 -2
  161. package/components/ion-segment.js +427 -401
  162. package/components/ion-select-option.d.ts +2 -2
  163. package/components/ion-select-option.js +27 -27
  164. package/components/ion-select-popover.d.ts +2 -2
  165. package/components/ion-select.d.ts +2 -2
  166. package/components/ion-select.js +778 -763
  167. package/components/ion-skeleton-text.d.ts +2 -2
  168. package/components/ion-skeleton-text.js +45 -32
  169. package/components/ion-spinner.d.ts +2 -2
  170. package/components/ion-split-pane.d.ts +2 -2
  171. package/components/ion-split-pane.js +145 -145
  172. package/components/ion-tab-bar.d.ts +2 -2
  173. package/components/ion-tab-bar.js +79 -79
  174. package/components/ion-tab-button.d.ts +2 -2
  175. package/components/ion-tab-button.js +106 -106
  176. package/components/ion-tab.d.ts +2 -2
  177. package/components/ion-tab.js +72 -72
  178. package/components/ion-tabs.d.ts +2 -2
  179. package/components/ion-tabs.js +160 -160
  180. package/components/ion-text.d.ts +2 -2
  181. package/components/ion-text.js +26 -26
  182. package/components/ion-textarea.d.ts +2 -2
  183. package/components/ion-textarea.js +424 -392
  184. package/components/ion-thumbnail.d.ts +2 -2
  185. package/components/ion-thumbnail.js +20 -20
  186. package/components/ion-title.d.ts +2 -2
  187. package/components/ion-title.js +57 -57
  188. package/components/ion-toast.d.ts +2 -2
  189. package/components/ion-toast.js +819 -464
  190. package/components/ion-toggle.d.ts +2 -2
  191. package/components/ion-toggle.js +243 -241
  192. package/components/ion-toolbar.d.ts +2 -2
  193. package/components/ion-toolbar.js +71 -71
  194. package/components/ionic-global.js +163 -163
  195. package/components/ios.transition.js +598 -598
  196. package/components/item.js +301 -301
  197. package/components/keyboard-controller.js +128 -128
  198. package/components/keyboard.js +62 -62
  199. package/components/keyboard2.js +59 -59
  200. package/components/label.js +85 -85
  201. package/components/list-header.js +35 -35
  202. package/components/list.js +52 -52
  203. package/components/lock-controller.js +24 -24
  204. package/components/md.transition.js +44 -44
  205. package/components/menu-toggle-util.js +2 -2
  206. package/components/notch-controller.js +120 -120
  207. package/components/note.js +29 -29
  208. package/components/overlays.js +496 -495
  209. package/components/picker-column-internal.js +350 -345
  210. package/components/picker-column.js +334 -334
  211. package/components/picker-internal.js +470 -470
  212. package/components/popover.js +1156 -1146
  213. package/components/radio-group.js +162 -151
  214. package/components/radio.js +248 -209
  215. package/components/ripple-effect.js +81 -81
  216. package/components/select-popover.js +163 -163
  217. package/components/spinner.js +182 -182
  218. package/components/status-tap.js +26 -26
  219. package/components/swipe-back.js +65 -65
  220. package/components/theme.js +23 -23
  221. package/components/watch-options.js +37 -26
  222. package/css/core.css +66 -0
  223. package/css/core.css.map +1 -1
  224. package/css/display.css +44 -0
  225. package/css/display.css.map +1 -1
  226. package/css/float-elements.css +44 -0
  227. package/css/float-elements.css.map +1 -1
  228. package/css/global.bundle.css +88 -0
  229. package/css/global.bundle.css.map +1 -1
  230. package/css/ionic-swiper.css +22 -0
  231. package/css/ionic-swiper.css.map +1 -1
  232. package/css/ionic.bundle.css.map +1 -1
  233. package/css/padding.css +44 -0
  234. package/css/padding.css.map +1 -1
  235. package/css/structure.css +44 -0
  236. package/css/structure.css.map +1 -1
  237. package/css/text-alignment.css +44 -0
  238. package/css/text-alignment.css.map +1 -1
  239. package/css/text-transformation.css +44 -0
  240. package/css/text-transformation.css.map +1 -1
  241. package/css/typography.css +44 -0
  242. package/css/typography.css.map +1 -1
  243. package/css/utils.bundle.css +220 -0
  244. package/css/utils.bundle.css.map +1 -1
  245. package/dist/cjs/animation-9b401d39.js +1062 -0
  246. package/dist/cjs/{app-globals-fe1ad535.js → app-globals-0af482c7.js} +1 -1
  247. package/dist/cjs/button-active-a5185907.js +69 -0
  248. package/dist/cjs/{capacitor-2ffba62a.js → capacitor-c04564bf.js} +5 -5
  249. package/dist/cjs/compare-with-utils-df1001d7.js +44 -0
  250. package/dist/cjs/config-4f60b98a.js +199 -0
  251. package/dist/cjs/cubic-bezier-f2dccc53.js +92 -0
  252. package/dist/cjs/data-36b9094e.js +1622 -0
  253. package/dist/cjs/{dir-f1e0ca26.js → dir-94c21456.js} +5 -5
  254. package/dist/cjs/focus-visible-7a0ce04f.js +77 -0
  255. package/dist/cjs/form-controller-7d42a722.js +66 -0
  256. package/dist/cjs/framework-delegate-1c29b14a.js +144 -0
  257. package/dist/cjs/gesture-controller-c40c045a.js +197 -0
  258. package/dist/cjs/haptic-b882e0bb.js +212 -0
  259. package/dist/cjs/hardware-back-button-76833cac.js +76 -0
  260. package/dist/cjs/helpers-76bb7efb.js +441 -0
  261. package/dist/cjs/{index-cc7dfb7c.js → index-5915f9b3.js} +3 -3
  262. package/dist/cjs/index-b4f986cd.js +198 -0
  263. package/dist/cjs/{index-305a23dc.js → index-bbb4336c.js} +184 -63
  264. package/dist/cjs/index-c8d52405.js +10 -0
  265. package/dist/cjs/index-ce101dc9.js +308 -0
  266. package/dist/cjs/index-d1b59ffa.js +459 -0
  267. package/dist/cjs/{index-10873539.js → index-da15e99c.js} +60 -61
  268. package/dist/cjs/index-f8f13389.js +243 -0
  269. package/dist/cjs/index.cjs.js +113 -113
  270. package/dist/cjs/input-shims-a23bb0f4.js +601 -0
  271. package/dist/cjs/input.utils-3d0166a2.js +138 -0
  272. package/dist/cjs/ion-accordion_2.cjs.entry.js +491 -481
  273. package/dist/cjs/ion-action-sheet.cjs.entry.js +262 -252
  274. package/dist/cjs/ion-alert.cjs.entry.js +442 -432
  275. package/dist/cjs/ion-app_8.cjs.entry.js +1153 -1153
  276. package/dist/cjs/ion-avatar_3.cjs.entry.js +29 -29
  277. package/dist/cjs/ion-back-button.cjs.entry.js +73 -73
  278. package/dist/cjs/ion-backdrop.cjs.entry.js +40 -40
  279. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +194 -194
  280. package/dist/cjs/ion-button_2.cjs.entry.js +303 -303
  281. package/dist/cjs/ion-card_5.cjs.entry.js +105 -105
  282. package/dist/cjs/ion-checkbox.cjs.entry.js +149 -147
  283. package/dist/cjs/ion-chip.cjs.entry.js +20 -20
  284. package/dist/cjs/ion-col_3.cjs.entry.js +136 -136
  285. package/dist/cjs/ion-datetime-button.cjs.entry.js +325 -325
  286. package/dist/cjs/ion-datetime_3.cjs.entry.js +2185 -2137
  287. package/dist/cjs/ion-fab_3.cjs.entry.js +152 -152
  288. package/dist/cjs/ion-img.cjs.entry.js +79 -79
  289. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +198 -190
  290. package/dist/cjs/ion-input.cjs.entry.js +426 -394
  291. package/dist/cjs/ion-item-option_3.cjs.entry.js +459 -459
  292. package/dist/cjs/ion-item_8.cjs.entry.js +447 -434
  293. package/dist/cjs/ion-loading.cjs.entry.js +220 -210
  294. package/dist/cjs/ion-menu_3.cjs.entry.js +670 -658
  295. package/dist/cjs/ion-modal.cjs.entry.js +1415 -1405
  296. package/dist/cjs/ion-nav_2.cjs.entry.js +904 -904
  297. package/dist/cjs/ion-picker-column-internal.cjs.entry.js +331 -327
  298. package/dist/cjs/ion-picker-internal.cjs.entry.js +455 -455
  299. package/dist/cjs/ion-popover.cjs.entry.js +1110 -1100
  300. package/dist/cjs/ion-progress-bar.cjs.entry.js +40 -40
  301. package/dist/cjs/ion-radio_2.cjs.entry.js +322 -309
  302. package/dist/cjs/ion-range.cjs.entry.js +558 -556
  303. package/dist/cjs/ion-refresher_2.cjs.entry.js +786 -779
  304. package/dist/cjs/ion-reorder_2.cjs.entry.js +269 -269
  305. package/dist/cjs/ion-ripple-effect.cjs.entry.js +66 -66
  306. package/dist/cjs/ion-route_4.cjs.entry.js +693 -693
  307. package/dist/cjs/ion-searchbar.cjs.entry.js +363 -354
  308. package/dist/cjs/ion-segment_2.cjs.entry.js +509 -483
  309. package/dist/cjs/ion-select_3.cjs.entry.js +784 -768
  310. package/dist/cjs/ion-spinner.cjs.entry.js +46 -46
  311. package/dist/cjs/ion-split-pane.cjs.entry.js +117 -117
  312. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +142 -142
  313. package/dist/cjs/ion-tab_2.cjs.entry.js +187 -187
  314. package/dist/cjs/ion-text.cjs.entry.js +13 -13
  315. package/dist/cjs/ion-textarea.cjs.entry.js +381 -349
  316. package/dist/cjs/ion-toast.cjs.entry.js +771 -419
  317. package/dist/cjs/ion-toggle.cjs.entry.js +227 -225
  318. package/dist/cjs/ionic-global-f4a2093b.js +230 -0
  319. package/dist/cjs/ionic.cjs.js +5 -5
  320. package/dist/cjs/ios.transition-6787b799.js +654 -0
  321. package/dist/cjs/keyboard-0272231f.js +81 -0
  322. package/dist/cjs/{keyboard-38f2bb7b.js → keyboard-af1bb365.js} +62 -62
  323. package/dist/cjs/keyboard-controller-c05e747a.js +167 -0
  324. package/dist/cjs/loader.cjs.js +4 -4
  325. package/dist/cjs/lock-controller-6585a42a.js +40 -0
  326. package/dist/cjs/md.transition-e033d20a.js +59 -0
  327. package/dist/cjs/notch-controller-9735e7ac.js +155 -0
  328. package/dist/cjs/overlays-27a6fb16.js +716 -0
  329. package/dist/cjs/spinner-configs-282fd50a.js +147 -0
  330. package/dist/cjs/status-tap-415acac6.js +42 -0
  331. package/dist/cjs/swipe-back-e37a1a5c.js +81 -0
  332. package/dist/cjs/theme-d1c573d2.js +48 -0
  333. package/dist/cjs/watch-options-f5f3e158.js +49 -0
  334. package/dist/collection/collection-manifest.json +7 -7
  335. package/dist/collection/components/accordion/accordion.ios.css +44 -0
  336. package/dist/collection/components/accordion/accordion.js +410 -410
  337. package/dist/collection/components/accordion/accordion.md.css +22 -0
  338. package/dist/collection/components/accordion/test/a11y/accordion.e2e.js +31 -31
  339. package/dist/collection/components/accordion/test/accordion.e2e.js +24 -24
  340. package/dist/collection/components/accordion/test/accordion.spec.js +195 -0
  341. package/dist/collection/components/accordion/test/basic/accordion.e2e.js +26 -26
  342. package/dist/collection/components/accordion/test/multiple/accordion.e2e.js +18 -18
  343. package/dist/collection/components/accordion/test/nested/accordion.e2e.js +16 -16
  344. package/dist/collection/components/accordion/test/standalone/accordion.e2e.js +6 -6
  345. package/dist/collection/components/accordion-group/accordion-group.ios.css +44 -0
  346. package/dist/collection/components/accordion-group/accordion-group.js +422 -412
  347. package/dist/collection/components/accordion-group/accordion-group.md.css +68 -2
  348. package/dist/collection/components/action-sheet/action-sheet.ios.css +62 -5
  349. package/dist/collection/components/action-sheet/action-sheet.js +739 -729
  350. package/dist/collection/components/action-sheet/action-sheet.md.css +62 -5
  351. package/dist/collection/components/action-sheet/animations/ios.enter.js +18 -18
  352. package/dist/collection/components/action-sheet/animations/ios.leave.js +12 -12
  353. package/dist/collection/components/action-sheet/animations/md.enter.js +18 -18
  354. package/dist/collection/components/action-sheet/animations/md.leave.js +12 -12
  355. package/dist/collection/components/action-sheet/test/a11y/action-sheet.e2e.js +59 -59
  356. package/dist/collection/components/action-sheet/test/action-sheet-id.spec.js +32 -0
  357. package/dist/collection/components/action-sheet/test/basic/action-sheet-rendering.e2e.js +33 -33
  358. package/dist/collection/components/action-sheet/test/basic/action-sheet.e2e.js +118 -59
  359. package/dist/collection/components/action-sheet/test/basic/action-sheet.spec.js +18 -0
  360. package/dist/collection/components/action-sheet/test/basic/fixture.js +23 -23
  361. package/dist/collection/components/action-sheet/test/is-open/action-sheet.e2e.js +25 -25
  362. package/dist/collection/components/action-sheet/test/translucent/action-sheet.e2e.js +10 -10
  363. package/dist/collection/components/action-sheet/test/trigger/action-sheet.e2e.js +21 -21
  364. package/dist/collection/components/alert/alert.ios.css +122 -5
  365. package/dist/collection/components/alert/alert.js +977 -967
  366. package/dist/collection/components/alert/alert.md.css +152 -7
  367. package/dist/collection/components/alert/animations/ios.enter.js +19 -19
  368. package/dist/collection/components/alert/animations/ios.leave.js +13 -13
  369. package/dist/collection/components/alert/animations/md.enter.js +19 -19
  370. package/dist/collection/components/alert/animations/md.leave.js +10 -10
  371. package/dist/collection/components/alert/test/a11y/alert.e2e.js +139 -91
  372. package/dist/collection/components/alert/test/alert-id.spec.js +32 -0
  373. package/dist/collection/components/alert/test/alert.spec.js +37 -0
  374. package/dist/collection/components/alert/test/basic/alert-tablet.e2e.js +40 -0
  375. package/dist/collection/components/alert/test/basic/alert.e2e.js +96 -96
  376. package/dist/collection/components/alert/test/is-open/alert.e2e.js +25 -25
  377. package/dist/collection/components/alert/test/standalone/alert.e2e.js +9 -9
  378. package/dist/collection/components/alert/test/trigger/alert.e2e.js +21 -21
  379. package/dist/collection/components/app/app.js +116 -116
  380. package/dist/collection/components/app/test/safe-area/app.e2e.js +24 -24
  381. package/dist/collection/components/avatar/avatar.ios.css +44 -0
  382. package/dist/collection/components/avatar/avatar.js +17 -17
  383. package/dist/collection/components/avatar/avatar.md.css +44 -0
  384. package/dist/collection/components/avatar/test/basic/avatar.e2e.js +12 -12
  385. package/dist/collection/components/back-button/back-button.ios.css +44 -0
  386. package/dist/collection/components/back-button/back-button.js +214 -214
  387. package/dist/collection/components/back-button/back-button.md.css +44 -0
  388. package/dist/collection/components/back-button/test/a11y/back-button.e2e.js +6 -6
  389. package/dist/collection/components/back-button/test/back-button.spec.js +86 -0
  390. package/dist/collection/components/back-button/test/basic/back-button.e2e.js +6 -6
  391. package/dist/collection/components/back-button/test/toolbar/back-button.e2e.js +6 -6
  392. package/dist/collection/components/backdrop/backdrop.ios.css +44 -0
  393. package/dist/collection/components/backdrop/backdrop.js +131 -131
  394. package/dist/collection/components/backdrop/backdrop.md.css +44 -0
  395. package/dist/collection/components/badge/badge.ios.css +44 -0
  396. package/dist/collection/components/badge/badge.js +49 -49
  397. package/dist/collection/components/badge/badge.md.css +44 -0
  398. package/dist/collection/components/badge/test/a11y/badge.e2e.js +6 -6
  399. package/dist/collection/components/badge/test/basic/badge.e2e.js +6 -6
  400. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +44 -0
  401. package/dist/collection/components/breadcrumb/breadcrumb.js +395 -395
  402. package/dist/collection/components/breadcrumb/breadcrumb.md.css +44 -0
  403. package/dist/collection/components/breadcrumb/test/aria.spec.js +22 -0
  404. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +22 -0
  405. package/dist/collection/components/breadcrumbs/breadcrumbs.js +247 -247
  406. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +22 -0
  407. package/dist/collection/components/breadcrumbs/test/a11y/breadcrumbs.e2e.js +12 -12
  408. package/dist/collection/components/breadcrumbs/test/basic/breadcrumbs.e2e.js +6 -6
  409. package/dist/collection/components/breadcrumbs/test/breadcrumbs.spec.js +58 -0
  410. package/dist/collection/components/breadcrumbs/test/collapsed/breadcrumbs.e2e.js +6 -6
  411. package/dist/collection/components/breadcrumbs/test/reactive/breadcrumbs.e2e.js +43 -43
  412. package/dist/collection/components/button/button.ios.css +66 -0
  413. package/dist/collection/components/button/button.js +541 -541
  414. package/dist/collection/components/button/button.md.css +44 -0
  415. package/dist/collection/components/button/test/a11y/button.e2e.js +21 -21
  416. package/dist/collection/components/button/test/basic/button.e2e.js +32 -32
  417. package/dist/collection/components/button/test/clear/button.e2e.js +6 -6
  418. package/dist/collection/components/button/test/expand/button.e2e.js +6 -6
  419. package/dist/collection/components/button/test/form-reference/button.e2e.js +84 -84
  420. package/dist/collection/components/button/test/form-reference/button.spec.js +26 -0
  421. package/dist/collection/components/button/test/icon/button.e2e.js +6 -6
  422. package/dist/collection/components/button/test/outline/button.e2e.js +6 -6
  423. package/dist/collection/components/button/test/round/button.e2e.js +6 -6
  424. package/dist/collection/components/button/test/size/button.e2e.js +22 -22
  425. package/dist/collection/components/button/test/strong/button.e2e.js +22 -22
  426. package/dist/collection/components/button/test/wrap/button.e2e.js +73 -73
  427. package/dist/collection/components/buttons/buttons.ios.css +66 -0
  428. package/dist/collection/components/buttons/buttons.js +46 -46
  429. package/dist/collection/components/buttons/buttons.md.css +66 -0
  430. package/dist/collection/components/buttons/test/a11y/buttons.e2e.js +21 -21
  431. package/dist/collection/components/card/card.ios.css +44 -0
  432. package/dist/collection/components/card/card.js +251 -251
  433. package/dist/collection/components/card/card.md.css +44 -0
  434. package/dist/collection/components/card/test/a11y/card.e2e.js +6 -6
  435. package/dist/collection/components/card/test/aria.spec.js +16 -0
  436. package/dist/collection/components/card/test/basic/card.e2e.js +38 -38
  437. package/dist/collection/components/card-content/card-content.ios.css +44 -0
  438. package/dist/collection/components/card-content/card-content.js +21 -21
  439. package/dist/collection/components/card-content/card-content.md.css +44 -0
  440. package/dist/collection/components/card-header/card-header.ios.css +44 -0
  441. package/dist/collection/components/card-header/card-header.js +70 -70
  442. package/dist/collection/components/card-header/card-header.md.css +44 -0
  443. package/dist/collection/components/card-header/test/basic/card-header.e2e.js +6 -6
  444. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +44 -0
  445. package/dist/collection/components/card-subtitle/card-subtitle.js +50 -50
  446. package/dist/collection/components/card-subtitle/card-subtitle.md.css +44 -0
  447. package/dist/collection/components/card-title/card-title.ios.css +44 -0
  448. package/dist/collection/components/card-title/card-title.js +50 -50
  449. package/dist/collection/components/card-title/card-title.md.css +44 -0
  450. package/dist/collection/components/checkbox/checkbox.ios.css +69 -9
  451. package/dist/collection/components/checkbox/checkbox.js +418 -415
  452. package/dist/collection/components/checkbox/checkbox.md.css +69 -9
  453. package/dist/collection/components/checkbox/test/a11y/checkbox.e2e.js +14 -14
  454. package/dist/collection/components/checkbox/test/basic/checkbox.e2e.js +50 -50
  455. package/dist/collection/components/checkbox/test/checkbox.spec.js +34 -0
  456. package/dist/collection/components/checkbox/test/color/checkbox.e2e.js +11 -11
  457. package/dist/collection/components/checkbox/test/indeterminate/checkbox.e2e.js +6 -6
  458. package/dist/collection/components/checkbox/test/item/checkbox.e2e.js +29 -29
  459. package/dist/collection/components/checkbox/test/label/checkbox.e2e.js +75 -75
  460. package/dist/collection/components/checkbox/test/legacy/basic/checkbox.e2e.js +45 -45
  461. package/dist/collection/components/checkbox/test/legacy/indeterminate/checkbox.e2e.js +6 -6
  462. package/dist/collection/components/checkbox/test/states/checkbox.e2e.js +21 -21
  463. package/dist/collection/components/chip/chip.ios.css +22 -0
  464. package/dist/collection/components/chip/chip.js +90 -90
  465. package/dist/collection/components/chip/chip.md.css +22 -0
  466. package/dist/collection/components/chip/test/a11y/chip.e2e.js +19 -19
  467. package/dist/collection/components/chip/test/basic/chip.e2e.js +42 -42
  468. package/dist/collection/components/chip/test/states/chip.e2e.js +14 -14
  469. package/dist/collection/components/col/col.css +66 -0
  470. package/dist/collection/components/col/col.js +536 -536
  471. package/dist/collection/components/content/content.css +22 -0
  472. package/dist/collection/components/content/content.js +745 -745
  473. package/dist/collection/components/content/test/basic/content.e2e.js +6 -6
  474. package/dist/collection/components/content/test/fixed/content.e2e.js +6 -6
  475. package/dist/collection/components/content/test/fullscreen/content.e2e.js +6 -6
  476. package/dist/collection/components/content/test/standalone/content.e2e.js +5 -5
  477. package/dist/collection/components/datetime/datetime.ios.css +69 -4
  478. package/dist/collection/components/datetime/datetime.js +2246 -2208
  479. package/dist/collection/components/datetime/datetime.md.css +69 -8
  480. package/dist/collection/components/datetime/test/a11y/datetime.e2e.js +73 -7
  481. package/dist/collection/components/datetime/test/a11y/datetime.spec.js +43 -0
  482. package/dist/collection/components/datetime/test/basic/datetime.e2e.js +241 -241
  483. package/dist/collection/components/datetime/test/color/datetime.e2e.js +9 -9
  484. package/dist/collection/components/datetime/test/comparison.spec.js +43 -0
  485. package/dist/collection/components/datetime/test/custom/datetime.e2e.js +37 -37
  486. package/dist/collection/components/datetime/test/data.spec.js +456 -0
  487. package/dist/collection/components/datetime/test/datetime.e2e.js +29 -29
  488. package/dist/collection/components/datetime/test/disable-dates/datetime.e2e.js +119 -119
  489. package/dist/collection/components/datetime/test/disabled/datetime.e2e.js +68 -0
  490. package/dist/collection/components/datetime/test/disabled/datetime.spec.js +33 -0
  491. package/dist/collection/components/datetime/test/display/datetime.e2e.js +86 -86
  492. package/dist/collection/components/datetime/test/first-day-of-week/datetime.e2e.js +6 -6
  493. package/dist/collection/components/datetime/test/format.spec.js +124 -0
  494. package/dist/collection/components/datetime/test/helpers.spec.js +72 -0
  495. package/dist/collection/components/datetime/test/highlighted-dates/datetime.e2e.js +76 -76
  496. package/dist/collection/components/datetime/test/hour-cycle/datetime.e2e.js +21 -21
  497. package/dist/collection/components/datetime/test/locale/datetime.e2e.js +98 -98
  498. package/dist/collection/components/datetime/test/manipulation.spec.js +433 -0
  499. package/dist/collection/components/datetime/test/minmax/datetime.e2e.js +178 -178
  500. package/dist/collection/components/datetime/test/month-year-picker/datetime.e2e.js +17 -17
  501. package/dist/collection/components/datetime/test/multiple/datetime.e2e.js +170 -170
  502. package/dist/collection/components/datetime/test/parse.spec.js +222 -0
  503. package/dist/collection/components/datetime/test/position/datetime.e2e.js +14 -14
  504. package/dist/collection/components/datetime/test/prefer-wheel/datetime.e2e.js +263 -263
  505. package/dist/collection/components/datetime/test/presentation/datetime.e2e.js +137 -137
  506. package/dist/collection/components/datetime/test/readonly/datetime.e2e.js +113 -0
  507. package/dist/collection/components/datetime/test/set-value/datetime.e2e.js +40 -40
  508. package/dist/collection/components/datetime/test/state.spec.js +114 -0
  509. package/dist/collection/components/datetime/test/time-label/datetime.e2e.js +13 -13
  510. package/dist/collection/components/datetime/test/values/datetime.e2e.js +77 -77
  511. package/dist/collection/components/datetime/utils/comparison.js +22 -22
  512. package/dist/collection/components/datetime/utils/data.js +394 -394
  513. package/dist/collection/components/datetime/utils/format.js +143 -143
  514. package/dist/collection/components/datetime/utils/helpers.js +74 -74
  515. package/dist/collection/components/datetime/utils/manipulation.js +274 -274
  516. package/dist/collection/components/datetime/utils/parse.js +139 -139
  517. package/dist/collection/components/datetime/utils/state.js +123 -123
  518. package/dist/collection/components/datetime-button/datetime-button.css +22 -0
  519. package/dist/collection/components/datetime-button/datetime-button.js +399 -399
  520. package/dist/collection/components/datetime-button/test/a11y/datetime-button.e2e.js +11 -11
  521. package/dist/collection/components/datetime-button/test/basic/datetime-button.e2e.js +123 -123
  522. package/dist/collection/components/datetime-button/test/disabled/datetime-button.e2e.js +13 -13
  523. package/dist/collection/components/datetime-button/test/multiple/datetime-button.e2e.js +38 -38
  524. package/dist/collection/components/datetime-button/test/overlays/datetime-button.e2e.js +102 -102
  525. package/dist/collection/components/fab/fab.css +112 -36
  526. package/dist/collection/components/fab/fab.js +179 -179
  527. package/dist/collection/components/fab/test/basic/fab.e2e.js +50 -50
  528. package/dist/collection/components/fab/test/custom-size/fab.e2e.js +6 -6
  529. package/dist/collection/components/fab/test/safe-area/fab.e2e.js +63 -0
  530. package/dist/collection/components/fab/test/states/fab.e2e.js +6 -6
  531. package/dist/collection/components/fab/test/translucent/fab.e2e.js +17 -17
  532. package/dist/collection/components/fab-button/fab-button.ios.css +44 -0
  533. package/dist/collection/components/fab-button/fab-button.js +374 -374
  534. package/dist/collection/components/fab-button/fab-button.md.css +44 -0
  535. package/dist/collection/components/fab-button/test/a11y/fab-button.e2e.js +6 -6
  536. package/dist/collection/components/fab-list/fab-list.css +46 -2
  537. package/dist/collection/components/fab-list/fab-list.js +79 -79
  538. package/dist/collection/components/footer/footer.ios.css +44 -0
  539. package/dist/collection/components/footer/footer.js +135 -135
  540. package/dist/collection/components/footer/footer.md.css +44 -0
  541. package/dist/collection/components/footer/footer.utils.js +25 -25
  542. package/dist/collection/components/footer/test/basic/footer.e2e.js +18 -18
  543. package/dist/collection/components/footer/test/fade/footer.e2e.js +10 -10
  544. package/dist/collection/components/footer/test/scroll-target/footer.e2e.js +15 -15
  545. package/dist/collection/components/footer/test/with-tabs/footer.e2e.js +6 -6
  546. package/dist/collection/components/grid/grid.css +66 -0
  547. package/dist/collection/components/grid/grid.js +44 -44
  548. package/dist/collection/components/grid/test/basic/grid.e2e.js +6 -6
  549. package/dist/collection/components/grid/test/offsets/grid.e2e.js +6 -6
  550. package/dist/collection/components/grid/test/padding/grid.e2e.js +6 -6
  551. package/dist/collection/components/grid/test/sizes/grid.e2e.js +6 -6
  552. package/dist/collection/components/header/header.ios.css +48 -1
  553. package/dist/collection/components/header/header.js +181 -181
  554. package/dist/collection/components/header/header.md.css +44 -0
  555. package/dist/collection/components/header/header.utils.js +148 -148
  556. package/dist/collection/components/header/test/a11y/header.e2e.js +18 -18
  557. package/dist/collection/components/header/test/basic/header.e2e.js +23 -23
  558. package/dist/collection/components/header/test/condense/header.e2e.js +25 -25
  559. package/dist/collection/components/header/test/fade/header.e2e.js +10 -10
  560. package/dist/collection/components/header/test/scroll-target/header.e2e.js +15 -15
  561. package/dist/collection/components/icon/test/basic/icon.e2e.js +6 -6
  562. package/dist/collection/components/icon/test/dir/icon.e2e.js +11 -11
  563. package/dist/collection/components/img/img.js +177 -177
  564. package/dist/collection/components/img/test/basic/img.e2e.js +62 -62
  565. package/dist/collection/components/img/test/draggable/img.e2e.js +10 -10
  566. package/dist/collection/components/infinite-scroll/infinite-scroll.js +279 -271
  567. package/dist/collection/components/infinite-scroll/test/basic/infinite-scroll.e2e.js +11 -11
  568. package/dist/collection/components/infinite-scroll/test/scroll-target/infinite-scroll.e2e.js +11 -11
  569. package/dist/collection/components/infinite-scroll/test/small-dom-update/infinite-scroll.e2e.js +31 -0
  570. package/dist/collection/components/infinite-scroll/test/top/infinite-scroll.e2e.js +11 -11
  571. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +44 -0
  572. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +86 -86
  573. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +44 -0
  574. package/dist/collection/components/infinite-scroll-content/test/infinite-scroll-content.spec.js +37 -0
  575. package/dist/collection/components/input/input.ios.css +91 -18
  576. package/dist/collection/components/input/input.js +1234 -1200
  577. package/dist/collection/components/input/input.md.css +167 -22
  578. package/dist/collection/components/input/input.utils.js +22 -22
  579. package/dist/collection/components/input/test/a11y/input.e2e.js +12 -12
  580. package/dist/collection/components/input/test/basic/input.e2e.js +63 -63
  581. package/dist/collection/components/input/test/bottom-content/input.e2e.js +89 -89
  582. package/dist/collection/components/input/test/card/input.e2e.js +6 -6
  583. package/dist/collection/components/input/test/clear-on-edit/input.e2e.js +25 -25
  584. package/dist/collection/components/input/test/color/input.e2e.js +88 -88
  585. package/dist/collection/components/input/test/fill/input.e2e.js +63 -63
  586. package/dist/collection/components/input/test/highlight/input.e2e.js +52 -52
  587. package/dist/collection/components/input/test/input.e2e.js +6 -6
  588. package/dist/collection/components/input/test/input.spec.js +85 -0
  589. package/dist/collection/components/input/test/item/input.e2e.js +11 -11
  590. package/dist/collection/components/input/test/item/input.spec.js +24 -0
  591. package/dist/collection/components/input/test/label-placement/input.e2e.js +104 -104
  592. package/dist/collection/components/input/test/legacy/a11y/input.e2e.js +15 -15
  593. package/dist/collection/components/input/test/legacy/basic/input.e2e.js +102 -102
  594. package/dist/collection/components/input/test/legacy/clear-on-edit/input.e2e.js +44 -44
  595. package/dist/collection/components/input/test/legacy/input-events.e2e.js +56 -56
  596. package/dist/collection/components/input/test/legacy/masking/input.e2e.js +15 -15
  597. package/dist/collection/components/input/test/legacy/spec/input.e2e.js +8 -8
  598. package/dist/collection/components/input/test/slot/input.e2e.js +51 -0
  599. package/dist/collection/components/input/test/states/input.e2e.js +11 -11
  600. package/dist/collection/components/item/item.ios.css +145 -15
  601. package/dist/collection/components/item/item.js +614 -614
  602. package/dist/collection/components/item/item.md.css +192 -18
  603. package/dist/collection/components/item/test/a11y/item.e2e.js +47 -47
  604. package/dist/collection/components/item/test/a11y/item.spec.js +48 -0
  605. package/dist/collection/components/item/test/alignment/item.e2e.js +6 -6
  606. package/dist/collection/components/item/test/basic/item.e2e.js +32 -6
  607. package/dist/collection/components/item/test/buttons/item.e2e.js +18 -18
  608. package/dist/collection/components/item/test/colors/item.e2e.js +6 -6
  609. package/dist/collection/components/item/test/counter/item.e2e.js +34 -34
  610. package/dist/collection/components/item/test/css-variables/item.e2e.js +6 -6
  611. package/dist/collection/components/item/test/disabled/item.e2e.js +6 -7
  612. package/dist/collection/components/item/test/dividers/item.e2e.js +6 -6
  613. package/dist/collection/components/item/test/groups/item.e2e.js +8 -8
  614. package/dist/collection/components/item/test/highlight/item.e2e.js +6 -6
  615. package/dist/collection/components/item/test/icons/item.e2e.js +6 -6
  616. package/dist/collection/components/item/test/images/item.e2e.js +6 -6
  617. package/dist/collection/components/item/test/inputs/item.e2e.js +139 -139
  618. package/dist/collection/components/item/test/legacy/alignment/item.e2e.js +6 -6
  619. package/dist/collection/components/item/test/legacy/disabled/item.e2e.js +6 -6
  620. package/dist/collection/components/item/test/legacy/fill/item.e2e.js +6 -6
  621. package/dist/collection/components/item/test/legacy/form/item.e2e.js +6 -6
  622. package/dist/collection/components/item/test/lines/item.e2e.js +6 -6
  623. package/dist/collection/components/item/test/media/item.e2e.js +6 -6
  624. package/dist/collection/components/item/test/reorder/item.e2e.js +8 -8
  625. package/dist/collection/components/item/test/slotted-inputs/item.e2e.js +6 -6
  626. package/dist/collection/components/item/test/states/item.e2e.js +6 -6
  627. package/dist/collection/components/item-divider/item-divider.ios.css +101 -8
  628. package/dist/collection/components/item-divider/item-divider.js +71 -71
  629. package/dist/collection/components/item-divider/item-divider.md.css +101 -8
  630. package/dist/collection/components/item-divider/test/a11y/item-divider.e2e.js +11 -11
  631. package/dist/collection/components/item-divider/test/basic/item-divider.e2e.js +38 -16
  632. package/dist/collection/components/item-divider/test/spec/item-divider.e2e.js +8 -8
  633. package/dist/collection/components/item-group/item-group.ios.css +44 -0
  634. package/dist/collection/components/item-group/item-group.js +22 -22
  635. package/dist/collection/components/item-group/item-group.md.css +44 -0
  636. package/dist/collection/components/item-option/item-option.ios.css +44 -10
  637. package/dist/collection/components/item-option/item-option.js +197 -197
  638. package/dist/collection/components/item-option/item-option.md.css +44 -10
  639. package/dist/collection/components/item-options/item-options.ios.css +66 -0
  640. package/dist/collection/components/item-options/item-options.js +110 -110
  641. package/dist/collection/components/item-options/item-options.md.css +66 -0
  642. package/dist/collection/components/item-sliding/item-sliding.css +22 -0
  643. package/dist/collection/components/item-sliding/item-sliding.js +538 -538
  644. package/dist/collection/components/item-sliding/test/a11y/item-sliding.e2e.js +5 -5
  645. package/dist/collection/components/item-sliding/test/async/item-sliding.e2e.js +25 -25
  646. package/dist/collection/components/item-sliding/test/basic/item-sliding.e2e.js +140 -63
  647. package/dist/collection/components/item-sliding/test/icons/item-sliding.e2e.js +20 -20
  648. package/dist/collection/components/item-sliding/test/scroll-target/item-sliding.e2e.js +18 -18
  649. package/dist/collection/components/item-sliding/test/test.utils.js +20 -20
  650. package/dist/collection/components/label/label.ios.css +81 -4
  651. package/dist/collection/components/label/label.js +174 -174
  652. package/dist/collection/components/label/label.md.css +80 -3
  653. package/dist/collection/components/label/test/a11y/label.e2e.js +21 -21
  654. package/dist/collection/components/label/test/basic/label.e2e.js +21 -21
  655. package/dist/collection/components/label/test/color/label.e2e.js +21 -21
  656. package/dist/collection/components/label/test/headings/label.e2e.js +5 -5
  657. package/dist/collection/components/list/list.ios.css +81 -1
  658. package/dist/collection/components/list/list.js +101 -101
  659. package/dist/collection/components/list/list.md.css +107 -3
  660. package/dist/collection/components/list/test/a11y/list.e2e.js +6 -6
  661. package/dist/collection/components/list/test/basic/list.e2e.js +6 -6
  662. package/dist/collection/components/list/test/inset/list.e2e.js +16 -16
  663. package/dist/collection/components/list/test/lines/list.e2e.js +158 -15
  664. package/dist/collection/components/list-header/list-header.ios.css +81 -2
  665. package/dist/collection/components/list-header/list-header.js +69 -69
  666. package/dist/collection/components/list-header/list-header.md.css +81 -2
  667. package/dist/collection/components/list-header/test/a11y/list-header.e2e.js +6 -6
  668. package/dist/collection/components/list-header/test/basic/list-header.e2e.js +34 -6
  669. package/dist/collection/components/loading/animations/ios.enter.js +19 -19
  670. package/dist/collection/components/loading/animations/ios.leave.js +13 -13
  671. package/dist/collection/components/loading/animations/md.enter.js +19 -19
  672. package/dist/collection/components/loading/animations/md.leave.js +13 -13
  673. package/dist/collection/components/loading/loading.ios.css +44 -0
  674. package/dist/collection/components/loading/loading.js +730 -720
  675. package/dist/collection/components/loading/loading.md.css +44 -0
  676. package/dist/collection/components/loading/test/a11y/loading.e2e.js +26 -26
  677. package/dist/collection/components/loading/test/basic/loading.e2e.js +60 -60
  678. package/dist/collection/components/loading/test/basic/loading.spec.js +16 -0
  679. package/dist/collection/components/loading/test/is-open/loading.e2e.js +17 -17
  680. package/dist/collection/components/loading/test/loading-id.spec.js +32 -0
  681. package/dist/collection/components/loading/test/loading.spec.js +37 -0
  682. package/dist/collection/components/loading/test/standalone/loading.e2e.js +13 -13
  683. package/dist/collection/components/loading/test/trigger/loading.e2e.js +21 -21
  684. package/dist/collection/components/menu/menu.ios.css +48 -4
  685. package/dist/collection/components/menu/menu.js +956 -944
  686. package/dist/collection/components/menu/menu.md.css +48 -4
  687. package/dist/collection/components/menu/test/a11y/menu.e2e.js +13 -13
  688. package/dist/collection/components/menu/test/basic/menu.e2e.js +102 -102
  689. package/dist/collection/components/menu/test/disable/menu.e2e.js +44 -44
  690. package/dist/collection/components/menu/test/focus-trap/menu.e2e.js +61 -61
  691. package/dist/collection/components/menu/test/multiple/menu.e2e.js +49 -49
  692. package/dist/collection/components/menu/test/safe-area/menu.e2e.js +54 -54
  693. package/dist/collection/components/menu-button/menu-button.ios.css +44 -0
  694. package/dist/collection/components/menu-button/menu-button.js +173 -173
  695. package/dist/collection/components/menu-button/menu-button.md.css +44 -0
  696. package/dist/collection/components/menu-button/test/a11y/menu-button.e2e.js +12 -12
  697. package/dist/collection/components/menu-button/test/async/menu-button.e2e.js +12 -12
  698. package/dist/collection/components/menu-button/test/basic/menu-button.e2e.js +6 -6
  699. package/dist/collection/components/menu-toggle/menu-toggle-util.js +2 -2
  700. package/dist/collection/components/menu-toggle/menu-toggle.js +93 -93
  701. package/dist/collection/components/menu-toggle/test/basic/menu-toggle.e2e.js +33 -33
  702. package/dist/collection/components/modal/animations/ios.enter.js +81 -81
  703. package/dist/collection/components/modal/animations/ios.leave.js +74 -74
  704. package/dist/collection/components/modal/animations/md.enter.js +21 -21
  705. package/dist/collection/components/modal/animations/md.leave.js +15 -15
  706. package/dist/collection/components/modal/animations/sheet.js +43 -43
  707. package/dist/collection/components/modal/gestures/sheet.js +289 -289
  708. package/dist/collection/components/modal/gestures/swipe-to-close.js +248 -247
  709. package/dist/collection/components/modal/gestures/utils.js +39 -39
  710. package/dist/collection/components/modal/modal.ios.css +46 -2
  711. package/dist/collection/components/modal/modal.js +1290 -1280
  712. package/dist/collection/components/modal/modal.md.css +44 -0
  713. package/dist/collection/components/modal/test/a11y/modal.e2e.js +12 -12
  714. package/dist/collection/components/modal/test/a11y/modal.spec.js +22 -0
  715. package/dist/collection/components/modal/test/basic/modal.e2e.js +110 -110
  716. package/dist/collection/components/modal/test/basic/modal.spec.js +16 -0
  717. package/dist/collection/components/modal/test/can-dismiss/modal-card.e2e.js +44 -44
  718. package/dist/collection/components/modal/test/can-dismiss/modal-sheet.e2e.js +62 -62
  719. package/dist/collection/components/modal/test/can-dismiss/modal.e2e.js +16 -16
  720. package/dist/collection/components/modal/test/can-dismiss/modal.spec.js +191 -0
  721. package/dist/collection/components/modal/test/card/modal-card.e2e.js +69 -69
  722. package/dist/collection/components/modal/test/card/modal-tablet.e2e.js +67 -67
  723. package/dist/collection/components/modal/test/card-nav/modal.e2e.js +26 -26
  724. package/dist/collection/components/modal/test/card-refresher/modal.e2e.js +14 -14
  725. package/dist/collection/components/modal/test/card-scroll-target/modal.e2e.js +34 -34
  726. package/dist/collection/components/modal/test/custom/modal.e2e.js +16 -16
  727. package/dist/collection/components/modal/test/custom-dialog/modal.e2e.js +12 -12
  728. package/dist/collection/components/modal/test/dark-mode/model.e2e.js +12 -12
  729. package/dist/collection/components/modal/test/fixtures.js +21 -21
  730. package/dist/collection/components/modal/test/inline/modal.e2e.js +34 -34
  731. package/dist/collection/components/modal/test/is-open/modal.e2e.js +17 -17
  732. package/dist/collection/components/modal/test/modal-id.spec.js +32 -0
  733. package/dist/collection/components/modal/test/sheet/modal.e2e.js +178 -178
  734. package/dist/collection/components/modal/test/standalone/modal.e2e.js +12 -12
  735. package/dist/collection/components/modal/test/trigger/modal.e2e.js +23 -23
  736. package/dist/collection/components/modal/utils.js +55 -55
  737. package/dist/collection/components/modal/utils.spec.js +7 -7
  738. package/dist/collection/components/nav/nav.css +22 -0
  739. package/dist/collection/components/nav/nav.js +1748 -1748
  740. package/dist/collection/components/nav/test/basic/nav.e2e.js +58 -58
  741. package/dist/collection/components/nav/test/modal-navigation/nav.e2e.js +52 -52
  742. package/dist/collection/components/nav/test/nav-controller.spec.js +749 -0
  743. package/dist/collection/components/nav/test/nested/nav.e2e.js +54 -54
  744. package/dist/collection/components/nav/test/routing/nav.e2e.js +75 -75
  745. package/dist/collection/components/nav/view-controller.js +52 -52
  746. package/dist/collection/components/nav-link/nav-link-utils.js +16 -16
  747. package/dist/collection/components/nav-link/nav-link.js +106 -106
  748. package/dist/collection/components/note/note.ios.css +44 -0
  749. package/dist/collection/components/note/note.js +49 -49
  750. package/dist/collection/components/note/note.md.css +44 -0
  751. package/dist/collection/components/note/test/a11y/note.e2e.js +59 -16
  752. package/dist/collection/components/note/test/basic/note.e2e.js +33 -33
  753. package/dist/collection/components/picker/animations/ios.enter.js +18 -18
  754. package/dist/collection/components/picker/animations/ios.leave.js +14 -14
  755. package/dist/collection/components/picker/picker.ios.css +45 -1
  756. package/dist/collection/components/picker/picker.js +782 -772
  757. package/dist/collection/components/picker/picker.md.css +45 -1
  758. package/dist/collection/components/picker/test/basic/picker.e2e.js +17 -17
  759. package/dist/collection/components/picker/test/is-open/picker.e2e.js +17 -17
  760. package/dist/collection/components/picker/test/picker-id.spec.js +32 -0
  761. package/dist/collection/components/picker/test/trigger/picker.e2e.js +21 -21
  762. package/dist/collection/components/picker-column/picker-column.ios.css +44 -0
  763. package/dist/collection/components/picker-column/picker-column.js +377 -377
  764. package/dist/collection/components/picker-column/picker-column.md.css +44 -0
  765. package/dist/collection/components/picker-column/test/picker-column-aria.spec.js +35 -0
  766. package/dist/collection/components/picker-column/test/picker-column-dynamic.spec.js +29 -0
  767. package/dist/collection/components/picker-column/test/picker-column.spec.js +17 -0
  768. package/dist/collection/components/picker-column/test/standalone/picker-column.e2e.js +27 -27
  769. package/dist/collection/components/picker-column/test/test.utils.js +29 -29
  770. package/dist/collection/components/picker-column-internal/picker-column-internal.ios.css +33 -3
  771. package/dist/collection/components/picker-column-internal/picker-column-internal.js +523 -501
  772. package/dist/collection/components/picker-column-internal/picker-column-internal.md.css +55 -3
  773. package/dist/collection/components/picker-column-internal/test/basic/picker-column-internal.e2e.js +53 -53
  774. package/dist/collection/components/picker-column-internal/test/disabled/picker-column-internal.e2e.js +66 -37
  775. package/dist/collection/components/picker-internal/picker-internal.ios.css +46 -2
  776. package/dist/collection/components/picker-internal/picker-internal.js +517 -517
  777. package/dist/collection/components/picker-internal/picker-internal.md.css +46 -2
  778. package/dist/collection/components/picker-internal/test/a11y/picker-internal.e2e.js +6 -6
  779. package/dist/collection/components/picker-internal/test/basic/picker-internal.e2e.js +76 -71
  780. package/dist/collection/components/picker-internal/test/keyboard-entry/picker-internal.e2e.js +39 -39
  781. package/dist/collection/components/popover/animations/ios.enter.js +79 -79
  782. package/dist/collection/components/popover/animations/ios.leave.js +28 -28
  783. package/dist/collection/components/popover/animations/md.enter.js +58 -58
  784. package/dist/collection/components/popover/animations/md.leave.js +19 -19
  785. package/dist/collection/components/popover/popover.ios.css +48 -4
  786. package/dist/collection/components/popover/popover.js +1189 -1179
  787. package/dist/collection/components/popover/popover.md.css +46 -2
  788. package/dist/collection/components/popover/test/adjustment/popover.e2e.js +22 -22
  789. package/dist/collection/components/popover/test/arrow/popover.e2e.js +15 -15
  790. package/dist/collection/components/popover/test/async/popover.e2e.js +29 -29
  791. package/dist/collection/components/popover/test/basic/popover.e2e.js +108 -108
  792. package/dist/collection/components/popover/test/basic/popover.spec.js +16 -0
  793. package/dist/collection/components/popover/test/dismiss-on-select/popover.e2e.js +26 -26
  794. package/dist/collection/components/popover/test/fixture.js +16 -16
  795. package/dist/collection/components/popover/test/inline/popover.e2e.js +18 -18
  796. package/dist/collection/components/popover/test/is-open/popover.e2e.js +5 -5
  797. package/dist/collection/components/popover/test/nested/popover.e2e.js +81 -81
  798. package/dist/collection/components/popover/test/popover-id.spec.js +32 -0
  799. package/dist/collection/components/popover/test/position/popover.e2e.js +18 -18
  800. package/dist/collection/components/popover/test/reference/popover.e2e.js +14 -14
  801. package/dist/collection/components/popover/test/size/popover.e2e.js +29 -29
  802. package/dist/collection/components/popover/test/standalone/popover.e2e.js +7 -7
  803. package/dist/collection/components/popover/test/test.utils.js +23 -23
  804. package/dist/collection/components/popover/test/trigger/popover.e2e.js +35 -35
  805. package/dist/collection/components/popover/test/util.spec.js +53 -0
  806. package/dist/collection/components/popover/utils.js +606 -606
  807. package/dist/collection/components/progress-bar/progress-bar.ios.css +22 -0
  808. package/dist/collection/components/progress-bar/progress-bar.js +145 -145
  809. package/dist/collection/components/progress-bar/progress-bar.md.css +22 -0
  810. package/dist/collection/components/progress-bar/test/basic/progress-bar.e2e.js +6 -6
  811. package/dist/collection/components/progress-bar/test/buffer/progress-bar.e2e.js +10 -10
  812. package/dist/collection/components/progress-bar/test/determinate/progress-bar.e2e.js +10 -10
  813. package/dist/collection/components/radio/radio.ios.css +70 -10
  814. package/dist/collection/components/radio/radio.js +454 -447
  815. package/dist/collection/components/radio/radio.md.css +70 -10
  816. package/dist/collection/components/radio/test/a11y/radio.e2e.js +40 -40
  817. package/dist/collection/components/radio/test/color/radio.e2e.js +11 -11
  818. package/dist/collection/components/radio/test/item/radio.e2e.js +37 -37
  819. package/dist/collection/components/radio/test/label-placement/radio.e2e.js +70 -70
  820. package/dist/collection/components/radio/test/legacy/a11y/radio.e2e.js +29 -29
  821. package/dist/collection/components/radio/test/legacy/basic/radio.e2e.js +43 -43
  822. package/dist/collection/components/radio/test/radio.spec.js +60 -0
  823. package/dist/collection/components/radio/test/states/radio.e2e.js +21 -21
  824. package/dist/collection/components/radio-group/radio-group.js +280 -247
  825. package/dist/collection/components/radio-group/test/basic/radio-group.e2e.js +35 -35
  826. package/dist/collection/components/radio-group/test/fixtures.js +22 -22
  827. package/dist/collection/components/radio-group/test/form/radio-group.e2e.js +39 -39
  828. package/dist/collection/components/radio-group/test/legacy/basic/radio-group.e2e.js +59 -59
  829. package/dist/collection/components/radio-group/test/legacy/form/radio-group.e2e.js +22 -22
  830. package/dist/collection/components/radio-group/test/legacy/search/radio-group.e2e.js +27 -27
  831. package/dist/collection/components/radio-group/test/radio-group-events.e2e.js +42 -42
  832. package/dist/collection/components/radio-group/test/radio-group.spec.js +69 -0
  833. package/dist/collection/components/radio-group/test/search/radio-group.e2e.js +23 -23
  834. package/dist/collection/components/range/range.ios.css +45 -7
  835. package/dist/collection/components/range/range.js +1001 -998
  836. package/dist/collection/components/range/range.md.css +45 -7
  837. package/dist/collection/components/range/test/a11y/range.e2e.js +46 -46
  838. package/dist/collection/components/range/test/active-bar-start/range.e2e.js +6 -6
  839. package/dist/collection/components/range/test/basic/range.e2e.js +23 -23
  840. package/dist/collection/components/range/test/color/range.e2e.js +6 -6
  841. package/dist/collection/components/range/test/custom/range.e2e.js +6 -6
  842. package/dist/collection/components/range/test/item/range.e2e.js +28 -28
  843. package/dist/collection/components/range/test/label/range.e2e.js +99 -99
  844. package/dist/collection/components/range/test/label/range.spec.js +23 -0
  845. package/dist/collection/components/range/test/legacy/a11y/range.e2e.js +25 -25
  846. package/dist/collection/components/range/test/legacy/active-bar-start/range.e2e.js +6 -6
  847. package/dist/collection/components/range/test/legacy/basic/range.e2e.js +61 -61
  848. package/dist/collection/components/range/test/legacy/range-events.e2e.js +80 -80
  849. package/dist/collection/components/range/test/legacy/scroll-target/range.e2e.js +23 -23
  850. package/dist/collection/components/range/test/range-events.e2e.js +135 -135
  851. package/dist/collection/components/range/test/range.spec.js +221 -0
  852. package/dist/collection/components/range/test/scroll-target/range.e2e.js +23 -23
  853. package/dist/collection/components/range/test/states/range.e2e.js +21 -21
  854. package/dist/collection/components/refresher/refresher.ios.css +44 -0
  855. package/dist/collection/components/refresher/refresher.js +806 -806
  856. package/dist/collection/components/refresher/refresher.md.css +44 -0
  857. package/dist/collection/components/refresher/refresher.utils.js +148 -141
  858. package/dist/collection/components/refresher/test/basic/refresher.e2e.js +25 -25
  859. package/dist/collection/components/refresher/test/scroll-target/refresher.e2e.js +25 -25
  860. package/dist/collection/components/refresher/test/test.utils.js +5 -5
  861. package/dist/collection/components/refresher-content/refresher-content.js +131 -131
  862. package/dist/collection/components/refresher-content/test/refresher-content.spec.js +46 -0
  863. package/dist/collection/components/reorder/reorder.ios.css +23 -34
  864. package/dist/collection/components/reorder/reorder.js +37 -37
  865. package/dist/collection/components/reorder/reorder.md.css +23 -34
  866. package/dist/collection/components/reorder-group/reorder-group.css +22 -0
  867. package/dist/collection/components/reorder-group/reorder-group.js +327 -327
  868. package/dist/collection/components/reorder-group/test/a11y/reorder-group.e2e.js +6 -6
  869. package/dist/collection/components/reorder-group/test/basic/reorder-group.e2e.js +11 -11
  870. package/dist/collection/components/reorder-group/test/interactive/reorder-group.e2e.js +21 -21
  871. package/dist/collection/components/reorder-group/test/nested/reorder-group.e2e.js +21 -21
  872. package/dist/collection/components/reorder-group/test/scroll-target/reorder-group.e2e.js +21 -21
  873. package/dist/collection/components/ripple-effect/ripple-effect.css +22 -0
  874. package/dist/collection/components/ripple-effect/ripple-effect.js +135 -135
  875. package/dist/collection/components/ripple-effect/test/basic/ripple-effect.e2e.js +48 -48
  876. package/dist/collection/components/route/route.js +151 -151
  877. package/dist/collection/components/route-redirect/route-redirect.js +76 -76
  878. package/dist/collection/components/router/router.js +472 -472
  879. package/dist/collection/components/router/test/basic/router.e2e.js +55 -55
  880. package/dist/collection/components/router/test/guards/href/router.e2e.js +51 -51
  881. package/dist/collection/components/router/test/guards/link/router.e2e.js +51 -51
  882. package/dist/collection/components/router/test/guards/push/router.e2e.js +51 -51
  883. package/dist/collection/components/router/test/guards/router.e2e.js +5 -5
  884. package/dist/collection/components/router/test/guards/test.utils.js +2 -2
  885. package/dist/collection/components/router/test/matching.spec.js +250 -0
  886. package/dist/collection/components/router/test/parser.spec.js +133 -0
  887. package/dist/collection/components/router/test/path.spec.js +218 -0
  888. package/dist/collection/components/router/test/router.spec.js +55 -0
  889. package/dist/collection/components/router/utils/debug.js +14 -14
  890. package/dist/collection/components/router/utils/dom.js +56 -56
  891. package/dist/collection/components/router/utils/matching.js +150 -150
  892. package/dist/collection/components/router/utils/parser.js +52 -52
  893. package/dist/collection/components/router/utils/path.js +66 -66
  894. package/dist/collection/components/router-link/router-link.css +22 -0
  895. package/dist/collection/components/router-link/router-link.js +157 -157
  896. package/dist/collection/components/router-outlet/router-outlet.css +22 -0
  897. package/dist/collection/components/router-outlet/router-outlet.js +459 -459
  898. package/dist/collection/components/router-outlet/test/basic/router-outlet.e2e.js +31 -31
  899. package/dist/collection/components/row/row.css +66 -0
  900. package/dist/collection/components/row/row.js +15 -15
  901. package/dist/collection/components/searchbar/searchbar.ios.css +44 -0
  902. package/dist/collection/components/searchbar/searchbar.js +893 -884
  903. package/dist/collection/components/searchbar/searchbar.md.css +56 -6
  904. package/dist/collection/components/searchbar/test/a11y/searchbar.e2e.js +11 -11
  905. package/dist/collection/components/searchbar/test/basic/searchbar.e2e.js +116 -91
  906. package/dist/collection/components/searchbar/test/events/searchbar.e2e.js +55 -55
  907. package/dist/collection/components/searchbar/test/searchbar.spec.js +15 -0
  908. package/dist/collection/components/segment/segment.ios.css +66 -0
  909. package/dist/collection/components/segment/segment.js +633 -607
  910. package/dist/collection/components/segment/segment.md.css +66 -0
  911. package/dist/collection/components/segment/test/a11y/segment.e2e.js +37 -37
  912. package/dist/collection/components/segment/test/basic/segment.e2e.js +22 -22
  913. package/dist/collection/components/segment/test/custom/segment.e2e.js +6 -6
  914. package/dist/collection/components/segment/test/icon/segment.e2e.js +6 -6
  915. package/dist/collection/components/segment/test/modes/segment.e2e.js +15 -15
  916. package/dist/collection/components/segment/test/scrollable/segment.e2e.js +12 -12
  917. package/dist/collection/components/segment/test/segment-events.e2e.js +97 -97
  918. package/dist/collection/components/segment/test/segment.spec.js +37 -0
  919. package/dist/collection/components/segment/test/toolbar/segment.e2e.js +21 -21
  920. package/dist/collection/components/segment/test/wrap/segment.e2e.js +21 -21
  921. package/dist/collection/components/segment-button/segment-button.ios.css +44 -0
  922. package/dist/collection/components/segment-button/segment-button.js +217 -217
  923. package/dist/collection/components/segment-button/segment-button.md.css +44 -0
  924. package/dist/collection/components/select/select.ios.css +138 -22
  925. package/dist/collection/components/select/select.js +1201 -1184
  926. package/dist/collection/components/select/select.md.css +189 -26
  927. package/dist/collection/components/select/test/a11y/select.e2e.js +14 -14
  928. package/dist/collection/components/select/test/async/select.e2e.js +14 -14
  929. package/dist/collection/components/select/test/basic/select.e2e.js +140 -140
  930. package/dist/collection/components/select/test/card/select.e2e.js +6 -6
  931. package/dist/collection/components/select/test/color/select.e2e.js +22 -22
  932. package/dist/collection/components/select/test/compare-with/select.e2e.js +33 -33
  933. package/dist/collection/components/select/test/custom/select.e2e.js +19 -19
  934. package/dist/collection/components/select/test/disabled/select.e2e.js +17 -17
  935. package/dist/collection/components/select/test/fill/select.e2e.js +63 -63
  936. package/dist/collection/components/select/test/highlight/select.e2e.js +74 -74
  937. package/dist/collection/components/select/test/item/select.e2e.js +26 -11
  938. package/dist/collection/components/select/test/label/select.e2e.js +141 -141
  939. package/dist/collection/components/select/test/legacy/async/select.e2e.js +8 -8
  940. package/dist/collection/components/select/test/legacy/basic/select.e2e.js +108 -108
  941. package/dist/collection/components/select/test/legacy/compare-with/select.e2e.js +33 -33
  942. package/dist/collection/components/select/test/legacy/custom/custom.e2e.js +5 -5
  943. package/dist/collection/components/select/test/legacy/single-value/select.e2e.js +8 -8
  944. package/dist/collection/components/select/test/legacy/spec/select.e2e.js +6 -6
  945. package/dist/collection/components/select/test/legacy/standalone/select.e2e.js +11 -11
  946. package/dist/collection/components/select/test/legacy/wrapping/select.e2e.js +17 -17
  947. package/dist/collection/components/select/test/popover-size/select.e2e.js +63 -63
  948. package/dist/collection/components/select/test/select.spec.js +59 -0
  949. package/dist/collection/components/select/test/slot/select.e2e.js +67 -0
  950. package/dist/collection/components/select/test/states/select.e2e.js +21 -21
  951. package/dist/collection/components/select/test/toggle-icon/select.e2e.js +14 -14
  952. package/dist/collection/components/select/test/wrapping/select.e2e.js +16 -16
  953. package/dist/collection/components/select-option/select-option.js +60 -60
  954. package/dist/collection/components/select-popover/select-popover.ios.css +66 -0
  955. package/dist/collection/components/select-popover/select-popover.js +197 -197
  956. package/dist/collection/components/select-popover/select-popover.md.css +66 -0
  957. package/dist/collection/components/select-popover/test/basic/select-popover.e2e.js +52 -52
  958. package/dist/collection/components/select-popover/test/fixtures.js +33 -33
  959. package/dist/collection/components/skeleton-text/skeleton-text.css +22 -0
  960. package/dist/collection/components/skeleton-text/skeleton-text.js +87 -48
  961. package/dist/collection/components/skeleton-text/test/basic/skeleton-text.e2e.js +6 -6
  962. package/dist/collection/components/skeleton-text/test/custom/skeleton-text.e2e.js +6 -6
  963. package/dist/collection/components/slides/IonicSlides.js +95 -95
  964. package/dist/collection/components/spinner/spinner-configs.js +121 -121
  965. package/dist/collection/components/spinner/spinner.css +22 -0
  966. package/dist/collection/components/spinner/spinner.js +137 -137
  967. package/dist/collection/components/spinner/test/basic/spinner.e2e.js +10 -10
  968. package/dist/collection/components/spinner/test/color/spinner.e2e.js +10 -10
  969. package/dist/collection/components/spinner/test/resize/spinner.e2e.js +8 -8
  970. package/dist/collection/components/split-pane/split-pane.ios.css +66 -0
  971. package/dist/collection/components/split-pane/split-pane.js +225 -225
  972. package/dist/collection/components/split-pane/split-pane.md.css +66 -0
  973. package/dist/collection/components/split-pane/test/basic/split-pane.e2e.js +18 -18
  974. package/dist/collection/components/split-pane/test/multiple/split-pane.e2e.js +31 -0
  975. package/dist/collection/components/tab/tab.js +170 -170
  976. package/dist/collection/components/tab-bar/tab-bar.ios.css +70 -4
  977. package/dist/collection/components/tab-bar/tab-bar.js +177 -177
  978. package/dist/collection/components/tab-bar/tab-bar.md.css +70 -4
  979. package/dist/collection/components/tab-bar/test/basic/tab-bar.e2e.js +43 -0
  980. package/dist/collection/components/tab-bar/test/custom/tab-bar.e2e.js +6 -6
  981. package/dist/collection/components/tab-bar/test/translucent/tab-bar.e2e.js +14 -14
  982. package/dist/collection/components/tab-button/tab-button.ios.css +47 -3
  983. package/dist/collection/components/tab-button/tab-button.js +267 -267
  984. package/dist/collection/components/tab-button/tab-button.md.css +47 -3
  985. package/dist/collection/components/tab-button/test/a11y/tab-button.e2e.js +6 -6
  986. package/dist/collection/components/tab-button/test/basic/tab-button.e2e.js +16 -16
  987. package/dist/collection/components/tab-button/test/layout/tab-button.e2e.js +26 -26
  988. package/dist/collection/components/tab-button/test/states/tab-button.e2e.js +26 -26
  989. package/dist/collection/components/tabs/tabs.css +22 -0
  990. package/dist/collection/components/tabs/tabs.js +344 -344
  991. package/dist/collection/components/tabs/test/basic/tabs.e2e.js +24 -24
  992. package/dist/collection/components/tabs/test/placements/tabs.e2e.js +17 -17
  993. package/dist/collection/components/text/test/basic/text.e2e.js +11 -11
  994. package/dist/collection/components/text/text.css +22 -0
  995. package/dist/collection/components/text/text.js +47 -47
  996. package/dist/collection/components/textarea/test/a11y/textarea.e2e.js +12 -12
  997. package/dist/collection/components/textarea/test/autogrow/textarea.e2e.js +31 -31
  998. package/dist/collection/components/textarea/test/bottom-content/textarea.e2e.js +82 -82
  999. package/dist/collection/components/textarea/test/card/textarea.e2e.js +6 -6
  1000. package/dist/collection/components/textarea/test/clear-on-edit/textarea.e2e.js +17 -17
  1001. package/dist/collection/components/textarea/test/color/textarea.e2e.js +88 -88
  1002. package/dist/collection/components/textarea/test/cols/textarea.e2e.js +11 -11
  1003. package/dist/collection/components/textarea/test/fill/textarea.e2e.js +63 -63
  1004. package/dist/collection/components/textarea/test/highlight/textarea.e2e.js +52 -52
  1005. package/dist/collection/components/textarea/test/item/textarea.e2e.js +11 -11
  1006. package/dist/collection/components/textarea/test/label-placement/textarea.e2e.js +150 -150
  1007. package/dist/collection/components/textarea/test/legacy/a11y/textarea.e2e.js +15 -15
  1008. package/dist/collection/components/textarea/test/legacy/autogrow/textarea.e2e.js +31 -31
  1009. package/dist/collection/components/textarea/test/legacy/basic/textarea.e2e.js +30 -30
  1010. package/dist/collection/components/textarea/test/legacy/clear-on-edit/textarea.e2e.js +17 -17
  1011. package/dist/collection/components/textarea/test/slot/textarea.e2e.js +51 -0
  1012. package/dist/collection/components/textarea/test/states/textarea.e2e.js +11 -11
  1013. package/dist/collection/components/textarea/test/textarea-events.e2e.js +57 -57
  1014. package/dist/collection/components/textarea/test/textarea.spec.js +59 -0
  1015. package/dist/collection/components/textarea/textarea.ios.css +144 -24
  1016. package/dist/collection/components/textarea/textarea.js +1050 -1016
  1017. package/dist/collection/components/textarea/textarea.md.css +205 -34
  1018. package/dist/collection/components/thumbnail/test/basic/thumbnail.e2e.js +28 -28
  1019. package/dist/collection/components/thumbnail/thumbnail.css +22 -0
  1020. package/dist/collection/components/thumbnail/thumbnail.js +15 -15
  1021. package/dist/collection/components/title/test/a11y/title.e2e.js +17 -17
  1022. package/dist/collection/components/title/test/basic/title.e2e.js +13 -13
  1023. package/dist/collection/components/title/title.ios.css +24 -2
  1024. package/dist/collection/components/title/title.js +119 -119
  1025. package/dist/collection/components/title/title.md.css +22 -0
  1026. package/dist/collection/components/toast/animations/ios.enter.js +21 -20
  1027. package/dist/collection/components/toast/animations/ios.leave.js +18 -18
  1028. package/dist/collection/components/toast/animations/md.enter.js +23 -22
  1029. package/dist/collection/components/toast/animations/md.leave.js +6 -6
  1030. package/dist/collection/components/toast/animations/utils.js +62 -56
  1031. package/dist/collection/components/toast/gestures/swipe-to-dismiss.js +267 -0
  1032. package/dist/collection/components/toast/test/a11y/toast.e2e.js +92 -92
  1033. package/dist/collection/components/toast/test/basic/toast.e2e.js +101 -101
  1034. package/dist/collection/components/toast/test/is-open/toast.e2e.js +17 -17
  1035. package/dist/collection/components/toast/test/layout/toast.e2e.js +9 -9
  1036. package/dist/collection/components/toast/test/position-anchor/toast.e2e.js +37 -37
  1037. package/dist/collection/components/toast/test/standalone/toast.e2e.js +10 -10
  1038. package/dist/collection/components/toast/test/swipe-gesture/toast.e2e.js +84 -0
  1039. package/dist/collection/components/toast/test/toast-config.spec.js +25 -0
  1040. package/dist/collection/components/toast/test/toast-id.spec.js +32 -0
  1041. package/dist/collection/components/toast/test/toast.spec.js +200 -0
  1042. package/dist/collection/components/toast/test/trigger/toast.e2e.js +21 -21
  1043. package/dist/collection/components/toast/toast.ios.css +55 -11
  1044. package/dist/collection/components/toast/toast.js +1065 -952
  1045. package/dist/collection/components/toast/toast.md.css +55 -1
  1046. package/dist/collection/components/toggle/test/a11y/toggle.e2e.js +6 -6
  1047. package/dist/collection/components/toggle/test/color/toggle.e2e.js +11 -11
  1048. package/dist/collection/components/toggle/test/enable-on-off-labels/toggle.e2e.js +27 -27
  1049. package/dist/collection/components/toggle/test/item/toggle.e2e.js +52 -52
  1050. package/dist/collection/components/toggle/test/label/toggle.e2e.js +65 -65
  1051. package/dist/collection/components/toggle/test/legacy/basic/toggle.e2e.js +69 -69
  1052. package/dist/collection/components/toggle/test/legacy/enable-on-off-labels/toggle.e2e.js +23 -23
  1053. package/dist/collection/components/toggle/test/legacy/sizes/toggle.e2e.js +6 -6
  1054. package/dist/collection/components/toggle/test/sizes/toggle.e2e.js +6 -6
  1055. package/dist/collection/components/toggle/test/states/toggle.e2e.js +16 -16
  1056. package/dist/collection/components/toggle/test/toggle.spec.js +67 -0
  1057. package/dist/collection/components/toggle/toggle.ios.css +69 -9
  1058. package/dist/collection/components/toggle/toggle.js +487 -484
  1059. package/dist/collection/components/toggle/toggle.md.css +69 -9
  1060. package/dist/collection/components/toolbar/test/basic/toolbar.e2e.js +7 -7
  1061. package/dist/collection/components/toolbar/test/colors/toolbar.e2e.js +6 -6
  1062. package/dist/collection/components/toolbar/toolbar.ios.css +44 -0
  1063. package/dist/collection/components/toolbar/toolbar.js +100 -100
  1064. package/dist/collection/components/toolbar/toolbar.md.css +44 -0
  1065. package/dist/collection/css/test/a11y/typography.e2e.js +6 -6
  1066. package/dist/collection/global/config.js +51 -51
  1067. package/dist/collection/global/ionic-global.js +54 -54
  1068. package/dist/collection/global/test/config-controller.spec.js +77 -0
  1069. package/dist/collection/utils/animation/animation-utils.js +91 -91
  1070. package/dist/collection/utils/animation/animation.js +906 -890
  1071. package/dist/collection/utils/animation/cubic-bezier.js +49 -49
  1072. package/dist/collection/utils/animation/test/animation.spec.js +447 -0
  1073. package/dist/collection/utils/animation/test/animationbuilder/animation.e2e.js +26 -26
  1074. package/dist/collection/utils/animation/test/basic/animation.e2e.js +12 -12
  1075. package/dist/collection/utils/animation/test/display/animation.e2e.js +18 -18
  1076. package/dist/collection/utils/animation/test/hooks/animation.e2e.js +39 -39
  1077. package/dist/collection/utils/animation/test/multiple/animation.e2e.js +27 -27
  1078. package/dist/collection/utils/browser/index.js +0 -22
  1079. package/dist/collection/utils/config.js +20 -20
  1080. package/dist/collection/utils/content/content.utils.spec.js +121 -121
  1081. package/dist/collection/utils/content/index.js +58 -59
  1082. package/dist/collection/utils/floating-point/floating-point.spec.js +14 -14
  1083. package/dist/collection/utils/floating-point/index.js +5 -5
  1084. package/dist/collection/utils/focus-visible.js +63 -63
  1085. package/dist/collection/utils/forms/compare-with-utils.js +39 -0
  1086. package/dist/collection/utils/forms/form-controller.js +45 -49
  1087. package/dist/collection/utils/forms/index.js +1 -0
  1088. package/dist/collection/utils/forms/notch-controller.js +120 -120
  1089. package/dist/collection/utils/framework-delegate.js +121 -121
  1090. package/dist/collection/utils/gesture/button-active.js +56 -56
  1091. package/dist/collection/utils/gesture/gesture-controller.js +182 -182
  1092. package/dist/collection/utils/gesture/index.js +222 -222
  1093. package/dist/collection/utils/gesture/listener.js +36 -36
  1094. package/dist/collection/utils/gesture/pointer-events.js +113 -113
  1095. package/dist/collection/utils/gesture/recognizers.js +46 -46
  1096. package/dist/collection/utils/gesture/swipe-back.js +65 -65
  1097. package/dist/collection/utils/hardware-back-button.js +48 -48
  1098. package/dist/collection/utils/helpers.js +258 -258
  1099. package/dist/collection/utils/helpers.spec.js +28 -28
  1100. package/dist/collection/utils/input-shims/hacks/common.js +61 -53
  1101. package/dist/collection/utils/input-shims/hacks/hide-caret.js +19 -19
  1102. package/dist/collection/utils/input-shims/hacks/input-blurring.js +47 -47
  1103. package/dist/collection/utils/input-shims/hacks/scroll-assist.js +225 -225
  1104. package/dist/collection/utils/input-shims/hacks/scroll-data.js +29 -29
  1105. package/dist/collection/utils/input-shims/hacks/scroll-padding.js +21 -21
  1106. package/dist/collection/utils/input-shims/hacks/test/scroll-assist.e2e.js +97 -97
  1107. package/dist/collection/utils/input-shims/input-shims.js +87 -81
  1108. package/dist/collection/utils/keyboard/keyboard-controller.js +128 -128
  1109. package/dist/collection/utils/keyboard/keyboard.js +59 -59
  1110. package/dist/collection/utils/keyboard/test/keyboard-controller.spec.js +21 -0
  1111. package/dist/collection/utils/keyboard/test/keyboard.spec.js +214 -0
  1112. package/dist/collection/utils/lock-controller.js +24 -24
  1113. package/dist/collection/utils/logging/index.js +3 -3
  1114. package/dist/collection/utils/media.js +13 -13
  1115. package/dist/collection/utils/menu-controller/animations/base.js +8 -8
  1116. package/dist/collection/utils/menu-controller/animations/overlay.js +21 -21
  1117. package/dist/collection/utils/menu-controller/animations/push.js +20 -20
  1118. package/dist/collection/utils/menu-controller/animations/reveal.js +6 -6
  1119. package/dist/collection/utils/menu-controller/index.js +204 -206
  1120. package/dist/collection/utils/native/capacitor.js +4 -4
  1121. package/dist/collection/utils/native/haptic.js +151 -151
  1122. package/dist/collection/utils/native/keyboard.js +47 -47
  1123. package/dist/collection/utils/native/native-interface.js +15 -15
  1124. package/dist/collection/utils/native/status-bar.js +36 -36
  1125. package/dist/collection/utils/overlays.js +495 -494
  1126. package/dist/collection/utils/platform.js +56 -56
  1127. package/dist/collection/utils/rtl/dir.js +5 -5
  1128. package/dist/collection/utils/rtl/dir.spec.js +17 -17
  1129. package/dist/collection/utils/sanitization/index.js +122 -122
  1130. package/dist/collection/utils/sanitization/test/sanitization.spec.js +43 -0
  1131. package/dist/collection/utils/slot-mutation-controller.js +86 -85
  1132. package/dist/collection/utils/status-tap.js +26 -26
  1133. package/dist/collection/utils/tap-click/index.js +171 -171
  1134. package/dist/collection/utils/tap-click/test/tap-click.e2e.js +12 -12
  1135. package/dist/collection/utils/test/aria.spec.js +79 -0
  1136. package/dist/collection/utils/test/attributes.spec.js +53 -0
  1137. package/dist/collection/utils/test/framework-delegate/framework-delegate.e2e.js +25 -25
  1138. package/dist/collection/utils/test/hardware-back-button.spec.js +53 -0
  1139. package/dist/collection/utils/test/overlays/overlays.e2e.js +137 -137
  1140. package/dist/collection/utils/test/overlays/overlays.spec.js +102 -0
  1141. package/dist/collection/utils/test/platform.spec.js +132 -0
  1142. package/dist/collection/utils/test/platform.utils.js +77 -77
  1143. package/dist/collection/utils/test/playwright/drag-element.js +69 -69
  1144. package/dist/collection/utils/test/playwright/generator.js +48 -25
  1145. package/dist/collection/utils/test/playwright/matchers/index.js +3 -3
  1146. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEvent.js +21 -21
  1147. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventDetail.js +28 -28
  1148. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventTimes.js +22 -22
  1149. package/dist/collection/utils/test/playwright/page/event-spy.js +110 -110
  1150. package/dist/collection/utils/test/playwright/page/utils/goto.js +52 -52
  1151. package/dist/collection/utils/test/playwright/page/utils/locator.js +8 -8
  1152. package/dist/collection/utils/test/playwright/page/utils/set-content.js +44 -35
  1153. package/dist/collection/utils/test/playwright/page/utils/set-ion-viewport.js +19 -19
  1154. package/dist/collection/utils/test/playwright/page/utils/spy-on-event.js +4 -4
  1155. package/dist/collection/utils/test/playwright/page/utils/wait-for-changes.js +48 -48
  1156. package/dist/collection/utils/test/playwright/playwright-page.js +35 -35
  1157. package/dist/collection/utils/test/playwright/viewports/index.js +13 -13
  1158. package/dist/collection/utils/test/press-keys.js +77 -77
  1159. package/dist/collection/utils/test/ready.spec.js +39 -0
  1160. package/dist/collection/utils/test/theme.spec.js +56 -0
  1161. package/dist/collection/utils/theme.js +23 -23
  1162. package/dist/collection/utils/transition/index.js +163 -163
  1163. package/dist/collection/utils/transition/ios.transition.js +598 -598
  1164. package/dist/collection/utils/transition/md.transition.js +44 -44
  1165. package/dist/collection/utils/watch-options.js +37 -26
  1166. package/dist/docs.json +196 -39
  1167. package/dist/esm/animation-dde8cc0d.js +1060 -0
  1168. package/dist/esm/{app-globals-ec816a70.js → app-globals-722340c4.js} +1 -1
  1169. package/dist/esm/button-active-c6ee4f50.js +67 -0
  1170. package/dist/esm/capacitor-59395cbd.js +13 -0
  1171. package/dist/esm/compare-with-utils-a96ff2ea.js +41 -0
  1172. package/dist/esm/config-49c88215.js +193 -0
  1173. package/dist/esm/cubic-bezier-fe2083dc.js +90 -0
  1174. package/dist/esm/data-f5c75b4e.js +1575 -0
  1175. package/dist/esm/{dir-912e3e13.js → dir-babeabeb.js} +5 -5
  1176. package/dist/esm/focus-visible-dd40d69f.js +75 -0
  1177. package/dist/esm/form-controller-548aa79c.js +64 -0
  1178. package/dist/esm/framework-delegate-bc1fd82a.js +140 -0
  1179. package/dist/esm/gesture-controller-1bf57181.js +195 -0
  1180. package/dist/esm/haptic-554688a5.js +206 -0
  1181. package/dist/esm/hardware-back-button-b2bc76db.js +71 -0
  1182. package/dist/esm/helpers-ae653409.js +418 -0
  1183. package/dist/esm/{index-b49b173c.js → index-08d686eb.js} +184 -63
  1184. package/dist/esm/index-0c12c22b.js +306 -0
  1185. package/dist/esm/index-1932b201.js +231 -0
  1186. package/dist/esm/index-2cf77112.js +457 -0
  1187. package/dist/esm/index-82eeb47f.js +196 -0
  1188. package/dist/esm/{index-595d62c9.js → index-9b0d46f4.js} +3 -3
  1189. package/dist/esm/index-a5d50daf.js +7 -0
  1190. package/dist/esm/{index-746a238e.js → index-b9e742e5.js} +60 -61
  1191. package/dist/esm/index.js +113 -113
  1192. package/dist/esm/input-shims-6539ce13.js +599 -0
  1193. package/dist/esm/input.utils-a5a2d164.js +135 -0
  1194. package/dist/esm/ion-accordion_2.entry.js +491 -481
  1195. package/dist/esm/ion-action-sheet.entry.js +262 -252
  1196. package/dist/esm/ion-alert.entry.js +442 -432
  1197. package/dist/esm/ion-app_8.entry.js +1153 -1153
  1198. package/dist/esm/ion-avatar_3.entry.js +29 -29
  1199. package/dist/esm/ion-back-button.entry.js +73 -73
  1200. package/dist/esm/ion-backdrop.entry.js +40 -40
  1201. package/dist/esm/ion-breadcrumb_2.entry.js +194 -194
  1202. package/dist/esm/ion-button_2.entry.js +303 -303
  1203. package/dist/esm/ion-card_5.entry.js +105 -105
  1204. package/dist/esm/ion-checkbox.entry.js +149 -147
  1205. package/dist/esm/ion-chip.entry.js +20 -20
  1206. package/dist/esm/ion-col_3.entry.js +136 -136
  1207. package/dist/esm/ion-datetime-button.entry.js +325 -325
  1208. package/dist/esm/ion-datetime_3.entry.js +2185 -2137
  1209. package/dist/esm/ion-fab_3.entry.js +152 -152
  1210. package/dist/esm/ion-img.entry.js +79 -79
  1211. package/dist/esm/ion-infinite-scroll_2.entry.js +198 -190
  1212. package/dist/esm/ion-input.entry.js +426 -394
  1213. package/dist/esm/ion-item-option_3.entry.js +459 -459
  1214. package/dist/esm/ion-item_8.entry.js +447 -434
  1215. package/dist/esm/ion-loading.entry.js +220 -210
  1216. package/dist/esm/ion-menu_3.entry.js +670 -658
  1217. package/dist/esm/ion-modal.entry.js +1415 -1405
  1218. package/dist/esm/ion-nav_2.entry.js +904 -904
  1219. package/dist/esm/ion-picker-column-internal.entry.js +331 -327
  1220. package/dist/esm/ion-picker-internal.entry.js +455 -455
  1221. package/dist/esm/ion-popover.entry.js +1110 -1100
  1222. package/dist/esm/ion-progress-bar.entry.js +40 -40
  1223. package/dist/esm/ion-radio_2.entry.js +322 -309
  1224. package/dist/esm/ion-range.entry.js +558 -556
  1225. package/dist/esm/ion-refresher_2.entry.js +786 -779
  1226. package/dist/esm/ion-reorder_2.entry.js +269 -269
  1227. package/dist/esm/ion-ripple-effect.entry.js +66 -66
  1228. package/dist/esm/ion-route_4.entry.js +693 -693
  1229. package/dist/esm/ion-searchbar.entry.js +363 -354
  1230. package/dist/esm/ion-segment_2.entry.js +509 -483
  1231. package/dist/esm/ion-select_3.entry.js +784 -768
  1232. package/dist/esm/ion-spinner.entry.js +46 -46
  1233. package/dist/esm/ion-split-pane.entry.js +117 -117
  1234. package/dist/esm/ion-tab-bar_2.entry.js +142 -142
  1235. package/dist/esm/ion-tab_2.entry.js +187 -187
  1236. package/dist/esm/ion-text.entry.js +13 -13
  1237. package/dist/esm/ion-textarea.entry.js +381 -349
  1238. package/dist/esm/ion-toast.entry.js +771 -419
  1239. package/dist/esm/ion-toggle.entry.js +227 -225
  1240. package/dist/esm/ionic-global-c0cda98e.js +224 -0
  1241. package/dist/esm/ionic.js +6 -6
  1242. package/dist/esm/ios.transition-802a84a6.js +651 -0
  1243. package/dist/esm/keyboard-52278bd7.js +146 -0
  1244. package/dist/esm/keyboard-73175e24.js +79 -0
  1245. package/dist/esm/keyboard-controller-ec5c2bfa.js +165 -0
  1246. package/dist/esm/loader.js +5 -5
  1247. package/dist/esm/lock-controller-316928be.js +38 -0
  1248. package/dist/esm/md.transition-43c2874d.js +57 -0
  1249. package/dist/esm/notch-controller-fea7f9c5.js +153 -0
  1250. package/dist/esm/overlays-32ef481d.js +693 -0
  1251. package/dist/esm/spinner-configs-964f7cf3.js +145 -0
  1252. package/dist/esm/status-tap-2b93b1b5.js +40 -0
  1253. package/dist/esm/swipe-back-18cb49f7.js +79 -0
  1254. package/dist/esm/theme-01f3f29c.js +43 -0
  1255. package/dist/esm/watch-options-c2911ace.js +47 -0
  1256. package/dist/esm-es5/animation-dde8cc0d.js +4 -0
  1257. package/dist/esm-es5/app-globals-722340c4.js +4 -0
  1258. package/dist/esm-es5/{button-active-d926d4f4.js → button-active-c6ee4f50.js} +1 -1
  1259. package/dist/esm-es5/{capacitor-b4979570.js → capacitor-59395cbd.js} +1 -1
  1260. package/dist/esm-es5/compare-with-utils-a96ff2ea.js +4 -0
  1261. package/dist/esm-es5/config-49c88215.js +4 -0
  1262. package/dist/esm-es5/cubic-bezier-fe2083dc.js +4 -0
  1263. package/dist/esm-es5/data-f5c75b4e.js +4 -0
  1264. package/dist/esm-es5/{dir-912e3e13.js → dir-babeabeb.js} +1 -1
  1265. package/dist/esm-es5/focus-visible-dd40d69f.js +4 -0
  1266. package/dist/esm-es5/form-controller-548aa79c.js +4 -0
  1267. package/dist/esm-es5/framework-delegate-bc1fd82a.js +4 -0
  1268. package/dist/esm-es5/{gesture-controller-0fa396c4.js → gesture-controller-1bf57181.js} +1 -1
  1269. package/dist/esm-es5/{haptic-1243b917.js → haptic-554688a5.js} +1 -1
  1270. package/dist/esm-es5/hardware-back-button-b2bc76db.js +4 -0
  1271. package/dist/esm-es5/helpers-ae653409.js +4 -0
  1272. package/dist/esm-es5/index-08d686eb.js +5 -0
  1273. package/dist/esm-es5/index-0c12c22b.js +4 -0
  1274. package/dist/esm-es5/{index-a09eac70.js → index-1932b201.js} +1 -1
  1275. package/dist/esm-es5/index-2cf77112.js +4 -0
  1276. package/dist/esm-es5/index-82eeb47f.js +4 -0
  1277. package/dist/esm-es5/index-b9e742e5.js +4 -0
  1278. package/dist/esm-es5/index.js +1 -1
  1279. package/dist/esm-es5/input-shims-6539ce13.js +4 -0
  1280. package/dist/esm-es5/input.utils-a5a2d164.js +4 -0
  1281. package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
  1282. package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
  1283. package/dist/esm-es5/ion-alert.entry.js +1 -1
  1284. package/dist/esm-es5/ion-app_8.entry.js +1 -1
  1285. package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
  1286. package/dist/esm-es5/ion-back-button.entry.js +1 -1
  1287. package/dist/esm-es5/ion-backdrop.entry.js +1 -1
  1288. package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
  1289. package/dist/esm-es5/ion-button_2.entry.js +1 -1
  1290. package/dist/esm-es5/ion-card_5.entry.js +1 -1
  1291. package/dist/esm-es5/ion-checkbox.entry.js +1 -1
  1292. package/dist/esm-es5/ion-chip.entry.js +1 -1
  1293. package/dist/esm-es5/ion-col_3.entry.js +1 -1
  1294. package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
  1295. package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
  1296. package/dist/esm-es5/ion-fab_3.entry.js +1 -1
  1297. package/dist/esm-es5/ion-img.entry.js +1 -1
  1298. package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
  1299. package/dist/esm-es5/ion-input.entry.js +1 -1
  1300. package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
  1301. package/dist/esm-es5/ion-item_8.entry.js +1 -1
  1302. package/dist/esm-es5/ion-loading.entry.js +1 -1
  1303. package/dist/esm-es5/ion-menu_3.entry.js +1 -1
  1304. package/dist/esm-es5/ion-modal.entry.js +1 -1
  1305. package/dist/esm-es5/ion-nav_2.entry.js +1 -1
  1306. package/dist/esm-es5/ion-picker-column-internal.entry.js +1 -1
  1307. package/dist/esm-es5/ion-picker-internal.entry.js +1 -1
  1308. package/dist/esm-es5/ion-popover.entry.js +1 -1
  1309. package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
  1310. package/dist/esm-es5/ion-radio_2.entry.js +1 -1
  1311. package/dist/esm-es5/ion-range.entry.js +1 -1
  1312. package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
  1313. package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
  1314. package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
  1315. package/dist/esm-es5/ion-route_4.entry.js +1 -1
  1316. package/dist/esm-es5/ion-searchbar.entry.js +1 -1
  1317. package/dist/esm-es5/ion-segment_2.entry.js +1 -1
  1318. package/dist/esm-es5/ion-select_3.entry.js +1 -1
  1319. package/dist/esm-es5/ion-spinner.entry.js +1 -1
  1320. package/dist/esm-es5/ion-split-pane.entry.js +1 -1
  1321. package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
  1322. package/dist/esm-es5/ion-tab_2.entry.js +1 -1
  1323. package/dist/esm-es5/ion-text.entry.js +1 -1
  1324. package/dist/esm-es5/ion-textarea.entry.js +1 -1
  1325. package/dist/esm-es5/ion-toast.entry.js +1 -1
  1326. package/dist/esm-es5/ion-toggle.entry.js +1 -1
  1327. package/dist/esm-es5/ionic-global-c0cda98e.js +4 -0
  1328. package/dist/esm-es5/ionic.js +1 -1
  1329. package/dist/esm-es5/{ios.transition-4d1322d6.js → ios.transition-802a84a6.js} +1 -1
  1330. package/dist/esm-es5/{keyboard-b551279d.js → keyboard-52278bd7.js} +1 -1
  1331. package/dist/esm-es5/{keyboard-b063f012.js → keyboard-73175e24.js} +1 -1
  1332. package/dist/esm-es5/keyboard-controller-ec5c2bfa.js +4 -0
  1333. package/dist/esm-es5/loader.js +1 -1
  1334. package/dist/esm-es5/md.transition-43c2874d.js +4 -0
  1335. package/dist/esm-es5/notch-controller-fea7f9c5.js +4 -0
  1336. package/dist/esm-es5/overlays-32ef481d.js +4 -0
  1337. package/dist/esm-es5/spinner-configs-964f7cf3.js +4 -0
  1338. package/dist/esm-es5/status-tap-2b93b1b5.js +4 -0
  1339. package/dist/esm-es5/swipe-back-18cb49f7.js +4 -0
  1340. package/dist/esm-es5/watch-options-c2911ace.js +4 -0
  1341. package/dist/html.html-data.json +17 -4
  1342. package/dist/ionic/index.esm.js +1 -1
  1343. package/dist/ionic/ionic.esm.js +1 -1
  1344. package/dist/ionic/ionic.js +15 -15
  1345. package/dist/ionic/p-012c3ceb.system.js +4 -0
  1346. package/dist/ionic/p-013013a3.js +4 -0
  1347. package/dist/ionic/p-01d14eba.system.entry.js +4 -0
  1348. package/dist/ionic/p-042e6f4b.entry.js +4 -0
  1349. package/dist/ionic/{p-819ff3b9.system.js → p-08e01816.system.js} +1 -1
  1350. package/dist/ionic/{p-f919c026.entry.js → p-0add7211.entry.js} +1 -1
  1351. package/dist/ionic/p-0bd51c34.system.js +4 -0
  1352. package/dist/ionic/{p-6f6646bf.system.entry.js → p-0e53f8ea.system.entry.js} +1 -1
  1353. package/dist/ionic/{p-6ea2e653.entry.js → p-1161a793.entry.js} +1 -1
  1354. package/dist/ionic/{p-96ba8eac.entry.js → p-1208f939.entry.js} +1 -1
  1355. package/dist/ionic/p-16756e94.system.entry.js +4 -0
  1356. package/dist/ionic/p-1786bc72.js +4 -0
  1357. package/dist/ionic/{p-1ecba429.entry.js → p-17da5ed1.entry.js} +1 -1
  1358. package/dist/ionic/p-18ba8221.entry.js +4 -0
  1359. package/dist/ionic/p-1b19c04b.entry.js +4 -0
  1360. package/dist/ionic/p-1cca10d6.system.js +4 -0
  1361. package/dist/ionic/p-1e4371bd.js +4 -0
  1362. package/dist/ionic/{p-fcf47f80.entry.js → p-2092f39f.entry.js} +1 -1
  1363. package/dist/ionic/p-251666e2.entry.js +4 -0
  1364. package/dist/ionic/{p-7423746f.entry.js → p-270e1a1d.entry.js} +1 -1
  1365. package/dist/ionic/{p-419eb426.js → p-27281edd.js} +1 -1
  1366. package/dist/ionic/p-28249b10.system.entry.js +4 -0
  1367. package/dist/ionic/p-28a2c2a2.entry.js +4 -0
  1368. package/dist/ionic/{p-6129af0a.system.entry.js → p-2938823a.system.entry.js} +1 -1
  1369. package/dist/ionic/p-29d03b3a.js +4 -0
  1370. package/dist/ionic/{p-17240d90.js → p-2aea8b1e.js} +1 -1
  1371. package/dist/ionic/p-2b7827c7.js +4 -0
  1372. package/dist/ionic/p-2d3b9fa3.system.entry.js +4 -0
  1373. package/dist/ionic/p-2d539df1.entry.js +4 -0
  1374. package/dist/ionic/p-31b2326e.system.js +4 -0
  1375. package/dist/ionic/{p-e028178a.system.js → p-31fcb233.system.js} +1 -1
  1376. package/dist/ionic/p-32ad210f.system.js +4 -0
  1377. package/dist/ionic/{p-aa377971.system.js → p-33a37fad.system.js} +1 -1
  1378. package/dist/ionic/p-350f7292.system.entry.js +4 -0
  1379. package/dist/ionic/{p-cabd2c6d.entry.js → p-353b349d.entry.js} +1 -1
  1380. package/dist/ionic/p-36d187af.js +4 -0
  1381. package/dist/ionic/p-376a6063.js +4 -0
  1382. package/dist/ionic/p-38c337e7.system.js +4 -0
  1383. package/dist/ionic/p-38f2c6bb.system.js +4 -0
  1384. package/dist/ionic/{p-9e106f58.entry.js → p-3a45a82b.entry.js} +1 -1
  1385. package/dist/ionic/{p-3bad5c1a.js → p-3a75d7fd.js} +1 -1
  1386. package/dist/ionic/p-3dd98a73.entry.js +4 -0
  1387. package/dist/ionic/p-3e6b47e8.system.entry.js +4 -0
  1388. package/dist/ionic/p-3f5179b5.entry.js +4 -0
  1389. package/dist/ionic/p-40f68333.system.js +4 -0
  1390. package/dist/ionic/p-4155f352.system.js +4 -0
  1391. package/dist/ionic/{p-b287ab05.js → p-4180a747.js} +1 -1
  1392. package/dist/ionic/p-4233cc1e.system.entry.js +4 -0
  1393. package/dist/ionic/{p-b923f3d7.js → p-42f189f4.js} +1 -1
  1394. package/dist/ionic/p-459d13d5.js +4 -0
  1395. package/dist/ionic/p-4609d030.system.js +4 -0
  1396. package/dist/ionic/p-46d400b4.system.entry.js +4 -0
  1397. package/dist/ionic/{p-cf62e1c8.js → p-47b6ba5b.js} +1 -1
  1398. package/dist/ionic/p-4d67d27a.entry.js +4 -0
  1399. package/dist/ionic/p-4f255d5a.system.js +4 -0
  1400. package/dist/ionic/p-4fb51e61.system.entry.js +4 -0
  1401. package/dist/ionic/{p-c575a7b8.system.entry.js → p-517a9885.system.entry.js} +1 -1
  1402. package/dist/ionic/{p-8083aadb.entry.js → p-51a087d6.entry.js} +1 -1
  1403. package/dist/ionic/p-53ec4f1c.system.js +4 -0
  1404. package/dist/ionic/{p-6f8a95a3.system.entry.js → p-564af202.system.entry.js} +2 -2
  1405. package/dist/ionic/{p-0ac3fb2c.entry.js → p-588fdf40.entry.js} +1 -1
  1406. package/dist/ionic/p-5b365ca7.system.js +4 -0
  1407. package/dist/ionic/{p-c42c86c0.system.entry.js → p-5bebc7b3.system.entry.js} +1 -1
  1408. package/dist/ionic/p-5e4eec2e.entry.js +4 -0
  1409. package/dist/ionic/{p-2a8eeef7.system.js → p-5e745192.system.js} +1 -1
  1410. package/dist/ionic/{p-76378400.js → p-5ecae037.js} +1 -1
  1411. package/dist/ionic/{p-c679fcb5.entry.js → p-5eda1d7d.entry.js} +1 -1
  1412. package/dist/ionic/{p-1289b3b5.system.entry.js → p-6577aea9.system.entry.js} +2 -2
  1413. package/dist/ionic/p-66d633fb.js +4 -0
  1414. package/dist/ionic/{p-0bbede6a.system.entry.js → p-6ad34705.system.entry.js} +1 -1
  1415. package/dist/ionic/p-6de472cb.js +4 -0
  1416. package/dist/ionic/{p-ce7d67a7.system.entry.js → p-6de62649.system.entry.js} +2 -2
  1417. package/dist/ionic/{p-8a2801f1.system.entry.js → p-6e70dd1a.system.entry.js} +1 -1
  1418. package/dist/ionic/{p-61b192a4.system.entry.js → p-6f8dbe92.system.entry.js} +1 -1
  1419. package/dist/ionic/{p-0b00b937.entry.js → p-6fbecbda.entry.js} +1 -1
  1420. package/dist/ionic/p-72f6ff89.js +4 -0
  1421. package/dist/ionic/p-765f4dde.entry.js +4 -0
  1422. package/dist/ionic/p-7798c78a.system.js +4 -0
  1423. package/dist/ionic/p-78aadecb.entry.js +4 -0
  1424. package/dist/ionic/p-790220fd.system.js +4 -0
  1425. package/dist/ionic/p-7d92bf15.system.entry.js +4 -0
  1426. package/dist/ionic/p-80fa068e.entry.js +4 -0
  1427. package/dist/ionic/p-82e3d633.system.js +4 -0
  1428. package/dist/ionic/p-8314281e.system.js +4 -0
  1429. package/dist/ionic/p-8804a472.system.entry.js +4 -0
  1430. package/dist/ionic/p-888db766.system.js +4 -0
  1431. package/dist/ionic/p-88d5fbd3.js +4 -0
  1432. package/dist/ionic/p-88fde0e0.entry.js +4 -0
  1433. package/dist/ionic/p-8985cdb6.system.js +4 -0
  1434. package/dist/ionic/p-8aa1d0b7.system.js +4 -0
  1435. package/dist/ionic/p-8acae6b0.system.entry.js +4 -0
  1436. package/dist/ionic/p-8d69a624.entry.js +4 -0
  1437. package/dist/ionic/p-8f5d30f5.entry.js +4 -0
  1438. package/dist/ionic/{p-beb864e4.system.entry.js → p-908475e7.system.entry.js} +1 -1
  1439. package/dist/ionic/p-91d33c4a.js +4 -0
  1440. package/dist/ionic/p-953009b1.entry.js +4 -0
  1441. package/dist/ionic/{p-eb8dc56f.system.entry.js → p-958d6ebe.system.entry.js} +2 -2
  1442. package/dist/ionic/{p-78030c1f.system.entry.js → p-9709ebd8.system.entry.js} +1 -1
  1443. package/dist/ionic/p-9738fd82.js +5 -0
  1444. package/dist/ionic/p-979d4f5c.system.js +4 -0
  1445. package/dist/ionic/{p-c4a5de01.entry.js → p-98f3d827.entry.js} +1 -1
  1446. package/dist/ionic/p-9b7f0b0f.entry.js +4 -0
  1447. package/dist/ionic/p-9e447eb1.system.js +4 -0
  1448. package/dist/ionic/p-9eec42cc.system.entry.js +4 -0
  1449. package/dist/ionic/p-9f6ee2c0.system.entry.js +4 -0
  1450. package/dist/ionic/p-a0bb7b92.system.entry.js +4 -0
  1451. package/dist/ionic/p-a0d7bb5e.system.js +4 -0
  1452. package/dist/ionic/p-a1987850.entry.js +4 -0
  1453. package/dist/ionic/{p-8209372c.entry.js → p-a3277a67.entry.js} +1 -1
  1454. package/dist/ionic/{p-4e6e43c1.entry.js → p-a4afcc88.entry.js} +1 -1
  1455. package/dist/ionic/p-a9978d08.entry.js +4 -0
  1456. package/dist/ionic/p-ada96dd0.system.entry.js +4 -0
  1457. package/dist/ionic/p-afd6ca9d.entry.js +4 -0
  1458. package/dist/ionic/p-b3b3efba.system.entry.js +4 -0
  1459. package/dist/ionic/p-b4a51c42.system.js +4 -0
  1460. package/dist/ionic/p-b56d0866.system.entry.js +4 -0
  1461. package/dist/ionic/{p-4e50b8d1.entry.js → p-b5f9f14c.entry.js} +1 -1
  1462. package/dist/ionic/{p-eab10949.system.entry.js → p-b6f5e4f2.system.entry.js} +1 -1
  1463. package/dist/ionic/p-b6f9d32a.entry.js +4 -0
  1464. package/dist/ionic/p-b7010c69.system.entry.js +4 -0
  1465. package/dist/ionic/{p-181b7c2a.js → p-c3c3333a.js} +1 -1
  1466. package/dist/ionic/p-c468af8a.system.js +4 -0
  1467. package/dist/ionic/p-c61cc894.js +4 -0
  1468. package/dist/ionic/p-c7c8429a.system.js +4 -0
  1469. package/dist/ionic/p-c847fb35.system.entry.js +4 -0
  1470. package/dist/ionic/{p-e0f52215.system.entry.js → p-c91ccbfa.system.entry.js} +1 -1
  1471. package/dist/ionic/p-c9a21dfd.system.entry.js +4 -0
  1472. package/dist/ionic/p-cabad15b.system.js +4 -0
  1473. package/dist/ionic/{p-8c1805f4.system.entry.js → p-caf21b46.system.entry.js} +1 -1
  1474. package/dist/ionic/p-cce9f61a.system.entry.js +4 -0
  1475. package/dist/ionic/{p-de68588d.js → p-cdbeaadc.js} +1 -1
  1476. package/dist/ionic/{p-108f9d49.entry.js → p-cfe57b1b.entry.js} +1 -1
  1477. package/dist/ionic/p-d032f825.system.entry.js +4 -0
  1478. package/dist/ionic/{p-31119a15.entry.js → p-d37b441e.entry.js} +1 -1
  1479. package/dist/ionic/p-d3b030b8.system.js +5 -0
  1480. package/dist/ionic/p-d51674c5.system.js +4 -0
  1481. package/dist/ionic/p-d8d84afa.system.js +4 -0
  1482. package/dist/ionic/p-dc6af8e9.entry.js +4 -0
  1483. package/dist/ionic/{p-3818f63f.entry.js → p-ddb30596.entry.js} +1 -1
  1484. package/dist/ionic/p-ddbb2d5b.system.js +4 -0
  1485. package/dist/ionic/p-de6f8b28.system.js +4 -0
  1486. package/dist/ionic/p-de756e5c.js +4 -0
  1487. package/dist/ionic/p-dee7c1d0.system.entry.js +4 -0
  1488. package/dist/ionic/{p-e0f0d55f.system.js → p-e24ce1e5.system.js} +1 -1
  1489. package/dist/ionic/p-e3584231.system.js +4 -0
  1490. package/dist/ionic/{p-c4f2dce7.system.js → p-e673a0a2.system.js} +1 -1
  1491. package/dist/ionic/p-e6d68e02.system.entry.js +4 -0
  1492. package/dist/ionic/{p-012952cd.system.entry.js → p-e7ea9815.system.entry.js} +2 -2
  1493. package/dist/ionic/{p-db1a1e00.entry.js → p-e94c392d.entry.js} +1 -1
  1494. package/dist/ionic/{p-a04bfada.entry.js → p-ea69616e.entry.js} +1 -1
  1495. package/dist/ionic/p-eef72e06.js +4 -0
  1496. package/dist/ionic/p-ef126ae8.system.entry.js +4 -0
  1497. package/dist/ionic/p-f0445d82.system.entry.js +4 -0
  1498. package/dist/ionic/p-f233f1e0.system.js +4 -0
  1499. package/dist/ionic/p-f5d2dc9b.js +4 -0
  1500. package/dist/ionic/p-f656e032.system.entry.js +4 -0
  1501. package/dist/ionic/p-f70970cf.js +4 -0
  1502. package/dist/ionic/p-f8a5bb89.entry.js +4 -0
  1503. package/dist/ionic/p-fba0a6e7.system.entry.js +4 -0
  1504. package/dist/ionic/p-feae5133.entry.js +4 -0
  1505. package/dist/ionic/p-ff4b7e40.system.js +4 -0
  1506. package/dist/types/components/accordion/accordion.d.ts +62 -62
  1507. package/dist/types/components/accordion-group/accordion-group-interface.d.ts +3 -3
  1508. package/dist/types/components/accordion-group/accordion-group.d.ts +76 -76
  1509. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +25 -25
  1510. package/dist/types/components/action-sheet/action-sheet.d.ts +149 -149
  1511. package/dist/types/components/action-sheet/test/basic/fixture.d.ts +7 -7
  1512. package/dist/types/components/alert/alert-interface.d.ts +45 -45
  1513. package/dist/types/components/alert/alert.d.ts +181 -181
  1514. package/dist/types/components/app/app.d.ts +15 -15
  1515. package/dist/types/components/avatar/avatar.d.ts +1 -1
  1516. package/dist/types/components/back-button/back-button.d.ts +41 -41
  1517. package/dist/types/components/backdrop/backdrop.d.ts +22 -22
  1518. package/dist/types/components/badge/badge.d.ts +7 -7
  1519. package/dist/types/components/breadcrumb/breadcrumb-interface.d.ts +4 -4
  1520. package/dist/types/components/breadcrumb/breadcrumb.d.ts +87 -87
  1521. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +39 -39
  1522. package/dist/types/components/button/button.d.ts +121 -121
  1523. package/dist/types/components/buttons/buttons.d.ts +14 -14
  1524. package/dist/types/components/card/card.d.ts +57 -57
  1525. package/dist/types/components/card-content/card-content.d.ts +1 -1
  1526. package/dist/types/components/card-header/card-header.d.ts +13 -13
  1527. package/dist/types/components/card-subtitle/card-subtitle.d.ts +7 -7
  1528. package/dist/types/components/card-title/card-title.d.ts +7 -7
  1529. package/dist/types/components/checkbox/checkbox-interface.d.ts +4 -4
  1530. package/dist/types/components/checkbox/checkbox.d.ts +112 -111
  1531. package/dist/types/components/chip/chip.d.ts +15 -15
  1532. package/dist/types/components/col/col.d.ts +128 -128
  1533. package/dist/types/components/content/content-interface.d.ts +6 -6
  1534. package/dist/types/components/content/content.d.ts +129 -129
  1535. package/dist/types/components/datetime/datetime-interface.d.ts +15 -15
  1536. package/dist/types/components/datetime/datetime.d.ts +407 -407
  1537. package/dist/types/components/datetime/utils/data.d.ts +11 -11
  1538. package/dist/types/components/datetime/utils/manipulation.d.ts +25 -25
  1539. package/dist/types/components/datetime/utils/state.d.ts +8 -8
  1540. package/dist/types/components/datetime-button/datetime-button.d.ts +59 -59
  1541. package/dist/types/components/fab/fab.d.ts +33 -33
  1542. package/dist/types/components/fab-button/fab-button.d.ts +88 -88
  1543. package/dist/types/components/fab-list/fab-list.d.ts +11 -11
  1544. package/dist/types/components/footer/footer.d.ts +27 -27
  1545. package/dist/types/components/grid/grid.d.ts +5 -5
  1546. package/dist/types/components/header/header.d.ts +31 -31
  1547. package/dist/types/components/header/header.utils.d.ts +7 -7
  1548. package/dist/types/components/img/img.d.ts +30 -30
  1549. package/dist/types/components/infinite-scroll/infinite-scroll-interface.d.ts +1 -1
  1550. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +65 -58
  1551. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +23 -23
  1552. package/dist/types/components/input/input-interface.d.ts +6 -6
  1553. package/dist/types/components/input/input.d.ts +321 -315
  1554. package/dist/types/components/item/item.d.ts +111 -111
  1555. package/dist/types/components/item-divider/item-divider.d.ts +16 -16
  1556. package/dist/types/components/item-group/item-group.d.ts +1 -1
  1557. package/dist/types/components/item-option/item-option.d.ts +44 -44
  1558. package/dist/types/components/item-options/item-options.d.ts +13 -13
  1559. package/dist/types/components/item-sliding/item-sliding-interface.d.ts +1 -1
  1560. package/dist/types/components/item-sliding/item-sliding.d.ts +75 -75
  1561. package/dist/types/components/label/label.d.ts +30 -30
  1562. package/dist/types/components/list/list.d.ts +17 -17
  1563. package/dist/types/components/list-header/list-header.d.ts +11 -11
  1564. package/dist/types/components/loading/loading-interface.d.ts +16 -16
  1565. package/dist/types/components/loading/loading.d.ts +152 -152
  1566. package/dist/types/components/menu/menu-interface.d.ts +39 -39
  1567. package/dist/types/components/menu/menu.d.ts +140 -140
  1568. package/dist/types/components/menu-button/menu-button.d.ts +30 -30
  1569. package/dist/types/components/menu-toggle/menu-toggle.d.ts +21 -21
  1570. package/dist/types/components/modal/animations/sheet.d.ts +4 -4
  1571. package/dist/types/components/modal/gestures/sheet.d.ts +30 -30
  1572. package/dist/types/components/modal/gestures/swipe-to-close.d.ts +1 -1
  1573. package/dist/types/components/modal/modal-interface.d.ts +27 -27
  1574. package/dist/types/components/modal/modal.d.ts +265 -265
  1575. package/dist/types/components/modal/test/fixtures.d.ts +7 -7
  1576. package/dist/types/components/nav/nav-interface.d.ts +40 -40
  1577. package/dist/types/components/nav/nav.d.ts +247 -247
  1578. package/dist/types/components/nav/view-controller.d.ts +13 -13
  1579. package/dist/types/components/nav-link/nav-link.d.ts +19 -19
  1580. package/dist/types/components/note/note.d.ts +7 -7
  1581. package/dist/types/components/picker/picker-interface.d.ts +43 -43
  1582. package/dist/types/components/picker/picker.d.ts +149 -149
  1583. package/dist/types/components/picker-column/picker-column.d.ts +39 -39
  1584. package/dist/types/components/picker-column-internal/picker-column-internal-interfaces.d.ts +3 -3
  1585. package/dist/types/components/picker-column-internal/picker-column-internal.d.ts +93 -89
  1586. package/dist/types/components/picker-internal/picker-internal-interfaces.d.ts +4 -4
  1587. package/dist/types/components/picker-internal/picker-internal.d.ts +94 -94
  1588. package/dist/types/components/popover/popover-interface.d.ts +26 -26
  1589. package/dist/types/components/popover/popover.d.ts +279 -279
  1590. package/dist/types/components/popover/test/fixture.d.ts +5 -5
  1591. package/dist/types/components/popover/utils.d.ts +25 -25
  1592. package/dist/types/components/progress-bar/progress-bar.d.ts +27 -27
  1593. package/dist/types/components/radio/radio.d.ts +100 -99
  1594. package/dist/types/components/radio-group/radio-group-interface.d.ts +5 -4
  1595. package/dist/types/components/radio-group/radio-group.d.ts +51 -44
  1596. package/dist/types/components/radio-group/test/fixtures.d.ts +5 -5
  1597. package/dist/types/components/range/range-interface.d.ts +7 -7
  1598. package/dist/types/components/range/range.d.ts +193 -192
  1599. package/dist/types/components/refresher/refresher-interface.d.ts +3 -3
  1600. package/dist/types/components/refresher/refresher.d.ts +132 -132
  1601. package/dist/types/components/refresher-content/refresher-content.d.ts +44 -44
  1602. package/dist/types/components/reorder/reorder.d.ts +3 -3
  1603. package/dist/types/components/reorder-group/reorder-group-interface.d.ts +5 -5
  1604. package/dist/types/components/reorder-group/reorder-group.d.ts +53 -53
  1605. package/dist/types/components/ripple-effect/ripple-effect.d.ts +20 -20
  1606. package/dist/types/components/route/route-interface.d.ts +1 -1
  1607. package/dist/types/components/route/route.d.ts +43 -43
  1608. package/dist/types/components/route-redirect/route-redirect.d.ts +33 -33
  1609. package/dist/types/components/router/router.d.ts +74 -73
  1610. package/dist/types/components/router/utils/dom.d.ts +2 -2
  1611. package/dist/types/components/router/utils/interface.d.ts +31 -31
  1612. package/dist/types/components/router/utils/matching.d.ts +6 -6
  1613. package/dist/types/components/router-link/router-link.d.ts +34 -34
  1614. package/dist/types/components/router-outlet/router-outlet.d.ts +41 -41
  1615. package/dist/types/components/row/row.d.ts +1 -1
  1616. package/dist/types/components/searchbar/searchbar-interface.d.ts +6 -6
  1617. package/dist/types/components/searchbar/searchbar.d.ts +235 -233
  1618. package/dist/types/components/segment/segment-interface.d.ts +3 -3
  1619. package/dist/types/components/segment/segment.d.ts +82 -82
  1620. package/dist/types/components/segment-button/segment-button.d.ts +36 -36
  1621. package/dist/types/components/select/select-interface.d.ts +3 -3
  1622. package/dist/types/components/select/select.d.ts +238 -233
  1623. package/dist/types/components/select-option/select-option.d.ts +11 -11
  1624. package/dist/types/components/select-popover/select-popover-interface.d.ts +8 -8
  1625. package/dist/types/components/select-popover/select-popover.d.ts +39 -39
  1626. package/dist/types/components/select-popover/test/fixtures.d.ts +12 -12
  1627. package/dist/types/components/skeleton-text/skeleton-text.d.ts +15 -7
  1628. package/dist/types/components/spinner/spinner-configs.d.ts +96 -96
  1629. package/dist/types/components/spinner/spinner-interface.d.ts +14 -14
  1630. package/dist/types/components/spinner/spinner.d.ts +21 -21
  1631. package/dist/types/components/split-pane/split-pane.d.ts +33 -33
  1632. package/dist/types/components/tab/tab.d.ts +21 -21
  1633. package/dist/types/components/tab-bar/tab-bar-interface.d.ts +4 -4
  1634. package/dist/types/components/tab-bar/tab-bar.d.ts +34 -34
  1635. package/dist/types/components/tab-button/tab-button.d.ts +56 -56
  1636. package/dist/types/components/tabs/tabs-interface.d.ts +4 -4
  1637. package/dist/types/components/tabs/tabs.d.ts +52 -52
  1638. package/dist/types/components/text/text.d.ts +7 -7
  1639. package/dist/types/components/textarea/textarea-interface.d.ts +6 -6
  1640. package/dist/types/components/textarea/textarea.d.ts +275 -269
  1641. package/dist/types/components/thumbnail/thumbnail.d.ts +1 -1
  1642. package/dist/types/components/title/title.d.ts +21 -21
  1643. package/dist/types/components/toast/animations/utils.d.ts +15 -4
  1644. package/dist/types/components/toast/gestures/swipe-to-dismiss.d.ts +9 -0
  1645. package/dist/types/components/toast/toast-interface.d.ts +37 -35
  1646. package/dist/types/components/toast/toast.d.ts +241 -214
  1647. package/dist/types/components/toggle/toggle-interface.d.ts +4 -4
  1648. package/dist/types/components/toggle/toggle.d.ts +117 -116
  1649. package/dist/types/components/toolbar/toolbar.d.ts +11 -11
  1650. package/dist/types/components.d.ts +679 -16
  1651. package/dist/types/global/config.d.ts +6 -6
  1652. package/dist/types/interface.d.ts +1 -5
  1653. package/dist/types/jest.d.ts +5 -0
  1654. package/dist/types/stencil-public-runtime.d.ts +10 -0
  1655. package/dist/types/utils/animation/animation-interface.d.ts +205 -205
  1656. package/dist/types/utils/browser/index.d.ts +17 -8
  1657. package/dist/types/utils/config.d.ts +175 -175
  1658. package/dist/types/utils/content/index.d.ts +1 -1
  1659. package/dist/types/utils/element-interface.d.ts +6 -6
  1660. package/dist/types/utils/focus-visible.d.ts +5 -4
  1661. package/dist/types/utils/forms/compare-with-utils.d.ts +18 -0
  1662. package/dist/types/utils/forms/form-controller.d.ts +3 -3
  1663. package/dist/types/utils/forms/index.d.ts +1 -0
  1664. package/dist/types/utils/forms/notch-controller.d.ts +2 -2
  1665. package/dist/types/utils/framework-delegate.d.ts +3 -3
  1666. package/dist/types/utils/gesture/gesture-controller.d.ts +49 -49
  1667. package/dist/types/utils/gesture/index.d.ts +31 -31
  1668. package/dist/types/utils/gesture/listener.d.ts +2 -2
  1669. package/dist/types/utils/gesture/pointer-events.d.ts +12 -12
  1670. package/dist/types/utils/gesture/recognizers.d.ts +4 -4
  1671. package/dist/types/utils/hardware-back-button.d.ts +4 -0
  1672. package/dist/types/utils/helpers.d.ts +8 -8
  1673. package/dist/types/utils/input-shims/hacks/scroll-data.d.ts +4 -4
  1674. package/dist/types/utils/keyboard/keyboard-controller.d.ts +3 -3
  1675. package/dist/types/utils/lock-controller.d.ts +1 -1
  1676. package/dist/types/utils/native/haptic.d.ts +38 -38
  1677. package/dist/types/utils/native/keyboard.d.ts +29 -29
  1678. package/dist/types/utils/native/native-interface.d.ts +15 -15
  1679. package/dist/types/utils/native/status-bar.d.ts +8 -8
  1680. package/dist/types/utils/overlays-interface.d.ts +27 -27
  1681. package/dist/types/utils/overlays.d.ts +29 -28
  1682. package/dist/types/utils/platform.d.ts +16 -16
  1683. package/dist/types/utils/sanitization/index.d.ts +2 -2
  1684. package/dist/types/utils/slot-mutation-controller.d.ts +3 -3
  1685. package/dist/types/utils/test/platform.utils.d.ts +67 -67
  1686. package/dist/types/utils/test/playwright/generator.d.ts +16 -7
  1687. package/dist/types/utils/test/playwright/matchers/index.d.ts +3 -3
  1688. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEvent.d.ts +2 -2
  1689. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventDetail.d.ts +2 -2
  1690. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventTimes.d.ts +2 -2
  1691. package/dist/types/utils/test/playwright/page/event-spy.d.ts +15 -15
  1692. package/dist/types/utils/test/playwright/page/utils/goto.d.ts +3 -3
  1693. package/dist/types/utils/test/playwright/page/utils/locator.d.ts +15 -15
  1694. package/dist/types/utils/test/playwright/playwright-declarations.d.ts +92 -92
  1695. package/dist/types/utils/test/playwright/playwright-page.d.ts +3 -3
  1696. package/dist/types/utils/test/playwright/viewports/index.d.ts +12 -12
  1697. package/dist/types/utils/test/press-keys.d.ts +14 -14
  1698. package/dist/types/utils/transition/index.d.ts +6 -6
  1699. package/dist/types/utils/watch-options.d.ts +9 -1
  1700. package/hydrate/index.d.ts +1 -1
  1701. package/hydrate/index.js +30673 -29948
  1702. package/package.json +10 -12
  1703. package/dist/cjs/animation-c8bdd3c7.js +0 -1046
  1704. package/dist/cjs/button-active-c0ff1915.js +0 -69
  1705. package/dist/cjs/config-d5882735.js +0 -199
  1706. package/dist/cjs/cubic-bezier-6b9222ad.js +0 -92
  1707. package/dist/cjs/data-c8d21093.js +0 -1622
  1708. package/dist/cjs/focus-visible-a7545600.js +0 -77
  1709. package/dist/cjs/form-controller-5e223b54.js +0 -70
  1710. package/dist/cjs/framework-delegate-c0873a6f.js +0 -144
  1711. package/dist/cjs/gesture-controller-b46721be.js +0 -197
  1712. package/dist/cjs/haptic-678abc9f.js +0 -212
  1713. package/dist/cjs/hardware-back-button-b67c8e75.js +0 -76
  1714. package/dist/cjs/helpers-ea4ccbcb.js +0 -441
  1715. package/dist/cjs/index-0ee995e4.js +0 -459
  1716. package/dist/cjs/index-306a7476.js +0 -32
  1717. package/dist/cjs/index-5e7529f6.js +0 -310
  1718. package/dist/cjs/index-9f379eaa.js +0 -198
  1719. package/dist/cjs/index-eccba000.js +0 -243
  1720. package/dist/cjs/input-shims-da7dc0de.js +0 -588
  1721. package/dist/cjs/input.utils-0fe3097c.js +0 -137
  1722. package/dist/cjs/ionic-global-fb752503.js +0 -230
  1723. package/dist/cjs/ios.transition-5af5991e.js +0 -654
  1724. package/dist/cjs/keyboard-controller-50beb83a.js +0 -167
  1725. package/dist/cjs/keyboard-fd7db491.js +0 -81
  1726. package/dist/cjs/lock-controller-4ae2eb59.js +0 -40
  1727. package/dist/cjs/md.transition-1e740a6a.js +0 -59
  1728. package/dist/cjs/notch-controller-f4f6af5d.js +0 -155
  1729. package/dist/cjs/overlays-1a734051.js +0 -714
  1730. package/dist/cjs/spinner-configs-f7b5105b.js +0 -147
  1731. package/dist/cjs/status-tap-778e8054.js +0 -42
  1732. package/dist/cjs/swipe-back-7e843e77.js +0 -81
  1733. package/dist/cjs/theme-fbc56b3b.js +0 -48
  1734. package/dist/cjs/watch-options-f3f77e54.js +0 -38
  1735. package/dist/collection/components/item/test/text/item.e2e.js +0 -14
  1736. package/dist/esm/animation-92066c62.js +0 -1044
  1737. package/dist/esm/button-active-d926d4f4.js +0 -67
  1738. package/dist/esm/capacitor-b4979570.js +0 -13
  1739. package/dist/esm/config-96c9ace3.js +0 -193
  1740. package/dist/esm/cubic-bezier-66542bc5.js +0 -90
  1741. package/dist/esm/data-44d9e816.js +0 -1575
  1742. package/dist/esm/focus-visible-85493433.js +0 -75
  1743. package/dist/esm/form-controller-ed77647a.js +0 -68
  1744. package/dist/esm/framework-delegate-aa433dea.js +0 -140
  1745. package/dist/esm/gesture-controller-0fa396c4.js +0 -195
  1746. package/dist/esm/haptic-1243b917.js +0 -206
  1747. package/dist/esm/hardware-back-button-39299f84.js +0 -71
  1748. package/dist/esm/helpers-3379ba19.js +0 -418
  1749. package/dist/esm/index-7a14ecec.js +0 -29
  1750. package/dist/esm/index-a09eac70.js +0 -231
  1751. package/dist/esm/index-df55802d.js +0 -308
  1752. package/dist/esm/index-f0cc4e14.js +0 -196
  1753. package/dist/esm/index-ff313b19.js +0 -457
  1754. package/dist/esm/input-shims-d78a3c77.js +0 -586
  1755. package/dist/esm/input.utils-ec063df4.js +0 -134
  1756. package/dist/esm/ionic-global-246ca78f.js +0 -224
  1757. package/dist/esm/ios.transition-4d1322d6.js +0 -651
  1758. package/dist/esm/keyboard-b063f012.js +0 -79
  1759. package/dist/esm/keyboard-b551279d.js +0 -146
  1760. package/dist/esm/keyboard-controller-0c2dce71.js +0 -165
  1761. package/dist/esm/lock-controller-e8c6c051.js +0 -38
  1762. package/dist/esm/md.transition-66b425d0.js +0 -57
  1763. package/dist/esm/notch-controller-8c9c0e54.js +0 -153
  1764. package/dist/esm/overlays-cec6bac8.js +0 -692
  1765. package/dist/esm/spinner-configs-d09fbbbb.js +0 -145
  1766. package/dist/esm/status-tap-9aeeaca5.js +0 -40
  1767. package/dist/esm/swipe-back-cd4295f3.js +0 -79
  1768. package/dist/esm/theme-17531cdf.js +0 -43
  1769. package/dist/esm/watch-options-355a920a.js +0 -36
  1770. package/dist/esm-es5/animation-92066c62.js +0 -4
  1771. package/dist/esm-es5/app-globals-ec816a70.js +0 -4
  1772. package/dist/esm-es5/config-96c9ace3.js +0 -4
  1773. package/dist/esm-es5/cubic-bezier-66542bc5.js +0 -4
  1774. package/dist/esm-es5/data-44d9e816.js +0 -4
  1775. package/dist/esm-es5/focus-visible-85493433.js +0 -4
  1776. package/dist/esm-es5/form-controller-ed77647a.js +0 -4
  1777. package/dist/esm-es5/framework-delegate-aa433dea.js +0 -4
  1778. package/dist/esm-es5/hardware-back-button-39299f84.js +0 -4
  1779. package/dist/esm-es5/helpers-3379ba19.js +0 -4
  1780. package/dist/esm-es5/index-746a238e.js +0 -4
  1781. package/dist/esm-es5/index-b49b173c.js +0 -5
  1782. package/dist/esm-es5/index-df55802d.js +0 -4
  1783. package/dist/esm-es5/index-f0cc4e14.js +0 -4
  1784. package/dist/esm-es5/index-ff313b19.js +0 -4
  1785. package/dist/esm-es5/input-shims-d78a3c77.js +0 -4
  1786. package/dist/esm-es5/input.utils-ec063df4.js +0 -4
  1787. package/dist/esm-es5/ionic-global-246ca78f.js +0 -4
  1788. package/dist/esm-es5/keyboard-controller-0c2dce71.js +0 -4
  1789. package/dist/esm-es5/md.transition-66b425d0.js +0 -4
  1790. package/dist/esm-es5/notch-controller-8c9c0e54.js +0 -4
  1791. package/dist/esm-es5/overlays-cec6bac8.js +0 -4
  1792. package/dist/esm-es5/spinner-configs-d09fbbbb.js +0 -4
  1793. package/dist/esm-es5/status-tap-9aeeaca5.js +0 -4
  1794. package/dist/esm-es5/swipe-back-cd4295f3.js +0 -4
  1795. package/dist/esm-es5/watch-options-355a920a.js +0 -4
  1796. package/dist/ionic/p-015187e5.system.js +0 -4
  1797. package/dist/ionic/p-06ac429a.js +0 -5
  1798. package/dist/ionic/p-091c8792.system.js +0 -4
  1799. package/dist/ionic/p-0b7c25ee.system.entry.js +0 -4
  1800. package/dist/ionic/p-0f1f59da.system.entry.js +0 -4
  1801. package/dist/ionic/p-19fba51c.entry.js +0 -4
  1802. package/dist/ionic/p-1a463b1e.system.entry.js +0 -4
  1803. package/dist/ionic/p-1edb53a1.entry.js +0 -4
  1804. package/dist/ionic/p-1f260a7b.entry.js +0 -4
  1805. package/dist/ionic/p-1f81b5be.entry.js +0 -4
  1806. package/dist/ionic/p-276afddd.js +0 -4
  1807. package/dist/ionic/p-28ea45b9.js +0 -4
  1808. package/dist/ionic/p-29073efe.system.entry.js +0 -4
  1809. package/dist/ionic/p-2b89ea1b.system.js +0 -4
  1810. package/dist/ionic/p-303bf1e8.system.entry.js +0 -4
  1811. package/dist/ionic/p-32083c2d.js +0 -4
  1812. package/dist/ionic/p-33a8349a.system.entry.js +0 -4
  1813. package/dist/ionic/p-34259245.system.entry.js +0 -4
  1814. package/dist/ionic/p-35b26732.entry.js +0 -4
  1815. package/dist/ionic/p-35e399bd.entry.js +0 -4
  1816. package/dist/ionic/p-3632220b.system.js +0 -4
  1817. package/dist/ionic/p-38089641.entry.js +0 -4
  1818. package/dist/ionic/p-38c5fe2b.system.entry.js +0 -4
  1819. package/dist/ionic/p-3a58e3a4.system.entry.js +0 -4
  1820. package/dist/ionic/p-3d726a67.system.js +0 -4
  1821. package/dist/ionic/p-3f3da911.system.entry.js +0 -4
  1822. package/dist/ionic/p-41477ad9.system.js +0 -4
  1823. package/dist/ionic/p-4215652f.system.entry.js +0 -4
  1824. package/dist/ionic/p-446230d7.js +0 -4
  1825. package/dist/ionic/p-44bc8b45.system.js +0 -4
  1826. package/dist/ionic/p-479cdbf8.system.js +0 -4
  1827. package/dist/ionic/p-4f97c112.entry.js +0 -4
  1828. package/dist/ionic/p-54200074.entry.js +0 -4
  1829. package/dist/ionic/p-54f6cd27.system.entry.js +0 -4
  1830. package/dist/ionic/p-56dc022e.system.js +0 -4
  1831. package/dist/ionic/p-572cce26.system.entry.js +0 -4
  1832. package/dist/ionic/p-5b976d70.entry.js +0 -4
  1833. package/dist/ionic/p-5bf16a18.js +0 -4
  1834. package/dist/ionic/p-613d4042.system.js +0 -4
  1835. package/dist/ionic/p-629aa3fd.system.js +0 -5
  1836. package/dist/ionic/p-62e7d4fa.js +0 -4
  1837. package/dist/ionic/p-64475ab5.system.js +0 -4
  1838. package/dist/ionic/p-673846f6.entry.js +0 -4
  1839. package/dist/ionic/p-6ce0a709.system.entry.js +0 -4
  1840. package/dist/ionic/p-755b2917.system.js +0 -4
  1841. package/dist/ionic/p-772f6c84.system.js +0 -4
  1842. package/dist/ionic/p-815c2fba.system.js +0 -4
  1843. package/dist/ionic/p-818b2e75.entry.js +0 -4
  1844. package/dist/ionic/p-81c818e7.js +0 -4
  1845. package/dist/ionic/p-81ef7437.system.entry.js +0 -4
  1846. package/dist/ionic/p-87411e39.system.js +0 -4
  1847. package/dist/ionic/p-8b1be026.js +0 -4
  1848. package/dist/ionic/p-8c15eda7.system.js +0 -4
  1849. package/dist/ionic/p-8cf94fc1.js +0 -4
  1850. package/dist/ionic/p-8d6728a1.system.entry.js +0 -4
  1851. package/dist/ionic/p-8e24ebbc.js +0 -4
  1852. package/dist/ionic/p-8f01a9a2.system.js +0 -4
  1853. package/dist/ionic/p-939e0fa1.system.js +0 -4
  1854. package/dist/ionic/p-9ab6f3e6.system.js +0 -4
  1855. package/dist/ionic/p-9dc85536.system.entry.js +0 -4
  1856. package/dist/ionic/p-9e852ff1.system.js +0 -4
  1857. package/dist/ionic/p-9f2e0db9.js +0 -4
  1858. package/dist/ionic/p-a164e3ab.system.entry.js +0 -4
  1859. package/dist/ionic/p-a200a7fc.entry.js +0 -4
  1860. package/dist/ionic/p-a34fc12e.system.entry.js +0 -4
  1861. package/dist/ionic/p-a9c32660.entry.js +0 -4
  1862. package/dist/ionic/p-ab4cff27.system.js +0 -4
  1863. package/dist/ionic/p-ad48dd13.system.js +0 -4
  1864. package/dist/ionic/p-afb6658f.entry.js +0 -4
  1865. package/dist/ionic/p-b132c2c0.system.js +0 -4
  1866. package/dist/ionic/p-b24aa895.js +0 -4
  1867. package/dist/ionic/p-b3c68723.system.js +0 -4
  1868. package/dist/ionic/p-b4b4bb29.system.js +0 -4
  1869. package/dist/ionic/p-b61a2fa0.system.entry.js +0 -4
  1870. package/dist/ionic/p-b753ec0d.system.entry.js +0 -4
  1871. package/dist/ionic/p-b8c3f071.system.js +0 -4
  1872. package/dist/ionic/p-b912e055.system.js +0 -4
  1873. package/dist/ionic/p-bb055450.system.entry.js +0 -4
  1874. package/dist/ionic/p-bba2ce59.system.js +0 -4
  1875. package/dist/ionic/p-c105bd36.entry.js +0 -4
  1876. package/dist/ionic/p-c44fe9fd.js +0 -4
  1877. package/dist/ionic/p-c49672d8.system.js +0 -4
  1878. package/dist/ionic/p-c87827ca.system.js +0 -4
  1879. package/dist/ionic/p-c8c9d699.system.entry.js +0 -4
  1880. package/dist/ionic/p-c92f0a6d.system.entry.js +0 -4
  1881. package/dist/ionic/p-c956e82c.system.entry.js +0 -4
  1882. package/dist/ionic/p-ca5cf574.js +0 -4
  1883. package/dist/ionic/p-cc196b34.js +0 -4
  1884. package/dist/ionic/p-ccdcb022.system.js +0 -4
  1885. package/dist/ionic/p-cd2d17c3.system.entry.js +0 -4
  1886. package/dist/ionic/p-cf0c93e3.system.entry.js +0 -4
  1887. package/dist/ionic/p-d1de1188.js +0 -4
  1888. package/dist/ionic/p-d35217be.entry.js +0 -4
  1889. package/dist/ionic/p-d6e53e66.entry.js +0 -4
  1890. package/dist/ionic/p-e1d5752d.system.entry.js +0 -4
  1891. package/dist/ionic/p-e25cb483.entry.js +0 -4
  1892. package/dist/ionic/p-e65ebe96.entry.js +0 -4
  1893. package/dist/ionic/p-e74faf2a.entry.js +0 -4
  1894. package/dist/ionic/p-eac263dd.entry.js +0 -4
  1895. package/dist/ionic/p-eb7d0922.js +0 -4
  1896. package/dist/ionic/p-f4309ac7.entry.js +0 -4
  1897. package/dist/ionic/p-f5bf698b.entry.js +0 -4
  1898. package/dist/ionic/p-f7566bad.entry.js +0 -4
  1899. package/dist/ionic/p-f9fa802c.system.entry.js +0 -4
  1900. package/dist/ionic/p-fa8d4788.system.js +0 -4
  1901. package/dist/ionic/p-ff5a10f9.system.js +0 -4
  1902. /package/dist/esm-es5/{index-595d62c9.js → index-9b0d46f4.js} +0 -0
  1903. /package/dist/esm-es5/{index-7a14ecec.js → index-a5d50daf.js} +0 -0
  1904. /package/dist/esm-es5/{lock-controller-e8c6c051.js → lock-controller-316928be.js} +0 -0
  1905. /package/dist/esm-es5/{theme-17531cdf.js → theme-01f3f29c.js} +0 -0
  1906. /package/dist/ionic/{p-1b8e1d03.js → p-06fee233.js} +0 -0
  1907. /package/dist/ionic/{p-63eb0acd.js → p-23a9d086.js} +0 -0
  1908. /package/dist/ionic/{p-7c2bac85.js → p-2408c236.js} +0 -0
  1909. /package/dist/ionic/{p-7b021525.js → p-41d5544e.js} +0 -0
  1910. /package/dist/ionic/{p-1d072d3d.js → p-47794def.js} +0 -0
  1911. /package/dist/ionic/{p-185e427e.js → p-4b3623da.js} +0 -0
  1912. /package/dist/ionic/{p-0e94957a.system.js → p-792919fd.system.js} +0 -0
  1913. /package/dist/ionic/{p-b347cfd1.js → p-7b30edcc.js} +0 -0
  1914. /package/dist/ionic/{p-e0b06b65.js → p-bb3615f7.js} +0 -0
  1915. /package/dist/ionic/{p-53b2a46f.js → p-ccd02320.js} +0 -0
  1916. /package/dist/ionic/{p-76fce40e.js → p-d47265c8.js} +0 -0
  1917. /package/dist/ionic/{p-c18d6eac.js → p-f0c2a614.js} +0 -0
  1918. /package/dist/ionic/{p-6dbfe5d4.js → p-fb813dab.js} +0 -0
@@ -41,2289 +41,2327 @@ import { getCalendarDayState, getHighlightStyles, isDayDisabled, isMonthDisabled
41
41
  * @part calendar-day disabled - The calendar day that is disabled.
42
42
  */
43
43
  export class Datetime {
44
- constructor() {
45
- this.inputId = `ion-dt-${datetimeIds++}`;
46
- this.prevPresentation = null;
47
- this.warnIfIncorrectValueUsage = () => {
48
- const { multiple, value } = this;
49
- if (!multiple && Array.isArray(value)) {
50
- /**
51
- * We do some processing on the `value` array so
52
- * that it looks more like an array when logged to
53
- * the console.
54
- * Example given ['a', 'b']
55
- * Default toString() behavior: a,b
56
- * Custom behavior: ['a', 'b']
57
- */
58
- 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".
44
+ constructor() {
45
+ this.inputId = `ion-dt-${datetimeIds++}`;
46
+ this.prevPresentation = null;
47
+ this.warnIfIncorrectValueUsage = () => {
48
+ const { multiple, value } = this;
49
+ if (!multiple && Array.isArray(value)) {
50
+ /**
51
+ * We do some processing on the `value` array so
52
+ * that it looks more like an array when logged to
53
+ * the console.
54
+ * Example given ['a', 'b']
55
+ * Default toString() behavior: a,b
56
+ * Custom behavior: ['a', 'b']
57
+ */
58
+ 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".
59
59
 
60
60
  Value Passed: [${value.map((v) => `'${v}'`).join(', ')}]
61
61
  `, this.el);
62
- }
63
- };
64
- this.setValue = (value) => {
65
- this.value = value;
66
- this.ionChange.emit({ value });
67
- };
68
- /**
69
- * Returns the DatetimePart interface
70
- * to use when rendering an initial set of
71
- * data. This should be used when rendering an
72
- * interface in an environment where the `value`
73
- * may not be set. This function works
74
- * by returning the first selected date and then
75
- * falling back to defaultParts if no active date
76
- * is selected.
77
- */
78
- this.getActivePartsWithFallback = () => {
79
- var _a;
80
- const { defaultParts } = this;
81
- return (_a = this.getActivePart()) !== null && _a !== void 0 ? _a : defaultParts;
82
- };
83
- this.getActivePart = () => {
84
- const { activeParts } = this;
85
- return Array.isArray(activeParts) ? activeParts[0] : activeParts;
86
- };
87
- this.closeParentOverlay = () => {
88
- const popoverOrModal = this.el.closest('ion-modal, ion-popover');
89
- if (popoverOrModal) {
90
- popoverOrModal.dismiss();
91
- }
92
- };
93
- this.setWorkingParts = (parts) => {
94
- this.workingParts = Object.assign({}, parts);
95
- };
96
- this.setActiveParts = (parts, removeDate = false) => {
97
- const { multiple, minParts, maxParts, activeParts } = this;
98
- /**
99
- * When setting the active parts, it is possible
100
- * to set invalid data. For example,
101
- * when updating January 31 to February,
102
- * February 31 does not exist. As a result
103
- * we need to validate the active parts and
104
- * ensure that we are only setting valid dates.
105
- * Additionally, we need to update the working parts
106
- * too in the event that the validated parts are different.
107
- */
108
- const validatedParts = validateParts(parts, minParts, maxParts);
109
- this.setWorkingParts(validatedParts);
110
- if (multiple) {
111
- const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
112
- if (removeDate) {
113
- this.activeParts = activePartsArray.filter((p) => !isSameDay(p, validatedParts));
114
- }
115
- else {
116
- this.activeParts = [...activePartsArray, validatedParts];
117
- }
118
- }
119
- else {
120
- this.activeParts = Object.assign({}, validatedParts);
121
- }
122
- const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
123
- if (hasSlottedButtons || this.showDefaultButtons) {
124
- return;
125
- }
126
- this.confirm();
127
- };
128
- this.initializeKeyboardListeners = () => {
129
- const calendarBodyRef = this.calendarBodyRef;
130
- if (!calendarBodyRef) {
131
- return;
132
- }
133
- const root = this.el.shadowRoot;
134
- /**
135
- * Get a reference to the month
136
- * element we are currently viewing.
137
- */
138
- const currentMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(2)');
139
- /**
140
- * When focusing the calendar body, we want to pass focus
141
- * to the working day, but other days should
142
- * only be accessible using the arrow keys. Pressing
143
- * Tab should jump between bodies of selectable content.
144
- */
145
- const checkCalendarBodyFocus = (ev) => {
146
- var _a;
147
- const record = ev[0];
148
- /**
149
- * If calendar body was already focused
150
- * when this fired or if the calendar body
151
- * if not currently focused, we should not re-focus
152
- * the inner day.
153
- */
154
- if (((_a = record.oldValue) === null || _a === void 0 ? void 0 : _a.includes('ion-focused')) || !calendarBodyRef.classList.contains('ion-focused')) {
155
- return;
156
- }
157
- this.focusWorkingDay(currentMonth);
158
- };
159
- const mo = new MutationObserver(checkCalendarBodyFocus);
160
- mo.observe(calendarBodyRef, { attributeFilter: ['class'], attributeOldValue: true });
161
- this.destroyKeyboardMO = () => {
162
- mo === null || mo === void 0 ? void 0 : mo.disconnect();
163
- };
164
- /**
165
- * We must use keydown not keyup as we want
166
- * to prevent scrolling when using the arrow keys.
167
- */
168
- calendarBodyRef.addEventListener('keydown', (ev) => {
169
- const activeElement = root.activeElement;
170
- if (!activeElement || !activeElement.classList.contains('calendar-day')) {
171
- return;
172
- }
173
- const parts = getPartsFromCalendarDay(activeElement);
174
- let partsToFocus;
175
- switch (ev.key) {
176
- case 'ArrowDown':
177
- ev.preventDefault();
178
- partsToFocus = getNextWeek(parts);
179
- break;
180
- case 'ArrowUp':
181
- ev.preventDefault();
182
- partsToFocus = getPreviousWeek(parts);
183
- break;
184
- case 'ArrowRight':
185
- ev.preventDefault();
186
- partsToFocus = getNextDay(parts);
187
- break;
188
- case 'ArrowLeft':
189
- ev.preventDefault();
190
- partsToFocus = getPreviousDay(parts);
191
- break;
192
- case 'Home':
193
- ev.preventDefault();
194
- partsToFocus = getStartOfWeek(parts);
195
- break;
196
- case 'End':
197
- ev.preventDefault();
198
- partsToFocus = getEndOfWeek(parts);
199
- break;
200
- case 'PageUp':
201
- ev.preventDefault();
202
- partsToFocus = ev.shiftKey ? getPreviousYear(parts) : getPreviousMonth(parts);
203
- break;
204
- case 'PageDown':
205
- ev.preventDefault();
206
- partsToFocus = ev.shiftKey ? getNextYear(parts) : getNextMonth(parts);
207
- break;
208
- /**
209
- * Do not preventDefault here
210
- * as we do not want to override other
211
- * browser defaults such as pressing Enter/Space
212
- * to select a day.
213
- */
214
- default:
215
- return;
216
- }
217
- /**
218
- * If the day we want to move focus to is
219
- * disabled, do not do anything.
220
- */
221
- if (isDayDisabled(partsToFocus, this.minParts, this.maxParts)) {
222
- return;
223
- }
224
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), partsToFocus));
62
+ }
63
+ };
64
+ this.setValue = (value) => {
65
+ this.value = value;
66
+ this.ionChange.emit({ value });
67
+ };
225
68
  /**
226
- * Give view a chance to re-render
227
- * then move focus to the new working day
69
+ * Returns the DatetimePart interface
70
+ * to use when rendering an initial set of
71
+ * data. This should be used when rendering an
72
+ * interface in an environment where the `value`
73
+ * may not be set. This function works
74
+ * by returning the first selected date and then
75
+ * falling back to defaultParts if no active date
76
+ * is selected.
228
77
  */
229
- requestAnimationFrame(() => this.focusWorkingDay(currentMonth));
230
- });
231
- };
232
- this.focusWorkingDay = (currentMonth) => {
233
- /**
234
- * Get the number of padding days so
235
- * we know how much to offset our next selector by
236
- * to grab the correct calendar-day element.
237
- */
238
- const padding = currentMonth.querySelectorAll('.calendar-day-padding');
239
- const { day } = this.workingParts;
240
- if (day === null) {
241
- return;
242
- }
243
- /**
244
- * Get the calendar day element
245
- * and focus it.
246
- */
247
- const dayEl = currentMonth.querySelector(`.calendar-day-wrapper:nth-of-type(${padding.length + day}) .calendar-day`);
248
- if (dayEl) {
249
- dayEl.focus();
250
- }
251
- };
252
- this.processMinParts = () => {
253
- const { min, defaultParts } = this;
254
- if (min === undefined) {
255
- this.minParts = undefined;
256
- return;
257
- }
258
- this.minParts = parseMinParts(min, defaultParts);
259
- };
260
- this.processMaxParts = () => {
261
- const { max, defaultParts } = this;
262
- if (max === undefined) {
263
- this.maxParts = undefined;
264
- return;
265
- }
266
- this.maxParts = parseMaxParts(max, defaultParts);
267
- };
268
- this.initializeCalendarListener = () => {
269
- const calendarBodyRef = this.calendarBodyRef;
270
- if (!calendarBodyRef) {
271
- return;
272
- }
273
- /**
274
- * For performance reasons, we only render 3
275
- * months at a time: The current month, the previous
276
- * month, and the next month. We have a scroll listener
277
- * on the calendar body to append/prepend new months.
278
- *
279
- * We can do this because Stencil is smart enough to not
280
- * re-create the .calendar-month containers, but rather
281
- * update the content within those containers.
282
- *
283
- * As an added bonus, WebKit has some troubles with
284
- * scroll-snap-stop: always, so not rendering all of
285
- * the months in a row allows us to mostly sidestep
286
- * that issue.
287
- */
288
- const months = calendarBodyRef.querySelectorAll('.calendar-month');
289
- const startMonth = months[0];
290
- const workingMonth = months[1];
291
- const endMonth = months[2];
292
- const mode = getIonMode(this);
293
- const needsiOSRubberBandFix = mode === 'ios' && typeof navigator !== 'undefined' && navigator.maxTouchPoints > 1;
294
- /**
295
- * Before setting up the scroll listener,
296
- * scroll the middle month into view.
297
- * scrollIntoView() will scroll entire page
298
- * if element is not in viewport. Use scrollLeft instead.
299
- */
300
- writeTask(() => {
301
- calendarBodyRef.scrollLeft = startMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
302
- const getChangedMonth = (parts) => {
303
- const box = calendarBodyRef.getBoundingClientRect();
304
- /**
305
- * If the current scroll position is all the way to the left
306
- * then we have scrolled to the previous month.
307
- * Otherwise, assume that we have scrolled to the next
308
- * month. We have a tolerance of 2px to account for
309
- * sub pixel rendering.
310
- *
311
- * Check below the next line ensures that we did not
312
- * swipe and abort (i.e. we swiped but we are still on the current month).
313
- */
314
- const month = calendarBodyRef.scrollLeft <= 2 ? startMonth : endMonth;
315
- /**
316
- * The edge of the month must be lined up with
317
- * the edge of the calendar body in order for
318
- * the component to update. Otherwise, it
319
- * may be the case that the user has paused their
320
- * swipe or the browser has not finished snapping yet.
321
- * Rather than check if the x values are equal,
322
- * we give it a tolerance of 2px to account for
323
- * sub pixel rendering.
324
- */
325
- const monthBox = month.getBoundingClientRect();
326
- if (Math.abs(monthBox.x - box.x) > 2)
327
- return;
328
- /**
329
- * If we're force-rendering a month, assume we've
330
- * scrolled to that and return it.
331
- *
332
- * If forceRenderDate is ever used in a context where the
333
- * forced month is not immediately auto-scrolled to, this
334
- * should be updated to also check whether `month` has the
335
- * same month and year as the forced date.
336
- */
337
- const { forceRenderDate } = this;
338
- if (forceRenderDate !== undefined) {
339
- return { month: forceRenderDate.month, year: forceRenderDate.year, day: forceRenderDate.day };
340
- }
341
- /**
342
- * From here, we can determine if the start
343
- * month or the end month was scrolled into view.
344
- * If no month was changed, then we can return from
345
- * the scroll callback early.
346
- */
347
- if (month === startMonth) {
348
- return getPreviousMonth(parts);
349
- }
350
- else if (month === endMonth) {
351
- return getNextMonth(parts);
352
- }
353
- else {
354
- return;
355
- }
78
+ this.getActivePartsWithFallback = () => {
79
+ var _a;
80
+ const { defaultParts } = this;
81
+ return (_a = this.getActivePart()) !== null && _a !== void 0 ? _a : defaultParts;
356
82
  };
357
- const updateActiveMonth = () => {
358
- if (needsiOSRubberBandFix) {
359
- calendarBodyRef.style.removeProperty('pointer-events');
360
- appliediOSRubberBandFix = false;
361
- }
362
- /**
363
- * If the month did not change
364
- * then we can return early.
365
- */
366
- const newDate = getChangedMonth(this.workingParts);
367
- if (!newDate)
368
- return;
369
- const { month, day, year } = newDate;
370
- if (isMonthDisabled({ month, year, day: null }, {
371
- minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
372
- maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
373
- })) {
374
- return;
375
- }
376
- /**
377
- * Prevent scrolling for other browsers
378
- * to give the DOM time to update and the container
379
- * time to properly snap.
380
- */
381
- calendarBodyRef.style.setProperty('overflow', 'hidden');
382
- /**
383
- * Use a writeTask here to ensure
384
- * that the state is updated and the
385
- * correct month is scrolled into view
386
- * in the same frame. This is not
387
- * typically a problem on newer devices
388
- * but older/slower device may have a flicker
389
- * if we did not do this.
390
- */
391
- writeTask(() => {
392
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month, day: day, year }));
393
- calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
394
- calendarBodyRef.style.removeProperty('overflow');
395
- if (this.resolveForceDateScrolling) {
396
- this.resolveForceDateScrolling();
83
+ this.getActivePart = () => {
84
+ const { activeParts } = this;
85
+ return Array.isArray(activeParts) ? activeParts[0] : activeParts;
86
+ };
87
+ this.closeParentOverlay = () => {
88
+ const popoverOrModal = this.el.closest('ion-modal, ion-popover');
89
+ if (popoverOrModal) {
90
+ popoverOrModal.dismiss();
397
91
  }
398
- });
399
92
  };
400
- /**
401
- * When the container finishes scrolling we
402
- * need to update the DOM with the selected month.
403
- */
404
- let scrollTimeout;
405
- /**
406
- * We do not want to attempt to set pointer-events
407
- * multiple times within a single swipe gesture as
408
- * that adds unnecessary work to the main thread.
409
- */
410
- let appliediOSRubberBandFix = false;
411
- const scrollCallback = () => {
412
- if (scrollTimeout) {
413
- clearTimeout(scrollTimeout);
414
- }
415
- /**
416
- * On iOS it is possible to quickly rubber band
417
- * the scroll area before the scroll timeout has fired.
418
- * This results in users reaching the end of the scrollable
419
- * container before the DOM has updated.
420
- * By setting `pointer-events: none` we can ensure that
421
- * subsequent swipes do not happen while the container
422
- * is snapping.
423
- */
424
- if (!appliediOSRubberBandFix && needsiOSRubberBandFix) {
425
- calendarBodyRef.style.setProperty('pointer-events', 'none');
426
- appliediOSRubberBandFix = true;
427
- }
428
- // Wait ~3 frames
429
- scrollTimeout = setTimeout(updateActiveMonth, 50);
93
+ this.setWorkingParts = (parts) => {
94
+ this.workingParts = Object.assign({}, parts);
95
+ };
96
+ this.setActiveParts = (parts, removeDate = false) => {
97
+ /** if the datetime component is in readonly mode,
98
+ * allow browsing of the calendar without changing
99
+ * the set value
100
+ */
101
+ if (this.readonly) {
102
+ return;
103
+ }
104
+ const { multiple, minParts, maxParts, activeParts } = this;
105
+ /**
106
+ * When setting the active parts, it is possible
107
+ * to set invalid data. For example,
108
+ * when updating January 31 to February,
109
+ * February 31 does not exist. As a result
110
+ * we need to validate the active parts and
111
+ * ensure that we are only setting valid dates.
112
+ * Additionally, we need to update the working parts
113
+ * too in the event that the validated parts are different.
114
+ */
115
+ const validatedParts = validateParts(parts, minParts, maxParts);
116
+ this.setWorkingParts(validatedParts);
117
+ if (multiple) {
118
+ const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
119
+ if (removeDate) {
120
+ this.activeParts = activePartsArray.filter((p) => !isSameDay(p, validatedParts));
121
+ }
122
+ else {
123
+ this.activeParts = [...activePartsArray, validatedParts];
124
+ }
125
+ }
126
+ else {
127
+ this.activeParts = Object.assign({}, validatedParts);
128
+ }
129
+ const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
130
+ if (hasSlottedButtons || this.showDefaultButtons) {
131
+ return;
132
+ }
133
+ this.confirm();
430
134
  };
431
- calendarBodyRef.addEventListener('scroll', scrollCallback);
432
- this.destroyCalendarListener = () => {
433
- calendarBodyRef.removeEventListener('scroll', scrollCallback);
135
+ this.initializeKeyboardListeners = () => {
136
+ const calendarBodyRef = this.calendarBodyRef;
137
+ if (!calendarBodyRef) {
138
+ return;
139
+ }
140
+ const root = this.el.shadowRoot;
141
+ /**
142
+ * Get a reference to the month
143
+ * element we are currently viewing.
144
+ */
145
+ const currentMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(2)');
146
+ /**
147
+ * When focusing the calendar body, we want to pass focus
148
+ * to the working day, but other days should
149
+ * only be accessible using the arrow keys. Pressing
150
+ * Tab should jump between bodies of selectable content.
151
+ */
152
+ const checkCalendarBodyFocus = (ev) => {
153
+ var _a;
154
+ const record = ev[0];
155
+ /**
156
+ * If calendar body was already focused
157
+ * when this fired or if the calendar body
158
+ * if not currently focused, we should not re-focus
159
+ * the inner day.
160
+ */
161
+ if (((_a = record.oldValue) === null || _a === void 0 ? void 0 : _a.includes('ion-focused')) || !calendarBodyRef.classList.contains('ion-focused')) {
162
+ return;
163
+ }
164
+ this.focusWorkingDay(currentMonth);
165
+ };
166
+ const mo = new MutationObserver(checkCalendarBodyFocus);
167
+ mo.observe(calendarBodyRef, { attributeFilter: ['class'], attributeOldValue: true });
168
+ this.destroyKeyboardMO = () => {
169
+ mo === null || mo === void 0 ? void 0 : mo.disconnect();
170
+ };
171
+ /**
172
+ * We must use keydown not keyup as we want
173
+ * to prevent scrolling when using the arrow keys.
174
+ */
175
+ calendarBodyRef.addEventListener('keydown', (ev) => {
176
+ const activeElement = root.activeElement;
177
+ if (!activeElement || !activeElement.classList.contains('calendar-day')) {
178
+ return;
179
+ }
180
+ const parts = getPartsFromCalendarDay(activeElement);
181
+ let partsToFocus;
182
+ switch (ev.key) {
183
+ case 'ArrowDown':
184
+ ev.preventDefault();
185
+ partsToFocus = getNextWeek(parts);
186
+ break;
187
+ case 'ArrowUp':
188
+ ev.preventDefault();
189
+ partsToFocus = getPreviousWeek(parts);
190
+ break;
191
+ case 'ArrowRight':
192
+ ev.preventDefault();
193
+ partsToFocus = getNextDay(parts);
194
+ break;
195
+ case 'ArrowLeft':
196
+ ev.preventDefault();
197
+ partsToFocus = getPreviousDay(parts);
198
+ break;
199
+ case 'Home':
200
+ ev.preventDefault();
201
+ partsToFocus = getStartOfWeek(parts);
202
+ break;
203
+ case 'End':
204
+ ev.preventDefault();
205
+ partsToFocus = getEndOfWeek(parts);
206
+ break;
207
+ case 'PageUp':
208
+ ev.preventDefault();
209
+ partsToFocus = ev.shiftKey ? getPreviousYear(parts) : getPreviousMonth(parts);
210
+ break;
211
+ case 'PageDown':
212
+ ev.preventDefault();
213
+ partsToFocus = ev.shiftKey ? getNextYear(parts) : getNextMonth(parts);
214
+ break;
215
+ /**
216
+ * Do not preventDefault here
217
+ * as we do not want to override other
218
+ * browser defaults such as pressing Enter/Space
219
+ * to select a day.
220
+ */
221
+ default:
222
+ return;
223
+ }
224
+ /**
225
+ * If the day we want to move focus to is
226
+ * disabled, do not do anything.
227
+ */
228
+ if (isDayDisabled(partsToFocus, this.minParts, this.maxParts)) {
229
+ return;
230
+ }
231
+ this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), partsToFocus));
232
+ /**
233
+ * Give view a chance to re-render
234
+ * then move focus to the new working day
235
+ */
236
+ requestAnimationFrame(() => this.focusWorkingDay(currentMonth));
237
+ });
238
+ };
239
+ this.focusWorkingDay = (currentMonth) => {
240
+ /**
241
+ * Get the number of padding days so
242
+ * we know how much to offset our next selector by
243
+ * to grab the correct calendar-day element.
244
+ */
245
+ const padding = currentMonth.querySelectorAll('.calendar-day-padding');
246
+ const { day } = this.workingParts;
247
+ if (day === null) {
248
+ return;
249
+ }
250
+ /**
251
+ * Get the calendar day element
252
+ * and focus it.
253
+ */
254
+ const dayEl = currentMonth.querySelector(`.calendar-day-wrapper:nth-of-type(${padding.length + day}) .calendar-day`);
255
+ if (dayEl) {
256
+ dayEl.focus();
257
+ }
258
+ };
259
+ this.processMinParts = () => {
260
+ const { min, defaultParts } = this;
261
+ if (min === undefined) {
262
+ this.minParts = undefined;
263
+ return;
264
+ }
265
+ this.minParts = parseMinParts(min, defaultParts);
266
+ };
267
+ this.processMaxParts = () => {
268
+ const { max, defaultParts } = this;
269
+ if (max === undefined) {
270
+ this.maxParts = undefined;
271
+ return;
272
+ }
273
+ this.maxParts = parseMaxParts(max, defaultParts);
274
+ };
275
+ this.initializeCalendarListener = () => {
276
+ const calendarBodyRef = this.calendarBodyRef;
277
+ if (!calendarBodyRef) {
278
+ return;
279
+ }
280
+ /**
281
+ * For performance reasons, we only render 3
282
+ * months at a time: The current month, the previous
283
+ * month, and the next month. We have a scroll listener
284
+ * on the calendar body to append/prepend new months.
285
+ *
286
+ * We can do this because Stencil is smart enough to not
287
+ * re-create the .calendar-month containers, but rather
288
+ * update the content within those containers.
289
+ *
290
+ * As an added bonus, WebKit has some troubles with
291
+ * scroll-snap-stop: always, so not rendering all of
292
+ * the months in a row allows us to mostly sidestep
293
+ * that issue.
294
+ */
295
+ const months = calendarBodyRef.querySelectorAll('.calendar-month');
296
+ const startMonth = months[0];
297
+ const workingMonth = months[1];
298
+ const endMonth = months[2];
299
+ const mode = getIonMode(this);
300
+ const needsiOSRubberBandFix = mode === 'ios' && typeof navigator !== 'undefined' && navigator.maxTouchPoints > 1;
301
+ /**
302
+ * Before setting up the scroll listener,
303
+ * scroll the middle month into view.
304
+ * scrollIntoView() will scroll entire page
305
+ * if element is not in viewport. Use scrollLeft instead.
306
+ */
307
+ writeTask(() => {
308
+ calendarBodyRef.scrollLeft = startMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
309
+ const getChangedMonth = (parts) => {
310
+ const box = calendarBodyRef.getBoundingClientRect();
311
+ /**
312
+ * If the current scroll position is all the way to the left
313
+ * then we have scrolled to the previous month.
314
+ * Otherwise, assume that we have scrolled to the next
315
+ * month. We have a tolerance of 2px to account for
316
+ * sub pixel rendering.
317
+ *
318
+ * Check below the next line ensures that we did not
319
+ * swipe and abort (i.e. we swiped but we are still on the current month).
320
+ */
321
+ const month = calendarBodyRef.scrollLeft <= 2 ? startMonth : endMonth;
322
+ /**
323
+ * The edge of the month must be lined up with
324
+ * the edge of the calendar body in order for
325
+ * the component to update. Otherwise, it
326
+ * may be the case that the user has paused their
327
+ * swipe or the browser has not finished snapping yet.
328
+ * Rather than check if the x values are equal,
329
+ * we give it a tolerance of 2px to account for
330
+ * sub pixel rendering.
331
+ */
332
+ const monthBox = month.getBoundingClientRect();
333
+ if (Math.abs(monthBox.x - box.x) > 2)
334
+ return;
335
+ /**
336
+ * If we're force-rendering a month, assume we've
337
+ * scrolled to that and return it.
338
+ *
339
+ * If forceRenderDate is ever used in a context where the
340
+ * forced month is not immediately auto-scrolled to, this
341
+ * should be updated to also check whether `month` has the
342
+ * same month and year as the forced date.
343
+ */
344
+ const { forceRenderDate } = this;
345
+ if (forceRenderDate !== undefined) {
346
+ return { month: forceRenderDate.month, year: forceRenderDate.year, day: forceRenderDate.day };
347
+ }
348
+ /**
349
+ * From here, we can determine if the start
350
+ * month or the end month was scrolled into view.
351
+ * If no month was changed, then we can return from
352
+ * the scroll callback early.
353
+ */
354
+ if (month === startMonth) {
355
+ return getPreviousMonth(parts);
356
+ }
357
+ else if (month === endMonth) {
358
+ return getNextMonth(parts);
359
+ }
360
+ else {
361
+ return;
362
+ }
363
+ };
364
+ const updateActiveMonth = () => {
365
+ if (needsiOSRubberBandFix) {
366
+ calendarBodyRef.style.removeProperty('pointer-events');
367
+ appliediOSRubberBandFix = false;
368
+ }
369
+ /**
370
+ * If the month did not change
371
+ * then we can return early.
372
+ */
373
+ const newDate = getChangedMonth(this.workingParts);
374
+ if (!newDate)
375
+ return;
376
+ const { month, day, year } = newDate;
377
+ if (isMonthDisabled({ month, year, day: null }, {
378
+ minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
379
+ maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
380
+ })) {
381
+ return;
382
+ }
383
+ /**
384
+ * Prevent scrolling for other browsers
385
+ * to give the DOM time to update and the container
386
+ * time to properly snap.
387
+ */
388
+ calendarBodyRef.style.setProperty('overflow', 'hidden');
389
+ /**
390
+ * Use a writeTask here to ensure
391
+ * that the state is updated and the
392
+ * correct month is scrolled into view
393
+ * in the same frame. This is not
394
+ * typically a problem on newer devices
395
+ * but older/slower device may have a flicker
396
+ * if we did not do this.
397
+ */
398
+ writeTask(() => {
399
+ this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month, day: day, year }));
400
+ calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
401
+ calendarBodyRef.style.removeProperty('overflow');
402
+ if (this.resolveForceDateScrolling) {
403
+ this.resolveForceDateScrolling();
404
+ }
405
+ });
406
+ };
407
+ /**
408
+ * When the container finishes scrolling we
409
+ * need to update the DOM with the selected month.
410
+ */
411
+ let scrollTimeout;
412
+ /**
413
+ * We do not want to attempt to set pointer-events
414
+ * multiple times within a single swipe gesture as
415
+ * that adds unnecessary work to the main thread.
416
+ */
417
+ let appliediOSRubberBandFix = false;
418
+ const scrollCallback = () => {
419
+ if (scrollTimeout) {
420
+ clearTimeout(scrollTimeout);
421
+ }
422
+ /**
423
+ * On iOS it is possible to quickly rubber band
424
+ * the scroll area before the scroll timeout has fired.
425
+ * This results in users reaching the end of the scrollable
426
+ * container before the DOM has updated.
427
+ * By setting `pointer-events: none` we can ensure that
428
+ * subsequent swipes do not happen while the container
429
+ * is snapping.
430
+ */
431
+ if (!appliediOSRubberBandFix && needsiOSRubberBandFix) {
432
+ calendarBodyRef.style.setProperty('pointer-events', 'none');
433
+ appliediOSRubberBandFix = true;
434
+ }
435
+ // Wait ~3 frames
436
+ scrollTimeout = setTimeout(updateActiveMonth, 50);
437
+ };
438
+ calendarBodyRef.addEventListener('scroll', scrollCallback);
439
+ this.destroyCalendarListener = () => {
440
+ calendarBodyRef.removeEventListener('scroll', scrollCallback);
441
+ };
442
+ });
434
443
  };
435
- });
436
- };
437
- /**
438
- * Clean up all listeners except for the overlay
439
- * listener. This is so that we can re-create the listeners
440
- * if the datetime has been hidden/presented by a modal or popover.
441
- */
442
- this.destroyInteractionListeners = () => {
443
- const { destroyCalendarListener, destroyKeyboardMO } = this;
444
- if (destroyCalendarListener !== undefined) {
445
- destroyCalendarListener();
446
- }
447
- if (destroyKeyboardMO !== undefined) {
448
- destroyKeyboardMO();
449
- }
450
- };
451
- this.processValue = (value) => {
452
- const hasValue = value !== null && value !== undefined && (!Array.isArray(value) || value.length > 0);
453
- const valueToProcess = hasValue ? parseDate(value) : this.defaultParts;
454
- const { minParts, maxParts, workingParts, el } = this;
455
- this.warnIfIncorrectValueUsage();
456
- /**
457
- * Return early if the value wasn't parsed correctly, such as
458
- * if an improperly formatted date string was provided.
459
- */
460
- if (!valueToProcess) {
461
- return;
462
- }
463
- /**
464
- * Datetime should only warn of out of bounds values
465
- * if set by the user. If the `value` is undefined,
466
- * we will default to today's date which may be out
467
- * of bounds. In this case, the warning makes it look
468
- * like the developer did something wrong which is
469
- * not true.
470
- */
471
- if (hasValue) {
472
- warnIfValueOutOfBounds(valueToProcess, minParts, maxParts);
473
- }
474
- /**
475
- * If there are multiple values, pick an arbitrary one to clamp to. This way,
476
- * if the values are across months, we always show at least one of them. Note
477
- * that the values don't necessarily have to be in order.
478
- */
479
- const singleValue = Array.isArray(valueToProcess) ? valueToProcess[0] : valueToProcess;
480
- const targetValue = clampDate(singleValue, minParts, maxParts);
481
- const { month, day, year, hour, minute } = targetValue;
482
- const ampm = parseAmPm(hour);
483
- /**
484
- * Since `activeParts` indicates a value that
485
- * been explicitly selected either by the
486
- * user or the app, only update `activeParts`
487
- * if the `value` property is set.
488
- */
489
- if (hasValue) {
490
- if (Array.isArray(valueToProcess)) {
491
- this.activeParts = [...valueToProcess];
492
- }
493
- else {
494
- this.activeParts = {
495
- month,
496
- day,
497
- year,
498
- hour,
499
- minute,
500
- ampm,
501
- };
502
- }
503
- }
504
- else {
505
444
  /**
506
- * Reset the active parts if the value is not set.
507
- * This will clear the selected calendar day when
508
- * performing a clear action or using the reset() method.
445
+ * Clean up all listeners except for the overlay
446
+ * listener. This is so that we can re-create the listeners
447
+ * if the datetime has been hidden/presented by a modal or popover.
509
448
  */
449
+ this.destroyInteractionListeners = () => {
450
+ const { destroyCalendarListener, destroyKeyboardMO } = this;
451
+ if (destroyCalendarListener !== undefined) {
452
+ destroyCalendarListener();
453
+ }
454
+ if (destroyKeyboardMO !== undefined) {
455
+ destroyKeyboardMO();
456
+ }
457
+ };
458
+ this.processValue = (value) => {
459
+ const hasValue = value !== null && value !== undefined && (!Array.isArray(value) || value.length > 0);
460
+ const valueToProcess = hasValue ? parseDate(value) : this.defaultParts;
461
+ const { minParts, maxParts, workingParts, el } = this;
462
+ this.warnIfIncorrectValueUsage();
463
+ /**
464
+ * Return early if the value wasn't parsed correctly, such as
465
+ * if an improperly formatted date string was provided.
466
+ */
467
+ if (!valueToProcess) {
468
+ return;
469
+ }
470
+ /**
471
+ * Datetime should only warn of out of bounds values
472
+ * if set by the user. If the `value` is undefined,
473
+ * we will default to today's date which may be out
474
+ * of bounds. In this case, the warning makes it look
475
+ * like the developer did something wrong which is
476
+ * not true.
477
+ */
478
+ if (hasValue) {
479
+ warnIfValueOutOfBounds(valueToProcess, minParts, maxParts);
480
+ }
481
+ /**
482
+ * If there are multiple values, pick an arbitrary one to clamp to. This way,
483
+ * if the values are across months, we always show at least one of them. Note
484
+ * that the values don't necessarily have to be in order.
485
+ */
486
+ const singleValue = Array.isArray(valueToProcess) ? valueToProcess[0] : valueToProcess;
487
+ const targetValue = clampDate(singleValue, minParts, maxParts);
488
+ const { month, day, year, hour, minute } = targetValue;
489
+ const ampm = parseAmPm(hour);
490
+ /**
491
+ * Since `activeParts` indicates a value that
492
+ * been explicitly selected either by the
493
+ * user or the app, only update `activeParts`
494
+ * if the `value` property is set.
495
+ */
496
+ if (hasValue) {
497
+ if (Array.isArray(valueToProcess)) {
498
+ this.activeParts = [...valueToProcess];
499
+ }
500
+ else {
501
+ this.activeParts = {
502
+ month,
503
+ day,
504
+ year,
505
+ hour,
506
+ minute,
507
+ ampm,
508
+ };
509
+ }
510
+ }
511
+ else {
512
+ /**
513
+ * Reset the active parts if the value is not set.
514
+ * This will clear the selected calendar day when
515
+ * performing a clear action or using the reset() method.
516
+ */
517
+ this.activeParts = [];
518
+ }
519
+ /**
520
+ * Only animate if:
521
+ * 1. We're using grid style (wheel style pickers should just jump to new value)
522
+ * 2. The month and/or year actually changed, and both are defined (otherwise there's nothing to animate to)
523
+ * 3. The calendar body is visible (prevents animation when in collapsed datetime-button, for example)
524
+ * 4. The month/year picker is not open (since you wouldn't see the animation anyway)
525
+ */
526
+ const didChangeMonth = (month !== undefined && month !== workingParts.month) || (year !== undefined && year !== workingParts.year);
527
+ const bodyIsVisible = el.classList.contains('datetime-ready');
528
+ const { isGridStyle, showMonthAndYear } = this;
529
+ if (isGridStyle && didChangeMonth && bodyIsVisible && !showMonthAndYear) {
530
+ this.animateToDate(targetValue);
531
+ }
532
+ else {
533
+ /**
534
+ * We only need to do this if we didn't just animate to a new month,
535
+ * since that calls prevMonth/nextMonth which calls setWorkingParts for us.
536
+ */
537
+ this.setWorkingParts({
538
+ month,
539
+ day,
540
+ year,
541
+ hour,
542
+ minute,
543
+ ampm,
544
+ });
545
+ }
546
+ };
547
+ this.animateToDate = async (targetValue) => {
548
+ const { workingParts } = this;
549
+ /**
550
+ * Tell other render functions that we need to force the
551
+ * target month to appear in place of the actual next/prev month.
552
+ * Because this is a State variable, a rerender will be triggered
553
+ * automatically, updating the rendered months.
554
+ */
555
+ this.forceRenderDate = targetValue;
556
+ /**
557
+ * Flag that we've started scrolling to the forced date.
558
+ * The resolve function will be called by the datetime's
559
+ * scroll listener when it's done updating everything.
560
+ * This is a replacement for making prev/nextMonth async,
561
+ * since the logic we're waiting on is in a listener.
562
+ */
563
+ const forceDateScrollingPromise = new Promise((resolve) => {
564
+ this.resolveForceDateScrolling = resolve;
565
+ });
566
+ /**
567
+ * Animate smoothly to the forced month. This will also update
568
+ * workingParts and correct the surrounding months for us.
569
+ */
570
+ const targetMonthIsBefore = isBefore(targetValue, workingParts);
571
+ targetMonthIsBefore ? this.prevMonth() : this.nextMonth();
572
+ await forceDateScrollingPromise;
573
+ this.resolveForceDateScrolling = undefined;
574
+ this.forceRenderDate = undefined;
575
+ };
576
+ this.onFocus = () => {
577
+ this.ionFocus.emit();
578
+ };
579
+ this.onBlur = () => {
580
+ this.ionBlur.emit();
581
+ };
582
+ this.hasValue = () => {
583
+ return this.value != null;
584
+ };
585
+ this.nextMonth = () => {
586
+ const calendarBodyRef = this.calendarBodyRef;
587
+ if (!calendarBodyRef) {
588
+ return;
589
+ }
590
+ const nextMonth = calendarBodyRef.querySelector('.calendar-month:last-of-type');
591
+ if (!nextMonth) {
592
+ return;
593
+ }
594
+ const left = nextMonth.offsetWidth * 2;
595
+ calendarBodyRef.scrollTo({
596
+ top: 0,
597
+ left: left * (isRTL(this.el) ? -1 : 1),
598
+ behavior: 'smooth',
599
+ });
600
+ };
601
+ this.prevMonth = () => {
602
+ const calendarBodyRef = this.calendarBodyRef;
603
+ if (!calendarBodyRef) {
604
+ return;
605
+ }
606
+ const prevMonth = calendarBodyRef.querySelector('.calendar-month:first-of-type');
607
+ if (!prevMonth) {
608
+ return;
609
+ }
610
+ calendarBodyRef.scrollTo({
611
+ top: 0,
612
+ left: 0,
613
+ behavior: 'smooth',
614
+ });
615
+ };
616
+ this.toggleMonthAndYearView = () => {
617
+ this.showMonthAndYear = !this.showMonthAndYear;
618
+ };
619
+ this.showMonthAndYear = false;
510
620
  this.activeParts = [];
511
- }
512
- /**
513
- * Only animate if:
514
- * 1. We're using grid style (wheel style pickers should just jump to new value)
515
- * 2. The month and/or year actually changed, and both are defined (otherwise there's nothing to animate to)
516
- * 3. The calendar body is visible (prevents animation when in collapsed datetime-button, for example)
517
- * 4. The month/year picker is not open (since you wouldn't see the animation anyway)
518
- */
519
- const didChangeMonth = (month !== undefined && month !== workingParts.month) || (year !== undefined && year !== workingParts.year);
520
- const bodyIsVisible = el.classList.contains('datetime-ready');
521
- const { isGridStyle, showMonthAndYear } = this;
522
- if (isGridStyle && didChangeMonth && bodyIsVisible && !showMonthAndYear) {
523
- this.animateToDate(targetValue);
524
- }
525
- else {
526
- /**
527
- * We only need to do this if we didn't just animate to a new month,
528
- * since that calls prevMonth/nextMonth which calls setWorkingParts for us.
529
- */
530
- this.setWorkingParts({
531
- month,
532
- day,
533
- year,
534
- hour,
535
- minute,
536
- ampm,
537
- });
538
- }
539
- };
540
- this.animateToDate = async (targetValue) => {
541
- const { workingParts } = this;
542
- /**
543
- * Tell other render functions that we need to force the
544
- * target month to appear in place of the actual next/prev month.
545
- * Because this is a State variable, a rerender will be triggered
546
- * automatically, updating the rendered months.
547
- */
548
- this.forceRenderDate = targetValue;
549
- /**
550
- * Flag that we've started scrolling to the forced date.
551
- * The resolve function will be called by the datetime's
552
- * scroll listener when it's done updating everything.
553
- * This is a replacement for making prev/nextMonth async,
554
- * since the logic we're waiting on is in a listener.
555
- */
556
- const forceDateScrollingPromise = new Promise((resolve) => {
557
- this.resolveForceDateScrolling = resolve;
558
- });
559
- /**
560
- * Animate smoothly to the forced month. This will also update
561
- * workingParts and correct the surrounding months for us.
562
- */
563
- const targetMonthIsBefore = isBefore(targetValue, workingParts);
564
- targetMonthIsBefore ? this.prevMonth() : this.nextMonth();
565
- await forceDateScrollingPromise;
566
- this.resolveForceDateScrolling = undefined;
567
- this.forceRenderDate = undefined;
568
- };
569
- this.onFocus = () => {
570
- this.ionFocus.emit();
571
- };
572
- this.onBlur = () => {
573
- this.ionBlur.emit();
574
- };
575
- this.hasValue = () => {
576
- return this.value != null;
577
- };
578
- this.nextMonth = () => {
579
- const calendarBodyRef = this.calendarBodyRef;
580
- if (!calendarBodyRef) {
581
- return;
582
- }
583
- const nextMonth = calendarBodyRef.querySelector('.calendar-month:last-of-type');
584
- if (!nextMonth) {
585
- return;
586
- }
587
- const left = nextMonth.offsetWidth * 2;
588
- calendarBodyRef.scrollTo({
589
- top: 0,
590
- left: left * (isRTL(this.el) ? -1 : 1),
591
- behavior: 'smooth',
592
- });
593
- };
594
- this.prevMonth = () => {
595
- const calendarBodyRef = this.calendarBodyRef;
596
- if (!calendarBodyRef) {
597
- return;
598
- }
599
- const prevMonth = calendarBodyRef.querySelector('.calendar-month:first-of-type');
600
- if (!prevMonth) {
601
- return;
602
- }
603
- calendarBodyRef.scrollTo({
604
- top: 0,
605
- left: 0,
606
- behavior: 'smooth',
607
- });
608
- };
609
- this.toggleMonthAndYearView = () => {
610
- this.showMonthAndYear = !this.showMonthAndYear;
611
- };
612
- this.showMonthAndYear = false;
613
- this.activeParts = [];
614
- this.workingParts = {
615
- month: 5,
616
- day: 28,
617
- year: 2021,
618
- hour: 13,
619
- minute: 52,
620
- ampm: 'pm',
621
- };
622
- this.isTimePopoverOpen = false;
623
- this.forceRenderDate = undefined;
624
- this.color = 'primary';
625
- this.name = this.inputId;
626
- this.disabled = false;
627
- this.readonly = false;
628
- this.isDateEnabled = undefined;
629
- this.min = undefined;
630
- this.max = undefined;
631
- this.presentation = 'date-time';
632
- this.cancelText = 'Cancel';
633
- this.doneText = 'Done';
634
- this.clearText = 'Clear';
635
- this.yearValues = undefined;
636
- this.monthValues = undefined;
637
- this.dayValues = undefined;
638
- this.hourValues = undefined;
639
- this.minuteValues = undefined;
640
- this.locale = 'default';
641
- this.firstDayOfWeek = 0;
642
- this.titleSelectedDatesFormatter = undefined;
643
- this.multiple = false;
644
- this.highlightedDates = undefined;
645
- this.value = undefined;
646
- this.showDefaultTitle = false;
647
- this.showDefaultButtons = false;
648
- this.showClearButton = false;
649
- this.showDefaultTimeLabel = true;
650
- this.hourCycle = undefined;
651
- this.size = 'fixed';
652
- this.preferWheel = false;
653
- }
654
- disabledChanged() {
655
- this.emitStyle();
656
- }
657
- minChanged() {
658
- this.processMinParts();
659
- }
660
- maxChanged() {
661
- this.processMaxParts();
662
- }
663
- get isGridStyle() {
664
- const { presentation, preferWheel } = this;
665
- const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
666
- return hasDatePresentation && !preferWheel;
667
- }
668
- yearValuesChanged() {
669
- this.parsedYearValues = convertToArrayOfNumbers(this.yearValues);
670
- }
671
- monthValuesChanged() {
672
- this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues);
673
- }
674
- dayValuesChanged() {
675
- this.parsedDayValues = convertToArrayOfNumbers(this.dayValues);
676
- }
677
- hourValuesChanged() {
678
- this.parsedHourValues = convertToArrayOfNumbers(this.hourValues);
679
- }
680
- minuteValuesChanged() {
681
- this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues);
682
- }
683
- /**
684
- * Update the datetime value when the value changes
685
- */
686
- async valueChanged() {
687
- const { value } = this;
688
- if (this.hasValue()) {
689
- this.processValue(value);
621
+ this.workingParts = {
622
+ month: 5,
623
+ day: 28,
624
+ year: 2021,
625
+ hour: 13,
626
+ minute: 52,
627
+ ampm: 'pm',
628
+ };
629
+ this.isTimePopoverOpen = false;
630
+ this.forceRenderDate = undefined;
631
+ this.color = 'primary';
632
+ this.name = this.inputId;
633
+ this.disabled = false;
634
+ this.readonly = false;
635
+ this.isDateEnabled = undefined;
636
+ this.min = undefined;
637
+ this.max = undefined;
638
+ this.presentation = 'date-time';
639
+ this.cancelText = 'Cancel';
640
+ this.doneText = 'Done';
641
+ this.clearText = 'Clear';
642
+ this.yearValues = undefined;
643
+ this.monthValues = undefined;
644
+ this.dayValues = undefined;
645
+ this.hourValues = undefined;
646
+ this.minuteValues = undefined;
647
+ this.locale = 'default';
648
+ this.firstDayOfWeek = 0;
649
+ this.titleSelectedDatesFormatter = undefined;
650
+ this.multiple = false;
651
+ this.highlightedDates = undefined;
652
+ this.value = undefined;
653
+ this.showDefaultTitle = false;
654
+ this.showDefaultButtons = false;
655
+ this.showClearButton = false;
656
+ this.showDefaultTimeLabel = true;
657
+ this.hourCycle = undefined;
658
+ this.size = 'fixed';
659
+ this.preferWheel = false;
690
660
  }
691
- this.emitStyle();
692
- this.ionValueChange.emit({ value });
693
- }
694
- /**
695
- * Confirms the selected datetime value, updates the
696
- * `value` property, and optionally closes the popover
697
- * or modal that the datetime was presented in.
698
- */
699
- async confirm(closeOverlay = false) {
700
- const { isCalendarPicker, activeParts } = this;
701
- /**
702
- * We only update the value if the presentation is not a calendar picker.
703
- */
704
- if (activeParts !== undefined || !isCalendarPicker) {
705
- const activePartsIsArray = Array.isArray(activeParts);
706
- if (activePartsIsArray && activeParts.length === 0) {
707
- this.setValue(undefined);
708
- }
709
- else {
710
- this.setValue(convertDataToISO(activeParts));
711
- }
661
+ disabledChanged() {
662
+ this.emitStyle();
712
663
  }
713
- if (closeOverlay) {
714
- this.closeParentOverlay();
664
+ minChanged() {
665
+ this.processMinParts();
715
666
  }
716
- }
717
- /**
718
- * Resets the internal state of the datetime but does not update the value.
719
- * Passing a valid ISO-8601 string will reset the state of the component to the provided date.
720
- * If no value is provided, the internal state will be reset to the clamped value of the min, max and today.
721
- */
722
- async reset(startDate) {
723
- this.processValue(startDate);
724
- }
725
- /**
726
- * Emits the ionCancel event and
727
- * optionally closes the popover
728
- * or modal that the datetime was
729
- * presented in.
730
- */
731
- async cancel(closeOverlay = false) {
732
- this.ionCancel.emit();
733
- if (closeOverlay) {
734
- this.closeParentOverlay();
667
+ maxChanged() {
668
+ this.processMaxParts();
735
669
  }
736
- }
737
- get isCalendarPicker() {
738
- const { presentation } = this;
739
- return presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
740
- }
741
- connectedCallback() {
742
- this.clearFocusVisible = startFocusVisible(this.el).destroy;
743
- }
744
- disconnectedCallback() {
745
- if (this.clearFocusVisible) {
746
- this.clearFocusVisible();
747
- this.clearFocusVisible = undefined;
670
+ get isGridStyle() {
671
+ const { presentation, preferWheel } = this;
672
+ const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
673
+ return hasDatePresentation && !preferWheel;
748
674
  }
749
- }
750
- initializeListeners() {
751
- this.initializeCalendarListener();
752
- this.initializeKeyboardListeners();
753
- }
754
- componentDidLoad() {
755
- /**
756
- * If a scrollable element is hidden using `display: none`,
757
- * it will not have a scroll height meaning we cannot scroll elements
758
- * into view. As a result, we will need to wait for the datetime to become
759
- * visible if used inside of a modal or a popover otherwise the scrollable
760
- * areas will not have the correct values snapped into place.
761
- */
762
- const visibleCallback = (entries) => {
763
- const ev = entries[0];
764
- if (!ev.isIntersecting) {
765
- return;
766
- }
767
- this.initializeListeners();
768
- /**
769
- * TODO FW-2793: Datetime needs a frame to ensure that it
770
- * can properly scroll contents into view. As a result
771
- * we hide the scrollable content until after that frame
772
- * so users do not see the content quickly shifting. The downside
773
- * is that the content will pop into view a frame after. Maybe there
774
- * is a better way to handle this?
775
- */
776
- writeTask(() => {
777
- this.el.classList.add('datetime-ready');
778
- });
779
- };
780
- const visibleIO = new IntersectionObserver(visibleCallback, { threshold: 0.01 });
781
- /**
782
- * Use raf to avoid a race condition between the component loading and
783
- * its display animation starting (such as when shown in a modal). This
784
- * could cause the datetime to start at a visibility of 0, erroneously
785
- * triggering the `hiddenIO` observer below.
786
- */
787
- raf(() => visibleIO === null || visibleIO === void 0 ? void 0 : visibleIO.observe(this.el));
788
- /**
789
- * We need to clean up listeners when the datetime is hidden
790
- * in a popover/modal so that we can properly scroll containers
791
- * back into view if they are re-presented. When the datetime is hidden
792
- * the scroll areas have scroll widths/heights of 0px, so any snapping
793
- * we did originally has been lost.
794
- */
795
- const hiddenCallback = (entries) => {
796
- const ev = entries[0];
797
- if (ev.isIntersecting) {
798
- return;
799
- }
800
- this.destroyInteractionListeners();
801
- /**
802
- * When datetime is hidden, we need to make sure that
803
- * the month/year picker is closed. Otherwise,
804
- * it will be open when the datetime re-appears
805
- * and the scroll area of the calendar grid will be 0.
806
- * As a result, the wrong month will be shown.
807
- */
808
- this.showMonthAndYear = false;
809
- writeTask(() => {
810
- this.el.classList.remove('datetime-ready');
811
- });
812
- };
813
- const hiddenIO = new IntersectionObserver(hiddenCallback, { threshold: 0 });
814
- raf(() => hiddenIO === null || hiddenIO === void 0 ? void 0 : hiddenIO.observe(this.el));
815
- /**
816
- * Datetime uses Ionic components that emit
817
- * ionFocus and ionBlur. These events are
818
- * composed meaning they will cross
819
- * the shadow dom boundary. We need to
820
- * stop propagation on these events otherwise
821
- * developers will see 2 ionFocus or 2 ionBlur
822
- * events at a time.
823
- */
824
- const root = getElementRoot(this.el);
825
- root.addEventListener('ionFocus', (ev) => ev.stopPropagation());
826
- root.addEventListener('ionBlur', (ev) => ev.stopPropagation());
827
- }
828
- /**
829
- * When the presentation is changed, all calendar content is recreated,
830
- * so we need to re-init behavior with the new elements.
831
- */
832
- componentDidRender() {
833
- const { presentation, prevPresentation, calendarBodyRef, minParts, preferWheel } = this;
834
- /**
835
- * TODO(FW-2165)
836
- * Remove this when https://bugs.webkit.org/show_bug.cgi?id=235960 is fixed.
837
- * When using `min`, we add `scroll-snap-align: none`
838
- * to the disabled month so that users cannot scroll to it.
839
- * This triggers a bug in WebKit where the scroll position is reset.
840
- * Since the month change logic is handled by a scroll listener,
841
- * this causes the month to change leading to `scroll-snap-align`
842
- * changing again, thus changing the scroll position again and causing
843
- * an infinite loop.
844
- * This issue only applies to the calendar grid, so we can disable
845
- * it if the calendar grid is not being used.
846
- */
847
- const hasCalendarGrid = !preferWheel && ['date-time', 'time-date', 'date'].includes(presentation);
848
- if (minParts !== undefined && hasCalendarGrid && calendarBodyRef) {
849
- const workingMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(1)');
850
- if (workingMonth) {
851
- calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
852
- }
853
- }
854
- if (prevPresentation === null) {
855
- this.prevPresentation = presentation;
856
- return;
675
+ yearValuesChanged() {
676
+ this.parsedYearValues = convertToArrayOfNumbers(this.yearValues);
857
677
  }
858
- if (presentation === prevPresentation) {
859
- return;
678
+ monthValuesChanged() {
679
+ this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues);
860
680
  }
861
- this.prevPresentation = presentation;
862
- this.destroyInteractionListeners();
863
- this.initializeListeners();
864
- /**
865
- * The month/year picker from the date interface
866
- * should be closed as it is not available in non-date
867
- * interfaces.
868
- */
869
- this.showMonthAndYear = false;
870
- raf(() => {
871
- this.ionRender.emit();
872
- });
873
- }
874
- componentWillLoad() {
875
- const { el, highlightedDates, multiple, presentation, preferWheel } = this;
876
- if (multiple) {
877
- if (presentation !== 'date') {
878
- printIonWarning('Multiple date selection is only supported for presentation="date".', el);
879
- }
880
- if (preferWheel) {
881
- printIonWarning('Multiple date selection is not supported with preferWheel="true".', el);
882
- }
681
+ dayValuesChanged() {
682
+ this.parsedDayValues = convertToArrayOfNumbers(this.dayValues);
883
683
  }
884
- if (highlightedDates !== undefined) {
885
- if (presentation !== 'date' && presentation !== 'date-time' && presentation !== 'time-date') {
886
- printIonWarning('The highlightedDates property is only supported with the date, date-time, and time-date presentations.', el);
887
- }
888
- if (preferWheel) {
889
- printIonWarning('The highlightedDates property is not supported with preferWheel="true".', el);
890
- }
684
+ hourValuesChanged() {
685
+ this.parsedHourValues = convertToArrayOfNumbers(this.hourValues);
891
686
  }
892
- const hourValues = (this.parsedHourValues = convertToArrayOfNumbers(this.hourValues));
893
- const minuteValues = (this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues));
894
- const monthValues = (this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues));
895
- const yearValues = (this.parsedYearValues = convertToArrayOfNumbers(this.yearValues));
896
- const dayValues = (this.parsedDayValues = convertToArrayOfNumbers(this.dayValues));
897
- const todayParts = (this.todayParts = parseDate(getToday()));
898
- this.defaultParts = getClosestValidDate(todayParts, monthValues, dayValues, yearValues, hourValues, minuteValues);
899
- this.processMinParts();
900
- this.processMaxParts();
901
- this.processValue(this.value);
902
- this.emitStyle();
903
- }
904
- emitStyle() {
905
- this.ionStyle.emit({
906
- interactive: true,
907
- datetime: true,
908
- 'interactive-disabled': this.disabled,
909
- });
910
- }
911
- /**
912
- * Universal render methods
913
- * These are pieces of datetime that
914
- * are rendered independently of presentation.
915
- */
916
- renderFooter() {
917
- const { showDefaultButtons, showClearButton } = this;
918
- const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
919
- if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
920
- return;
687
+ minuteValuesChanged() {
688
+ this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues);
921
689
  }
922
- const clearButtonClick = () => {
923
- this.reset();
924
- this.setValue(undefined);
925
- };
926
- /**
927
- * By default we render two buttons:
928
- * Cancel - Dismisses the datetime and
929
- * does not update the `value` prop.
930
- * OK - Dismisses the datetime and
931
- * updates the `value` prop.
932
- */
933
- return (h("div", { class: "datetime-footer" }, h("div", { class: "datetime-buttons" }, h("div", { class: {
934
- ['datetime-action-buttons']: true,
935
- ['has-clear-button']: this.showClearButton,
936
- } }, h("slot", { name: "buttons" }, h("ion-buttons", null, showDefaultButtons && (h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true) }, this.cancelText)), h("div", { class: "datetime-action-buttons-container" }, showClearButton && (h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick() }, this.clearText)), showDefaultButtons && (h("ion-button", { id: "confirm-button", color: this.color, onClick: () => this.confirm(true) }, this.doneText)))))))));
937
- }
938
- /**
939
- * Wheel picker render methods
940
- */
941
- renderWheelPicker(forcePresentation = this.presentation) {
942
690
  /**
943
- * If presentation="time-date" we switch the
944
- * order of the render array here instead of
945
- * manually reordering each date/time picker
946
- * column with CSS. This allows for additional
947
- * flexibility if we need to render subsets
948
- * of the date/time data or do additional ordering
949
- * within the child render functions.
691
+ * Update the datetime value when the value changes
950
692
  */
951
- const renderArray = forcePresentation === 'time-date'
952
- ? [this.renderTimePickerColumns(forcePresentation), this.renderDatePickerColumns(forcePresentation)]
953
- : [this.renderDatePickerColumns(forcePresentation), this.renderTimePickerColumns(forcePresentation)];
954
- return h("ion-picker-internal", null, renderArray);
955
- }
956
- renderDatePickerColumns(forcePresentation) {
957
- return forcePresentation === 'date-time' || forcePresentation === 'time-date'
958
- ? this.renderCombinedDatePickerColumn()
959
- : this.renderIndividualDatePickerColumns(forcePresentation);
960
- }
961
- renderCombinedDatePickerColumn() {
962
- const { defaultParts, workingParts, locale, minParts, maxParts, todayParts, isDateEnabled } = this;
963
- const activePart = this.getActivePartsWithFallback();
964
- /**
965
- * By default, generate a range of 3 months:
966
- * Previous month, current month, and next month
967
- */
968
- const monthsToRender = generateMonths(workingParts);
969
- const lastMonth = monthsToRender[monthsToRender.length - 1];
970
- /**
971
- * Ensure that users can select the entire window of dates.
972
- */
973
- monthsToRender[0].day = 1;
974
- lastMonth.day = getNumDaysInMonth(lastMonth.month, lastMonth.year);
693
+ async valueChanged() {
694
+ const { value } = this;
695
+ if (this.hasValue()) {
696
+ this.processValue(value);
697
+ }
698
+ this.emitStyle();
699
+ this.ionValueChange.emit({ value });
700
+ }
975
701
  /**
976
- * Narrow the dates rendered based on min/max dates (if any).
977
- * The `min` date is used if the min is after the generated min month.
978
- * The `max` date is used if the max is before the generated max month.
979
- * This ensures that the sliding window always stays at 3 months
980
- * but still allows future dates to be lazily rendered based on any min/max
981
- * constraints.
702
+ * Confirms the selected datetime value, updates the
703
+ * `value` property, and optionally closes the popover
704
+ * or modal that the datetime was presented in.
982
705
  */
983
- const min = minParts !== undefined && isAfter(minParts, monthsToRender[0]) ? minParts : monthsToRender[0];
984
- const max = maxParts !== undefined && isBefore(maxParts, lastMonth) ? maxParts : lastMonth;
985
- const result = getCombinedDateColumnData(locale, todayParts, min, max, this.parsedDayValues, this.parsedMonthValues);
986
- let items = result.items;
987
- const parts = result.parts;
988
- if (isDateEnabled) {
989
- items = items.map((itemObject, index) => {
990
- const referenceParts = parts[index];
991
- let disabled;
992
- try {
993
- /**
994
- * The `isDateEnabled` implementation is try-catch wrapped
995
- * to prevent exceptions in the user's function from
996
- * interrupting the calendar rendering.
997
- */
998
- disabled = !isDateEnabled(convertDataToISO(referenceParts));
706
+ async confirm(closeOverlay = false) {
707
+ const { isCalendarPicker, activeParts } = this;
708
+ /**
709
+ * We only update the value if the presentation is not a calendar picker.
710
+ */
711
+ if (activeParts !== undefined || !isCalendarPicker) {
712
+ const activePartsIsArray = Array.isArray(activeParts);
713
+ if (activePartsIsArray && activeParts.length === 0) {
714
+ this.setValue(undefined);
715
+ }
716
+ else {
717
+ this.setValue(convertDataToISO(activeParts));
718
+ }
999
719
  }
1000
- catch (e) {
1001
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
720
+ if (closeOverlay) {
721
+ this.closeParentOverlay();
1002
722
  }
1003
- return Object.assign(Object.assign({}, itemObject), { disabled });
1004
- });
1005
723
  }
1006
724
  /**
1007
- * If we have selected a day already, then default the column
1008
- * to that value. Otherwise, set it to the default date.
725
+ * Resets the internal state of the datetime but does not update the value.
726
+ * Passing a valid ISO-8601 string will reset the state of the component to the provided date.
727
+ * If no value is provided, the internal state will be reset to the clamped value of the min, max and today.
1009
728
  */
1010
- const todayString = workingParts.day !== null
1011
- ? `${workingParts.year}-${workingParts.month}-${workingParts.day}`
1012
- : `${defaultParts.year}-${defaultParts.month}-${defaultParts.day}`;
1013
- return (h("ion-picker-column-internal", { class: "date-column", color: this.color, items: items, value: todayString, onIonChange: (ev) => {
1014
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1015
- // Due to a Safari 14 issue we need to destroy
1016
- // the scroll listener before we update state
1017
- // and trigger a re-render.
1018
- if (this.destroyCalendarListener) {
1019
- this.destroyCalendarListener();
1020
- }
1021
- const { value } = ev.detail;
1022
- const findPart = parts.find(({ month, day, year }) => value === `${year}-${month}-${day}`);
1023
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), findPart));
1024
- this.setActiveParts(Object.assign(Object.assign({}, activePart), findPart));
1025
- // We can re-attach the scroll listener after
1026
- // the working parts have been updated.
1027
- this.initializeCalendarListener();
1028
- ev.stopPropagation();
1029
- } }));
1030
- }
1031
- renderIndividualDatePickerColumns(forcePresentation) {
1032
- const { workingParts, isDateEnabled } = this;
1033
- const shouldRenderMonths = forcePresentation !== 'year' && forcePresentation !== 'time';
1034
- const months = shouldRenderMonths
1035
- ? getMonthColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedMonthValues)
1036
- : [];
1037
- const shouldRenderDays = forcePresentation === 'date';
1038
- let days = shouldRenderDays
1039
- ? getDayColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedDayValues)
1040
- : [];
1041
- if (isDateEnabled) {
1042
- days = days.map((dayObject) => {
1043
- const { value } = dayObject;
1044
- const valueNum = typeof value === 'string' ? parseInt(value) : value;
1045
- const referenceParts = {
1046
- month: workingParts.month,
1047
- day: valueNum,
1048
- year: workingParts.year,
1049
- };
1050
- let disabled;
1051
- try {
1052
- /**
1053
- * The `isDateEnabled` implementation is try-catch wrapped
1054
- * to prevent exceptions in the user's function from
1055
- * interrupting the calendar rendering.
1056
- */
1057
- disabled = !isDateEnabled(convertDataToISO(referenceParts));
1058
- }
1059
- catch (e) {
1060
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1061
- }
1062
- return Object.assign(Object.assign({}, dayObject), { disabled });
1063
- });
729
+ async reset(startDate) {
730
+ this.processValue(startDate);
1064
731
  }
1065
- const shouldRenderYears = forcePresentation !== 'month' && forcePresentation !== 'time';
1066
- const years = shouldRenderYears
1067
- ? getYearColumnData(this.locale, this.defaultParts, this.minParts, this.maxParts, this.parsedYearValues)
1068
- : [];
1069
732
  /**
1070
- * Certain locales show the day before the month.
733
+ * Emits the ionCancel event and
734
+ * optionally closes the popover
735
+ * or modal that the datetime was
736
+ * presented in.
1071
737
  */
1072
- const showMonthFirst = isMonthFirstLocale(this.locale, { month: 'numeric', day: 'numeric' });
1073
- let renderArray = [];
1074
- if (showMonthFirst) {
1075
- renderArray = [
1076
- this.renderMonthPickerColumn(months),
1077
- this.renderDayPickerColumn(days),
1078
- this.renderYearPickerColumn(years),
1079
- ];
738
+ async cancel(closeOverlay = false) {
739
+ this.ionCancel.emit();
740
+ if (closeOverlay) {
741
+ this.closeParentOverlay();
742
+ }
1080
743
  }
1081
- else {
1082
- renderArray = [
1083
- this.renderDayPickerColumn(days),
1084
- this.renderMonthPickerColumn(months),
1085
- this.renderYearPickerColumn(years),
1086
- ];
744
+ get isCalendarPicker() {
745
+ const { presentation } = this;
746
+ return presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1087
747
  }
1088
- return renderArray;
1089
- }
1090
- renderDayPickerColumn(days) {
1091
- var _a;
1092
- if (days.length === 0) {
1093
- return [];
748
+ connectedCallback() {
749
+ this.clearFocusVisible = startFocusVisible(this.el).destroy;
1094
750
  }
1095
- const { workingParts } = this;
1096
- const activePart = this.getActivePartsWithFallback();
1097
- return (h("ion-picker-column-internal", { class: "day-column", color: this.color, items: days, value: (_a = (workingParts.day !== null ? workingParts.day : this.defaultParts.day)) !== null && _a !== void 0 ? _a : undefined, onIonChange: (ev) => {
1098
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1099
- // Due to a Safari 14 issue we need to destroy
1100
- // the scroll listener before we update state
1101
- // and trigger a re-render.
1102
- if (this.destroyCalendarListener) {
1103
- this.destroyCalendarListener();
751
+ disconnectedCallback() {
752
+ if (this.clearFocusVisible) {
753
+ this.clearFocusVisible();
754
+ this.clearFocusVisible = undefined;
1104
755
  }
1105
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { day: ev.detail.value }));
1106
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { day: ev.detail.value }));
1107
- // We can re-attach the scroll listener after
1108
- // the working parts have been updated.
1109
- this.initializeCalendarListener();
1110
- ev.stopPropagation();
1111
- } }));
1112
- }
1113
- renderMonthPickerColumn(months) {
1114
- if (months.length === 0) {
1115
- return [];
1116
756
  }
1117
- const { workingParts } = this;
1118
- const activePart = this.getActivePartsWithFallback();
1119
- return (h("ion-picker-column-internal", { class: "month-column", color: this.color, items: months, value: workingParts.month, onIonChange: (ev) => {
1120
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1121
- // Due to a Safari 14 issue we need to destroy
1122
- // the scroll listener before we update state
1123
- // and trigger a re-render.
1124
- if (this.destroyCalendarListener) {
1125
- this.destroyCalendarListener();
1126
- }
1127
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { month: ev.detail.value }));
1128
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { month: ev.detail.value }));
1129
- // We can re-attach the scroll listener after
1130
- // the working parts have been updated.
757
+ initializeListeners() {
1131
758
  this.initializeCalendarListener();
1132
- ev.stopPropagation();
1133
- } }));
1134
- }
1135
- renderYearPickerColumn(years) {
1136
- if (years.length === 0) {
1137
- return [];
759
+ this.initializeKeyboardListeners();
1138
760
  }
1139
- const { workingParts } = this;
1140
- const activePart = this.getActivePartsWithFallback();
1141
- return (h("ion-picker-column-internal", { class: "year-column", color: this.color, items: years, value: workingParts.year, onIonChange: (ev) => {
1142
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1143
- // Due to a Safari 14 issue we need to destroy
1144
- // the scroll listener before we update state
1145
- // and trigger a re-render.
1146
- if (this.destroyCalendarListener) {
1147
- this.destroyCalendarListener();
1148
- }
1149
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { year: ev.detail.value }));
1150
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { year: ev.detail.value }));
1151
- // We can re-attach the scroll listener after
1152
- // the working parts have been updated.
1153
- this.initializeCalendarListener();
1154
- ev.stopPropagation();
1155
- } }));
1156
- }
1157
- renderTimePickerColumns(forcePresentation) {
1158
- if (['date', 'month', 'month-year', 'year'].includes(forcePresentation)) {
1159
- return [];
761
+ componentDidLoad() {
762
+ /**
763
+ * If a scrollable element is hidden using `display: none`,
764
+ * it will not have a scroll height meaning we cannot scroll elements
765
+ * into view. As a result, we will need to wait for the datetime to become
766
+ * visible if used inside of a modal or a popover otherwise the scrollable
767
+ * areas will not have the correct values snapped into place.
768
+ */
769
+ const visibleCallback = (entries) => {
770
+ const ev = entries[0];
771
+ if (!ev.isIntersecting) {
772
+ return;
773
+ }
774
+ this.initializeListeners();
775
+ /**
776
+ * TODO FW-2793: Datetime needs a frame to ensure that it
777
+ * can properly scroll contents into view. As a result
778
+ * we hide the scrollable content until after that frame
779
+ * so users do not see the content quickly shifting. The downside
780
+ * is that the content will pop into view a frame after. Maybe there
781
+ * is a better way to handle this?
782
+ */
783
+ writeTask(() => {
784
+ this.el.classList.add('datetime-ready');
785
+ });
786
+ };
787
+ const visibleIO = new IntersectionObserver(visibleCallback, { threshold: 0.01 });
788
+ /**
789
+ * Use raf to avoid a race condition between the component loading and
790
+ * its display animation starting (such as when shown in a modal). This
791
+ * could cause the datetime to start at a visibility of 0, erroneously
792
+ * triggering the `hiddenIO` observer below.
793
+ */
794
+ raf(() => visibleIO === null || visibleIO === void 0 ? void 0 : visibleIO.observe(this.el));
795
+ /**
796
+ * We need to clean up listeners when the datetime is hidden
797
+ * in a popover/modal so that we can properly scroll containers
798
+ * back into view if they are re-presented. When the datetime is hidden
799
+ * the scroll areas have scroll widths/heights of 0px, so any snapping
800
+ * we did originally has been lost.
801
+ */
802
+ const hiddenCallback = (entries) => {
803
+ const ev = entries[0];
804
+ if (ev.isIntersecting) {
805
+ return;
806
+ }
807
+ this.destroyInteractionListeners();
808
+ /**
809
+ * When datetime is hidden, we need to make sure that
810
+ * the month/year picker is closed. Otherwise,
811
+ * it will be open when the datetime re-appears
812
+ * and the scroll area of the calendar grid will be 0.
813
+ * As a result, the wrong month will be shown.
814
+ */
815
+ this.showMonthAndYear = false;
816
+ writeTask(() => {
817
+ this.el.classList.remove('datetime-ready');
818
+ });
819
+ };
820
+ const hiddenIO = new IntersectionObserver(hiddenCallback, { threshold: 0 });
821
+ raf(() => hiddenIO === null || hiddenIO === void 0 ? void 0 : hiddenIO.observe(this.el));
822
+ /**
823
+ * Datetime uses Ionic components that emit
824
+ * ionFocus and ionBlur. These events are
825
+ * composed meaning they will cross
826
+ * the shadow dom boundary. We need to
827
+ * stop propagation on these events otherwise
828
+ * developers will see 2 ionFocus or 2 ionBlur
829
+ * events at a time.
830
+ */
831
+ const root = getElementRoot(this.el);
832
+ root.addEventListener('ionFocus', (ev) => ev.stopPropagation());
833
+ root.addEventListener('ionBlur', (ev) => ev.stopPropagation());
1160
834
  }
1161
835
  /**
1162
- * If a user has not selected a date,
1163
- * then we should show all times. If the
1164
- * user has selected a date (even if it has
1165
- * not been confirmed yet), we should apply
1166
- * the max and min restrictions so that the
1167
- * time picker shows values that are
1168
- * appropriate for the selected date.
836
+ * When the presentation is changed, all calendar content is recreated,
837
+ * so we need to re-init behavior with the new elements.
1169
838
  */
1170
- const activePart = this.getActivePart();
1171
- const userHasSelectedDate = activePart !== undefined;
1172
- const { hoursData, minutesData, dayPeriodData } = getTimeColumnsData(this.locale, this.workingParts, this.hourCycle, userHasSelectedDate ? this.minParts : undefined, userHasSelectedDate ? this.maxParts : undefined, this.parsedHourValues, this.parsedMinuteValues);
1173
- return [
1174
- this.renderHourPickerColumn(hoursData),
1175
- this.renderMinutePickerColumn(minutesData),
1176
- this.renderDayPeriodPickerColumn(dayPeriodData),
1177
- ];
1178
- }
1179
- renderHourPickerColumn(hoursData) {
1180
- const { workingParts } = this;
1181
- if (hoursData.length === 0)
1182
- return [];
1183
- const activePart = this.getActivePartsWithFallback();
1184
- return (h("ion-picker-column-internal", { color: this.color, value: activePart.hour, items: hoursData, numericInput: true, onIonChange: (ev) => {
1185
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { hour: ev.detail.value }));
1186
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { hour: ev.detail.value }));
1187
- ev.stopPropagation();
1188
- } }));
1189
- }
1190
- renderMinutePickerColumn(minutesData) {
1191
- const { workingParts } = this;
1192
- if (minutesData.length === 0)
1193
- return [];
1194
- const activePart = this.getActivePartsWithFallback();
1195
- return (h("ion-picker-column-internal", { color: this.color, value: activePart.minute, items: minutesData, numericInput: true, onIonChange: (ev) => {
1196
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { minute: ev.detail.value }));
1197
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { minute: ev.detail.value }));
1198
- ev.stopPropagation();
1199
- } }));
1200
- }
1201
- renderDayPeriodPickerColumn(dayPeriodData) {
1202
- const { workingParts } = this;
1203
- if (dayPeriodData.length === 0) {
1204
- return [];
1205
- }
1206
- const activePart = this.getActivePartsWithFallback();
1207
- const isDayPeriodRTL = isLocaleDayPeriodRTL(this.locale);
1208
- return (h("ion-picker-column-internal", { style: isDayPeriodRTL ? { order: '-1' } : {}, color: this.color, value: activePart.ampm, items: dayPeriodData, onIonChange: (ev) => {
1209
- const hour = calculateHourFromAMPM(workingParts, ev.detail.value);
1210
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm: ev.detail.value, hour }));
1211
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { ampm: ev.detail.value, hour }));
1212
- ev.stopPropagation();
1213
- } }));
1214
- }
1215
- renderWheelView(forcePresentation) {
1216
- const { locale } = this;
1217
- const showMonthFirst = isMonthFirstLocale(locale);
1218
- const columnOrder = showMonthFirst ? 'month-first' : 'year-first';
1219
- return (h("div", { class: {
1220
- [`wheel-order-${columnOrder}`]: true,
1221
- } }, this.renderWheelPicker(forcePresentation)));
1222
- }
1223
- /**
1224
- * Grid Render Methods
1225
- */
1226
- renderCalendarHeader(mode) {
1227
- const expandedIcon = mode === 'ios' ? chevronDown : caretUpSharp;
1228
- const collapsedIcon = mode === 'ios' ? chevronForward : caretDownSharp;
1229
- const prevMonthDisabled = isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
1230
- const nextMonthDisabled = isNextMonthDisabled(this.workingParts, this.maxParts);
1231
- // don't use the inheritAttributes util because it removes dir from the host, and we still need that
1232
- const hostDir = this.el.getAttribute('dir') || undefined;
1233
- return (h("div", { class: "calendar-header" }, h("div", { class: "calendar-action-buttons" }, h("div", { class: "calendar-month-year" }, h("ion-item", { part: "month-year-button", ref: (el) => (this.monthYearToggleItemRef = el), button: true, "aria-label": "Show year picker", detail: false, lines: "none", onClick: () => {
1234
- var _a;
1235
- this.toggleMonthAndYearView();
839
+ componentDidRender() {
840
+ const { presentation, prevPresentation, calendarBodyRef, minParts, preferWheel, forceRenderDate } = this;
1236
841
  /**
1237
- * TODO: FW-3547
1238
- *
1239
- * Currently there is not a way to set the aria-label on the inner button
1240
- * on the `ion-item` and have it be reactive to changes. This is a workaround
1241
- * until we either refactor `ion-item` to a button or Stencil adds a way to
1242
- * have reactive props for built-in properties, such as `aria-label`.
842
+ * TODO(FW-2165)
843
+ * Remove this when https://bugs.webkit.org/show_bug.cgi?id=235960 is fixed.
844
+ * When using `min`, we add `scroll-snap-align: none`
845
+ * to the disabled month so that users cannot scroll to it.
846
+ * This triggers a bug in WebKit where the scroll position is reset.
847
+ * Since the month change logic is handled by a scroll listener,
848
+ * this causes the month to change leading to `scroll-snap-align`
849
+ * changing again, thus changing the scroll position again and causing
850
+ * an infinite loop.
851
+ * This issue only applies to the calendar grid, so we can disable
852
+ * it if the calendar grid is not being used.
1243
853
  */
1244
- const { monthYearToggleItemRef } = this;
1245
- if (monthYearToggleItemRef) {
1246
- const btn = (_a = monthYearToggleItemRef.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.item-native');
1247
- if (btn) {
1248
- const monthYearAriaLabel = this.showMonthAndYear ? 'Hide year picker' : 'Show year picker';
1249
- btn.setAttribute('aria-label', monthYearAriaLabel);
1250
- }
1251
- }
1252
- } }, h("ion-label", null, getMonthAndYear(this.locale, this.workingParts), h("ion-icon", { "aria-hidden": "true", icon: this.showMonthAndYear ? expandedIcon : collapsedIcon, lazy: false, flipRtl: true })))), h("div", { class: "calendar-next-prev" }, h("ion-buttons", null, h("ion-button", { "aria-label": "Previous month", disabled: prevMonthDisabled, onClick: () => this.prevMonth() }, h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: chevronBack, lazy: false, flipRtl: true })), h("ion-button", { "aria-label": "Next month", disabled: nextMonthDisabled, onClick: () => this.nextMonth() }, h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: chevronForward, lazy: false, flipRtl: true }))))), h("div", { class: "calendar-days-of-week", "aria-hidden": "true" }, getDaysOfWeek(this.locale, mode, this.firstDayOfWeek % 7).map((d) => {
1253
- return h("div", { class: "day-of-week" }, d);
1254
- }))));
1255
- }
1256
- renderMonth(month, year) {
1257
- const yearAllowed = this.parsedYearValues === undefined || this.parsedYearValues.includes(year);
1258
- const monthAllowed = this.parsedMonthValues === undefined || this.parsedMonthValues.includes(month);
1259
- const isCalMonthDisabled = !yearAllowed || !monthAllowed;
1260
- const swipeDisabled = isMonthDisabled({
1261
- month,
1262
- year,
1263
- day: null,
1264
- }, {
1265
- // The day is not used when checking if a month is disabled.
1266
- // Users should be able to access the min or max month, even if the
1267
- // min/max date is out of bounds (e.g. min is set to Feb 15, Feb should not be disabled).
1268
- minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
1269
- maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
1270
- });
1271
- // The working month should never have swipe disabled.
1272
- // Otherwise the CSS scroll snap will not work and the user
1273
- // can free-scroll the calendar.
1274
- const isWorkingMonth = this.workingParts.month === month && this.workingParts.year === year;
1275
- const activePart = this.getActivePartsWithFallback();
1276
- return (h("div", { "aria-hidden": !isWorkingMonth ? 'true' : null, class: {
1277
- 'calendar-month': true,
1278
- // Prevents scroll snap swipe gestures for months outside of the min/max bounds
1279
- 'calendar-month-disabled': !isWorkingMonth && swipeDisabled,
1280
- } }, h("div", { class: "calendar-month-grid" }, getDaysOfMonth(month, year, this.firstDayOfWeek % 7).map((dateObject, index) => {
1281
- const { day, dayOfWeek } = dateObject;
1282
- const { el, highlightedDates, isDateEnabled, multiple } = this;
1283
- const referenceParts = { month, day, year };
1284
- const isCalendarPadding = day === null;
1285
- const { isActive, isToday, ariaLabel, ariaSelected, disabled, text } = getCalendarDayState(this.locale, referenceParts, this.activeParts, this.todayParts, this.minParts, this.maxParts, this.parsedDayValues);
1286
- const dateIsoString = convertDataToISO(referenceParts);
1287
- let isCalDayDisabled = isCalMonthDisabled || disabled;
1288
- if (!isCalDayDisabled && isDateEnabled !== undefined) {
1289
- try {
1290
- /**
1291
- * The `isDateEnabled` implementation is try-catch wrapped
1292
- * to prevent exceptions in the user's function from
1293
- * interrupting the calendar rendering.
1294
- */
1295
- isCalDayDisabled = !isDateEnabled(dateIsoString);
854
+ const hasCalendarGrid = !preferWheel && ['date-time', 'time-date', 'date'].includes(presentation);
855
+ if (minParts !== undefined && hasCalendarGrid && calendarBodyRef) {
856
+ const workingMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(1)');
857
+ /**
858
+ * We need to make sure the datetime is not in the process
859
+ * of scrolling to a new datetime value if the value
860
+ * is updated programmatically.
861
+ * Otherwise, the datetime will appear to not scroll at all because
862
+ * we are resetting the scroll position to the center of the view.
863
+ * Prior to the datetime's value being updated programmatically,
864
+ * the calendarBodyRef is scrolled such that the middle month is centered
865
+ * in the view. The below code updates the scroll position so the middle
866
+ * month is also centered in the view. Since the scroll position did not change,
867
+ * the scroll callback in this file does not fire,
868
+ * and the resolveForceDateScrolling promise never resolves.
869
+ */
870
+ if (workingMonth && forceRenderDate === undefined) {
871
+ calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
872
+ }
1296
873
  }
1297
- catch (e) {
1298
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', el, e);
874
+ if (prevPresentation === null) {
875
+ this.prevPresentation = presentation;
876
+ return;
1299
877
  }
1300
- }
1301
- let dateStyle = undefined;
1302
- /**
1303
- * Custom highlight styles should not override the style for selected dates,
1304
- * nor apply to "filler days" at the start of the grid.
1305
- */
1306
- if (highlightedDates !== undefined && !isActive && day !== null) {
1307
- dateStyle = getHighlightStyles(highlightedDates, dateIsoString, el);
1308
- }
1309
- let dateParts = undefined;
1310
- // "Filler days" at the beginning of the grid should not get the calendar day
1311
- // CSS parts added to them
1312
- if (!isCalendarPadding) {
1313
- dateParts = `calendar-day${isActive ? ' active' : ''}${isToday ? ' today' : ''}${isCalDayDisabled ? ' disabled' : ''}`;
1314
- }
1315
- return (h("div", { class: "calendar-day-wrapper" }, h("button", {
1316
- // We need to use !important for the inline styles here because
1317
- // otherwise the CSS shadow parts will override these styles.
1318
- // See https://github.com/WICG/webcomponents/issues/847
1319
- // Both the CSS shadow parts and highlightedDates styles are
1320
- // provided by the developer, but highlightedDates styles should
1321
- // always take priority.
1322
- ref: (el) => {
1323
- if (el) {
1324
- el.style.setProperty('color', `${dateStyle ? dateStyle.textColor : ''}`, 'important');
1325
- el.style.setProperty('background-color', `${dateStyle ? dateStyle.backgroundColor : ''}`, 'important');
1326
- }
1327
- }, tabindex: "-1", "data-day": day, "data-month": month, "data-year": year, "data-index": index, "data-day-of-week": dayOfWeek, disabled: isCalDayDisabled, class: {
1328
- 'calendar-day-padding': isCalendarPadding,
1329
- 'calendar-day': true,
1330
- 'calendar-day-active': isActive,
1331
- 'calendar-day-today': isToday,
1332
- }, part: dateParts, "aria-hidden": isCalendarPadding ? 'true' : null, "aria-selected": ariaSelected, "aria-label": ariaLabel, onClick: () => {
1333
- if (isCalendarPadding) {
878
+ if (presentation === prevPresentation) {
1334
879
  return;
1335
- }
1336
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month,
1337
- day,
1338
- year }));
1339
- // multiple only needs date info, so we can wipe out other fields like time
1340
- if (multiple) {
1341
- this.setActiveParts({
1342
- month,
1343
- day,
1344
- year,
1345
- }, isActive);
1346
- }
1347
- else {
1348
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { month,
1349
- day,
1350
- year }));
1351
- }
1352
880
  }
1353
- }, text)));
1354
- }))));
1355
- }
1356
- renderCalendarBody() {
1357
- return (h("div", { class: "calendar-body ion-focusable", ref: (el) => (this.calendarBodyRef = el), tabindex: "0" }, generateMonths(this.workingParts, this.forceRenderDate).map(({ month, year }) => {
1358
- return this.renderMonth(month, year);
1359
- })));
1360
- }
1361
- renderCalendar(mode) {
1362
- return (h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(mode), this.renderCalendarBody()));
1363
- }
1364
- renderTimeLabel() {
1365
- const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
1366
- if (!hasSlottedTimeLabel && !this.showDefaultTimeLabel) {
1367
- return;
881
+ this.prevPresentation = presentation;
882
+ this.destroyInteractionListeners();
883
+ this.initializeListeners();
884
+ /**
885
+ * The month/year picker from the date interface
886
+ * should be closed as it is not available in non-date
887
+ * interfaces.
888
+ */
889
+ this.showMonthAndYear = false;
890
+ raf(() => {
891
+ this.ionRender.emit();
892
+ });
1368
893
  }
1369
- return h("slot", { name: "time-label" }, "Time");
1370
- }
1371
- renderTimeOverlay() {
1372
- const { hourCycle, isTimePopoverOpen, locale } = this;
1373
- const computedHourCycle = getHourCycle(locale, hourCycle);
1374
- const activePart = this.getActivePartsWithFallback();
1375
- return [
1376
- h("div", { class: "time-header" }, this.renderTimeLabel()),
1377
- h("button", { class: {
1378
- 'time-body': true,
1379
- 'time-body-active': isTimePopoverOpen,
1380
- }, part: `time-button${isTimePopoverOpen ? ' active' : ''}`, "aria-expanded": "false", "aria-haspopup": "true", onClick: async (ev) => {
1381
- const { popoverRef } = this;
1382
- if (popoverRef) {
1383
- this.isTimePopoverOpen = true;
1384
- popoverRef.present(new CustomEvent('ionShadowTarget', {
1385
- detail: {
1386
- ionShadowTarget: ev.target,
1387
- },
1388
- }));
1389
- await popoverRef.onWillDismiss();
1390
- this.isTimePopoverOpen = false;
1391
- }
1392
- } }, getLocalizedTime(locale, activePart, computedHourCycle)),
1393
- h("ion-popover", { alignment: "center", translucent: true, overlayIndex: 1, arrow: false, onWillPresent: (ev) => {
1394
- /**
1395
- * Intersection Observers do not consistently fire between Blink and Webkit
1396
- * when toggling the visibility of the popover and trying to scroll the picker
1397
- * column to the correct time value.
1398
- *
1399
- * This will correctly scroll the element position to the correct time value,
1400
- * before the popover is fully presented.
1401
- */
1402
- const cols = ev.target.querySelectorAll('ion-picker-column-internal');
1403
- // TODO (FW-615): Potentially remove this when intersection observers are fixed in picker column
1404
- cols.forEach((col) => col.scrollActiveItemIntoView());
1405
- }, style: {
1406
- '--offset-y': '-10px',
1407
- '--min-width': 'fit-content',
1408
- },
1409
- // Allow native browser keyboard events to support up/down/home/end key
1410
- // navigation within the time picker.
1411
- keyboardEvents: true, ref: (el) => (this.popoverRef = el) }, this.renderWheelPicker('time')),
1412
- ];
1413
- }
1414
- getHeaderSelectedDateText() {
1415
- const { activeParts, multiple, titleSelectedDatesFormatter } = this;
1416
- const isArray = Array.isArray(activeParts);
1417
- let headerText;
1418
- if (multiple && isArray && activeParts.length !== 1) {
1419
- headerText = `${activeParts.length} days`; // default/fallback for multiple selection
1420
- if (titleSelectedDatesFormatter !== undefined) {
1421
- try {
1422
- headerText = titleSelectedDatesFormatter(convertDataToISO(activeParts));
894
+ componentWillLoad() {
895
+ const { el, highlightedDates, multiple, presentation, preferWheel } = this;
896
+ if (multiple) {
897
+ if (presentation !== 'date') {
898
+ printIonWarning('Multiple date selection is only supported for presentation="date".', el);
899
+ }
900
+ if (preferWheel) {
901
+ printIonWarning('Multiple date selection is not supported with preferWheel="true".', el);
902
+ }
1423
903
  }
1424
- catch (e) {
1425
- printIonError('Exception in provided `titleSelectedDatesFormatter`: ', e);
904
+ if (highlightedDates !== undefined) {
905
+ if (presentation !== 'date' && presentation !== 'date-time' && presentation !== 'time-date') {
906
+ printIonWarning('The highlightedDates property is only supported with the date, date-time, and time-date presentations.', el);
907
+ }
908
+ if (preferWheel) {
909
+ printIonWarning('The highlightedDates property is not supported with preferWheel="true".', el);
910
+ }
1426
911
  }
1427
- }
912
+ const hourValues = (this.parsedHourValues = convertToArrayOfNumbers(this.hourValues));
913
+ const minuteValues = (this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues));
914
+ const monthValues = (this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues));
915
+ const yearValues = (this.parsedYearValues = convertToArrayOfNumbers(this.yearValues));
916
+ const dayValues = (this.parsedDayValues = convertToArrayOfNumbers(this.dayValues));
917
+ const todayParts = (this.todayParts = parseDate(getToday()));
918
+ this.defaultParts = getClosestValidDate(todayParts, monthValues, dayValues, yearValues, hourValues, minuteValues);
919
+ this.processMinParts();
920
+ this.processMaxParts();
921
+ this.processValue(this.value);
922
+ this.emitStyle();
1428
923
  }
1429
- else {
1430
- // for exactly 1 day selected (multiple set or not), show a formatted version of that
1431
- headerText = getMonthAndDay(this.locale, this.getActivePartsWithFallback());
924
+ emitStyle() {
925
+ this.ionStyle.emit({
926
+ interactive: true,
927
+ datetime: true,
928
+ 'interactive-disabled': this.disabled,
929
+ });
1432
930
  }
1433
- return headerText;
1434
- }
1435
- renderHeader(showExpandedHeader = true) {
1436
- const hasSlottedTitle = this.el.querySelector('[slot="title"]') !== null;
1437
- if (!hasSlottedTitle && !this.showDefaultTitle) {
1438
- return;
931
+ /**
932
+ * Universal render methods
933
+ * These are pieces of datetime that
934
+ * are rendered independently of presentation.
935
+ */
936
+ renderFooter() {
937
+ const { disabled, readonly, showDefaultButtons, showClearButton } = this;
938
+ /**
939
+ * The cancel, clear, and confirm buttons
940
+ * should not be interactive if the datetime
941
+ * is disabled or readonly.
942
+ */
943
+ const isButtonDisabled = disabled || readonly;
944
+ const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
945
+ if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
946
+ return;
947
+ }
948
+ const clearButtonClick = () => {
949
+ this.reset();
950
+ this.setValue(undefined);
951
+ };
952
+ /**
953
+ * By default we render two buttons:
954
+ * Cancel - Dismisses the datetime and
955
+ * does not update the `value` prop.
956
+ * OK - Dismisses the datetime and
957
+ * updates the `value` prop.
958
+ */
959
+ return (h("div", { class: "datetime-footer" }, h("div", { class: "datetime-buttons" }, h("div", { class: {
960
+ ['datetime-action-buttons']: true,
961
+ ['has-clear-button']: this.showClearButton,
962
+ } }, h("slot", { name: "buttons" }, h("ion-buttons", null, showDefaultButtons && (h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true), disabled: isButtonDisabled }, this.cancelText)), h("div", { class: "datetime-action-buttons-container" }, showClearButton && (h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick(), disabled: isButtonDisabled }, this.clearText)), showDefaultButtons && (h("ion-button", { id: "confirm-button", color: this.color, onClick: () => this.confirm(true), disabled: isButtonDisabled }, this.doneText)))))))));
1439
963
  }
1440
- return (h("div", { class: "datetime-header" }, h("div", { class: "datetime-title" }, h("slot", { name: "title" }, "Select Date")), showExpandedHeader && h("div", { class: "datetime-selected-date" }, this.getHeaderSelectedDateText())));
1441
- }
1442
- /**
1443
- * Render time picker inside of datetime.
1444
- * Do not pass color prop to segment on
1445
- * iOS mode. MD segment has been customized and
1446
- * should take on the color prop, but iOS
1447
- * should just be the default segment.
1448
- */
1449
- renderTime() {
1450
- const { presentation } = this;
1451
- const timeOnlyPresentation = presentation === 'time';
1452
- return (h("div", { class: "datetime-time" }, timeOnlyPresentation ? this.renderWheelPicker() : this.renderTimeOverlay()));
1453
- }
1454
- /**
1455
- * Renders the month/year picker that is
1456
- * displayed on the calendar grid.
1457
- * The .datetime-year class has additional
1458
- * styles that let us show/hide the
1459
- * picker when the user clicks on the
1460
- * toggle in the calendar header.
1461
- */
1462
- renderCalendarViewMonthYearPicker() {
1463
- return h("div", { class: "datetime-year" }, this.renderWheelView('month-year'));
1464
- }
1465
- /**
1466
- * Render entry point
1467
- * All presentation types are rendered from here.
1468
- */
1469
- renderDatetime(mode) {
1470
- const { presentation, preferWheel } = this;
1471
964
  /**
1472
- * Certain presentation types have separate grid and wheel displays.
1473
- * If preferWheel is true then we should show a wheel picker instead.
965
+ * Wheel picker render methods
1474
966
  */
1475
- const hasWheelVariant = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1476
- if (preferWheel && hasWheelVariant) {
1477
- return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
967
+ renderWheelPicker(forcePresentation = this.presentation) {
968
+ /**
969
+ * If presentation="time-date" we switch the
970
+ * order of the render array here instead of
971
+ * manually reordering each date/time picker
972
+ * column with CSS. This allows for additional
973
+ * flexibility if we need to render subsets
974
+ * of the date/time data or do additional ordering
975
+ * within the child render functions.
976
+ */
977
+ const renderArray = forcePresentation === 'time-date'
978
+ ? [this.renderTimePickerColumns(forcePresentation), this.renderDatePickerColumns(forcePresentation)]
979
+ : [this.renderDatePickerColumns(forcePresentation), this.renderTimePickerColumns(forcePresentation)];
980
+ return h("ion-picker-internal", null, renderArray);
1478
981
  }
1479
- switch (presentation) {
1480
- case 'date-time':
1481
- return [
1482
- this.renderHeader(),
1483
- this.renderCalendar(mode),
1484
- this.renderCalendarViewMonthYearPicker(),
1485
- this.renderTime(),
1486
- this.renderFooter(),
1487
- ];
1488
- case 'time-date':
1489
- return [
1490
- this.renderHeader(),
1491
- this.renderTime(),
1492
- this.renderCalendar(mode),
1493
- this.renderCalendarViewMonthYearPicker(),
1494
- this.renderFooter(),
1495
- ];
1496
- case 'time':
1497
- return [this.renderHeader(false), this.renderTime(), this.renderFooter()];
1498
- case 'month':
1499
- case 'month-year':
1500
- case 'year':
1501
- return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1502
- default:
982
+ renderDatePickerColumns(forcePresentation) {
983
+ return forcePresentation === 'date-time' || forcePresentation === 'time-date'
984
+ ? this.renderCombinedDatePickerColumn()
985
+ : this.renderIndividualDatePickerColumns(forcePresentation);
986
+ }
987
+ renderCombinedDatePickerColumn() {
988
+ const { defaultParts, disabled, workingParts, locale, minParts, maxParts, todayParts, isDateEnabled } = this;
989
+ const activePart = this.getActivePartsWithFallback();
990
+ /**
991
+ * By default, generate a range of 3 months:
992
+ * Previous month, current month, and next month
993
+ */
994
+ const monthsToRender = generateMonths(workingParts);
995
+ const lastMonth = monthsToRender[monthsToRender.length - 1];
996
+ /**
997
+ * Ensure that users can select the entire window of dates.
998
+ */
999
+ monthsToRender[0].day = 1;
1000
+ lastMonth.day = getNumDaysInMonth(lastMonth.month, lastMonth.year);
1001
+ /**
1002
+ * Narrow the dates rendered based on min/max dates (if any).
1003
+ * The `min` date is used if the min is after the generated min month.
1004
+ * The `max` date is used if the max is before the generated max month.
1005
+ * This ensures that the sliding window always stays at 3 months
1006
+ * but still allows future dates to be lazily rendered based on any min/max
1007
+ * constraints.
1008
+ */
1009
+ const min = minParts !== undefined && isAfter(minParts, monthsToRender[0]) ? minParts : monthsToRender[0];
1010
+ const max = maxParts !== undefined && isBefore(maxParts, lastMonth) ? maxParts : lastMonth;
1011
+ const result = getCombinedDateColumnData(locale, todayParts, min, max, this.parsedDayValues, this.parsedMonthValues);
1012
+ let items = result.items;
1013
+ const parts = result.parts;
1014
+ if (isDateEnabled) {
1015
+ items = items.map((itemObject, index) => {
1016
+ const referenceParts = parts[index];
1017
+ let disabled;
1018
+ try {
1019
+ /**
1020
+ * The `isDateEnabled` implementation is try-catch wrapped
1021
+ * to prevent exceptions in the user's function from
1022
+ * interrupting the calendar rendering.
1023
+ */
1024
+ disabled = !isDateEnabled(convertDataToISO(referenceParts));
1025
+ }
1026
+ catch (e) {
1027
+ printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1028
+ }
1029
+ return Object.assign(Object.assign({}, itemObject), { disabled });
1030
+ });
1031
+ }
1032
+ /**
1033
+ * If we have selected a day already, then default the column
1034
+ * to that value. Otherwise, set it to the default date.
1035
+ */
1036
+ const todayString = workingParts.day !== null
1037
+ ? `${workingParts.year}-${workingParts.month}-${workingParts.day}`
1038
+ : `${defaultParts.year}-${defaultParts.month}-${defaultParts.day}`;
1039
+ return (h("ion-picker-column-internal", { class: "date-column", color: this.color, disabled: disabled, items: items, value: todayString, onIonChange: (ev) => {
1040
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1041
+ // Due to a Safari 14 issue we need to destroy
1042
+ // the scroll listener before we update state
1043
+ // and trigger a re-render.
1044
+ if (this.destroyCalendarListener) {
1045
+ this.destroyCalendarListener();
1046
+ }
1047
+ const { value } = ev.detail;
1048
+ const findPart = parts.find(({ month, day, year }) => value === `${year}-${month}-${day}`);
1049
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), findPart));
1050
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), findPart));
1051
+ // We can re-attach the scroll listener after
1052
+ // the working parts have been updated.
1053
+ this.initializeCalendarListener();
1054
+ ev.stopPropagation();
1055
+ } }));
1056
+ }
1057
+ renderIndividualDatePickerColumns(forcePresentation) {
1058
+ const { workingParts, isDateEnabled } = this;
1059
+ const shouldRenderMonths = forcePresentation !== 'year' && forcePresentation !== 'time';
1060
+ const months = shouldRenderMonths
1061
+ ? getMonthColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedMonthValues)
1062
+ : [];
1063
+ const shouldRenderDays = forcePresentation === 'date';
1064
+ let days = shouldRenderDays
1065
+ ? getDayColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedDayValues)
1066
+ : [];
1067
+ if (isDateEnabled) {
1068
+ days = days.map((dayObject) => {
1069
+ const { value } = dayObject;
1070
+ const valueNum = typeof value === 'string' ? parseInt(value) : value;
1071
+ const referenceParts = {
1072
+ month: workingParts.month,
1073
+ day: valueNum,
1074
+ year: workingParts.year,
1075
+ };
1076
+ let disabled;
1077
+ try {
1078
+ /**
1079
+ * The `isDateEnabled` implementation is try-catch wrapped
1080
+ * to prevent exceptions in the user's function from
1081
+ * interrupting the calendar rendering.
1082
+ */
1083
+ disabled = !isDateEnabled(convertDataToISO(referenceParts));
1084
+ }
1085
+ catch (e) {
1086
+ printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1087
+ }
1088
+ return Object.assign(Object.assign({}, dayObject), { disabled });
1089
+ });
1090
+ }
1091
+ const shouldRenderYears = forcePresentation !== 'month' && forcePresentation !== 'time';
1092
+ const years = shouldRenderYears
1093
+ ? getYearColumnData(this.locale, this.defaultParts, this.minParts, this.maxParts, this.parsedYearValues)
1094
+ : [];
1095
+ /**
1096
+ * Certain locales show the day before the month.
1097
+ */
1098
+ const showMonthFirst = isMonthFirstLocale(this.locale, { month: 'numeric', day: 'numeric' });
1099
+ let renderArray = [];
1100
+ if (showMonthFirst) {
1101
+ renderArray = [
1102
+ this.renderMonthPickerColumn(months),
1103
+ this.renderDayPickerColumn(days),
1104
+ this.renderYearPickerColumn(years),
1105
+ ];
1106
+ }
1107
+ else {
1108
+ renderArray = [
1109
+ this.renderDayPickerColumn(days),
1110
+ this.renderMonthPickerColumn(months),
1111
+ this.renderYearPickerColumn(years),
1112
+ ];
1113
+ }
1114
+ return renderArray;
1115
+ }
1116
+ renderDayPickerColumn(days) {
1117
+ var _a;
1118
+ if (days.length === 0) {
1119
+ return [];
1120
+ }
1121
+ const { disabled, workingParts } = this;
1122
+ const activePart = this.getActivePartsWithFallback();
1123
+ return (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) => {
1124
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1125
+ // Due to a Safari 14 issue we need to destroy
1126
+ // the scroll listener before we update state
1127
+ // and trigger a re-render.
1128
+ if (this.destroyCalendarListener) {
1129
+ this.destroyCalendarListener();
1130
+ }
1131
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { day: ev.detail.value }));
1132
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { day: ev.detail.value }));
1133
+ // We can re-attach the scroll listener after
1134
+ // the working parts have been updated.
1135
+ this.initializeCalendarListener();
1136
+ ev.stopPropagation();
1137
+ } }));
1138
+ }
1139
+ renderMonthPickerColumn(months) {
1140
+ if (months.length === 0) {
1141
+ return [];
1142
+ }
1143
+ const { disabled, workingParts } = this;
1144
+ const activePart = this.getActivePartsWithFallback();
1145
+ return (h("ion-picker-column-internal", { class: "month-column", color: this.color, disabled: disabled, items: months, value: workingParts.month, onIonChange: (ev) => {
1146
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1147
+ // Due to a Safari 14 issue we need to destroy
1148
+ // the scroll listener before we update state
1149
+ // and trigger a re-render.
1150
+ if (this.destroyCalendarListener) {
1151
+ this.destroyCalendarListener();
1152
+ }
1153
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { month: ev.detail.value }));
1154
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { month: ev.detail.value }));
1155
+ // We can re-attach the scroll listener after
1156
+ // the working parts have been updated.
1157
+ this.initializeCalendarListener();
1158
+ ev.stopPropagation();
1159
+ } }));
1160
+ }
1161
+ renderYearPickerColumn(years) {
1162
+ if (years.length === 0) {
1163
+ return [];
1164
+ }
1165
+ const { disabled, workingParts } = this;
1166
+ const activePart = this.getActivePartsWithFallback();
1167
+ return (h("ion-picker-column-internal", { class: "year-column", color: this.color, disabled: disabled, items: years, value: workingParts.year, onIonChange: (ev) => {
1168
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1169
+ // Due to a Safari 14 issue we need to destroy
1170
+ // the scroll listener before we update state
1171
+ // and trigger a re-render.
1172
+ if (this.destroyCalendarListener) {
1173
+ this.destroyCalendarListener();
1174
+ }
1175
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { year: ev.detail.value }));
1176
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { year: ev.detail.value }));
1177
+ // We can re-attach the scroll listener after
1178
+ // the working parts have been updated.
1179
+ this.initializeCalendarListener();
1180
+ ev.stopPropagation();
1181
+ } }));
1182
+ }
1183
+ renderTimePickerColumns(forcePresentation) {
1184
+ if (['date', 'month', 'month-year', 'year'].includes(forcePresentation)) {
1185
+ return [];
1186
+ }
1187
+ /**
1188
+ * If a user has not selected a date,
1189
+ * then we should show all times. If the
1190
+ * user has selected a date (even if it has
1191
+ * not been confirmed yet), we should apply
1192
+ * the max and min restrictions so that the
1193
+ * time picker shows values that are
1194
+ * appropriate for the selected date.
1195
+ */
1196
+ const activePart = this.getActivePart();
1197
+ const userHasSelectedDate = activePart !== undefined;
1198
+ const { hoursData, minutesData, dayPeriodData } = getTimeColumnsData(this.locale, this.workingParts, this.hourCycle, userHasSelectedDate ? this.minParts : undefined, userHasSelectedDate ? this.maxParts : undefined, this.parsedHourValues, this.parsedMinuteValues);
1503
1199
  return [
1504
- this.renderHeader(),
1505
- this.renderCalendar(mode),
1506
- this.renderCalendarViewMonthYearPicker(),
1507
- this.renderFooter(),
1200
+ this.renderHourPickerColumn(hoursData),
1201
+ this.renderMinutePickerColumn(minutesData),
1202
+ this.renderDayPeriodPickerColumn(dayPeriodData),
1508
1203
  ];
1509
1204
  }
1510
- }
1511
- render() {
1512
- const { name, value, disabled, el, color, readonly, showMonthAndYear, preferWheel, presentation, size, isGridStyle, } = this;
1513
- const mode = getIonMode(this);
1514
- const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
1515
- const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
1516
- const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
1517
- const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1518
- const hasWheelVariant = hasDatePresentation && preferWheel;
1519
- renderHiddenInput(true, el, name, formatValue(value), disabled);
1520
- return (h(Host, { "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, createColorClasses(color, {
1521
- [mode]: true,
1522
- ['datetime-readonly']: readonly,
1523
- ['datetime-disabled']: disabled,
1524
- 'show-month-and-year': shouldShowMonthAndYear,
1525
- 'month-year-picker-open': monthYearPickerOpen,
1526
- [`datetime-presentation-${presentation}`]: true,
1527
- [`datetime-size-${size}`]: true,
1528
- [`datetime-prefer-wheel`]: hasWheelVariant,
1529
- [`datetime-grid`]: isGridStyle,
1530
- })) }, this.renderDatetime(mode)));
1531
- }
1532
- static get is() { return "ion-datetime"; }
1533
- static get encapsulation() { return "shadow"; }
1534
- static get originalStyleUrls() {
1535
- return {
1536
- "ios": ["datetime.ios.scss"],
1537
- "md": ["datetime.md.scss"]
1538
- };
1539
- }
1540
- static get styleUrls() {
1541
- return {
1542
- "ios": ["datetime.ios.css"],
1543
- "md": ["datetime.md.css"]
1544
- };
1545
- }
1546
- static get properties() {
1547
- return {
1548
- "color": {
1549
- "type": "string",
1550
- "mutable": false,
1551
- "complexType": {
1552
- "original": "Color",
1553
- "resolved": "\"danger\" | \"dark\" | \"light\" | \"medium\" | \"primary\" | \"secondary\" | \"success\" | \"tertiary\" | \"warning\" | string & Record<never, never> | undefined",
1554
- "references": {
1555
- "Color": {
1556
- "location": "import",
1557
- "path": "../../interface",
1558
- "id": "src/interface.d.ts::Color"
1559
- }
1560
- }
1561
- },
1562
- "required": false,
1563
- "optional": true,
1564
- "docs": {
1565
- "tags": [],
1566
- "text": "The color to use from your application's color palette.\nDefault options are: `\"primary\"`, `\"secondary\"`, `\"tertiary\"`, `\"success\"`, `\"warning\"`, `\"danger\"`, `\"light\"`, `\"medium\"`, and `\"dark\"`.\nFor more information on colors, see [theming](/docs/theming/basics)."
1567
- },
1568
- "attribute": "color",
1569
- "reflect": false,
1570
- "defaultValue": "'primary'"
1571
- },
1572
- "name": {
1573
- "type": "string",
1574
- "mutable": false,
1575
- "complexType": {
1576
- "original": "string",
1577
- "resolved": "string",
1578
- "references": {}
1579
- },
1580
- "required": false,
1581
- "optional": false,
1582
- "docs": {
1583
- "tags": [],
1584
- "text": "The name of the control, which is submitted with the form data."
1585
- },
1586
- "attribute": "name",
1587
- "reflect": false,
1588
- "defaultValue": "this.inputId"
1589
- },
1590
- "disabled": {
1591
- "type": "boolean",
1592
- "mutable": false,
1593
- "complexType": {
1594
- "original": "boolean",
1595
- "resolved": "boolean",
1596
- "references": {}
1597
- },
1598
- "required": false,
1599
- "optional": false,
1600
- "docs": {
1601
- "tags": [],
1602
- "text": "If `true`, the user cannot interact with the datetime."
1603
- },
1604
- "attribute": "disabled",
1605
- "reflect": false,
1606
- "defaultValue": "false"
1607
- },
1608
- "readonly": {
1609
- "type": "boolean",
1610
- "mutable": false,
1611
- "complexType": {
1612
- "original": "boolean",
1613
- "resolved": "boolean",
1614
- "references": {}
1615
- },
1616
- "required": false,
1617
- "optional": false,
1618
- "docs": {
1619
- "tags": [],
1620
- "text": "If `true`, the datetime appears normal but is not interactive."
1621
- },
1622
- "attribute": "readonly",
1623
- "reflect": false,
1624
- "defaultValue": "false"
1625
- },
1626
- "isDateEnabled": {
1627
- "type": "unknown",
1628
- "mutable": false,
1629
- "complexType": {
1630
- "original": "(dateIsoString: string) => boolean",
1631
- "resolved": "((dateIsoString: string) => boolean) | undefined",
1632
- "references": {}
1633
- },
1634
- "required": false,
1635
- "optional": true,
1636
- "docs": {
1637
- "tags": [],
1638
- "text": "Returns if an individual date (calendar day) is enabled or disabled.\n\nIf `true`, the day will be enabled/interactive.\nIf `false`, the day will be disabled/non-interactive.\n\nThe function accepts an ISO 8601 date string of a given day.\nBy default, all days are enabled. Developers can use this function\nto write custom logic to disable certain days.\n\nThe function is called for each rendered calendar day, for the previous, current and next month.\nCustom implementations should be optimized for performance to avoid jank."
1639
- }
1640
- },
1641
- "min": {
1642
- "type": "string",
1643
- "mutable": true,
1644
- "complexType": {
1645
- "original": "string",
1646
- "resolved": "string | undefined",
1647
- "references": {}
1648
- },
1649
- "required": false,
1650
- "optional": true,
1651
- "docs": {
1652
- "tags": [],
1653
- "text": "The minimum datetime allowed. Value must be a date string\nfollowing the\n[ISO 8601 datetime format standard](https://www.w3.org/TR/NOTE-datetime),\nsuch as `1996-12-19`. The format does not have to be specific to an exact\ndatetime. For example, the minimum could just be the year, such as `1994`.\nDefaults to the beginning of the year, 100 years ago from today."
1654
- },
1655
- "attribute": "min",
1656
- "reflect": false
1657
- },
1658
- "max": {
1659
- "type": "string",
1660
- "mutable": true,
1661
- "complexType": {
1662
- "original": "string",
1663
- "resolved": "string | undefined",
1664
- "references": {}
1665
- },
1666
- "required": false,
1667
- "optional": true,
1668
- "docs": {
1669
- "tags": [],
1670
- "text": "The maximum datetime allowed. Value must be a date string\nfollowing the\n[ISO 8601 datetime format standard](https://www.w3.org/TR/NOTE-datetime),\n`1996-12-19`. The format does not have to be specific to an exact\ndatetime. For example, the maximum could just be the year, such as `1994`.\nDefaults to the end of this year."
1671
- },
1672
- "attribute": "max",
1673
- "reflect": false
1674
- },
1675
- "presentation": {
1676
- "type": "string",
1677
- "mutable": false,
1678
- "complexType": {
1679
- "original": "DatetimePresentation",
1680
- "resolved": "\"date\" | \"date-time\" | \"month\" | \"month-year\" | \"time\" | \"time-date\" | \"year\"",
1681
- "references": {
1682
- "DatetimePresentation": {
1683
- "location": "import",
1684
- "path": "./datetime-interface",
1685
- "id": "src/components/datetime/datetime-interface.ts::DatetimePresentation"
1686
- }
1687
- }
1688
- },
1689
- "required": false,
1690
- "optional": false,
1691
- "docs": {
1692
- "tags": [],
1693
- "text": "Which values you want to select. `\"date\"` will show\na calendar picker to select the month, day, and year. `\"time\"`\nwill show a time picker to select the hour, minute, and (optionally)\nAM/PM. `\"date-time\"` will show the date picker first and time picker second.\n`\"time-date\"` will show the time picker first and date picker second."
1694
- },
1695
- "attribute": "presentation",
1696
- "reflect": false,
1697
- "defaultValue": "'date-time'"
1698
- },
1699
- "cancelText": {
1700
- "type": "string",
1701
- "mutable": false,
1702
- "complexType": {
1703
- "original": "string",
1704
- "resolved": "string",
1705
- "references": {}
1706
- },
1707
- "required": false,
1708
- "optional": false,
1709
- "docs": {
1710
- "tags": [],
1711
- "text": "The text to display on the picker's cancel button."
1712
- },
1713
- "attribute": "cancel-text",
1714
- "reflect": false,
1715
- "defaultValue": "'Cancel'"
1716
- },
1717
- "doneText": {
1718
- "type": "string",
1719
- "mutable": false,
1720
- "complexType": {
1721
- "original": "string",
1722
- "resolved": "string",
1723
- "references": {}
1724
- },
1725
- "required": false,
1726
- "optional": false,
1727
- "docs": {
1728
- "tags": [],
1729
- "text": "The text to display on the picker's \"Done\" button."
1730
- },
1731
- "attribute": "done-text",
1732
- "reflect": false,
1733
- "defaultValue": "'Done'"
1734
- },
1735
- "clearText": {
1736
- "type": "string",
1737
- "mutable": false,
1738
- "complexType": {
1739
- "original": "string",
1740
- "resolved": "string",
1741
- "references": {}
1742
- },
1743
- "required": false,
1744
- "optional": false,
1745
- "docs": {
1746
- "tags": [],
1747
- "text": "The text to display on the picker's \"Clear\" button."
1748
- },
1749
- "attribute": "clear-text",
1750
- "reflect": false,
1751
- "defaultValue": "'Clear'"
1752
- },
1753
- "yearValues": {
1754
- "type": "any",
1755
- "mutable": false,
1756
- "complexType": {
1757
- "original": "number[] | number | string",
1758
- "resolved": "number | number[] | string | undefined",
1759
- "references": {}
1760
- },
1761
- "required": false,
1762
- "optional": true,
1763
- "docs": {
1764
- "tags": [],
1765
- "text": "Values used to create the list of selectable years. By default\nthe year values range between the `min` and `max` datetime inputs. However, to\ncontrol exactly which years to display, the `yearValues` input can take a number, an array\nof numbers, or string of comma separated numbers. For example, to show upcoming and\nrecent leap years, then this input's value would be `yearValues=\"2008,2012,2016,2020,2024\"`."
1766
- },
1767
- "attribute": "year-values",
1768
- "reflect": false
1769
- },
1770
- "monthValues": {
1771
- "type": "any",
1772
- "mutable": false,
1773
- "complexType": {
1774
- "original": "number[] | number | string",
1775
- "resolved": "number | number[] | string | undefined",
1776
- "references": {}
1777
- },
1778
- "required": false,
1779
- "optional": true,
1780
- "docs": {
1781
- "tags": [],
1782
- "text": "Values used to create the list of selectable months. By default\nthe month values range from `1` to `12`. However, to control exactly which months to\ndisplay, the `monthValues` input can take a number, an array of numbers, or a string of\ncomma separated numbers. For example, if only summer months should be shown, then this\ninput value would be `monthValues=\"6,7,8\"`. Note that month numbers do *not* have a\nzero-based index, meaning January's value is `1`, and December's is `12`."
1783
- },
1784
- "attribute": "month-values",
1785
- "reflect": false
1786
- },
1787
- "dayValues": {
1788
- "type": "any",
1789
- "mutable": false,
1790
- "complexType": {
1791
- "original": "number[] | number | string",
1792
- "resolved": "number | number[] | string | undefined",
1793
- "references": {}
1794
- },
1795
- "required": false,
1796
- "optional": true,
1797
- "docs": {
1798
- "tags": [],
1799
- "text": "Values used to create the list of selectable days. By default\nevery day is shown for the given month. However, to control exactly which days of\nthe month to display, the `dayValues` input can take a number, an array of numbers, or\na string of comma separated numbers. Note that even if the array days have an invalid\nnumber for the selected month, like `31` in February, it will correctly not show\ndays which are not valid for the selected month."
1800
- },
1801
- "attribute": "day-values",
1802
- "reflect": false
1803
- },
1804
- "hourValues": {
1805
- "type": "any",
1806
- "mutable": false,
1807
- "complexType": {
1808
- "original": "number[] | number | string",
1809
- "resolved": "number | number[] | string | undefined",
1810
- "references": {}
1811
- },
1812
- "required": false,
1813
- "optional": true,
1814
- "docs": {
1815
- "tags": [],
1816
- "text": "Values used to create the list of selectable hours. By default\nthe hour values range from `0` to `23` for 24-hour, or `1` to `12` for 12-hour. However,\nto control exactly which hours to display, the `hourValues` input can take a number, an\narray of numbers, or a string of comma separated numbers."
1817
- },
1818
- "attribute": "hour-values",
1819
- "reflect": false
1820
- },
1821
- "minuteValues": {
1822
- "type": "any",
1823
- "mutable": false,
1824
- "complexType": {
1825
- "original": "number[] | number | string",
1826
- "resolved": "number | number[] | string | undefined",
1827
- "references": {}
1828
- },
1829
- "required": false,
1830
- "optional": true,
1831
- "docs": {
1832
- "tags": [],
1833
- "text": "Values used to create the list of selectable minutes. By default\nthe minutes range from `0` to `59`. However, to control exactly which minutes to display,\nthe `minuteValues` input can take a number, an array of numbers, or a string of comma\nseparated numbers. For example, if the minute selections should only be every 15 minutes,\nthen this input value would be `minuteValues=\"0,15,30,45\"`."
1834
- },
1835
- "attribute": "minute-values",
1836
- "reflect": false
1837
- },
1838
- "locale": {
1839
- "type": "string",
1840
- "mutable": false,
1841
- "complexType": {
1842
- "original": "string",
1843
- "resolved": "string",
1844
- "references": {}
1845
- },
1846
- "required": false,
1847
- "optional": false,
1848
- "docs": {
1849
- "tags": [],
1850
- "text": "The locale to use for `ion-datetime`. This\nimpacts month and day name formatting.\nThe `\"default\"` value refers to the default\nlocale set by your device."
1851
- },
1852
- "attribute": "locale",
1853
- "reflect": false,
1854
- "defaultValue": "'default'"
1855
- },
1856
- "firstDayOfWeek": {
1857
- "type": "number",
1858
- "mutable": false,
1859
- "complexType": {
1860
- "original": "number",
1861
- "resolved": "number",
1862
- "references": {}
1863
- },
1864
- "required": false,
1865
- "optional": false,
1866
- "docs": {
1867
- "tags": [],
1868
- "text": "The first day of the week to use for `ion-datetime`. The\ndefault value is `0` and represents Sunday."
1869
- },
1870
- "attribute": "first-day-of-week",
1871
- "reflect": false,
1872
- "defaultValue": "0"
1873
- },
1874
- "titleSelectedDatesFormatter": {
1875
- "type": "unknown",
1876
- "mutable": false,
1877
- "complexType": {
1878
- "original": "TitleSelectedDatesFormatter",
1879
- "resolved": "((selectedDates: string[]) => string) | undefined",
1880
- "references": {
1881
- "TitleSelectedDatesFormatter": {
1882
- "location": "import",
1883
- "path": "./datetime-interface",
1884
- "id": "src/components/datetime/datetime-interface.ts::TitleSelectedDatesFormatter"
1885
- }
1886
- }
1887
- },
1888
- "required": false,
1889
- "optional": true,
1890
- "docs": {
1891
- "tags": [],
1892
- "text": "A callback used to format the header text that shows how many\ndates are selected. Only used if there are 0 or more than 1\nselected (i.e. unused for exactly 1). By default, the header\ntext is set to \"numberOfDates days\"."
1205
+ renderHourPickerColumn(hoursData) {
1206
+ const { disabled, workingParts } = this;
1207
+ if (hoursData.length === 0)
1208
+ return [];
1209
+ const activePart = this.getActivePartsWithFallback();
1210
+ return (h("ion-picker-column-internal", { color: this.color, disabled: disabled, value: activePart.hour, items: hoursData, numericInput: true, onIonChange: (ev) => {
1211
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { hour: ev.detail.value }));
1212
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { hour: ev.detail.value }));
1213
+ ev.stopPropagation();
1214
+ } }));
1215
+ }
1216
+ renderMinutePickerColumn(minutesData) {
1217
+ const { disabled, workingParts } = this;
1218
+ if (minutesData.length === 0)
1219
+ return [];
1220
+ const activePart = this.getActivePartsWithFallback();
1221
+ return (h("ion-picker-column-internal", { color: this.color, disabled: disabled, value: activePart.minute, items: minutesData, numericInput: true, onIonChange: (ev) => {
1222
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { minute: ev.detail.value }));
1223
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { minute: ev.detail.value }));
1224
+ ev.stopPropagation();
1225
+ } }));
1226
+ }
1227
+ renderDayPeriodPickerColumn(dayPeriodData) {
1228
+ const { disabled, workingParts } = this;
1229
+ if (dayPeriodData.length === 0) {
1230
+ return [];
1893
1231
  }
1894
- },
1895
- "multiple": {
1896
- "type": "boolean",
1897
- "mutable": false,
1898
- "complexType": {
1899
- "original": "boolean",
1900
- "resolved": "boolean",
1901
- "references": {}
1902
- },
1903
- "required": false,
1904
- "optional": false,
1905
- "docs": {
1906
- "tags": [],
1907
- "text": "If `true`, multiple dates can be selected at once. Only\napplies to `presentation=\"date\"` and `preferWheel=\"false\"`."
1908
- },
1909
- "attribute": "multiple",
1910
- "reflect": false,
1911
- "defaultValue": "false"
1912
- },
1913
- "highlightedDates": {
1914
- "type": "unknown",
1915
- "mutable": false,
1916
- "complexType": {
1917
- "original": "DatetimeHighlight[] | DatetimeHighlightCallback",
1918
- "resolved": "((dateIsoString: string) => DatetimeHighlightStyle | undefined) | DatetimeHighlight[] | undefined",
1919
- "references": {
1920
- "DatetimeHighlight": {
1921
- "location": "import",
1922
- "path": "./datetime-interface",
1923
- "id": "src/components/datetime/datetime-interface.ts::DatetimeHighlight"
1924
- },
1925
- "DatetimeHighlightCallback": {
1926
- "location": "import",
1927
- "path": "./datetime-interface",
1928
- "id": "src/components/datetime/datetime-interface.ts::DatetimeHighlightCallback"
1232
+ const activePart = this.getActivePartsWithFallback();
1233
+ const isDayPeriodRTL = isLocaleDayPeriodRTL(this.locale);
1234
+ return (h("ion-picker-column-internal", { style: isDayPeriodRTL ? { order: '-1' } : {}, color: this.color, disabled: disabled, value: activePart.ampm, items: dayPeriodData, onIonChange: (ev) => {
1235
+ const hour = calculateHourFromAMPM(workingParts, ev.detail.value);
1236
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm: ev.detail.value, hour }));
1237
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { ampm: ev.detail.value, hour }));
1238
+ ev.stopPropagation();
1239
+ } }));
1240
+ }
1241
+ renderWheelView(forcePresentation) {
1242
+ const { locale } = this;
1243
+ const showMonthFirst = isMonthFirstLocale(locale);
1244
+ const columnOrder = showMonthFirst ? 'month-first' : 'year-first';
1245
+ return (h("div", { class: {
1246
+ [`wheel-order-${columnOrder}`]: true,
1247
+ } }, this.renderWheelPicker(forcePresentation)));
1248
+ }
1249
+ /**
1250
+ * Grid Render Methods
1251
+ */
1252
+ renderCalendarHeader(mode) {
1253
+ const { disabled } = this;
1254
+ const expandedIcon = mode === 'ios' ? chevronDown : caretUpSharp;
1255
+ const collapsedIcon = mode === 'ios' ? chevronForward : caretDownSharp;
1256
+ const prevMonthDisabled = disabled || isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
1257
+ const nextMonthDisabled = disabled || isNextMonthDisabled(this.workingParts, this.maxParts);
1258
+ // don't use the inheritAttributes util because it removes dir from the host, and we still need that
1259
+ const hostDir = this.el.getAttribute('dir') || undefined;
1260
+ return (h("div", { class: "calendar-header" }, h("div", { class: "calendar-action-buttons" }, h("div", { class: "calendar-month-year" }, 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: () => {
1261
+ var _a;
1262
+ this.toggleMonthAndYearView();
1263
+ /**
1264
+ * TODO: FW-3547
1265
+ *
1266
+ * Currently there is not a way to set the aria-label on the inner button
1267
+ * on the `ion-item` and have it be reactive to changes. This is a workaround
1268
+ * until we either refactor `ion-item` to a button or Stencil adds a way to
1269
+ * have reactive props for built-in properties, such as `aria-label`.
1270
+ */
1271
+ const { monthYearToggleItemRef } = this;
1272
+ if (monthYearToggleItemRef) {
1273
+ const btn = (_a = monthYearToggleItemRef.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.item-native');
1274
+ if (btn) {
1275
+ const monthYearAriaLabel = this.showMonthAndYear ? 'Hide year picker' : 'Show year picker';
1276
+ btn.setAttribute('aria-label', monthYearAriaLabel);
1277
+ }
1278
+ }
1279
+ } }, h("ion-label", null, getMonthAndYear(this.locale, this.workingParts), h("ion-icon", { "aria-hidden": "true", icon: this.showMonthAndYear ? expandedIcon : collapsedIcon, lazy: false, flipRtl: true })))), h("div", { class: "calendar-next-prev" }, h("ion-buttons", null, h("ion-button", { "aria-label": "Previous month", disabled: prevMonthDisabled, onClick: () => this.prevMonth() }, h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: chevronBack, lazy: false, flipRtl: true })), h("ion-button", { "aria-label": "Next month", disabled: nextMonthDisabled, onClick: () => this.nextMonth() }, h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: chevronForward, lazy: false, flipRtl: true }))))), h("div", { class: "calendar-days-of-week", "aria-hidden": "true" }, getDaysOfWeek(this.locale, mode, this.firstDayOfWeek % 7).map((d) => {
1280
+ return h("div", { class: "day-of-week" }, d);
1281
+ }))));
1282
+ }
1283
+ renderMonth(month, year) {
1284
+ const { disabled, readonly } = this;
1285
+ const yearAllowed = this.parsedYearValues === undefined || this.parsedYearValues.includes(year);
1286
+ const monthAllowed = this.parsedMonthValues === undefined || this.parsedMonthValues.includes(month);
1287
+ const isCalMonthDisabled = !yearAllowed || !monthAllowed;
1288
+ const isDatetimeDisabled = disabled || readonly;
1289
+ const swipeDisabled = disabled ||
1290
+ isMonthDisabled({
1291
+ month,
1292
+ year,
1293
+ day: null,
1294
+ }, {
1295
+ // The day is not used when checking if a month is disabled.
1296
+ // Users should be able to access the min or max month, even if the
1297
+ // min/max date is out of bounds (e.g. min is set to Feb 15, Feb should not be disabled).
1298
+ minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
1299
+ maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
1300
+ });
1301
+ // The working month should never have swipe disabled.
1302
+ // Otherwise the CSS scroll snap will not work and the user
1303
+ // can free-scroll the calendar.
1304
+ const isWorkingMonth = this.workingParts.month === month && this.workingParts.year === year;
1305
+ const activePart = this.getActivePartsWithFallback();
1306
+ return (h("div", { "aria-hidden": !isWorkingMonth ? 'true' : null, class: {
1307
+ 'calendar-month': true,
1308
+ // Prevents scroll snap swipe gestures for months outside of the min/max bounds
1309
+ 'calendar-month-disabled': !isWorkingMonth && swipeDisabled,
1310
+ } }, h("div", { class: "calendar-month-grid" }, getDaysOfMonth(month, year, this.firstDayOfWeek % 7).map((dateObject, index) => {
1311
+ const { day, dayOfWeek } = dateObject;
1312
+ const { el, highlightedDates, isDateEnabled, multiple } = this;
1313
+ const referenceParts = { month, day, year };
1314
+ const isCalendarPadding = day === null;
1315
+ const { isActive, isToday, ariaLabel, ariaSelected, disabled: isDayDisabled, text, } = getCalendarDayState(this.locale, referenceParts, this.activeParts, this.todayParts, this.minParts, this.maxParts, this.parsedDayValues);
1316
+ const dateIsoString = convertDataToISO(referenceParts);
1317
+ let isCalDayDisabled = isCalMonthDisabled || isDayDisabled;
1318
+ if (!isCalDayDisabled && isDateEnabled !== undefined) {
1319
+ try {
1320
+ /**
1321
+ * The `isDateEnabled` implementation is try-catch wrapped
1322
+ * to prevent exceptions in the user's function from
1323
+ * interrupting the calendar rendering.
1324
+ */
1325
+ isCalDayDisabled = !isDateEnabled(dateIsoString);
1326
+ }
1327
+ catch (e) {
1328
+ printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', el, e);
1329
+ }
1929
1330
  }
1930
- }
1931
- },
1932
- "required": false,
1933
- "optional": true,
1934
- "docs": {
1935
- "tags": [],
1936
- "text": "Used to apply custom text and background colors to specific dates.\n\nCan be either an array of objects containing ISO strings and colors,\nor a callback that receives an ISO string and returns the colors.\n\nOnly applies to the `date`, `date-time`, and `time-date` presentations,\nwith `preferWheel=\"false\"`."
1937
- }
1938
- },
1939
- "value": {
1940
- "type": "string",
1941
- "mutable": true,
1942
- "complexType": {
1943
- "original": "string | string[] | null",
1944
- "resolved": "null | string | string[] | undefined",
1945
- "references": {}
1946
- },
1947
- "required": false,
1948
- "optional": true,
1949
- "docs": {
1950
- "tags": [],
1951
- "text": "The value of the datetime as a valid ISO 8601 datetime string.\nThis should be an array of strings only when `multiple=\"true\"`."
1952
- },
1953
- "attribute": "value",
1954
- "reflect": false
1955
- },
1956
- "showDefaultTitle": {
1957
- "type": "boolean",
1958
- "mutable": false,
1959
- "complexType": {
1960
- "original": "boolean",
1961
- "resolved": "boolean",
1962
- "references": {}
1963
- },
1964
- "required": false,
1965
- "optional": false,
1966
- "docs": {
1967
- "tags": [],
1968
- "text": "If `true`, a header will be shown above the calendar\npicker. This will include both the slotted title, and\nthe selected date."
1969
- },
1970
- "attribute": "show-default-title",
1971
- "reflect": false,
1972
- "defaultValue": "false"
1973
- },
1974
- "showDefaultButtons": {
1975
- "type": "boolean",
1976
- "mutable": false,
1977
- "complexType": {
1978
- "original": "boolean",
1979
- "resolved": "boolean",
1980
- "references": {}
1981
- },
1982
- "required": false,
1983
- "optional": false,
1984
- "docs": {
1985
- "tags": [],
1986
- "text": "If `true`, the default \"Cancel\" and \"OK\" buttons\nwill be rendered at the bottom of the `ion-datetime`\ncomponent. Developers can also use the `button` slot\nif they want to customize these buttons. If custom\nbuttons are set in the `button` slot then the\ndefault buttons will not be rendered."
1987
- },
1988
- "attribute": "show-default-buttons",
1989
- "reflect": false,
1990
- "defaultValue": "false"
1991
- },
1992
- "showClearButton": {
1993
- "type": "boolean",
1994
- "mutable": false,
1995
- "complexType": {
1996
- "original": "boolean",
1997
- "resolved": "boolean",
1998
- "references": {}
1999
- },
2000
- "required": false,
2001
- "optional": false,
2002
- "docs": {
2003
- "tags": [],
2004
- "text": "If `true`, a \"Clear\" button will be rendered alongside\nthe default \"Cancel\" and \"OK\" buttons at the bottom of the `ion-datetime`\ncomponent. Developers can also use the `button` slot\nif they want to customize these buttons. If custom\nbuttons are set in the `button` slot then the\ndefault buttons will not be rendered."
2005
- },
2006
- "attribute": "show-clear-button",
2007
- "reflect": false,
2008
- "defaultValue": "false"
2009
- },
2010
- "showDefaultTimeLabel": {
2011
- "type": "boolean",
2012
- "mutable": false,
2013
- "complexType": {
2014
- "original": "boolean",
2015
- "resolved": "boolean",
2016
- "references": {}
2017
- },
2018
- "required": false,
2019
- "optional": false,
2020
- "docs": {
2021
- "tags": [],
2022
- "text": "If `true`, the default \"Time\" label will be rendered\nfor the time selector of the `ion-datetime` component.\nDevelopers can also use the `time-label` slot\nif they want to customize this label. If a custom\nlabel is set in the `time-label` slot then the\ndefault label will not be rendered."
2023
- },
2024
- "attribute": "show-default-time-label",
2025
- "reflect": false,
2026
- "defaultValue": "true"
2027
- },
2028
- "hourCycle": {
2029
- "type": "string",
2030
- "mutable": false,
2031
- "complexType": {
2032
- "original": "DatetimeHourCycle",
2033
- "resolved": "\"h11\" | \"h12\" | \"h23\" | \"h24\" | undefined",
2034
- "references": {
2035
- "DatetimeHourCycle": {
2036
- "location": "import",
2037
- "path": "./datetime-interface",
2038
- "id": "src/components/datetime/datetime-interface.ts::DatetimeHourCycle"
1331
+ /**
1332
+ * Some days are constrained through max & min or allowed dates
1333
+ * and also disabled because the component is readonly or disabled.
1334
+ * These need to be displayed differently.
1335
+ */
1336
+ const isCalDayConstrained = isCalDayDisabled && isDatetimeDisabled;
1337
+ const isButtonDisabled = isCalDayDisabled || isDatetimeDisabled;
1338
+ let dateStyle = undefined;
1339
+ /**
1340
+ * Custom highlight styles should not override the style for selected dates,
1341
+ * nor apply to "filler days" at the start of the grid.
1342
+ */
1343
+ if (highlightedDates !== undefined && !isActive && day !== null) {
1344
+ dateStyle = getHighlightStyles(highlightedDates, dateIsoString, el);
2039
1345
  }
2040
- }
2041
- },
2042
- "required": false,
2043
- "optional": true,
2044
- "docs": {
2045
- "tags": [],
2046
- "text": "The hour cycle of the `ion-datetime`. If no value is set, this is\nspecified by the current locale."
2047
- },
2048
- "attribute": "hour-cycle",
2049
- "reflect": false
2050
- },
2051
- "size": {
2052
- "type": "string",
2053
- "mutable": false,
2054
- "complexType": {
2055
- "original": "'cover' | 'fixed'",
2056
- "resolved": "\"cover\" | \"fixed\"",
2057
- "references": {}
2058
- },
2059
- "required": false,
2060
- "optional": false,
2061
- "docs": {
2062
- "tags": [],
2063
- "text": "If `cover`, the `ion-datetime` will expand to cover the full width of its container.\nIf `fixed`, the `ion-datetime` will have a fixed width."
2064
- },
2065
- "attribute": "size",
2066
- "reflect": false,
2067
- "defaultValue": "'fixed'"
2068
- },
2069
- "preferWheel": {
2070
- "type": "boolean",
2071
- "mutable": false,
2072
- "complexType": {
2073
- "original": "boolean",
2074
- "resolved": "boolean",
2075
- "references": {}
2076
- },
2077
- "required": false,
2078
- "optional": false,
2079
- "docs": {
2080
- "tags": [],
2081
- "text": "If `true`, a wheel picker will be rendered instead of a calendar grid\nwhere possible. If `false`, a calendar grid will be rendered instead of\na wheel picker where possible.\n\nA wheel picker can be rendered instead of a grid when `presentation` is\none of the following values: `\"date\"`, `\"date-time\"`, or `\"time-date\"`.\n\nA wheel picker will always be rendered regardless of\nthe `preferWheel` value when `presentation` is one of the following values:\n`\"time\"`, `\"month\"`, `\"month-year\"`, or `\"year\"`."
2082
- },
2083
- "attribute": "prefer-wheel",
2084
- "reflect": false,
2085
- "defaultValue": "false"
2086
- }
2087
- };
2088
- }
2089
- static get states() {
2090
- return {
2091
- "showMonthAndYear": {},
2092
- "activeParts": {},
2093
- "workingParts": {},
2094
- "isTimePopoverOpen": {},
2095
- "forceRenderDate": {}
2096
- };
2097
- }
2098
- static get events() {
2099
- return [{
2100
- "method": "ionCancel",
2101
- "name": "ionCancel",
2102
- "bubbles": true,
2103
- "cancelable": true,
2104
- "composed": true,
2105
- "docs": {
2106
- "tags": [],
2107
- "text": "Emitted when the datetime selection was cancelled."
2108
- },
2109
- "complexType": {
2110
- "original": "void",
2111
- "resolved": "void",
2112
- "references": {}
2113
- }
2114
- }, {
2115
- "method": "ionChange",
2116
- "name": "ionChange",
2117
- "bubbles": true,
2118
- "cancelable": true,
2119
- "composed": true,
2120
- "docs": {
2121
- "tags": [],
2122
- "text": "Emitted when the value (selected date) has changed."
2123
- },
2124
- "complexType": {
2125
- "original": "DatetimeChangeEventDetail",
2126
- "resolved": "DatetimeChangeEventDetail",
2127
- "references": {
2128
- "DatetimeChangeEventDetail": {
2129
- "location": "import",
2130
- "path": "./datetime-interface",
2131
- "id": "src/components/datetime/datetime-interface.ts::DatetimeChangeEventDetail"
1346
+ let dateParts = undefined;
1347
+ // "Filler days" at the beginning of the grid should not get the calendar day
1348
+ // CSS parts added to them
1349
+ if (!isCalendarPadding) {
1350
+ dateParts = `calendar-day${isActive ? ' active' : ''}${isToday ? ' today' : ''}${isCalDayDisabled ? ' disabled' : ''}`;
2132
1351
  }
2133
- }
1352
+ return (h("div", { class: "calendar-day-wrapper" }, h("button", {
1353
+ // We need to use !important for the inline styles here because
1354
+ // otherwise the CSS shadow parts will override these styles.
1355
+ // See https://github.com/WICG/webcomponents/issues/847
1356
+ // Both the CSS shadow parts and highlightedDates styles are
1357
+ // provided by the developer, but highlightedDates styles should
1358
+ // always take priority.
1359
+ ref: (el) => {
1360
+ if (el) {
1361
+ el.style.setProperty('color', `${dateStyle ? dateStyle.textColor : ''}`, 'important');
1362
+ el.style.setProperty('background-color', `${dateStyle ? dateStyle.backgroundColor : ''}`, 'important');
1363
+ }
1364
+ }, tabindex: "-1", "data-day": day, "data-month": month, "data-year": year, "data-index": index, "data-day-of-week": dayOfWeek, disabled: isButtonDisabled, class: {
1365
+ 'calendar-day-padding': isCalendarPadding,
1366
+ 'calendar-day': true,
1367
+ 'calendar-day-active': isActive,
1368
+ 'calendar-day-constrained': isCalDayConstrained,
1369
+ 'calendar-day-today': isToday,
1370
+ }, part: dateParts, "aria-hidden": isCalendarPadding ? 'true' : null, "aria-selected": ariaSelected, "aria-label": ariaLabel, onClick: () => {
1371
+ if (isCalendarPadding) {
1372
+ return;
1373
+ }
1374
+ this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month,
1375
+ day,
1376
+ year }));
1377
+ // multiple only needs date info, so we can wipe out other fields like time
1378
+ if (multiple) {
1379
+ this.setActiveParts({
1380
+ month,
1381
+ day,
1382
+ year,
1383
+ }, isActive);
1384
+ }
1385
+ else {
1386
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { month,
1387
+ day,
1388
+ year }));
1389
+ }
1390
+ }
1391
+ }, text)));
1392
+ }))));
1393
+ }
1394
+ renderCalendarBody() {
1395
+ return (h("div", { class: "calendar-body ion-focusable", ref: (el) => (this.calendarBodyRef = el), tabindex: "0" }, generateMonths(this.workingParts, this.forceRenderDate).map(({ month, year }) => {
1396
+ return this.renderMonth(month, year);
1397
+ })));
1398
+ }
1399
+ renderCalendar(mode) {
1400
+ return (h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(mode), this.renderCalendarBody()));
1401
+ }
1402
+ renderTimeLabel() {
1403
+ const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
1404
+ if (!hasSlottedTimeLabel && !this.showDefaultTimeLabel) {
1405
+ return;
2134
1406
  }
2135
- }, {
2136
- "method": "ionValueChange",
2137
- "name": "ionValueChange",
2138
- "bubbles": true,
2139
- "cancelable": true,
2140
- "composed": true,
2141
- "docs": {
2142
- "tags": [{
2143
- "name": "internal",
2144
- "text": undefined
2145
- }],
2146
- "text": "Emitted when the value property has changed.\nThis is used to ensure that ion-datetime-button can respond\nto any value property changes."
2147
- },
2148
- "complexType": {
2149
- "original": "DatetimeChangeEventDetail",
2150
- "resolved": "DatetimeChangeEventDetail",
2151
- "references": {
2152
- "DatetimeChangeEventDetail": {
2153
- "location": "import",
2154
- "path": "./datetime-interface",
2155
- "id": "src/components/datetime/datetime-interface.ts::DatetimeChangeEventDetail"
1407
+ return h("slot", { name: "time-label" }, "Time");
1408
+ }
1409
+ renderTimeOverlay() {
1410
+ const { disabled, hourCycle, isTimePopoverOpen, locale } = this;
1411
+ const computedHourCycle = getHourCycle(locale, hourCycle);
1412
+ const activePart = this.getActivePartsWithFallback();
1413
+ return [
1414
+ h("div", { class: "time-header" }, this.renderTimeLabel()),
1415
+ h("button", { class: {
1416
+ 'time-body': true,
1417
+ 'time-body-active': isTimePopoverOpen,
1418
+ }, part: `time-button${isTimePopoverOpen ? ' active' : ''}`, "aria-expanded": "false", "aria-haspopup": "true", disabled: disabled, onClick: async (ev) => {
1419
+ const { popoverRef } = this;
1420
+ if (popoverRef) {
1421
+ this.isTimePopoverOpen = true;
1422
+ popoverRef.present(new CustomEvent('ionShadowTarget', {
1423
+ detail: {
1424
+ ionShadowTarget: ev.target,
1425
+ },
1426
+ }));
1427
+ await popoverRef.onWillDismiss();
1428
+ this.isTimePopoverOpen = false;
1429
+ }
1430
+ } }, getLocalizedTime(locale, activePart, computedHourCycle)),
1431
+ h("ion-popover", { alignment: "center", translucent: true, overlayIndex: 1, arrow: false, onWillPresent: (ev) => {
1432
+ /**
1433
+ * Intersection Observers do not consistently fire between Blink and Webkit
1434
+ * when toggling the visibility of the popover and trying to scroll the picker
1435
+ * column to the correct time value.
1436
+ *
1437
+ * This will correctly scroll the element position to the correct time value,
1438
+ * before the popover is fully presented.
1439
+ */
1440
+ const cols = ev.target.querySelectorAll('ion-picker-column-internal');
1441
+ // TODO (FW-615): Potentially remove this when intersection observers are fixed in picker column
1442
+ cols.forEach((col) => col.scrollActiveItemIntoView());
1443
+ }, style: {
1444
+ '--offset-y': '-10px',
1445
+ '--min-width': 'fit-content',
1446
+ },
1447
+ // Allow native browser keyboard events to support up/down/home/end key
1448
+ // navigation within the time picker.
1449
+ keyboardEvents: true, ref: (el) => (this.popoverRef = el) }, this.renderWheelPicker('time')),
1450
+ ];
1451
+ }
1452
+ getHeaderSelectedDateText() {
1453
+ const { activeParts, multiple, titleSelectedDatesFormatter } = this;
1454
+ const isArray = Array.isArray(activeParts);
1455
+ let headerText;
1456
+ if (multiple && isArray && activeParts.length !== 1) {
1457
+ headerText = `${activeParts.length} days`; // default/fallback for multiple selection
1458
+ if (titleSelectedDatesFormatter !== undefined) {
1459
+ try {
1460
+ headerText = titleSelectedDatesFormatter(convertDataToISO(activeParts));
1461
+ }
1462
+ catch (e) {
1463
+ printIonError('Exception in provided `titleSelectedDatesFormatter`: ', e);
1464
+ }
2156
1465
  }
2157
- }
2158
1466
  }
2159
- }, {
2160
- "method": "ionFocus",
2161
- "name": "ionFocus",
2162
- "bubbles": true,
2163
- "cancelable": true,
2164
- "composed": true,
2165
- "docs": {
2166
- "tags": [],
2167
- "text": "Emitted when the datetime has focus."
2168
- },
2169
- "complexType": {
2170
- "original": "void",
2171
- "resolved": "void",
2172
- "references": {}
2173
- }
2174
- }, {
2175
- "method": "ionBlur",
2176
- "name": "ionBlur",
2177
- "bubbles": true,
2178
- "cancelable": true,
2179
- "composed": true,
2180
- "docs": {
2181
- "tags": [],
2182
- "text": "Emitted when the datetime loses focus."
2183
- },
2184
- "complexType": {
2185
- "original": "void",
2186
- "resolved": "void",
2187
- "references": {}
1467
+ else {
1468
+ // for exactly 1 day selected (multiple set or not), show a formatted version of that
1469
+ headerText = getMonthAndDay(this.locale, this.getActivePartsWithFallback());
2188
1470
  }
2189
- }, {
2190
- "method": "ionStyle",
2191
- "name": "ionStyle",
2192
- "bubbles": true,
2193
- "cancelable": true,
2194
- "composed": true,
2195
- "docs": {
2196
- "tags": [{
2197
- "name": "internal",
2198
- "text": undefined
2199
- }],
2200
- "text": "Emitted when the styles change."
2201
- },
2202
- "complexType": {
2203
- "original": "StyleEventDetail",
2204
- "resolved": "StyleEventDetail",
2205
- "references": {
2206
- "StyleEventDetail": {
2207
- "location": "import",
2208
- "path": "../../interface",
2209
- "id": "src/interface.d.ts::StyleEventDetail"
2210
- }
2211
- }
1471
+ return headerText;
1472
+ }
1473
+ renderHeader(showExpandedHeader = true) {
1474
+ const hasSlottedTitle = this.el.querySelector('[slot="title"]') !== null;
1475
+ if (!hasSlottedTitle && !this.showDefaultTitle) {
1476
+ return;
2212
1477
  }
2213
- }, {
2214
- "method": "ionRender",
2215
- "name": "ionRender",
2216
- "bubbles": true,
2217
- "cancelable": true,
2218
- "composed": true,
2219
- "docs": {
2220
- "tags": [{
2221
- "name": "internal",
2222
- "text": undefined
2223
- }],
2224
- "text": "Emitted when componentDidRender is fired."
2225
- },
2226
- "complexType": {
2227
- "original": "void",
2228
- "resolved": "void",
2229
- "references": {}
1478
+ return (h("div", { class: "datetime-header" }, h("div", { class: "datetime-title" }, h("slot", { name: "title" }, "Select Date")), showExpandedHeader && h("div", { class: "datetime-selected-date" }, this.getHeaderSelectedDateText())));
1479
+ }
1480
+ /**
1481
+ * Render time picker inside of datetime.
1482
+ * Do not pass color prop to segment on
1483
+ * iOS mode. MD segment has been customized and
1484
+ * should take on the color prop, but iOS
1485
+ * should just be the default segment.
1486
+ */
1487
+ renderTime() {
1488
+ const { presentation } = this;
1489
+ const timeOnlyPresentation = presentation === 'time';
1490
+ return (h("div", { class: "datetime-time" }, timeOnlyPresentation ? this.renderWheelPicker() : this.renderTimeOverlay()));
1491
+ }
1492
+ /**
1493
+ * Renders the month/year picker that is
1494
+ * displayed on the calendar grid.
1495
+ * The .datetime-year class has additional
1496
+ * styles that let us show/hide the
1497
+ * picker when the user clicks on the
1498
+ * toggle in the calendar header.
1499
+ */
1500
+ renderCalendarViewMonthYearPicker() {
1501
+ return h("div", { class: "datetime-year" }, this.renderWheelView('month-year'));
1502
+ }
1503
+ /**
1504
+ * Render entry point
1505
+ * All presentation types are rendered from here.
1506
+ */
1507
+ renderDatetime(mode) {
1508
+ const { presentation, preferWheel } = this;
1509
+ /**
1510
+ * Certain presentation types have separate grid and wheel displays.
1511
+ * If preferWheel is true then we should show a wheel picker instead.
1512
+ */
1513
+ const hasWheelVariant = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1514
+ if (preferWheel && hasWheelVariant) {
1515
+ return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
2230
1516
  }
2231
- }];
2232
- }
2233
- static get methods() {
2234
- return {
2235
- "confirm": {
2236
- "complexType": {
2237
- "signature": "(closeOverlay?: boolean) => Promise<void>",
2238
- "parameters": [{
2239
- "tags": [],
2240
- "text": ""
2241
- }],
2242
- "references": {
2243
- "Promise": {
2244
- "location": "global",
2245
- "id": "global::Promise"
2246
- }
2247
- },
2248
- "return": "Promise<void>"
2249
- },
2250
- "docs": {
2251
- "text": "Confirms the selected datetime value, updates the\n`value` property, and optionally closes the popover\nor modal that the datetime was presented in.",
2252
- "tags": []
1517
+ switch (presentation) {
1518
+ case 'date-time':
1519
+ return [
1520
+ this.renderHeader(),
1521
+ this.renderCalendar(mode),
1522
+ this.renderCalendarViewMonthYearPicker(),
1523
+ this.renderTime(),
1524
+ this.renderFooter(),
1525
+ ];
1526
+ case 'time-date':
1527
+ return [
1528
+ this.renderHeader(),
1529
+ this.renderTime(),
1530
+ this.renderCalendar(mode),
1531
+ this.renderCalendarViewMonthYearPicker(),
1532
+ this.renderFooter(),
1533
+ ];
1534
+ case 'time':
1535
+ return [this.renderHeader(false), this.renderTime(), this.renderFooter()];
1536
+ case 'month':
1537
+ case 'month-year':
1538
+ case 'year':
1539
+ return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1540
+ default:
1541
+ return [
1542
+ this.renderHeader(),
1543
+ this.renderCalendar(mode),
1544
+ this.renderCalendarViewMonthYearPicker(),
1545
+ this.renderFooter(),
1546
+ ];
2253
1547
  }
2254
- },
2255
- "reset": {
2256
- "complexType": {
2257
- "signature": "(startDate?: string) => Promise<void>",
2258
- "parameters": [{
2259
- "tags": [],
2260
- "text": ""
2261
- }],
2262
- "references": {
2263
- "Promise": {
2264
- "location": "global",
2265
- "id": "global::Promise"
1548
+ }
1549
+ render() {
1550
+ const { name, value, disabled, el, color, readonly, showMonthAndYear, preferWheel, presentation, size, isGridStyle, } = this;
1551
+ const mode = getIonMode(this);
1552
+ const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
1553
+ const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
1554
+ const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
1555
+ const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1556
+ const hasWheelVariant = hasDatePresentation && preferWheel;
1557
+ renderHiddenInput(true, el, name, formatValue(value), disabled);
1558
+ return (h(Host, { "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, createColorClasses(color, {
1559
+ [mode]: true,
1560
+ ['datetime-readonly']: readonly,
1561
+ ['datetime-disabled']: disabled,
1562
+ 'show-month-and-year': shouldShowMonthAndYear,
1563
+ 'month-year-picker-open': monthYearPickerOpen,
1564
+ [`datetime-presentation-${presentation}`]: true,
1565
+ [`datetime-size-${size}`]: true,
1566
+ [`datetime-prefer-wheel`]: hasWheelVariant,
1567
+ [`datetime-grid`]: isGridStyle,
1568
+ })) }, this.renderDatetime(mode)));
1569
+ }
1570
+ static get is() { return "ion-datetime"; }
1571
+ static get encapsulation() { return "shadow"; }
1572
+ static get originalStyleUrls() {
1573
+ return {
1574
+ "ios": ["datetime.ios.scss"],
1575
+ "md": ["datetime.md.scss"]
1576
+ };
1577
+ }
1578
+ static get styleUrls() {
1579
+ return {
1580
+ "ios": ["datetime.ios.css"],
1581
+ "md": ["datetime.md.css"]
1582
+ };
1583
+ }
1584
+ static get properties() {
1585
+ return {
1586
+ "color": {
1587
+ "type": "string",
1588
+ "mutable": false,
1589
+ "complexType": {
1590
+ "original": "Color",
1591
+ "resolved": "\"danger\" | \"dark\" | \"light\" | \"medium\" | \"primary\" | \"secondary\" | \"success\" | \"tertiary\" | \"warning\" | string & Record<never, never> | undefined",
1592
+ "references": {
1593
+ "Color": {
1594
+ "location": "import",
1595
+ "path": "../../interface",
1596
+ "id": "src/interface.d.ts::Color"
1597
+ }
1598
+ }
1599
+ },
1600
+ "required": false,
1601
+ "optional": true,
1602
+ "docs": {
1603
+ "tags": [],
1604
+ "text": "The color to use from your application's color palette.\nDefault options are: `\"primary\"`, `\"secondary\"`, `\"tertiary\"`, `\"success\"`, `\"warning\"`, `\"danger\"`, `\"light\"`, `\"medium\"`, and `\"dark\"`.\nFor more information on colors, see [theming](/docs/theming/basics)."
1605
+ },
1606
+ "attribute": "color",
1607
+ "reflect": false,
1608
+ "defaultValue": "'primary'"
1609
+ },
1610
+ "name": {
1611
+ "type": "string",
1612
+ "mutable": false,
1613
+ "complexType": {
1614
+ "original": "string",
1615
+ "resolved": "string",
1616
+ "references": {}
1617
+ },
1618
+ "required": false,
1619
+ "optional": false,
1620
+ "docs": {
1621
+ "tags": [],
1622
+ "text": "The name of the control, which is submitted with the form data."
1623
+ },
1624
+ "attribute": "name",
1625
+ "reflect": false,
1626
+ "defaultValue": "this.inputId"
1627
+ },
1628
+ "disabled": {
1629
+ "type": "boolean",
1630
+ "mutable": false,
1631
+ "complexType": {
1632
+ "original": "boolean",
1633
+ "resolved": "boolean",
1634
+ "references": {}
1635
+ },
1636
+ "required": false,
1637
+ "optional": false,
1638
+ "docs": {
1639
+ "tags": [],
1640
+ "text": "If `true`, the user cannot interact with the datetime."
1641
+ },
1642
+ "attribute": "disabled",
1643
+ "reflect": false,
1644
+ "defaultValue": "false"
1645
+ },
1646
+ "readonly": {
1647
+ "type": "boolean",
1648
+ "mutable": false,
1649
+ "complexType": {
1650
+ "original": "boolean",
1651
+ "resolved": "boolean",
1652
+ "references": {}
1653
+ },
1654
+ "required": false,
1655
+ "optional": false,
1656
+ "docs": {
1657
+ "tags": [],
1658
+ "text": "If `true`, the datetime appears normal but the selected date cannot be changed."
1659
+ },
1660
+ "attribute": "readonly",
1661
+ "reflect": false,
1662
+ "defaultValue": "false"
1663
+ },
1664
+ "isDateEnabled": {
1665
+ "type": "unknown",
1666
+ "mutable": false,
1667
+ "complexType": {
1668
+ "original": "(dateIsoString: string) => boolean",
1669
+ "resolved": "((dateIsoString: string) => boolean) | undefined",
1670
+ "references": {}
1671
+ },
1672
+ "required": false,
1673
+ "optional": true,
1674
+ "docs": {
1675
+ "tags": [],
1676
+ "text": "Returns if an individual date (calendar day) is enabled or disabled.\n\nIf `true`, the day will be enabled/interactive.\nIf `false`, the day will be disabled/non-interactive.\n\nThe function accepts an ISO 8601 date string of a given day.\nBy default, all days are enabled. Developers can use this function\nto write custom logic to disable certain days.\n\nThe function is called for each rendered calendar day, for the previous, current and next month.\nCustom implementations should be optimized for performance to avoid jank."
1677
+ }
1678
+ },
1679
+ "min": {
1680
+ "type": "string",
1681
+ "mutable": true,
1682
+ "complexType": {
1683
+ "original": "string",
1684
+ "resolved": "string | undefined",
1685
+ "references": {}
1686
+ },
1687
+ "required": false,
1688
+ "optional": true,
1689
+ "docs": {
1690
+ "tags": [],
1691
+ "text": "The minimum datetime allowed. Value must be a date string\nfollowing the\n[ISO 8601 datetime format standard](https://www.w3.org/TR/NOTE-datetime),\nsuch as `1996-12-19`. The format does not have to be specific to an exact\ndatetime. For example, the minimum could just be the year, such as `1994`.\nDefaults to the beginning of the year, 100 years ago from today."
1692
+ },
1693
+ "attribute": "min",
1694
+ "reflect": false
1695
+ },
1696
+ "max": {
1697
+ "type": "string",
1698
+ "mutable": true,
1699
+ "complexType": {
1700
+ "original": "string",
1701
+ "resolved": "string | undefined",
1702
+ "references": {}
1703
+ },
1704
+ "required": false,
1705
+ "optional": true,
1706
+ "docs": {
1707
+ "tags": [],
1708
+ "text": "The maximum datetime allowed. Value must be a date string\nfollowing the\n[ISO 8601 datetime format standard](https://www.w3.org/TR/NOTE-datetime),\n`1996-12-19`. The format does not have to be specific to an exact\ndatetime. For example, the maximum could just be the year, such as `1994`.\nDefaults to the end of this year."
1709
+ },
1710
+ "attribute": "max",
1711
+ "reflect": false
1712
+ },
1713
+ "presentation": {
1714
+ "type": "string",
1715
+ "mutable": false,
1716
+ "complexType": {
1717
+ "original": "DatetimePresentation",
1718
+ "resolved": "\"date\" | \"date-time\" | \"month\" | \"month-year\" | \"time\" | \"time-date\" | \"year\"",
1719
+ "references": {
1720
+ "DatetimePresentation": {
1721
+ "location": "import",
1722
+ "path": "./datetime-interface",
1723
+ "id": "src/components/datetime/datetime-interface.ts::DatetimePresentation"
1724
+ }
1725
+ }
1726
+ },
1727
+ "required": false,
1728
+ "optional": false,
1729
+ "docs": {
1730
+ "tags": [],
1731
+ "text": "Which values you want to select. `\"date\"` will show\na calendar picker to select the month, day, and year. `\"time\"`\nwill show a time picker to select the hour, minute, and (optionally)\nAM/PM. `\"date-time\"` will show the date picker first and time picker second.\n`\"time-date\"` will show the time picker first and date picker second."
1732
+ },
1733
+ "attribute": "presentation",
1734
+ "reflect": false,
1735
+ "defaultValue": "'date-time'"
1736
+ },
1737
+ "cancelText": {
1738
+ "type": "string",
1739
+ "mutable": false,
1740
+ "complexType": {
1741
+ "original": "string",
1742
+ "resolved": "string",
1743
+ "references": {}
1744
+ },
1745
+ "required": false,
1746
+ "optional": false,
1747
+ "docs": {
1748
+ "tags": [],
1749
+ "text": "The text to display on the picker's cancel button."
1750
+ },
1751
+ "attribute": "cancel-text",
1752
+ "reflect": false,
1753
+ "defaultValue": "'Cancel'"
1754
+ },
1755
+ "doneText": {
1756
+ "type": "string",
1757
+ "mutable": false,
1758
+ "complexType": {
1759
+ "original": "string",
1760
+ "resolved": "string",
1761
+ "references": {}
1762
+ },
1763
+ "required": false,
1764
+ "optional": false,
1765
+ "docs": {
1766
+ "tags": [],
1767
+ "text": "The text to display on the picker's \"Done\" button."
1768
+ },
1769
+ "attribute": "done-text",
1770
+ "reflect": false,
1771
+ "defaultValue": "'Done'"
1772
+ },
1773
+ "clearText": {
1774
+ "type": "string",
1775
+ "mutable": false,
1776
+ "complexType": {
1777
+ "original": "string",
1778
+ "resolved": "string",
1779
+ "references": {}
1780
+ },
1781
+ "required": false,
1782
+ "optional": false,
1783
+ "docs": {
1784
+ "tags": [],
1785
+ "text": "The text to display on the picker's \"Clear\" button."
1786
+ },
1787
+ "attribute": "clear-text",
1788
+ "reflect": false,
1789
+ "defaultValue": "'Clear'"
1790
+ },
1791
+ "yearValues": {
1792
+ "type": "any",
1793
+ "mutable": false,
1794
+ "complexType": {
1795
+ "original": "number[] | number | string",
1796
+ "resolved": "number | number[] | string | undefined",
1797
+ "references": {}
1798
+ },
1799
+ "required": false,
1800
+ "optional": true,
1801
+ "docs": {
1802
+ "tags": [],
1803
+ "text": "Values used to create the list of selectable years. By default\nthe year values range between the `min` and `max` datetime inputs. However, to\ncontrol exactly which years to display, the `yearValues` input can take a number, an array\nof numbers, or string of comma separated numbers. For example, to show upcoming and\nrecent leap years, then this input's value would be `yearValues=\"2008,2012,2016,2020,2024\"`."
1804
+ },
1805
+ "attribute": "year-values",
1806
+ "reflect": false
1807
+ },
1808
+ "monthValues": {
1809
+ "type": "any",
1810
+ "mutable": false,
1811
+ "complexType": {
1812
+ "original": "number[] | number | string",
1813
+ "resolved": "number | number[] | string | undefined",
1814
+ "references": {}
1815
+ },
1816
+ "required": false,
1817
+ "optional": true,
1818
+ "docs": {
1819
+ "tags": [],
1820
+ "text": "Values used to create the list of selectable months. By default\nthe month values range from `1` to `12`. However, to control exactly which months to\ndisplay, the `monthValues` input can take a number, an array of numbers, or a string of\ncomma separated numbers. For example, if only summer months should be shown, then this\ninput value would be `monthValues=\"6,7,8\"`. Note that month numbers do *not* have a\nzero-based index, meaning January's value is `1`, and December's is `12`."
1821
+ },
1822
+ "attribute": "month-values",
1823
+ "reflect": false
1824
+ },
1825
+ "dayValues": {
1826
+ "type": "any",
1827
+ "mutable": false,
1828
+ "complexType": {
1829
+ "original": "number[] | number | string",
1830
+ "resolved": "number | number[] | string | undefined",
1831
+ "references": {}
1832
+ },
1833
+ "required": false,
1834
+ "optional": true,
1835
+ "docs": {
1836
+ "tags": [],
1837
+ "text": "Values used to create the list of selectable days. By default\nevery day is shown for the given month. However, to control exactly which days of\nthe month to display, the `dayValues` input can take a number, an array of numbers, or\na string of comma separated numbers. Note that even if the array days have an invalid\nnumber for the selected month, like `31` in February, it will correctly not show\ndays which are not valid for the selected month."
1838
+ },
1839
+ "attribute": "day-values",
1840
+ "reflect": false
1841
+ },
1842
+ "hourValues": {
1843
+ "type": "any",
1844
+ "mutable": false,
1845
+ "complexType": {
1846
+ "original": "number[] | number | string",
1847
+ "resolved": "number | number[] | string | undefined",
1848
+ "references": {}
1849
+ },
1850
+ "required": false,
1851
+ "optional": true,
1852
+ "docs": {
1853
+ "tags": [],
1854
+ "text": "Values used to create the list of selectable hours. By default\nthe hour values range from `0` to `23` for 24-hour, or `1` to `12` for 12-hour. However,\nto control exactly which hours to display, the `hourValues` input can take a number, an\narray of numbers, or a string of comma separated numbers."
1855
+ },
1856
+ "attribute": "hour-values",
1857
+ "reflect": false
1858
+ },
1859
+ "minuteValues": {
1860
+ "type": "any",
1861
+ "mutable": false,
1862
+ "complexType": {
1863
+ "original": "number[] | number | string",
1864
+ "resolved": "number | number[] | string | undefined",
1865
+ "references": {}
1866
+ },
1867
+ "required": false,
1868
+ "optional": true,
1869
+ "docs": {
1870
+ "tags": [],
1871
+ "text": "Values used to create the list of selectable minutes. By default\nthe minutes range from `0` to `59`. However, to control exactly which minutes to display,\nthe `minuteValues` input can take a number, an array of numbers, or a string of comma\nseparated numbers. For example, if the minute selections should only be every 15 minutes,\nthen this input value would be `minuteValues=\"0,15,30,45\"`."
1872
+ },
1873
+ "attribute": "minute-values",
1874
+ "reflect": false
1875
+ },
1876
+ "locale": {
1877
+ "type": "string",
1878
+ "mutable": false,
1879
+ "complexType": {
1880
+ "original": "string",
1881
+ "resolved": "string",
1882
+ "references": {}
1883
+ },
1884
+ "required": false,
1885
+ "optional": false,
1886
+ "docs": {
1887
+ "tags": [],
1888
+ "text": "The locale to use for `ion-datetime`. This\nimpacts month and day name formatting.\nThe `\"default\"` value refers to the default\nlocale set by your device."
1889
+ },
1890
+ "attribute": "locale",
1891
+ "reflect": false,
1892
+ "defaultValue": "'default'"
1893
+ },
1894
+ "firstDayOfWeek": {
1895
+ "type": "number",
1896
+ "mutable": false,
1897
+ "complexType": {
1898
+ "original": "number",
1899
+ "resolved": "number",
1900
+ "references": {}
1901
+ },
1902
+ "required": false,
1903
+ "optional": false,
1904
+ "docs": {
1905
+ "tags": [],
1906
+ "text": "The first day of the week to use for `ion-datetime`. The\ndefault value is `0` and represents Sunday."
1907
+ },
1908
+ "attribute": "first-day-of-week",
1909
+ "reflect": false,
1910
+ "defaultValue": "0"
1911
+ },
1912
+ "titleSelectedDatesFormatter": {
1913
+ "type": "unknown",
1914
+ "mutable": false,
1915
+ "complexType": {
1916
+ "original": "TitleSelectedDatesFormatter",
1917
+ "resolved": "((selectedDates: string[]) => string) | undefined",
1918
+ "references": {
1919
+ "TitleSelectedDatesFormatter": {
1920
+ "location": "import",
1921
+ "path": "./datetime-interface",
1922
+ "id": "src/components/datetime/datetime-interface.ts::TitleSelectedDatesFormatter"
1923
+ }
1924
+ }
1925
+ },
1926
+ "required": false,
1927
+ "optional": true,
1928
+ "docs": {
1929
+ "tags": [],
1930
+ "text": "A callback used to format the header text that shows how many\ndates are selected. Only used if there are 0 or more than 1\nselected (i.e. unused for exactly 1). By default, the header\ntext is set to \"numberOfDates days\"."
1931
+ }
1932
+ },
1933
+ "multiple": {
1934
+ "type": "boolean",
1935
+ "mutable": false,
1936
+ "complexType": {
1937
+ "original": "boolean",
1938
+ "resolved": "boolean",
1939
+ "references": {}
1940
+ },
1941
+ "required": false,
1942
+ "optional": false,
1943
+ "docs": {
1944
+ "tags": [],
1945
+ "text": "If `true`, multiple dates can be selected at once. Only\napplies to `presentation=\"date\"` and `preferWheel=\"false\"`."
1946
+ },
1947
+ "attribute": "multiple",
1948
+ "reflect": false,
1949
+ "defaultValue": "false"
1950
+ },
1951
+ "highlightedDates": {
1952
+ "type": "unknown",
1953
+ "mutable": false,
1954
+ "complexType": {
1955
+ "original": "DatetimeHighlight[] | DatetimeHighlightCallback",
1956
+ "resolved": "((dateIsoString: string) => DatetimeHighlightStyle | undefined) | DatetimeHighlight[] | undefined",
1957
+ "references": {
1958
+ "DatetimeHighlight": {
1959
+ "location": "import",
1960
+ "path": "./datetime-interface",
1961
+ "id": "src/components/datetime/datetime-interface.ts::DatetimeHighlight"
1962
+ },
1963
+ "DatetimeHighlightCallback": {
1964
+ "location": "import",
1965
+ "path": "./datetime-interface",
1966
+ "id": "src/components/datetime/datetime-interface.ts::DatetimeHighlightCallback"
1967
+ }
1968
+ }
1969
+ },
1970
+ "required": false,
1971
+ "optional": true,
1972
+ "docs": {
1973
+ "tags": [],
1974
+ "text": "Used to apply custom text and background colors to specific dates.\n\nCan be either an array of objects containing ISO strings and colors,\nor a callback that receives an ISO string and returns the colors.\n\nOnly applies to the `date`, `date-time`, and `time-date` presentations,\nwith `preferWheel=\"false\"`."
1975
+ }
1976
+ },
1977
+ "value": {
1978
+ "type": "string",
1979
+ "mutable": true,
1980
+ "complexType": {
1981
+ "original": "string | string[] | null",
1982
+ "resolved": "null | string | string[] | undefined",
1983
+ "references": {}
1984
+ },
1985
+ "required": false,
1986
+ "optional": true,
1987
+ "docs": {
1988
+ "tags": [],
1989
+ "text": "The value of the datetime as a valid ISO 8601 datetime string.\nThis should be an array of strings only when `multiple=\"true\"`."
1990
+ },
1991
+ "attribute": "value",
1992
+ "reflect": false
1993
+ },
1994
+ "showDefaultTitle": {
1995
+ "type": "boolean",
1996
+ "mutable": false,
1997
+ "complexType": {
1998
+ "original": "boolean",
1999
+ "resolved": "boolean",
2000
+ "references": {}
2001
+ },
2002
+ "required": false,
2003
+ "optional": false,
2004
+ "docs": {
2005
+ "tags": [],
2006
+ "text": "If `true`, a header will be shown above the calendar\npicker. This will include both the slotted title, and\nthe selected date."
2007
+ },
2008
+ "attribute": "show-default-title",
2009
+ "reflect": false,
2010
+ "defaultValue": "false"
2011
+ },
2012
+ "showDefaultButtons": {
2013
+ "type": "boolean",
2014
+ "mutable": false,
2015
+ "complexType": {
2016
+ "original": "boolean",
2017
+ "resolved": "boolean",
2018
+ "references": {}
2019
+ },
2020
+ "required": false,
2021
+ "optional": false,
2022
+ "docs": {
2023
+ "tags": [],
2024
+ "text": "If `true`, the default \"Cancel\" and \"OK\" buttons\nwill be rendered at the bottom of the `ion-datetime`\ncomponent. Developers can also use the `button` slot\nif they want to customize these buttons. If custom\nbuttons are set in the `button` slot then the\ndefault buttons will not be rendered."
2025
+ },
2026
+ "attribute": "show-default-buttons",
2027
+ "reflect": false,
2028
+ "defaultValue": "false"
2029
+ },
2030
+ "showClearButton": {
2031
+ "type": "boolean",
2032
+ "mutable": false,
2033
+ "complexType": {
2034
+ "original": "boolean",
2035
+ "resolved": "boolean",
2036
+ "references": {}
2037
+ },
2038
+ "required": false,
2039
+ "optional": false,
2040
+ "docs": {
2041
+ "tags": [],
2042
+ "text": "If `true`, a \"Clear\" button will be rendered alongside\nthe default \"Cancel\" and \"OK\" buttons at the bottom of the `ion-datetime`\ncomponent. Developers can also use the `button` slot\nif they want to customize these buttons. If custom\nbuttons are set in the `button` slot then the\ndefault buttons will not be rendered."
2043
+ },
2044
+ "attribute": "show-clear-button",
2045
+ "reflect": false,
2046
+ "defaultValue": "false"
2047
+ },
2048
+ "showDefaultTimeLabel": {
2049
+ "type": "boolean",
2050
+ "mutable": false,
2051
+ "complexType": {
2052
+ "original": "boolean",
2053
+ "resolved": "boolean",
2054
+ "references": {}
2055
+ },
2056
+ "required": false,
2057
+ "optional": false,
2058
+ "docs": {
2059
+ "tags": [],
2060
+ "text": "If `true`, the default \"Time\" label will be rendered\nfor the time selector of the `ion-datetime` component.\nDevelopers can also use the `time-label` slot\nif they want to customize this label. If a custom\nlabel is set in the `time-label` slot then the\ndefault label will not be rendered."
2061
+ },
2062
+ "attribute": "show-default-time-label",
2063
+ "reflect": false,
2064
+ "defaultValue": "true"
2065
+ },
2066
+ "hourCycle": {
2067
+ "type": "string",
2068
+ "mutable": false,
2069
+ "complexType": {
2070
+ "original": "DatetimeHourCycle",
2071
+ "resolved": "\"h11\" | \"h12\" | \"h23\" | \"h24\" | undefined",
2072
+ "references": {
2073
+ "DatetimeHourCycle": {
2074
+ "location": "import",
2075
+ "path": "./datetime-interface",
2076
+ "id": "src/components/datetime/datetime-interface.ts::DatetimeHourCycle"
2077
+ }
2078
+ }
2079
+ },
2080
+ "required": false,
2081
+ "optional": true,
2082
+ "docs": {
2083
+ "tags": [],
2084
+ "text": "The hour cycle of the `ion-datetime`. If no value is set, this is\nspecified by the current locale."
2085
+ },
2086
+ "attribute": "hour-cycle",
2087
+ "reflect": false
2088
+ },
2089
+ "size": {
2090
+ "type": "string",
2091
+ "mutable": false,
2092
+ "complexType": {
2093
+ "original": "'cover' | 'fixed'",
2094
+ "resolved": "\"cover\" | \"fixed\"",
2095
+ "references": {}
2096
+ },
2097
+ "required": false,
2098
+ "optional": false,
2099
+ "docs": {
2100
+ "tags": [],
2101
+ "text": "If `cover`, the `ion-datetime` will expand to cover the full width of its container.\nIf `fixed`, the `ion-datetime` will have a fixed width."
2102
+ },
2103
+ "attribute": "size",
2104
+ "reflect": false,
2105
+ "defaultValue": "'fixed'"
2106
+ },
2107
+ "preferWheel": {
2108
+ "type": "boolean",
2109
+ "mutable": false,
2110
+ "complexType": {
2111
+ "original": "boolean",
2112
+ "resolved": "boolean",
2113
+ "references": {}
2114
+ },
2115
+ "required": false,
2116
+ "optional": false,
2117
+ "docs": {
2118
+ "tags": [],
2119
+ "text": "If `true`, a wheel picker will be rendered instead of a calendar grid\nwhere possible. If `false`, a calendar grid will be rendered instead of\na wheel picker where possible.\n\nA wheel picker can be rendered instead of a grid when `presentation` is\none of the following values: `\"date\"`, `\"date-time\"`, or `\"time-date\"`.\n\nA wheel picker will always be rendered regardless of\nthe `preferWheel` value when `presentation` is one of the following values:\n`\"time\"`, `\"month\"`, `\"month-year\"`, or `\"year\"`."
2120
+ },
2121
+ "attribute": "prefer-wheel",
2122
+ "reflect": false,
2123
+ "defaultValue": "false"
2266
2124
  }
2267
- },
2268
- "return": "Promise<void>"
2269
- },
2270
- "docs": {
2271
- "text": "Resets the internal state of the datetime but does not update the value.\nPassing a valid ISO-8601 string will reset the state of the component to the provided date.\nIf no value is provided, the internal state will be reset to the clamped value of the min, max and today.",
2272
- "tags": []
2273
- }
2274
- },
2275
- "cancel": {
2276
- "complexType": {
2277
- "signature": "(closeOverlay?: boolean) => Promise<void>",
2278
- "parameters": [{
2279
- "tags": [],
2280
- "text": ""
2281
- }],
2282
- "references": {
2283
- "Promise": {
2284
- "location": "global",
2285
- "id": "global::Promise"
2125
+ };
2126
+ }
2127
+ static get states() {
2128
+ return {
2129
+ "showMonthAndYear": {},
2130
+ "activeParts": {},
2131
+ "workingParts": {},
2132
+ "isTimePopoverOpen": {},
2133
+ "forceRenderDate": {}
2134
+ };
2135
+ }
2136
+ static get events() {
2137
+ return [{
2138
+ "method": "ionCancel",
2139
+ "name": "ionCancel",
2140
+ "bubbles": true,
2141
+ "cancelable": true,
2142
+ "composed": true,
2143
+ "docs": {
2144
+ "tags": [],
2145
+ "text": "Emitted when the datetime selection was cancelled."
2146
+ },
2147
+ "complexType": {
2148
+ "original": "void",
2149
+ "resolved": "void",
2150
+ "references": {}
2151
+ }
2152
+ }, {
2153
+ "method": "ionChange",
2154
+ "name": "ionChange",
2155
+ "bubbles": true,
2156
+ "cancelable": true,
2157
+ "composed": true,
2158
+ "docs": {
2159
+ "tags": [],
2160
+ "text": "Emitted when the value (selected date) has changed."
2161
+ },
2162
+ "complexType": {
2163
+ "original": "DatetimeChangeEventDetail",
2164
+ "resolved": "DatetimeChangeEventDetail",
2165
+ "references": {
2166
+ "DatetimeChangeEventDetail": {
2167
+ "location": "import",
2168
+ "path": "./datetime-interface",
2169
+ "id": "src/components/datetime/datetime-interface.ts::DatetimeChangeEventDetail"
2170
+ }
2171
+ }
2172
+ }
2173
+ }, {
2174
+ "method": "ionValueChange",
2175
+ "name": "ionValueChange",
2176
+ "bubbles": true,
2177
+ "cancelable": true,
2178
+ "composed": true,
2179
+ "docs": {
2180
+ "tags": [{
2181
+ "name": "internal",
2182
+ "text": undefined
2183
+ }],
2184
+ "text": "Emitted when the value property has changed.\nThis is used to ensure that ion-datetime-button can respond\nto any value property changes."
2185
+ },
2186
+ "complexType": {
2187
+ "original": "DatetimeChangeEventDetail",
2188
+ "resolved": "DatetimeChangeEventDetail",
2189
+ "references": {
2190
+ "DatetimeChangeEventDetail": {
2191
+ "location": "import",
2192
+ "path": "./datetime-interface",
2193
+ "id": "src/components/datetime/datetime-interface.ts::DatetimeChangeEventDetail"
2194
+ }
2195
+ }
2196
+ }
2197
+ }, {
2198
+ "method": "ionFocus",
2199
+ "name": "ionFocus",
2200
+ "bubbles": true,
2201
+ "cancelable": true,
2202
+ "composed": true,
2203
+ "docs": {
2204
+ "tags": [],
2205
+ "text": "Emitted when the datetime has focus."
2206
+ },
2207
+ "complexType": {
2208
+ "original": "void",
2209
+ "resolved": "void",
2210
+ "references": {}
2211
+ }
2212
+ }, {
2213
+ "method": "ionBlur",
2214
+ "name": "ionBlur",
2215
+ "bubbles": true,
2216
+ "cancelable": true,
2217
+ "composed": true,
2218
+ "docs": {
2219
+ "tags": [],
2220
+ "text": "Emitted when the datetime loses focus."
2221
+ },
2222
+ "complexType": {
2223
+ "original": "void",
2224
+ "resolved": "void",
2225
+ "references": {}
2226
+ }
2227
+ }, {
2228
+ "method": "ionStyle",
2229
+ "name": "ionStyle",
2230
+ "bubbles": true,
2231
+ "cancelable": true,
2232
+ "composed": true,
2233
+ "docs": {
2234
+ "tags": [{
2235
+ "name": "internal",
2236
+ "text": undefined
2237
+ }],
2238
+ "text": "Emitted when the styles change."
2239
+ },
2240
+ "complexType": {
2241
+ "original": "StyleEventDetail",
2242
+ "resolved": "StyleEventDetail",
2243
+ "references": {
2244
+ "StyleEventDetail": {
2245
+ "location": "import",
2246
+ "path": "../../interface",
2247
+ "id": "src/interface.d.ts::StyleEventDetail"
2248
+ }
2249
+ }
2250
+ }
2251
+ }, {
2252
+ "method": "ionRender",
2253
+ "name": "ionRender",
2254
+ "bubbles": true,
2255
+ "cancelable": true,
2256
+ "composed": true,
2257
+ "docs": {
2258
+ "tags": [{
2259
+ "name": "internal",
2260
+ "text": undefined
2261
+ }],
2262
+ "text": "Emitted when componentDidRender is fired."
2263
+ },
2264
+ "complexType": {
2265
+ "original": "void",
2266
+ "resolved": "void",
2267
+ "references": {}
2268
+ }
2269
+ }];
2270
+ }
2271
+ static get methods() {
2272
+ return {
2273
+ "confirm": {
2274
+ "complexType": {
2275
+ "signature": "(closeOverlay?: boolean) => Promise<void>",
2276
+ "parameters": [{
2277
+ "tags": [],
2278
+ "text": ""
2279
+ }],
2280
+ "references": {
2281
+ "Promise": {
2282
+ "location": "global",
2283
+ "id": "global::Promise"
2284
+ }
2285
+ },
2286
+ "return": "Promise<void>"
2287
+ },
2288
+ "docs": {
2289
+ "text": "Confirms the selected datetime value, updates the\n`value` property, and optionally closes the popover\nor modal that the datetime was presented in.",
2290
+ "tags": []
2291
+ }
2292
+ },
2293
+ "reset": {
2294
+ "complexType": {
2295
+ "signature": "(startDate?: string) => Promise<void>",
2296
+ "parameters": [{
2297
+ "tags": [],
2298
+ "text": ""
2299
+ }],
2300
+ "references": {
2301
+ "Promise": {
2302
+ "location": "global",
2303
+ "id": "global::Promise"
2304
+ }
2305
+ },
2306
+ "return": "Promise<void>"
2307
+ },
2308
+ "docs": {
2309
+ "text": "Resets the internal state of the datetime but does not update the value.\nPassing a valid ISO-8601 string will reset the state of the component to the provided date.\nIf no value is provided, the internal state will be reset to the clamped value of the min, max and today.",
2310
+ "tags": []
2311
+ }
2312
+ },
2313
+ "cancel": {
2314
+ "complexType": {
2315
+ "signature": "(closeOverlay?: boolean) => Promise<void>",
2316
+ "parameters": [{
2317
+ "tags": [],
2318
+ "text": ""
2319
+ }],
2320
+ "references": {
2321
+ "Promise": {
2322
+ "location": "global",
2323
+ "id": "global::Promise"
2324
+ }
2325
+ },
2326
+ "return": "Promise<void>"
2327
+ },
2328
+ "docs": {
2329
+ "text": "Emits the ionCancel event and\noptionally closes the popover\nor modal that the datetime was\npresented in.",
2330
+ "tags": []
2331
+ }
2286
2332
  }
2287
- },
2288
- "return": "Promise<void>"
2289
- },
2290
- "docs": {
2291
- "text": "Emits the ionCancel event and\noptionally closes the popover\nor modal that the datetime was\npresented in.",
2292
- "tags": []
2293
- }
2294
- }
2295
- };
2296
- }
2297
- static get elementRef() { return "el"; }
2298
- static get watchers() {
2299
- return [{
2300
- "propName": "disabled",
2301
- "methodName": "disabledChanged"
2302
- }, {
2303
- "propName": "min",
2304
- "methodName": "minChanged"
2305
- }, {
2306
- "propName": "max",
2307
- "methodName": "maxChanged"
2308
- }, {
2309
- "propName": "yearValues",
2310
- "methodName": "yearValuesChanged"
2311
- }, {
2312
- "propName": "monthValues",
2313
- "methodName": "monthValuesChanged"
2314
- }, {
2315
- "propName": "dayValues",
2316
- "methodName": "dayValuesChanged"
2317
- }, {
2318
- "propName": "hourValues",
2319
- "methodName": "hourValuesChanged"
2320
- }, {
2321
- "propName": "minuteValues",
2322
- "methodName": "minuteValuesChanged"
2323
- }, {
2324
- "propName": "value",
2325
- "methodName": "valueChanged"
2326
- }];
2327
- }
2333
+ };
2334
+ }
2335
+ static get elementRef() { return "el"; }
2336
+ static get watchers() {
2337
+ return [{
2338
+ "propName": "disabled",
2339
+ "methodName": "disabledChanged"
2340
+ }, {
2341
+ "propName": "min",
2342
+ "methodName": "minChanged"
2343
+ }, {
2344
+ "propName": "max",
2345
+ "methodName": "maxChanged"
2346
+ }, {
2347
+ "propName": "yearValues",
2348
+ "methodName": "yearValuesChanged"
2349
+ }, {
2350
+ "propName": "monthValues",
2351
+ "methodName": "monthValuesChanged"
2352
+ }, {
2353
+ "propName": "dayValues",
2354
+ "methodName": "dayValuesChanged"
2355
+ }, {
2356
+ "propName": "hourValues",
2357
+ "methodName": "hourValuesChanged"
2358
+ }, {
2359
+ "propName": "minuteValues",
2360
+ "methodName": "minuteValuesChanged"
2361
+ }, {
2362
+ "propName": "value",
2363
+ "methodName": "valueChanged"
2364
+ }];
2365
+ }
2328
2366
  }
2329
2367
  let datetimeIds = 0;