voyager-ionic-core 7.5.5 → 7.6.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1858) hide show
  1. package/components/action-sheet.js +297 -287
  2. package/components/alert.js +477 -467
  3. package/components/animation.js +991 -990
  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 +1112 -1062
  13. package/components/dir.js +5 -5
  14. package/components/focus-visible.js +63 -63
  15. package/components/form-controller.js +45 -45
  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 -58
  29. package/components/index9.js +171 -171
  30. package/components/input-shims.js +488 -483
  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 +220 -220
  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 +1741 -1709
  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 +44 -44
  78. package/components/ion-fab.d.ts +2 -2
  79. package/components/ion-fab.js +75 -75
  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 +298 -298
  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 +498 -454
  94. package/components/ion-item-divider.d.ts +2 -2
  95. package/components/ion-item-divider.js +34 -34
  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 +67 -67
  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 -631
  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 -747
  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 +39 -39
  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 +402 -400
  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 -427
  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 +147 -147
  172. package/components/ion-tab-bar.d.ts +2 -2
  173. package/components/ion-tab-bar.js +77 -77
  174. package/components/ion-tab-button.d.ts +2 -2
  175. package/components/ion-tab-button.js +104 -104
  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 +443 -395
  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 +56 -56
  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 +33 -33
  202. package/components/list.js +50 -50
  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 +468 -468
  212. package/components/popover.js +1154 -1144
  213. package/components/radio-group.js +161 -159
  214. package/components/radio.js +248 -208
  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 +30 -30
  222. package/css/core.css +66 -8
  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 +1 -1
  233. package/css/ionic.bundle.css.map +1 -1
  234. package/css/padding.css +44 -0
  235. package/css/padding.css.map +1 -1
  236. package/css/structure.css +44 -0
  237. package/css/structure.css.map +1 -1
  238. package/css/text-alignment.css +44 -0
  239. package/css/text-alignment.css.map +1 -1
  240. package/css/text-transformation.css +44 -0
  241. package/css/text-transformation.css.map +1 -1
  242. package/css/typography.css +44 -0
  243. package/css/typography.css.map +1 -1
  244. package/css/utils.bundle.css +220 -0
  245. package/css/utils.bundle.css.map +1 -1
  246. package/dist/cjs/animation-9b401d39.js +1062 -0
  247. package/dist/cjs/{app-globals-1d4c1dbf.js → app-globals-7def22c8.js} +1 -1
  248. package/dist/cjs/button-active-962fe442.js +69 -0
  249. package/dist/cjs/{capacitor-2ffba62a.js → capacitor-c04564bf.js} +5 -5
  250. package/dist/cjs/compare-with-utils-df1001d7.js +44 -0
  251. package/dist/cjs/config-4f60b98a.js +199 -0
  252. package/dist/cjs/cubic-bezier-f2dccc53.js +92 -0
  253. package/dist/cjs/data-a5109f09.js +1672 -0
  254. package/dist/cjs/{dir-f1e0ca26.js → dir-94c21456.js} +5 -5
  255. package/dist/cjs/focus-visible-7a0ce04f.js +77 -0
  256. package/dist/cjs/form-controller-7d42a722.js +66 -0
  257. package/dist/cjs/framework-delegate-1c29b14a.js +144 -0
  258. package/dist/cjs/gesture-controller-c40c045a.js +197 -0
  259. package/dist/cjs/haptic-b882e0bb.js +212 -0
  260. package/dist/cjs/hardware-back-button-76833cac.js +76 -0
  261. package/dist/cjs/helpers-76bb7efb.js +441 -0
  262. package/dist/cjs/index-17ab7794.js +243 -0
  263. package/dist/cjs/index-3b012034.js +308 -0
  264. package/dist/cjs/{index-c2940dc1.js → index-50dcfe2f.js} +79 -15
  265. package/dist/cjs/{index-cc7dfb7c.js → index-5915f9b3.js} +3 -3
  266. package/dist/cjs/index-b4f986cd.js +198 -0
  267. package/dist/cjs/index-c8d52405.js +10 -0
  268. package/dist/cjs/index-d1b59ffa.js +459 -0
  269. package/dist/cjs/{index-da2c7a37.js → index-da15e99c.js} +60 -60
  270. package/dist/cjs/index.cjs.js +113 -113
  271. package/dist/cjs/input-shims-a23bb0f4.js +601 -0
  272. package/dist/cjs/input.utils-3d0166a2.js +138 -0
  273. package/dist/cjs/ion-accordion_2.cjs.entry.js +488 -488
  274. package/dist/cjs/ion-action-sheet.cjs.entry.js +260 -250
  275. package/dist/cjs/ion-alert.cjs.entry.js +442 -432
  276. package/dist/cjs/ion-app_8.cjs.entry.js +1151 -1151
  277. package/dist/cjs/ion-avatar_3.cjs.entry.js +29 -29
  278. package/dist/cjs/ion-back-button.cjs.entry.js +73 -73
  279. package/dist/cjs/ion-backdrop.cjs.entry.js +40 -40
  280. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +194 -194
  281. package/dist/cjs/ion-button_2.cjs.entry.js +303 -303
  282. package/dist/cjs/ion-card_5.cjs.entry.js +105 -105
  283. package/dist/cjs/ion-checkbox.cjs.entry.js +149 -147
  284. package/dist/cjs/ion-chip.cjs.entry.js +20 -20
  285. package/dist/cjs/ion-col_3.cjs.entry.js +136 -136
  286. package/dist/cjs/ion-datetime-button.cjs.entry.js +325 -325
  287. package/dist/cjs/ion-datetime_3.cjs.entry.js +2204 -2162
  288. package/dist/cjs/ion-fab_3.cjs.entry.js +150 -150
  289. package/dist/cjs/ion-img.cjs.entry.js +79 -79
  290. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +198 -190
  291. package/dist/cjs/ion-input.cjs.entry.js +443 -399
  292. package/dist/cjs/ion-item-option_3.cjs.entry.js +457 -457
  293. package/dist/cjs/ion-item_8.cjs.entry.js +441 -428
  294. package/dist/cjs/ion-loading.cjs.entry.js +220 -210
  295. package/dist/cjs/ion-menu_3.cjs.entry.js +670 -670
  296. package/dist/cjs/ion-modal.cjs.entry.js +1415 -1405
  297. package/dist/cjs/ion-nav_2.cjs.entry.js +904 -904
  298. package/dist/cjs/ion-picker-column-internal.cjs.entry.js +331 -327
  299. package/dist/cjs/ion-picker-internal.cjs.entry.js +453 -453
  300. package/dist/cjs/ion-popover.cjs.entry.js +1108 -1098
  301. package/dist/cjs/ion-progress-bar.cjs.entry.js +40 -40
  302. package/dist/cjs/ion-radio_2.cjs.entry.js +321 -316
  303. package/dist/cjs/ion-range.cjs.entry.js +558 -556
  304. package/dist/cjs/ion-refresher_2.cjs.entry.js +786 -786
  305. package/dist/cjs/ion-reorder_2.cjs.entry.js +267 -267
  306. package/dist/cjs/ion-ripple-effect.cjs.entry.js +66 -66
  307. package/dist/cjs/ion-route_4.cjs.entry.js +693 -693
  308. package/dist/cjs/ion-searchbar.cjs.entry.js +360 -358
  309. package/dist/cjs/ion-segment_2.cjs.entry.js +507 -507
  310. package/dist/cjs/ion-select_3.cjs.entry.js +784 -768
  311. package/dist/cjs/ion-spinner.cjs.entry.js +46 -46
  312. package/dist/cjs/ion-split-pane.cjs.entry.js +119 -119
  313. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +138 -138
  314. package/dist/cjs/ion-tab_2.cjs.entry.js +187 -187
  315. package/dist/cjs/ion-text.cjs.entry.js +13 -13
  316. package/dist/cjs/ion-textarea.cjs.entry.js +401 -353
  317. package/dist/cjs/ion-toast.cjs.entry.js +771 -419
  318. package/dist/cjs/ion-toggle.cjs.entry.js +227 -225
  319. package/dist/cjs/ionic-global-a4edbf03.js +230 -0
  320. package/dist/cjs/ionic.cjs.js +5 -5
  321. package/dist/cjs/ios.transition-b5353f3e.js +654 -0
  322. package/dist/cjs/keyboard-0272231f.js +81 -0
  323. package/dist/cjs/{keyboard-38f2bb7b.js → keyboard-af1bb365.js} +62 -62
  324. package/dist/cjs/keyboard-controller-c05e747a.js +167 -0
  325. package/dist/cjs/loader.cjs.js +4 -4
  326. package/dist/cjs/lock-controller-6585a42a.js +40 -0
  327. package/dist/cjs/md.transition-67157dd9.js +59 -0
  328. package/dist/cjs/notch-controller-9735e7ac.js +155 -0
  329. package/dist/cjs/overlays-e77cc023.js +716 -0
  330. package/dist/cjs/spinner-configs-282fd50a.js +147 -0
  331. package/dist/cjs/status-tap-b5d77c08.js +42 -0
  332. package/dist/cjs/swipe-back-e37a1a5c.js +81 -0
  333. package/dist/cjs/theme-d1c573d2.js +48 -0
  334. package/dist/cjs/watch-options-f5f3e158.js +49 -0
  335. package/dist/collection/collection-manifest.json +7 -7
  336. package/dist/collection/components/accordion/accordion.ios.css +44 -0
  337. package/dist/collection/components/accordion/accordion.js +410 -410
  338. package/dist/collection/components/accordion/accordion.md.css +22 -0
  339. package/dist/collection/components/accordion/test/a11y/accordion.e2e.js +31 -31
  340. package/dist/collection/components/accordion/test/accordion.e2e.js +24 -24
  341. package/dist/collection/components/accordion/test/accordion.spec.js +195 -0
  342. package/dist/collection/components/accordion/test/basic/accordion.e2e.js +26 -26
  343. package/dist/collection/components/accordion/test/multiple/accordion.e2e.js +18 -18
  344. package/dist/collection/components/accordion/test/nested/accordion.e2e.js +16 -16
  345. package/dist/collection/components/accordion/test/standalone/accordion.e2e.js +6 -6
  346. package/dist/collection/components/accordion-group/accordion-group.ios.css +44 -0
  347. package/dist/collection/components/accordion-group/accordion-group.js +421 -421
  348. package/dist/collection/components/accordion-group/accordion-group.md.css +66 -0
  349. package/dist/collection/components/action-sheet/action-sheet.ios.css +44 -0
  350. package/dist/collection/components/action-sheet/action-sheet.js +739 -729
  351. package/dist/collection/components/action-sheet/action-sheet.md.css +44 -0
  352. package/dist/collection/components/action-sheet/animations/ios.enter.js +18 -18
  353. package/dist/collection/components/action-sheet/animations/ios.leave.js +12 -12
  354. package/dist/collection/components/action-sheet/animations/md.enter.js +18 -18
  355. package/dist/collection/components/action-sheet/animations/md.leave.js +12 -12
  356. package/dist/collection/components/action-sheet/test/a11y/action-sheet.e2e.js +59 -59
  357. package/dist/collection/components/action-sheet/test/action-sheet-id.spec.js +32 -0
  358. package/dist/collection/components/action-sheet/test/basic/action-sheet-rendering.e2e.js +33 -33
  359. package/dist/collection/components/action-sheet/test/basic/action-sheet.e2e.js +74 -74
  360. package/dist/collection/components/action-sheet/test/basic/action-sheet.spec.js +18 -0
  361. package/dist/collection/components/action-sheet/test/basic/fixture.js +23 -23
  362. package/dist/collection/components/action-sheet/test/is-open/action-sheet.e2e.js +25 -25
  363. package/dist/collection/components/action-sheet/test/translucent/action-sheet.e2e.js +10 -10
  364. package/dist/collection/components/action-sheet/test/trigger/action-sheet.e2e.js +21 -21
  365. package/dist/collection/components/alert/alert.ios.css +85 -1
  366. package/dist/collection/components/alert/alert.js +977 -967
  367. package/dist/collection/components/alert/alert.md.css +115 -3
  368. package/dist/collection/components/alert/animations/ios.enter.js +19 -19
  369. package/dist/collection/components/alert/animations/ios.leave.js +13 -13
  370. package/dist/collection/components/alert/animations/md.enter.js +19 -19
  371. package/dist/collection/components/alert/animations/md.leave.js +10 -10
  372. package/dist/collection/components/alert/test/a11y/alert.e2e.js +116 -116
  373. package/dist/collection/components/alert/test/alert-id.spec.js +32 -0
  374. package/dist/collection/components/alert/test/alert.spec.js +37 -0
  375. package/dist/collection/components/alert/test/basic/alert-tablet.e2e.js +40 -0
  376. package/dist/collection/components/alert/test/basic/alert.e2e.js +96 -96
  377. package/dist/collection/components/alert/test/is-open/alert.e2e.js +25 -25
  378. package/dist/collection/components/alert/test/standalone/alert.e2e.js +9 -9
  379. package/dist/collection/components/alert/test/trigger/alert.e2e.js +21 -21
  380. package/dist/collection/components/app/app.js +116 -116
  381. package/dist/collection/components/app/test/safe-area/app.e2e.js +24 -24
  382. package/dist/collection/components/avatar/avatar.ios.css +44 -0
  383. package/dist/collection/components/avatar/avatar.js +17 -17
  384. package/dist/collection/components/avatar/avatar.md.css +44 -0
  385. package/dist/collection/components/avatar/test/basic/avatar.e2e.js +12 -12
  386. package/dist/collection/components/back-button/back-button.ios.css +44 -0
  387. package/dist/collection/components/back-button/back-button.js +214 -214
  388. package/dist/collection/components/back-button/back-button.md.css +44 -0
  389. package/dist/collection/components/back-button/test/a11y/back-button.e2e.js +6 -6
  390. package/dist/collection/components/back-button/test/back-button.spec.js +86 -0
  391. package/dist/collection/components/back-button/test/basic/back-button.e2e.js +6 -6
  392. package/dist/collection/components/back-button/test/toolbar/back-button.e2e.js +6 -6
  393. package/dist/collection/components/backdrop/backdrop.ios.css +44 -0
  394. package/dist/collection/components/backdrop/backdrop.js +131 -131
  395. package/dist/collection/components/backdrop/backdrop.md.css +44 -0
  396. package/dist/collection/components/badge/badge.ios.css +44 -0
  397. package/dist/collection/components/badge/badge.js +49 -49
  398. package/dist/collection/components/badge/badge.md.css +44 -0
  399. package/dist/collection/components/badge/test/a11y/badge.e2e.js +6 -6
  400. package/dist/collection/components/badge/test/basic/badge.e2e.js +6 -6
  401. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +44 -0
  402. package/dist/collection/components/breadcrumb/breadcrumb.js +395 -395
  403. package/dist/collection/components/breadcrumb/breadcrumb.md.css +44 -0
  404. package/dist/collection/components/breadcrumb/test/aria.spec.js +22 -0
  405. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +22 -0
  406. package/dist/collection/components/breadcrumbs/breadcrumbs.js +247 -247
  407. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +22 -0
  408. package/dist/collection/components/breadcrumbs/test/a11y/breadcrumbs.e2e.js +12 -12
  409. package/dist/collection/components/breadcrumbs/test/basic/breadcrumbs.e2e.js +6 -6
  410. package/dist/collection/components/breadcrumbs/test/breadcrumbs.spec.js +58 -0
  411. package/dist/collection/components/breadcrumbs/test/collapsed/breadcrumbs.e2e.js +6 -6
  412. package/dist/collection/components/breadcrumbs/test/reactive/breadcrumbs.e2e.js +43 -43
  413. package/dist/collection/components/button/button.ios.css +66 -0
  414. package/dist/collection/components/button/button.js +541 -541
  415. package/dist/collection/components/button/button.md.css +44 -0
  416. package/dist/collection/components/button/test/a11y/button.e2e.js +21 -21
  417. package/dist/collection/components/button/test/basic/button.e2e.js +32 -32
  418. package/dist/collection/components/button/test/clear/button.e2e.js +6 -6
  419. package/dist/collection/components/button/test/expand/button.e2e.js +6 -6
  420. package/dist/collection/components/button/test/form-reference/button.e2e.js +84 -84
  421. package/dist/collection/components/button/test/form-reference/button.spec.js +26 -0
  422. package/dist/collection/components/button/test/icon/button.e2e.js +6 -6
  423. package/dist/collection/components/button/test/outline/button.e2e.js +6 -6
  424. package/dist/collection/components/button/test/round/button.e2e.js +6 -6
  425. package/dist/collection/components/button/test/size/button.e2e.js +22 -22
  426. package/dist/collection/components/button/test/strong/button.e2e.js +22 -22
  427. package/dist/collection/components/button/test/wrap/button.e2e.js +73 -73
  428. package/dist/collection/components/buttons/buttons.ios.css +66 -0
  429. package/dist/collection/components/buttons/buttons.js +46 -46
  430. package/dist/collection/components/buttons/buttons.md.css +66 -0
  431. package/dist/collection/components/buttons/test/a11y/buttons.e2e.js +21 -21
  432. package/dist/collection/components/card/card.ios.css +44 -0
  433. package/dist/collection/components/card/card.js +251 -251
  434. package/dist/collection/components/card/card.md.css +44 -0
  435. package/dist/collection/components/card/test/a11y/card.e2e.js +6 -6
  436. package/dist/collection/components/card/test/aria.spec.js +16 -0
  437. package/dist/collection/components/card/test/basic/card.e2e.js +38 -38
  438. package/dist/collection/components/card-content/card-content.ios.css +44 -0
  439. package/dist/collection/components/card-content/card-content.js +21 -21
  440. package/dist/collection/components/card-content/card-content.md.css +44 -0
  441. package/dist/collection/components/card-header/card-header.ios.css +44 -0
  442. package/dist/collection/components/card-header/card-header.js +70 -70
  443. package/dist/collection/components/card-header/card-header.md.css +44 -0
  444. package/dist/collection/components/card-header/test/basic/card-header.e2e.js +6 -6
  445. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +44 -0
  446. package/dist/collection/components/card-subtitle/card-subtitle.js +50 -50
  447. package/dist/collection/components/card-subtitle/card-subtitle.md.css +44 -0
  448. package/dist/collection/components/card-title/card-title.ios.css +44 -0
  449. package/dist/collection/components/card-title/card-title.js +50 -50
  450. package/dist/collection/components/card-title/card-title.md.css +44 -0
  451. package/dist/collection/components/checkbox/checkbox.ios.css +66 -6
  452. package/dist/collection/components/checkbox/checkbox.js +418 -415
  453. package/dist/collection/components/checkbox/checkbox.md.css +66 -6
  454. package/dist/collection/components/checkbox/test/a11y/checkbox.e2e.js +14 -14
  455. package/dist/collection/components/checkbox/test/basic/checkbox.e2e.js +50 -50
  456. package/dist/collection/components/checkbox/test/checkbox.spec.js +34 -0
  457. package/dist/collection/components/checkbox/test/color/checkbox.e2e.js +11 -11
  458. package/dist/collection/components/checkbox/test/indeterminate/checkbox.e2e.js +6 -6
  459. package/dist/collection/components/checkbox/test/item/checkbox.e2e.js +29 -29
  460. package/dist/collection/components/checkbox/test/label/checkbox.e2e.js +75 -75
  461. package/dist/collection/components/checkbox/test/legacy/basic/checkbox.e2e.js +45 -45
  462. package/dist/collection/components/checkbox/test/legacy/indeterminate/checkbox.e2e.js +6 -6
  463. package/dist/collection/components/checkbox/test/states/checkbox.e2e.js +21 -21
  464. package/dist/collection/components/chip/chip.ios.css +22 -0
  465. package/dist/collection/components/chip/chip.js +90 -90
  466. package/dist/collection/components/chip/chip.md.css +22 -0
  467. package/dist/collection/components/chip/test/a11y/chip.e2e.js +19 -19
  468. package/dist/collection/components/chip/test/basic/chip.e2e.js +42 -42
  469. package/dist/collection/components/chip/test/states/chip.e2e.js +14 -14
  470. package/dist/collection/components/col/col.css +66 -0
  471. package/dist/collection/components/col/col.js +536 -536
  472. package/dist/collection/components/content/content.css +22 -0
  473. package/dist/collection/components/content/content.js +745 -745
  474. package/dist/collection/components/content/test/basic/content.e2e.js +6 -6
  475. package/dist/collection/components/content/test/fixed/content.e2e.js +6 -6
  476. package/dist/collection/components/content/test/fullscreen/content.e2e.js +6 -6
  477. package/dist/collection/components/content/test/standalone/content.e2e.js +5 -5
  478. package/dist/collection/components/datetime/datetime.ios.css +45 -0
  479. package/dist/collection/components/datetime/datetime.js +2264 -2232
  480. package/dist/collection/components/datetime/datetime.md.css +45 -0
  481. package/dist/collection/components/datetime/test/a11y/datetime.e2e.js +58 -58
  482. package/dist/collection/components/datetime/test/a11y/datetime.spec.js +43 -0
  483. package/dist/collection/components/datetime/test/basic/datetime.e2e.js +241 -241
  484. package/dist/collection/components/datetime/test/color/datetime.e2e.js +9 -9
  485. package/dist/collection/components/datetime/test/comparison.spec.js +43 -0
  486. package/dist/collection/components/datetime/test/custom/datetime.e2e.js +37 -37
  487. package/dist/collection/components/datetime/test/data.spec.js +456 -0
  488. package/dist/collection/components/datetime/test/datetime.e2e.js +29 -29
  489. package/dist/collection/components/datetime/test/disable-dates/datetime.e2e.js +119 -119
  490. package/dist/collection/components/datetime/test/disabled/datetime.e2e.js +43 -43
  491. package/dist/collection/components/datetime/test/disabled/datetime.spec.js +33 -0
  492. package/dist/collection/components/datetime/test/display/datetime.e2e.js +86 -86
  493. package/dist/collection/components/datetime/test/first-day-of-week/datetime.e2e.js +6 -6
  494. package/dist/collection/components/datetime/test/format.spec.js +124 -0
  495. package/dist/collection/components/datetime/test/helpers.spec.js +72 -0
  496. package/dist/collection/components/datetime/test/highlighted-dates/datetime.e2e.js +76 -76
  497. package/dist/collection/components/datetime/test/hour-cycle/datetime.e2e.js +21 -21
  498. package/dist/collection/components/datetime/test/locale/datetime.e2e.js +98 -98
  499. package/dist/collection/components/datetime/test/manipulation.spec.js +565 -0
  500. package/dist/collection/components/datetime/test/minmax/datetime.e2e.js +178 -178
  501. package/dist/collection/components/datetime/test/month-year-picker/datetime.e2e.js +17 -17
  502. package/dist/collection/components/datetime/test/multiple/datetime.e2e.js +170 -170
  503. package/dist/collection/components/datetime/test/parse.spec.js +222 -0
  504. package/dist/collection/components/datetime/test/position/datetime.e2e.js +14 -14
  505. package/dist/collection/components/datetime/test/prefer-wheel/datetime.e2e.js +263 -263
  506. package/dist/collection/components/datetime/test/prefer-wheel/datetime.spec.js +27 -0
  507. package/dist/collection/components/datetime/test/presentation/datetime.e2e.js +137 -137
  508. package/dist/collection/components/datetime/test/readonly/datetime.e2e.js +86 -86
  509. package/dist/collection/components/datetime/test/set-value/datetime.e2e.js +40 -40
  510. package/dist/collection/components/datetime/test/state.spec.js +114 -0
  511. package/dist/collection/components/datetime/test/time-label/datetime.e2e.js +13 -13
  512. package/dist/collection/components/datetime/test/values/datetime.e2e.js +77 -77
  513. package/dist/collection/components/datetime/utils/comparison.js +22 -22
  514. package/dist/collection/components/datetime/utils/data.js +394 -394
  515. package/dist/collection/components/datetime/utils/format.js +143 -143
  516. package/dist/collection/components/datetime/utils/helpers.js +74 -74
  517. package/dist/collection/components/datetime/utils/manipulation.js +332 -282
  518. package/dist/collection/components/datetime/utils/parse.js +139 -139
  519. package/dist/collection/components/datetime/utils/state.js +123 -123
  520. package/dist/collection/components/datetime-button/datetime-button.css +22 -0
  521. package/dist/collection/components/datetime-button/datetime-button.js +399 -399
  522. package/dist/collection/components/datetime-button/test/a11y/datetime-button.e2e.js +11 -11
  523. package/dist/collection/components/datetime-button/test/basic/datetime-button.e2e.js +123 -123
  524. package/dist/collection/components/datetime-button/test/disabled/datetime-button.e2e.js +13 -13
  525. package/dist/collection/components/datetime-button/test/multiple/datetime-button.e2e.js +38 -38
  526. package/dist/collection/components/datetime-button/test/overlays/datetime-button.e2e.js +102 -102
  527. package/dist/collection/components/fab/fab.css +88 -0
  528. package/dist/collection/components/fab/fab.js +179 -179
  529. package/dist/collection/components/fab/test/basic/fab.e2e.js +50 -50
  530. package/dist/collection/components/fab/test/custom-size/fab.e2e.js +6 -6
  531. package/dist/collection/components/fab/test/safe-area/fab.e2e.js +25 -25
  532. package/dist/collection/components/fab/test/states/fab.e2e.js +6 -6
  533. package/dist/collection/components/fab/test/translucent/fab.e2e.js +17 -17
  534. package/dist/collection/components/fab-button/fab-button.ios.css +44 -0
  535. package/dist/collection/components/fab-button/fab-button.js +374 -374
  536. package/dist/collection/components/fab-button/fab-button.md.css +44 -0
  537. package/dist/collection/components/fab-button/test/a11y/fab-button.e2e.js +6 -6
  538. package/dist/collection/components/fab-list/fab-list.css +44 -0
  539. package/dist/collection/components/fab-list/fab-list.js +79 -79
  540. package/dist/collection/components/footer/footer.ios.css +44 -0
  541. package/dist/collection/components/footer/footer.js +135 -135
  542. package/dist/collection/components/footer/footer.md.css +44 -0
  543. package/dist/collection/components/footer/footer.utils.js +25 -25
  544. package/dist/collection/components/footer/test/basic/footer.e2e.js +18 -18
  545. package/dist/collection/components/footer/test/fade/footer.e2e.js +10 -10
  546. package/dist/collection/components/footer/test/scroll-target/footer.e2e.js +15 -15
  547. package/dist/collection/components/footer/test/with-tabs/footer.e2e.js +6 -6
  548. package/dist/collection/components/grid/grid.css +66 -0
  549. package/dist/collection/components/grid/grid.js +44 -44
  550. package/dist/collection/components/grid/test/basic/grid.e2e.js +6 -6
  551. package/dist/collection/components/grid/test/offsets/grid.e2e.js +6 -6
  552. package/dist/collection/components/grid/test/padding/grid.e2e.js +6 -6
  553. package/dist/collection/components/grid/test/sizes/grid.e2e.js +6 -6
  554. package/dist/collection/components/header/header.ios.css +44 -0
  555. package/dist/collection/components/header/header.js +181 -181
  556. package/dist/collection/components/header/header.md.css +44 -0
  557. package/dist/collection/components/header/header.utils.js +148 -148
  558. package/dist/collection/components/header/test/a11y/header.e2e.js +18 -18
  559. package/dist/collection/components/header/test/basic/header.e2e.js +23 -23
  560. package/dist/collection/components/header/test/condense/header.e2e.js +25 -25
  561. package/dist/collection/components/header/test/fade/header.e2e.js +10 -10
  562. package/dist/collection/components/header/test/scroll-target/header.e2e.js +15 -15
  563. package/dist/collection/components/icon/test/basic/icon.e2e.js +6 -6
  564. package/dist/collection/components/icon/test/dir/icon.e2e.js +11 -11
  565. package/dist/collection/components/img/img.js +177 -177
  566. package/dist/collection/components/img/test/basic/img.e2e.js +62 -62
  567. package/dist/collection/components/img/test/draggable/img.e2e.js +10 -10
  568. package/dist/collection/components/infinite-scroll/infinite-scroll.js +279 -271
  569. package/dist/collection/components/infinite-scroll/test/basic/infinite-scroll.e2e.js +11 -11
  570. package/dist/collection/components/infinite-scroll/test/scroll-target/infinite-scroll.e2e.js +11 -11
  571. package/dist/collection/components/infinite-scroll/test/small-dom-update/infinite-scroll.e2e.js +31 -0
  572. package/dist/collection/components/infinite-scroll/test/top/infinite-scroll.e2e.js +11 -11
  573. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +44 -0
  574. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +86 -86
  575. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +44 -0
  576. package/dist/collection/components/infinite-scroll-content/test/infinite-scroll-content.spec.js +37 -0
  577. package/dist/collection/components/input/input.ios.css +76 -3
  578. package/dist/collection/components/input/input.js +1250 -1204
  579. package/dist/collection/components/input/input.md.css +145 -12
  580. package/dist/collection/components/input/input.utils.js +22 -22
  581. package/dist/collection/components/input/test/a11y/input.e2e.js +12 -12
  582. package/dist/collection/components/input/test/basic/input.e2e.js +63 -63
  583. package/dist/collection/components/input/test/bottom-content/input.e2e.js +89 -89
  584. package/dist/collection/components/input/test/card/input.e2e.js +6 -6
  585. package/dist/collection/components/input/test/clear-on-edit/input.e2e.js +45 -25
  586. package/dist/collection/components/input/test/color/input.e2e.js +88 -88
  587. package/dist/collection/components/input/test/fill/input.e2e.js +63 -63
  588. package/dist/collection/components/input/test/highlight/input.e2e.js +52 -52
  589. package/dist/collection/components/input/test/input.e2e.js +6 -6
  590. package/dist/collection/components/input/test/input.spec.js +85 -0
  591. package/dist/collection/components/input/test/item/input.e2e.js +11 -11
  592. package/dist/collection/components/input/test/item/input.spec.js +24 -0
  593. package/dist/collection/components/input/test/label-placement/input.e2e.js +104 -104
  594. package/dist/collection/components/input/test/legacy/a11y/input.e2e.js +15 -15
  595. package/dist/collection/components/input/test/legacy/basic/input.e2e.js +102 -102
  596. package/dist/collection/components/input/test/legacy/clear-on-edit/input.e2e.js +44 -44
  597. package/dist/collection/components/input/test/legacy/input-events.e2e.js +56 -56
  598. package/dist/collection/components/input/test/legacy/masking/input.e2e.js +15 -15
  599. package/dist/collection/components/input/test/legacy/spec/input.e2e.js +8 -8
  600. package/dist/collection/components/input/test/slot/input.e2e.js +51 -0
  601. package/dist/collection/components/input/test/states/input.e2e.js +11 -11
  602. package/dist/collection/components/item/item.ios.css +85 -3
  603. package/dist/collection/components/item/item.js +614 -614
  604. package/dist/collection/components/item/item.md.css +129 -3
  605. package/dist/collection/components/item/test/a11y/item.e2e.js +47 -47
  606. package/dist/collection/components/item/test/a11y/item.spec.js +48 -0
  607. package/dist/collection/components/item/test/alignment/item.e2e.js +6 -6
  608. package/dist/collection/components/item/test/basic/item.e2e.js +16 -16
  609. package/dist/collection/components/item/test/buttons/item.e2e.js +18 -18
  610. package/dist/collection/components/item/test/colors/item.e2e.js +6 -6
  611. package/dist/collection/components/item/test/counter/item.e2e.js +34 -34
  612. package/dist/collection/components/item/test/css-variables/item.e2e.js +6 -6
  613. package/dist/collection/components/item/test/disabled/item.e2e.js +6 -7
  614. package/dist/collection/components/item/test/dividers/item.e2e.js +6 -6
  615. package/dist/collection/components/item/test/groups/item.e2e.js +8 -8
  616. package/dist/collection/components/item/test/highlight/item.e2e.js +6 -6
  617. package/dist/collection/components/item/test/icons/item.e2e.js +6 -6
  618. package/dist/collection/components/item/test/images/item.e2e.js +6 -6
  619. package/dist/collection/components/item/test/inputs/item.e2e.js +139 -139
  620. package/dist/collection/components/item/test/legacy/alignment/item.e2e.js +6 -6
  621. package/dist/collection/components/item/test/legacy/disabled/item.e2e.js +6 -6
  622. package/dist/collection/components/item/test/legacy/fill/item.e2e.js +6 -6
  623. package/dist/collection/components/item/test/legacy/form/item.e2e.js +6 -6
  624. package/dist/collection/components/item/test/lines/item.e2e.js +6 -6
  625. package/dist/collection/components/item/test/media/item.e2e.js +6 -6
  626. package/dist/collection/components/item/test/reorder/item.e2e.js +8 -8
  627. package/dist/collection/components/item/test/slotted-inputs/item.e2e.js +6 -6
  628. package/dist/collection/components/item/test/states/item.e2e.js +6 -6
  629. package/dist/collection/components/item-divider/item-divider.ios.css +66 -0
  630. package/dist/collection/components/item-divider/item-divider.js +71 -71
  631. package/dist/collection/components/item-divider/item-divider.md.css +66 -0
  632. package/dist/collection/components/item-divider/test/a11y/item-divider.e2e.js +11 -11
  633. package/dist/collection/components/item-divider/test/basic/item-divider.e2e.js +25 -25
  634. package/dist/collection/components/item-divider/test/spec/item-divider.e2e.js +8 -8
  635. package/dist/collection/components/item-group/item-group.ios.css +44 -0
  636. package/dist/collection/components/item-group/item-group.js +22 -22
  637. package/dist/collection/components/item-group/item-group.md.css +44 -0
  638. package/dist/collection/components/item-option/item-option.ios.css +44 -0
  639. package/dist/collection/components/item-option/item-option.js +197 -197
  640. package/dist/collection/components/item-option/item-option.md.css +44 -0
  641. package/dist/collection/components/item-options/item-options.ios.css +66 -0
  642. package/dist/collection/components/item-options/item-options.js +110 -110
  643. package/dist/collection/components/item-options/item-options.md.css +66 -0
  644. package/dist/collection/components/item-sliding/item-sliding.css +22 -0
  645. package/dist/collection/components/item-sliding/item-sliding.js +538 -538
  646. package/dist/collection/components/item-sliding/test/a11y/item-sliding.e2e.js +5 -5
  647. package/dist/collection/components/item-sliding/test/async/item-sliding.e2e.js +25 -25
  648. package/dist/collection/components/item-sliding/test/basic/item-sliding.e2e.js +87 -87
  649. package/dist/collection/components/item-sliding/test/icons/item-sliding.e2e.js +20 -20
  650. package/dist/collection/components/item-sliding/test/scroll-target/item-sliding.e2e.js +18 -18
  651. package/dist/collection/components/item-sliding/test/test.utils.js +20 -20
  652. package/dist/collection/components/label/label.ios.css +80 -3
  653. package/dist/collection/components/label/label.js +174 -174
  654. package/dist/collection/components/label/label.md.css +80 -3
  655. package/dist/collection/components/label/test/a11y/label.e2e.js +21 -21
  656. package/dist/collection/components/label/test/basic/label.e2e.js +21 -21
  657. package/dist/collection/components/label/test/color/label.e2e.js +21 -21
  658. package/dist/collection/components/label/test/headings/label.e2e.js +5 -5
  659. package/dist/collection/components/list/list.ios.css +66 -0
  660. package/dist/collection/components/list/list.js +101 -101
  661. package/dist/collection/components/list/list.md.css +66 -0
  662. package/dist/collection/components/list/test/a11y/list.e2e.js +6 -6
  663. package/dist/collection/components/list/test/basic/list.e2e.js +6 -6
  664. package/dist/collection/components/list/test/inset/list.e2e.js +16 -16
  665. package/dist/collection/components/list/test/lines/list.e2e.js +40 -40
  666. package/dist/collection/components/list-header/list-header.ios.css +66 -0
  667. package/dist/collection/components/list-header/list-header.js +69 -69
  668. package/dist/collection/components/list-header/list-header.md.css +66 -0
  669. package/dist/collection/components/list-header/test/a11y/list-header.e2e.js +6 -6
  670. package/dist/collection/components/list-header/test/basic/list-header.e2e.js +14 -14
  671. package/dist/collection/components/loading/animations/ios.enter.js +19 -19
  672. package/dist/collection/components/loading/animations/ios.leave.js +13 -13
  673. package/dist/collection/components/loading/animations/md.enter.js +19 -19
  674. package/dist/collection/components/loading/animations/md.leave.js +13 -13
  675. package/dist/collection/components/loading/loading.ios.css +44 -0
  676. package/dist/collection/components/loading/loading.js +730 -720
  677. package/dist/collection/components/loading/loading.md.css +44 -0
  678. package/dist/collection/components/loading/test/a11y/loading.e2e.js +26 -26
  679. package/dist/collection/components/loading/test/basic/loading.e2e.js +60 -60
  680. package/dist/collection/components/loading/test/basic/loading.spec.js +16 -0
  681. package/dist/collection/components/loading/test/is-open/loading.e2e.js +17 -17
  682. package/dist/collection/components/loading/test/loading-id.spec.js +32 -0
  683. package/dist/collection/components/loading/test/loading.spec.js +37 -0
  684. package/dist/collection/components/loading/test/standalone/loading.e2e.js +13 -13
  685. package/dist/collection/components/loading/test/trigger/loading.e2e.js +21 -21
  686. package/dist/collection/components/menu/menu.ios.css +47 -4
  687. package/dist/collection/components/menu/menu.js +956 -956
  688. package/dist/collection/components/menu/menu.md.css +47 -4
  689. package/dist/collection/components/menu/test/a11y/menu.e2e.js +13 -13
  690. package/dist/collection/components/menu/test/basic/menu.e2e.js +102 -102
  691. package/dist/collection/components/menu/test/custom/menu.e2e.js +61 -0
  692. package/dist/collection/components/menu/test/disable/menu.e2e.js +44 -44
  693. package/dist/collection/components/menu/test/focus-trap/menu.e2e.js +61 -61
  694. package/dist/collection/components/menu/test/multiple/menu.e2e.js +49 -49
  695. package/dist/collection/components/menu/test/safe-area/menu.e2e.js +54 -54
  696. package/dist/collection/components/menu-button/menu-button.ios.css +44 -0
  697. package/dist/collection/components/menu-button/menu-button.js +173 -173
  698. package/dist/collection/components/menu-button/menu-button.md.css +44 -0
  699. package/dist/collection/components/menu-button/test/a11y/menu-button.e2e.js +12 -12
  700. package/dist/collection/components/menu-button/test/async/menu-button.e2e.js +12 -12
  701. package/dist/collection/components/menu-button/test/basic/menu-button.e2e.js +6 -6
  702. package/dist/collection/components/menu-toggle/menu-toggle-util.js +2 -2
  703. package/dist/collection/components/menu-toggle/menu-toggle.js +93 -93
  704. package/dist/collection/components/menu-toggle/test/basic/menu-toggle.e2e.js +33 -33
  705. package/dist/collection/components/modal/animations/ios.enter.js +81 -81
  706. package/dist/collection/components/modal/animations/ios.leave.js +74 -74
  707. package/dist/collection/components/modal/animations/md.enter.js +21 -21
  708. package/dist/collection/components/modal/animations/md.leave.js +15 -15
  709. package/dist/collection/components/modal/animations/sheet.js +43 -43
  710. package/dist/collection/components/modal/gestures/sheet.js +289 -289
  711. package/dist/collection/components/modal/gestures/swipe-to-close.js +248 -247
  712. package/dist/collection/components/modal/gestures/utils.js +39 -39
  713. package/dist/collection/components/modal/modal.ios.css +44 -0
  714. package/dist/collection/components/modal/modal.js +1290 -1280
  715. package/dist/collection/components/modal/modal.md.css +44 -0
  716. package/dist/collection/components/modal/test/a11y/modal.e2e.js +12 -12
  717. package/dist/collection/components/modal/test/a11y/modal.spec.js +22 -0
  718. package/dist/collection/components/modal/test/basic/modal.e2e.js +110 -110
  719. package/dist/collection/components/modal/test/basic/modal.spec.js +16 -0
  720. package/dist/collection/components/modal/test/can-dismiss/modal-card.e2e.js +44 -44
  721. package/dist/collection/components/modal/test/can-dismiss/modal-sheet.e2e.js +62 -62
  722. package/dist/collection/components/modal/test/can-dismiss/modal.e2e.js +16 -16
  723. package/dist/collection/components/modal/test/can-dismiss/modal.spec.js +191 -0
  724. package/dist/collection/components/modal/test/card/modal-card.e2e.js +69 -69
  725. package/dist/collection/components/modal/test/card/modal-tablet.e2e.js +67 -67
  726. package/dist/collection/components/modal/test/card-nav/modal.e2e.js +26 -26
  727. package/dist/collection/components/modal/test/card-refresher/modal.e2e.js +14 -14
  728. package/dist/collection/components/modal/test/card-scroll-target/modal.e2e.js +34 -34
  729. package/dist/collection/components/modal/test/custom/modal.e2e.js +16 -16
  730. package/dist/collection/components/modal/test/custom-dialog/modal.e2e.js +12 -12
  731. package/dist/collection/components/modal/test/dark-mode/model.e2e.js +12 -12
  732. package/dist/collection/components/modal/test/fixtures.js +21 -21
  733. package/dist/collection/components/modal/test/inline/modal.e2e.js +34 -34
  734. package/dist/collection/components/modal/test/is-open/modal.e2e.js +17 -17
  735. package/dist/collection/components/modal/test/modal-id.spec.js +32 -0
  736. package/dist/collection/components/modal/test/sheet/modal.e2e.js +178 -178
  737. package/dist/collection/components/modal/test/standalone/modal.e2e.js +12 -12
  738. package/dist/collection/components/modal/test/trigger/modal.e2e.js +23 -23
  739. package/dist/collection/components/modal/utils.js +55 -55
  740. package/dist/collection/components/modal/utils.spec.js +7 -7
  741. package/dist/collection/components/nav/nav.css +22 -0
  742. package/dist/collection/components/nav/nav.js +1748 -1748
  743. package/dist/collection/components/nav/test/basic/nav.e2e.js +58 -58
  744. package/dist/collection/components/nav/test/modal-navigation/nav.e2e.js +52 -52
  745. package/dist/collection/components/nav/test/nav-controller.spec.js +749 -0
  746. package/dist/collection/components/nav/test/nested/nav.e2e.js +54 -54
  747. package/dist/collection/components/nav/test/routing/nav.e2e.js +75 -75
  748. package/dist/collection/components/nav/view-controller.js +52 -52
  749. package/dist/collection/components/nav-link/nav-link-utils.js +16 -16
  750. package/dist/collection/components/nav-link/nav-link.js +106 -106
  751. package/dist/collection/components/note/note.ios.css +44 -0
  752. package/dist/collection/components/note/note.js +49 -49
  753. package/dist/collection/components/note/note.md.css +44 -0
  754. package/dist/collection/components/note/test/a11y/note.e2e.js +59 -16
  755. package/dist/collection/components/note/test/basic/note.e2e.js +33 -33
  756. package/dist/collection/components/picker/animations/ios.enter.js +18 -18
  757. package/dist/collection/components/picker/animations/ios.leave.js +14 -14
  758. package/dist/collection/components/picker/picker.ios.css +44 -0
  759. package/dist/collection/components/picker/picker.js +782 -772
  760. package/dist/collection/components/picker/picker.md.css +44 -0
  761. package/dist/collection/components/picker/test/basic/picker.e2e.js +17 -17
  762. package/dist/collection/components/picker/test/is-open/picker.e2e.js +17 -17
  763. package/dist/collection/components/picker/test/picker-id.spec.js +32 -0
  764. package/dist/collection/components/picker/test/trigger/picker.e2e.js +21 -21
  765. package/dist/collection/components/picker-column/picker-column.ios.css +44 -0
  766. package/dist/collection/components/picker-column/picker-column.js +377 -377
  767. package/dist/collection/components/picker-column/picker-column.md.css +44 -0
  768. package/dist/collection/components/picker-column/test/picker-column-aria.spec.js +35 -0
  769. package/dist/collection/components/picker-column/test/picker-column-dynamic.spec.js +29 -0
  770. package/dist/collection/components/picker-column/test/picker-column.spec.js +17 -0
  771. package/dist/collection/components/picker-column/test/standalone/picker-column.e2e.js +27 -27
  772. package/dist/collection/components/picker-column/test/test.utils.js +29 -29
  773. package/dist/collection/components/picker-column-internal/picker-column-internal.ios.css +33 -3
  774. package/dist/collection/components/picker-column-internal/picker-column-internal.js +523 -501
  775. package/dist/collection/components/picker-column-internal/picker-column-internal.md.css +55 -3
  776. package/dist/collection/components/picker-column-internal/test/basic/picker-column-internal.e2e.js +53 -53
  777. package/dist/collection/components/picker-column-internal/test/disabled/picker-column-internal.e2e.js +66 -37
  778. package/dist/collection/components/picker-internal/picker-internal.ios.css +44 -0
  779. package/dist/collection/components/picker-internal/picker-internal.js +517 -517
  780. package/dist/collection/components/picker-internal/picker-internal.md.css +44 -0
  781. package/dist/collection/components/picker-internal/test/a11y/picker-internal.e2e.js +6 -6
  782. package/dist/collection/components/picker-internal/test/basic/picker-internal.e2e.js +76 -76
  783. package/dist/collection/components/picker-internal/test/keyboard-entry/picker-internal.e2e.js +39 -39
  784. package/dist/collection/components/popover/animations/ios.enter.js +79 -79
  785. package/dist/collection/components/popover/animations/ios.leave.js +28 -28
  786. package/dist/collection/components/popover/animations/md.enter.js +58 -58
  787. package/dist/collection/components/popover/animations/md.leave.js +19 -19
  788. package/dist/collection/components/popover/popover.ios.css +44 -0
  789. package/dist/collection/components/popover/popover.js +1189 -1179
  790. package/dist/collection/components/popover/popover.md.css +44 -0
  791. package/dist/collection/components/popover/test/adjustment/popover.e2e.js +22 -22
  792. package/dist/collection/components/popover/test/arrow/popover.e2e.js +15 -15
  793. package/dist/collection/components/popover/test/async/popover.e2e.js +29 -29
  794. package/dist/collection/components/popover/test/basic/popover.e2e.js +108 -108
  795. package/dist/collection/components/popover/test/basic/popover.spec.js +16 -0
  796. package/dist/collection/components/popover/test/dismiss-on-select/popover.e2e.js +26 -26
  797. package/dist/collection/components/popover/test/fixture.js +16 -16
  798. package/dist/collection/components/popover/test/inline/popover.e2e.js +18 -18
  799. package/dist/collection/components/popover/test/is-open/popover.e2e.js +5 -5
  800. package/dist/collection/components/popover/test/nested/popover.e2e.js +81 -81
  801. package/dist/collection/components/popover/test/popover-id.spec.js +32 -0
  802. package/dist/collection/components/popover/test/position/popover.e2e.js +18 -18
  803. package/dist/collection/components/popover/test/reference/popover.e2e.js +14 -14
  804. package/dist/collection/components/popover/test/size/popover.e2e.js +29 -29
  805. package/dist/collection/components/popover/test/standalone/popover.e2e.js +7 -7
  806. package/dist/collection/components/popover/test/test.utils.js +23 -23
  807. package/dist/collection/components/popover/test/trigger/popover.e2e.js +35 -35
  808. package/dist/collection/components/popover/test/util.spec.js +53 -0
  809. package/dist/collection/components/popover/utils.js +606 -606
  810. package/dist/collection/components/progress-bar/progress-bar.ios.css +22 -0
  811. package/dist/collection/components/progress-bar/progress-bar.js +145 -145
  812. package/dist/collection/components/progress-bar/progress-bar.md.css +22 -0
  813. package/dist/collection/components/progress-bar/test/basic/progress-bar.e2e.js +6 -6
  814. package/dist/collection/components/progress-bar/test/buffer/progress-bar.e2e.js +10 -10
  815. package/dist/collection/components/progress-bar/test/determinate/progress-bar.e2e.js +10 -10
  816. package/dist/collection/components/radio/radio.ios.css +66 -6
  817. package/dist/collection/components/radio/radio.js +453 -449
  818. package/dist/collection/components/radio/radio.md.css +66 -6
  819. package/dist/collection/components/radio/test/a11y/radio.e2e.js +41 -40
  820. package/dist/collection/components/radio/test/color/radio.e2e.js +11 -11
  821. package/dist/collection/components/radio/test/item/radio.e2e.js +37 -37
  822. package/dist/collection/components/radio/test/label-placement/radio.e2e.js +70 -70
  823. package/dist/collection/components/radio/test/legacy/a11y/radio.e2e.js +29 -29
  824. package/dist/collection/components/radio/test/legacy/basic/radio.e2e.js +43 -43
  825. package/dist/collection/components/radio/test/radio.spec.js +60 -0
  826. package/dist/collection/components/radio/test/states/radio.e2e.js +21 -21
  827. package/dist/collection/components/radio-group/radio-group.js +279 -255
  828. package/dist/collection/components/radio-group/test/basic/radio-group.e2e.js +35 -35
  829. package/dist/collection/components/radio-group/test/fixtures.js +22 -22
  830. package/dist/collection/components/radio-group/test/form/radio-group.e2e.js +39 -39
  831. package/dist/collection/components/radio-group/test/legacy/basic/radio-group.e2e.js +59 -59
  832. package/dist/collection/components/radio-group/test/legacy/form/radio-group.e2e.js +22 -22
  833. package/dist/collection/components/radio-group/test/legacy/search/radio-group.e2e.js +27 -27
  834. package/dist/collection/components/radio-group/test/radio-group-events.e2e.js +42 -42
  835. package/dist/collection/components/radio-group/test/radio-group.spec.js +69 -0
  836. package/dist/collection/components/radio-group/test/search/radio-group.e2e.js +23 -23
  837. package/dist/collection/components/range/range.ios.css +44 -6
  838. package/dist/collection/components/range/range.js +1001 -998
  839. package/dist/collection/components/range/range.md.css +44 -6
  840. package/dist/collection/components/range/test/a11y/range.e2e.js +46 -46
  841. package/dist/collection/components/range/test/active-bar-start/range.e2e.js +6 -6
  842. package/dist/collection/components/range/test/basic/range.e2e.js +23 -23
  843. package/dist/collection/components/range/test/color/range.e2e.js +6 -6
  844. package/dist/collection/components/range/test/custom/range.e2e.js +6 -6
  845. package/dist/collection/components/range/test/item/range.e2e.js +28 -28
  846. package/dist/collection/components/range/test/label/range.e2e.js +99 -99
  847. package/dist/collection/components/range/test/label/range.spec.js +23 -0
  848. package/dist/collection/components/range/test/legacy/a11y/range.e2e.js +25 -25
  849. package/dist/collection/components/range/test/legacy/active-bar-start/range.e2e.js +6 -6
  850. package/dist/collection/components/range/test/legacy/basic/range.e2e.js +61 -61
  851. package/dist/collection/components/range/test/legacy/range-events.e2e.js +80 -80
  852. package/dist/collection/components/range/test/legacy/scroll-target/range.e2e.js +23 -23
  853. package/dist/collection/components/range/test/range-events.e2e.js +135 -135
  854. package/dist/collection/components/range/test/range.spec.js +221 -0
  855. package/dist/collection/components/range/test/scroll-target/range.e2e.js +23 -23
  856. package/dist/collection/components/range/test/states/range.e2e.js +21 -21
  857. package/dist/collection/components/refresher/refresher.ios.css +44 -0
  858. package/dist/collection/components/refresher/refresher.js +806 -806
  859. package/dist/collection/components/refresher/refresher.md.css +44 -0
  860. package/dist/collection/components/refresher/refresher.utils.js +148 -148
  861. package/dist/collection/components/refresher/test/basic/refresher.e2e.js +25 -25
  862. package/dist/collection/components/refresher/test/scroll-target/refresher.e2e.js +25 -25
  863. package/dist/collection/components/refresher/test/test.utils.js +5 -5
  864. package/dist/collection/components/refresher-content/refresher-content.js +131 -131
  865. package/dist/collection/components/refresher-content/test/refresher-content.spec.js +46 -0
  866. package/dist/collection/components/reorder/reorder.ios.css +22 -0
  867. package/dist/collection/components/reorder/reorder.js +37 -37
  868. package/dist/collection/components/reorder/reorder.md.css +22 -0
  869. package/dist/collection/components/reorder-group/reorder-group.css +22 -0
  870. package/dist/collection/components/reorder-group/reorder-group.js +327 -327
  871. package/dist/collection/components/reorder-group/test/a11y/reorder-group.e2e.js +6 -6
  872. package/dist/collection/components/reorder-group/test/basic/reorder-group.e2e.js +11 -11
  873. package/dist/collection/components/reorder-group/test/interactive/reorder-group.e2e.js +21 -21
  874. package/dist/collection/components/reorder-group/test/nested/reorder-group.e2e.js +21 -21
  875. package/dist/collection/components/reorder-group/test/scroll-target/reorder-group.e2e.js +21 -21
  876. package/dist/collection/components/ripple-effect/ripple-effect.css +22 -0
  877. package/dist/collection/components/ripple-effect/ripple-effect.js +135 -135
  878. package/dist/collection/components/ripple-effect/test/basic/ripple-effect.e2e.js +48 -48
  879. package/dist/collection/components/route/route.js +151 -151
  880. package/dist/collection/components/route-redirect/route-redirect.js +76 -76
  881. package/dist/collection/components/router/router.js +472 -472
  882. package/dist/collection/components/router/test/basic/router.e2e.js +55 -55
  883. package/dist/collection/components/router/test/guards/href/router.e2e.js +51 -51
  884. package/dist/collection/components/router/test/guards/link/router.e2e.js +51 -51
  885. package/dist/collection/components/router/test/guards/push/router.e2e.js +51 -51
  886. package/dist/collection/components/router/test/guards/router.e2e.js +5 -5
  887. package/dist/collection/components/router/test/guards/test.utils.js +2 -2
  888. package/dist/collection/components/router/test/matching.spec.js +250 -0
  889. package/dist/collection/components/router/test/parser.spec.js +133 -0
  890. package/dist/collection/components/router/test/path.spec.js +218 -0
  891. package/dist/collection/components/router/test/router.spec.js +55 -0
  892. package/dist/collection/components/router/utils/debug.js +14 -14
  893. package/dist/collection/components/router/utils/dom.js +56 -56
  894. package/dist/collection/components/router/utils/matching.js +150 -150
  895. package/dist/collection/components/router/utils/parser.js +52 -52
  896. package/dist/collection/components/router/utils/path.js +66 -66
  897. package/dist/collection/components/router-link/router-link.css +22 -0
  898. package/dist/collection/components/router-link/router-link.js +157 -157
  899. package/dist/collection/components/router-outlet/router-outlet.css +22 -0
  900. package/dist/collection/components/router-outlet/router-outlet.js +459 -459
  901. package/dist/collection/components/router-outlet/test/basic/router-outlet.e2e.js +31 -31
  902. package/dist/collection/components/row/row.css +66 -0
  903. package/dist/collection/components/row/row.js +15 -15
  904. package/dist/collection/components/searchbar/searchbar.ios.css +44 -0
  905. package/dist/collection/components/searchbar/searchbar.js +891 -889
  906. package/dist/collection/components/searchbar/searchbar.md.css +44 -0
  907. package/dist/collection/components/searchbar/test/a11y/searchbar.e2e.js +11 -11
  908. package/dist/collection/components/searchbar/test/basic/searchbar.e2e.js +101 -101
  909. package/dist/collection/components/searchbar/test/events/searchbar.e2e.js +55 -55
  910. package/dist/collection/components/searchbar/test/searchbar.spec.js +15 -0
  911. package/dist/collection/components/segment/segment.ios.css +66 -0
  912. package/dist/collection/components/segment/segment.js +631 -631
  913. package/dist/collection/components/segment/segment.md.css +66 -0
  914. package/dist/collection/components/segment/test/a11y/segment.e2e.js +37 -37
  915. package/dist/collection/components/segment/test/basic/segment.e2e.js +22 -22
  916. package/dist/collection/components/segment/test/custom/segment.e2e.js +6 -6
  917. package/dist/collection/components/segment/test/icon/segment.e2e.js +6 -6
  918. package/dist/collection/components/segment/test/modes/segment.e2e.js +15 -15
  919. package/dist/collection/components/segment/test/scrollable/segment.e2e.js +12 -12
  920. package/dist/collection/components/segment/test/segment-events.e2e.js +97 -97
  921. package/dist/collection/components/segment/test/segment.spec.js +37 -0
  922. package/dist/collection/components/segment/test/toolbar/segment.e2e.js +21 -21
  923. package/dist/collection/components/segment/test/wrap/segment.e2e.js +21 -21
  924. package/dist/collection/components/segment-button/segment-button.ios.css +44 -0
  925. package/dist/collection/components/segment-button/segment-button.js +217 -217
  926. package/dist/collection/components/segment-button/segment-button.md.css +44 -0
  927. package/dist/collection/components/select/select.ios.css +126 -7
  928. package/dist/collection/components/select/select.js +1201 -1184
  929. package/dist/collection/components/select/select.md.css +173 -19
  930. package/dist/collection/components/select/test/a11y/select.e2e.js +14 -14
  931. package/dist/collection/components/select/test/async/select.e2e.js +14 -14
  932. package/dist/collection/components/select/test/basic/select.e2e.js +140 -140
  933. package/dist/collection/components/select/test/card/select.e2e.js +6 -6
  934. package/dist/collection/components/select/test/color/select.e2e.js +22 -22
  935. package/dist/collection/components/select/test/compare-with/select.e2e.js +33 -33
  936. package/dist/collection/components/select/test/custom/select.e2e.js +19 -19
  937. package/dist/collection/components/select/test/disabled/select.e2e.js +17 -17
  938. package/dist/collection/components/select/test/fill/select.e2e.js +63 -63
  939. package/dist/collection/components/select/test/highlight/select.e2e.js +74 -74
  940. package/dist/collection/components/select/test/item/select.e2e.js +26 -11
  941. package/dist/collection/components/select/test/label/select.e2e.js +141 -141
  942. package/dist/collection/components/select/test/legacy/async/select.e2e.js +8 -8
  943. package/dist/collection/components/select/test/legacy/basic/select.e2e.js +108 -108
  944. package/dist/collection/components/select/test/legacy/compare-with/select.e2e.js +33 -33
  945. package/dist/collection/components/select/test/legacy/custom/custom.e2e.js +5 -5
  946. package/dist/collection/components/select/test/legacy/single-value/select.e2e.js +8 -8
  947. package/dist/collection/components/select/test/legacy/spec/select.e2e.js +6 -6
  948. package/dist/collection/components/select/test/legacy/standalone/select.e2e.js +11 -11
  949. package/dist/collection/components/select/test/legacy/wrapping/select.e2e.js +17 -17
  950. package/dist/collection/components/select/test/popover-size/select.e2e.js +63 -63
  951. package/dist/collection/components/select/test/select.spec.js +59 -0
  952. package/dist/collection/components/select/test/slot/select.e2e.js +67 -0
  953. package/dist/collection/components/select/test/states/select.e2e.js +21 -21
  954. package/dist/collection/components/select/test/toggle-icon/select.e2e.js +14 -14
  955. package/dist/collection/components/select/test/wrapping/select.e2e.js +16 -16
  956. package/dist/collection/components/select-option/select-option.js +60 -60
  957. package/dist/collection/components/select-popover/select-popover.ios.css +66 -0
  958. package/dist/collection/components/select-popover/select-popover.js +197 -197
  959. package/dist/collection/components/select-popover/select-popover.md.css +66 -0
  960. package/dist/collection/components/select-popover/test/basic/select-popover.e2e.js +52 -52
  961. package/dist/collection/components/select-popover/test/fixtures.js +33 -33
  962. package/dist/collection/components/skeleton-text/skeleton-text.css +22 -0
  963. package/dist/collection/components/skeleton-text/skeleton-text.js +87 -48
  964. package/dist/collection/components/skeleton-text/test/basic/skeleton-text.e2e.js +6 -6
  965. package/dist/collection/components/skeleton-text/test/custom/skeleton-text.e2e.js +6 -6
  966. package/dist/collection/components/slides/IonicSlides.js +95 -95
  967. package/dist/collection/components/spinner/spinner-configs.js +121 -121
  968. package/dist/collection/components/spinner/spinner.css +22 -0
  969. package/dist/collection/components/spinner/spinner.js +137 -137
  970. package/dist/collection/components/spinner/test/basic/spinner.e2e.js +10 -10
  971. package/dist/collection/components/spinner/test/color/spinner.e2e.js +10 -10
  972. package/dist/collection/components/spinner/test/resize/spinner.e2e.js +8 -8
  973. package/dist/collection/components/split-pane/split-pane.ios.css +67 -2
  974. package/dist/collection/components/split-pane/split-pane.js +225 -225
  975. package/dist/collection/components/split-pane/split-pane.md.css +67 -2
  976. package/dist/collection/components/split-pane/test/basic/split-pane.e2e.js +18 -18
  977. package/dist/collection/components/split-pane/test/multiple/split-pane.e2e.js +23 -23
  978. package/dist/collection/components/tab/tab.js +170 -170
  979. package/dist/collection/components/tab-bar/tab-bar.ios.css +66 -0
  980. package/dist/collection/components/tab-bar/tab-bar.js +177 -177
  981. package/dist/collection/components/tab-bar/tab-bar.md.css +66 -0
  982. package/dist/collection/components/tab-bar/test/basic/tab-bar.e2e.js +8 -8
  983. package/dist/collection/components/tab-bar/test/custom/tab-bar.e2e.js +6 -6
  984. package/dist/collection/components/tab-bar/test/translucent/tab-bar.e2e.js +14 -14
  985. package/dist/collection/components/tab-button/tab-button.ios.css +44 -0
  986. package/dist/collection/components/tab-button/tab-button.js +267 -267
  987. package/dist/collection/components/tab-button/tab-button.md.css +44 -0
  988. package/dist/collection/components/tab-button/test/a11y/tab-button.e2e.js +6 -6
  989. package/dist/collection/components/tab-button/test/basic/tab-button.e2e.js +16 -16
  990. package/dist/collection/components/tab-button/test/layout/tab-button.e2e.js +26 -26
  991. package/dist/collection/components/tab-button/test/states/tab-button.e2e.js +26 -26
  992. package/dist/collection/components/tabs/tabs.css +22 -0
  993. package/dist/collection/components/tabs/tabs.js +344 -344
  994. package/dist/collection/components/tabs/test/basic/tabs.e2e.js +24 -24
  995. package/dist/collection/components/tabs/test/placements/tabs.e2e.js +17 -17
  996. package/dist/collection/components/text/test/basic/text.e2e.js +11 -11
  997. package/dist/collection/components/text/text.css +22 -0
  998. package/dist/collection/components/text/text.js +47 -47
  999. package/dist/collection/components/textarea/test/a11y/textarea.e2e.js +12 -12
  1000. package/dist/collection/components/textarea/test/autogrow/textarea.e2e.js +31 -31
  1001. package/dist/collection/components/textarea/test/bottom-content/textarea.e2e.js +82 -82
  1002. package/dist/collection/components/textarea/test/card/textarea.e2e.js +6 -6
  1003. package/dist/collection/components/textarea/test/clear-on-edit/textarea.e2e.js +53 -17
  1004. package/dist/collection/components/textarea/test/color/textarea.e2e.js +88 -88
  1005. package/dist/collection/components/textarea/test/cols/textarea.e2e.js +11 -11
  1006. package/dist/collection/components/textarea/test/fill/textarea.e2e.js +63 -63
  1007. package/dist/collection/components/textarea/test/highlight/textarea.e2e.js +52 -52
  1008. package/dist/collection/components/textarea/test/item/textarea.e2e.js +11 -11
  1009. package/dist/collection/components/textarea/test/label-placement/textarea.e2e.js +150 -150
  1010. package/dist/collection/components/textarea/test/legacy/a11y/textarea.e2e.js +15 -15
  1011. package/dist/collection/components/textarea/test/legacy/autogrow/textarea.e2e.js +31 -31
  1012. package/dist/collection/components/textarea/test/legacy/basic/textarea.e2e.js +30 -30
  1013. package/dist/collection/components/textarea/test/legacy/clear-on-edit/textarea.e2e.js +17 -17
  1014. package/dist/collection/components/textarea/test/slot/textarea.e2e.js +51 -0
  1015. package/dist/collection/components/textarea/test/states/textarea.e2e.js +11 -11
  1016. package/dist/collection/components/textarea/test/textarea-events.e2e.js +57 -57
  1017. package/dist/collection/components/textarea/test/textarea.spec.js +59 -0
  1018. package/dist/collection/components/textarea/textarea.ios.css +125 -5
  1019. package/dist/collection/components/textarea/textarea.js +1069 -1019
  1020. package/dist/collection/components/textarea/textarea.md.css +179 -14
  1021. package/dist/collection/components/thumbnail/test/basic/thumbnail.e2e.js +28 -28
  1022. package/dist/collection/components/thumbnail/thumbnail.css +22 -0
  1023. package/dist/collection/components/thumbnail/thumbnail.js +15 -15
  1024. package/dist/collection/components/title/test/a11y/title.e2e.js +17 -17
  1025. package/dist/collection/components/title/test/basic/title.e2e.js +13 -13
  1026. package/dist/collection/components/title/title.ios.css +22 -0
  1027. package/dist/collection/components/title/title.js +119 -119
  1028. package/dist/collection/components/title/title.md.css +22 -0
  1029. package/dist/collection/components/toast/animations/ios.enter.js +21 -20
  1030. package/dist/collection/components/toast/animations/ios.leave.js +18 -18
  1031. package/dist/collection/components/toast/animations/md.enter.js +23 -22
  1032. package/dist/collection/components/toast/animations/md.leave.js +6 -6
  1033. package/dist/collection/components/toast/animations/utils.js +62 -56
  1034. package/dist/collection/components/toast/gestures/swipe-to-dismiss.js +267 -0
  1035. package/dist/collection/components/toast/test/a11y/toast.e2e.js +92 -92
  1036. package/dist/collection/components/toast/test/basic/toast.e2e.js +101 -101
  1037. package/dist/collection/components/toast/test/is-open/toast.e2e.js +17 -17
  1038. package/dist/collection/components/toast/test/layout/toast.e2e.js +9 -9
  1039. package/dist/collection/components/toast/test/position-anchor/toast.e2e.js +37 -37
  1040. package/dist/collection/components/toast/test/standalone/toast.e2e.js +10 -10
  1041. package/dist/collection/components/toast/test/swipe-gesture/toast.e2e.js +84 -0
  1042. package/dist/collection/components/toast/test/toast-config.spec.js +25 -0
  1043. package/dist/collection/components/toast/test/toast-id.spec.js +32 -0
  1044. package/dist/collection/components/toast/test/toast.spec.js +200 -0
  1045. package/dist/collection/components/toast/test/trigger/toast.e2e.js +21 -21
  1046. package/dist/collection/components/toast/toast.ios.css +54 -10
  1047. package/dist/collection/components/toast/toast.js +1065 -952
  1048. package/dist/collection/components/toast/toast.md.css +54 -0
  1049. package/dist/collection/components/toggle/test/a11y/toggle.e2e.js +6 -6
  1050. package/dist/collection/components/toggle/test/color/toggle.e2e.js +11 -11
  1051. package/dist/collection/components/toggle/test/enable-on-off-labels/toggle.e2e.js +27 -27
  1052. package/dist/collection/components/toggle/test/item/toggle.e2e.js +52 -52
  1053. package/dist/collection/components/toggle/test/label/toggle.e2e.js +65 -65
  1054. package/dist/collection/components/toggle/test/legacy/basic/toggle.e2e.js +69 -69
  1055. package/dist/collection/components/toggle/test/legacy/enable-on-off-labels/toggle.e2e.js +23 -23
  1056. package/dist/collection/components/toggle/test/legacy/sizes/toggle.e2e.js +6 -6
  1057. package/dist/collection/components/toggle/test/sizes/toggle.e2e.js +6 -6
  1058. package/dist/collection/components/toggle/test/states/toggle.e2e.js +16 -16
  1059. package/dist/collection/components/toggle/test/toggle.spec.js +67 -0
  1060. package/dist/collection/components/toggle/toggle.ios.css +66 -6
  1061. package/dist/collection/components/toggle/toggle.js +487 -484
  1062. package/dist/collection/components/toggle/toggle.md.css +66 -6
  1063. package/dist/collection/components/toolbar/test/basic/toolbar.e2e.js +7 -7
  1064. package/dist/collection/components/toolbar/test/colors/toolbar.e2e.js +6 -6
  1065. package/dist/collection/components/toolbar/toolbar.ios.css +44 -0
  1066. package/dist/collection/components/toolbar/toolbar.js +100 -100
  1067. package/dist/collection/components/toolbar/toolbar.md.css +44 -0
  1068. package/dist/collection/css/test/a11y/typography.e2e.js +6 -6
  1069. package/dist/collection/global/config.js +51 -51
  1070. package/dist/collection/global/ionic-global.js +54 -54
  1071. package/dist/collection/global/test/config-controller.spec.js +77 -0
  1072. package/dist/collection/utils/animation/animation-utils.js +91 -91
  1073. package/dist/collection/utils/animation/animation.js +905 -904
  1074. package/dist/collection/utils/animation/cubic-bezier.js +49 -49
  1075. package/dist/collection/utils/animation/test/animation.spec.js +447 -0
  1076. package/dist/collection/utils/animation/test/animationbuilder/animation.e2e.js +26 -26
  1077. package/dist/collection/utils/animation/test/basic/animation.e2e.js +12 -12
  1078. package/dist/collection/utils/animation/test/display/animation.e2e.js +18 -18
  1079. package/dist/collection/utils/animation/test/hooks/animation.e2e.js +39 -39
  1080. package/dist/collection/utils/animation/test/multiple/animation.e2e.js +27 -27
  1081. package/dist/collection/utils/browser/index.js +0 -22
  1082. package/dist/collection/utils/config.js +20 -20
  1083. package/dist/collection/utils/content/content.utils.spec.js +121 -121
  1084. package/dist/collection/utils/content/index.js +58 -58
  1085. package/dist/collection/utils/floating-point/floating-point.spec.js +14 -14
  1086. package/dist/collection/utils/floating-point/index.js +5 -5
  1087. package/dist/collection/utils/focus-visible.js +63 -63
  1088. package/dist/collection/utils/forms/compare-with-utils.js +39 -0
  1089. package/dist/collection/utils/forms/form-controller.js +45 -45
  1090. package/dist/collection/utils/forms/index.js +1 -0
  1091. package/dist/collection/utils/forms/notch-controller.js +120 -120
  1092. package/dist/collection/utils/framework-delegate.js +121 -121
  1093. package/dist/collection/utils/gesture/button-active.js +56 -56
  1094. package/dist/collection/utils/gesture/gesture-controller.js +182 -182
  1095. package/dist/collection/utils/gesture/index.js +222 -222
  1096. package/dist/collection/utils/gesture/listener.js +36 -36
  1097. package/dist/collection/utils/gesture/pointer-events.js +113 -113
  1098. package/dist/collection/utils/gesture/recognizers.js +46 -46
  1099. package/dist/collection/utils/gesture/swipe-back.js +65 -65
  1100. package/dist/collection/utils/hardware-back-button.js +48 -48
  1101. package/dist/collection/utils/helpers.js +258 -258
  1102. package/dist/collection/utils/helpers.spec.js +28 -28
  1103. package/dist/collection/utils/input-shims/hacks/common.js +61 -61
  1104. package/dist/collection/utils/input-shims/hacks/hide-caret.js +19 -19
  1105. package/dist/collection/utils/input-shims/hacks/input-blurring.js +47 -47
  1106. package/dist/collection/utils/input-shims/hacks/scroll-assist.js +225 -225
  1107. package/dist/collection/utils/input-shims/hacks/scroll-data.js +29 -29
  1108. package/dist/collection/utils/input-shims/hacks/scroll-padding.js +21 -21
  1109. package/dist/collection/utils/input-shims/hacks/test/scroll-assist.e2e.js +97 -97
  1110. package/dist/collection/utils/input-shims/input-shims.js +87 -81
  1111. package/dist/collection/utils/keyboard/keyboard-controller.js +128 -128
  1112. package/dist/collection/utils/keyboard/keyboard.js +59 -59
  1113. package/dist/collection/utils/keyboard/test/keyboard-controller.spec.js +21 -0
  1114. package/dist/collection/utils/keyboard/test/keyboard.spec.js +214 -0
  1115. package/dist/collection/utils/lock-controller.js +24 -24
  1116. package/dist/collection/utils/logging/index.js +3 -3
  1117. package/dist/collection/utils/media.js +13 -13
  1118. package/dist/collection/utils/menu-controller/animations/base.js +8 -8
  1119. package/dist/collection/utils/menu-controller/animations/overlay.js +21 -21
  1120. package/dist/collection/utils/menu-controller/animations/push.js +20 -20
  1121. package/dist/collection/utils/menu-controller/animations/reveal.js +6 -6
  1122. package/dist/collection/utils/menu-controller/index.js +204 -206
  1123. package/dist/collection/utils/native/capacitor.js +4 -4
  1124. package/dist/collection/utils/native/haptic.js +151 -151
  1125. package/dist/collection/utils/native/keyboard.js +47 -47
  1126. package/dist/collection/utils/native/native-interface.js +15 -15
  1127. package/dist/collection/utils/native/status-bar.js +36 -36
  1128. package/dist/collection/utils/overlays.js +495 -494
  1129. package/dist/collection/utils/platform.js +56 -56
  1130. package/dist/collection/utils/rtl/dir.js +5 -5
  1131. package/dist/collection/utils/rtl/dir.spec.js +17 -17
  1132. package/dist/collection/utils/sanitization/index.js +122 -122
  1133. package/dist/collection/utils/sanitization/test/sanitization.spec.js +43 -0
  1134. package/dist/collection/utils/slot-mutation-controller.js +86 -85
  1135. package/dist/collection/utils/status-tap.js +26 -26
  1136. package/dist/collection/utils/tap-click/index.js +171 -171
  1137. package/dist/collection/utils/tap-click/test/tap-click.e2e.js +12 -12
  1138. package/dist/collection/utils/test/aria.spec.js +79 -0
  1139. package/dist/collection/utils/test/attributes.spec.js +53 -0
  1140. package/dist/collection/utils/test/framework-delegate/framework-delegate.e2e.js +25 -25
  1141. package/dist/collection/utils/test/hardware-back-button.spec.js +53 -0
  1142. package/dist/collection/utils/test/overlays/overlays.e2e.js +137 -137
  1143. package/dist/collection/utils/test/overlays/overlays.spec.js +102 -0
  1144. package/dist/collection/utils/test/platform.spec.js +132 -0
  1145. package/dist/collection/utils/test/platform.utils.js +77 -77
  1146. package/dist/collection/utils/test/playwright/drag-element.js +69 -69
  1147. package/dist/collection/utils/test/playwright/generator.js +48 -25
  1148. package/dist/collection/utils/test/playwright/matchers/index.js +3 -3
  1149. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEvent.js +21 -21
  1150. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventDetail.js +28 -28
  1151. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventTimes.js +22 -22
  1152. package/dist/collection/utils/test/playwright/page/event-spy.js +110 -110
  1153. package/dist/collection/utils/test/playwright/page/utils/goto.js +52 -52
  1154. package/dist/collection/utils/test/playwright/page/utils/locator.js +8 -8
  1155. package/dist/collection/utils/test/playwright/page/utils/set-content.js +44 -35
  1156. package/dist/collection/utils/test/playwright/page/utils/set-ion-viewport.js +19 -19
  1157. package/dist/collection/utils/test/playwright/page/utils/spy-on-event.js +4 -4
  1158. package/dist/collection/utils/test/playwright/page/utils/wait-for-changes.js +48 -48
  1159. package/dist/collection/utils/test/playwright/playwright-page.js +35 -35
  1160. package/dist/collection/utils/test/playwright/viewports/index.js +13 -13
  1161. package/dist/collection/utils/test/press-keys.js +77 -77
  1162. package/dist/collection/utils/test/ready.spec.js +39 -0
  1163. package/dist/collection/utils/test/theme.spec.js +56 -0
  1164. package/dist/collection/utils/theme.js +23 -23
  1165. package/dist/collection/utils/transition/index.js +163 -163
  1166. package/dist/collection/utils/transition/ios.transition.js +598 -598
  1167. package/dist/collection/utils/transition/md.transition.js +44 -44
  1168. package/dist/collection/utils/watch-options.js +30 -30
  1169. package/dist/docs.json +195 -38
  1170. package/dist/esm/animation-dde8cc0d.js +1060 -0
  1171. package/dist/esm/{app-globals-2398e405.js → app-globals-8c62bec2.js} +1 -1
  1172. package/dist/esm/button-active-308d3edd.js +67 -0
  1173. package/dist/esm/capacitor-59395cbd.js +13 -0
  1174. package/dist/esm/compare-with-utils-a96ff2ea.js +41 -0
  1175. package/dist/esm/config-49c88215.js +193 -0
  1176. package/dist/esm/cubic-bezier-fe2083dc.js +90 -0
  1177. package/dist/esm/data-775093f5.js +1625 -0
  1178. package/dist/esm/{dir-912e3e13.js → dir-babeabeb.js} +5 -5
  1179. package/dist/esm/focus-visible-dd40d69f.js +75 -0
  1180. package/dist/esm/form-controller-548aa79c.js +64 -0
  1181. package/dist/esm/framework-delegate-bc1fd82a.js +140 -0
  1182. package/dist/esm/gesture-controller-1bf57181.js +195 -0
  1183. package/dist/esm/haptic-554688a5.js +206 -0
  1184. package/dist/esm/hardware-back-button-b2bc76db.js +71 -0
  1185. package/dist/esm/helpers-ae653409.js +418 -0
  1186. package/dist/esm/index-1193f005.js +306 -0
  1187. package/dist/esm/index-2cf77112.js +457 -0
  1188. package/dist/esm/index-4743453d.js +231 -0
  1189. package/dist/esm/index-82eeb47f.js +196 -0
  1190. package/dist/esm/{index-595d62c9.js → index-9b0d46f4.js} +3 -3
  1191. package/dist/esm/index-a5d50daf.js +7 -0
  1192. package/dist/esm/{index-7c9b1bca.js → index-b7d870cf.js} +79 -15
  1193. package/dist/esm/{index-4392efa5.js → index-b9e742e5.js} +60 -60
  1194. package/dist/esm/index.js +113 -113
  1195. package/dist/esm/input-shims-6539ce13.js +599 -0
  1196. package/dist/esm/input.utils-a5a2d164.js +135 -0
  1197. package/dist/esm/ion-accordion_2.entry.js +488 -488
  1198. package/dist/esm/ion-action-sheet.entry.js +260 -250
  1199. package/dist/esm/ion-alert.entry.js +442 -432
  1200. package/dist/esm/ion-app_8.entry.js +1151 -1151
  1201. package/dist/esm/ion-avatar_3.entry.js +29 -29
  1202. package/dist/esm/ion-back-button.entry.js +73 -73
  1203. package/dist/esm/ion-backdrop.entry.js +40 -40
  1204. package/dist/esm/ion-breadcrumb_2.entry.js +194 -194
  1205. package/dist/esm/ion-button_2.entry.js +303 -303
  1206. package/dist/esm/ion-card_5.entry.js +105 -105
  1207. package/dist/esm/ion-checkbox.entry.js +149 -147
  1208. package/dist/esm/ion-chip.entry.js +20 -20
  1209. package/dist/esm/ion-col_3.entry.js +136 -136
  1210. package/dist/esm/ion-datetime-button.entry.js +325 -325
  1211. package/dist/esm/ion-datetime_3.entry.js +2204 -2162
  1212. package/dist/esm/ion-fab_3.entry.js +150 -150
  1213. package/dist/esm/ion-img.entry.js +79 -79
  1214. package/dist/esm/ion-infinite-scroll_2.entry.js +198 -190
  1215. package/dist/esm/ion-input.entry.js +443 -399
  1216. package/dist/esm/ion-item-option_3.entry.js +457 -457
  1217. package/dist/esm/ion-item_8.entry.js +441 -428
  1218. package/dist/esm/ion-loading.entry.js +220 -210
  1219. package/dist/esm/ion-menu_3.entry.js +670 -670
  1220. package/dist/esm/ion-modal.entry.js +1415 -1405
  1221. package/dist/esm/ion-nav_2.entry.js +904 -904
  1222. package/dist/esm/ion-picker-column-internal.entry.js +331 -327
  1223. package/dist/esm/ion-picker-internal.entry.js +453 -453
  1224. package/dist/esm/ion-popover.entry.js +1108 -1098
  1225. package/dist/esm/ion-progress-bar.entry.js +40 -40
  1226. package/dist/esm/ion-radio_2.entry.js +321 -316
  1227. package/dist/esm/ion-range.entry.js +558 -556
  1228. package/dist/esm/ion-refresher_2.entry.js +786 -786
  1229. package/dist/esm/ion-reorder_2.entry.js +267 -267
  1230. package/dist/esm/ion-ripple-effect.entry.js +66 -66
  1231. package/dist/esm/ion-route_4.entry.js +693 -693
  1232. package/dist/esm/ion-searchbar.entry.js +360 -358
  1233. package/dist/esm/ion-segment_2.entry.js +507 -507
  1234. package/dist/esm/ion-select_3.entry.js +784 -768
  1235. package/dist/esm/ion-spinner.entry.js +46 -46
  1236. package/dist/esm/ion-split-pane.entry.js +119 -119
  1237. package/dist/esm/ion-tab-bar_2.entry.js +138 -138
  1238. package/dist/esm/ion-tab_2.entry.js +187 -187
  1239. package/dist/esm/ion-text.entry.js +13 -13
  1240. package/dist/esm/ion-textarea.entry.js +401 -353
  1241. package/dist/esm/ion-toast.entry.js +771 -419
  1242. package/dist/esm/ion-toggle.entry.js +227 -225
  1243. package/dist/esm/ionic-global-1f99b929.js +224 -0
  1244. package/dist/esm/ionic.js +6 -6
  1245. package/dist/esm/ios.transition-3376ccb2.js +651 -0
  1246. package/dist/esm/keyboard-52278bd7.js +146 -0
  1247. package/dist/esm/keyboard-73175e24.js +79 -0
  1248. package/dist/esm/keyboard-controller-ec5c2bfa.js +165 -0
  1249. package/dist/esm/loader.js +5 -5
  1250. package/dist/esm/lock-controller-316928be.js +38 -0
  1251. package/dist/esm/md.transition-f992779f.js +57 -0
  1252. package/dist/esm/notch-controller-fea7f9c5.js +153 -0
  1253. package/dist/esm/overlays-b33f6bca.js +693 -0
  1254. package/dist/esm/spinner-configs-964f7cf3.js +145 -0
  1255. package/dist/esm/status-tap-16fd8f3d.js +40 -0
  1256. package/dist/esm/swipe-back-18cb49f7.js +79 -0
  1257. package/dist/esm/theme-01f3f29c.js +43 -0
  1258. package/dist/esm/watch-options-c2911ace.js +47 -0
  1259. package/dist/esm-es5/{animation-8aa13916.js → animation-dde8cc0d.js} +1 -1
  1260. package/dist/esm-es5/app-globals-8c62bec2.js +4 -0
  1261. package/dist/esm-es5/{button-active-ce5cba4c.js → button-active-308d3edd.js} +1 -1
  1262. package/dist/esm-es5/{capacitor-b4979570.js → capacitor-59395cbd.js} +1 -1
  1263. package/dist/esm-es5/compare-with-utils-a96ff2ea.js +4 -0
  1264. package/dist/esm-es5/data-775093f5.js +4 -0
  1265. package/dist/esm-es5/{form-controller-64edeaad.js → form-controller-548aa79c.js} +1 -1
  1266. package/dist/esm-es5/{framework-delegate-aa433dea.js → framework-delegate-bc1fd82a.js} +1 -1
  1267. package/dist/esm-es5/{haptic-1243b917.js → haptic-554688a5.js} +1 -1
  1268. package/dist/esm-es5/index-1193f005.js +4 -0
  1269. package/dist/esm-es5/{index-ff313b19.js → index-2cf77112.js} +1 -1
  1270. package/dist/esm-es5/{index-6a0ccabb.js → index-4743453d.js} +1 -1
  1271. package/dist/esm-es5/{index-f0cc4e14.js → index-82eeb47f.js} +1 -1
  1272. package/dist/esm-es5/index-b7d870cf.js +5 -0
  1273. package/dist/esm-es5/{index-4392efa5.js → index-b9e742e5.js} +1 -1
  1274. package/dist/esm-es5/index.js +1 -1
  1275. package/dist/esm-es5/input-shims-6539ce13.js +4 -0
  1276. package/dist/esm-es5/input.utils-a5a2d164.js +4 -0
  1277. package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
  1278. package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
  1279. package/dist/esm-es5/ion-alert.entry.js +1 -1
  1280. package/dist/esm-es5/ion-app_8.entry.js +1 -1
  1281. package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
  1282. package/dist/esm-es5/ion-back-button.entry.js +1 -1
  1283. package/dist/esm-es5/ion-backdrop.entry.js +1 -1
  1284. package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
  1285. package/dist/esm-es5/ion-button_2.entry.js +1 -1
  1286. package/dist/esm-es5/ion-card_5.entry.js +1 -1
  1287. package/dist/esm-es5/ion-checkbox.entry.js +1 -1
  1288. package/dist/esm-es5/ion-chip.entry.js +1 -1
  1289. package/dist/esm-es5/ion-col_3.entry.js +1 -1
  1290. package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
  1291. package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
  1292. package/dist/esm-es5/ion-fab_3.entry.js +1 -1
  1293. package/dist/esm-es5/ion-img.entry.js +1 -1
  1294. package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
  1295. package/dist/esm-es5/ion-input.entry.js +1 -1
  1296. package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
  1297. package/dist/esm-es5/ion-item_8.entry.js +1 -1
  1298. package/dist/esm-es5/ion-loading.entry.js +1 -1
  1299. package/dist/esm-es5/ion-menu_3.entry.js +1 -1
  1300. package/dist/esm-es5/ion-modal.entry.js +1 -1
  1301. package/dist/esm-es5/ion-nav_2.entry.js +1 -1
  1302. package/dist/esm-es5/ion-picker-column-internal.entry.js +1 -1
  1303. package/dist/esm-es5/ion-picker-internal.entry.js +1 -1
  1304. package/dist/esm-es5/ion-popover.entry.js +1 -1
  1305. package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
  1306. package/dist/esm-es5/ion-radio_2.entry.js +1 -1
  1307. package/dist/esm-es5/ion-range.entry.js +1 -1
  1308. package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
  1309. package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
  1310. package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
  1311. package/dist/esm-es5/ion-route_4.entry.js +1 -1
  1312. package/dist/esm-es5/ion-searchbar.entry.js +1 -1
  1313. package/dist/esm-es5/ion-segment_2.entry.js +1 -1
  1314. package/dist/esm-es5/ion-select_3.entry.js +1 -1
  1315. package/dist/esm-es5/ion-spinner.entry.js +1 -1
  1316. package/dist/esm-es5/ion-split-pane.entry.js +1 -1
  1317. package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
  1318. package/dist/esm-es5/ion-tab_2.entry.js +1 -1
  1319. package/dist/esm-es5/ion-text.entry.js +1 -1
  1320. package/dist/esm-es5/ion-textarea.entry.js +1 -1
  1321. package/dist/esm-es5/ion-toast.entry.js +1 -1
  1322. package/dist/esm-es5/ion-toggle.entry.js +1 -1
  1323. package/dist/esm-es5/{ionic-global-40e42e7f.js → ionic-global-1f99b929.js} +1 -1
  1324. package/dist/esm-es5/ionic.js +1 -1
  1325. package/dist/esm-es5/{ios.transition-1651c430.js → ios.transition-3376ccb2.js} +1 -1
  1326. package/dist/esm-es5/{keyboard-b551279d.js → keyboard-52278bd7.js} +1 -1
  1327. package/dist/esm-es5/{keyboard-b063f012.js → keyboard-73175e24.js} +1 -1
  1328. package/dist/esm-es5/{keyboard-controller-0c2dce71.js → keyboard-controller-ec5c2bfa.js} +1 -1
  1329. package/dist/esm-es5/loader.js +1 -1
  1330. package/dist/esm-es5/md.transition-f992779f.js +4 -0
  1331. package/dist/esm-es5/{notch-controller-8c9c0e54.js → notch-controller-fea7f9c5.js} +1 -1
  1332. package/dist/esm-es5/{overlays-6c9feb7e.js → overlays-b33f6bca.js} +1 -1
  1333. package/dist/esm-es5/{status-tap-9ce68758.js → status-tap-16fd8f3d.js} +1 -1
  1334. package/dist/esm-es5/{swipe-back-cd4295f3.js → swipe-back-18cb49f7.js} +1 -1
  1335. package/dist/html.html-data.json +16 -3
  1336. package/dist/ionic/index.esm.js +1 -1
  1337. package/dist/ionic/ionic.esm.js +1 -1
  1338. package/dist/ionic/ionic.js +15 -15
  1339. package/dist/ionic/p-013013a3.js +4 -0
  1340. package/dist/ionic/p-0235067a.js +4 -0
  1341. package/dist/ionic/{p-a0b6d438.js → p-04377cfa.js} +1 -1
  1342. package/dist/ionic/p-043aa6cc.system.entry.js +4 -0
  1343. package/dist/ionic/{p-5d711127.js → p-0509fd34.js} +1 -1
  1344. package/dist/ionic/p-0550f802.entry.js +4 -0
  1345. package/dist/ionic/p-06abe918.system.entry.js +4 -0
  1346. package/dist/ionic/{p-702d85d8.system.js → p-0aa78a8d.system.js} +1 -1
  1347. package/dist/ionic/{p-41477ad9.system.js → p-0bd51c34.system.js} +1 -1
  1348. package/dist/ionic/p-0dfa4ab4.system.entry.js +4 -0
  1349. package/dist/ionic/p-0ebc87b7.system.entry.js +4 -0
  1350. package/dist/ionic/{p-bed722c4.system.entry.js → p-10ec9af7.system.entry.js} +1 -1
  1351. package/dist/ionic/{p-f4cc91f6.entry.js → p-11786dc7.entry.js} +1 -1
  1352. package/dist/ionic/{p-0dc0d9b5.entry.js → p-11a3973f.entry.js} +1 -1
  1353. package/dist/ionic/{p-a545b4f1.system.js → p-1501b945.system.js} +1 -1
  1354. package/dist/ionic/{p-4e6a1efb.system.entry.js → p-158efe8d.system.entry.js} +1 -1
  1355. package/dist/ionic/p-164aa69c.entry.js +4 -0
  1356. package/dist/ionic/p-17d283b9.system.entry.js +4 -0
  1357. package/dist/ionic/p-18cae04f.js +4 -0
  1358. package/dist/ionic/{p-abacb44b.system.entry.js → p-19c379da.system.entry.js} +1 -1
  1359. package/dist/ionic/p-19d9ceb8.system.js +4 -0
  1360. package/dist/ionic/p-1b27ac67.entry.js +4 -0
  1361. package/dist/ionic/{p-b91fe549.entry.js → p-1c249831.entry.js} +1 -1
  1362. package/dist/ionic/{p-b4b4bb29.system.js → p-1cca10d6.system.js} +1 -1
  1363. package/dist/ionic/p-1e4371bd.js +4 -0
  1364. package/dist/ionic/{p-c7b8c2ef.system.entry.js → p-20e0e75d.system.entry.js} +1 -1
  1365. package/dist/ionic/{p-34d2de14.system.entry.js → p-22827063.system.entry.js} +1 -1
  1366. package/dist/ionic/{p-64ed03a3.entry.js → p-26c4bf85.entry.js} +1 -1
  1367. package/dist/ionic/{p-419eb426.js → p-27281edd.js} +1 -1
  1368. package/dist/ionic/{p-965677f1.entry.js → p-2894d5f6.entry.js} +1 -1
  1369. package/dist/ionic/p-290d3fe9.js +5 -0
  1370. package/dist/ionic/p-29d03b3a.js +4 -0
  1371. package/dist/ionic/p-2a583966.entry.js +4 -0
  1372. package/dist/ionic/p-2b7827c7.js +4 -0
  1373. package/dist/ionic/{p-3d7fea9b.system.entry.js → p-2ba9a9bd.system.entry.js} +1 -1
  1374. package/dist/ionic/p-2cf21a15.system.entry.js +4 -0
  1375. package/dist/ionic/p-2df97906.system.entry.js +4 -0
  1376. package/dist/ionic/{p-fa8d4788.system.js → p-31b2326e.system.js} +1 -1
  1377. package/dist/ionic/{p-744973f3.entry.js → p-3313c481.entry.js} +1 -1
  1378. package/dist/ionic/{p-ffb876b0.system.entry.js → p-332ea4d3.system.entry.js} +1 -1
  1379. package/dist/ionic/{p-97e31c0a.system.js → p-3671f1b9.system.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-38531958.system.entry.js +4 -0
  1383. package/dist/ionic/{p-55ed230e.system.js → p-38c337e7.system.js} +1 -1
  1384. package/dist/ionic/p-38f2c6bb.system.js +4 -0
  1385. package/dist/ionic/{p-3bad5c1a.js → p-3a75d7fd.js} +1 -1
  1386. package/dist/ionic/{p-8b29691f.entry.js → p-3dfc522b.entry.js} +1 -1
  1387. package/dist/ionic/{p-3de79805.entry.js → p-3e8d5e53.entry.js} +1 -1
  1388. package/dist/ionic/p-40f68333.system.js +4 -0
  1389. package/dist/ionic/{p-a6d83a03.system.entry.js → p-41208f54.system.entry.js} +1 -1
  1390. package/dist/ionic/{p-b287ab05.js → p-4180a747.js} +1 -1
  1391. package/dist/ionic/{p-b923f3d7.js → p-42f189f4.js} +1 -1
  1392. package/dist/ionic/{p-d7ea6a0d.system.entry.js → p-4489dd20.system.entry.js} +1 -1
  1393. package/dist/ionic/p-44a56556.js +4 -0
  1394. package/dist/ionic/{p-e76a4bc8.entry.js → p-44dc52e5.entry.js} +1 -1
  1395. package/dist/ionic/{p-f5a750e4.system.entry.js → p-4685218a.system.entry.js} +1 -1
  1396. package/dist/ionic/p-469dd571.system.entry.js +4 -0
  1397. package/dist/ionic/{p-5bd4e009.entry.js → p-47bb15a1.entry.js} +1 -1
  1398. package/dist/ionic/{p-664d2b07.system.entry.js → p-4981ea0a.system.entry.js} +1 -1
  1399. package/dist/ionic/{p-cf425ec5.system.entry.js → p-507ddbfe.system.entry.js} +1 -1
  1400. package/dist/ionic/{p-14aca3fb.entry.js → p-529b24fb.entry.js} +1 -1
  1401. package/dist/ionic/p-52cfafe9.system.js +5 -0
  1402. package/dist/ionic/p-53ec4f1c.system.js +4 -0
  1403. package/dist/ionic/{p-c0c81820.system.js → p-5ad1fe3b.system.js} +1 -1
  1404. package/dist/ionic/{p-7cee75c0.entry.js → p-60959b71.entry.js} +1 -1
  1405. package/dist/ionic/p-61e4d3ec.entry.js +4 -0
  1406. package/dist/ionic/{p-1cb5f2f8.system.entry.js → p-648ad047.system.entry.js} +1 -1
  1407. package/dist/ionic/p-66d633fb.js +4 -0
  1408. package/dist/ionic/{p-63f08fe3.entry.js → p-6855f26a.entry.js} +1 -1
  1409. package/dist/ionic/{p-1a8ae7a7.system.entry.js → p-69641343.system.entry.js} +1 -1
  1410. package/dist/ionic/{p-800ef057.js → p-6ab03751.js} +1 -1
  1411. package/dist/ionic/{p-18e01b30.system.entry.js → p-6c277fa2.system.entry.js} +1 -1
  1412. package/dist/ionic/{p-0e23256e.system.entry.js → p-6e0539ea.system.entry.js} +1 -1
  1413. package/dist/ionic/p-6fba0ce1.system.entry.js +4 -0
  1414. package/dist/ionic/{p-4c80afe1.system.entry.js → p-745e3339.system.entry.js} +1 -1
  1415. package/dist/ionic/p-767f1a92.entry.js +4 -0
  1416. package/dist/ionic/{p-8a308596.system.js → p-7798c78a.system.js} +2 -2
  1417. package/dist/ionic/p-7dc892f8.entry.js +4 -0
  1418. package/dist/ionic/{p-6c3d5383.js → p-7fae5c36.js} +1 -1
  1419. package/dist/ionic/{p-48d9faa7.entry.js → p-803efb5d.entry.js} +1 -1
  1420. package/dist/ionic/{p-a8e68fd9.entry.js → p-806a9810.entry.js} +1 -1
  1421. package/dist/ionic/p-84b567a6.entry.js +4 -0
  1422. package/dist/ionic/p-85f48531.entry.js +4 -0
  1423. package/dist/ionic/p-87bb3735.system.js +4 -0
  1424. package/dist/ionic/{p-613d4042.system.js → p-888db766.system.js} +1 -1
  1425. package/dist/ionic/p-88d5fbd3.js +4 -0
  1426. package/dist/ionic/{p-ccdcb022.system.js → p-8985cdb6.system.js} +1 -1
  1427. package/dist/ionic/p-8aa1d0b7.system.js +4 -0
  1428. package/dist/ionic/{p-a9c3699b.system.entry.js → p-8f301ac5.system.entry.js} +1 -1
  1429. package/dist/ionic/{p-174f3446.entry.js → p-928ee57a.entry.js} +1 -1
  1430. package/dist/ionic/p-932f2259.system.entry.js +4 -0
  1431. package/dist/ionic/p-93390f78.entry.js +4 -0
  1432. package/dist/ionic/p-950c05ad.entry.js +4 -0
  1433. package/dist/ionic/{p-3fb57e1b.system.entry.js → p-96d4814f.system.entry.js} +1 -1
  1434. package/dist/ionic/p-97174c1e.js +4 -0
  1435. package/dist/ionic/p-979d4f5c.system.js +4 -0
  1436. package/dist/ionic/p-98f35d98.js +4 -0
  1437. package/dist/ionic/{p-14b4348c.system.js → p-9a68d8ef.system.js} +1 -1
  1438. package/dist/ionic/p-9ba72fdb.system.entry.js +4 -0
  1439. package/dist/ionic/{p-41122cd6.system.js → p-9f94c72e.system.js} +1 -1
  1440. package/dist/ionic/{p-92800752.entry.js → p-9fb45814.entry.js} +1 -1
  1441. package/dist/ionic/p-9fda6824.system.entry.js +4 -0
  1442. package/dist/ionic/{p-1dc91702.entry.js → p-a06501e3.entry.js} +1 -1
  1443. package/dist/ionic/{p-c4042875.system.js → p-a074be82.system.js} +1 -1
  1444. package/dist/ionic/{p-c7d30db9.entry.js → p-a3013394.entry.js} +1 -1
  1445. package/dist/ionic/p-a42ef163.system.entry.js +4 -0
  1446. package/dist/ionic/p-a49931aa.system.js +4 -0
  1447. package/dist/ionic/{p-db5043df.system.entry.js → p-a821750c.system.entry.js} +1 -1
  1448. package/dist/ionic/{p-1d269117.system.entry.js → p-abd5d0d5.system.entry.js} +1 -1
  1449. package/dist/ionic/{p-9209d90c.entry.js → p-ade3cf46.entry.js} +1 -1
  1450. package/dist/ionic/{p-1e86a71b.entry.js → p-ae4b7df8.entry.js} +1 -1
  1451. package/dist/ionic/p-aee39e06.entry.js +4 -0
  1452. package/dist/ionic/{p-09d142b3.system.js → p-afa9f205.system.js} +1 -1
  1453. package/dist/ionic/{p-67e18f02.system.entry.js → p-b7058a0e.system.entry.js} +1 -1
  1454. package/dist/ionic/p-b78e6a44.entry.js +4 -0
  1455. package/dist/ionic/{p-beb64be7.system.entry.js → p-b7a2ffc9.system.entry.js} +1 -1
  1456. package/dist/ionic/{p-0330f0a3.system.entry.js → p-b8a9e195.system.entry.js} +1 -1
  1457. package/dist/ionic/{p-8ad82eb3.entry.js → p-b964aba3.entry.js} +1 -1
  1458. package/dist/ionic/{p-ff5144f3.system.entry.js → p-beeed22c.system.entry.js} +1 -1
  1459. package/dist/ionic/{p-5deff017.entry.js → p-c08fe2c0.entry.js} +1 -1
  1460. package/dist/ionic/p-c1701827.entry.js +4 -0
  1461. package/dist/ionic/{p-b2a74a72.entry.js → p-c5acfeb1.entry.js} +1 -1
  1462. package/dist/ionic/p-c61cc894.js +4 -0
  1463. package/dist/ionic/{p-ab4cff27.system.js → p-cabad15b.system.js} +1 -1
  1464. package/dist/ionic/{p-07d9e9cd.system.entry.js → p-cb8dff22.system.entry.js} +1 -1
  1465. package/dist/ionic/p-cd1b920b.entry.js +4 -0
  1466. package/dist/ionic/p-cd574dfa.js +4 -0
  1467. package/dist/ionic/{p-0492946a.entry.js → p-cf235986.entry.js} +1 -1
  1468. package/dist/ionic/p-cf53213c.entry.js +4 -0
  1469. package/dist/ionic/p-d51674c5.system.js +4 -0
  1470. package/dist/ionic/{p-45da1e68.system.entry.js → p-d93eed83.system.entry.js} +1 -1
  1471. package/dist/ionic/{p-c919498d.entry.js → p-da5e2652.entry.js} +1 -1
  1472. package/dist/ionic/p-dc6d8647.entry.js +4 -0
  1473. package/dist/ionic/p-dc71e4ef.system.entry.js +4 -0
  1474. package/dist/ionic/{p-bba2ce59.system.js → p-ddbb2d5b.system.js} +1 -1
  1475. package/dist/ionic/{p-6e23777e.system.entry.js → p-ddd48faf.system.entry.js} +1 -1
  1476. package/dist/ionic/p-de6f8b28.system.js +4 -0
  1477. package/dist/ionic/p-de756e5c.js +4 -0
  1478. package/dist/ionic/{p-7ab6fc5a.system.entry.js → p-e2903cdc.system.entry.js} +1 -1
  1479. package/dist/ionic/{p-0a794e83.entry.js → p-e33d1ebc.entry.js} +1 -1
  1480. package/dist/ionic/p-ebe8bd8a.entry.js +4 -0
  1481. package/dist/ionic/p-eef72e06.js +4 -0
  1482. package/dist/ionic/{p-5da0eb3e.system.entry.js → p-f0504446.system.entry.js} +1 -1
  1483. package/dist/ionic/p-f434bcf3.system.entry.js +4 -0
  1484. package/dist/ionic/p-f5d2dc9b.js +4 -0
  1485. package/dist/ionic/{p-a936d224.system.js → p-f6e9c227.system.js} +1 -1
  1486. package/dist/ionic/p-f894e0ad.entry.js +4 -0
  1487. package/dist/types/components/accordion/accordion.d.ts +62 -62
  1488. package/dist/types/components/accordion-group/accordion-group-interface.d.ts +3 -3
  1489. package/dist/types/components/accordion-group/accordion-group.d.ts +76 -76
  1490. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +25 -25
  1491. package/dist/types/components/action-sheet/action-sheet.d.ts +149 -149
  1492. package/dist/types/components/action-sheet/test/basic/fixture.d.ts +7 -7
  1493. package/dist/types/components/alert/alert-interface.d.ts +45 -45
  1494. package/dist/types/components/alert/alert.d.ts +181 -181
  1495. package/dist/types/components/app/app.d.ts +15 -15
  1496. package/dist/types/components/avatar/avatar.d.ts +1 -1
  1497. package/dist/types/components/back-button/back-button.d.ts +41 -41
  1498. package/dist/types/components/backdrop/backdrop.d.ts +22 -22
  1499. package/dist/types/components/badge/badge.d.ts +7 -7
  1500. package/dist/types/components/breadcrumb/breadcrumb-interface.d.ts +4 -4
  1501. package/dist/types/components/breadcrumb/breadcrumb.d.ts +87 -87
  1502. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +39 -39
  1503. package/dist/types/components/button/button.d.ts +121 -121
  1504. package/dist/types/components/buttons/buttons.d.ts +14 -14
  1505. package/dist/types/components/card/card.d.ts +57 -57
  1506. package/dist/types/components/card-content/card-content.d.ts +1 -1
  1507. package/dist/types/components/card-header/card-header.d.ts +13 -13
  1508. package/dist/types/components/card-subtitle/card-subtitle.d.ts +7 -7
  1509. package/dist/types/components/card-title/card-title.d.ts +7 -7
  1510. package/dist/types/components/checkbox/checkbox-interface.d.ts +4 -4
  1511. package/dist/types/components/checkbox/checkbox.d.ts +112 -111
  1512. package/dist/types/components/chip/chip.d.ts +15 -15
  1513. package/dist/types/components/col/col.d.ts +128 -128
  1514. package/dist/types/components/content/content-interface.d.ts +6 -6
  1515. package/dist/types/components/content/content.d.ts +129 -129
  1516. package/dist/types/components/datetime/datetime-interface.d.ts +15 -15
  1517. package/dist/types/components/datetime/datetime.d.ts +407 -407
  1518. package/dist/types/components/datetime/utils/data.d.ts +11 -11
  1519. package/dist/types/components/datetime/utils/manipulation.d.ts +59 -32
  1520. package/dist/types/components/datetime/utils/state.d.ts +8 -8
  1521. package/dist/types/components/datetime-button/datetime-button.d.ts +59 -59
  1522. package/dist/types/components/fab/fab.d.ts +33 -33
  1523. package/dist/types/components/fab-button/fab-button.d.ts +88 -88
  1524. package/dist/types/components/fab-list/fab-list.d.ts +11 -11
  1525. package/dist/types/components/footer/footer.d.ts +27 -27
  1526. package/dist/types/components/grid/grid.d.ts +5 -5
  1527. package/dist/types/components/header/header.d.ts +31 -31
  1528. package/dist/types/components/header/header.utils.d.ts +7 -7
  1529. package/dist/types/components/img/img.d.ts +30 -30
  1530. package/dist/types/components/infinite-scroll/infinite-scroll-interface.d.ts +1 -1
  1531. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +65 -58
  1532. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +23 -23
  1533. package/dist/types/components/input/input-interface.d.ts +6 -6
  1534. package/dist/types/components/input/input.d.ts +321 -315
  1535. package/dist/types/components/item/item.d.ts +111 -111
  1536. package/dist/types/components/item-divider/item-divider.d.ts +16 -16
  1537. package/dist/types/components/item-group/item-group.d.ts +1 -1
  1538. package/dist/types/components/item-option/item-option.d.ts +44 -44
  1539. package/dist/types/components/item-options/item-options.d.ts +13 -13
  1540. package/dist/types/components/item-sliding/item-sliding-interface.d.ts +1 -1
  1541. package/dist/types/components/item-sliding/item-sliding.d.ts +75 -75
  1542. package/dist/types/components/label/label.d.ts +30 -30
  1543. package/dist/types/components/list/list.d.ts +17 -17
  1544. package/dist/types/components/list-header/list-header.d.ts +11 -11
  1545. package/dist/types/components/loading/loading-interface.d.ts +16 -16
  1546. package/dist/types/components/loading/loading.d.ts +152 -152
  1547. package/dist/types/components/menu/menu-interface.d.ts +39 -39
  1548. package/dist/types/components/menu/menu.d.ts +140 -140
  1549. package/dist/types/components/menu-button/menu-button.d.ts +30 -30
  1550. package/dist/types/components/menu-toggle/menu-toggle.d.ts +21 -21
  1551. package/dist/types/components/modal/animations/sheet.d.ts +4 -4
  1552. package/dist/types/components/modal/gestures/sheet.d.ts +30 -30
  1553. package/dist/types/components/modal/gestures/swipe-to-close.d.ts +1 -1
  1554. package/dist/types/components/modal/modal-interface.d.ts +27 -27
  1555. package/dist/types/components/modal/modal.d.ts +265 -265
  1556. package/dist/types/components/modal/test/fixtures.d.ts +7 -7
  1557. package/dist/types/components/nav/nav-interface.d.ts +40 -40
  1558. package/dist/types/components/nav/nav.d.ts +247 -247
  1559. package/dist/types/components/nav/view-controller.d.ts +13 -13
  1560. package/dist/types/components/nav-link/nav-link.d.ts +19 -19
  1561. package/dist/types/components/note/note.d.ts +7 -7
  1562. package/dist/types/components/picker/picker-interface.d.ts +43 -43
  1563. package/dist/types/components/picker/picker.d.ts +149 -149
  1564. package/dist/types/components/picker-column/picker-column.d.ts +39 -39
  1565. package/dist/types/components/picker-column-internal/picker-column-internal-interfaces.d.ts +3 -3
  1566. package/dist/types/components/picker-column-internal/picker-column-internal.d.ts +93 -89
  1567. package/dist/types/components/picker-internal/picker-internal-interfaces.d.ts +4 -4
  1568. package/dist/types/components/picker-internal/picker-internal.d.ts +94 -94
  1569. package/dist/types/components/popover/popover-interface.d.ts +26 -26
  1570. package/dist/types/components/popover/popover.d.ts +279 -279
  1571. package/dist/types/components/popover/test/fixture.d.ts +5 -5
  1572. package/dist/types/components/popover/utils.d.ts +25 -25
  1573. package/dist/types/components/progress-bar/progress-bar.d.ts +27 -27
  1574. package/dist/types/components/radio/radio.d.ts +100 -99
  1575. package/dist/types/components/radio-group/radio-group-interface.d.ts +5 -4
  1576. package/dist/types/components/radio-group/radio-group.d.ts +51 -44
  1577. package/dist/types/components/radio-group/test/fixtures.d.ts +5 -5
  1578. package/dist/types/components/range/range-interface.d.ts +7 -7
  1579. package/dist/types/components/range/range.d.ts +193 -192
  1580. package/dist/types/components/refresher/refresher-interface.d.ts +3 -3
  1581. package/dist/types/components/refresher/refresher.d.ts +132 -132
  1582. package/dist/types/components/refresher-content/refresher-content.d.ts +44 -44
  1583. package/dist/types/components/reorder/reorder.d.ts +3 -3
  1584. package/dist/types/components/reorder-group/reorder-group-interface.d.ts +5 -5
  1585. package/dist/types/components/reorder-group/reorder-group.d.ts +53 -53
  1586. package/dist/types/components/ripple-effect/ripple-effect.d.ts +20 -20
  1587. package/dist/types/components/route/route-interface.d.ts +1 -1
  1588. package/dist/types/components/route/route.d.ts +43 -43
  1589. package/dist/types/components/route-redirect/route-redirect.d.ts +33 -33
  1590. package/dist/types/components/router/router.d.ts +74 -73
  1591. package/dist/types/components/router/utils/dom.d.ts +2 -2
  1592. package/dist/types/components/router/utils/interface.d.ts +31 -31
  1593. package/dist/types/components/router/utils/matching.d.ts +6 -6
  1594. package/dist/types/components/router-link/router-link.d.ts +34 -34
  1595. package/dist/types/components/router-outlet/router-outlet.d.ts +41 -41
  1596. package/dist/types/components/row/row.d.ts +1 -1
  1597. package/dist/types/components/searchbar/searchbar-interface.d.ts +6 -6
  1598. package/dist/types/components/searchbar/searchbar.d.ts +235 -233
  1599. package/dist/types/components/segment/segment-interface.d.ts +3 -3
  1600. package/dist/types/components/segment/segment.d.ts +82 -82
  1601. package/dist/types/components/segment-button/segment-button.d.ts +36 -36
  1602. package/dist/types/components/select/select-interface.d.ts +3 -3
  1603. package/dist/types/components/select/select.d.ts +238 -233
  1604. package/dist/types/components/select-option/select-option.d.ts +11 -11
  1605. package/dist/types/components/select-popover/select-popover-interface.d.ts +8 -8
  1606. package/dist/types/components/select-popover/select-popover.d.ts +39 -39
  1607. package/dist/types/components/select-popover/test/fixtures.d.ts +12 -12
  1608. package/dist/types/components/skeleton-text/skeleton-text.d.ts +15 -7
  1609. package/dist/types/components/spinner/spinner-configs.d.ts +96 -96
  1610. package/dist/types/components/spinner/spinner-interface.d.ts +14 -14
  1611. package/dist/types/components/spinner/spinner.d.ts +21 -21
  1612. package/dist/types/components/split-pane/split-pane.d.ts +33 -33
  1613. package/dist/types/components/tab/tab.d.ts +21 -21
  1614. package/dist/types/components/tab-bar/tab-bar-interface.d.ts +4 -4
  1615. package/dist/types/components/tab-bar/tab-bar.d.ts +34 -34
  1616. package/dist/types/components/tab-button/tab-button.d.ts +56 -56
  1617. package/dist/types/components/tabs/tabs-interface.d.ts +4 -4
  1618. package/dist/types/components/tabs/tabs.d.ts +52 -52
  1619. package/dist/types/components/text/text.d.ts +7 -7
  1620. package/dist/types/components/textarea/textarea-interface.d.ts +6 -6
  1621. package/dist/types/components/textarea/textarea.d.ts +275 -269
  1622. package/dist/types/components/thumbnail/thumbnail.d.ts +1 -1
  1623. package/dist/types/components/title/title.d.ts +21 -21
  1624. package/dist/types/components/toast/animations/utils.d.ts +15 -4
  1625. package/dist/types/components/toast/gestures/swipe-to-dismiss.d.ts +9 -0
  1626. package/dist/types/components/toast/toast-interface.d.ts +37 -35
  1627. package/dist/types/components/toast/toast.d.ts +241 -214
  1628. package/dist/types/components/toggle/toggle-interface.d.ts +4 -4
  1629. package/dist/types/components/toggle/toggle.d.ts +117 -116
  1630. package/dist/types/components/toolbar/toolbar.d.ts +11 -11
  1631. package/dist/types/components.d.ts +52 -13
  1632. package/dist/types/global/config.d.ts +6 -6
  1633. package/dist/types/interface.d.ts +1 -5
  1634. package/dist/types/jest.d.ts +5 -0
  1635. package/dist/types/stencil-public-runtime.d.ts +8 -0
  1636. package/dist/types/utils/animation/animation-interface.d.ts +205 -205
  1637. package/dist/types/utils/browser/index.d.ts +17 -8
  1638. package/dist/types/utils/config.d.ts +175 -175
  1639. package/dist/types/utils/element-interface.d.ts +6 -6
  1640. package/dist/types/utils/focus-visible.d.ts +2 -2
  1641. package/dist/types/utils/forms/compare-with-utils.d.ts +18 -0
  1642. package/dist/types/utils/forms/form-controller.d.ts +3 -3
  1643. package/dist/types/utils/forms/index.d.ts +1 -0
  1644. package/dist/types/utils/forms/notch-controller.d.ts +2 -2
  1645. package/dist/types/utils/framework-delegate.d.ts +3 -3
  1646. package/dist/types/utils/gesture/gesture-controller.d.ts +49 -49
  1647. package/dist/types/utils/gesture/index.d.ts +31 -31
  1648. package/dist/types/utils/gesture/listener.d.ts +2 -2
  1649. package/dist/types/utils/gesture/pointer-events.d.ts +12 -12
  1650. package/dist/types/utils/gesture/recognizers.d.ts +4 -4
  1651. package/dist/types/utils/hardware-back-button.d.ts +4 -0
  1652. package/dist/types/utils/helpers.d.ts +8 -8
  1653. package/dist/types/utils/input-shims/hacks/scroll-data.d.ts +4 -4
  1654. package/dist/types/utils/keyboard/keyboard-controller.d.ts +3 -3
  1655. package/dist/types/utils/lock-controller.d.ts +1 -1
  1656. package/dist/types/utils/native/haptic.d.ts +38 -38
  1657. package/dist/types/utils/native/keyboard.d.ts +29 -29
  1658. package/dist/types/utils/native/native-interface.d.ts +15 -15
  1659. package/dist/types/utils/native/status-bar.d.ts +8 -8
  1660. package/dist/types/utils/overlays-interface.d.ts +27 -27
  1661. package/dist/types/utils/overlays.d.ts +29 -28
  1662. package/dist/types/utils/platform.d.ts +16 -16
  1663. package/dist/types/utils/sanitization/index.d.ts +2 -2
  1664. package/dist/types/utils/slot-mutation-controller.d.ts +3 -3
  1665. package/dist/types/utils/test/platform.utils.d.ts +66 -66
  1666. package/dist/types/utils/test/playwright/generator.d.ts +16 -7
  1667. package/dist/types/utils/test/playwright/matchers/index.d.ts +3 -3
  1668. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEvent.d.ts +2 -2
  1669. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventDetail.d.ts +2 -2
  1670. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventTimes.d.ts +2 -2
  1671. package/dist/types/utils/test/playwright/page/event-spy.d.ts +15 -15
  1672. package/dist/types/utils/test/playwright/page/utils/goto.d.ts +3 -3
  1673. package/dist/types/utils/test/playwright/page/utils/locator.d.ts +15 -15
  1674. package/dist/types/utils/test/playwright/playwright-declarations.d.ts +92 -92
  1675. package/dist/types/utils/test/playwright/playwright-page.d.ts +3 -3
  1676. package/dist/types/utils/test/playwright/viewports/index.d.ts +12 -12
  1677. package/dist/types/utils/test/press-keys.d.ts +14 -14
  1678. package/dist/types/utils/transition/index.d.ts +6 -6
  1679. package/dist/types/utils/watch-options.d.ts +1 -1
  1680. package/hydrate/index.d.ts +1 -1
  1681. package/hydrate/index.js +30685 -30001
  1682. package/package.json +4 -3
  1683. package/dist/cjs/animation-1083855c.js +0 -1061
  1684. package/dist/cjs/button-active-af897e0e.js +0 -69
  1685. package/dist/cjs/config-d5882735.js +0 -199
  1686. package/dist/cjs/cubic-bezier-6b9222ad.js +0 -92
  1687. package/dist/cjs/data-c8d21093.js +0 -1622
  1688. package/dist/cjs/focus-visible-a7545600.js +0 -77
  1689. package/dist/cjs/form-controller-9343050c.js +0 -66
  1690. package/dist/cjs/framework-delegate-c0873a6f.js +0 -144
  1691. package/dist/cjs/gesture-controller-b46721be.js +0 -197
  1692. package/dist/cjs/haptic-678abc9f.js +0 -212
  1693. package/dist/cjs/hardware-back-button-b67c8e75.js +0 -76
  1694. package/dist/cjs/helpers-ea4ccbcb.js +0 -441
  1695. package/dist/cjs/index-0ee995e4.js +0 -459
  1696. package/dist/cjs/index-306a7476.js +0 -32
  1697. package/dist/cjs/index-573877f3.js +0 -243
  1698. package/dist/cjs/index-9f379eaa.js +0 -198
  1699. package/dist/cjs/index-d7561763.js +0 -310
  1700. package/dist/cjs/input-shims-b0a75a01.js +0 -596
  1701. package/dist/cjs/input.utils-0fe3097c.js +0 -137
  1702. package/dist/cjs/ionic-global-ea2901a3.js +0 -230
  1703. package/dist/cjs/ios.transition-ac909bc8.js +0 -654
  1704. package/dist/cjs/keyboard-controller-50beb83a.js +0 -167
  1705. package/dist/cjs/keyboard-fd7db491.js +0 -81
  1706. package/dist/cjs/lock-controller-4ae2eb59.js +0 -40
  1707. package/dist/cjs/md.transition-907af519.js +0 -59
  1708. package/dist/cjs/notch-controller-f4f6af5d.js +0 -155
  1709. package/dist/cjs/overlays-2ffc5f27.js +0 -714
  1710. package/dist/cjs/spinner-configs-f7b5105b.js +0 -147
  1711. package/dist/cjs/status-tap-3fb2391a.js +0 -42
  1712. package/dist/cjs/swipe-back-7e843e77.js +0 -81
  1713. package/dist/cjs/theme-fbc56b3b.js +0 -48
  1714. package/dist/cjs/watch-options-53bbb124.js +0 -49
  1715. package/dist/collection/components/item/test/text/item.e2e.js +0 -14
  1716. package/dist/esm/animation-8aa13916.js +0 -1059
  1717. package/dist/esm/button-active-ce5cba4c.js +0 -67
  1718. package/dist/esm/capacitor-b4979570.js +0 -13
  1719. package/dist/esm/config-96c9ace3.js +0 -193
  1720. package/dist/esm/cubic-bezier-66542bc5.js +0 -90
  1721. package/dist/esm/data-44d9e816.js +0 -1575
  1722. package/dist/esm/focus-visible-85493433.js +0 -75
  1723. package/dist/esm/form-controller-64edeaad.js +0 -64
  1724. package/dist/esm/framework-delegate-aa433dea.js +0 -140
  1725. package/dist/esm/gesture-controller-0fa396c4.js +0 -195
  1726. package/dist/esm/haptic-1243b917.js +0 -206
  1727. package/dist/esm/hardware-back-button-39299f84.js +0 -71
  1728. package/dist/esm/helpers-3379ba19.js +0 -418
  1729. package/dist/esm/index-0aa6e61f.js +0 -308
  1730. package/dist/esm/index-6a0ccabb.js +0 -231
  1731. package/dist/esm/index-7a14ecec.js +0 -29
  1732. package/dist/esm/index-f0cc4e14.js +0 -196
  1733. package/dist/esm/index-ff313b19.js +0 -457
  1734. package/dist/esm/input-shims-d0c93e5d.js +0 -594
  1735. package/dist/esm/input.utils-ec063df4.js +0 -134
  1736. package/dist/esm/ionic-global-40e42e7f.js +0 -224
  1737. package/dist/esm/ios.transition-1651c430.js +0 -651
  1738. package/dist/esm/keyboard-b063f012.js +0 -79
  1739. package/dist/esm/keyboard-b551279d.js +0 -146
  1740. package/dist/esm/keyboard-controller-0c2dce71.js +0 -165
  1741. package/dist/esm/lock-controller-e8c6c051.js +0 -38
  1742. package/dist/esm/md.transition-66f18369.js +0 -57
  1743. package/dist/esm/notch-controller-8c9c0e54.js +0 -153
  1744. package/dist/esm/overlays-6c9feb7e.js +0 -692
  1745. package/dist/esm/spinner-configs-d09fbbbb.js +0 -145
  1746. package/dist/esm/status-tap-9ce68758.js +0 -40
  1747. package/dist/esm/swipe-back-cd4295f3.js +0 -79
  1748. package/dist/esm/theme-17531cdf.js +0 -43
  1749. package/dist/esm/watch-options-02d8498b.js +0 -47
  1750. package/dist/esm-es5/app-globals-2398e405.js +0 -4
  1751. package/dist/esm-es5/data-44d9e816.js +0 -4
  1752. package/dist/esm-es5/index-0aa6e61f.js +0 -4
  1753. package/dist/esm-es5/index-7c9b1bca.js +0 -5
  1754. package/dist/esm-es5/input-shims-d0c93e5d.js +0 -4
  1755. package/dist/esm-es5/input.utils-ec063df4.js +0 -4
  1756. package/dist/esm-es5/md.transition-66f18369.js +0 -4
  1757. package/dist/ionic/p-0d8e9393.entry.js +0 -4
  1758. package/dist/ionic/p-114a36ed.js +0 -4
  1759. package/dist/ionic/p-17240d90.js +0 -4
  1760. package/dist/ionic/p-1e5165db.system.entry.js +0 -4
  1761. package/dist/ionic/p-1f4f0d59.system.entry.js +0 -4
  1762. package/dist/ionic/p-20cf4994.js +0 -4
  1763. package/dist/ionic/p-236063ec.system.entry.js +0 -4
  1764. package/dist/ionic/p-276afddd.js +0 -4
  1765. package/dist/ionic/p-2e8e0045.js +0 -4
  1766. package/dist/ionic/p-32083c2d.js +0 -4
  1767. package/dist/ionic/p-352c0232.system.entry.js +0 -4
  1768. package/dist/ionic/p-3602001b.system.js +0 -4
  1769. package/dist/ionic/p-3632220b.system.js +0 -4
  1770. package/dist/ionic/p-377c636c.system.entry.js +0 -4
  1771. package/dist/ionic/p-39044fe6.system.entry.js +0 -4
  1772. package/dist/ionic/p-3ce8c3e3.entry.js +0 -4
  1773. package/dist/ionic/p-40903d34.system.js +0 -4
  1774. package/dist/ionic/p-4518e4c0.system.entry.js +0 -4
  1775. package/dist/ionic/p-4794e0ac.system.entry.js +0 -4
  1776. package/dist/ionic/p-4a142496.system.entry.js +0 -4
  1777. package/dist/ionic/p-4cd588b3.system.entry.js +0 -4
  1778. package/dist/ionic/p-4dbac22d.entry.js +0 -4
  1779. package/dist/ionic/p-4ecb5692.entry.js +0 -4
  1780. package/dist/ionic/p-5370e786.js +0 -4
  1781. package/dist/ionic/p-5cfb3feb.system.entry.js +0 -4
  1782. package/dist/ionic/p-63d519fb.entry.js +0 -4
  1783. package/dist/ionic/p-64296b15.entry.js +0 -4
  1784. package/dist/ionic/p-67aab78f.js +0 -4
  1785. package/dist/ionic/p-67ed452a.system.entry.js +0 -4
  1786. package/dist/ionic/p-67eecef4.system.js +0 -4
  1787. package/dist/ionic/p-7176cea3.entry.js +0 -4
  1788. package/dist/ionic/p-73411c1b.entry.js +0 -4
  1789. package/dist/ionic/p-73420380.js +0 -4
  1790. package/dist/ionic/p-77e7a9c8.entry.js +0 -4
  1791. package/dist/ionic/p-81c818e7.js +0 -4
  1792. package/dist/ionic/p-8b1be026.js +0 -4
  1793. package/dist/ionic/p-8cf94fc1.js +0 -4
  1794. package/dist/ionic/p-8e1bded3.entry.js +0 -4
  1795. package/dist/ionic/p-97c65aa5.js +0 -4
  1796. package/dist/ionic/p-9ab6f3e6.system.js +0 -4
  1797. package/dist/ionic/p-9b89cbde.js +0 -4
  1798. package/dist/ionic/p-a5c1e6ce.entry.js +0 -4
  1799. package/dist/ionic/p-af016cd3.entry.js +0 -4
  1800. package/dist/ionic/p-b0cee324.entry.js +0 -4
  1801. package/dist/ionic/p-b1142133.entry.js +0 -4
  1802. package/dist/ionic/p-b17b7c3c.system.entry.js +0 -4
  1803. package/dist/ionic/p-b203659a.system.entry.js +0 -4
  1804. package/dist/ionic/p-b6f8ee31.entry.js +0 -4
  1805. package/dist/ionic/p-b8c3f071.system.js +0 -4
  1806. package/dist/ionic/p-b906c5ca.entry.js +0 -4
  1807. package/dist/ionic/p-b912e055.system.js +0 -4
  1808. package/dist/ionic/p-c224b9a9.js +0 -5
  1809. package/dist/ionic/p-ca5219df.entry.js +0 -4
  1810. package/dist/ionic/p-cc196b34.js +0 -4
  1811. package/dist/ionic/p-d1de1188.js +0 -4
  1812. package/dist/ionic/p-d2597b3e.system.js +0 -5
  1813. package/dist/ionic/p-d3952bd5.system.entry.js +0 -4
  1814. package/dist/ionic/p-dfa756ed.system.js +0 -4
  1815. package/dist/ionic/p-e6b240a0.js +0 -4
  1816. package/dist/ionic/p-e8400078.system.entry.js +0 -4
  1817. package/dist/ionic/p-ed636a74.entry.js +0 -4
  1818. package/dist/ionic/p-f8e620f1.entry.js +0 -4
  1819. package/dist/ionic/p-ff5a10f9.system.js +0 -4
  1820. /package/dist/esm-es5/{config-96c9ace3.js → config-49c88215.js} +0 -0
  1821. /package/dist/esm-es5/{cubic-bezier-66542bc5.js → cubic-bezier-fe2083dc.js} +0 -0
  1822. /package/dist/esm-es5/{dir-912e3e13.js → dir-babeabeb.js} +0 -0
  1823. /package/dist/esm-es5/{focus-visible-85493433.js → focus-visible-dd40d69f.js} +0 -0
  1824. /package/dist/esm-es5/{gesture-controller-0fa396c4.js → gesture-controller-1bf57181.js} +0 -0
  1825. /package/dist/esm-es5/{hardware-back-button-39299f84.js → hardware-back-button-b2bc76db.js} +0 -0
  1826. /package/dist/esm-es5/{helpers-3379ba19.js → helpers-ae653409.js} +0 -0
  1827. /package/dist/esm-es5/{index-595d62c9.js → index-9b0d46f4.js} +0 -0
  1828. /package/dist/esm-es5/{index-7a14ecec.js → index-a5d50daf.js} +0 -0
  1829. /package/dist/esm-es5/{lock-controller-e8c6c051.js → lock-controller-316928be.js} +0 -0
  1830. /package/dist/esm-es5/{spinner-configs-d09fbbbb.js → spinner-configs-964f7cf3.js} +0 -0
  1831. /package/dist/esm-es5/{theme-17531cdf.js → theme-01f3f29c.js} +0 -0
  1832. /package/dist/esm-es5/{watch-options-02d8498b.js → watch-options-c2911ace.js} +0 -0
  1833. /package/dist/ionic/{p-5aac9314.system.js → p-012c3ceb.system.js} +0 -0
  1834. /package/dist/ionic/{p-1b8e1d03.js → p-06fee233.js} +0 -0
  1835. /package/dist/ionic/{p-819ff3b9.system.js → p-08e01816.system.js} +0 -0
  1836. /package/dist/ionic/{p-63eb0acd.js → p-23a9d086.js} +0 -0
  1837. /package/dist/ionic/{p-7c2bac85.js → p-2408c236.js} +0 -0
  1838. /package/dist/ionic/{p-815c2fba.system.js → p-32ad210f.system.js} +0 -0
  1839. /package/dist/ionic/{p-7b021525.js → p-41d5544e.js} +0 -0
  1840. /package/dist/ionic/{p-f10de93b.js → p-459d13d5.js} +0 -0
  1841. /package/dist/ionic/{p-44bc8b45.system.js → p-4609d030.system.js} +0 -0
  1842. /package/dist/ionic/{p-1d072d3d.js → p-47794def.js} +0 -0
  1843. /package/dist/ionic/{p-185e427e.js → p-4b3623da.js} +0 -0
  1844. /package/dist/ionic/{p-772f6c84.system.js → p-4f255d5a.system.js} +0 -0
  1845. /package/dist/ionic/{p-8c15eda7.system.js → p-790220fd.system.js} +0 -0
  1846. /package/dist/ionic/{p-0e94957a.system.js → p-792919fd.system.js} +0 -0
  1847. /package/dist/ionic/{p-b347cfd1.js → p-7b30edcc.js} +0 -0
  1848. /package/dist/ionic/{p-e0b06b65.js → p-bb3615f7.js} +0 -0
  1849. /package/dist/ionic/{p-87411e39.system.js → p-c468af8a.system.js} +0 -0
  1850. /package/dist/ionic/{p-9e852ff1.system.js → p-c7c8429a.system.js} +0 -0
  1851. /package/dist/ionic/{p-53b2a46f.js → p-ccd02320.js} +0 -0
  1852. /package/dist/ionic/{p-76fce40e.js → p-d47265c8.js} +0 -0
  1853. /package/dist/ionic/{p-56dc022e.system.js → p-d8d84afa.system.js} +0 -0
  1854. /package/dist/ionic/{p-c4f2dce7.system.js → p-e673a0a2.system.js} +0 -0
  1855. /package/dist/ionic/{p-c18d6eac.js → p-f0c2a614.js} +0 -0
  1856. /package/dist/ionic/{p-2b89ea1b.system.js → p-f233f1e0.system.js} +0 -0
  1857. /package/dist/ionic/{p-6dbfe5d4.js → p-fb813dab.js} +0 -0
  1858. /package/dist/ionic/{p-479cdbf8.system.js → p-ff4b7e40.system.js} +0 -0
@@ -5,111 +5,111 @@
5
5
 
6
6
  Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
- const index = require('./index-c2940dc1.js');
9
- const ionicGlobal = require('./ionic-global-ea2901a3.js');
10
- const helpers = require('./helpers-ea4ccbcb.js');
11
- const dir = require('./dir-f1e0ca26.js');
12
- const theme = require('./theme-fbc56b3b.js');
13
- const index$1 = require('./index-da2c7a37.js');
14
- const keyboardController = require('./keyboard-controller-50beb83a.js');
15
- const cubicBezier = require('./cubic-bezier-6b9222ad.js');
16
- const frameworkDelegate = require('./framework-delegate-c0873a6f.js');
17
- const lockController = require('./lock-controller-4ae2eb59.js');
18
- const index$2 = require('./index-573877f3.js');
19
- require('./index-cc7dfb7c.js');
20
- require('./index-306a7476.js');
21
- require('./keyboard-fd7db491.js');
22
- require('./capacitor-2ffba62a.js');
8
+ const index = require('./index-50dcfe2f.js');
9
+ const ionicGlobal = require('./ionic-global-a4edbf03.js');
10
+ const helpers = require('./helpers-76bb7efb.js');
11
+ const dir = require('./dir-94c21456.js');
12
+ const theme = require('./theme-d1c573d2.js');
13
+ const index$1 = require('./index-da15e99c.js');
14
+ const keyboardController = require('./keyboard-controller-c05e747a.js');
15
+ const cubicBezier = require('./cubic-bezier-f2dccc53.js');
16
+ const frameworkDelegate = require('./framework-delegate-1c29b14a.js');
17
+ const lockController = require('./lock-controller-6585a42a.js');
18
+ const index$2 = require('./index-17ab7794.js');
19
+ require('./index-5915f9b3.js');
20
+ require('./index-c8d52405.js');
21
+ require('./keyboard-0272231f.js');
22
+ require('./capacitor-c04564bf.js');
23
23
 
24
24
  const appCss = "html.plt-mobile ion-app{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}html.plt-mobile ion-app [contenteditable]{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}ion-app.force-statusbar-padding{--ion-safe-area-top:20px}";
25
25
 
26
26
  const App = class {
27
- constructor(hostRef) {
28
- index.registerInstance(this, hostRef);
29
- }
30
- componentDidLoad() {
31
- {
32
- rIC(async () => {
33
- const isHybrid = ionicGlobal.isPlatform(window, 'hybrid');
34
- if (!ionicGlobal.config.getBoolean('_testing')) {
35
- Promise.resolve().then(function () { return require('./index-9f379eaa.js'); }).then((module) => module.startTapClick(ionicGlobal.config));
36
- }
37
- if (ionicGlobal.config.getBoolean('statusTap', isHybrid)) {
38
- Promise.resolve().then(function () { return require('./status-tap-3fb2391a.js'); }).then((module) => module.startStatusTap());
39
- }
40
- if (ionicGlobal.config.getBoolean('inputShims', needInputShims())) {
41
- /**
42
- * needInputShims() ensures that only iOS and Android
43
- * platforms proceed into this block.
44
- */
45
- const platform = ionicGlobal.isPlatform(window, 'ios') ? 'ios' : 'android';
46
- Promise.resolve().then(function () { return require('./input-shims-b0a75a01.js'); }).then((module) => module.startInputShims(ionicGlobal.config, platform));
47
- }
48
- const hardwareBackButtonModule = await Promise.resolve().then(function () { return require('./hardware-back-button-b67c8e75.js'); });
49
- if (ionicGlobal.config.getBoolean('hardwareBackButton', isHybrid)) {
50
- hardwareBackButtonModule.startHardwareBackButton();
51
- }
52
- else {
53
- hardwareBackButtonModule.blockHardwareBackButton();
27
+ constructor(hostRef) {
28
+ index.registerInstance(this, hostRef);
29
+ }
30
+ componentDidLoad() {
31
+ {
32
+ rIC(async () => {
33
+ const isHybrid = ionicGlobal.isPlatform(window, 'hybrid');
34
+ if (!ionicGlobal.config.getBoolean('_testing')) {
35
+ Promise.resolve().then(function () { return require('./index-b4f986cd.js'); }).then((module) => module.startTapClick(ionicGlobal.config));
36
+ }
37
+ if (ionicGlobal.config.getBoolean('statusTap', isHybrid)) {
38
+ Promise.resolve().then(function () { return require('./status-tap-b5d77c08.js'); }).then((module) => module.startStatusTap());
39
+ }
40
+ if (ionicGlobal.config.getBoolean('inputShims', needInputShims())) {
41
+ /**
42
+ * needInputShims() ensures that only iOS and Android
43
+ * platforms proceed into this block.
44
+ */
45
+ const platform = ionicGlobal.isPlatform(window, 'ios') ? 'ios' : 'android';
46
+ Promise.resolve().then(function () { return require('./input-shims-a23bb0f4.js'); }).then((module) => module.startInputShims(ionicGlobal.config, platform));
47
+ }
48
+ const hardwareBackButtonModule = await Promise.resolve().then(function () { return require('./hardware-back-button-76833cac.js'); });
49
+ if (ionicGlobal.config.getBoolean('hardwareBackButton', isHybrid)) {
50
+ hardwareBackButtonModule.startHardwareBackButton();
51
+ }
52
+ else {
53
+ hardwareBackButtonModule.blockHardwareBackButton();
54
+ }
55
+ if (typeof window !== 'undefined') {
56
+ Promise.resolve().then(function () { return require('./keyboard-af1bb365.js'); }).then((module) => module.startKeyboardAssist(window));
57
+ }
58
+ Promise.resolve().then(function () { return require('./focus-visible-7a0ce04f.js'); }).then((module) => (this.focusVisible = module.startFocusVisible()));
59
+ });
54
60
  }
55
- if (typeof window !== 'undefined') {
56
- Promise.resolve().then(function () { return require('./keyboard-38f2bb7b.js'); }).then((module) => module.startKeyboardAssist(window));
61
+ }
62
+ /**
63
+ * @internal
64
+ * Used to set focus on an element that uses `ion-focusable`.
65
+ * Do not use this if focusing the element as a result of a keyboard
66
+ * event as the focus utility should handle this for us. This method
67
+ * should be used when we want to programmatically focus an element as
68
+ * a result of another user action. (Ex: We focus the first element
69
+ * inside of a popover when the user presents it, but the popover is not always
70
+ * presented as a result of keyboard action.)
71
+ */
72
+ async setFocus(elements) {
73
+ if (this.focusVisible) {
74
+ this.focusVisible.setFocus(elements);
57
75
  }
58
- Promise.resolve().then(function () { return require('./focus-visible-a7545600.js'); }).then((module) => (this.focusVisible = module.startFocusVisible()));
59
- });
60
- }
61
- }
62
- /**
63
- * @internal
64
- * Used to set focus on an element that uses `ion-focusable`.
65
- * Do not use this if focusing the element as a result of a keyboard
66
- * event as the focus utility should handle this for us. This method
67
- * should be used when we want to programmatically focus an element as
68
- * a result of another user action. (Ex: We focus the first element
69
- * inside of a popover when the user presents it, but the popover is not always
70
- * presented as a result of keyboard action.)
71
- */
72
- async setFocus(elements) {
73
- if (this.focusVisible) {
74
- this.focusVisible.setFocus(elements);
75
- }
76
- }
77
- render() {
78
- const mode = ionicGlobal.getIonMode(this);
79
- return (index.h(index.Host, { class: {
80
- [mode]: true,
81
- 'ion-page': true,
82
- 'force-statusbar-padding': ionicGlobal.config.getBoolean('_forceStatusbarPadding'),
83
- } }));
84
- }
85
- get el() { return index.getElement(this); }
76
+ }
77
+ render() {
78
+ const mode = ionicGlobal.getIonMode(this);
79
+ return (index.h(index.Host, { class: {
80
+ [mode]: true,
81
+ 'ion-page': true,
82
+ 'force-statusbar-padding': ionicGlobal.config.getBoolean('_forceStatusbarPadding'),
83
+ } }));
84
+ }
85
+ get el() { return index.getElement(this); }
86
86
  };
87
87
  const needInputShims = () => {
88
- /**
89
- * iOS always needs input shims
90
- */
91
- const needsShimsIOS = ionicGlobal.isPlatform(window, 'ios') && ionicGlobal.isPlatform(window, 'mobile');
92
- if (needsShimsIOS) {
93
- return true;
94
- }
95
- /**
96
- * Android only needs input shims when running
97
- * in the browser and only if the browser is using the
98
- * new Chrome 108+ resize behavior: https://developer.chrome.com/blog/viewport-resize-behavior/
99
- */
100
- const isAndroidMobileWeb = ionicGlobal.isPlatform(window, 'android') && ionicGlobal.isPlatform(window, 'mobileweb');
101
- if (isAndroidMobileWeb) {
102
- return true;
103
- }
104
- return false;
88
+ /**
89
+ * iOS always needs input shims
90
+ */
91
+ const needsShimsIOS = ionicGlobal.isPlatform(window, 'ios') && ionicGlobal.isPlatform(window, 'mobile');
92
+ if (needsShimsIOS) {
93
+ return true;
94
+ }
95
+ /**
96
+ * Android only needs input shims when running
97
+ * in the browser and only if the browser is using the
98
+ * new Chrome 108+ resize behavior: https://developer.chrome.com/blog/viewport-resize-behavior/
99
+ */
100
+ const isAndroidMobileWeb = ionicGlobal.isPlatform(window, 'android') && ionicGlobal.isPlatform(window, 'mobileweb');
101
+ if (isAndroidMobileWeb) {
102
+ return true;
103
+ }
104
+ return false;
105
105
  };
106
106
  const rIC = (callback) => {
107
- if ('requestIdleCallback' in window) {
108
- window.requestIdleCallback(callback);
109
- }
110
- else {
111
- setTimeout(callback, 32);
112
- }
107
+ if ('requestIdleCallback' in window) {
108
+ window.requestIdleCallback(callback);
109
+ }
110
+ else {
111
+ setTimeout(callback, 32);
112
+ }
113
113
  };
114
114
  App.style = appCss;
115
115
 
@@ -118,452 +118,452 @@ const buttonsIosCss = ".sc-ion-buttons-ios-h{display:-ms-flexbox;display:flex;-m
118
118
  const buttonsMdCss = ".sc-ion-buttons-md-h{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0);z-index:99}.sc-ion-buttons-md-s ion-button{--padding-top:0;--padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.sc-ion-buttons-md-s ion-button{--padding-top:3px;--padding-bottom:3px;--padding-start:8px;--padding-end:8px;--box-shadow:none;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px;min-height:32px}.sc-ion-buttons-md-s .button-has-icon-only{--padding-top:0;--padding-bottom:0}.sc-ion-buttons-md-s ion-button:not(.button-round){--border-radius:2px}.sc-ion-buttons-md-h.ion-color.sc-ion-buttons-md-s .button,.ion-color .sc-ion-buttons-md-h.sc-ion-buttons-md-s .button{--color:initial;--color-focused:var(--ion-color-contrast);--color-hover:var(--ion-color-contrast);--background-activated:transparent;--background-focused:var(--ion-color-contrast);--background-hover:var(--ion-color-contrast)}.sc-ion-buttons-md-h.ion-color.sc-ion-buttons-md-s .button-solid,.ion-color .sc-ion-buttons-md-h.sc-ion-buttons-md-s .button-solid{--background:var(--ion-color-contrast);--background-activated:transparent;--background-focused:var(--ion-color-shade);--background-hover:var(--ion-color-base);--color:var(--ion-color-base);--color-focused:var(--ion-color-base);--color-hover:var(--ion-color-base)}.sc-ion-buttons-md-h.ion-color.sc-ion-buttons-md-s .button-outline,.ion-color .sc-ion-buttons-md-h.sc-ion-buttons-md-s .button-outline{--border-color:var(--ion-color-contrast)}.sc-ion-buttons-md-s .button-has-icon-only.button-clear{--padding-top:12px;--padding-end:12px;--padding-bottom:12px;--padding-start:12px;--border-radius:50%;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;width:3rem;height:3rem}.sc-ion-buttons-md-s .button{--background-hover:currentColor}.sc-ion-buttons-md-s .button-solid{--color:var(--ion-toolbar-background, var(--ion-background-color, #fff));--background:var(--ion-toolbar-color, var(--ion-text-color, #424242));--background-activated:transparent;--background-focused:currentColor}.sc-ion-buttons-md-s .button-outline{--color:initial;--background:transparent;--background-activated:transparent;--background-focused:currentColor;--background-hover:currentColor;--border-color:currentColor}.sc-ion-buttons-md-s .button-clear{--color:initial;--background:transparent;--background-activated:transparent;--background-focused:currentColor;--background-hover:currentColor}.sc-ion-buttons-md-s ion-icon[slot=start]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-end:0.3em;margin-inline-end:0.3em;font-size:1.4em}.sc-ion-buttons-md-s ion-icon[slot=end]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-start:0.4em;margin-inline-start:0.4em;font-size:1.4em}.sc-ion-buttons-md-s ion-icon[slot=icon-only]{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;font-size:1.8em}";
119
119
 
120
120
  const Buttons = class {
121
- constructor(hostRef) {
122
- index.registerInstance(this, hostRef);
123
- this.collapse = false;
124
- }
125
- render() {
126
- const mode = ionicGlobal.getIonMode(this);
127
- return (index.h(index.Host, { class: {
128
- [mode]: true,
129
- ['buttons-collapse']: this.collapse,
130
- } }));
131
- }
121
+ constructor(hostRef) {
122
+ index.registerInstance(this, hostRef);
123
+ this.collapse = false;
124
+ }
125
+ render() {
126
+ const mode = ionicGlobal.getIonMode(this);
127
+ return (index.h(index.Host, { class: {
128
+ [mode]: true,
129
+ ['buttons-collapse']: this.collapse,
130
+ } }));
131
+ }
132
132
  };
133
133
  Buttons.style = {
134
- ios: buttonsIosCss,
135
- md: buttonsMdCss
134
+ ios: buttonsIosCss,
135
+ md: buttonsMdCss
136
136
  };
137
137
 
138
138
  const contentCss = ":host{--background:var(--ion-background-color, #fff);--color:var(--ion-text-color, #000);--padding-top:0px;--padding-bottom:0px;--padding-start:0px;--padding-end:0px;--keyboard-offset:0px;--offset-top:0px;--offset-bottom:0px;--overflow:auto;display:block;position:relative;-ms-flex:1;flex:1;width:100%;height:100%;margin:0 !important;padding:0 !important;font-family:var(--ion-font-family, inherit);contain:size style}:host(.ion-color) .inner-scroll{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.outer-content){--background:var(--ion-color-step-50, #f2f2f2)}#background-content{left:0px;right:0px;top:calc(var(--offset-top) * -1);bottom:calc(var(--offset-bottom) * -1);position:absolute;background:var(--background)}.inner-scroll{left:0px;right:0px;top:calc(var(--offset-top) * -1);bottom:calc(var(--offset-bottom) * -1);-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:calc(var(--padding-top) + var(--offset-top));padding-bottom:calc(var(--padding-bottom) + var(--keyboard-offset) + var(--offset-bottom));position:absolute;color:var(--color);-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden;-ms-touch-action:pan-x pan-y pinch-zoom;touch-action:pan-x pan-y pinch-zoom}.scroll-y,.scroll-x{-webkit-overflow-scrolling:touch;z-index:0;will-change:scroll-position}.scroll-y{overflow-y:var(--overflow);overscroll-behavior-y:contain}.scroll-x{overflow-x:var(--overflow);overscroll-behavior-x:contain}.overscroll::before,.overscroll::after{position:absolute;width:1px;height:1px;content:\"\"}.overscroll::before{bottom:-1px}.overscroll::after{top:-1px}:host(.content-sizing){display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;min-height:0;contain:none}:host(.content-sizing) .inner-scroll{position:relative;top:0;bottom:0;margin-top:calc(var(--offset-top) * -1);margin-bottom:calc(var(--offset-bottom) * -1)}.transition-effect{display:none;position:absolute;width:100%;height:100vh;opacity:0;pointer-events:none}:host(.content-ltr) .transition-effect{left:-100%;}:host(.content-rtl) .transition-effect{right:-100%;}.transition-cover{position:absolute;right:0;width:100%;height:100%;background:black;opacity:0.1}.transition-shadow{display:block;position:absolute;width:100%;height:100%;-webkit-box-shadow:inset -9px 0 9px 0 rgba(0, 0, 100, 0.03);box-shadow:inset -9px 0 9px 0 rgba(0, 0, 100, 0.03)}:host(.content-ltr) .transition-shadow{right:0;}:host(.content-rtl) .transition-shadow{left:0;-webkit-transform:scaleX(-1);transform:scaleX(-1)}::slotted([slot=fixed]){position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0)}";
139
139
 
140
140
  const Content = class {
141
- constructor(hostRef) {
142
- index.registerInstance(this, hostRef);
143
- this.ionScrollStart = index.createEvent(this, "ionScrollStart", 7);
144
- this.ionScroll = index.createEvent(this, "ionScroll", 7);
145
- this.ionScrollEnd = index.createEvent(this, "ionScrollEnd", 7);
146
- this.watchDog = null;
147
- this.isScrolling = false;
148
- this.lastScroll = 0;
149
- this.queued = false;
150
- this.cTop = -1;
151
- this.cBottom = -1;
152
- this.isMainContent = true;
153
- this.resizeTimeout = null;
154
- this.tabsElement = null;
155
- // Detail is used in a hot loop in the scroll event, by allocating it here
156
- // V8 will be able to inline any read/write to it since it's a monomorphic class.
157
- // https://mrale.ph/blog/2015/01/11/whats-up-with-monomorphism.html
158
- this.detail = {
159
- scrollTop: 0,
160
- scrollLeft: 0,
161
- type: 'scroll',
162
- event: undefined,
163
- startX: 0,
164
- startY: 0,
165
- startTime: 0,
166
- currentX: 0,
167
- currentY: 0,
168
- velocityX: 0,
169
- velocityY: 0,
170
- deltaX: 0,
171
- deltaY: 0,
172
- currentTime: 0,
173
- data: undefined,
174
- isScrolling: true,
175
- };
176
- this.color = undefined;
177
- this.fullscreen = false;
178
- this.forceOverscroll = undefined;
179
- this.scrollX = false;
180
- this.scrollY = true;
181
- this.scrollEvents = false;
182
- }
183
- connectedCallback() {
184
- this.isMainContent = this.el.closest('ion-menu, ion-popover, ion-modal') === null;
141
+ constructor(hostRef) {
142
+ index.registerInstance(this, hostRef);
143
+ this.ionScrollStart = index.createEvent(this, "ionScrollStart", 7);
144
+ this.ionScroll = index.createEvent(this, "ionScroll", 7);
145
+ this.ionScrollEnd = index.createEvent(this, "ionScrollEnd", 7);
146
+ this.watchDog = null;
147
+ this.isScrolling = false;
148
+ this.lastScroll = 0;
149
+ this.queued = false;
150
+ this.cTop = -1;
151
+ this.cBottom = -1;
152
+ this.isMainContent = true;
153
+ this.resizeTimeout = null;
154
+ this.tabsElement = null;
155
+ // Detail is used in a hot loop in the scroll event, by allocating it here
156
+ // V8 will be able to inline any read/write to it since it's a monomorphic class.
157
+ // https://mrale.ph/blog/2015/01/11/whats-up-with-monomorphism.html
158
+ this.detail = {
159
+ scrollTop: 0,
160
+ scrollLeft: 0,
161
+ type: 'scroll',
162
+ event: undefined,
163
+ startX: 0,
164
+ startY: 0,
165
+ startTime: 0,
166
+ currentX: 0,
167
+ currentY: 0,
168
+ velocityX: 0,
169
+ velocityY: 0,
170
+ deltaX: 0,
171
+ deltaY: 0,
172
+ currentTime: 0,
173
+ data: undefined,
174
+ isScrolling: true,
175
+ };
176
+ this.color = undefined;
177
+ this.fullscreen = false;
178
+ this.forceOverscroll = undefined;
179
+ this.scrollX = false;
180
+ this.scrollY = true;
181
+ this.scrollEvents = false;
182
+ }
183
+ connectedCallback() {
184
+ this.isMainContent = this.el.closest('ion-menu, ion-popover, ion-modal') === null;
185
+ /**
186
+ * The fullscreen content offsets need to be
187
+ * computed after the tab bar has loaded. Since
188
+ * lazy evaluation means components are not hydrated
189
+ * at the same time, we need to wait for the ionTabBarLoaded
190
+ * event to fire. This does not impact dist-custom-elements
191
+ * because there is no hydration there.
192
+ */
193
+ if (helpers.hasLazyBuild(this.el)) {
194
+ /**
195
+ * We need to cache the reference to the tabs.
196
+ * If just the content is unmounted then we won't
197
+ * be able to query for the closest tabs on disconnectedCallback
198
+ * since the content has been removed from the DOM tree.
199
+ */
200
+ const closestTabs = (this.tabsElement = this.el.closest('ion-tabs'));
201
+ if (closestTabs !== null) {
202
+ /**
203
+ * When adding and removing the event listener
204
+ * we need to make sure we pass the same function reference
205
+ * otherwise the event listener will not be removed properly.
206
+ * We can't only pass `this.resize` because "this" in the function
207
+ * context becomes a reference to IonTabs instead of IonContent.
208
+ *
209
+ * Additionally, we listen for ionTabBarLoaded on the IonTabs
210
+ * instance rather than the IonTabBar instance. It's possible for
211
+ * a tab bar to be conditionally rendered/mounted. Since ionTabBarLoaded
212
+ * bubbles, we can catch any instances of child tab bars loading by listening
213
+ * on IonTabs.
214
+ */
215
+ this.tabsLoadCallback = () => this.resize();
216
+ closestTabs.addEventListener('ionTabBarLoaded', this.tabsLoadCallback);
217
+ }
218
+ }
219
+ }
220
+ disconnectedCallback() {
221
+ this.onScrollEnd();
222
+ if (helpers.hasLazyBuild(this.el)) {
223
+ /**
224
+ * The event listener and tabs caches need to
225
+ * be cleared otherwise this will create a memory
226
+ * leak where the IonTabs instance can never be
227
+ * garbage collected.
228
+ */
229
+ const { tabsElement, tabsLoadCallback } = this;
230
+ if (tabsElement !== null && tabsLoadCallback !== undefined) {
231
+ tabsElement.removeEventListener('ionTabBarLoaded', tabsLoadCallback);
232
+ }
233
+ this.tabsElement = null;
234
+ this.tabsLoadCallback = undefined;
235
+ }
236
+ }
185
237
  /**
186
- * The fullscreen content offsets need to be
187
- * computed after the tab bar has loaded. Since
188
- * lazy evaluation means components are not hydrated
189
- * at the same time, we need to wait for the ionTabBarLoaded
190
- * event to fire. This does not impact dist-custom-elements
191
- * because there is no hydration there.
238
+ * Rotating certain devices can update
239
+ * the safe area insets. As a result,
240
+ * the fullscreen feature on ion-content
241
+ * needs to be recalculated.
242
+ *
243
+ * We listen for "resize" because we
244
+ * do not care what the orientation of
245
+ * the device is. Other APIs
246
+ * such as ScreenOrientation or
247
+ * the deviceorientation event must have
248
+ * permission from the user first whereas
249
+ * the "resize" event does not.
250
+ *
251
+ * We also throttle the callback to minimize
252
+ * thrashing when quickly resizing a window.
192
253
  */
193
- if (helpers.hasLazyBuild(this.el)) {
194
- /**
195
- * We need to cache the reference to the tabs.
196
- * If just the content is unmounted then we won't
197
- * be able to query for the closest tabs on disconnectedCallback
198
- * since the content has been removed from the DOM tree.
199
- */
200
- const closestTabs = (this.tabsElement = this.el.closest('ion-tabs'));
201
- if (closestTabs !== null) {
254
+ onResize() {
255
+ if (this.resizeTimeout) {
256
+ clearTimeout(this.resizeTimeout);
257
+ this.resizeTimeout = null;
258
+ }
259
+ this.resizeTimeout = setTimeout(() => {
260
+ /**
261
+ * Resize should only happen
262
+ * if the content is visible.
263
+ * When the content is hidden
264
+ * then offsetParent will be null.
265
+ */
266
+ if (this.el.offsetParent === null) {
267
+ return;
268
+ }
269
+ this.resize();
270
+ }, 100);
271
+ }
272
+ shouldForceOverscroll() {
273
+ const { forceOverscroll } = this;
274
+ const mode = ionicGlobal.getIonMode(this);
275
+ return forceOverscroll === undefined ? mode === 'ios' && ionicGlobal.isPlatform('ios') : forceOverscroll;
276
+ }
277
+ resize() {
202
278
  /**
203
- * When adding and removing the event listener
204
- * we need to make sure we pass the same function reference
205
- * otherwise the event listener will not be removed properly.
206
- * We can't only pass `this.resize` because "this" in the function
207
- * context becomes a reference to IonTabs instead of IonContent.
279
+ * Only force update if the component is rendered in a browser context.
280
+ * Using `forceUpdate` in a server context with pre-rendering can lead to an infinite loop.
281
+ * The `hydrateDocument` function in `@stencil/core` will render the `ion-content`, but
282
+ * `forceUpdate` will trigger another render, locking up the server.
208
283
  *
209
- * Additionally, we listen for ionTabBarLoaded on the IonTabs
210
- * instance rather than the IonTabBar instance. It's possible for
211
- * a tab bar to be conditionally rendered/mounted. Since ionTabBarLoaded
212
- * bubbles, we can catch any instances of child tab bars loading by listening
213
- * on IonTabs.
284
+ * TODO: Remove if STENCIL-834 determines Stencil will account for this.
214
285
  */
215
- this.tabsLoadCallback = () => this.resize();
216
- closestTabs.addEventListener('ionTabBarLoaded', this.tabsLoadCallback);
217
- }
218
- }
219
- }
220
- disconnectedCallback() {
221
- this.onScrollEnd();
222
- if (helpers.hasLazyBuild(this.el)) {
223
- /**
224
- * The event listener and tabs caches need to
225
- * be cleared otherwise this will create a memory
226
- * leak where the IonTabs instance can never be
227
- * garbage collected.
228
- */
229
- const { tabsElement, tabsLoadCallback } = this;
230
- if (tabsElement !== null && tabsLoadCallback !== undefined) {
231
- tabsElement.removeEventListener('ionTabBarLoaded', tabsLoadCallback);
232
- }
233
- this.tabsElement = null;
234
- this.tabsLoadCallback = undefined;
235
- }
236
- }
237
- /**
238
- * Rotating certain devices can update
239
- * the safe area insets. As a result,
240
- * the fullscreen feature on ion-content
241
- * needs to be recalculated.
242
- *
243
- * We listen for "resize" because we
244
- * do not care what the orientation of
245
- * the device is. Other APIs
246
- * such as ScreenOrientation or
247
- * the deviceorientation event must have
248
- * permission from the user first whereas
249
- * the "resize" event does not.
250
- *
251
- * We also throttle the callback to minimize
252
- * thrashing when quickly resizing a window.
253
- */
254
- onResize() {
255
- if (this.resizeTimeout) {
256
- clearTimeout(this.resizeTimeout);
257
- this.resizeTimeout = null;
258
- }
259
- this.resizeTimeout = setTimeout(() => {
260
- /**
261
- * Resize should only happen
262
- * if the content is visible.
263
- * When the content is hidden
264
- * then offsetParent will be null.
265
- */
266
- if (this.el.offsetParent === null) {
267
- return;
268
- }
269
- this.resize();
270
- }, 100);
271
- }
272
- shouldForceOverscroll() {
273
- const { forceOverscroll } = this;
274
- const mode = ionicGlobal.getIonMode(this);
275
- return forceOverscroll === undefined ? mode === 'ios' && ionicGlobal.isPlatform('ios') : forceOverscroll;
276
- }
277
- resize() {
286
+ {
287
+ if (this.fullscreen) {
288
+ index.readTask(() => this.readDimensions());
289
+ }
290
+ else if (this.cTop !== 0 || this.cBottom !== 0) {
291
+ this.cTop = this.cBottom = 0;
292
+ index.forceUpdate(this);
293
+ }
294
+ }
295
+ }
296
+ readDimensions() {
297
+ const page = getPageElement(this.el);
298
+ const top = Math.max(this.el.offsetTop, 0);
299
+ const bottom = Math.max(page.offsetHeight - top - this.el.offsetHeight, 0);
300
+ const dirty = top !== this.cTop || bottom !== this.cBottom;
301
+ if (dirty) {
302
+ this.cTop = top;
303
+ this.cBottom = bottom;
304
+ index.forceUpdate(this);
305
+ }
306
+ }
307
+ onScroll(ev) {
308
+ const timeStamp = Date.now();
309
+ const shouldStart = !this.isScrolling;
310
+ this.lastScroll = timeStamp;
311
+ if (shouldStart) {
312
+ this.onScrollStart();
313
+ }
314
+ if (!this.queued && this.scrollEvents) {
315
+ this.queued = true;
316
+ index.readTask((ts) => {
317
+ this.queued = false;
318
+ this.detail.event = ev;
319
+ updateScrollDetail(this.detail, this.scrollEl, ts, shouldStart);
320
+ this.ionScroll.emit(this.detail);
321
+ });
322
+ }
323
+ }
278
324
  /**
279
- * Only force update if the component is rendered in a browser context.
280
- * Using `forceUpdate` in a server context with pre-rendering can lead to an infinite loop.
281
- * The `hydrateDocument` function in `@stencil/core` will render the `ion-content`, but
282
- * `forceUpdate` will trigger another render, locking up the server.
325
+ * Get the element where the actual scrolling takes place.
326
+ * This element can be used to subscribe to `scroll` events or manually modify
327
+ * `scrollTop`. However, it's recommended to use the API provided by `ion-content`:
283
328
  *
284
- * TODO: Remove if STENCIL-834 determines Stencil will account for this.
329
+ * i.e. Using `ionScroll`, `ionScrollStart`, `ionScrollEnd` for scrolling events
330
+ * and `scrollToPoint()` to scroll the content into a certain point.
285
331
  */
286
- {
287
- if (this.fullscreen) {
288
- index.readTask(() => this.readDimensions());
289
- }
290
- else if (this.cTop !== 0 || this.cBottom !== 0) {
291
- this.cTop = this.cBottom = 0;
292
- index.forceUpdate(this);
293
- }
294
- }
295
- }
296
- readDimensions() {
297
- const page = getPageElement(this.el);
298
- const top = Math.max(this.el.offsetTop, 0);
299
- const bottom = Math.max(page.offsetHeight - top - this.el.offsetHeight, 0);
300
- const dirty = top !== this.cTop || bottom !== this.cBottom;
301
- if (dirty) {
302
- this.cTop = top;
303
- this.cBottom = bottom;
304
- index.forceUpdate(this);
305
- }
306
- }
307
- onScroll(ev) {
308
- const timeStamp = Date.now();
309
- const shouldStart = !this.isScrolling;
310
- this.lastScroll = timeStamp;
311
- if (shouldStart) {
312
- this.onScrollStart();
332
+ async getScrollElement() {
333
+ /**
334
+ * If this gets called in certain early lifecycle hooks (ex: Vue onMounted),
335
+ * scrollEl won't be defined yet with the custom elements build, so wait for it to load in.
336
+ */
337
+ if (!this.scrollEl) {
338
+ await new Promise((resolve) => helpers.componentOnReady(this.el, resolve));
339
+ }
340
+ return Promise.resolve(this.scrollEl);
313
341
  }
314
- if (!this.queued && this.scrollEvents) {
315
- this.queued = true;
316
- index.readTask((ts) => {
317
- this.queued = false;
318
- this.detail.event = ev;
319
- updateScrollDetail(this.detail, this.scrollEl, ts, shouldStart);
320
- this.ionScroll.emit(this.detail);
321
- });
322
- }
323
- }
324
- /**
325
- * Get the element where the actual scrolling takes place.
326
- * This element can be used to subscribe to `scroll` events or manually modify
327
- * `scrollTop`. However, it's recommended to use the API provided by `ion-content`:
328
- *
329
- * i.e. Using `ionScroll`, `ionScrollStart`, `ionScrollEnd` for scrolling events
330
- * and `scrollToPoint()` to scroll the content into a certain point.
331
- */
332
- async getScrollElement() {
333
342
  /**
334
- * If this gets called in certain early lifecycle hooks (ex: Vue onMounted),
335
- * scrollEl won't be defined yet with the custom elements build, so wait for it to load in.
343
+ * Returns the background content element.
344
+ * @internal
336
345
  */
337
- if (!this.scrollEl) {
338
- await new Promise((resolve) => helpers.componentOnReady(this.el, resolve));
339
- }
340
- return Promise.resolve(this.scrollEl);
341
- }
342
- /**
343
- * Returns the background content element.
344
- * @internal
345
- */
346
- async getBackgroundElement() {
347
- if (!this.backgroundContentEl) {
348
- await new Promise((resolve) => helpers.componentOnReady(this.el, resolve));
349
- }
350
- return Promise.resolve(this.backgroundContentEl);
351
- }
352
- /**
353
- * Scroll to the top of the component.
354
- *
355
- * @param duration The amount of time to take scrolling to the top. Defaults to `0`.
356
- */
357
- scrollToTop(duration = 0) {
358
- return this.scrollToPoint(undefined, 0, duration);
359
- }
360
- /**
361
- * Scroll to the bottom of the component.
362
- *
363
- * @param duration The amount of time to take scrolling to the bottom. Defaults to `0`.
364
- */
365
- async scrollToBottom(duration = 0) {
366
- const scrollEl = await this.getScrollElement();
367
- const y = scrollEl.scrollHeight - scrollEl.clientHeight;
368
- return this.scrollToPoint(undefined, y, duration);
369
- }
370
- /**
371
- * Scroll by a specified X/Y distance in the component.
372
- *
373
- * @param x The amount to scroll by on the horizontal axis.
374
- * @param y The amount to scroll by on the vertical axis.
375
- * @param duration The amount of time to take scrolling by that amount.
376
- */
377
- async scrollByPoint(x, y, duration) {
378
- const scrollEl = await this.getScrollElement();
379
- return this.scrollToPoint(x + scrollEl.scrollLeft, y + scrollEl.scrollTop, duration);
380
- }
381
- /**
382
- * Scroll to a specified X/Y location in the component.
383
- *
384
- * @param x The point to scroll to on the horizontal axis.
385
- * @param y The point to scroll to on the vertical axis.
386
- * @param duration The amount of time to take scrolling to that point. Defaults to `0`.
387
- */
388
- async scrollToPoint(x, y, duration = 0) {
389
- const el = await this.getScrollElement();
390
- if (duration < 32) {
391
- if (y != null) {
392
- el.scrollTop = y;
393
- }
394
- if (x != null) {
395
- el.scrollLeft = x;
396
- }
397
- return;
398
- }
399
- let resolve;
400
- let startTime = 0;
401
- const promise = new Promise((r) => (resolve = r));
402
- const fromY = el.scrollTop;
403
- const fromX = el.scrollLeft;
404
- const deltaY = y != null ? y - fromY : 0;
405
- const deltaX = x != null ? x - fromX : 0;
406
- // scroll loop
407
- const step = (timeStamp) => {
408
- const linearTime = Math.min(1, (timeStamp - startTime) / duration) - 1;
409
- const easedT = Math.pow(linearTime, 3) + 1;
410
- if (deltaY !== 0) {
411
- el.scrollTop = Math.floor(easedT * deltaY + fromY);
412
- }
413
- if (deltaX !== 0) {
414
- el.scrollLeft = Math.floor(easedT * deltaX + fromX);
415
- }
416
- if (easedT < 1) {
417
- // do not use DomController here
418
- // must use nativeRaf in order to fire in the next frame
419
- requestAnimationFrame(step);
420
- }
421
- else {
422
- resolve();
423
- }
424
- };
425
- // chill out for a frame first
426
- requestAnimationFrame((ts) => {
427
- startTime = ts;
428
- step(ts);
429
- });
430
- return promise;
431
- }
432
- onScrollStart() {
433
- this.isScrolling = true;
434
- this.ionScrollStart.emit({
435
- isScrolling: true,
436
- });
437
- if (this.watchDog) {
438
- clearInterval(this.watchDog);
346
+ async getBackgroundElement() {
347
+ if (!this.backgroundContentEl) {
348
+ await new Promise((resolve) => helpers.componentOnReady(this.el, resolve));
349
+ }
350
+ return Promise.resolve(this.backgroundContentEl);
439
351
  }
440
- // watchdog
441
- this.watchDog = setInterval(() => {
442
- if (this.lastScroll < Date.now() - 120) {
443
- this.onScrollEnd();
444
- }
445
- }, 100);
446
- }
447
- onScrollEnd() {
448
- if (this.watchDog)
449
- clearInterval(this.watchDog);
450
- this.watchDog = null;
451
- if (this.isScrolling) {
452
- this.isScrolling = false;
453
- this.ionScrollEnd.emit({
454
- isScrolling: false,
455
- });
456
- }
457
- }
458
- render() {
459
- const { isMainContent, scrollX, scrollY, el } = this;
460
- const rtl = dir.isRTL(el) ? 'rtl' : 'ltr';
461
- const mode = ionicGlobal.getIonMode(this);
462
- const forceOverscroll = this.shouldForceOverscroll();
463
- const transitionShadow = mode === 'ios';
464
- const TagType = isMainContent ? 'main' : 'div';
465
- this.resize();
466
- return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
467
- [mode]: true,
468
- 'content-sizing': theme.hostContext('ion-popover', this.el),
469
- overscroll: forceOverscroll,
470
- [`content-${rtl}`]: true,
471
- }), style: {
472
- '--offset-top': `${this.cTop}px`,
473
- '--offset-bottom': `${this.cBottom}px`,
474
- } }, index.h("div", { ref: (el) => (this.backgroundContentEl = el), id: "background-content", part: "background" }), index.h(TagType, { class: {
475
- 'inner-scroll': true,
476
- 'scroll-x': scrollX,
477
- 'scroll-y': scrollY,
478
- overscroll: (scrollX || scrollY) && forceOverscroll,
479
- }, ref: (scrollEl) => (this.scrollEl = scrollEl), onScroll: this.scrollEvents ? (ev) => this.onScroll(ev) : undefined, part: "scroll" }, index.h("slot", null)), transitionShadow ? (index.h("div", { class: "transition-effect" }, index.h("div", { class: "transition-cover" }), index.h("div", { class: "transition-shadow" }))) : null, index.h("slot", { name: "fixed" })));
480
- }
481
- get el() { return index.getElement(this); }
352
+ /**
353
+ * Scroll to the top of the component.
354
+ *
355
+ * @param duration The amount of time to take scrolling to the top. Defaults to `0`.
356
+ */
357
+ scrollToTop(duration = 0) {
358
+ return this.scrollToPoint(undefined, 0, duration);
359
+ }
360
+ /**
361
+ * Scroll to the bottom of the component.
362
+ *
363
+ * @param duration The amount of time to take scrolling to the bottom. Defaults to `0`.
364
+ */
365
+ async scrollToBottom(duration = 0) {
366
+ const scrollEl = await this.getScrollElement();
367
+ const y = scrollEl.scrollHeight - scrollEl.clientHeight;
368
+ return this.scrollToPoint(undefined, y, duration);
369
+ }
370
+ /**
371
+ * Scroll by a specified X/Y distance in the component.
372
+ *
373
+ * @param x The amount to scroll by on the horizontal axis.
374
+ * @param y The amount to scroll by on the vertical axis.
375
+ * @param duration The amount of time to take scrolling by that amount.
376
+ */
377
+ async scrollByPoint(x, y, duration) {
378
+ const scrollEl = await this.getScrollElement();
379
+ return this.scrollToPoint(x + scrollEl.scrollLeft, y + scrollEl.scrollTop, duration);
380
+ }
381
+ /**
382
+ * Scroll to a specified X/Y location in the component.
383
+ *
384
+ * @param x The point to scroll to on the horizontal axis.
385
+ * @param y The point to scroll to on the vertical axis.
386
+ * @param duration The amount of time to take scrolling to that point. Defaults to `0`.
387
+ */
388
+ async scrollToPoint(x, y, duration = 0) {
389
+ const el = await this.getScrollElement();
390
+ if (duration < 32) {
391
+ if (y != null) {
392
+ el.scrollTop = y;
393
+ }
394
+ if (x != null) {
395
+ el.scrollLeft = x;
396
+ }
397
+ return;
398
+ }
399
+ let resolve;
400
+ let startTime = 0;
401
+ const promise = new Promise((r) => (resolve = r));
402
+ const fromY = el.scrollTop;
403
+ const fromX = el.scrollLeft;
404
+ const deltaY = y != null ? y - fromY : 0;
405
+ const deltaX = x != null ? x - fromX : 0;
406
+ // scroll loop
407
+ const step = (timeStamp) => {
408
+ const linearTime = Math.min(1, (timeStamp - startTime) / duration) - 1;
409
+ const easedT = Math.pow(linearTime, 3) + 1;
410
+ if (deltaY !== 0) {
411
+ el.scrollTop = Math.floor(easedT * deltaY + fromY);
412
+ }
413
+ if (deltaX !== 0) {
414
+ el.scrollLeft = Math.floor(easedT * deltaX + fromX);
415
+ }
416
+ if (easedT < 1) {
417
+ // do not use DomController here
418
+ // must use nativeRaf in order to fire in the next frame
419
+ requestAnimationFrame(step);
420
+ }
421
+ else {
422
+ resolve();
423
+ }
424
+ };
425
+ // chill out for a frame first
426
+ requestAnimationFrame((ts) => {
427
+ startTime = ts;
428
+ step(ts);
429
+ });
430
+ return promise;
431
+ }
432
+ onScrollStart() {
433
+ this.isScrolling = true;
434
+ this.ionScrollStart.emit({
435
+ isScrolling: true,
436
+ });
437
+ if (this.watchDog) {
438
+ clearInterval(this.watchDog);
439
+ }
440
+ // watchdog
441
+ this.watchDog = setInterval(() => {
442
+ if (this.lastScroll < Date.now() - 120) {
443
+ this.onScrollEnd();
444
+ }
445
+ }, 100);
446
+ }
447
+ onScrollEnd() {
448
+ if (this.watchDog)
449
+ clearInterval(this.watchDog);
450
+ this.watchDog = null;
451
+ if (this.isScrolling) {
452
+ this.isScrolling = false;
453
+ this.ionScrollEnd.emit({
454
+ isScrolling: false,
455
+ });
456
+ }
457
+ }
458
+ render() {
459
+ const { isMainContent, scrollX, scrollY, el } = this;
460
+ const rtl = dir.isRTL(el) ? 'rtl' : 'ltr';
461
+ const mode = ionicGlobal.getIonMode(this);
462
+ const forceOverscroll = this.shouldForceOverscroll();
463
+ const transitionShadow = mode === 'ios';
464
+ const TagType = isMainContent ? 'main' : 'div';
465
+ this.resize();
466
+ return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
467
+ [mode]: true,
468
+ 'content-sizing': theme.hostContext('ion-popover', this.el),
469
+ overscroll: forceOverscroll,
470
+ [`content-${rtl}`]: true,
471
+ }), style: {
472
+ '--offset-top': `${this.cTop}px`,
473
+ '--offset-bottom': `${this.cBottom}px`,
474
+ } }, index.h("div", { ref: (el) => (this.backgroundContentEl = el), id: "background-content", part: "background" }), index.h(TagType, { class: {
475
+ 'inner-scroll': true,
476
+ 'scroll-x': scrollX,
477
+ 'scroll-y': scrollY,
478
+ overscroll: (scrollX || scrollY) && forceOverscroll,
479
+ }, ref: (scrollEl) => (this.scrollEl = scrollEl), onScroll: this.scrollEvents ? (ev) => this.onScroll(ev) : undefined, part: "scroll" }, index.h("slot", null)), transitionShadow ? (index.h("div", { class: "transition-effect" }, index.h("div", { class: "transition-cover" }), index.h("div", { class: "transition-shadow" }))) : null, index.h("slot", { name: "fixed" })));
480
+ }
481
+ get el() { return index.getElement(this); }
482
482
  };
483
483
  const getParentElement = (el) => {
484
- var _a;
485
- if (el.parentElement) {
486
- // normal element with a parent element
487
- return el.parentElement;
488
- }
489
- if ((_a = el.parentNode) === null || _a === void 0 ? void 0 : _a.host) {
490
- // shadow dom's document fragment
491
- return el.parentNode.host;
492
- }
493
- return null;
484
+ var _a;
485
+ if (el.parentElement) {
486
+ // normal element with a parent element
487
+ return el.parentElement;
488
+ }
489
+ if ((_a = el.parentNode) === null || _a === void 0 ? void 0 : _a.host) {
490
+ // shadow dom's document fragment
491
+ return el.parentNode.host;
492
+ }
493
+ return null;
494
494
  };
495
495
  const getPageElement = (el) => {
496
- const tabs = el.closest('ion-tabs');
497
- if (tabs) {
498
- return tabs;
499
- }
500
- /**
501
- * If we're in a popover, we need to use its wrapper so we can account for space
502
- * between the popover and the edges of the screen. But if the popover contains
503
- * its own page element, we should use that instead.
504
- */
505
- const page = el.closest('ion-app, ion-page, .ion-page, page-inner, .popover-content');
506
- if (page) {
507
- return page;
508
- }
509
- return getParentElement(el);
496
+ const tabs = el.closest('ion-tabs');
497
+ if (tabs) {
498
+ return tabs;
499
+ }
500
+ /**
501
+ * If we're in a popover, we need to use its wrapper so we can account for space
502
+ * between the popover and the edges of the screen. But if the popover contains
503
+ * its own page element, we should use that instead.
504
+ */
505
+ const page = el.closest('ion-app, ion-page, .ion-page, page-inner, .popover-content');
506
+ if (page) {
507
+ return page;
508
+ }
509
+ return getParentElement(el);
510
510
  };
511
511
  // ******** DOM READ ****************
512
512
  const updateScrollDetail = (detail, el, timestamp, shouldStart) => {
513
- const prevX = detail.currentX;
514
- const prevY = detail.currentY;
515
- const prevT = detail.currentTime;
516
- const currentX = el.scrollLeft;
517
- const currentY = el.scrollTop;
518
- const timeDelta = timestamp - prevT;
519
- if (shouldStart) {
520
- // remember the start positions
521
- detail.startTime = timestamp;
522
- detail.startX = currentX;
523
- detail.startY = currentY;
524
- detail.velocityX = detail.velocityY = 0;
525
- }
526
- detail.currentTime = timestamp;
527
- detail.currentX = detail.scrollLeft = currentX;
528
- detail.currentY = detail.scrollTop = currentY;
529
- detail.deltaX = currentX - detail.startX;
530
- detail.deltaY = currentY - detail.startY;
531
- if (timeDelta > 0 && timeDelta < 100) {
532
- const velocityX = (currentX - prevX) / timeDelta;
533
- const velocityY = (currentY - prevY) / timeDelta;
534
- detail.velocityX = velocityX * 0.7 + detail.velocityX * 0.3;
535
- detail.velocityY = velocityY * 0.7 + detail.velocityY * 0.3;
536
- }
513
+ const prevX = detail.currentX;
514
+ const prevY = detail.currentY;
515
+ const prevT = detail.currentTime;
516
+ const currentX = el.scrollLeft;
517
+ const currentY = el.scrollTop;
518
+ const timeDelta = timestamp - prevT;
519
+ if (shouldStart) {
520
+ // remember the start positions
521
+ detail.startTime = timestamp;
522
+ detail.startX = currentX;
523
+ detail.startY = currentY;
524
+ detail.velocityX = detail.velocityY = 0;
525
+ }
526
+ detail.currentTime = timestamp;
527
+ detail.currentX = detail.scrollLeft = currentX;
528
+ detail.currentY = detail.scrollTop = currentY;
529
+ detail.deltaX = currentX - detail.startX;
530
+ detail.deltaY = currentY - detail.startY;
531
+ if (timeDelta > 0 && timeDelta < 100) {
532
+ const velocityX = (currentX - prevX) / timeDelta;
533
+ const velocityY = (currentY - prevY) / timeDelta;
534
+ detail.velocityX = velocityX * 0.7 + detail.velocityX * 0.3;
535
+ detail.velocityY = velocityY * 0.7 + detail.velocityY * 0.3;
536
+ }
537
537
  };
538
538
  Content.style = contentCss;
539
539
 
540
540
  const handleFooterFade = (scrollEl, baseEl) => {
541
- index.readTask(() => {
542
- const scrollTop = scrollEl.scrollTop;
543
- const maxScroll = scrollEl.scrollHeight - scrollEl.clientHeight;
544
- /**
545
- * Toolbar background will fade
546
- * out over fadeDuration in pixels.
547
- */
548
- const fadeDuration = 10;
549
- /**
550
- * Begin fading out maxScroll - 30px
551
- * from the bottom of the content.
552
- * Also determine how close we are
553
- * to starting the fade. If we are
554
- * before the starting point, the
555
- * scale value will get clamped to 0.
556
- * If we are after the maxScroll (rubber
557
- * band scrolling), the scale value will
558
- * get clamped to 1.
559
- */
560
- const fadeStart = maxScroll - fadeDuration;
561
- const distanceToStart = scrollTop - fadeStart;
562
- const scale = helpers.clamp(0, 1 - distanceToStart / fadeDuration, 1);
563
- index.writeTask(() => {
564
- baseEl.style.setProperty('--opacity-scale', scale.toString());
541
+ index.readTask(() => {
542
+ const scrollTop = scrollEl.scrollTop;
543
+ const maxScroll = scrollEl.scrollHeight - scrollEl.clientHeight;
544
+ /**
545
+ * Toolbar background will fade
546
+ * out over fadeDuration in pixels.
547
+ */
548
+ const fadeDuration = 10;
549
+ /**
550
+ * Begin fading out maxScroll - 30px
551
+ * from the bottom of the content.
552
+ * Also determine how close we are
553
+ * to starting the fade. If we are
554
+ * before the starting point, the
555
+ * scale value will get clamped to 0.
556
+ * If we are after the maxScroll (rubber
557
+ * band scrolling), the scale value will
558
+ * get clamped to 1.
559
+ */
560
+ const fadeStart = maxScroll - fadeDuration;
561
+ const distanceToStart = scrollTop - fadeStart;
562
+ const scale = helpers.clamp(0, 1 - distanceToStart / fadeDuration, 1);
563
+ index.writeTask(() => {
564
+ baseEl.style.setProperty('--opacity-scale', scale.toString());
565
+ });
565
566
  });
566
- });
567
567
  };
568
568
 
569
569
  const footerIosCss = "ion-footer{display:block;position:relative;-ms-flex-order:1;order:1;width:100%;z-index:10}ion-footer.footer-toolbar-padding ion-toolbar:last-of-type{padding-bottom:var(--ion-safe-area-bottom, 0)}.footer-ios ion-toolbar:first-of-type{--border-width:0.55px 0 0}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){.footer-background{left:0;right:0;top:0;bottom:0;position:absolute;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}.footer-translucent-ios ion-toolbar{--opacity:.8}}.footer-ios.ion-no-border ion-toolbar:first-of-type{--border-width:0}.footer-collapse-fade ion-toolbar{--opacity-scale:inherit}";
@@ -571,172 +571,172 @@ const footerIosCss = "ion-footer{display:block;position:relative;-ms-flex-order:
571
571
  const footerMdCss = "ion-footer{display:block;position:relative;-ms-flex-order:1;order:1;width:100%;z-index:10}ion-footer.footer-toolbar-padding ion-toolbar:last-of-type{padding-bottom:var(--ion-safe-area-bottom, 0)}.footer-md{-webkit-box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12);box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12)}.footer-md.ion-no-border{-webkit-box-shadow:none;box-shadow:none}";
572
572
 
573
573
  const Footer = class {
574
- constructor(hostRef) {
575
- index.registerInstance(this, hostRef);
576
- this.keyboardCtrl = null;
577
- this.checkCollapsibleFooter = () => {
578
- const mode = ionicGlobal.getIonMode(this);
579
- if (mode !== 'ios') {
580
- return;
581
- }
582
- const { collapse } = this;
583
- const hasFade = collapse === 'fade';
584
- this.destroyCollapsibleFooter();
585
- if (hasFade) {
586
- const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
587
- const contentEl = pageEl ? index$1.findIonContent(pageEl) : null;
588
- if (!contentEl) {
589
- index$1.printIonContentErrorMsg(this.el);
590
- return;
574
+ constructor(hostRef) {
575
+ index.registerInstance(this, hostRef);
576
+ this.keyboardCtrl = null;
577
+ this.checkCollapsibleFooter = () => {
578
+ const mode = ionicGlobal.getIonMode(this);
579
+ if (mode !== 'ios') {
580
+ return;
581
+ }
582
+ const { collapse } = this;
583
+ const hasFade = collapse === 'fade';
584
+ this.destroyCollapsibleFooter();
585
+ if (hasFade) {
586
+ const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
587
+ const contentEl = pageEl ? index$1.findIonContent(pageEl) : null;
588
+ if (!contentEl) {
589
+ index$1.printIonContentErrorMsg(this.el);
590
+ return;
591
+ }
592
+ this.setupFadeFooter(contentEl);
593
+ }
594
+ };
595
+ this.setupFadeFooter = async (contentEl) => {
596
+ const scrollEl = (this.scrollEl = await index$1.getScrollElement(contentEl));
597
+ /**
598
+ * Handle fading of toolbars on scroll
599
+ */
600
+ this.contentScrollCallback = () => {
601
+ handleFooterFade(scrollEl, this.el);
602
+ };
603
+ scrollEl.addEventListener('scroll', this.contentScrollCallback);
604
+ handleFooterFade(scrollEl, this.el);
605
+ };
606
+ this.keyboardVisible = false;
607
+ this.collapse = undefined;
608
+ this.translucent = false;
609
+ }
610
+ componentDidLoad() {
611
+ this.checkCollapsibleFooter();
612
+ }
613
+ componentDidUpdate() {
614
+ this.checkCollapsibleFooter();
615
+ }
616
+ async connectedCallback() {
617
+ this.keyboardCtrl = await keyboardController.createKeyboardController(async (keyboardOpen, waitForResize) => {
618
+ /**
619
+ * If the keyboard is hiding, then we need to wait
620
+ * for the webview to resize. Otherwise, the footer
621
+ * will flicker before the webview resizes.
622
+ */
623
+ if (keyboardOpen === false && waitForResize !== undefined) {
624
+ await waitForResize;
625
+ }
626
+ this.keyboardVisible = keyboardOpen; // trigger re-render by updating state
627
+ });
628
+ }
629
+ disconnectedCallback() {
630
+ if (this.keyboardCtrl) {
631
+ this.keyboardCtrl.destroy();
591
632
  }
592
- this.setupFadeFooter(contentEl);
593
- }
594
- };
595
- this.setupFadeFooter = async (contentEl) => {
596
- const scrollEl = (this.scrollEl = await index$1.getScrollElement(contentEl));
597
- /**
598
- * Handle fading of toolbars on scroll
599
- */
600
- this.contentScrollCallback = () => {
601
- handleFooterFade(scrollEl, this.el);
602
- };
603
- scrollEl.addEventListener('scroll', this.contentScrollCallback);
604
- handleFooterFade(scrollEl, this.el);
605
- };
606
- this.keyboardVisible = false;
607
- this.collapse = undefined;
608
- this.translucent = false;
609
- }
610
- componentDidLoad() {
611
- this.checkCollapsibleFooter();
612
- }
613
- componentDidUpdate() {
614
- this.checkCollapsibleFooter();
615
- }
616
- async connectedCallback() {
617
- this.keyboardCtrl = await keyboardController.createKeyboardController(async (keyboardOpen, waitForResize) => {
618
- /**
619
- * If the keyboard is hiding, then we need to wait
620
- * for the webview to resize. Otherwise, the footer
621
- * will flicker before the webview resizes.
622
- */
623
- if (keyboardOpen === false && waitForResize !== undefined) {
624
- await waitForResize;
625
- }
626
- this.keyboardVisible = keyboardOpen; // trigger re-render by updating state
627
- });
628
- }
629
- disconnectedCallback() {
630
- if (this.keyboardCtrl) {
631
- this.keyboardCtrl.destroy();
632
- }
633
- }
634
- destroyCollapsibleFooter() {
635
- if (this.scrollEl && this.contentScrollCallback) {
636
- this.scrollEl.removeEventListener('scroll', this.contentScrollCallback);
637
- this.contentScrollCallback = undefined;
638
- }
639
- }
640
- render() {
641
- const { translucent, collapse } = this;
642
- const mode = ionicGlobal.getIonMode(this);
643
- const tabs = this.el.closest('ion-tabs');
644
- const tabBar = tabs === null || tabs === void 0 ? void 0 : tabs.querySelector(':scope > ion-tab-bar');
645
- return (index.h(index.Host, { role: "contentinfo", class: {
646
- [mode]: true,
647
- // Used internally for styling
648
- [`footer-${mode}`]: true,
649
- [`footer-translucent`]: translucent,
650
- [`footer-translucent-${mode}`]: translucent,
651
- ['footer-toolbar-padding']: !this.keyboardVisible && (!tabBar || tabBar.slot !== 'bottom'),
652
- [`footer-collapse-${collapse}`]: collapse !== undefined,
653
- } }, mode === 'ios' && translucent && index.h("div", { class: "footer-background" }), index.h("slot", null)));
654
- }
655
- get el() { return index.getElement(this); }
633
+ }
634
+ destroyCollapsibleFooter() {
635
+ if (this.scrollEl && this.contentScrollCallback) {
636
+ this.scrollEl.removeEventListener('scroll', this.contentScrollCallback);
637
+ this.contentScrollCallback = undefined;
638
+ }
639
+ }
640
+ render() {
641
+ const { translucent, collapse } = this;
642
+ const mode = ionicGlobal.getIonMode(this);
643
+ const tabs = this.el.closest('ion-tabs');
644
+ const tabBar = tabs === null || tabs === void 0 ? void 0 : tabs.querySelector(':scope > ion-tab-bar');
645
+ return (index.h(index.Host, { role: "contentinfo", class: {
646
+ [mode]: true,
647
+ // Used internally for styling
648
+ [`footer-${mode}`]: true,
649
+ [`footer-translucent`]: translucent,
650
+ [`footer-translucent-${mode}`]: translucent,
651
+ ['footer-toolbar-padding']: !this.keyboardVisible && (!tabBar || tabBar.slot !== 'bottom'),
652
+ [`footer-collapse-${collapse}`]: collapse !== undefined,
653
+ } }, mode === 'ios' && translucent && index.h("div", { class: "footer-background" }), index.h("slot", null)));
654
+ }
655
+ get el() { return index.getElement(this); }
656
656
  };
657
657
  Footer.style = {
658
- ios: footerIosCss,
659
- md: footerMdCss
658
+ ios: footerIosCss,
659
+ md: footerMdCss
660
660
  };
661
661
 
662
662
  const TRANSITION = 'all 0.2s ease-in-out';
663
663
  const cloneElement = (tagName) => {
664
- const getCachedEl = document.querySelector(`${tagName}.ion-cloned-element`);
665
- if (getCachedEl !== null) {
666
- return getCachedEl;
667
- }
668
- const clonedEl = document.createElement(tagName);
669
- clonedEl.classList.add('ion-cloned-element');
670
- clonedEl.style.setProperty('display', 'none');
671
- document.body.appendChild(clonedEl);
672
- return clonedEl;
664
+ const getCachedEl = document.querySelector(`${tagName}.ion-cloned-element`);
665
+ if (getCachedEl !== null) {
666
+ return getCachedEl;
667
+ }
668
+ const clonedEl = document.createElement(tagName);
669
+ clonedEl.classList.add('ion-cloned-element');
670
+ clonedEl.style.setProperty('display', 'none');
671
+ document.body.appendChild(clonedEl);
672
+ return clonedEl;
673
673
  };
674
674
  const createHeaderIndex = (headerEl) => {
675
- if (!headerEl) {
676
- return;
677
- }
678
- const toolbars = headerEl.querySelectorAll('ion-toolbar');
679
- return {
680
- el: headerEl,
681
- toolbars: Array.from(toolbars).map((toolbar) => {
682
- const ionTitleEl = toolbar.querySelector('ion-title');
683
- return {
684
- el: toolbar,
685
- background: toolbar.shadowRoot.querySelector('.toolbar-background'),
686
- ionTitleEl,
687
- innerTitleEl: ionTitleEl ? ionTitleEl.shadowRoot.querySelector('.toolbar-title') : null,
688
- ionButtonsEl: Array.from(toolbar.querySelectorAll('ion-buttons')),
689
- };
690
- }),
691
- };
675
+ if (!headerEl) {
676
+ return;
677
+ }
678
+ const toolbars = headerEl.querySelectorAll('ion-toolbar');
679
+ return {
680
+ el: headerEl,
681
+ toolbars: Array.from(toolbars).map((toolbar) => {
682
+ const ionTitleEl = toolbar.querySelector('ion-title');
683
+ return {
684
+ el: toolbar,
685
+ background: toolbar.shadowRoot.querySelector('.toolbar-background'),
686
+ ionTitleEl,
687
+ innerTitleEl: ionTitleEl ? ionTitleEl.shadowRoot.querySelector('.toolbar-title') : null,
688
+ ionButtonsEl: Array.from(toolbar.querySelectorAll('ion-buttons')),
689
+ };
690
+ }),
691
+ };
692
692
  };
693
693
  const handleContentScroll = (scrollEl, scrollHeaderIndex, contentEl) => {
694
- index.readTask(() => {
695
- const scrollTop = scrollEl.scrollTop;
696
- const scale = helpers.clamp(1, 1 + -scrollTop / 500, 1.1);
697
- // Native refresher should not cause titles to scale
698
- const nativeRefresher = contentEl.querySelector('ion-refresher.refresher-native');
699
- if (nativeRefresher === null) {
700
- index.writeTask(() => {
701
- scaleLargeTitles(scrollHeaderIndex.toolbars, scale);
702
- });
703
- }
704
- });
694
+ index.readTask(() => {
695
+ const scrollTop = scrollEl.scrollTop;
696
+ const scale = helpers.clamp(1, 1 + -scrollTop / 500, 1.1);
697
+ // Native refresher should not cause titles to scale
698
+ const nativeRefresher = contentEl.querySelector('ion-refresher.refresher-native');
699
+ if (nativeRefresher === null) {
700
+ index.writeTask(() => {
701
+ scaleLargeTitles(scrollHeaderIndex.toolbars, scale);
702
+ });
703
+ }
704
+ });
705
705
  };
706
706
  const setToolbarBackgroundOpacity = (headerEl, opacity) => {
707
- /**
708
- * Fading in the backdrop opacity
709
- * should happen after the large title
710
- * has collapsed, so it is handled
711
- * by handleHeaderFade()
712
- */
713
- if (headerEl.collapse === 'fade') {
714
- return;
715
- }
716
- if (opacity === undefined) {
717
- headerEl.style.removeProperty('--opacity-scale');
718
- }
719
- else {
720
- headerEl.style.setProperty('--opacity-scale', opacity.toString());
721
- }
707
+ /**
708
+ * Fading in the backdrop opacity
709
+ * should happen after the large title
710
+ * has collapsed, so it is handled
711
+ * by handleHeaderFade()
712
+ */
713
+ if (headerEl.collapse === 'fade') {
714
+ return;
715
+ }
716
+ if (opacity === undefined) {
717
+ headerEl.style.removeProperty('--opacity-scale');
718
+ }
719
+ else {
720
+ headerEl.style.setProperty('--opacity-scale', opacity.toString());
721
+ }
722
722
  };
723
723
  const handleToolbarBorderIntersection = (ev, mainHeaderIndex, scrollTop) => {
724
- if (!ev[0].isIntersecting) {
725
- return;
726
- }
727
- /**
728
- * There is a bug in Safari where overflow scrolling on a non-body element
729
- * does not always reset the scrollTop position to 0 when letting go. It will
730
- * set to 1 once the rubber band effect has ended. This causes the background to
731
- * appear slightly on certain app setups.
732
- *
733
- * Additionally, we check if user is rubber banding (scrolling is negative)
734
- * as this can mean they are using pull to refresh. Once the refresher starts,
735
- * the content is transformed which can cause the intersection observer to erroneously
736
- * fire here as well.
737
- */
738
- const scale = ev[0].intersectionRatio > 0.9 || scrollTop <= 0 ? 0 : ((1 - ev[0].intersectionRatio) * 100) / 75;
739
- setToolbarBackgroundOpacity(mainHeaderIndex.el, scale === 1 ? undefined : scale);
724
+ if (!ev[0].isIntersecting) {
725
+ return;
726
+ }
727
+ /**
728
+ * There is a bug in Safari where overflow scrolling on a non-body element
729
+ * does not always reset the scrollTop position to 0 when letting go. It will
730
+ * set to 1 once the rubber band effect has ended. This causes the background to
731
+ * appear slightly on certain app setups.
732
+ *
733
+ * Additionally, we check if user is rubber banding (scrolling is negative)
734
+ * as this can mean they are using pull to refresh. Once the refresher starts,
735
+ * the content is transformed which can cause the intersection observer to erroneously
736
+ * fire here as well.
737
+ */
738
+ const scale = ev[0].intersectionRatio > 0.9 || scrollTop <= 0 ? 0 : ((1 - ev[0].intersectionRatio) * 100) / 75;
739
+ setToolbarBackgroundOpacity(mainHeaderIndex.el, scale === 1 ? undefined : scale);
740
740
  };
741
741
  /**
742
742
  * If toolbars are intersecting, hide the scrollable toolbar content
@@ -745,94 +745,94 @@ const handleToolbarBorderIntersection = (ev, mainHeaderIndex, scrollTop) => {
745
745
  */
746
746
  const handleToolbarIntersection = (ev, // TODO(FW-2832): type (IntersectionObserverEntry[] triggers errors which should be sorted)
747
747
  mainHeaderIndex, scrollHeaderIndex, scrollEl) => {
748
- index.writeTask(() => {
749
- const scrollTop = scrollEl.scrollTop;
750
- handleToolbarBorderIntersection(ev, mainHeaderIndex, scrollTop);
751
- const event = ev[0];
752
- const intersection = event.intersectionRect;
753
- const intersectionArea = intersection.width * intersection.height;
754
- const rootArea = event.rootBounds.width * event.rootBounds.height;
755
- const isPageHidden = intersectionArea === 0 && rootArea === 0;
756
- const leftDiff = Math.abs(intersection.left - event.boundingClientRect.left);
757
- const rightDiff = Math.abs(intersection.right - event.boundingClientRect.right);
758
- const isPageTransitioning = intersectionArea > 0 && (leftDiff >= 5 || rightDiff >= 5);
759
- if (isPageHidden || isPageTransitioning) {
760
- return;
761
- }
762
- if (event.isIntersecting) {
763
- setHeaderActive(mainHeaderIndex, false);
764
- setHeaderActive(scrollHeaderIndex);
765
- }
766
- else {
767
- /**
768
- * There is a bug with IntersectionObserver on Safari
769
- * where `event.isIntersecting === false` when cancelling
770
- * a swipe to go back gesture. Checking the intersection
771
- * x, y, width, and height provides a workaround. This bug
772
- * does not happen when using Safari + Web Animations,
773
- * only Safari + CSS Animations.
774
- */
775
- const hasValidIntersection = (intersection.x === 0 && intersection.y === 0) || (intersection.width !== 0 && intersection.height !== 0);
776
- if (hasValidIntersection && scrollTop > 0) {
777
- setHeaderActive(mainHeaderIndex);
778
- setHeaderActive(scrollHeaderIndex, false);
779
- setToolbarBackgroundOpacity(mainHeaderIndex.el);
780
- }
781
- }
782
- });
748
+ index.writeTask(() => {
749
+ const scrollTop = scrollEl.scrollTop;
750
+ handleToolbarBorderIntersection(ev, mainHeaderIndex, scrollTop);
751
+ const event = ev[0];
752
+ const intersection = event.intersectionRect;
753
+ const intersectionArea = intersection.width * intersection.height;
754
+ const rootArea = event.rootBounds.width * event.rootBounds.height;
755
+ const isPageHidden = intersectionArea === 0 && rootArea === 0;
756
+ const leftDiff = Math.abs(intersection.left - event.boundingClientRect.left);
757
+ const rightDiff = Math.abs(intersection.right - event.boundingClientRect.right);
758
+ const isPageTransitioning = intersectionArea > 0 && (leftDiff >= 5 || rightDiff >= 5);
759
+ if (isPageHidden || isPageTransitioning) {
760
+ return;
761
+ }
762
+ if (event.isIntersecting) {
763
+ setHeaderActive(mainHeaderIndex, false);
764
+ setHeaderActive(scrollHeaderIndex);
765
+ }
766
+ else {
767
+ /**
768
+ * There is a bug with IntersectionObserver on Safari
769
+ * where `event.isIntersecting === false` when cancelling
770
+ * a swipe to go back gesture. Checking the intersection
771
+ * x, y, width, and height provides a workaround. This bug
772
+ * does not happen when using Safari + Web Animations,
773
+ * only Safari + CSS Animations.
774
+ */
775
+ const hasValidIntersection = (intersection.x === 0 && intersection.y === 0) || (intersection.width !== 0 && intersection.height !== 0);
776
+ if (hasValidIntersection && scrollTop > 0) {
777
+ setHeaderActive(mainHeaderIndex);
778
+ setHeaderActive(scrollHeaderIndex, false);
779
+ setToolbarBackgroundOpacity(mainHeaderIndex.el);
780
+ }
781
+ }
782
+ });
783
783
  };
784
784
  const setHeaderActive = (headerIndex, active = true) => {
785
- const headerEl = headerIndex.el;
786
- if (active) {
787
- headerEl.classList.remove('header-collapse-condense-inactive');
788
- headerEl.removeAttribute('aria-hidden');
789
- }
790
- else {
791
- headerEl.classList.add('header-collapse-condense-inactive');
792
- headerEl.setAttribute('aria-hidden', 'true');
793
- }
785
+ const headerEl = headerIndex.el;
786
+ if (active) {
787
+ headerEl.classList.remove('header-collapse-condense-inactive');
788
+ headerEl.removeAttribute('aria-hidden');
789
+ }
790
+ else {
791
+ headerEl.classList.add('header-collapse-condense-inactive');
792
+ headerEl.setAttribute('aria-hidden', 'true');
793
+ }
794
794
  };
795
795
  const scaleLargeTitles = (toolbars = [], scale = 1, transition = false) => {
796
- toolbars.forEach((toolbar) => {
797
- const ionTitle = toolbar.ionTitleEl;
798
- const titleDiv = toolbar.innerTitleEl;
799
- if (!ionTitle || ionTitle.size !== 'large') {
800
- return;
801
- }
802
- titleDiv.style.transition = transition ? TRANSITION : '';
803
- titleDiv.style.transform = `scale3d(${scale}, ${scale}, 1)`;
804
- });
796
+ toolbars.forEach((toolbar) => {
797
+ const ionTitle = toolbar.ionTitleEl;
798
+ const titleDiv = toolbar.innerTitleEl;
799
+ if (!ionTitle || ionTitle.size !== 'large') {
800
+ return;
801
+ }
802
+ titleDiv.style.transition = transition ? TRANSITION : '';
803
+ titleDiv.style.transform = `scale3d(${scale}, ${scale}, 1)`;
804
+ });
805
805
  };
806
806
  const handleHeaderFade = (scrollEl, baseEl, condenseHeader) => {
807
- index.readTask(() => {
808
- const scrollTop = scrollEl.scrollTop;
809
- const baseElHeight = baseEl.clientHeight;
810
- const fadeStart = condenseHeader ? condenseHeader.clientHeight : 0;
811
- /**
812
- * If we are using fade header with a condense
813
- * header, then the toolbar backgrounds should
814
- * not begin to fade in until the condense
815
- * header has fully collapsed.
816
- *
817
- * Additionally, the main content should not
818
- * overflow out of the container until the
819
- * condense header has fully collapsed. When
820
- * using just the condense header the content
821
- * should overflow out of the container.
822
- */
823
- if (condenseHeader !== null && scrollTop < fadeStart) {
824
- baseEl.style.setProperty('--opacity-scale', '0');
825
- scrollEl.style.setProperty('clip-path', `inset(${baseElHeight}px 0px 0px 0px)`);
826
- return;
827
- }
828
- const distanceToStart = scrollTop - fadeStart;
829
- const fadeDuration = 10;
830
- const scale = helpers.clamp(0, distanceToStart / fadeDuration, 1);
831
- index.writeTask(() => {
832
- scrollEl.style.removeProperty('clip-path');
833
- baseEl.style.setProperty('--opacity-scale', scale.toString());
807
+ index.readTask(() => {
808
+ const scrollTop = scrollEl.scrollTop;
809
+ const baseElHeight = baseEl.clientHeight;
810
+ const fadeStart = condenseHeader ? condenseHeader.clientHeight : 0;
811
+ /**
812
+ * If we are using fade header with a condense
813
+ * header, then the toolbar backgrounds should
814
+ * not begin to fade in until the condense
815
+ * header has fully collapsed.
816
+ *
817
+ * Additionally, the main content should not
818
+ * overflow out of the container until the
819
+ * condense header has fully collapsed. When
820
+ * using just the condense header the content
821
+ * should overflow out of the container.
822
+ */
823
+ if (condenseHeader !== null && scrollTop < fadeStart) {
824
+ baseEl.style.setProperty('--opacity-scale', '0');
825
+ scrollEl.style.setProperty('clip-path', `inset(${baseElHeight}px 0px 0px 0px)`);
826
+ return;
827
+ }
828
+ const distanceToStart = scrollTop - fadeStart;
829
+ const fadeDuration = 10;
830
+ const scale = helpers.clamp(0, distanceToStart / fadeDuration, 1);
831
+ index.writeTask(() => {
832
+ scrollEl.style.removeProperty('clip-path');
833
+ baseEl.style.setProperty('--opacity-scale', scale.toString());
834
+ });
834
835
  });
835
- });
836
836
  };
837
837
 
838
838
  const headerIosCss = "ion-header{display:block;position:relative;-ms-flex-order:-1;order:-1;width:100%;z-index:10}ion-header ion-toolbar:first-of-type{padding-top:var(--ion-safe-area-top, 0)}.header-ios ion-toolbar:last-of-type{--border-width:0 0 0.55px}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){.header-background{left:0;right:0;top:0;bottom:0;position:absolute;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}.header-translucent-ios ion-toolbar{--opacity:.8}.header-collapse-condense-inactive .header-background{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}}.header-ios.ion-no-border ion-toolbar:last-of-type{--border-width:0}.header-collapse-fade ion-toolbar{--opacity-scale:inherit}.header-collapse-condense{z-index:9}.header-collapse-condense ion-toolbar{position:-webkit-sticky;position:sticky;top:0}.header-collapse-condense ion-toolbar:first-of-type{padding-top:0px;z-index:1}.header-collapse-condense ion-toolbar{--background:var(--ion-background-color, #fff);z-index:0}.header-collapse-condense ion-toolbar:last-of-type{--border-width:0px}.header-collapse-condense ion-toolbar ion-searchbar{padding-top:0px;padding-bottom:13px}.header-collapse-main{--opacity-scale:1}.header-collapse-main ion-toolbar{--opacity-scale:inherit}.header-collapse-main ion-toolbar.in-toolbar ion-title,.header-collapse-main ion-toolbar.in-toolbar ion-buttons{-webkit-transition:all 0.2s ease-in-out;transition:all 0.2s ease-in-out}.header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-title,.header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-buttons.buttons-collapse{opacity:0;pointer-events:none}.header-collapse-condense-inactive.header-collapse-condense ion-toolbar.in-toolbar ion-title,.header-collapse-condense-inactive.header-collapse-condense ion-toolbar.in-toolbar ion-buttons.buttons-collapse{visibility:hidden}ion-header:not(.header-collapse-main):has(~ion-content ion-header[collapse=condense],~ion-content ion-header.header-collapse-condense){opacity:0}";
@@ -840,333 +840,333 @@ const headerIosCss = "ion-header{display:block;position:relative;-ms-flex-order:
840
840
  const headerMdCss = "ion-header{display:block;position:relative;-ms-flex-order:-1;order:-1;width:100%;z-index:10}ion-header ion-toolbar:first-of-type{padding-top:var(--ion-safe-area-top, 0)}.header-md{-webkit-box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12);box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12)}.header-collapse-condense{display:none}.header-md.ion-no-border{-webkit-box-shadow:none;box-shadow:none}";
841
841
 
842
842
  const Header = class {
843
- constructor(hostRef) {
844
- index.registerInstance(this, hostRef);
845
- this.inheritedAttributes = {};
846
- this.setupFadeHeader = async (contentEl, condenseHeader) => {
847
- const scrollEl = (this.scrollEl = await index$1.getScrollElement(contentEl));
848
- /**
849
- * Handle fading of toolbars on scroll
850
- */
851
- this.contentScrollCallback = () => {
852
- handleHeaderFade(this.scrollEl, this.el, condenseHeader);
853
- };
854
- scrollEl.addEventListener('scroll', this.contentScrollCallback);
855
- handleHeaderFade(this.scrollEl, this.el, condenseHeader);
856
- };
857
- this.collapse = undefined;
858
- this.translucent = false;
859
- }
860
- componentWillLoad() {
861
- this.inheritedAttributes = helpers.inheritAriaAttributes(this.el);
862
- }
863
- componentDidLoad() {
864
- this.checkCollapsibleHeader();
865
- }
866
- componentDidUpdate() {
867
- this.checkCollapsibleHeader();
868
- }
869
- disconnectedCallback() {
870
- this.destroyCollapsibleHeader();
871
- }
872
- async checkCollapsibleHeader() {
873
- const mode = ionicGlobal.getIonMode(this);
874
- if (mode !== 'ios') {
875
- return;
876
- }
877
- const { collapse } = this;
878
- const hasCondense = collapse === 'condense';
879
- const hasFade = collapse === 'fade';
880
- this.destroyCollapsibleHeader();
881
- if (hasCondense) {
882
- const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
883
- const contentEl = pageEl ? index$1.findIonContent(pageEl) : null;
884
- // Cloned elements are always needed in iOS transition
885
- index.writeTask(() => {
886
- const title = cloneElement('ion-title');
887
- title.size = 'large';
888
- cloneElement('ion-back-button');
889
- });
890
- await this.setupCondenseHeader(contentEl, pageEl);
891
- }
892
- else if (hasFade) {
893
- const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
894
- const contentEl = pageEl ? index$1.findIonContent(pageEl) : null;
895
- if (!contentEl) {
896
- index$1.printIonContentErrorMsg(this.el);
897
- return;
898
- }
899
- const condenseHeader = contentEl.querySelector('ion-header[collapse="condense"]');
900
- await this.setupFadeHeader(contentEl, condenseHeader);
901
- }
902
- }
903
- destroyCollapsibleHeader() {
904
- if (this.intersectionObserver) {
905
- this.intersectionObserver.disconnect();
906
- this.intersectionObserver = undefined;
907
- }
908
- if (this.scrollEl && this.contentScrollCallback) {
909
- this.scrollEl.removeEventListener('scroll', this.contentScrollCallback);
910
- this.contentScrollCallback = undefined;
911
- }
912
- if (this.collapsibleMainHeader) {
913
- this.collapsibleMainHeader.classList.remove('header-collapse-main');
914
- this.collapsibleMainHeader = undefined;
915
- }
916
- }
917
- async setupCondenseHeader(contentEl, pageEl) {
918
- if (!contentEl || !pageEl) {
919
- index$1.printIonContentErrorMsg(this.el);
920
- return;
921
- }
922
- if (typeof IntersectionObserver === 'undefined') {
923
- return;
924
- }
925
- this.scrollEl = await index$1.getScrollElement(contentEl);
926
- const headers = pageEl.querySelectorAll('ion-header');
927
- this.collapsibleMainHeader = Array.from(headers).find((header) => header.collapse !== 'condense');
928
- if (!this.collapsibleMainHeader) {
929
- return;
930
- }
931
- const mainHeaderIndex = createHeaderIndex(this.collapsibleMainHeader);
932
- const scrollHeaderIndex = createHeaderIndex(this.el);
933
- if (!mainHeaderIndex || !scrollHeaderIndex) {
934
- return;
935
- }
936
- setHeaderActive(mainHeaderIndex, false);
937
- setToolbarBackgroundOpacity(mainHeaderIndex.el, 0);
938
- /**
939
- * Handle interaction between toolbar collapse and
940
- * showing/hiding content in the primary ion-header
941
- * as well as progressively showing/hiding the main header
942
- * border as the top-most toolbar collapses or expands.
943
- */
944
- const toolbarIntersection = (ev) => {
945
- handleToolbarIntersection(ev, mainHeaderIndex, scrollHeaderIndex, this.scrollEl);
946
- };
947
- this.intersectionObserver = new IntersectionObserver(toolbarIntersection, {
948
- root: contentEl,
949
- threshold: [0.25, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1],
950
- });
951
- this.intersectionObserver.observe(scrollHeaderIndex.toolbars[scrollHeaderIndex.toolbars.length - 1].el);
952
- /**
953
- * Handle scaling of large iOS titles and
954
- * showing/hiding border on last toolbar
955
- * in primary header
956
- */
957
- this.contentScrollCallback = () => {
958
- handleContentScroll(this.scrollEl, scrollHeaderIndex, contentEl);
959
- };
960
- this.scrollEl.addEventListener('scroll', this.contentScrollCallback);
961
- index.writeTask(() => {
962
- if (this.collapsibleMainHeader !== undefined) {
963
- this.collapsibleMainHeader.classList.add('header-collapse-main');
964
- }
965
- });
966
- }
967
- render() {
968
- const { translucent, inheritedAttributes } = this;
969
- const mode = ionicGlobal.getIonMode(this);
970
- const collapse = this.collapse || 'none';
971
- // banner role must be at top level, so remove role if inside a menu
972
- const roleType = theme.hostContext('ion-menu', this.el) ? 'none' : 'banner';
973
- return (index.h(index.Host, Object.assign({ role: roleType, class: {
974
- [mode]: true,
975
- // Used internally for styling
976
- [`header-${mode}`]: true,
977
- [`header-translucent`]: this.translucent,
978
- [`header-collapse-${collapse}`]: true,
979
- [`header-translucent-${mode}`]: this.translucent,
980
- } }, inheritedAttributes), mode === 'ios' && translucent && index.h("div", { class: "header-background" }), index.h("slot", null)));
981
- }
982
- get el() { return index.getElement(this); }
843
+ constructor(hostRef) {
844
+ index.registerInstance(this, hostRef);
845
+ this.inheritedAttributes = {};
846
+ this.setupFadeHeader = async (contentEl, condenseHeader) => {
847
+ const scrollEl = (this.scrollEl = await index$1.getScrollElement(contentEl));
848
+ /**
849
+ * Handle fading of toolbars on scroll
850
+ */
851
+ this.contentScrollCallback = () => {
852
+ handleHeaderFade(this.scrollEl, this.el, condenseHeader);
853
+ };
854
+ scrollEl.addEventListener('scroll', this.contentScrollCallback);
855
+ handleHeaderFade(this.scrollEl, this.el, condenseHeader);
856
+ };
857
+ this.collapse = undefined;
858
+ this.translucent = false;
859
+ }
860
+ componentWillLoad() {
861
+ this.inheritedAttributes = helpers.inheritAriaAttributes(this.el);
862
+ }
863
+ componentDidLoad() {
864
+ this.checkCollapsibleHeader();
865
+ }
866
+ componentDidUpdate() {
867
+ this.checkCollapsibleHeader();
868
+ }
869
+ disconnectedCallback() {
870
+ this.destroyCollapsibleHeader();
871
+ }
872
+ async checkCollapsibleHeader() {
873
+ const mode = ionicGlobal.getIonMode(this);
874
+ if (mode !== 'ios') {
875
+ return;
876
+ }
877
+ const { collapse } = this;
878
+ const hasCondense = collapse === 'condense';
879
+ const hasFade = collapse === 'fade';
880
+ this.destroyCollapsibleHeader();
881
+ if (hasCondense) {
882
+ const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
883
+ const contentEl = pageEl ? index$1.findIonContent(pageEl) : null;
884
+ // Cloned elements are always needed in iOS transition
885
+ index.writeTask(() => {
886
+ const title = cloneElement('ion-title');
887
+ title.size = 'large';
888
+ cloneElement('ion-back-button');
889
+ });
890
+ await this.setupCondenseHeader(contentEl, pageEl);
891
+ }
892
+ else if (hasFade) {
893
+ const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
894
+ const contentEl = pageEl ? index$1.findIonContent(pageEl) : null;
895
+ if (!contentEl) {
896
+ index$1.printIonContentErrorMsg(this.el);
897
+ return;
898
+ }
899
+ const condenseHeader = contentEl.querySelector('ion-header[collapse="condense"]');
900
+ await this.setupFadeHeader(contentEl, condenseHeader);
901
+ }
902
+ }
903
+ destroyCollapsibleHeader() {
904
+ if (this.intersectionObserver) {
905
+ this.intersectionObserver.disconnect();
906
+ this.intersectionObserver = undefined;
907
+ }
908
+ if (this.scrollEl && this.contentScrollCallback) {
909
+ this.scrollEl.removeEventListener('scroll', this.contentScrollCallback);
910
+ this.contentScrollCallback = undefined;
911
+ }
912
+ if (this.collapsibleMainHeader) {
913
+ this.collapsibleMainHeader.classList.remove('header-collapse-main');
914
+ this.collapsibleMainHeader = undefined;
915
+ }
916
+ }
917
+ async setupCondenseHeader(contentEl, pageEl) {
918
+ if (!contentEl || !pageEl) {
919
+ index$1.printIonContentErrorMsg(this.el);
920
+ return;
921
+ }
922
+ if (typeof IntersectionObserver === 'undefined') {
923
+ return;
924
+ }
925
+ this.scrollEl = await index$1.getScrollElement(contentEl);
926
+ const headers = pageEl.querySelectorAll('ion-header');
927
+ this.collapsibleMainHeader = Array.from(headers).find((header) => header.collapse !== 'condense');
928
+ if (!this.collapsibleMainHeader) {
929
+ return;
930
+ }
931
+ const mainHeaderIndex = createHeaderIndex(this.collapsibleMainHeader);
932
+ const scrollHeaderIndex = createHeaderIndex(this.el);
933
+ if (!mainHeaderIndex || !scrollHeaderIndex) {
934
+ return;
935
+ }
936
+ setHeaderActive(mainHeaderIndex, false);
937
+ setToolbarBackgroundOpacity(mainHeaderIndex.el, 0);
938
+ /**
939
+ * Handle interaction between toolbar collapse and
940
+ * showing/hiding content in the primary ion-header
941
+ * as well as progressively showing/hiding the main header
942
+ * border as the top-most toolbar collapses or expands.
943
+ */
944
+ const toolbarIntersection = (ev) => {
945
+ handleToolbarIntersection(ev, mainHeaderIndex, scrollHeaderIndex, this.scrollEl);
946
+ };
947
+ this.intersectionObserver = new IntersectionObserver(toolbarIntersection, {
948
+ root: contentEl,
949
+ threshold: [0.25, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1],
950
+ });
951
+ this.intersectionObserver.observe(scrollHeaderIndex.toolbars[scrollHeaderIndex.toolbars.length - 1].el);
952
+ /**
953
+ * Handle scaling of large iOS titles and
954
+ * showing/hiding border on last toolbar
955
+ * in primary header
956
+ */
957
+ this.contentScrollCallback = () => {
958
+ handleContentScroll(this.scrollEl, scrollHeaderIndex, contentEl);
959
+ };
960
+ this.scrollEl.addEventListener('scroll', this.contentScrollCallback);
961
+ index.writeTask(() => {
962
+ if (this.collapsibleMainHeader !== undefined) {
963
+ this.collapsibleMainHeader.classList.add('header-collapse-main');
964
+ }
965
+ });
966
+ }
967
+ render() {
968
+ const { translucent, inheritedAttributes } = this;
969
+ const mode = ionicGlobal.getIonMode(this);
970
+ const collapse = this.collapse || 'none';
971
+ // banner role must be at top level, so remove role if inside a menu
972
+ const roleType = theme.hostContext('ion-menu', this.el) ? 'none' : 'banner';
973
+ return (index.h(index.Host, Object.assign({ role: roleType, class: {
974
+ [mode]: true,
975
+ // Used internally for styling
976
+ [`header-${mode}`]: true,
977
+ [`header-translucent`]: this.translucent,
978
+ [`header-collapse-${collapse}`]: true,
979
+ [`header-translucent-${mode}`]: this.translucent,
980
+ } }, inheritedAttributes), mode === 'ios' && translucent && index.h("div", { class: "header-background" }), index.h("slot", null)));
981
+ }
982
+ get el() { return index.getElement(this); }
983
983
  };
984
984
  Header.style = {
985
- ios: headerIosCss,
986
- md: headerMdCss
985
+ ios: headerIosCss,
986
+ md: headerMdCss
987
987
  };
988
988
 
989
989
  const routerOutletCss = ":host{left:0;right:0;top:0;bottom:0;position:absolute;contain:layout size style;z-index:0}";
990
990
 
991
991
  const RouterOutlet = class {
992
- constructor(hostRef) {
993
- index.registerInstance(this, hostRef);
994
- this.ionNavWillLoad = index.createEvent(this, "ionNavWillLoad", 7);
995
- this.ionNavWillChange = index.createEvent(this, "ionNavWillChange", 3);
996
- this.ionNavDidChange = index.createEvent(this, "ionNavDidChange", 3);
997
- this.lockController = lockController.createLockController();
998
- this.gestureOrAnimationInProgress = false;
999
- this.mode = ionicGlobal.getIonMode(this);
1000
- this.delegate = undefined;
1001
- this.animated = true;
1002
- this.animation = undefined;
1003
- this.swipeHandler = undefined;
1004
- }
1005
- swipeHandlerChanged() {
1006
- if (this.gesture) {
1007
- this.gesture.enable(this.swipeHandler !== undefined);
1008
- }
1009
- }
1010
- async connectedCallback() {
1011
- const onStart = () => {
1012
- this.gestureOrAnimationInProgress = true;
1013
- if (this.swipeHandler) {
1014
- this.swipeHandler.onStart();
1015
- }
1016
- };
1017
- this.gesture = (await Promise.resolve().then(function () { return require('./swipe-back-7e843e77.js'); })).createSwipeBackGesture(this.el, () => !this.gestureOrAnimationInProgress && !!this.swipeHandler && this.swipeHandler.canStart(), () => onStart(), (step) => { var _a; return (_a = this.ani) === null || _a === void 0 ? void 0 : _a.progressStep(step); }, (shouldComplete, step, dur) => {
1018
- if (this.ani) {
1019
- this.ani.onFinish(() => {
1020
- this.gestureOrAnimationInProgress = false;
1021
- if (this.swipeHandler) {
1022
- this.swipeHandler.onEnd(shouldComplete);
1023
- }
1024
- }, { oneTimeCallback: true });
1025
- // Account for rounding errors in JS
1026
- let newStepValue = shouldComplete ? -0.001 : 0.001;
1027
- /**
1028
- * Animation will be reversed here, so need to
1029
- * reverse the easing curve as well
1030
- *
1031
- * Additionally, we need to account for the time relative
1032
- * to the new easing curve, as `stepValue` is going to be given
1033
- * in terms of a linear curve.
1034
- */
1035
- if (!shouldComplete) {
1036
- this.ani.easing('cubic-bezier(1, 0, 0.68, 0.28)');
1037
- newStepValue += cubicBezier.getTimeGivenProgression([0, 0], [1, 0], [0.68, 0.28], [1, 1], step)[0];
1038
- }
1039
- else {
1040
- this.ani.easing('linear');
1041
- newStepValue += step;
1042
- }
1043
- this.ani.progressEnd(shouldComplete ? 1 : 0, newStepValue, dur);
1044
- }
1045
- else {
992
+ constructor(hostRef) {
993
+ index.registerInstance(this, hostRef);
994
+ this.ionNavWillLoad = index.createEvent(this, "ionNavWillLoad", 7);
995
+ this.ionNavWillChange = index.createEvent(this, "ionNavWillChange", 3);
996
+ this.ionNavDidChange = index.createEvent(this, "ionNavDidChange", 3);
997
+ this.lockController = lockController.createLockController();
1046
998
  this.gestureOrAnimationInProgress = false;
1047
- }
1048
- });
1049
- this.swipeHandlerChanged();
1050
- }
1051
- componentWillLoad() {
1052
- this.ionNavWillLoad.emit();
1053
- }
1054
- disconnectedCallback() {
1055
- if (this.gesture) {
1056
- this.gesture.destroy();
1057
- this.gesture = undefined;
1058
- }
1059
- }
1060
- /** @internal */
1061
- async commit(enteringEl, leavingEl, opts) {
1062
- const unlock = await this.lockController.lock();
1063
- let changed = false;
1064
- try {
1065
- changed = await this.transition(enteringEl, leavingEl, opts);
1066
- }
1067
- catch (e) {
1068
- console.error(e);
1069
- }
1070
- unlock();
1071
- return changed;
1072
- }
1073
- /** @internal */
1074
- async setRouteId(id, params, direction, animation) {
1075
- const changed = await this.setRoot(id, params, {
1076
- duration: direction === 'root' ? 0 : undefined,
1077
- direction: direction === 'back' ? 'back' : 'forward',
1078
- animationBuilder: animation,
1079
- });
1080
- return {
1081
- changed,
1082
- element: this.activeEl,
1083
- };
1084
- }
1085
- /** @internal */
1086
- async getRouteId() {
1087
- const active = this.activeEl;
1088
- return active
1089
- ? {
1090
- id: active.tagName,
1091
- element: active,
1092
- params: this.activeParams,
1093
- }
1094
- : undefined;
1095
- }
1096
- async setRoot(component, params, opts) {
1097
- if (this.activeComponent === component && helpers.shallowEqualStringMap(params, this.activeParams)) {
1098
- return false;
1099
- }
1100
- // attach entering view to DOM
1101
- const leavingEl = this.activeEl;
1102
- const enteringEl = await frameworkDelegate.attachComponent(this.delegate, this.el, component, ['ion-page', 'ion-page-invisible'], params);
1103
- this.activeComponent = component;
1104
- this.activeEl = enteringEl;
1105
- this.activeParams = params;
1106
- // commit animation
1107
- await this.commit(enteringEl, leavingEl, opts);
1108
- await frameworkDelegate.detachComponent(this.delegate, leavingEl);
1109
- return true;
1110
- }
1111
- async transition(enteringEl, leavingEl, opts = {}) {
1112
- if (leavingEl === enteringEl) {
1113
- return false;
1114
- }
1115
- // emit nav will change event
1116
- this.ionNavWillChange.emit();
1117
- const { el, mode } = this;
1118
- const animated = this.animated && ionicGlobal.config.getBoolean('animated', true);
1119
- const animationBuilder = opts.animationBuilder || this.animation || ionicGlobal.config.get('navAnimation');
1120
- await index$2.transition(Object.assign(Object.assign({ mode,
1121
- animated,
1122
- enteringEl,
1123
- leavingEl, baseEl: el,
1124
- /**
1125
- * We need to wait for all Stencil components
1126
- * to be ready only when using the lazy
1127
- * loaded bundle.
1128
- */
1129
- deepWait: helpers.hasLazyBuild(el), progressCallback: opts.progressAnimation
1130
- ? (ani) => {
1131
- /**
1132
- * Because this progress callback is called asynchronously
1133
- * it is possible for the gesture to start and end before
1134
- * the animation is ever set. In that scenario, we should
1135
- * immediately call progressEnd so that the transition promise
1136
- * resolves and the gesture does not get locked up.
1137
- */
1138
- if (ani !== undefined && !this.gestureOrAnimationInProgress) {
999
+ this.mode = ionicGlobal.getIonMode(this);
1000
+ this.delegate = undefined;
1001
+ this.animated = true;
1002
+ this.animation = undefined;
1003
+ this.swipeHandler = undefined;
1004
+ }
1005
+ swipeHandlerChanged() {
1006
+ if (this.gesture) {
1007
+ this.gesture.enable(this.swipeHandler !== undefined);
1008
+ }
1009
+ }
1010
+ async connectedCallback() {
1011
+ const onStart = () => {
1139
1012
  this.gestureOrAnimationInProgress = true;
1140
- ani.onFinish(() => {
1141
- this.gestureOrAnimationInProgress = false;
1142
- if (this.swipeHandler) {
1143
- this.swipeHandler.onEnd(false);
1144
- }
1145
- }, { oneTimeCallback: true });
1013
+ if (this.swipeHandler) {
1014
+ this.swipeHandler.onStart();
1015
+ }
1016
+ };
1017
+ this.gesture = (await Promise.resolve().then(function () { return require('./swipe-back-e37a1a5c.js'); })).createSwipeBackGesture(this.el, () => !this.gestureOrAnimationInProgress && !!this.swipeHandler && this.swipeHandler.canStart(), () => onStart(), (step) => { var _a; return (_a = this.ani) === null || _a === void 0 ? void 0 : _a.progressStep(step); }, (shouldComplete, step, dur) => {
1018
+ if (this.ani) {
1019
+ this.ani.onFinish(() => {
1020
+ this.gestureOrAnimationInProgress = false;
1021
+ if (this.swipeHandler) {
1022
+ this.swipeHandler.onEnd(shouldComplete);
1023
+ }
1024
+ }, { oneTimeCallback: true });
1025
+ // Account for rounding errors in JS
1026
+ let newStepValue = shouldComplete ? -0.001 : 0.001;
1027
+ /**
1028
+ * Animation will be reversed here, so need to
1029
+ * reverse the easing curve as well
1030
+ *
1031
+ * Additionally, we need to account for the time relative
1032
+ * to the new easing curve, as `stepValue` is going to be given
1033
+ * in terms of a linear curve.
1034
+ */
1035
+ if (!shouldComplete) {
1036
+ this.ani.easing('cubic-bezier(1, 0, 0.68, 0.28)');
1037
+ newStepValue += cubicBezier.getTimeGivenProgression([0, 0], [1, 0], [0.68, 0.28], [1, 1], step)[0];
1038
+ }
1039
+ else {
1040
+ this.ani.easing('linear');
1041
+ newStepValue += step;
1042
+ }
1043
+ this.ani.progressEnd(shouldComplete ? 1 : 0, newStepValue, dur);
1044
+ }
1045
+ else {
1046
+ this.gestureOrAnimationInProgress = false;
1047
+ }
1048
+ });
1049
+ this.swipeHandlerChanged();
1050
+ }
1051
+ componentWillLoad() {
1052
+ this.ionNavWillLoad.emit();
1053
+ }
1054
+ disconnectedCallback() {
1055
+ if (this.gesture) {
1056
+ this.gesture.destroy();
1057
+ this.gesture = undefined;
1058
+ }
1059
+ }
1060
+ /** @internal */
1061
+ async commit(enteringEl, leavingEl, opts) {
1062
+ const unlock = await this.lockController.lock();
1063
+ let changed = false;
1064
+ try {
1065
+ changed = await this.transition(enteringEl, leavingEl, opts);
1066
+ }
1067
+ catch (e) {
1068
+ console.error(e);
1069
+ }
1070
+ unlock();
1071
+ return changed;
1072
+ }
1073
+ /** @internal */
1074
+ async setRouteId(id, params, direction, animation) {
1075
+ const changed = await this.setRoot(id, params, {
1076
+ duration: direction === 'root' ? 0 : undefined,
1077
+ direction: direction === 'back' ? 'back' : 'forward',
1078
+ animationBuilder: animation,
1079
+ });
1080
+ return {
1081
+ changed,
1082
+ element: this.activeEl,
1083
+ };
1084
+ }
1085
+ /** @internal */
1086
+ async getRouteId() {
1087
+ const active = this.activeEl;
1088
+ return active
1089
+ ? {
1090
+ id: active.tagName,
1091
+ element: active,
1092
+ params: this.activeParams,
1093
+ }
1094
+ : undefined;
1095
+ }
1096
+ async setRoot(component, params, opts) {
1097
+ if (this.activeComponent === component && helpers.shallowEqualStringMap(params, this.activeParams)) {
1098
+ return false;
1099
+ }
1100
+ // attach entering view to DOM
1101
+ const leavingEl = this.activeEl;
1102
+ const enteringEl = await frameworkDelegate.attachComponent(this.delegate, this.el, component, ['ion-page', 'ion-page-invisible'], params);
1103
+ this.activeComponent = component;
1104
+ this.activeEl = enteringEl;
1105
+ this.activeParams = params;
1106
+ // commit animation
1107
+ await this.commit(enteringEl, leavingEl, opts);
1108
+ await frameworkDelegate.detachComponent(this.delegate, leavingEl);
1109
+ return true;
1110
+ }
1111
+ async transition(enteringEl, leavingEl, opts = {}) {
1112
+ if (leavingEl === enteringEl) {
1113
+ return false;
1114
+ }
1115
+ // emit nav will change event
1116
+ this.ionNavWillChange.emit();
1117
+ const { el, mode } = this;
1118
+ const animated = this.animated && ionicGlobal.config.getBoolean('animated', true);
1119
+ const animationBuilder = opts.animationBuilder || this.animation || ionicGlobal.config.get('navAnimation');
1120
+ await index$2.transition(Object.assign(Object.assign({ mode,
1121
+ animated,
1122
+ enteringEl,
1123
+ leavingEl, baseEl: el,
1146
1124
  /**
1147
- * Playing animation to beginning
1148
- * with a duration of 0 prevents
1149
- * any flickering when the animation
1150
- * is later cleaned up.
1125
+ * We need to wait for all Stencil components
1126
+ * to be ready only when using the lazy
1127
+ * loaded bundle.
1151
1128
  */
1152
- ani.progressEnd(0, 0, 0);
1153
- }
1154
- else {
1155
- this.ani = ani;
1156
- }
1157
- }
1158
- : undefined }, opts), { animationBuilder }));
1159
- // emit nav changed event
1160
- this.ionNavDidChange.emit();
1161
- return true;
1162
- }
1163
- render() {
1164
- return index.h("slot", null);
1165
- }
1166
- get el() { return index.getElement(this); }
1167
- static get watchers() { return {
1168
- "swipeHandler": ["swipeHandlerChanged"]
1169
- }; }
1129
+ deepWait: helpers.hasLazyBuild(el), progressCallback: opts.progressAnimation
1130
+ ? (ani) => {
1131
+ /**
1132
+ * Because this progress callback is called asynchronously
1133
+ * it is possible for the gesture to start and end before
1134
+ * the animation is ever set. In that scenario, we should
1135
+ * immediately call progressEnd so that the transition promise
1136
+ * resolves and the gesture does not get locked up.
1137
+ */
1138
+ if (ani !== undefined && !this.gestureOrAnimationInProgress) {
1139
+ this.gestureOrAnimationInProgress = true;
1140
+ ani.onFinish(() => {
1141
+ this.gestureOrAnimationInProgress = false;
1142
+ if (this.swipeHandler) {
1143
+ this.swipeHandler.onEnd(false);
1144
+ }
1145
+ }, { oneTimeCallback: true });
1146
+ /**
1147
+ * Playing animation to beginning
1148
+ * with a duration of 0 prevents
1149
+ * any flickering when the animation
1150
+ * is later cleaned up.
1151
+ */
1152
+ ani.progressEnd(0, 0, 0);
1153
+ }
1154
+ else {
1155
+ this.ani = ani;
1156
+ }
1157
+ }
1158
+ : undefined }, opts), { animationBuilder }));
1159
+ // emit nav changed event
1160
+ this.ionNavDidChange.emit();
1161
+ return true;
1162
+ }
1163
+ render() {
1164
+ return index.h("slot", null);
1165
+ }
1166
+ get el() { return index.getElement(this); }
1167
+ static get watchers() { return {
1168
+ "swipeHandler": ["swipeHandlerChanged"]
1169
+ }; }
1170
1170
  };
1171
1171
  RouterOutlet.style = routerOutletCss;
1172
1172
 
@@ -1175,44 +1175,44 @@ const titleIosCss = ":host{--color:initial;display:-ms-flexbox;display:flex;-ms-
1175
1175
  const titleMdCss = ":host{--color:initial;display:-ms-flexbox;display:flex;-ms-flex:1;flex:1;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0);color:var(--color)}:host(.ion-color){color:var(--ion-color-base)}.toolbar-title{display:block;width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;pointer-events:auto}:host(.title-small) .toolbar-title{white-space:normal}:host{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px;padding-top:0;padding-bottom:0;font-size:1.25rem;font-weight:500;letter-spacing:0.0125em}:host(.title-small){width:100%;height:100%;font-size:0.9375rem;font-weight:normal}";
1176
1176
 
1177
1177
  const ToolbarTitle = class {
1178
- constructor(hostRef) {
1179
- index.registerInstance(this, hostRef);
1180
- this.ionStyle = index.createEvent(this, "ionStyle", 7);
1181
- this.color = undefined;
1182
- this.size = undefined;
1183
- }
1184
- sizeChanged() {
1185
- this.emitStyle();
1186
- }
1187
- connectedCallback() {
1188
- this.emitStyle();
1189
- }
1190
- emitStyle() {
1191
- const size = this.getSize();
1192
- this.ionStyle.emit({
1193
- [`title-${size}`]: true,
1194
- });
1195
- }
1196
- getSize() {
1197
- return this.size !== undefined ? this.size : 'default';
1198
- }
1199
- render() {
1200
- const mode = ionicGlobal.getIonMode(this);
1201
- const size = this.getSize();
1202
- return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
1203
- [mode]: true,
1204
- [`title-${size}`]: true,
1205
- 'title-rtl': document.dir === 'rtl',
1206
- }) }, index.h("div", { class: "toolbar-title" }, index.h("slot", null))));
1207
- }
1208
- get el() { return index.getElement(this); }
1209
- static get watchers() { return {
1210
- "size": ["sizeChanged"]
1211
- }; }
1178
+ constructor(hostRef) {
1179
+ index.registerInstance(this, hostRef);
1180
+ this.ionStyle = index.createEvent(this, "ionStyle", 7);
1181
+ this.color = undefined;
1182
+ this.size = undefined;
1183
+ }
1184
+ sizeChanged() {
1185
+ this.emitStyle();
1186
+ }
1187
+ connectedCallback() {
1188
+ this.emitStyle();
1189
+ }
1190
+ emitStyle() {
1191
+ const size = this.getSize();
1192
+ this.ionStyle.emit({
1193
+ [`title-${size}`]: true,
1194
+ });
1195
+ }
1196
+ getSize() {
1197
+ return this.size !== undefined ? this.size : 'default';
1198
+ }
1199
+ render() {
1200
+ const mode = ionicGlobal.getIonMode(this);
1201
+ const size = this.getSize();
1202
+ return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
1203
+ [mode]: true,
1204
+ [`title-${size}`]: true,
1205
+ 'title-rtl': document.dir === 'rtl',
1206
+ }) }, index.h("div", { class: "toolbar-title" }, index.h("slot", null))));
1207
+ }
1208
+ get el() { return index.getElement(this); }
1209
+ static get watchers() { return {
1210
+ "size": ["sizeChanged"]
1211
+ }; }
1212
1212
  };
1213
1213
  ToolbarTitle.style = {
1214
- ios: titleIosCss,
1215
- md: titleMdCss
1214
+ ios: titleIosCss,
1215
+ md: titleMdCss
1216
1216
  };
1217
1217
 
1218
1218
  const toolbarIosCss = ":host{--border-width:0;--border-style:solid;--opacity:1;--opacity-scale:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;width:100%;padding-right:var(--ion-safe-area-right);padding-left:var(--ion-safe-area-left);color:var(--color);font-family:var(--ion-font-family, inherit);contain:content;z-index:10;-webkit-box-sizing:border-box;box-sizing:border-box}:host(.ion-color){color:var(--ion-color-contrast)}:host(.ion-color) .toolbar-background{background:var(--ion-color-base)}.toolbar-container{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;position:relative;-ms-flex-direction:row;flex-direction:row;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;width:100%;min-height:var(--min-height);contain:content;overflow:hidden;z-index:10;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-background{left:0;right:0;top:0;bottom:0;position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;opacity:calc(var(--opacity) * var(--opacity-scale));z-index:-1;pointer-events:none}::slotted(ion-progress-bar){left:0;right:0;bottom:0;position:absolute}:host{--background:var(--ion-toolbar-background, var(--ion-color-step-50, #f7f7f7));--color:var(--ion-toolbar-color, var(--ion-text-color, #000));--border-color:var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.2))));--padding-top:3px;--padding-bottom:3px;--padding-start:4px;--padding-end:4px;--min-height:44px}.toolbar-content{-ms-flex:1;flex:1;-ms-flex-order:4;order:4;min-width:0}:host(.toolbar-segment) .toolbar-content{display:-ms-inline-flexbox;display:inline-flex}:host(.toolbar-searchbar) .toolbar-container{padding-top:0;padding-bottom:0}:host(.toolbar-searchbar) ::slotted(*){-ms-flex-item-align:start;align-self:start}:host(.toolbar-searchbar) ::slotted(ion-chip){margin-top:3px}::slotted(ion-buttons){min-height:38px}::slotted([slot=start]){-ms-flex-order:2;order:2}::slotted([slot=secondary]){-ms-flex-order:3;order:3}::slotted([slot=primary]){-ms-flex-order:5;order:5;text-align:end}::slotted([slot=end]){-ms-flex-order:6;order:6;text-align:end}:host(.toolbar-title-large) .toolbar-container{-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:start;align-items:flex-start}:host(.toolbar-title-large) .toolbar-content ion-title{-ms-flex:1;flex:1;-ms-flex-order:8;order:8;min-width:100%}";
@@ -1220,65 +1220,65 @@ const toolbarIosCss = ":host{--border-width:0;--border-style:solid;--opacity:1;-
1220
1220
  const toolbarMdCss = ":host{--border-width:0;--border-style:solid;--opacity:1;--opacity-scale:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;width:100%;padding-right:var(--ion-safe-area-right);padding-left:var(--ion-safe-area-left);color:var(--color);font-family:var(--ion-font-family, inherit);contain:content;z-index:10;-webkit-box-sizing:border-box;box-sizing:border-box}:host(.ion-color){color:var(--ion-color-contrast)}:host(.ion-color) .toolbar-background{background:var(--ion-color-base)}.toolbar-container{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;position:relative;-ms-flex-direction:row;flex-direction:row;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;width:100%;min-height:var(--min-height);contain:content;overflow:hidden;z-index:10;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-background{left:0;right:0;top:0;bottom:0;position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;opacity:calc(var(--opacity) * var(--opacity-scale));z-index:-1;pointer-events:none}::slotted(ion-progress-bar){left:0;right:0;bottom:0;position:absolute}:host{--background:var(--ion-toolbar-background, var(--ion-background-color, #fff));--color:var(--ion-toolbar-color, var(--ion-text-color, #424242));--border-color:var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, #c1c4cd)));--padding-top:0;--padding-bottom:0;--padding-start:0;--padding-end:0;--min-height:56px}.toolbar-content{-ms-flex:1;flex:1;-ms-flex-order:3;order:3;min-width:0;max-width:100%}::slotted(.buttons-first-slot){-webkit-margin-start:4px;margin-inline-start:4px}::slotted(.buttons-last-slot){-webkit-margin-end:4px;margin-inline-end:4px}::slotted([slot=start]){-ms-flex-order:2;order:2}::slotted([slot=secondary]){-ms-flex-order:4;order:4}::slotted([slot=primary]){-ms-flex-order:5;order:5;text-align:end}::slotted([slot=end]){-ms-flex-order:6;order:6;text-align:end}";
1221
1221
 
1222
1222
  const Toolbar = class {
1223
- constructor(hostRef) {
1224
- index.registerInstance(this, hostRef);
1225
- this.childrenStyles = new Map();
1226
- this.color = undefined;
1227
- }
1228
- componentWillLoad() {
1229
- const buttons = Array.from(this.el.querySelectorAll('ion-buttons'));
1230
- const firstButtons = buttons.find((button) => {
1231
- return button.slot === 'start';
1232
- });
1233
- if (firstButtons) {
1234
- firstButtons.classList.add('buttons-first-slot');
1235
- }
1236
- const buttonsReversed = buttons.reverse();
1237
- const lastButtons = buttonsReversed.find((button) => button.slot === 'end') ||
1238
- buttonsReversed.find((button) => button.slot === 'primary') ||
1239
- buttonsReversed.find((button) => button.slot === 'secondary');
1240
- if (lastButtons) {
1241
- lastButtons.classList.add('buttons-last-slot');
1242
- }
1243
- }
1244
- childrenStyle(ev) {
1245
- ev.stopPropagation();
1246
- const tagName = ev.target.tagName;
1247
- const updatedStyles = ev.detail;
1248
- const newStyles = {};
1249
- const childStyles = this.childrenStyles.get(tagName) || {};
1250
- let hasStyleChange = false;
1251
- Object.keys(updatedStyles).forEach((key) => {
1252
- const childKey = `toolbar-${key}`;
1253
- const newValue = updatedStyles[key];
1254
- if (newValue !== childStyles[childKey]) {
1255
- hasStyleChange = true;
1256
- }
1257
- if (newValue) {
1258
- newStyles[childKey] = true;
1259
- }
1260
- });
1261
- if (hasStyleChange) {
1262
- this.childrenStyles.set(tagName, newStyles);
1263
- index.forceUpdate(this);
1264
- }
1265
- }
1266
- render() {
1267
- const mode = ionicGlobal.getIonMode(this);
1268
- const childStyles = {};
1269
- this.childrenStyles.forEach((value) => {
1270
- Object.assign(childStyles, value);
1271
- });
1272
- return (index.h(index.Host, { class: Object.assign(Object.assign({}, childStyles), theme.createColorClasses(this.color, {
1273
- [mode]: true,
1274
- 'in-toolbar': theme.hostContext('ion-toolbar', this.el),
1275
- })) }, index.h("div", { class: "toolbar-background" }), index.h("div", { class: "toolbar-container" }, index.h("slot", { name: "start" }), index.h("slot", { name: "secondary" }), index.h("div", { class: "toolbar-content" }, index.h("slot", null)), index.h("slot", { name: "primary" }), index.h("slot", { name: "end" }))));
1276
- }
1277
- get el() { return index.getElement(this); }
1223
+ constructor(hostRef) {
1224
+ index.registerInstance(this, hostRef);
1225
+ this.childrenStyles = new Map();
1226
+ this.color = undefined;
1227
+ }
1228
+ componentWillLoad() {
1229
+ const buttons = Array.from(this.el.querySelectorAll('ion-buttons'));
1230
+ const firstButtons = buttons.find((button) => {
1231
+ return button.slot === 'start';
1232
+ });
1233
+ if (firstButtons) {
1234
+ firstButtons.classList.add('buttons-first-slot');
1235
+ }
1236
+ const buttonsReversed = buttons.reverse();
1237
+ const lastButtons = buttonsReversed.find((button) => button.slot === 'end') ||
1238
+ buttonsReversed.find((button) => button.slot === 'primary') ||
1239
+ buttonsReversed.find((button) => button.slot === 'secondary');
1240
+ if (lastButtons) {
1241
+ lastButtons.classList.add('buttons-last-slot');
1242
+ }
1243
+ }
1244
+ childrenStyle(ev) {
1245
+ ev.stopPropagation();
1246
+ const tagName = ev.target.tagName;
1247
+ const updatedStyles = ev.detail;
1248
+ const newStyles = {};
1249
+ const childStyles = this.childrenStyles.get(tagName) || {};
1250
+ let hasStyleChange = false;
1251
+ Object.keys(updatedStyles).forEach((key) => {
1252
+ const childKey = `toolbar-${key}`;
1253
+ const newValue = updatedStyles[key];
1254
+ if (newValue !== childStyles[childKey]) {
1255
+ hasStyleChange = true;
1256
+ }
1257
+ if (newValue) {
1258
+ newStyles[childKey] = true;
1259
+ }
1260
+ });
1261
+ if (hasStyleChange) {
1262
+ this.childrenStyles.set(tagName, newStyles);
1263
+ index.forceUpdate(this);
1264
+ }
1265
+ }
1266
+ render() {
1267
+ const mode = ionicGlobal.getIonMode(this);
1268
+ const childStyles = {};
1269
+ this.childrenStyles.forEach((value) => {
1270
+ Object.assign(childStyles, value);
1271
+ });
1272
+ return (index.h(index.Host, { class: Object.assign(Object.assign({}, childStyles), theme.createColorClasses(this.color, {
1273
+ [mode]: true,
1274
+ 'in-toolbar': theme.hostContext('ion-toolbar', this.el),
1275
+ })) }, index.h("div", { class: "toolbar-background" }), index.h("div", { class: "toolbar-container" }, index.h("slot", { name: "start" }), index.h("slot", { name: "secondary" }), index.h("div", { class: "toolbar-content" }, index.h("slot", null)), index.h("slot", { name: "primary" }), index.h("slot", { name: "end" }))));
1276
+ }
1277
+ get el() { return index.getElement(this); }
1278
1278
  };
1279
1279
  Toolbar.style = {
1280
- ios: toolbarIosCss,
1281
- md: toolbarMdCss
1280
+ ios: toolbarIosCss,
1281
+ md: toolbarMdCss
1282
1282
  };
1283
1283
 
1284
1284
  exports.ion_app = App;