voyager-ionic-core 7.5.1 → 7.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1918) hide show
  1. package/components/action-sheet.js +299 -289
  2. package/components/alert.js +477 -467
  3. package/components/animation.js +992 -976
  4. package/components/backdrop.js +56 -56
  5. package/components/button-active.js +56 -56
  6. package/components/button.js +236 -236
  7. package/components/buttons.js +29 -29
  8. package/components/capacitor.js +4 -4
  9. package/components/checkbox.js +172 -170
  10. package/components/config.js +142 -142
  11. package/components/cubic-bezier.js +49 -49
  12. package/components/data.js +1055 -1055
  13. package/components/dir.js +5 -5
  14. package/components/focus-visible.js +63 -63
  15. package/components/form-controller.js +45 -49
  16. package/components/framework-delegate.js +121 -121
  17. package/components/gesture-controller.js +182 -182
  18. package/components/haptic.js +150 -150
  19. package/components/hardware-back-button.js +48 -48
  20. package/components/helpers.js +257 -257
  21. package/components/icon.js +133 -133
  22. package/components/index.js +95 -95
  23. package/components/index2.js +163 -163
  24. package/components/index3.js +417 -417
  25. package/components/index4.js +257 -259
  26. package/components/index5.js +0 -22
  27. package/components/index6.js +3 -3
  28. package/components/index8.js +58 -59
  29. package/components/index9.js +171 -171
  30. package/components/input-shims.js +488 -475
  31. package/components/input.utils.js +107 -106
  32. package/components/ion-accordion-group.d.ts +2 -2
  33. package/components/ion-accordion-group.js +223 -213
  34. package/components/ion-accordion.d.ts +2 -2
  35. package/components/ion-accordion.js +326 -326
  36. package/components/ion-action-sheet.d.ts +2 -2
  37. package/components/ion-alert.d.ts +2 -2
  38. package/components/ion-app.d.ts +2 -2
  39. package/components/ion-app.js +93 -93
  40. package/components/ion-avatar.d.ts +2 -2
  41. package/components/ion-avatar.js +23 -23
  42. package/components/ion-back-button.d.ts +2 -2
  43. package/components/ion-back-button.js +102 -102
  44. package/components/ion-backdrop.d.ts +2 -2
  45. package/components/ion-badge.d.ts +2 -2
  46. package/components/ion-badge.js +29 -29
  47. package/components/ion-breadcrumb.d.ts +2 -2
  48. package/components/ion-breadcrumb.js +111 -111
  49. package/components/ion-breadcrumbs.d.ts +2 -2
  50. package/components/ion-breadcrumbs.js +139 -139
  51. package/components/ion-button.d.ts +2 -2
  52. package/components/ion-buttons.d.ts +2 -2
  53. package/components/ion-card-content.d.ts +2 -2
  54. package/components/ion-card-content.js +27 -27
  55. package/components/ion-card-header.d.ts +2 -2
  56. package/components/ion-card-header.js +33 -33
  57. package/components/ion-card-subtitle.d.ts +2 -2
  58. package/components/ion-card-subtitle.js +30 -30
  59. package/components/ion-card-title.d.ts +2 -2
  60. package/components/ion-card-title.js +30 -30
  61. package/components/ion-card.d.ts +2 -2
  62. package/components/ion-card.js +78 -78
  63. package/components/ion-checkbox.d.ts +2 -2
  64. package/components/ion-chip.d.ts +2 -2
  65. package/components/ion-chip.js +41 -41
  66. package/components/ion-col.d.ts +2 -2
  67. package/components/ion-col.js +156 -156
  68. package/components/ion-content.d.ts +2 -2
  69. package/components/ion-content.js +394 -394
  70. package/components/ion-datetime-button.d.ts +2 -2
  71. package/components/ion-datetime-button.js +348 -348
  72. package/components/ion-datetime.d.ts +2 -2
  73. package/components/ion-datetime.js +1722 -1684
  74. package/components/ion-fab-button.d.ts +2 -2
  75. package/components/ion-fab-button.js +109 -109
  76. package/components/ion-fab-list.d.ts +2 -2
  77. package/components/ion-fab-list.js +45 -45
  78. package/components/ion-fab.d.ts +2 -2
  79. package/components/ion-fab.js +76 -76
  80. package/components/ion-footer.d.ts +2 -2
  81. package/components/ion-footer.js +124 -124
  82. package/components/ion-grid.d.ts +2 -2
  83. package/components/ion-grid.js +27 -27
  84. package/components/ion-header.d.ts +2 -2
  85. package/components/ion-header.js +299 -299
  86. package/components/ion-img.d.ts +2 -2
  87. package/components/ion-img.js +97 -97
  88. package/components/ion-infinite-scroll-content.d.ts +2 -2
  89. package/components/ion-infinite-scroll-content.js +49 -49
  90. package/components/ion-infinite-scroll.d.ts +2 -2
  91. package/components/ion-infinite-scroll.js +187 -179
  92. package/components/ion-input.d.ts +2 -2
  93. package/components/ion-input.js +482 -450
  94. package/components/ion-item-divider.d.ts +2 -2
  95. package/components/ion-item-divider.js +36 -36
  96. package/components/ion-item-group.d.ts +2 -2
  97. package/components/ion-item-group.js +28 -28
  98. package/components/ion-item-option.d.ts +2 -2
  99. package/components/ion-item-option.js +69 -69
  100. package/components/ion-item-options.d.ts +2 -2
  101. package/components/ion-item-options.js +50 -50
  102. package/components/ion-item-sliding.d.ts +2 -2
  103. package/components/ion-item-sliding.js +404 -404
  104. package/components/ion-item.d.ts +2 -2
  105. package/components/ion-label.d.ts +2 -2
  106. package/components/ion-list-header.d.ts +2 -2
  107. package/components/ion-list.d.ts +2 -2
  108. package/components/ion-loading.d.ts +2 -2
  109. package/components/ion-loading.js +257 -247
  110. package/components/ion-menu-button.d.ts +2 -2
  111. package/components/ion-menu-button.js +77 -77
  112. package/components/ion-menu-toggle.d.ts +2 -2
  113. package/components/ion-menu-toggle.js +41 -41
  114. package/components/ion-menu.d.ts +2 -2
  115. package/components/ion-menu.js +631 -619
  116. package/components/ion-modal.d.ts +2 -2
  117. package/components/ion-modal.js +1451 -1441
  118. package/components/ion-nav-link.d.ts +2 -2
  119. package/components/ion-nav-link.js +47 -47
  120. package/components/ion-nav.d.ts +2 -2
  121. package/components/ion-nav.js +910 -910
  122. package/components/ion-note.d.ts +2 -2
  123. package/components/ion-picker-column-internal.d.ts +2 -2
  124. package/components/ion-picker-column.d.ts +2 -2
  125. package/components/ion-picker-internal.d.ts +2 -2
  126. package/components/ion-picker.d.ts +2 -2
  127. package/components/ion-picker.js +263 -253
  128. package/components/ion-popover.d.ts +2 -2
  129. package/components/ion-progress-bar.d.ts +2 -2
  130. package/components/ion-progress-bar.js +57 -57
  131. package/components/ion-radio-group.d.ts +2 -2
  132. package/components/ion-radio.d.ts +2 -2
  133. package/components/ion-range.d.ts +2 -2
  134. package/components/ion-range.js +593 -591
  135. package/components/ion-refresher-content.d.ts +2 -2
  136. package/components/ion-refresher-content.js +63 -63
  137. package/components/ion-refresher.d.ts +2 -2
  138. package/components/ion-refresher.js +747 -740
  139. package/components/ion-reorder-group.d.ts +2 -2
  140. package/components/ion-reorder-group.js +259 -259
  141. package/components/ion-reorder.d.ts +2 -2
  142. package/components/ion-reorder.js +41 -41
  143. package/components/ion-ripple-effect.d.ts +2 -2
  144. package/components/ion-route-redirect.d.ts +2 -2
  145. package/components/ion-route-redirect.js +34 -34
  146. package/components/ion-route.d.ts +2 -2
  147. package/components/ion-route.js +56 -56
  148. package/components/ion-router-link.d.ts +2 -2
  149. package/components/ion-router-link.js +45 -45
  150. package/components/ion-router-outlet.d.ts +2 -2
  151. package/components/ion-router-outlet.js +193 -193
  152. package/components/ion-router.d.ts +2 -2
  153. package/components/ion-router.js +632 -632
  154. package/components/ion-row.d.ts +2 -2
  155. package/components/ion-row.js +20 -20
  156. package/components/ion-searchbar.d.ts +2 -2
  157. package/components/ion-searchbar.js +406 -397
  158. package/components/ion-segment-button.d.ts +2 -2
  159. package/components/ion-segment-button.js +117 -117
  160. package/components/ion-segment.d.ts +2 -2
  161. package/components/ion-segment.js +427 -401
  162. package/components/ion-select-option.d.ts +2 -2
  163. package/components/ion-select-option.js +27 -27
  164. package/components/ion-select-popover.d.ts +2 -2
  165. package/components/ion-select.d.ts +2 -2
  166. package/components/ion-select.js +778 -763
  167. package/components/ion-skeleton-text.d.ts +2 -2
  168. package/components/ion-skeleton-text.js +45 -32
  169. package/components/ion-spinner.d.ts +2 -2
  170. package/components/ion-split-pane.d.ts +2 -2
  171. package/components/ion-split-pane.js +145 -145
  172. package/components/ion-tab-bar.d.ts +2 -2
  173. package/components/ion-tab-bar.js +79 -79
  174. package/components/ion-tab-button.d.ts +2 -2
  175. package/components/ion-tab-button.js +106 -106
  176. package/components/ion-tab.d.ts +2 -2
  177. package/components/ion-tab.js +72 -72
  178. package/components/ion-tabs.d.ts +2 -2
  179. package/components/ion-tabs.js +160 -160
  180. package/components/ion-text.d.ts +2 -2
  181. package/components/ion-text.js +26 -26
  182. package/components/ion-textarea.d.ts +2 -2
  183. package/components/ion-textarea.js +424 -392
  184. package/components/ion-thumbnail.d.ts +2 -2
  185. package/components/ion-thumbnail.js +20 -20
  186. package/components/ion-title.d.ts +2 -2
  187. package/components/ion-title.js +57 -57
  188. package/components/ion-toast.d.ts +2 -2
  189. package/components/ion-toast.js +819 -464
  190. package/components/ion-toggle.d.ts +2 -2
  191. package/components/ion-toggle.js +243 -241
  192. package/components/ion-toolbar.d.ts +2 -2
  193. package/components/ion-toolbar.js +71 -71
  194. package/components/ionic-global.js +163 -163
  195. package/components/ios.transition.js +598 -598
  196. package/components/item.js +301 -301
  197. package/components/keyboard-controller.js +128 -128
  198. package/components/keyboard.js +62 -62
  199. package/components/keyboard2.js +59 -59
  200. package/components/label.js +85 -85
  201. package/components/list-header.js +35 -35
  202. package/components/list.js +52 -52
  203. package/components/lock-controller.js +24 -24
  204. package/components/md.transition.js +44 -44
  205. package/components/menu-toggle-util.js +2 -2
  206. package/components/notch-controller.js +120 -120
  207. package/components/note.js +29 -29
  208. package/components/overlays.js +496 -495
  209. package/components/picker-column-internal.js +350 -345
  210. package/components/picker-column.js +334 -334
  211. package/components/picker-internal.js +470 -470
  212. package/components/popover.js +1156 -1146
  213. package/components/radio-group.js +162 -151
  214. package/components/radio.js +248 -209
  215. package/components/ripple-effect.js +81 -81
  216. package/components/select-popover.js +163 -163
  217. package/components/spinner.js +182 -182
  218. package/components/status-tap.js +26 -26
  219. package/components/swipe-back.js +65 -65
  220. package/components/theme.js +23 -23
  221. package/components/watch-options.js +37 -26
  222. package/css/core.css +66 -0
  223. package/css/core.css.map +1 -1
  224. package/css/display.css +44 -0
  225. package/css/display.css.map +1 -1
  226. package/css/float-elements.css +44 -0
  227. package/css/float-elements.css.map +1 -1
  228. package/css/global.bundle.css +88 -0
  229. package/css/global.bundle.css.map +1 -1
  230. package/css/ionic-swiper.css +22 -0
  231. package/css/ionic-swiper.css.map +1 -1
  232. package/css/ionic.bundle.css.map +1 -1
  233. package/css/padding.css +44 -0
  234. package/css/padding.css.map +1 -1
  235. package/css/structure.css +44 -0
  236. package/css/structure.css.map +1 -1
  237. package/css/text-alignment.css +44 -0
  238. package/css/text-alignment.css.map +1 -1
  239. package/css/text-transformation.css +44 -0
  240. package/css/text-transformation.css.map +1 -1
  241. package/css/typography.css +44 -0
  242. package/css/typography.css.map +1 -1
  243. package/css/utils.bundle.css +220 -0
  244. package/css/utils.bundle.css.map +1 -1
  245. package/dist/cjs/animation-9b401d39.js +1062 -0
  246. package/dist/cjs/{app-globals-fe1ad535.js → app-globals-0af482c7.js} +1 -1
  247. package/dist/cjs/button-active-a5185907.js +69 -0
  248. package/dist/cjs/{capacitor-2ffba62a.js → capacitor-c04564bf.js} +5 -5
  249. package/dist/cjs/compare-with-utils-df1001d7.js +44 -0
  250. package/dist/cjs/config-4f60b98a.js +199 -0
  251. package/dist/cjs/cubic-bezier-f2dccc53.js +92 -0
  252. package/dist/cjs/data-36b9094e.js +1622 -0
  253. package/dist/cjs/{dir-f1e0ca26.js → dir-94c21456.js} +5 -5
  254. package/dist/cjs/focus-visible-7a0ce04f.js +77 -0
  255. package/dist/cjs/form-controller-7d42a722.js +66 -0
  256. package/dist/cjs/framework-delegate-1c29b14a.js +144 -0
  257. package/dist/cjs/gesture-controller-c40c045a.js +197 -0
  258. package/dist/cjs/haptic-b882e0bb.js +212 -0
  259. package/dist/cjs/hardware-back-button-76833cac.js +76 -0
  260. package/dist/cjs/helpers-76bb7efb.js +441 -0
  261. package/dist/cjs/{index-cc7dfb7c.js → index-5915f9b3.js} +3 -3
  262. package/dist/cjs/index-b4f986cd.js +198 -0
  263. package/dist/cjs/{index-305a23dc.js → index-bbb4336c.js} +184 -63
  264. package/dist/cjs/index-c8d52405.js +10 -0
  265. package/dist/cjs/index-ce101dc9.js +308 -0
  266. package/dist/cjs/index-d1b59ffa.js +459 -0
  267. package/dist/cjs/{index-10873539.js → index-da15e99c.js} +60 -61
  268. package/dist/cjs/index-f8f13389.js +243 -0
  269. package/dist/cjs/index.cjs.js +113 -113
  270. package/dist/cjs/input-shims-a23bb0f4.js +601 -0
  271. package/dist/cjs/input.utils-3d0166a2.js +138 -0
  272. package/dist/cjs/ion-accordion_2.cjs.entry.js +491 -481
  273. package/dist/cjs/ion-action-sheet.cjs.entry.js +262 -252
  274. package/dist/cjs/ion-alert.cjs.entry.js +442 -432
  275. package/dist/cjs/ion-app_8.cjs.entry.js +1153 -1153
  276. package/dist/cjs/ion-avatar_3.cjs.entry.js +29 -29
  277. package/dist/cjs/ion-back-button.cjs.entry.js +73 -73
  278. package/dist/cjs/ion-backdrop.cjs.entry.js +40 -40
  279. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +194 -194
  280. package/dist/cjs/ion-button_2.cjs.entry.js +303 -303
  281. package/dist/cjs/ion-card_5.cjs.entry.js +105 -105
  282. package/dist/cjs/ion-checkbox.cjs.entry.js +149 -147
  283. package/dist/cjs/ion-chip.cjs.entry.js +20 -20
  284. package/dist/cjs/ion-col_3.cjs.entry.js +136 -136
  285. package/dist/cjs/ion-datetime-button.cjs.entry.js +325 -325
  286. package/dist/cjs/ion-datetime_3.cjs.entry.js +2185 -2137
  287. package/dist/cjs/ion-fab_3.cjs.entry.js +152 -152
  288. package/dist/cjs/ion-img.cjs.entry.js +79 -79
  289. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +198 -190
  290. package/dist/cjs/ion-input.cjs.entry.js +426 -394
  291. package/dist/cjs/ion-item-option_3.cjs.entry.js +459 -459
  292. package/dist/cjs/ion-item_8.cjs.entry.js +447 -434
  293. package/dist/cjs/ion-loading.cjs.entry.js +220 -210
  294. package/dist/cjs/ion-menu_3.cjs.entry.js +670 -658
  295. package/dist/cjs/ion-modal.cjs.entry.js +1415 -1405
  296. package/dist/cjs/ion-nav_2.cjs.entry.js +904 -904
  297. package/dist/cjs/ion-picker-column-internal.cjs.entry.js +331 -327
  298. package/dist/cjs/ion-picker-internal.cjs.entry.js +455 -455
  299. package/dist/cjs/ion-popover.cjs.entry.js +1110 -1100
  300. package/dist/cjs/ion-progress-bar.cjs.entry.js +40 -40
  301. package/dist/cjs/ion-radio_2.cjs.entry.js +322 -309
  302. package/dist/cjs/ion-range.cjs.entry.js +558 -556
  303. package/dist/cjs/ion-refresher_2.cjs.entry.js +786 -779
  304. package/dist/cjs/ion-reorder_2.cjs.entry.js +269 -269
  305. package/dist/cjs/ion-ripple-effect.cjs.entry.js +66 -66
  306. package/dist/cjs/ion-route_4.cjs.entry.js +693 -693
  307. package/dist/cjs/ion-searchbar.cjs.entry.js +363 -354
  308. package/dist/cjs/ion-segment_2.cjs.entry.js +509 -483
  309. package/dist/cjs/ion-select_3.cjs.entry.js +784 -768
  310. package/dist/cjs/ion-spinner.cjs.entry.js +46 -46
  311. package/dist/cjs/ion-split-pane.cjs.entry.js +117 -117
  312. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +142 -142
  313. package/dist/cjs/ion-tab_2.cjs.entry.js +187 -187
  314. package/dist/cjs/ion-text.cjs.entry.js +13 -13
  315. package/dist/cjs/ion-textarea.cjs.entry.js +381 -349
  316. package/dist/cjs/ion-toast.cjs.entry.js +771 -419
  317. package/dist/cjs/ion-toggle.cjs.entry.js +227 -225
  318. package/dist/cjs/ionic-global-f4a2093b.js +230 -0
  319. package/dist/cjs/ionic.cjs.js +5 -5
  320. package/dist/cjs/ios.transition-6787b799.js +654 -0
  321. package/dist/cjs/keyboard-0272231f.js +81 -0
  322. package/dist/cjs/{keyboard-38f2bb7b.js → keyboard-af1bb365.js} +62 -62
  323. package/dist/cjs/keyboard-controller-c05e747a.js +167 -0
  324. package/dist/cjs/loader.cjs.js +4 -4
  325. package/dist/cjs/lock-controller-6585a42a.js +40 -0
  326. package/dist/cjs/md.transition-e033d20a.js +59 -0
  327. package/dist/cjs/notch-controller-9735e7ac.js +155 -0
  328. package/dist/cjs/overlays-27a6fb16.js +716 -0
  329. package/dist/cjs/spinner-configs-282fd50a.js +147 -0
  330. package/dist/cjs/status-tap-415acac6.js +42 -0
  331. package/dist/cjs/swipe-back-e37a1a5c.js +81 -0
  332. package/dist/cjs/theme-d1c573d2.js +48 -0
  333. package/dist/cjs/watch-options-f5f3e158.js +49 -0
  334. package/dist/collection/collection-manifest.json +7 -7
  335. package/dist/collection/components/accordion/accordion.ios.css +44 -0
  336. package/dist/collection/components/accordion/accordion.js +410 -410
  337. package/dist/collection/components/accordion/accordion.md.css +22 -0
  338. package/dist/collection/components/accordion/test/a11y/accordion.e2e.js +31 -31
  339. package/dist/collection/components/accordion/test/accordion.e2e.js +24 -24
  340. package/dist/collection/components/accordion/test/accordion.spec.js +195 -0
  341. package/dist/collection/components/accordion/test/basic/accordion.e2e.js +26 -26
  342. package/dist/collection/components/accordion/test/multiple/accordion.e2e.js +18 -18
  343. package/dist/collection/components/accordion/test/nested/accordion.e2e.js +16 -16
  344. package/dist/collection/components/accordion/test/standalone/accordion.e2e.js +6 -6
  345. package/dist/collection/components/accordion-group/accordion-group.ios.css +44 -0
  346. package/dist/collection/components/accordion-group/accordion-group.js +422 -412
  347. package/dist/collection/components/accordion-group/accordion-group.md.css +68 -2
  348. package/dist/collection/components/action-sheet/action-sheet.ios.css +62 -5
  349. package/dist/collection/components/action-sheet/action-sheet.js +739 -729
  350. package/dist/collection/components/action-sheet/action-sheet.md.css +62 -5
  351. package/dist/collection/components/action-sheet/animations/ios.enter.js +18 -18
  352. package/dist/collection/components/action-sheet/animations/ios.leave.js +12 -12
  353. package/dist/collection/components/action-sheet/animations/md.enter.js +18 -18
  354. package/dist/collection/components/action-sheet/animations/md.leave.js +12 -12
  355. package/dist/collection/components/action-sheet/test/a11y/action-sheet.e2e.js +59 -59
  356. package/dist/collection/components/action-sheet/test/action-sheet-id.spec.js +32 -0
  357. package/dist/collection/components/action-sheet/test/basic/action-sheet-rendering.e2e.js +33 -33
  358. package/dist/collection/components/action-sheet/test/basic/action-sheet.e2e.js +118 -59
  359. package/dist/collection/components/action-sheet/test/basic/action-sheet.spec.js +18 -0
  360. package/dist/collection/components/action-sheet/test/basic/fixture.js +23 -23
  361. package/dist/collection/components/action-sheet/test/is-open/action-sheet.e2e.js +25 -25
  362. package/dist/collection/components/action-sheet/test/translucent/action-sheet.e2e.js +10 -10
  363. package/dist/collection/components/action-sheet/test/trigger/action-sheet.e2e.js +21 -21
  364. package/dist/collection/components/alert/alert.ios.css +122 -5
  365. package/dist/collection/components/alert/alert.js +977 -967
  366. package/dist/collection/components/alert/alert.md.css +152 -7
  367. package/dist/collection/components/alert/animations/ios.enter.js +19 -19
  368. package/dist/collection/components/alert/animations/ios.leave.js +13 -13
  369. package/dist/collection/components/alert/animations/md.enter.js +19 -19
  370. package/dist/collection/components/alert/animations/md.leave.js +10 -10
  371. package/dist/collection/components/alert/test/a11y/alert.e2e.js +139 -91
  372. package/dist/collection/components/alert/test/alert-id.spec.js +32 -0
  373. package/dist/collection/components/alert/test/alert.spec.js +37 -0
  374. package/dist/collection/components/alert/test/basic/alert-tablet.e2e.js +40 -0
  375. package/dist/collection/components/alert/test/basic/alert.e2e.js +96 -96
  376. package/dist/collection/components/alert/test/is-open/alert.e2e.js +25 -25
  377. package/dist/collection/components/alert/test/standalone/alert.e2e.js +9 -9
  378. package/dist/collection/components/alert/test/trigger/alert.e2e.js +21 -21
  379. package/dist/collection/components/app/app.js +116 -116
  380. package/dist/collection/components/app/test/safe-area/app.e2e.js +24 -24
  381. package/dist/collection/components/avatar/avatar.ios.css +44 -0
  382. package/dist/collection/components/avatar/avatar.js +17 -17
  383. package/dist/collection/components/avatar/avatar.md.css +44 -0
  384. package/dist/collection/components/avatar/test/basic/avatar.e2e.js +12 -12
  385. package/dist/collection/components/back-button/back-button.ios.css +44 -0
  386. package/dist/collection/components/back-button/back-button.js +214 -214
  387. package/dist/collection/components/back-button/back-button.md.css +44 -0
  388. package/dist/collection/components/back-button/test/a11y/back-button.e2e.js +6 -6
  389. package/dist/collection/components/back-button/test/back-button.spec.js +86 -0
  390. package/dist/collection/components/back-button/test/basic/back-button.e2e.js +6 -6
  391. package/dist/collection/components/back-button/test/toolbar/back-button.e2e.js +6 -6
  392. package/dist/collection/components/backdrop/backdrop.ios.css +44 -0
  393. package/dist/collection/components/backdrop/backdrop.js +131 -131
  394. package/dist/collection/components/backdrop/backdrop.md.css +44 -0
  395. package/dist/collection/components/badge/badge.ios.css +44 -0
  396. package/dist/collection/components/badge/badge.js +49 -49
  397. package/dist/collection/components/badge/badge.md.css +44 -0
  398. package/dist/collection/components/badge/test/a11y/badge.e2e.js +6 -6
  399. package/dist/collection/components/badge/test/basic/badge.e2e.js +6 -6
  400. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +44 -0
  401. package/dist/collection/components/breadcrumb/breadcrumb.js +395 -395
  402. package/dist/collection/components/breadcrumb/breadcrumb.md.css +44 -0
  403. package/dist/collection/components/breadcrumb/test/aria.spec.js +22 -0
  404. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +22 -0
  405. package/dist/collection/components/breadcrumbs/breadcrumbs.js +247 -247
  406. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +22 -0
  407. package/dist/collection/components/breadcrumbs/test/a11y/breadcrumbs.e2e.js +12 -12
  408. package/dist/collection/components/breadcrumbs/test/basic/breadcrumbs.e2e.js +6 -6
  409. package/dist/collection/components/breadcrumbs/test/breadcrumbs.spec.js +58 -0
  410. package/dist/collection/components/breadcrumbs/test/collapsed/breadcrumbs.e2e.js +6 -6
  411. package/dist/collection/components/breadcrumbs/test/reactive/breadcrumbs.e2e.js +43 -43
  412. package/dist/collection/components/button/button.ios.css +66 -0
  413. package/dist/collection/components/button/button.js +541 -541
  414. package/dist/collection/components/button/button.md.css +44 -0
  415. package/dist/collection/components/button/test/a11y/button.e2e.js +21 -21
  416. package/dist/collection/components/button/test/basic/button.e2e.js +32 -32
  417. package/dist/collection/components/button/test/clear/button.e2e.js +6 -6
  418. package/dist/collection/components/button/test/expand/button.e2e.js +6 -6
  419. package/dist/collection/components/button/test/form-reference/button.e2e.js +84 -84
  420. package/dist/collection/components/button/test/form-reference/button.spec.js +26 -0
  421. package/dist/collection/components/button/test/icon/button.e2e.js +6 -6
  422. package/dist/collection/components/button/test/outline/button.e2e.js +6 -6
  423. package/dist/collection/components/button/test/round/button.e2e.js +6 -6
  424. package/dist/collection/components/button/test/size/button.e2e.js +22 -22
  425. package/dist/collection/components/button/test/strong/button.e2e.js +22 -22
  426. package/dist/collection/components/button/test/wrap/button.e2e.js +73 -73
  427. package/dist/collection/components/buttons/buttons.ios.css +66 -0
  428. package/dist/collection/components/buttons/buttons.js +46 -46
  429. package/dist/collection/components/buttons/buttons.md.css +66 -0
  430. package/dist/collection/components/buttons/test/a11y/buttons.e2e.js +21 -21
  431. package/dist/collection/components/card/card.ios.css +44 -0
  432. package/dist/collection/components/card/card.js +251 -251
  433. package/dist/collection/components/card/card.md.css +44 -0
  434. package/dist/collection/components/card/test/a11y/card.e2e.js +6 -6
  435. package/dist/collection/components/card/test/aria.spec.js +16 -0
  436. package/dist/collection/components/card/test/basic/card.e2e.js +38 -38
  437. package/dist/collection/components/card-content/card-content.ios.css +44 -0
  438. package/dist/collection/components/card-content/card-content.js +21 -21
  439. package/dist/collection/components/card-content/card-content.md.css +44 -0
  440. package/dist/collection/components/card-header/card-header.ios.css +44 -0
  441. package/dist/collection/components/card-header/card-header.js +70 -70
  442. package/dist/collection/components/card-header/card-header.md.css +44 -0
  443. package/dist/collection/components/card-header/test/basic/card-header.e2e.js +6 -6
  444. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +44 -0
  445. package/dist/collection/components/card-subtitle/card-subtitle.js +50 -50
  446. package/dist/collection/components/card-subtitle/card-subtitle.md.css +44 -0
  447. package/dist/collection/components/card-title/card-title.ios.css +44 -0
  448. package/dist/collection/components/card-title/card-title.js +50 -50
  449. package/dist/collection/components/card-title/card-title.md.css +44 -0
  450. package/dist/collection/components/checkbox/checkbox.ios.css +69 -9
  451. package/dist/collection/components/checkbox/checkbox.js +418 -415
  452. package/dist/collection/components/checkbox/checkbox.md.css +69 -9
  453. package/dist/collection/components/checkbox/test/a11y/checkbox.e2e.js +14 -14
  454. package/dist/collection/components/checkbox/test/basic/checkbox.e2e.js +50 -50
  455. package/dist/collection/components/checkbox/test/checkbox.spec.js +34 -0
  456. package/dist/collection/components/checkbox/test/color/checkbox.e2e.js +11 -11
  457. package/dist/collection/components/checkbox/test/indeterminate/checkbox.e2e.js +6 -6
  458. package/dist/collection/components/checkbox/test/item/checkbox.e2e.js +29 -29
  459. package/dist/collection/components/checkbox/test/label/checkbox.e2e.js +75 -75
  460. package/dist/collection/components/checkbox/test/legacy/basic/checkbox.e2e.js +45 -45
  461. package/dist/collection/components/checkbox/test/legacy/indeterminate/checkbox.e2e.js +6 -6
  462. package/dist/collection/components/checkbox/test/states/checkbox.e2e.js +21 -21
  463. package/dist/collection/components/chip/chip.ios.css +22 -0
  464. package/dist/collection/components/chip/chip.js +90 -90
  465. package/dist/collection/components/chip/chip.md.css +22 -0
  466. package/dist/collection/components/chip/test/a11y/chip.e2e.js +19 -19
  467. package/dist/collection/components/chip/test/basic/chip.e2e.js +42 -42
  468. package/dist/collection/components/chip/test/states/chip.e2e.js +14 -14
  469. package/dist/collection/components/col/col.css +66 -0
  470. package/dist/collection/components/col/col.js +536 -536
  471. package/dist/collection/components/content/content.css +22 -0
  472. package/dist/collection/components/content/content.js +745 -745
  473. package/dist/collection/components/content/test/basic/content.e2e.js +6 -6
  474. package/dist/collection/components/content/test/fixed/content.e2e.js +6 -6
  475. package/dist/collection/components/content/test/fullscreen/content.e2e.js +6 -6
  476. package/dist/collection/components/content/test/standalone/content.e2e.js +5 -5
  477. package/dist/collection/components/datetime/datetime.ios.css +69 -4
  478. package/dist/collection/components/datetime/datetime.js +2246 -2208
  479. package/dist/collection/components/datetime/datetime.md.css +69 -8
  480. package/dist/collection/components/datetime/test/a11y/datetime.e2e.js +73 -7
  481. package/dist/collection/components/datetime/test/a11y/datetime.spec.js +43 -0
  482. package/dist/collection/components/datetime/test/basic/datetime.e2e.js +241 -241
  483. package/dist/collection/components/datetime/test/color/datetime.e2e.js +9 -9
  484. package/dist/collection/components/datetime/test/comparison.spec.js +43 -0
  485. package/dist/collection/components/datetime/test/custom/datetime.e2e.js +37 -37
  486. package/dist/collection/components/datetime/test/data.spec.js +456 -0
  487. package/dist/collection/components/datetime/test/datetime.e2e.js +29 -29
  488. package/dist/collection/components/datetime/test/disable-dates/datetime.e2e.js +119 -119
  489. package/dist/collection/components/datetime/test/disabled/datetime.e2e.js +68 -0
  490. package/dist/collection/components/datetime/test/disabled/datetime.spec.js +33 -0
  491. package/dist/collection/components/datetime/test/display/datetime.e2e.js +86 -86
  492. package/dist/collection/components/datetime/test/first-day-of-week/datetime.e2e.js +6 -6
  493. package/dist/collection/components/datetime/test/format.spec.js +124 -0
  494. package/dist/collection/components/datetime/test/helpers.spec.js +72 -0
  495. package/dist/collection/components/datetime/test/highlighted-dates/datetime.e2e.js +76 -76
  496. package/dist/collection/components/datetime/test/hour-cycle/datetime.e2e.js +21 -21
  497. package/dist/collection/components/datetime/test/locale/datetime.e2e.js +98 -98
  498. package/dist/collection/components/datetime/test/manipulation.spec.js +433 -0
  499. package/dist/collection/components/datetime/test/minmax/datetime.e2e.js +178 -178
  500. package/dist/collection/components/datetime/test/month-year-picker/datetime.e2e.js +17 -17
  501. package/dist/collection/components/datetime/test/multiple/datetime.e2e.js +170 -170
  502. package/dist/collection/components/datetime/test/parse.spec.js +222 -0
  503. package/dist/collection/components/datetime/test/position/datetime.e2e.js +14 -14
  504. package/dist/collection/components/datetime/test/prefer-wheel/datetime.e2e.js +263 -263
  505. package/dist/collection/components/datetime/test/presentation/datetime.e2e.js +137 -137
  506. package/dist/collection/components/datetime/test/readonly/datetime.e2e.js +113 -0
  507. package/dist/collection/components/datetime/test/set-value/datetime.e2e.js +40 -40
  508. package/dist/collection/components/datetime/test/state.spec.js +114 -0
  509. package/dist/collection/components/datetime/test/time-label/datetime.e2e.js +13 -13
  510. package/dist/collection/components/datetime/test/values/datetime.e2e.js +77 -77
  511. package/dist/collection/components/datetime/utils/comparison.js +22 -22
  512. package/dist/collection/components/datetime/utils/data.js +394 -394
  513. package/dist/collection/components/datetime/utils/format.js +143 -143
  514. package/dist/collection/components/datetime/utils/helpers.js +74 -74
  515. package/dist/collection/components/datetime/utils/manipulation.js +274 -274
  516. package/dist/collection/components/datetime/utils/parse.js +139 -139
  517. package/dist/collection/components/datetime/utils/state.js +123 -123
  518. package/dist/collection/components/datetime-button/datetime-button.css +22 -0
  519. package/dist/collection/components/datetime-button/datetime-button.js +399 -399
  520. package/dist/collection/components/datetime-button/test/a11y/datetime-button.e2e.js +11 -11
  521. package/dist/collection/components/datetime-button/test/basic/datetime-button.e2e.js +123 -123
  522. package/dist/collection/components/datetime-button/test/disabled/datetime-button.e2e.js +13 -13
  523. package/dist/collection/components/datetime-button/test/multiple/datetime-button.e2e.js +38 -38
  524. package/dist/collection/components/datetime-button/test/overlays/datetime-button.e2e.js +102 -102
  525. package/dist/collection/components/fab/fab.css +112 -36
  526. package/dist/collection/components/fab/fab.js +179 -179
  527. package/dist/collection/components/fab/test/basic/fab.e2e.js +50 -50
  528. package/dist/collection/components/fab/test/custom-size/fab.e2e.js +6 -6
  529. package/dist/collection/components/fab/test/safe-area/fab.e2e.js +63 -0
  530. package/dist/collection/components/fab/test/states/fab.e2e.js +6 -6
  531. package/dist/collection/components/fab/test/translucent/fab.e2e.js +17 -17
  532. package/dist/collection/components/fab-button/fab-button.ios.css +44 -0
  533. package/dist/collection/components/fab-button/fab-button.js +374 -374
  534. package/dist/collection/components/fab-button/fab-button.md.css +44 -0
  535. package/dist/collection/components/fab-button/test/a11y/fab-button.e2e.js +6 -6
  536. package/dist/collection/components/fab-list/fab-list.css +46 -2
  537. package/dist/collection/components/fab-list/fab-list.js +79 -79
  538. package/dist/collection/components/footer/footer.ios.css +44 -0
  539. package/dist/collection/components/footer/footer.js +135 -135
  540. package/dist/collection/components/footer/footer.md.css +44 -0
  541. package/dist/collection/components/footer/footer.utils.js +25 -25
  542. package/dist/collection/components/footer/test/basic/footer.e2e.js +18 -18
  543. package/dist/collection/components/footer/test/fade/footer.e2e.js +10 -10
  544. package/dist/collection/components/footer/test/scroll-target/footer.e2e.js +15 -15
  545. package/dist/collection/components/footer/test/with-tabs/footer.e2e.js +6 -6
  546. package/dist/collection/components/grid/grid.css +66 -0
  547. package/dist/collection/components/grid/grid.js +44 -44
  548. package/dist/collection/components/grid/test/basic/grid.e2e.js +6 -6
  549. package/dist/collection/components/grid/test/offsets/grid.e2e.js +6 -6
  550. package/dist/collection/components/grid/test/padding/grid.e2e.js +6 -6
  551. package/dist/collection/components/grid/test/sizes/grid.e2e.js +6 -6
  552. package/dist/collection/components/header/header.ios.css +48 -1
  553. package/dist/collection/components/header/header.js +181 -181
  554. package/dist/collection/components/header/header.md.css +44 -0
  555. package/dist/collection/components/header/header.utils.js +148 -148
  556. package/dist/collection/components/header/test/a11y/header.e2e.js +18 -18
  557. package/dist/collection/components/header/test/basic/header.e2e.js +23 -23
  558. package/dist/collection/components/header/test/condense/header.e2e.js +25 -25
  559. package/dist/collection/components/header/test/fade/header.e2e.js +10 -10
  560. package/dist/collection/components/header/test/scroll-target/header.e2e.js +15 -15
  561. package/dist/collection/components/icon/test/basic/icon.e2e.js +6 -6
  562. package/dist/collection/components/icon/test/dir/icon.e2e.js +11 -11
  563. package/dist/collection/components/img/img.js +177 -177
  564. package/dist/collection/components/img/test/basic/img.e2e.js +62 -62
  565. package/dist/collection/components/img/test/draggable/img.e2e.js +10 -10
  566. package/dist/collection/components/infinite-scroll/infinite-scroll.js +279 -271
  567. package/dist/collection/components/infinite-scroll/test/basic/infinite-scroll.e2e.js +11 -11
  568. package/dist/collection/components/infinite-scroll/test/scroll-target/infinite-scroll.e2e.js +11 -11
  569. package/dist/collection/components/infinite-scroll/test/small-dom-update/infinite-scroll.e2e.js +31 -0
  570. package/dist/collection/components/infinite-scroll/test/top/infinite-scroll.e2e.js +11 -11
  571. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +44 -0
  572. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +86 -86
  573. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +44 -0
  574. package/dist/collection/components/infinite-scroll-content/test/infinite-scroll-content.spec.js +37 -0
  575. package/dist/collection/components/input/input.ios.css +91 -18
  576. package/dist/collection/components/input/input.js +1234 -1200
  577. package/dist/collection/components/input/input.md.css +167 -22
  578. package/dist/collection/components/input/input.utils.js +22 -22
  579. package/dist/collection/components/input/test/a11y/input.e2e.js +12 -12
  580. package/dist/collection/components/input/test/basic/input.e2e.js +63 -63
  581. package/dist/collection/components/input/test/bottom-content/input.e2e.js +89 -89
  582. package/dist/collection/components/input/test/card/input.e2e.js +6 -6
  583. package/dist/collection/components/input/test/clear-on-edit/input.e2e.js +25 -25
  584. package/dist/collection/components/input/test/color/input.e2e.js +88 -88
  585. package/dist/collection/components/input/test/fill/input.e2e.js +63 -63
  586. package/dist/collection/components/input/test/highlight/input.e2e.js +52 -52
  587. package/dist/collection/components/input/test/input.e2e.js +6 -6
  588. package/dist/collection/components/input/test/input.spec.js +85 -0
  589. package/dist/collection/components/input/test/item/input.e2e.js +11 -11
  590. package/dist/collection/components/input/test/item/input.spec.js +24 -0
  591. package/dist/collection/components/input/test/label-placement/input.e2e.js +104 -104
  592. package/dist/collection/components/input/test/legacy/a11y/input.e2e.js +15 -15
  593. package/dist/collection/components/input/test/legacy/basic/input.e2e.js +102 -102
  594. package/dist/collection/components/input/test/legacy/clear-on-edit/input.e2e.js +44 -44
  595. package/dist/collection/components/input/test/legacy/input-events.e2e.js +56 -56
  596. package/dist/collection/components/input/test/legacy/masking/input.e2e.js +15 -15
  597. package/dist/collection/components/input/test/legacy/spec/input.e2e.js +8 -8
  598. package/dist/collection/components/input/test/slot/input.e2e.js +51 -0
  599. package/dist/collection/components/input/test/states/input.e2e.js +11 -11
  600. package/dist/collection/components/item/item.ios.css +145 -15
  601. package/dist/collection/components/item/item.js +614 -614
  602. package/dist/collection/components/item/item.md.css +192 -18
  603. package/dist/collection/components/item/test/a11y/item.e2e.js +47 -47
  604. package/dist/collection/components/item/test/a11y/item.spec.js +48 -0
  605. package/dist/collection/components/item/test/alignment/item.e2e.js +6 -6
  606. package/dist/collection/components/item/test/basic/item.e2e.js +32 -6
  607. package/dist/collection/components/item/test/buttons/item.e2e.js +18 -18
  608. package/dist/collection/components/item/test/colors/item.e2e.js +6 -6
  609. package/dist/collection/components/item/test/counter/item.e2e.js +34 -34
  610. package/dist/collection/components/item/test/css-variables/item.e2e.js +6 -6
  611. package/dist/collection/components/item/test/disabled/item.e2e.js +6 -7
  612. package/dist/collection/components/item/test/dividers/item.e2e.js +6 -6
  613. package/dist/collection/components/item/test/groups/item.e2e.js +8 -8
  614. package/dist/collection/components/item/test/highlight/item.e2e.js +6 -6
  615. package/dist/collection/components/item/test/icons/item.e2e.js +6 -6
  616. package/dist/collection/components/item/test/images/item.e2e.js +6 -6
  617. package/dist/collection/components/item/test/inputs/item.e2e.js +139 -139
  618. package/dist/collection/components/item/test/legacy/alignment/item.e2e.js +6 -6
  619. package/dist/collection/components/item/test/legacy/disabled/item.e2e.js +6 -6
  620. package/dist/collection/components/item/test/legacy/fill/item.e2e.js +6 -6
  621. package/dist/collection/components/item/test/legacy/form/item.e2e.js +6 -6
  622. package/dist/collection/components/item/test/lines/item.e2e.js +6 -6
  623. package/dist/collection/components/item/test/media/item.e2e.js +6 -6
  624. package/dist/collection/components/item/test/reorder/item.e2e.js +8 -8
  625. package/dist/collection/components/item/test/slotted-inputs/item.e2e.js +6 -6
  626. package/dist/collection/components/item/test/states/item.e2e.js +6 -6
  627. package/dist/collection/components/item-divider/item-divider.ios.css +101 -8
  628. package/dist/collection/components/item-divider/item-divider.js +71 -71
  629. package/dist/collection/components/item-divider/item-divider.md.css +101 -8
  630. package/dist/collection/components/item-divider/test/a11y/item-divider.e2e.js +11 -11
  631. package/dist/collection/components/item-divider/test/basic/item-divider.e2e.js +38 -16
  632. package/dist/collection/components/item-divider/test/spec/item-divider.e2e.js +8 -8
  633. package/dist/collection/components/item-group/item-group.ios.css +44 -0
  634. package/dist/collection/components/item-group/item-group.js +22 -22
  635. package/dist/collection/components/item-group/item-group.md.css +44 -0
  636. package/dist/collection/components/item-option/item-option.ios.css +44 -10
  637. package/dist/collection/components/item-option/item-option.js +197 -197
  638. package/dist/collection/components/item-option/item-option.md.css +44 -10
  639. package/dist/collection/components/item-options/item-options.ios.css +66 -0
  640. package/dist/collection/components/item-options/item-options.js +110 -110
  641. package/dist/collection/components/item-options/item-options.md.css +66 -0
  642. package/dist/collection/components/item-sliding/item-sliding.css +22 -0
  643. package/dist/collection/components/item-sliding/item-sliding.js +538 -538
  644. package/dist/collection/components/item-sliding/test/a11y/item-sliding.e2e.js +5 -5
  645. package/dist/collection/components/item-sliding/test/async/item-sliding.e2e.js +25 -25
  646. package/dist/collection/components/item-sliding/test/basic/item-sliding.e2e.js +140 -63
  647. package/dist/collection/components/item-sliding/test/icons/item-sliding.e2e.js +20 -20
  648. package/dist/collection/components/item-sliding/test/scroll-target/item-sliding.e2e.js +18 -18
  649. package/dist/collection/components/item-sliding/test/test.utils.js +20 -20
  650. package/dist/collection/components/label/label.ios.css +81 -4
  651. package/dist/collection/components/label/label.js +174 -174
  652. package/dist/collection/components/label/label.md.css +80 -3
  653. package/dist/collection/components/label/test/a11y/label.e2e.js +21 -21
  654. package/dist/collection/components/label/test/basic/label.e2e.js +21 -21
  655. package/dist/collection/components/label/test/color/label.e2e.js +21 -21
  656. package/dist/collection/components/label/test/headings/label.e2e.js +5 -5
  657. package/dist/collection/components/list/list.ios.css +81 -1
  658. package/dist/collection/components/list/list.js +101 -101
  659. package/dist/collection/components/list/list.md.css +107 -3
  660. package/dist/collection/components/list/test/a11y/list.e2e.js +6 -6
  661. package/dist/collection/components/list/test/basic/list.e2e.js +6 -6
  662. package/dist/collection/components/list/test/inset/list.e2e.js +16 -16
  663. package/dist/collection/components/list/test/lines/list.e2e.js +158 -15
  664. package/dist/collection/components/list-header/list-header.ios.css +81 -2
  665. package/dist/collection/components/list-header/list-header.js +69 -69
  666. package/dist/collection/components/list-header/list-header.md.css +81 -2
  667. package/dist/collection/components/list-header/test/a11y/list-header.e2e.js +6 -6
  668. package/dist/collection/components/list-header/test/basic/list-header.e2e.js +34 -6
  669. package/dist/collection/components/loading/animations/ios.enter.js +19 -19
  670. package/dist/collection/components/loading/animations/ios.leave.js +13 -13
  671. package/dist/collection/components/loading/animations/md.enter.js +19 -19
  672. package/dist/collection/components/loading/animations/md.leave.js +13 -13
  673. package/dist/collection/components/loading/loading.ios.css +44 -0
  674. package/dist/collection/components/loading/loading.js +730 -720
  675. package/dist/collection/components/loading/loading.md.css +44 -0
  676. package/dist/collection/components/loading/test/a11y/loading.e2e.js +26 -26
  677. package/dist/collection/components/loading/test/basic/loading.e2e.js +60 -60
  678. package/dist/collection/components/loading/test/basic/loading.spec.js +16 -0
  679. package/dist/collection/components/loading/test/is-open/loading.e2e.js +17 -17
  680. package/dist/collection/components/loading/test/loading-id.spec.js +32 -0
  681. package/dist/collection/components/loading/test/loading.spec.js +37 -0
  682. package/dist/collection/components/loading/test/standalone/loading.e2e.js +13 -13
  683. package/dist/collection/components/loading/test/trigger/loading.e2e.js +21 -21
  684. package/dist/collection/components/menu/menu.ios.css +48 -4
  685. package/dist/collection/components/menu/menu.js +956 -944
  686. package/dist/collection/components/menu/menu.md.css +48 -4
  687. package/dist/collection/components/menu/test/a11y/menu.e2e.js +13 -13
  688. package/dist/collection/components/menu/test/basic/menu.e2e.js +102 -102
  689. package/dist/collection/components/menu/test/disable/menu.e2e.js +44 -44
  690. package/dist/collection/components/menu/test/focus-trap/menu.e2e.js +61 -61
  691. package/dist/collection/components/menu/test/multiple/menu.e2e.js +49 -49
  692. package/dist/collection/components/menu/test/safe-area/menu.e2e.js +54 -54
  693. package/dist/collection/components/menu-button/menu-button.ios.css +44 -0
  694. package/dist/collection/components/menu-button/menu-button.js +173 -173
  695. package/dist/collection/components/menu-button/menu-button.md.css +44 -0
  696. package/dist/collection/components/menu-button/test/a11y/menu-button.e2e.js +12 -12
  697. package/dist/collection/components/menu-button/test/async/menu-button.e2e.js +12 -12
  698. package/dist/collection/components/menu-button/test/basic/menu-button.e2e.js +6 -6
  699. package/dist/collection/components/menu-toggle/menu-toggle-util.js +2 -2
  700. package/dist/collection/components/menu-toggle/menu-toggle.js +93 -93
  701. package/dist/collection/components/menu-toggle/test/basic/menu-toggle.e2e.js +33 -33
  702. package/dist/collection/components/modal/animations/ios.enter.js +81 -81
  703. package/dist/collection/components/modal/animations/ios.leave.js +74 -74
  704. package/dist/collection/components/modal/animations/md.enter.js +21 -21
  705. package/dist/collection/components/modal/animations/md.leave.js +15 -15
  706. package/dist/collection/components/modal/animations/sheet.js +43 -43
  707. package/dist/collection/components/modal/gestures/sheet.js +289 -289
  708. package/dist/collection/components/modal/gestures/swipe-to-close.js +248 -247
  709. package/dist/collection/components/modal/gestures/utils.js +39 -39
  710. package/dist/collection/components/modal/modal.ios.css +46 -2
  711. package/dist/collection/components/modal/modal.js +1290 -1280
  712. package/dist/collection/components/modal/modal.md.css +44 -0
  713. package/dist/collection/components/modal/test/a11y/modal.e2e.js +12 -12
  714. package/dist/collection/components/modal/test/a11y/modal.spec.js +22 -0
  715. package/dist/collection/components/modal/test/basic/modal.e2e.js +110 -110
  716. package/dist/collection/components/modal/test/basic/modal.spec.js +16 -0
  717. package/dist/collection/components/modal/test/can-dismiss/modal-card.e2e.js +44 -44
  718. package/dist/collection/components/modal/test/can-dismiss/modal-sheet.e2e.js +62 -62
  719. package/dist/collection/components/modal/test/can-dismiss/modal.e2e.js +16 -16
  720. package/dist/collection/components/modal/test/can-dismiss/modal.spec.js +191 -0
  721. package/dist/collection/components/modal/test/card/modal-card.e2e.js +69 -69
  722. package/dist/collection/components/modal/test/card/modal-tablet.e2e.js +67 -67
  723. package/dist/collection/components/modal/test/card-nav/modal.e2e.js +26 -26
  724. package/dist/collection/components/modal/test/card-refresher/modal.e2e.js +14 -14
  725. package/dist/collection/components/modal/test/card-scroll-target/modal.e2e.js +34 -34
  726. package/dist/collection/components/modal/test/custom/modal.e2e.js +16 -16
  727. package/dist/collection/components/modal/test/custom-dialog/modal.e2e.js +12 -12
  728. package/dist/collection/components/modal/test/dark-mode/model.e2e.js +12 -12
  729. package/dist/collection/components/modal/test/fixtures.js +21 -21
  730. package/dist/collection/components/modal/test/inline/modal.e2e.js +34 -34
  731. package/dist/collection/components/modal/test/is-open/modal.e2e.js +17 -17
  732. package/dist/collection/components/modal/test/modal-id.spec.js +32 -0
  733. package/dist/collection/components/modal/test/sheet/modal.e2e.js +178 -178
  734. package/dist/collection/components/modal/test/standalone/modal.e2e.js +12 -12
  735. package/dist/collection/components/modal/test/trigger/modal.e2e.js +23 -23
  736. package/dist/collection/components/modal/utils.js +55 -55
  737. package/dist/collection/components/modal/utils.spec.js +7 -7
  738. package/dist/collection/components/nav/nav.css +22 -0
  739. package/dist/collection/components/nav/nav.js +1748 -1748
  740. package/dist/collection/components/nav/test/basic/nav.e2e.js +58 -58
  741. package/dist/collection/components/nav/test/modal-navigation/nav.e2e.js +52 -52
  742. package/dist/collection/components/nav/test/nav-controller.spec.js +749 -0
  743. package/dist/collection/components/nav/test/nested/nav.e2e.js +54 -54
  744. package/dist/collection/components/nav/test/routing/nav.e2e.js +75 -75
  745. package/dist/collection/components/nav/view-controller.js +52 -52
  746. package/dist/collection/components/nav-link/nav-link-utils.js +16 -16
  747. package/dist/collection/components/nav-link/nav-link.js +106 -106
  748. package/dist/collection/components/note/note.ios.css +44 -0
  749. package/dist/collection/components/note/note.js +49 -49
  750. package/dist/collection/components/note/note.md.css +44 -0
  751. package/dist/collection/components/note/test/a11y/note.e2e.js +59 -16
  752. package/dist/collection/components/note/test/basic/note.e2e.js +33 -33
  753. package/dist/collection/components/picker/animations/ios.enter.js +18 -18
  754. package/dist/collection/components/picker/animations/ios.leave.js +14 -14
  755. package/dist/collection/components/picker/picker.ios.css +45 -1
  756. package/dist/collection/components/picker/picker.js +782 -772
  757. package/dist/collection/components/picker/picker.md.css +45 -1
  758. package/dist/collection/components/picker/test/basic/picker.e2e.js +17 -17
  759. package/dist/collection/components/picker/test/is-open/picker.e2e.js +17 -17
  760. package/dist/collection/components/picker/test/picker-id.spec.js +32 -0
  761. package/dist/collection/components/picker/test/trigger/picker.e2e.js +21 -21
  762. package/dist/collection/components/picker-column/picker-column.ios.css +44 -0
  763. package/dist/collection/components/picker-column/picker-column.js +377 -377
  764. package/dist/collection/components/picker-column/picker-column.md.css +44 -0
  765. package/dist/collection/components/picker-column/test/picker-column-aria.spec.js +35 -0
  766. package/dist/collection/components/picker-column/test/picker-column-dynamic.spec.js +29 -0
  767. package/dist/collection/components/picker-column/test/picker-column.spec.js +17 -0
  768. package/dist/collection/components/picker-column/test/standalone/picker-column.e2e.js +27 -27
  769. package/dist/collection/components/picker-column/test/test.utils.js +29 -29
  770. package/dist/collection/components/picker-column-internal/picker-column-internal.ios.css +33 -3
  771. package/dist/collection/components/picker-column-internal/picker-column-internal.js +523 -501
  772. package/dist/collection/components/picker-column-internal/picker-column-internal.md.css +55 -3
  773. package/dist/collection/components/picker-column-internal/test/basic/picker-column-internal.e2e.js +53 -53
  774. package/dist/collection/components/picker-column-internal/test/disabled/picker-column-internal.e2e.js +66 -37
  775. package/dist/collection/components/picker-internal/picker-internal.ios.css +46 -2
  776. package/dist/collection/components/picker-internal/picker-internal.js +517 -517
  777. package/dist/collection/components/picker-internal/picker-internal.md.css +46 -2
  778. package/dist/collection/components/picker-internal/test/a11y/picker-internal.e2e.js +6 -6
  779. package/dist/collection/components/picker-internal/test/basic/picker-internal.e2e.js +76 -71
  780. package/dist/collection/components/picker-internal/test/keyboard-entry/picker-internal.e2e.js +39 -39
  781. package/dist/collection/components/popover/animations/ios.enter.js +79 -79
  782. package/dist/collection/components/popover/animations/ios.leave.js +28 -28
  783. package/dist/collection/components/popover/animations/md.enter.js +58 -58
  784. package/dist/collection/components/popover/animations/md.leave.js +19 -19
  785. package/dist/collection/components/popover/popover.ios.css +48 -4
  786. package/dist/collection/components/popover/popover.js +1189 -1179
  787. package/dist/collection/components/popover/popover.md.css +46 -2
  788. package/dist/collection/components/popover/test/adjustment/popover.e2e.js +22 -22
  789. package/dist/collection/components/popover/test/arrow/popover.e2e.js +15 -15
  790. package/dist/collection/components/popover/test/async/popover.e2e.js +29 -29
  791. package/dist/collection/components/popover/test/basic/popover.e2e.js +108 -108
  792. package/dist/collection/components/popover/test/basic/popover.spec.js +16 -0
  793. package/dist/collection/components/popover/test/dismiss-on-select/popover.e2e.js +26 -26
  794. package/dist/collection/components/popover/test/fixture.js +16 -16
  795. package/dist/collection/components/popover/test/inline/popover.e2e.js +18 -18
  796. package/dist/collection/components/popover/test/is-open/popover.e2e.js +5 -5
  797. package/dist/collection/components/popover/test/nested/popover.e2e.js +81 -81
  798. package/dist/collection/components/popover/test/popover-id.spec.js +32 -0
  799. package/dist/collection/components/popover/test/position/popover.e2e.js +18 -18
  800. package/dist/collection/components/popover/test/reference/popover.e2e.js +14 -14
  801. package/dist/collection/components/popover/test/size/popover.e2e.js +29 -29
  802. package/dist/collection/components/popover/test/standalone/popover.e2e.js +7 -7
  803. package/dist/collection/components/popover/test/test.utils.js +23 -23
  804. package/dist/collection/components/popover/test/trigger/popover.e2e.js +35 -35
  805. package/dist/collection/components/popover/test/util.spec.js +53 -0
  806. package/dist/collection/components/popover/utils.js +606 -606
  807. package/dist/collection/components/progress-bar/progress-bar.ios.css +22 -0
  808. package/dist/collection/components/progress-bar/progress-bar.js +145 -145
  809. package/dist/collection/components/progress-bar/progress-bar.md.css +22 -0
  810. package/dist/collection/components/progress-bar/test/basic/progress-bar.e2e.js +6 -6
  811. package/dist/collection/components/progress-bar/test/buffer/progress-bar.e2e.js +10 -10
  812. package/dist/collection/components/progress-bar/test/determinate/progress-bar.e2e.js +10 -10
  813. package/dist/collection/components/radio/radio.ios.css +70 -10
  814. package/dist/collection/components/radio/radio.js +454 -447
  815. package/dist/collection/components/radio/radio.md.css +70 -10
  816. package/dist/collection/components/radio/test/a11y/radio.e2e.js +40 -40
  817. package/dist/collection/components/radio/test/color/radio.e2e.js +11 -11
  818. package/dist/collection/components/radio/test/item/radio.e2e.js +37 -37
  819. package/dist/collection/components/radio/test/label-placement/radio.e2e.js +70 -70
  820. package/dist/collection/components/radio/test/legacy/a11y/radio.e2e.js +29 -29
  821. package/dist/collection/components/radio/test/legacy/basic/radio.e2e.js +43 -43
  822. package/dist/collection/components/radio/test/radio.spec.js +60 -0
  823. package/dist/collection/components/radio/test/states/radio.e2e.js +21 -21
  824. package/dist/collection/components/radio-group/radio-group.js +280 -247
  825. package/dist/collection/components/radio-group/test/basic/radio-group.e2e.js +35 -35
  826. package/dist/collection/components/radio-group/test/fixtures.js +22 -22
  827. package/dist/collection/components/radio-group/test/form/radio-group.e2e.js +39 -39
  828. package/dist/collection/components/radio-group/test/legacy/basic/radio-group.e2e.js +59 -59
  829. package/dist/collection/components/radio-group/test/legacy/form/radio-group.e2e.js +22 -22
  830. package/dist/collection/components/radio-group/test/legacy/search/radio-group.e2e.js +27 -27
  831. package/dist/collection/components/radio-group/test/radio-group-events.e2e.js +42 -42
  832. package/dist/collection/components/radio-group/test/radio-group.spec.js +69 -0
  833. package/dist/collection/components/radio-group/test/search/radio-group.e2e.js +23 -23
  834. package/dist/collection/components/range/range.ios.css +45 -7
  835. package/dist/collection/components/range/range.js +1001 -998
  836. package/dist/collection/components/range/range.md.css +45 -7
  837. package/dist/collection/components/range/test/a11y/range.e2e.js +46 -46
  838. package/dist/collection/components/range/test/active-bar-start/range.e2e.js +6 -6
  839. package/dist/collection/components/range/test/basic/range.e2e.js +23 -23
  840. package/dist/collection/components/range/test/color/range.e2e.js +6 -6
  841. package/dist/collection/components/range/test/custom/range.e2e.js +6 -6
  842. package/dist/collection/components/range/test/item/range.e2e.js +28 -28
  843. package/dist/collection/components/range/test/label/range.e2e.js +99 -99
  844. package/dist/collection/components/range/test/label/range.spec.js +23 -0
  845. package/dist/collection/components/range/test/legacy/a11y/range.e2e.js +25 -25
  846. package/dist/collection/components/range/test/legacy/active-bar-start/range.e2e.js +6 -6
  847. package/dist/collection/components/range/test/legacy/basic/range.e2e.js +61 -61
  848. package/dist/collection/components/range/test/legacy/range-events.e2e.js +80 -80
  849. package/dist/collection/components/range/test/legacy/scroll-target/range.e2e.js +23 -23
  850. package/dist/collection/components/range/test/range-events.e2e.js +135 -135
  851. package/dist/collection/components/range/test/range.spec.js +221 -0
  852. package/dist/collection/components/range/test/scroll-target/range.e2e.js +23 -23
  853. package/dist/collection/components/range/test/states/range.e2e.js +21 -21
  854. package/dist/collection/components/refresher/refresher.ios.css +44 -0
  855. package/dist/collection/components/refresher/refresher.js +806 -806
  856. package/dist/collection/components/refresher/refresher.md.css +44 -0
  857. package/dist/collection/components/refresher/refresher.utils.js +148 -141
  858. package/dist/collection/components/refresher/test/basic/refresher.e2e.js +25 -25
  859. package/dist/collection/components/refresher/test/scroll-target/refresher.e2e.js +25 -25
  860. package/dist/collection/components/refresher/test/test.utils.js +5 -5
  861. package/dist/collection/components/refresher-content/refresher-content.js +131 -131
  862. package/dist/collection/components/refresher-content/test/refresher-content.spec.js +46 -0
  863. package/dist/collection/components/reorder/reorder.ios.css +23 -34
  864. package/dist/collection/components/reorder/reorder.js +37 -37
  865. package/dist/collection/components/reorder/reorder.md.css +23 -34
  866. package/dist/collection/components/reorder-group/reorder-group.css +22 -0
  867. package/dist/collection/components/reorder-group/reorder-group.js +327 -327
  868. package/dist/collection/components/reorder-group/test/a11y/reorder-group.e2e.js +6 -6
  869. package/dist/collection/components/reorder-group/test/basic/reorder-group.e2e.js +11 -11
  870. package/dist/collection/components/reorder-group/test/interactive/reorder-group.e2e.js +21 -21
  871. package/dist/collection/components/reorder-group/test/nested/reorder-group.e2e.js +21 -21
  872. package/dist/collection/components/reorder-group/test/scroll-target/reorder-group.e2e.js +21 -21
  873. package/dist/collection/components/ripple-effect/ripple-effect.css +22 -0
  874. package/dist/collection/components/ripple-effect/ripple-effect.js +135 -135
  875. package/dist/collection/components/ripple-effect/test/basic/ripple-effect.e2e.js +48 -48
  876. package/dist/collection/components/route/route.js +151 -151
  877. package/dist/collection/components/route-redirect/route-redirect.js +76 -76
  878. package/dist/collection/components/router/router.js +472 -472
  879. package/dist/collection/components/router/test/basic/router.e2e.js +55 -55
  880. package/dist/collection/components/router/test/guards/href/router.e2e.js +51 -51
  881. package/dist/collection/components/router/test/guards/link/router.e2e.js +51 -51
  882. package/dist/collection/components/router/test/guards/push/router.e2e.js +51 -51
  883. package/dist/collection/components/router/test/guards/router.e2e.js +5 -5
  884. package/dist/collection/components/router/test/guards/test.utils.js +2 -2
  885. package/dist/collection/components/router/test/matching.spec.js +250 -0
  886. package/dist/collection/components/router/test/parser.spec.js +133 -0
  887. package/dist/collection/components/router/test/path.spec.js +218 -0
  888. package/dist/collection/components/router/test/router.spec.js +55 -0
  889. package/dist/collection/components/router/utils/debug.js +14 -14
  890. package/dist/collection/components/router/utils/dom.js +56 -56
  891. package/dist/collection/components/router/utils/matching.js +150 -150
  892. package/dist/collection/components/router/utils/parser.js +52 -52
  893. package/dist/collection/components/router/utils/path.js +66 -66
  894. package/dist/collection/components/router-link/router-link.css +22 -0
  895. package/dist/collection/components/router-link/router-link.js +157 -157
  896. package/dist/collection/components/router-outlet/router-outlet.css +22 -0
  897. package/dist/collection/components/router-outlet/router-outlet.js +459 -459
  898. package/dist/collection/components/router-outlet/test/basic/router-outlet.e2e.js +31 -31
  899. package/dist/collection/components/row/row.css +66 -0
  900. package/dist/collection/components/row/row.js +15 -15
  901. package/dist/collection/components/searchbar/searchbar.ios.css +44 -0
  902. package/dist/collection/components/searchbar/searchbar.js +893 -884
  903. package/dist/collection/components/searchbar/searchbar.md.css +56 -6
  904. package/dist/collection/components/searchbar/test/a11y/searchbar.e2e.js +11 -11
  905. package/dist/collection/components/searchbar/test/basic/searchbar.e2e.js +116 -91
  906. package/dist/collection/components/searchbar/test/events/searchbar.e2e.js +55 -55
  907. package/dist/collection/components/searchbar/test/searchbar.spec.js +15 -0
  908. package/dist/collection/components/segment/segment.ios.css +66 -0
  909. package/dist/collection/components/segment/segment.js +633 -607
  910. package/dist/collection/components/segment/segment.md.css +66 -0
  911. package/dist/collection/components/segment/test/a11y/segment.e2e.js +37 -37
  912. package/dist/collection/components/segment/test/basic/segment.e2e.js +22 -22
  913. package/dist/collection/components/segment/test/custom/segment.e2e.js +6 -6
  914. package/dist/collection/components/segment/test/icon/segment.e2e.js +6 -6
  915. package/dist/collection/components/segment/test/modes/segment.e2e.js +15 -15
  916. package/dist/collection/components/segment/test/scrollable/segment.e2e.js +12 -12
  917. package/dist/collection/components/segment/test/segment-events.e2e.js +97 -97
  918. package/dist/collection/components/segment/test/segment.spec.js +37 -0
  919. package/dist/collection/components/segment/test/toolbar/segment.e2e.js +21 -21
  920. package/dist/collection/components/segment/test/wrap/segment.e2e.js +21 -21
  921. package/dist/collection/components/segment-button/segment-button.ios.css +44 -0
  922. package/dist/collection/components/segment-button/segment-button.js +217 -217
  923. package/dist/collection/components/segment-button/segment-button.md.css +44 -0
  924. package/dist/collection/components/select/select.ios.css +138 -22
  925. package/dist/collection/components/select/select.js +1201 -1184
  926. package/dist/collection/components/select/select.md.css +189 -26
  927. package/dist/collection/components/select/test/a11y/select.e2e.js +14 -14
  928. package/dist/collection/components/select/test/async/select.e2e.js +14 -14
  929. package/dist/collection/components/select/test/basic/select.e2e.js +140 -140
  930. package/dist/collection/components/select/test/card/select.e2e.js +6 -6
  931. package/dist/collection/components/select/test/color/select.e2e.js +22 -22
  932. package/dist/collection/components/select/test/compare-with/select.e2e.js +33 -33
  933. package/dist/collection/components/select/test/custom/select.e2e.js +19 -19
  934. package/dist/collection/components/select/test/disabled/select.e2e.js +17 -17
  935. package/dist/collection/components/select/test/fill/select.e2e.js +63 -63
  936. package/dist/collection/components/select/test/highlight/select.e2e.js +74 -74
  937. package/dist/collection/components/select/test/item/select.e2e.js +26 -11
  938. package/dist/collection/components/select/test/label/select.e2e.js +141 -141
  939. package/dist/collection/components/select/test/legacy/async/select.e2e.js +8 -8
  940. package/dist/collection/components/select/test/legacy/basic/select.e2e.js +108 -108
  941. package/dist/collection/components/select/test/legacy/compare-with/select.e2e.js +33 -33
  942. package/dist/collection/components/select/test/legacy/custom/custom.e2e.js +5 -5
  943. package/dist/collection/components/select/test/legacy/single-value/select.e2e.js +8 -8
  944. package/dist/collection/components/select/test/legacy/spec/select.e2e.js +6 -6
  945. package/dist/collection/components/select/test/legacy/standalone/select.e2e.js +11 -11
  946. package/dist/collection/components/select/test/legacy/wrapping/select.e2e.js +17 -17
  947. package/dist/collection/components/select/test/popover-size/select.e2e.js +63 -63
  948. package/dist/collection/components/select/test/select.spec.js +59 -0
  949. package/dist/collection/components/select/test/slot/select.e2e.js +67 -0
  950. package/dist/collection/components/select/test/states/select.e2e.js +21 -21
  951. package/dist/collection/components/select/test/toggle-icon/select.e2e.js +14 -14
  952. package/dist/collection/components/select/test/wrapping/select.e2e.js +16 -16
  953. package/dist/collection/components/select-option/select-option.js +60 -60
  954. package/dist/collection/components/select-popover/select-popover.ios.css +66 -0
  955. package/dist/collection/components/select-popover/select-popover.js +197 -197
  956. package/dist/collection/components/select-popover/select-popover.md.css +66 -0
  957. package/dist/collection/components/select-popover/test/basic/select-popover.e2e.js +52 -52
  958. package/dist/collection/components/select-popover/test/fixtures.js +33 -33
  959. package/dist/collection/components/skeleton-text/skeleton-text.css +22 -0
  960. package/dist/collection/components/skeleton-text/skeleton-text.js +87 -48
  961. package/dist/collection/components/skeleton-text/test/basic/skeleton-text.e2e.js +6 -6
  962. package/dist/collection/components/skeleton-text/test/custom/skeleton-text.e2e.js +6 -6
  963. package/dist/collection/components/slides/IonicSlides.js +95 -95
  964. package/dist/collection/components/spinner/spinner-configs.js +121 -121
  965. package/dist/collection/components/spinner/spinner.css +22 -0
  966. package/dist/collection/components/spinner/spinner.js +137 -137
  967. package/dist/collection/components/spinner/test/basic/spinner.e2e.js +10 -10
  968. package/dist/collection/components/spinner/test/color/spinner.e2e.js +10 -10
  969. package/dist/collection/components/spinner/test/resize/spinner.e2e.js +8 -8
  970. package/dist/collection/components/split-pane/split-pane.ios.css +66 -0
  971. package/dist/collection/components/split-pane/split-pane.js +225 -225
  972. package/dist/collection/components/split-pane/split-pane.md.css +66 -0
  973. package/dist/collection/components/split-pane/test/basic/split-pane.e2e.js +18 -18
  974. package/dist/collection/components/split-pane/test/multiple/split-pane.e2e.js +31 -0
  975. package/dist/collection/components/tab/tab.js +170 -170
  976. package/dist/collection/components/tab-bar/tab-bar.ios.css +70 -4
  977. package/dist/collection/components/tab-bar/tab-bar.js +177 -177
  978. package/dist/collection/components/tab-bar/tab-bar.md.css +70 -4
  979. package/dist/collection/components/tab-bar/test/basic/tab-bar.e2e.js +43 -0
  980. package/dist/collection/components/tab-bar/test/custom/tab-bar.e2e.js +6 -6
  981. package/dist/collection/components/tab-bar/test/translucent/tab-bar.e2e.js +14 -14
  982. package/dist/collection/components/tab-button/tab-button.ios.css +47 -3
  983. package/dist/collection/components/tab-button/tab-button.js +267 -267
  984. package/dist/collection/components/tab-button/tab-button.md.css +47 -3
  985. package/dist/collection/components/tab-button/test/a11y/tab-button.e2e.js +6 -6
  986. package/dist/collection/components/tab-button/test/basic/tab-button.e2e.js +16 -16
  987. package/dist/collection/components/tab-button/test/layout/tab-button.e2e.js +26 -26
  988. package/dist/collection/components/tab-button/test/states/tab-button.e2e.js +26 -26
  989. package/dist/collection/components/tabs/tabs.css +22 -0
  990. package/dist/collection/components/tabs/tabs.js +344 -344
  991. package/dist/collection/components/tabs/test/basic/tabs.e2e.js +24 -24
  992. package/dist/collection/components/tabs/test/placements/tabs.e2e.js +17 -17
  993. package/dist/collection/components/text/test/basic/text.e2e.js +11 -11
  994. package/dist/collection/components/text/text.css +22 -0
  995. package/dist/collection/components/text/text.js +47 -47
  996. package/dist/collection/components/textarea/test/a11y/textarea.e2e.js +12 -12
  997. package/dist/collection/components/textarea/test/autogrow/textarea.e2e.js +31 -31
  998. package/dist/collection/components/textarea/test/bottom-content/textarea.e2e.js +82 -82
  999. package/dist/collection/components/textarea/test/card/textarea.e2e.js +6 -6
  1000. package/dist/collection/components/textarea/test/clear-on-edit/textarea.e2e.js +17 -17
  1001. package/dist/collection/components/textarea/test/color/textarea.e2e.js +88 -88
  1002. package/dist/collection/components/textarea/test/cols/textarea.e2e.js +11 -11
  1003. package/dist/collection/components/textarea/test/fill/textarea.e2e.js +63 -63
  1004. package/dist/collection/components/textarea/test/highlight/textarea.e2e.js +52 -52
  1005. package/dist/collection/components/textarea/test/item/textarea.e2e.js +11 -11
  1006. package/dist/collection/components/textarea/test/label-placement/textarea.e2e.js +150 -150
  1007. package/dist/collection/components/textarea/test/legacy/a11y/textarea.e2e.js +15 -15
  1008. package/dist/collection/components/textarea/test/legacy/autogrow/textarea.e2e.js +31 -31
  1009. package/dist/collection/components/textarea/test/legacy/basic/textarea.e2e.js +30 -30
  1010. package/dist/collection/components/textarea/test/legacy/clear-on-edit/textarea.e2e.js +17 -17
  1011. package/dist/collection/components/textarea/test/slot/textarea.e2e.js +51 -0
  1012. package/dist/collection/components/textarea/test/states/textarea.e2e.js +11 -11
  1013. package/dist/collection/components/textarea/test/textarea-events.e2e.js +57 -57
  1014. package/dist/collection/components/textarea/test/textarea.spec.js +59 -0
  1015. package/dist/collection/components/textarea/textarea.ios.css +144 -24
  1016. package/dist/collection/components/textarea/textarea.js +1050 -1016
  1017. package/dist/collection/components/textarea/textarea.md.css +205 -34
  1018. package/dist/collection/components/thumbnail/test/basic/thumbnail.e2e.js +28 -28
  1019. package/dist/collection/components/thumbnail/thumbnail.css +22 -0
  1020. package/dist/collection/components/thumbnail/thumbnail.js +15 -15
  1021. package/dist/collection/components/title/test/a11y/title.e2e.js +17 -17
  1022. package/dist/collection/components/title/test/basic/title.e2e.js +13 -13
  1023. package/dist/collection/components/title/title.ios.css +24 -2
  1024. package/dist/collection/components/title/title.js +119 -119
  1025. package/dist/collection/components/title/title.md.css +22 -0
  1026. package/dist/collection/components/toast/animations/ios.enter.js +21 -20
  1027. package/dist/collection/components/toast/animations/ios.leave.js +18 -18
  1028. package/dist/collection/components/toast/animations/md.enter.js +23 -22
  1029. package/dist/collection/components/toast/animations/md.leave.js +6 -6
  1030. package/dist/collection/components/toast/animations/utils.js +62 -56
  1031. package/dist/collection/components/toast/gestures/swipe-to-dismiss.js +267 -0
  1032. package/dist/collection/components/toast/test/a11y/toast.e2e.js +92 -92
  1033. package/dist/collection/components/toast/test/basic/toast.e2e.js +101 -101
  1034. package/dist/collection/components/toast/test/is-open/toast.e2e.js +17 -17
  1035. package/dist/collection/components/toast/test/layout/toast.e2e.js +9 -9
  1036. package/dist/collection/components/toast/test/position-anchor/toast.e2e.js +37 -37
  1037. package/dist/collection/components/toast/test/standalone/toast.e2e.js +10 -10
  1038. package/dist/collection/components/toast/test/swipe-gesture/toast.e2e.js +84 -0
  1039. package/dist/collection/components/toast/test/toast-config.spec.js +25 -0
  1040. package/dist/collection/components/toast/test/toast-id.spec.js +32 -0
  1041. package/dist/collection/components/toast/test/toast.spec.js +200 -0
  1042. package/dist/collection/components/toast/test/trigger/toast.e2e.js +21 -21
  1043. package/dist/collection/components/toast/toast.ios.css +55 -11
  1044. package/dist/collection/components/toast/toast.js +1065 -952
  1045. package/dist/collection/components/toast/toast.md.css +55 -1
  1046. package/dist/collection/components/toggle/test/a11y/toggle.e2e.js +6 -6
  1047. package/dist/collection/components/toggle/test/color/toggle.e2e.js +11 -11
  1048. package/dist/collection/components/toggle/test/enable-on-off-labels/toggle.e2e.js +27 -27
  1049. package/dist/collection/components/toggle/test/item/toggle.e2e.js +52 -52
  1050. package/dist/collection/components/toggle/test/label/toggle.e2e.js +65 -65
  1051. package/dist/collection/components/toggle/test/legacy/basic/toggle.e2e.js +69 -69
  1052. package/dist/collection/components/toggle/test/legacy/enable-on-off-labels/toggle.e2e.js +23 -23
  1053. package/dist/collection/components/toggle/test/legacy/sizes/toggle.e2e.js +6 -6
  1054. package/dist/collection/components/toggle/test/sizes/toggle.e2e.js +6 -6
  1055. package/dist/collection/components/toggle/test/states/toggle.e2e.js +16 -16
  1056. package/dist/collection/components/toggle/test/toggle.spec.js +67 -0
  1057. package/dist/collection/components/toggle/toggle.ios.css +69 -9
  1058. package/dist/collection/components/toggle/toggle.js +487 -484
  1059. package/dist/collection/components/toggle/toggle.md.css +69 -9
  1060. package/dist/collection/components/toolbar/test/basic/toolbar.e2e.js +7 -7
  1061. package/dist/collection/components/toolbar/test/colors/toolbar.e2e.js +6 -6
  1062. package/dist/collection/components/toolbar/toolbar.ios.css +44 -0
  1063. package/dist/collection/components/toolbar/toolbar.js +100 -100
  1064. package/dist/collection/components/toolbar/toolbar.md.css +44 -0
  1065. package/dist/collection/css/test/a11y/typography.e2e.js +6 -6
  1066. package/dist/collection/global/config.js +51 -51
  1067. package/dist/collection/global/ionic-global.js +54 -54
  1068. package/dist/collection/global/test/config-controller.spec.js +77 -0
  1069. package/dist/collection/utils/animation/animation-utils.js +91 -91
  1070. package/dist/collection/utils/animation/animation.js +906 -890
  1071. package/dist/collection/utils/animation/cubic-bezier.js +49 -49
  1072. package/dist/collection/utils/animation/test/animation.spec.js +447 -0
  1073. package/dist/collection/utils/animation/test/animationbuilder/animation.e2e.js +26 -26
  1074. package/dist/collection/utils/animation/test/basic/animation.e2e.js +12 -12
  1075. package/dist/collection/utils/animation/test/display/animation.e2e.js +18 -18
  1076. package/dist/collection/utils/animation/test/hooks/animation.e2e.js +39 -39
  1077. package/dist/collection/utils/animation/test/multiple/animation.e2e.js +27 -27
  1078. package/dist/collection/utils/browser/index.js +0 -22
  1079. package/dist/collection/utils/config.js +20 -20
  1080. package/dist/collection/utils/content/content.utils.spec.js +121 -121
  1081. package/dist/collection/utils/content/index.js +58 -59
  1082. package/dist/collection/utils/floating-point/floating-point.spec.js +14 -14
  1083. package/dist/collection/utils/floating-point/index.js +5 -5
  1084. package/dist/collection/utils/focus-visible.js +63 -63
  1085. package/dist/collection/utils/forms/compare-with-utils.js +39 -0
  1086. package/dist/collection/utils/forms/form-controller.js +45 -49
  1087. package/dist/collection/utils/forms/index.js +1 -0
  1088. package/dist/collection/utils/forms/notch-controller.js +120 -120
  1089. package/dist/collection/utils/framework-delegate.js +121 -121
  1090. package/dist/collection/utils/gesture/button-active.js +56 -56
  1091. package/dist/collection/utils/gesture/gesture-controller.js +182 -182
  1092. package/dist/collection/utils/gesture/index.js +222 -222
  1093. package/dist/collection/utils/gesture/listener.js +36 -36
  1094. package/dist/collection/utils/gesture/pointer-events.js +113 -113
  1095. package/dist/collection/utils/gesture/recognizers.js +46 -46
  1096. package/dist/collection/utils/gesture/swipe-back.js +65 -65
  1097. package/dist/collection/utils/hardware-back-button.js +48 -48
  1098. package/dist/collection/utils/helpers.js +258 -258
  1099. package/dist/collection/utils/helpers.spec.js +28 -28
  1100. package/dist/collection/utils/input-shims/hacks/common.js +61 -53
  1101. package/dist/collection/utils/input-shims/hacks/hide-caret.js +19 -19
  1102. package/dist/collection/utils/input-shims/hacks/input-blurring.js +47 -47
  1103. package/dist/collection/utils/input-shims/hacks/scroll-assist.js +225 -225
  1104. package/dist/collection/utils/input-shims/hacks/scroll-data.js +29 -29
  1105. package/dist/collection/utils/input-shims/hacks/scroll-padding.js +21 -21
  1106. package/dist/collection/utils/input-shims/hacks/test/scroll-assist.e2e.js +97 -97
  1107. package/dist/collection/utils/input-shims/input-shims.js +87 -81
  1108. package/dist/collection/utils/keyboard/keyboard-controller.js +128 -128
  1109. package/dist/collection/utils/keyboard/keyboard.js +59 -59
  1110. package/dist/collection/utils/keyboard/test/keyboard-controller.spec.js +21 -0
  1111. package/dist/collection/utils/keyboard/test/keyboard.spec.js +214 -0
  1112. package/dist/collection/utils/lock-controller.js +24 -24
  1113. package/dist/collection/utils/logging/index.js +3 -3
  1114. package/dist/collection/utils/media.js +13 -13
  1115. package/dist/collection/utils/menu-controller/animations/base.js +8 -8
  1116. package/dist/collection/utils/menu-controller/animations/overlay.js +21 -21
  1117. package/dist/collection/utils/menu-controller/animations/push.js +20 -20
  1118. package/dist/collection/utils/menu-controller/animations/reveal.js +6 -6
  1119. package/dist/collection/utils/menu-controller/index.js +204 -206
  1120. package/dist/collection/utils/native/capacitor.js +4 -4
  1121. package/dist/collection/utils/native/haptic.js +151 -151
  1122. package/dist/collection/utils/native/keyboard.js +47 -47
  1123. package/dist/collection/utils/native/native-interface.js +15 -15
  1124. package/dist/collection/utils/native/status-bar.js +36 -36
  1125. package/dist/collection/utils/overlays.js +495 -494
  1126. package/dist/collection/utils/platform.js +56 -56
  1127. package/dist/collection/utils/rtl/dir.js +5 -5
  1128. package/dist/collection/utils/rtl/dir.spec.js +17 -17
  1129. package/dist/collection/utils/sanitization/index.js +122 -122
  1130. package/dist/collection/utils/sanitization/test/sanitization.spec.js +43 -0
  1131. package/dist/collection/utils/slot-mutation-controller.js +86 -85
  1132. package/dist/collection/utils/status-tap.js +26 -26
  1133. package/dist/collection/utils/tap-click/index.js +171 -171
  1134. package/dist/collection/utils/tap-click/test/tap-click.e2e.js +12 -12
  1135. package/dist/collection/utils/test/aria.spec.js +79 -0
  1136. package/dist/collection/utils/test/attributes.spec.js +53 -0
  1137. package/dist/collection/utils/test/framework-delegate/framework-delegate.e2e.js +25 -25
  1138. package/dist/collection/utils/test/hardware-back-button.spec.js +53 -0
  1139. package/dist/collection/utils/test/overlays/overlays.e2e.js +137 -137
  1140. package/dist/collection/utils/test/overlays/overlays.spec.js +102 -0
  1141. package/dist/collection/utils/test/platform.spec.js +132 -0
  1142. package/dist/collection/utils/test/platform.utils.js +77 -77
  1143. package/dist/collection/utils/test/playwright/drag-element.js +69 -69
  1144. package/dist/collection/utils/test/playwright/generator.js +48 -25
  1145. package/dist/collection/utils/test/playwright/matchers/index.js +3 -3
  1146. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEvent.js +21 -21
  1147. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventDetail.js +28 -28
  1148. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventTimes.js +22 -22
  1149. package/dist/collection/utils/test/playwright/page/event-spy.js +110 -110
  1150. package/dist/collection/utils/test/playwright/page/utils/goto.js +52 -52
  1151. package/dist/collection/utils/test/playwright/page/utils/locator.js +8 -8
  1152. package/dist/collection/utils/test/playwright/page/utils/set-content.js +44 -35
  1153. package/dist/collection/utils/test/playwright/page/utils/set-ion-viewport.js +19 -19
  1154. package/dist/collection/utils/test/playwright/page/utils/spy-on-event.js +4 -4
  1155. package/dist/collection/utils/test/playwright/page/utils/wait-for-changes.js +48 -48
  1156. package/dist/collection/utils/test/playwright/playwright-page.js +35 -35
  1157. package/dist/collection/utils/test/playwright/viewports/index.js +13 -13
  1158. package/dist/collection/utils/test/press-keys.js +77 -77
  1159. package/dist/collection/utils/test/ready.spec.js +39 -0
  1160. package/dist/collection/utils/test/theme.spec.js +56 -0
  1161. package/dist/collection/utils/theme.js +23 -23
  1162. package/dist/collection/utils/transition/index.js +163 -163
  1163. package/dist/collection/utils/transition/ios.transition.js +598 -598
  1164. package/dist/collection/utils/transition/md.transition.js +44 -44
  1165. package/dist/collection/utils/watch-options.js +37 -26
  1166. package/dist/docs.json +196 -39
  1167. package/dist/esm/animation-dde8cc0d.js +1060 -0
  1168. package/dist/esm/{app-globals-ec816a70.js → app-globals-722340c4.js} +1 -1
  1169. package/dist/esm/button-active-c6ee4f50.js +67 -0
  1170. package/dist/esm/capacitor-59395cbd.js +13 -0
  1171. package/dist/esm/compare-with-utils-a96ff2ea.js +41 -0
  1172. package/dist/esm/config-49c88215.js +193 -0
  1173. package/dist/esm/cubic-bezier-fe2083dc.js +90 -0
  1174. package/dist/esm/data-f5c75b4e.js +1575 -0
  1175. package/dist/esm/{dir-912e3e13.js → dir-babeabeb.js} +5 -5
  1176. package/dist/esm/focus-visible-dd40d69f.js +75 -0
  1177. package/dist/esm/form-controller-548aa79c.js +64 -0
  1178. package/dist/esm/framework-delegate-bc1fd82a.js +140 -0
  1179. package/dist/esm/gesture-controller-1bf57181.js +195 -0
  1180. package/dist/esm/haptic-554688a5.js +206 -0
  1181. package/dist/esm/hardware-back-button-b2bc76db.js +71 -0
  1182. package/dist/esm/helpers-ae653409.js +418 -0
  1183. package/dist/esm/{index-b49b173c.js → index-08d686eb.js} +184 -63
  1184. package/dist/esm/index-0c12c22b.js +306 -0
  1185. package/dist/esm/index-1932b201.js +231 -0
  1186. package/dist/esm/index-2cf77112.js +457 -0
  1187. package/dist/esm/index-82eeb47f.js +196 -0
  1188. package/dist/esm/{index-595d62c9.js → index-9b0d46f4.js} +3 -3
  1189. package/dist/esm/index-a5d50daf.js +7 -0
  1190. package/dist/esm/{index-746a238e.js → index-b9e742e5.js} +60 -61
  1191. package/dist/esm/index.js +113 -113
  1192. package/dist/esm/input-shims-6539ce13.js +599 -0
  1193. package/dist/esm/input.utils-a5a2d164.js +135 -0
  1194. package/dist/esm/ion-accordion_2.entry.js +491 -481
  1195. package/dist/esm/ion-action-sheet.entry.js +262 -252
  1196. package/dist/esm/ion-alert.entry.js +442 -432
  1197. package/dist/esm/ion-app_8.entry.js +1153 -1153
  1198. package/dist/esm/ion-avatar_3.entry.js +29 -29
  1199. package/dist/esm/ion-back-button.entry.js +73 -73
  1200. package/dist/esm/ion-backdrop.entry.js +40 -40
  1201. package/dist/esm/ion-breadcrumb_2.entry.js +194 -194
  1202. package/dist/esm/ion-button_2.entry.js +303 -303
  1203. package/dist/esm/ion-card_5.entry.js +105 -105
  1204. package/dist/esm/ion-checkbox.entry.js +149 -147
  1205. package/dist/esm/ion-chip.entry.js +20 -20
  1206. package/dist/esm/ion-col_3.entry.js +136 -136
  1207. package/dist/esm/ion-datetime-button.entry.js +325 -325
  1208. package/dist/esm/ion-datetime_3.entry.js +2185 -2137
  1209. package/dist/esm/ion-fab_3.entry.js +152 -152
  1210. package/dist/esm/ion-img.entry.js +79 -79
  1211. package/dist/esm/ion-infinite-scroll_2.entry.js +198 -190
  1212. package/dist/esm/ion-input.entry.js +426 -394
  1213. package/dist/esm/ion-item-option_3.entry.js +459 -459
  1214. package/dist/esm/ion-item_8.entry.js +447 -434
  1215. package/dist/esm/ion-loading.entry.js +220 -210
  1216. package/dist/esm/ion-menu_3.entry.js +670 -658
  1217. package/dist/esm/ion-modal.entry.js +1415 -1405
  1218. package/dist/esm/ion-nav_2.entry.js +904 -904
  1219. package/dist/esm/ion-picker-column-internal.entry.js +331 -327
  1220. package/dist/esm/ion-picker-internal.entry.js +455 -455
  1221. package/dist/esm/ion-popover.entry.js +1110 -1100
  1222. package/dist/esm/ion-progress-bar.entry.js +40 -40
  1223. package/dist/esm/ion-radio_2.entry.js +322 -309
  1224. package/dist/esm/ion-range.entry.js +558 -556
  1225. package/dist/esm/ion-refresher_2.entry.js +786 -779
  1226. package/dist/esm/ion-reorder_2.entry.js +269 -269
  1227. package/dist/esm/ion-ripple-effect.entry.js +66 -66
  1228. package/dist/esm/ion-route_4.entry.js +693 -693
  1229. package/dist/esm/ion-searchbar.entry.js +363 -354
  1230. package/dist/esm/ion-segment_2.entry.js +509 -483
  1231. package/dist/esm/ion-select_3.entry.js +784 -768
  1232. package/dist/esm/ion-spinner.entry.js +46 -46
  1233. package/dist/esm/ion-split-pane.entry.js +117 -117
  1234. package/dist/esm/ion-tab-bar_2.entry.js +142 -142
  1235. package/dist/esm/ion-tab_2.entry.js +187 -187
  1236. package/dist/esm/ion-text.entry.js +13 -13
  1237. package/dist/esm/ion-textarea.entry.js +381 -349
  1238. package/dist/esm/ion-toast.entry.js +771 -419
  1239. package/dist/esm/ion-toggle.entry.js +227 -225
  1240. package/dist/esm/ionic-global-c0cda98e.js +224 -0
  1241. package/dist/esm/ionic.js +6 -6
  1242. package/dist/esm/ios.transition-802a84a6.js +651 -0
  1243. package/dist/esm/keyboard-52278bd7.js +146 -0
  1244. package/dist/esm/keyboard-73175e24.js +79 -0
  1245. package/dist/esm/keyboard-controller-ec5c2bfa.js +165 -0
  1246. package/dist/esm/loader.js +5 -5
  1247. package/dist/esm/lock-controller-316928be.js +38 -0
  1248. package/dist/esm/md.transition-43c2874d.js +57 -0
  1249. package/dist/esm/notch-controller-fea7f9c5.js +153 -0
  1250. package/dist/esm/overlays-32ef481d.js +693 -0
  1251. package/dist/esm/spinner-configs-964f7cf3.js +145 -0
  1252. package/dist/esm/status-tap-2b93b1b5.js +40 -0
  1253. package/dist/esm/swipe-back-18cb49f7.js +79 -0
  1254. package/dist/esm/theme-01f3f29c.js +43 -0
  1255. package/dist/esm/watch-options-c2911ace.js +47 -0
  1256. package/dist/esm-es5/animation-dde8cc0d.js +4 -0
  1257. package/dist/esm-es5/app-globals-722340c4.js +4 -0
  1258. package/dist/esm-es5/{button-active-d926d4f4.js → button-active-c6ee4f50.js} +1 -1
  1259. package/dist/esm-es5/{capacitor-b4979570.js → capacitor-59395cbd.js} +1 -1
  1260. package/dist/esm-es5/compare-with-utils-a96ff2ea.js +4 -0
  1261. package/dist/esm-es5/config-49c88215.js +4 -0
  1262. package/dist/esm-es5/cubic-bezier-fe2083dc.js +4 -0
  1263. package/dist/esm-es5/data-f5c75b4e.js +4 -0
  1264. package/dist/esm-es5/{dir-912e3e13.js → dir-babeabeb.js} +1 -1
  1265. package/dist/esm-es5/focus-visible-dd40d69f.js +4 -0
  1266. package/dist/esm-es5/form-controller-548aa79c.js +4 -0
  1267. package/dist/esm-es5/framework-delegate-bc1fd82a.js +4 -0
  1268. package/dist/esm-es5/{gesture-controller-0fa396c4.js → gesture-controller-1bf57181.js} +1 -1
  1269. package/dist/esm-es5/{haptic-1243b917.js → haptic-554688a5.js} +1 -1
  1270. package/dist/esm-es5/hardware-back-button-b2bc76db.js +4 -0
  1271. package/dist/esm-es5/helpers-ae653409.js +4 -0
  1272. package/dist/esm-es5/index-08d686eb.js +5 -0
  1273. package/dist/esm-es5/index-0c12c22b.js +4 -0
  1274. package/dist/esm-es5/{index-a09eac70.js → index-1932b201.js} +1 -1
  1275. package/dist/esm-es5/index-2cf77112.js +4 -0
  1276. package/dist/esm-es5/index-82eeb47f.js +4 -0
  1277. package/dist/esm-es5/index-b9e742e5.js +4 -0
  1278. package/dist/esm-es5/index.js +1 -1
  1279. package/dist/esm-es5/input-shims-6539ce13.js +4 -0
  1280. package/dist/esm-es5/input.utils-a5a2d164.js +4 -0
  1281. package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
  1282. package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
  1283. package/dist/esm-es5/ion-alert.entry.js +1 -1
  1284. package/dist/esm-es5/ion-app_8.entry.js +1 -1
  1285. package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
  1286. package/dist/esm-es5/ion-back-button.entry.js +1 -1
  1287. package/dist/esm-es5/ion-backdrop.entry.js +1 -1
  1288. package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
  1289. package/dist/esm-es5/ion-button_2.entry.js +1 -1
  1290. package/dist/esm-es5/ion-card_5.entry.js +1 -1
  1291. package/dist/esm-es5/ion-checkbox.entry.js +1 -1
  1292. package/dist/esm-es5/ion-chip.entry.js +1 -1
  1293. package/dist/esm-es5/ion-col_3.entry.js +1 -1
  1294. package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
  1295. package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
  1296. package/dist/esm-es5/ion-fab_3.entry.js +1 -1
  1297. package/dist/esm-es5/ion-img.entry.js +1 -1
  1298. package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
  1299. package/dist/esm-es5/ion-input.entry.js +1 -1
  1300. package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
  1301. package/dist/esm-es5/ion-item_8.entry.js +1 -1
  1302. package/dist/esm-es5/ion-loading.entry.js +1 -1
  1303. package/dist/esm-es5/ion-menu_3.entry.js +1 -1
  1304. package/dist/esm-es5/ion-modal.entry.js +1 -1
  1305. package/dist/esm-es5/ion-nav_2.entry.js +1 -1
  1306. package/dist/esm-es5/ion-picker-column-internal.entry.js +1 -1
  1307. package/dist/esm-es5/ion-picker-internal.entry.js +1 -1
  1308. package/dist/esm-es5/ion-popover.entry.js +1 -1
  1309. package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
  1310. package/dist/esm-es5/ion-radio_2.entry.js +1 -1
  1311. package/dist/esm-es5/ion-range.entry.js +1 -1
  1312. package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
  1313. package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
  1314. package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
  1315. package/dist/esm-es5/ion-route_4.entry.js +1 -1
  1316. package/dist/esm-es5/ion-searchbar.entry.js +1 -1
  1317. package/dist/esm-es5/ion-segment_2.entry.js +1 -1
  1318. package/dist/esm-es5/ion-select_3.entry.js +1 -1
  1319. package/dist/esm-es5/ion-spinner.entry.js +1 -1
  1320. package/dist/esm-es5/ion-split-pane.entry.js +1 -1
  1321. package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
  1322. package/dist/esm-es5/ion-tab_2.entry.js +1 -1
  1323. package/dist/esm-es5/ion-text.entry.js +1 -1
  1324. package/dist/esm-es5/ion-textarea.entry.js +1 -1
  1325. package/dist/esm-es5/ion-toast.entry.js +1 -1
  1326. package/dist/esm-es5/ion-toggle.entry.js +1 -1
  1327. package/dist/esm-es5/ionic-global-c0cda98e.js +4 -0
  1328. package/dist/esm-es5/ionic.js +1 -1
  1329. package/dist/esm-es5/{ios.transition-4d1322d6.js → ios.transition-802a84a6.js} +1 -1
  1330. package/dist/esm-es5/{keyboard-b551279d.js → keyboard-52278bd7.js} +1 -1
  1331. package/dist/esm-es5/{keyboard-b063f012.js → keyboard-73175e24.js} +1 -1
  1332. package/dist/esm-es5/keyboard-controller-ec5c2bfa.js +4 -0
  1333. package/dist/esm-es5/loader.js +1 -1
  1334. package/dist/esm-es5/md.transition-43c2874d.js +4 -0
  1335. package/dist/esm-es5/notch-controller-fea7f9c5.js +4 -0
  1336. package/dist/esm-es5/overlays-32ef481d.js +4 -0
  1337. package/dist/esm-es5/spinner-configs-964f7cf3.js +4 -0
  1338. package/dist/esm-es5/status-tap-2b93b1b5.js +4 -0
  1339. package/dist/esm-es5/swipe-back-18cb49f7.js +4 -0
  1340. package/dist/esm-es5/watch-options-c2911ace.js +4 -0
  1341. package/dist/html.html-data.json +17 -4
  1342. package/dist/ionic/index.esm.js +1 -1
  1343. package/dist/ionic/ionic.esm.js +1 -1
  1344. package/dist/ionic/ionic.js +15 -15
  1345. package/dist/ionic/p-012c3ceb.system.js +4 -0
  1346. package/dist/ionic/p-013013a3.js +4 -0
  1347. package/dist/ionic/p-01d14eba.system.entry.js +4 -0
  1348. package/dist/ionic/p-042e6f4b.entry.js +4 -0
  1349. package/dist/ionic/{p-819ff3b9.system.js → p-08e01816.system.js} +1 -1
  1350. package/dist/ionic/{p-f919c026.entry.js → p-0add7211.entry.js} +1 -1
  1351. package/dist/ionic/p-0bd51c34.system.js +4 -0
  1352. package/dist/ionic/{p-6f6646bf.system.entry.js → p-0e53f8ea.system.entry.js} +1 -1
  1353. package/dist/ionic/{p-6ea2e653.entry.js → p-1161a793.entry.js} +1 -1
  1354. package/dist/ionic/{p-96ba8eac.entry.js → p-1208f939.entry.js} +1 -1
  1355. package/dist/ionic/p-16756e94.system.entry.js +4 -0
  1356. package/dist/ionic/p-1786bc72.js +4 -0
  1357. package/dist/ionic/{p-1ecba429.entry.js → p-17da5ed1.entry.js} +1 -1
  1358. package/dist/ionic/p-18ba8221.entry.js +4 -0
  1359. package/dist/ionic/p-1b19c04b.entry.js +4 -0
  1360. package/dist/ionic/p-1cca10d6.system.js +4 -0
  1361. package/dist/ionic/p-1e4371bd.js +4 -0
  1362. package/dist/ionic/{p-fcf47f80.entry.js → p-2092f39f.entry.js} +1 -1
  1363. package/dist/ionic/p-251666e2.entry.js +4 -0
  1364. package/dist/ionic/{p-7423746f.entry.js → p-270e1a1d.entry.js} +1 -1
  1365. package/dist/ionic/{p-419eb426.js → p-27281edd.js} +1 -1
  1366. package/dist/ionic/p-28249b10.system.entry.js +4 -0
  1367. package/dist/ionic/p-28a2c2a2.entry.js +4 -0
  1368. package/dist/ionic/{p-6129af0a.system.entry.js → p-2938823a.system.entry.js} +1 -1
  1369. package/dist/ionic/p-29d03b3a.js +4 -0
  1370. package/dist/ionic/{p-17240d90.js → p-2aea8b1e.js} +1 -1
  1371. package/dist/ionic/p-2b7827c7.js +4 -0
  1372. package/dist/ionic/p-2d3b9fa3.system.entry.js +4 -0
  1373. package/dist/ionic/p-2d539df1.entry.js +4 -0
  1374. package/dist/ionic/p-31b2326e.system.js +4 -0
  1375. package/dist/ionic/{p-e028178a.system.js → p-31fcb233.system.js} +1 -1
  1376. package/dist/ionic/p-32ad210f.system.js +4 -0
  1377. package/dist/ionic/{p-aa377971.system.js → p-33a37fad.system.js} +1 -1
  1378. package/dist/ionic/p-350f7292.system.entry.js +4 -0
  1379. package/dist/ionic/{p-cabd2c6d.entry.js → p-353b349d.entry.js} +1 -1
  1380. package/dist/ionic/p-36d187af.js +4 -0
  1381. package/dist/ionic/p-376a6063.js +4 -0
  1382. package/dist/ionic/p-38c337e7.system.js +4 -0
  1383. package/dist/ionic/p-38f2c6bb.system.js +4 -0
  1384. package/dist/ionic/{p-9e106f58.entry.js → p-3a45a82b.entry.js} +1 -1
  1385. package/dist/ionic/{p-3bad5c1a.js → p-3a75d7fd.js} +1 -1
  1386. package/dist/ionic/p-3dd98a73.entry.js +4 -0
  1387. package/dist/ionic/p-3e6b47e8.system.entry.js +4 -0
  1388. package/dist/ionic/p-3f5179b5.entry.js +4 -0
  1389. package/dist/ionic/p-40f68333.system.js +4 -0
  1390. package/dist/ionic/p-4155f352.system.js +4 -0
  1391. package/dist/ionic/{p-b287ab05.js → p-4180a747.js} +1 -1
  1392. package/dist/ionic/p-4233cc1e.system.entry.js +4 -0
  1393. package/dist/ionic/{p-b923f3d7.js → p-42f189f4.js} +1 -1
  1394. package/dist/ionic/p-459d13d5.js +4 -0
  1395. package/dist/ionic/p-4609d030.system.js +4 -0
  1396. package/dist/ionic/p-46d400b4.system.entry.js +4 -0
  1397. package/dist/ionic/{p-cf62e1c8.js → p-47b6ba5b.js} +1 -1
  1398. package/dist/ionic/p-4d67d27a.entry.js +4 -0
  1399. package/dist/ionic/p-4f255d5a.system.js +4 -0
  1400. package/dist/ionic/p-4fb51e61.system.entry.js +4 -0
  1401. package/dist/ionic/{p-c575a7b8.system.entry.js → p-517a9885.system.entry.js} +1 -1
  1402. package/dist/ionic/{p-8083aadb.entry.js → p-51a087d6.entry.js} +1 -1
  1403. package/dist/ionic/p-53ec4f1c.system.js +4 -0
  1404. package/dist/ionic/{p-6f8a95a3.system.entry.js → p-564af202.system.entry.js} +2 -2
  1405. package/dist/ionic/{p-0ac3fb2c.entry.js → p-588fdf40.entry.js} +1 -1
  1406. package/dist/ionic/p-5b365ca7.system.js +4 -0
  1407. package/dist/ionic/{p-c42c86c0.system.entry.js → p-5bebc7b3.system.entry.js} +1 -1
  1408. package/dist/ionic/p-5e4eec2e.entry.js +4 -0
  1409. package/dist/ionic/{p-2a8eeef7.system.js → p-5e745192.system.js} +1 -1
  1410. package/dist/ionic/{p-76378400.js → p-5ecae037.js} +1 -1
  1411. package/dist/ionic/{p-c679fcb5.entry.js → p-5eda1d7d.entry.js} +1 -1
  1412. package/dist/ionic/{p-1289b3b5.system.entry.js → p-6577aea9.system.entry.js} +2 -2
  1413. package/dist/ionic/p-66d633fb.js +4 -0
  1414. package/dist/ionic/{p-0bbede6a.system.entry.js → p-6ad34705.system.entry.js} +1 -1
  1415. package/dist/ionic/p-6de472cb.js +4 -0
  1416. package/dist/ionic/{p-ce7d67a7.system.entry.js → p-6de62649.system.entry.js} +2 -2
  1417. package/dist/ionic/{p-8a2801f1.system.entry.js → p-6e70dd1a.system.entry.js} +1 -1
  1418. package/dist/ionic/{p-61b192a4.system.entry.js → p-6f8dbe92.system.entry.js} +1 -1
  1419. package/dist/ionic/{p-0b00b937.entry.js → p-6fbecbda.entry.js} +1 -1
  1420. package/dist/ionic/p-72f6ff89.js +4 -0
  1421. package/dist/ionic/p-765f4dde.entry.js +4 -0
  1422. package/dist/ionic/p-7798c78a.system.js +4 -0
  1423. package/dist/ionic/p-78aadecb.entry.js +4 -0
  1424. package/dist/ionic/p-790220fd.system.js +4 -0
  1425. package/dist/ionic/p-7d92bf15.system.entry.js +4 -0
  1426. package/dist/ionic/p-80fa068e.entry.js +4 -0
  1427. package/dist/ionic/p-82e3d633.system.js +4 -0
  1428. package/dist/ionic/p-8314281e.system.js +4 -0
  1429. package/dist/ionic/p-8804a472.system.entry.js +4 -0
  1430. package/dist/ionic/p-888db766.system.js +4 -0
  1431. package/dist/ionic/p-88d5fbd3.js +4 -0
  1432. package/dist/ionic/p-88fde0e0.entry.js +4 -0
  1433. package/dist/ionic/p-8985cdb6.system.js +4 -0
  1434. package/dist/ionic/p-8aa1d0b7.system.js +4 -0
  1435. package/dist/ionic/p-8acae6b0.system.entry.js +4 -0
  1436. package/dist/ionic/p-8d69a624.entry.js +4 -0
  1437. package/dist/ionic/p-8f5d30f5.entry.js +4 -0
  1438. package/dist/ionic/{p-beb864e4.system.entry.js → p-908475e7.system.entry.js} +1 -1
  1439. package/dist/ionic/p-91d33c4a.js +4 -0
  1440. package/dist/ionic/p-953009b1.entry.js +4 -0
  1441. package/dist/ionic/{p-eb8dc56f.system.entry.js → p-958d6ebe.system.entry.js} +2 -2
  1442. package/dist/ionic/{p-78030c1f.system.entry.js → p-9709ebd8.system.entry.js} +1 -1
  1443. package/dist/ionic/p-9738fd82.js +5 -0
  1444. package/dist/ionic/p-979d4f5c.system.js +4 -0
  1445. package/dist/ionic/{p-c4a5de01.entry.js → p-98f3d827.entry.js} +1 -1
  1446. package/dist/ionic/p-9b7f0b0f.entry.js +4 -0
  1447. package/dist/ionic/p-9e447eb1.system.js +4 -0
  1448. package/dist/ionic/p-9eec42cc.system.entry.js +4 -0
  1449. package/dist/ionic/p-9f6ee2c0.system.entry.js +4 -0
  1450. package/dist/ionic/p-a0bb7b92.system.entry.js +4 -0
  1451. package/dist/ionic/p-a0d7bb5e.system.js +4 -0
  1452. package/dist/ionic/p-a1987850.entry.js +4 -0
  1453. package/dist/ionic/{p-8209372c.entry.js → p-a3277a67.entry.js} +1 -1
  1454. package/dist/ionic/{p-4e6e43c1.entry.js → p-a4afcc88.entry.js} +1 -1
  1455. package/dist/ionic/p-a9978d08.entry.js +4 -0
  1456. package/dist/ionic/p-ada96dd0.system.entry.js +4 -0
  1457. package/dist/ionic/p-afd6ca9d.entry.js +4 -0
  1458. package/dist/ionic/p-b3b3efba.system.entry.js +4 -0
  1459. package/dist/ionic/p-b4a51c42.system.js +4 -0
  1460. package/dist/ionic/p-b56d0866.system.entry.js +4 -0
  1461. package/dist/ionic/{p-4e50b8d1.entry.js → p-b5f9f14c.entry.js} +1 -1
  1462. package/dist/ionic/{p-eab10949.system.entry.js → p-b6f5e4f2.system.entry.js} +1 -1
  1463. package/dist/ionic/p-b6f9d32a.entry.js +4 -0
  1464. package/dist/ionic/p-b7010c69.system.entry.js +4 -0
  1465. package/dist/ionic/{p-181b7c2a.js → p-c3c3333a.js} +1 -1
  1466. package/dist/ionic/p-c468af8a.system.js +4 -0
  1467. package/dist/ionic/p-c61cc894.js +4 -0
  1468. package/dist/ionic/p-c7c8429a.system.js +4 -0
  1469. package/dist/ionic/p-c847fb35.system.entry.js +4 -0
  1470. package/dist/ionic/{p-e0f52215.system.entry.js → p-c91ccbfa.system.entry.js} +1 -1
  1471. package/dist/ionic/p-c9a21dfd.system.entry.js +4 -0
  1472. package/dist/ionic/p-cabad15b.system.js +4 -0
  1473. package/dist/ionic/{p-8c1805f4.system.entry.js → p-caf21b46.system.entry.js} +1 -1
  1474. package/dist/ionic/p-cce9f61a.system.entry.js +4 -0
  1475. package/dist/ionic/{p-de68588d.js → p-cdbeaadc.js} +1 -1
  1476. package/dist/ionic/{p-108f9d49.entry.js → p-cfe57b1b.entry.js} +1 -1
  1477. package/dist/ionic/p-d032f825.system.entry.js +4 -0
  1478. package/dist/ionic/{p-31119a15.entry.js → p-d37b441e.entry.js} +1 -1
  1479. package/dist/ionic/p-d3b030b8.system.js +5 -0
  1480. package/dist/ionic/p-d51674c5.system.js +4 -0
  1481. package/dist/ionic/p-d8d84afa.system.js +4 -0
  1482. package/dist/ionic/p-dc6af8e9.entry.js +4 -0
  1483. package/dist/ionic/{p-3818f63f.entry.js → p-ddb30596.entry.js} +1 -1
  1484. package/dist/ionic/p-ddbb2d5b.system.js +4 -0
  1485. package/dist/ionic/p-de6f8b28.system.js +4 -0
  1486. package/dist/ionic/p-de756e5c.js +4 -0
  1487. package/dist/ionic/p-dee7c1d0.system.entry.js +4 -0
  1488. package/dist/ionic/{p-e0f0d55f.system.js → p-e24ce1e5.system.js} +1 -1
  1489. package/dist/ionic/p-e3584231.system.js +4 -0
  1490. package/dist/ionic/{p-c4f2dce7.system.js → p-e673a0a2.system.js} +1 -1
  1491. package/dist/ionic/p-e6d68e02.system.entry.js +4 -0
  1492. package/dist/ionic/{p-012952cd.system.entry.js → p-e7ea9815.system.entry.js} +2 -2
  1493. package/dist/ionic/{p-db1a1e00.entry.js → p-e94c392d.entry.js} +1 -1
  1494. package/dist/ionic/{p-a04bfada.entry.js → p-ea69616e.entry.js} +1 -1
  1495. package/dist/ionic/p-eef72e06.js +4 -0
  1496. package/dist/ionic/p-ef126ae8.system.entry.js +4 -0
  1497. package/dist/ionic/p-f0445d82.system.entry.js +4 -0
  1498. package/dist/ionic/p-f233f1e0.system.js +4 -0
  1499. package/dist/ionic/p-f5d2dc9b.js +4 -0
  1500. package/dist/ionic/p-f656e032.system.entry.js +4 -0
  1501. package/dist/ionic/p-f70970cf.js +4 -0
  1502. package/dist/ionic/p-f8a5bb89.entry.js +4 -0
  1503. package/dist/ionic/p-fba0a6e7.system.entry.js +4 -0
  1504. package/dist/ionic/p-feae5133.entry.js +4 -0
  1505. package/dist/ionic/p-ff4b7e40.system.js +4 -0
  1506. package/dist/types/components/accordion/accordion.d.ts +62 -62
  1507. package/dist/types/components/accordion-group/accordion-group-interface.d.ts +3 -3
  1508. package/dist/types/components/accordion-group/accordion-group.d.ts +76 -76
  1509. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +25 -25
  1510. package/dist/types/components/action-sheet/action-sheet.d.ts +149 -149
  1511. package/dist/types/components/action-sheet/test/basic/fixture.d.ts +7 -7
  1512. package/dist/types/components/alert/alert-interface.d.ts +45 -45
  1513. package/dist/types/components/alert/alert.d.ts +181 -181
  1514. package/dist/types/components/app/app.d.ts +15 -15
  1515. package/dist/types/components/avatar/avatar.d.ts +1 -1
  1516. package/dist/types/components/back-button/back-button.d.ts +41 -41
  1517. package/dist/types/components/backdrop/backdrop.d.ts +22 -22
  1518. package/dist/types/components/badge/badge.d.ts +7 -7
  1519. package/dist/types/components/breadcrumb/breadcrumb-interface.d.ts +4 -4
  1520. package/dist/types/components/breadcrumb/breadcrumb.d.ts +87 -87
  1521. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +39 -39
  1522. package/dist/types/components/button/button.d.ts +121 -121
  1523. package/dist/types/components/buttons/buttons.d.ts +14 -14
  1524. package/dist/types/components/card/card.d.ts +57 -57
  1525. package/dist/types/components/card-content/card-content.d.ts +1 -1
  1526. package/dist/types/components/card-header/card-header.d.ts +13 -13
  1527. package/dist/types/components/card-subtitle/card-subtitle.d.ts +7 -7
  1528. package/dist/types/components/card-title/card-title.d.ts +7 -7
  1529. package/dist/types/components/checkbox/checkbox-interface.d.ts +4 -4
  1530. package/dist/types/components/checkbox/checkbox.d.ts +112 -111
  1531. package/dist/types/components/chip/chip.d.ts +15 -15
  1532. package/dist/types/components/col/col.d.ts +128 -128
  1533. package/dist/types/components/content/content-interface.d.ts +6 -6
  1534. package/dist/types/components/content/content.d.ts +129 -129
  1535. package/dist/types/components/datetime/datetime-interface.d.ts +15 -15
  1536. package/dist/types/components/datetime/datetime.d.ts +407 -407
  1537. package/dist/types/components/datetime/utils/data.d.ts +11 -11
  1538. package/dist/types/components/datetime/utils/manipulation.d.ts +25 -25
  1539. package/dist/types/components/datetime/utils/state.d.ts +8 -8
  1540. package/dist/types/components/datetime-button/datetime-button.d.ts +59 -59
  1541. package/dist/types/components/fab/fab.d.ts +33 -33
  1542. package/dist/types/components/fab-button/fab-button.d.ts +88 -88
  1543. package/dist/types/components/fab-list/fab-list.d.ts +11 -11
  1544. package/dist/types/components/footer/footer.d.ts +27 -27
  1545. package/dist/types/components/grid/grid.d.ts +5 -5
  1546. package/dist/types/components/header/header.d.ts +31 -31
  1547. package/dist/types/components/header/header.utils.d.ts +7 -7
  1548. package/dist/types/components/img/img.d.ts +30 -30
  1549. package/dist/types/components/infinite-scroll/infinite-scroll-interface.d.ts +1 -1
  1550. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +65 -58
  1551. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +23 -23
  1552. package/dist/types/components/input/input-interface.d.ts +6 -6
  1553. package/dist/types/components/input/input.d.ts +321 -315
  1554. package/dist/types/components/item/item.d.ts +111 -111
  1555. package/dist/types/components/item-divider/item-divider.d.ts +16 -16
  1556. package/dist/types/components/item-group/item-group.d.ts +1 -1
  1557. package/dist/types/components/item-option/item-option.d.ts +44 -44
  1558. package/dist/types/components/item-options/item-options.d.ts +13 -13
  1559. package/dist/types/components/item-sliding/item-sliding-interface.d.ts +1 -1
  1560. package/dist/types/components/item-sliding/item-sliding.d.ts +75 -75
  1561. package/dist/types/components/label/label.d.ts +30 -30
  1562. package/dist/types/components/list/list.d.ts +17 -17
  1563. package/dist/types/components/list-header/list-header.d.ts +11 -11
  1564. package/dist/types/components/loading/loading-interface.d.ts +16 -16
  1565. package/dist/types/components/loading/loading.d.ts +152 -152
  1566. package/dist/types/components/menu/menu-interface.d.ts +39 -39
  1567. package/dist/types/components/menu/menu.d.ts +140 -140
  1568. package/dist/types/components/menu-button/menu-button.d.ts +30 -30
  1569. package/dist/types/components/menu-toggle/menu-toggle.d.ts +21 -21
  1570. package/dist/types/components/modal/animations/sheet.d.ts +4 -4
  1571. package/dist/types/components/modal/gestures/sheet.d.ts +30 -30
  1572. package/dist/types/components/modal/gestures/swipe-to-close.d.ts +1 -1
  1573. package/dist/types/components/modal/modal-interface.d.ts +27 -27
  1574. package/dist/types/components/modal/modal.d.ts +265 -265
  1575. package/dist/types/components/modal/test/fixtures.d.ts +7 -7
  1576. package/dist/types/components/nav/nav-interface.d.ts +40 -40
  1577. package/dist/types/components/nav/nav.d.ts +247 -247
  1578. package/dist/types/components/nav/view-controller.d.ts +13 -13
  1579. package/dist/types/components/nav-link/nav-link.d.ts +19 -19
  1580. package/dist/types/components/note/note.d.ts +7 -7
  1581. package/dist/types/components/picker/picker-interface.d.ts +43 -43
  1582. package/dist/types/components/picker/picker.d.ts +149 -149
  1583. package/dist/types/components/picker-column/picker-column.d.ts +39 -39
  1584. package/dist/types/components/picker-column-internal/picker-column-internal-interfaces.d.ts +3 -3
  1585. package/dist/types/components/picker-column-internal/picker-column-internal.d.ts +93 -89
  1586. package/dist/types/components/picker-internal/picker-internal-interfaces.d.ts +4 -4
  1587. package/dist/types/components/picker-internal/picker-internal.d.ts +94 -94
  1588. package/dist/types/components/popover/popover-interface.d.ts +26 -26
  1589. package/dist/types/components/popover/popover.d.ts +279 -279
  1590. package/dist/types/components/popover/test/fixture.d.ts +5 -5
  1591. package/dist/types/components/popover/utils.d.ts +25 -25
  1592. package/dist/types/components/progress-bar/progress-bar.d.ts +27 -27
  1593. package/dist/types/components/radio/radio.d.ts +100 -99
  1594. package/dist/types/components/radio-group/radio-group-interface.d.ts +5 -4
  1595. package/dist/types/components/radio-group/radio-group.d.ts +51 -44
  1596. package/dist/types/components/radio-group/test/fixtures.d.ts +5 -5
  1597. package/dist/types/components/range/range-interface.d.ts +7 -7
  1598. package/dist/types/components/range/range.d.ts +193 -192
  1599. package/dist/types/components/refresher/refresher-interface.d.ts +3 -3
  1600. package/dist/types/components/refresher/refresher.d.ts +132 -132
  1601. package/dist/types/components/refresher-content/refresher-content.d.ts +44 -44
  1602. package/dist/types/components/reorder/reorder.d.ts +3 -3
  1603. package/dist/types/components/reorder-group/reorder-group-interface.d.ts +5 -5
  1604. package/dist/types/components/reorder-group/reorder-group.d.ts +53 -53
  1605. package/dist/types/components/ripple-effect/ripple-effect.d.ts +20 -20
  1606. package/dist/types/components/route/route-interface.d.ts +1 -1
  1607. package/dist/types/components/route/route.d.ts +43 -43
  1608. package/dist/types/components/route-redirect/route-redirect.d.ts +33 -33
  1609. package/dist/types/components/router/router.d.ts +74 -73
  1610. package/dist/types/components/router/utils/dom.d.ts +2 -2
  1611. package/dist/types/components/router/utils/interface.d.ts +31 -31
  1612. package/dist/types/components/router/utils/matching.d.ts +6 -6
  1613. package/dist/types/components/router-link/router-link.d.ts +34 -34
  1614. package/dist/types/components/router-outlet/router-outlet.d.ts +41 -41
  1615. package/dist/types/components/row/row.d.ts +1 -1
  1616. package/dist/types/components/searchbar/searchbar-interface.d.ts +6 -6
  1617. package/dist/types/components/searchbar/searchbar.d.ts +235 -233
  1618. package/dist/types/components/segment/segment-interface.d.ts +3 -3
  1619. package/dist/types/components/segment/segment.d.ts +82 -82
  1620. package/dist/types/components/segment-button/segment-button.d.ts +36 -36
  1621. package/dist/types/components/select/select-interface.d.ts +3 -3
  1622. package/dist/types/components/select/select.d.ts +238 -233
  1623. package/dist/types/components/select-option/select-option.d.ts +11 -11
  1624. package/dist/types/components/select-popover/select-popover-interface.d.ts +8 -8
  1625. package/dist/types/components/select-popover/select-popover.d.ts +39 -39
  1626. package/dist/types/components/select-popover/test/fixtures.d.ts +12 -12
  1627. package/dist/types/components/skeleton-text/skeleton-text.d.ts +15 -7
  1628. package/dist/types/components/spinner/spinner-configs.d.ts +96 -96
  1629. package/dist/types/components/spinner/spinner-interface.d.ts +14 -14
  1630. package/dist/types/components/spinner/spinner.d.ts +21 -21
  1631. package/dist/types/components/split-pane/split-pane.d.ts +33 -33
  1632. package/dist/types/components/tab/tab.d.ts +21 -21
  1633. package/dist/types/components/tab-bar/tab-bar-interface.d.ts +4 -4
  1634. package/dist/types/components/tab-bar/tab-bar.d.ts +34 -34
  1635. package/dist/types/components/tab-button/tab-button.d.ts +56 -56
  1636. package/dist/types/components/tabs/tabs-interface.d.ts +4 -4
  1637. package/dist/types/components/tabs/tabs.d.ts +52 -52
  1638. package/dist/types/components/text/text.d.ts +7 -7
  1639. package/dist/types/components/textarea/textarea-interface.d.ts +6 -6
  1640. package/dist/types/components/textarea/textarea.d.ts +275 -269
  1641. package/dist/types/components/thumbnail/thumbnail.d.ts +1 -1
  1642. package/dist/types/components/title/title.d.ts +21 -21
  1643. package/dist/types/components/toast/animations/utils.d.ts +15 -4
  1644. package/dist/types/components/toast/gestures/swipe-to-dismiss.d.ts +9 -0
  1645. package/dist/types/components/toast/toast-interface.d.ts +37 -35
  1646. package/dist/types/components/toast/toast.d.ts +241 -214
  1647. package/dist/types/components/toggle/toggle-interface.d.ts +4 -4
  1648. package/dist/types/components/toggle/toggle.d.ts +117 -116
  1649. package/dist/types/components/toolbar/toolbar.d.ts +11 -11
  1650. package/dist/types/components.d.ts +679 -16
  1651. package/dist/types/global/config.d.ts +6 -6
  1652. package/dist/types/interface.d.ts +1 -5
  1653. package/dist/types/jest.d.ts +5 -0
  1654. package/dist/types/stencil-public-runtime.d.ts +10 -0
  1655. package/dist/types/utils/animation/animation-interface.d.ts +205 -205
  1656. package/dist/types/utils/browser/index.d.ts +17 -8
  1657. package/dist/types/utils/config.d.ts +175 -175
  1658. package/dist/types/utils/content/index.d.ts +1 -1
  1659. package/dist/types/utils/element-interface.d.ts +6 -6
  1660. package/dist/types/utils/focus-visible.d.ts +5 -4
  1661. package/dist/types/utils/forms/compare-with-utils.d.ts +18 -0
  1662. package/dist/types/utils/forms/form-controller.d.ts +3 -3
  1663. package/dist/types/utils/forms/index.d.ts +1 -0
  1664. package/dist/types/utils/forms/notch-controller.d.ts +2 -2
  1665. package/dist/types/utils/framework-delegate.d.ts +3 -3
  1666. package/dist/types/utils/gesture/gesture-controller.d.ts +49 -49
  1667. package/dist/types/utils/gesture/index.d.ts +31 -31
  1668. package/dist/types/utils/gesture/listener.d.ts +2 -2
  1669. package/dist/types/utils/gesture/pointer-events.d.ts +12 -12
  1670. package/dist/types/utils/gesture/recognizers.d.ts +4 -4
  1671. package/dist/types/utils/hardware-back-button.d.ts +4 -0
  1672. package/dist/types/utils/helpers.d.ts +8 -8
  1673. package/dist/types/utils/input-shims/hacks/scroll-data.d.ts +4 -4
  1674. package/dist/types/utils/keyboard/keyboard-controller.d.ts +3 -3
  1675. package/dist/types/utils/lock-controller.d.ts +1 -1
  1676. package/dist/types/utils/native/haptic.d.ts +38 -38
  1677. package/dist/types/utils/native/keyboard.d.ts +29 -29
  1678. package/dist/types/utils/native/native-interface.d.ts +15 -15
  1679. package/dist/types/utils/native/status-bar.d.ts +8 -8
  1680. package/dist/types/utils/overlays-interface.d.ts +27 -27
  1681. package/dist/types/utils/overlays.d.ts +29 -28
  1682. package/dist/types/utils/platform.d.ts +16 -16
  1683. package/dist/types/utils/sanitization/index.d.ts +2 -2
  1684. package/dist/types/utils/slot-mutation-controller.d.ts +3 -3
  1685. package/dist/types/utils/test/platform.utils.d.ts +67 -67
  1686. package/dist/types/utils/test/playwright/generator.d.ts +16 -7
  1687. package/dist/types/utils/test/playwright/matchers/index.d.ts +3 -3
  1688. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEvent.d.ts +2 -2
  1689. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventDetail.d.ts +2 -2
  1690. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventTimes.d.ts +2 -2
  1691. package/dist/types/utils/test/playwright/page/event-spy.d.ts +15 -15
  1692. package/dist/types/utils/test/playwright/page/utils/goto.d.ts +3 -3
  1693. package/dist/types/utils/test/playwright/page/utils/locator.d.ts +15 -15
  1694. package/dist/types/utils/test/playwright/playwright-declarations.d.ts +92 -92
  1695. package/dist/types/utils/test/playwright/playwright-page.d.ts +3 -3
  1696. package/dist/types/utils/test/playwright/viewports/index.d.ts +12 -12
  1697. package/dist/types/utils/test/press-keys.d.ts +14 -14
  1698. package/dist/types/utils/transition/index.d.ts +6 -6
  1699. package/dist/types/utils/watch-options.d.ts +9 -1
  1700. package/hydrate/index.d.ts +1 -1
  1701. package/hydrate/index.js +30673 -29948
  1702. package/package.json +10 -12
  1703. package/dist/cjs/animation-c8bdd3c7.js +0 -1046
  1704. package/dist/cjs/button-active-c0ff1915.js +0 -69
  1705. package/dist/cjs/config-d5882735.js +0 -199
  1706. package/dist/cjs/cubic-bezier-6b9222ad.js +0 -92
  1707. package/dist/cjs/data-c8d21093.js +0 -1622
  1708. package/dist/cjs/focus-visible-a7545600.js +0 -77
  1709. package/dist/cjs/form-controller-5e223b54.js +0 -70
  1710. package/dist/cjs/framework-delegate-c0873a6f.js +0 -144
  1711. package/dist/cjs/gesture-controller-b46721be.js +0 -197
  1712. package/dist/cjs/haptic-678abc9f.js +0 -212
  1713. package/dist/cjs/hardware-back-button-b67c8e75.js +0 -76
  1714. package/dist/cjs/helpers-ea4ccbcb.js +0 -441
  1715. package/dist/cjs/index-0ee995e4.js +0 -459
  1716. package/dist/cjs/index-306a7476.js +0 -32
  1717. package/dist/cjs/index-5e7529f6.js +0 -310
  1718. package/dist/cjs/index-9f379eaa.js +0 -198
  1719. package/dist/cjs/index-eccba000.js +0 -243
  1720. package/dist/cjs/input-shims-da7dc0de.js +0 -588
  1721. package/dist/cjs/input.utils-0fe3097c.js +0 -137
  1722. package/dist/cjs/ionic-global-fb752503.js +0 -230
  1723. package/dist/cjs/ios.transition-5af5991e.js +0 -654
  1724. package/dist/cjs/keyboard-controller-50beb83a.js +0 -167
  1725. package/dist/cjs/keyboard-fd7db491.js +0 -81
  1726. package/dist/cjs/lock-controller-4ae2eb59.js +0 -40
  1727. package/dist/cjs/md.transition-1e740a6a.js +0 -59
  1728. package/dist/cjs/notch-controller-f4f6af5d.js +0 -155
  1729. package/dist/cjs/overlays-1a734051.js +0 -714
  1730. package/dist/cjs/spinner-configs-f7b5105b.js +0 -147
  1731. package/dist/cjs/status-tap-778e8054.js +0 -42
  1732. package/dist/cjs/swipe-back-7e843e77.js +0 -81
  1733. package/dist/cjs/theme-fbc56b3b.js +0 -48
  1734. package/dist/cjs/watch-options-f3f77e54.js +0 -38
  1735. package/dist/collection/components/item/test/text/item.e2e.js +0 -14
  1736. package/dist/esm/animation-92066c62.js +0 -1044
  1737. package/dist/esm/button-active-d926d4f4.js +0 -67
  1738. package/dist/esm/capacitor-b4979570.js +0 -13
  1739. package/dist/esm/config-96c9ace3.js +0 -193
  1740. package/dist/esm/cubic-bezier-66542bc5.js +0 -90
  1741. package/dist/esm/data-44d9e816.js +0 -1575
  1742. package/dist/esm/focus-visible-85493433.js +0 -75
  1743. package/dist/esm/form-controller-ed77647a.js +0 -68
  1744. package/dist/esm/framework-delegate-aa433dea.js +0 -140
  1745. package/dist/esm/gesture-controller-0fa396c4.js +0 -195
  1746. package/dist/esm/haptic-1243b917.js +0 -206
  1747. package/dist/esm/hardware-back-button-39299f84.js +0 -71
  1748. package/dist/esm/helpers-3379ba19.js +0 -418
  1749. package/dist/esm/index-7a14ecec.js +0 -29
  1750. package/dist/esm/index-a09eac70.js +0 -231
  1751. package/dist/esm/index-df55802d.js +0 -308
  1752. package/dist/esm/index-f0cc4e14.js +0 -196
  1753. package/dist/esm/index-ff313b19.js +0 -457
  1754. package/dist/esm/input-shims-d78a3c77.js +0 -586
  1755. package/dist/esm/input.utils-ec063df4.js +0 -134
  1756. package/dist/esm/ionic-global-246ca78f.js +0 -224
  1757. package/dist/esm/ios.transition-4d1322d6.js +0 -651
  1758. package/dist/esm/keyboard-b063f012.js +0 -79
  1759. package/dist/esm/keyboard-b551279d.js +0 -146
  1760. package/dist/esm/keyboard-controller-0c2dce71.js +0 -165
  1761. package/dist/esm/lock-controller-e8c6c051.js +0 -38
  1762. package/dist/esm/md.transition-66b425d0.js +0 -57
  1763. package/dist/esm/notch-controller-8c9c0e54.js +0 -153
  1764. package/dist/esm/overlays-cec6bac8.js +0 -692
  1765. package/dist/esm/spinner-configs-d09fbbbb.js +0 -145
  1766. package/dist/esm/status-tap-9aeeaca5.js +0 -40
  1767. package/dist/esm/swipe-back-cd4295f3.js +0 -79
  1768. package/dist/esm/theme-17531cdf.js +0 -43
  1769. package/dist/esm/watch-options-355a920a.js +0 -36
  1770. package/dist/esm-es5/animation-92066c62.js +0 -4
  1771. package/dist/esm-es5/app-globals-ec816a70.js +0 -4
  1772. package/dist/esm-es5/config-96c9ace3.js +0 -4
  1773. package/dist/esm-es5/cubic-bezier-66542bc5.js +0 -4
  1774. package/dist/esm-es5/data-44d9e816.js +0 -4
  1775. package/dist/esm-es5/focus-visible-85493433.js +0 -4
  1776. package/dist/esm-es5/form-controller-ed77647a.js +0 -4
  1777. package/dist/esm-es5/framework-delegate-aa433dea.js +0 -4
  1778. package/dist/esm-es5/hardware-back-button-39299f84.js +0 -4
  1779. package/dist/esm-es5/helpers-3379ba19.js +0 -4
  1780. package/dist/esm-es5/index-746a238e.js +0 -4
  1781. package/dist/esm-es5/index-b49b173c.js +0 -5
  1782. package/dist/esm-es5/index-df55802d.js +0 -4
  1783. package/dist/esm-es5/index-f0cc4e14.js +0 -4
  1784. package/dist/esm-es5/index-ff313b19.js +0 -4
  1785. package/dist/esm-es5/input-shims-d78a3c77.js +0 -4
  1786. package/dist/esm-es5/input.utils-ec063df4.js +0 -4
  1787. package/dist/esm-es5/ionic-global-246ca78f.js +0 -4
  1788. package/dist/esm-es5/keyboard-controller-0c2dce71.js +0 -4
  1789. package/dist/esm-es5/md.transition-66b425d0.js +0 -4
  1790. package/dist/esm-es5/notch-controller-8c9c0e54.js +0 -4
  1791. package/dist/esm-es5/overlays-cec6bac8.js +0 -4
  1792. package/dist/esm-es5/spinner-configs-d09fbbbb.js +0 -4
  1793. package/dist/esm-es5/status-tap-9aeeaca5.js +0 -4
  1794. package/dist/esm-es5/swipe-back-cd4295f3.js +0 -4
  1795. package/dist/esm-es5/watch-options-355a920a.js +0 -4
  1796. package/dist/ionic/p-015187e5.system.js +0 -4
  1797. package/dist/ionic/p-06ac429a.js +0 -5
  1798. package/dist/ionic/p-091c8792.system.js +0 -4
  1799. package/dist/ionic/p-0b7c25ee.system.entry.js +0 -4
  1800. package/dist/ionic/p-0f1f59da.system.entry.js +0 -4
  1801. package/dist/ionic/p-19fba51c.entry.js +0 -4
  1802. package/dist/ionic/p-1a463b1e.system.entry.js +0 -4
  1803. package/dist/ionic/p-1edb53a1.entry.js +0 -4
  1804. package/dist/ionic/p-1f260a7b.entry.js +0 -4
  1805. package/dist/ionic/p-1f81b5be.entry.js +0 -4
  1806. package/dist/ionic/p-276afddd.js +0 -4
  1807. package/dist/ionic/p-28ea45b9.js +0 -4
  1808. package/dist/ionic/p-29073efe.system.entry.js +0 -4
  1809. package/dist/ionic/p-2b89ea1b.system.js +0 -4
  1810. package/dist/ionic/p-303bf1e8.system.entry.js +0 -4
  1811. package/dist/ionic/p-32083c2d.js +0 -4
  1812. package/dist/ionic/p-33a8349a.system.entry.js +0 -4
  1813. package/dist/ionic/p-34259245.system.entry.js +0 -4
  1814. package/dist/ionic/p-35b26732.entry.js +0 -4
  1815. package/dist/ionic/p-35e399bd.entry.js +0 -4
  1816. package/dist/ionic/p-3632220b.system.js +0 -4
  1817. package/dist/ionic/p-38089641.entry.js +0 -4
  1818. package/dist/ionic/p-38c5fe2b.system.entry.js +0 -4
  1819. package/dist/ionic/p-3a58e3a4.system.entry.js +0 -4
  1820. package/dist/ionic/p-3d726a67.system.js +0 -4
  1821. package/dist/ionic/p-3f3da911.system.entry.js +0 -4
  1822. package/dist/ionic/p-41477ad9.system.js +0 -4
  1823. package/dist/ionic/p-4215652f.system.entry.js +0 -4
  1824. package/dist/ionic/p-446230d7.js +0 -4
  1825. package/dist/ionic/p-44bc8b45.system.js +0 -4
  1826. package/dist/ionic/p-479cdbf8.system.js +0 -4
  1827. package/dist/ionic/p-4f97c112.entry.js +0 -4
  1828. package/dist/ionic/p-54200074.entry.js +0 -4
  1829. package/dist/ionic/p-54f6cd27.system.entry.js +0 -4
  1830. package/dist/ionic/p-56dc022e.system.js +0 -4
  1831. package/dist/ionic/p-572cce26.system.entry.js +0 -4
  1832. package/dist/ionic/p-5b976d70.entry.js +0 -4
  1833. package/dist/ionic/p-5bf16a18.js +0 -4
  1834. package/dist/ionic/p-613d4042.system.js +0 -4
  1835. package/dist/ionic/p-629aa3fd.system.js +0 -5
  1836. package/dist/ionic/p-62e7d4fa.js +0 -4
  1837. package/dist/ionic/p-64475ab5.system.js +0 -4
  1838. package/dist/ionic/p-673846f6.entry.js +0 -4
  1839. package/dist/ionic/p-6ce0a709.system.entry.js +0 -4
  1840. package/dist/ionic/p-755b2917.system.js +0 -4
  1841. package/dist/ionic/p-772f6c84.system.js +0 -4
  1842. package/dist/ionic/p-815c2fba.system.js +0 -4
  1843. package/dist/ionic/p-818b2e75.entry.js +0 -4
  1844. package/dist/ionic/p-81c818e7.js +0 -4
  1845. package/dist/ionic/p-81ef7437.system.entry.js +0 -4
  1846. package/dist/ionic/p-87411e39.system.js +0 -4
  1847. package/dist/ionic/p-8b1be026.js +0 -4
  1848. package/dist/ionic/p-8c15eda7.system.js +0 -4
  1849. package/dist/ionic/p-8cf94fc1.js +0 -4
  1850. package/dist/ionic/p-8d6728a1.system.entry.js +0 -4
  1851. package/dist/ionic/p-8e24ebbc.js +0 -4
  1852. package/dist/ionic/p-8f01a9a2.system.js +0 -4
  1853. package/dist/ionic/p-939e0fa1.system.js +0 -4
  1854. package/dist/ionic/p-9ab6f3e6.system.js +0 -4
  1855. package/dist/ionic/p-9dc85536.system.entry.js +0 -4
  1856. package/dist/ionic/p-9e852ff1.system.js +0 -4
  1857. package/dist/ionic/p-9f2e0db9.js +0 -4
  1858. package/dist/ionic/p-a164e3ab.system.entry.js +0 -4
  1859. package/dist/ionic/p-a200a7fc.entry.js +0 -4
  1860. package/dist/ionic/p-a34fc12e.system.entry.js +0 -4
  1861. package/dist/ionic/p-a9c32660.entry.js +0 -4
  1862. package/dist/ionic/p-ab4cff27.system.js +0 -4
  1863. package/dist/ionic/p-ad48dd13.system.js +0 -4
  1864. package/dist/ionic/p-afb6658f.entry.js +0 -4
  1865. package/dist/ionic/p-b132c2c0.system.js +0 -4
  1866. package/dist/ionic/p-b24aa895.js +0 -4
  1867. package/dist/ionic/p-b3c68723.system.js +0 -4
  1868. package/dist/ionic/p-b4b4bb29.system.js +0 -4
  1869. package/dist/ionic/p-b61a2fa0.system.entry.js +0 -4
  1870. package/dist/ionic/p-b753ec0d.system.entry.js +0 -4
  1871. package/dist/ionic/p-b8c3f071.system.js +0 -4
  1872. package/dist/ionic/p-b912e055.system.js +0 -4
  1873. package/dist/ionic/p-bb055450.system.entry.js +0 -4
  1874. package/dist/ionic/p-bba2ce59.system.js +0 -4
  1875. package/dist/ionic/p-c105bd36.entry.js +0 -4
  1876. package/dist/ionic/p-c44fe9fd.js +0 -4
  1877. package/dist/ionic/p-c49672d8.system.js +0 -4
  1878. package/dist/ionic/p-c87827ca.system.js +0 -4
  1879. package/dist/ionic/p-c8c9d699.system.entry.js +0 -4
  1880. package/dist/ionic/p-c92f0a6d.system.entry.js +0 -4
  1881. package/dist/ionic/p-c956e82c.system.entry.js +0 -4
  1882. package/dist/ionic/p-ca5cf574.js +0 -4
  1883. package/dist/ionic/p-cc196b34.js +0 -4
  1884. package/dist/ionic/p-ccdcb022.system.js +0 -4
  1885. package/dist/ionic/p-cd2d17c3.system.entry.js +0 -4
  1886. package/dist/ionic/p-cf0c93e3.system.entry.js +0 -4
  1887. package/dist/ionic/p-d1de1188.js +0 -4
  1888. package/dist/ionic/p-d35217be.entry.js +0 -4
  1889. package/dist/ionic/p-d6e53e66.entry.js +0 -4
  1890. package/dist/ionic/p-e1d5752d.system.entry.js +0 -4
  1891. package/dist/ionic/p-e25cb483.entry.js +0 -4
  1892. package/dist/ionic/p-e65ebe96.entry.js +0 -4
  1893. package/dist/ionic/p-e74faf2a.entry.js +0 -4
  1894. package/dist/ionic/p-eac263dd.entry.js +0 -4
  1895. package/dist/ionic/p-eb7d0922.js +0 -4
  1896. package/dist/ionic/p-f4309ac7.entry.js +0 -4
  1897. package/dist/ionic/p-f5bf698b.entry.js +0 -4
  1898. package/dist/ionic/p-f7566bad.entry.js +0 -4
  1899. package/dist/ionic/p-f9fa802c.system.entry.js +0 -4
  1900. package/dist/ionic/p-fa8d4788.system.js +0 -4
  1901. package/dist/ionic/p-ff5a10f9.system.js +0 -4
  1902. /package/dist/esm-es5/{index-595d62c9.js → index-9b0d46f4.js} +0 -0
  1903. /package/dist/esm-es5/{index-7a14ecec.js → index-a5d50daf.js} +0 -0
  1904. /package/dist/esm-es5/{lock-controller-e8c6c051.js → lock-controller-316928be.js} +0 -0
  1905. /package/dist/esm-es5/{theme-17531cdf.js → theme-01f3f29c.js} +0 -0
  1906. /package/dist/ionic/{p-1b8e1d03.js → p-06fee233.js} +0 -0
  1907. /package/dist/ionic/{p-63eb0acd.js → p-23a9d086.js} +0 -0
  1908. /package/dist/ionic/{p-7c2bac85.js → p-2408c236.js} +0 -0
  1909. /package/dist/ionic/{p-7b021525.js → p-41d5544e.js} +0 -0
  1910. /package/dist/ionic/{p-1d072d3d.js → p-47794def.js} +0 -0
  1911. /package/dist/ionic/{p-185e427e.js → p-4b3623da.js} +0 -0
  1912. /package/dist/ionic/{p-0e94957a.system.js → p-792919fd.system.js} +0 -0
  1913. /package/dist/ionic/{p-b347cfd1.js → p-7b30edcc.js} +0 -0
  1914. /package/dist/ionic/{p-e0b06b65.js → p-bb3615f7.js} +0 -0
  1915. /package/dist/ionic/{p-53b2a46f.js → p-ccd02320.js} +0 -0
  1916. /package/dist/ionic/{p-76fce40e.js → p-d47265c8.js} +0 -0
  1917. /package/dist/ionic/{p-c18d6eac.js → p-f0c2a614.js} +0 -0
  1918. /package/dist/ionic/{p-6dbfe5d4.js → p-fb813dab.js} +0 -0
@@ -5,18 +5,18 @@
5
5
 
6
6
  Object.defineProperty(exports, '__esModule', { value: true });
7
7
 
8
- const index = require('./index-305a23dc.js');
9
- const frameworkDelegate = require('./framework-delegate-c0873a6f.js');
10
- const helpers = require('./helpers-ea4ccbcb.js');
11
- const lockController = require('./lock-controller-4ae2eb59.js');
12
- const index$1 = require('./index-cc7dfb7c.js');
13
- const overlays = require('./overlays-1a734051.js');
14
- const ionicGlobal = require('./ionic-global-fb752503.js');
15
- const theme = require('./theme-fbc56b3b.js');
16
- const index$2 = require('./index-eccba000.js');
17
- const animation = require('./animation-c8bdd3c7.js');
18
- require('./index-306a7476.js');
19
- require('./hardware-back-button-b67c8e75.js');
8
+ const index = require('./index-bbb4336c.js');
9
+ const frameworkDelegate = require('./framework-delegate-1c29b14a.js');
10
+ const helpers = require('./helpers-76bb7efb.js');
11
+ const lockController = require('./lock-controller-6585a42a.js');
12
+ const index$1 = require('./index-5915f9b3.js');
13
+ const overlays = require('./overlays-27a6fb16.js');
14
+ const ionicGlobal = require('./ionic-global-f4a2093b.js');
15
+ const theme = require('./theme-d1c573d2.js');
16
+ const index$2 = require('./index-f8f13389.js');
17
+ const animation = require('./animation-9b401d39.js');
18
+ require('./index-c8d52405.js');
19
+ require('./hardware-back-button-76833cac.js');
20
20
 
21
21
  /**
22
22
  * Returns the dimensions of the popover
@@ -24,11 +24,11 @@ require('./hardware-back-button-b67c8e75.js');
24
24
  * returns (0, 0).
25
25
  */
26
26
  const getArrowDimensions = (arrowEl) => {
27
- if (!arrowEl) {
28
- return { arrowWidth: 0, arrowHeight: 0 };
29
- }
30
- const { width, height } = arrowEl.getBoundingClientRect();
31
- return { arrowWidth: width, arrowHeight: height };
27
+ if (!arrowEl) {
28
+ return { arrowWidth: 0, arrowHeight: 0 };
29
+ }
30
+ const { width, height } = arrowEl.getBoundingClientRect();
31
+ return { arrowWidth: width, arrowHeight: height };
32
32
  };
33
33
  /**
34
34
  * Returns the recommended dimensions of the popover
@@ -36,85 +36,85 @@ const getArrowDimensions = (arrowEl) => {
36
36
  * should match the trigger width.
37
37
  */
38
38
  const getPopoverDimensions = (size, contentEl, triggerEl) => {
39
- const contentDimentions = contentEl.getBoundingClientRect();
40
- const contentHeight = contentDimentions.height;
41
- let contentWidth = contentDimentions.width;
42
- if (size === 'cover' && triggerEl) {
43
- const triggerDimensions = triggerEl.getBoundingClientRect();
44
- contentWidth = triggerDimensions.width;
45
- }
46
- return {
47
- contentWidth,
48
- contentHeight,
49
- };
39
+ const contentDimentions = contentEl.getBoundingClientRect();
40
+ const contentHeight = contentDimentions.height;
41
+ let contentWidth = contentDimentions.width;
42
+ if (size === 'cover' && triggerEl) {
43
+ const triggerDimensions = triggerEl.getBoundingClientRect();
44
+ contentWidth = triggerDimensions.width;
45
+ }
46
+ return {
47
+ contentWidth,
48
+ contentHeight,
49
+ };
50
50
  };
51
51
  const configureDismissInteraction = (triggerEl, triggerAction, popoverEl, parentPopoverEl) => {
52
- let dismissCallbacks = [];
53
- const root = helpers.getElementRoot(parentPopoverEl);
54
- const parentContentEl = root.querySelector('.popover-content');
55
- switch (triggerAction) {
56
- case 'hover':
57
- dismissCallbacks = [
58
- {
59
- /**
60
- * Do not use mouseover here
61
- * as this will causes the event to
62
- * be dispatched on each underlying
63
- * element rather than on the popover
64
- * content as a whole.
65
- */
66
- eventName: 'mouseenter',
67
- callback: (ev) => {
68
- /**
69
- * Do not dismiss the popover is we
70
- * are hovering over its trigger.
71
- * This would be easier if we used mouseover
72
- * but this would cause the event to be dispatched
73
- * more often than we would like, potentially
74
- * causing performance issues.
75
- */
76
- const element = document.elementFromPoint(ev.clientX, ev.clientY);
77
- if (element === triggerEl) {
78
- return;
79
- }
80
- popoverEl.dismiss(undefined, undefined, false);
81
- },
82
- },
83
- ];
84
- break;
85
- case 'context-menu':
86
- case 'click':
87
- default:
88
- dismissCallbacks = [
89
- {
90
- eventName: 'click',
91
- callback: (ev) => {
92
- /**
93
- * Do not dismiss the popover is we
94
- * are hovering over its trigger.
95
- */
96
- const target = ev.target;
97
- const closestTrigger = target.closest('[data-ion-popover-trigger]');
98
- if (closestTrigger === triggerEl) {
99
- /**
100
- * stopPropagation here so if the
101
- * popover has dismissOnSelect="true"
102
- * the popover does not dismiss since
103
- * we just clicked a trigger element.
104
- */
105
- ev.stopPropagation();
106
- return;
107
- }
108
- popoverEl.dismiss(undefined, undefined, false);
109
- },
110
- },
111
- ];
112
- break;
113
- }
114
- dismissCallbacks.forEach(({ eventName, callback }) => parentContentEl.addEventListener(eventName, callback));
115
- return () => {
116
- dismissCallbacks.forEach(({ eventName, callback }) => parentContentEl.removeEventListener(eventName, callback));
117
- };
52
+ let dismissCallbacks = [];
53
+ const root = helpers.getElementRoot(parentPopoverEl);
54
+ const parentContentEl = root.querySelector('.popover-content');
55
+ switch (triggerAction) {
56
+ case 'hover':
57
+ dismissCallbacks = [
58
+ {
59
+ /**
60
+ * Do not use mouseover here
61
+ * as this will causes the event to
62
+ * be dispatched on each underlying
63
+ * element rather than on the popover
64
+ * content as a whole.
65
+ */
66
+ eventName: 'mouseenter',
67
+ callback: (ev) => {
68
+ /**
69
+ * Do not dismiss the popover is we
70
+ * are hovering over its trigger.
71
+ * This would be easier if we used mouseover
72
+ * but this would cause the event to be dispatched
73
+ * more often than we would like, potentially
74
+ * causing performance issues.
75
+ */
76
+ const element = document.elementFromPoint(ev.clientX, ev.clientY);
77
+ if (element === triggerEl) {
78
+ return;
79
+ }
80
+ popoverEl.dismiss(undefined, undefined, false);
81
+ },
82
+ },
83
+ ];
84
+ break;
85
+ case 'context-menu':
86
+ case 'click':
87
+ default:
88
+ dismissCallbacks = [
89
+ {
90
+ eventName: 'click',
91
+ callback: (ev) => {
92
+ /**
93
+ * Do not dismiss the popover is we
94
+ * are hovering over its trigger.
95
+ */
96
+ const target = ev.target;
97
+ const closestTrigger = target.closest('[data-ion-popover-trigger]');
98
+ if (closestTrigger === triggerEl) {
99
+ /**
100
+ * stopPropagation here so if the
101
+ * popover has dismissOnSelect="true"
102
+ * the popover does not dismiss since
103
+ * we just clicked a trigger element.
104
+ */
105
+ ev.stopPropagation();
106
+ return;
107
+ }
108
+ popoverEl.dismiss(undefined, undefined, false);
109
+ },
110
+ },
111
+ ];
112
+ break;
113
+ }
114
+ dismissCallbacks.forEach(({ eventName, callback }) => parentContentEl.addEventListener(eventName, callback));
115
+ return () => {
116
+ dismissCallbacks.forEach(({ eventName, callback }) => parentContentEl.removeEventListener(eventName, callback));
117
+ };
118
118
  };
119
119
  /**
120
120
  * Configures the triggerEl to respond
@@ -122,128 +122,128 @@ const configureDismissInteraction = (triggerEl, triggerAction, popoverEl, parent
122
122
  * prop that devs have defined.
123
123
  */
124
124
  const configureTriggerInteraction = (triggerEl, triggerAction, popoverEl) => {
125
- let triggerCallbacks = [];
126
- /**
127
- * Based upon the kind of trigger interaction
128
- * the user wants, we setup the correct event
129
- * listeners.
130
- */
131
- switch (triggerAction) {
132
- case 'hover':
133
- let hoverTimeout;
134
- triggerCallbacks = [
135
- {
136
- eventName: 'mouseenter',
137
- callback: async (ev) => {
138
- ev.stopPropagation();
139
- if (hoverTimeout) {
140
- clearTimeout(hoverTimeout);
141
- }
142
- /**
143
- * Hovering over a trigger should not
144
- * immediately open the next popover.
145
- */
146
- hoverTimeout = setTimeout(() => {
147
- helpers.raf(() => {
148
- popoverEl.presentFromTrigger(ev);
149
- hoverTimeout = undefined;
150
- });
151
- }, 100);
152
- },
153
- },
154
- {
155
- eventName: 'mouseleave',
156
- callback: (ev) => {
157
- if (hoverTimeout) {
158
- clearTimeout(hoverTimeout);
159
- }
160
- /**
161
- * If mouse is over another popover
162
- * that is not this popover then we should
163
- * close this popover.
164
- */
165
- const target = ev.relatedTarget;
166
- if (!target) {
167
- return;
168
- }
169
- if (target.closest('ion-popover') !== popoverEl) {
170
- popoverEl.dismiss(undefined, undefined, false);
171
- }
172
- },
173
- },
174
- {
175
- /**
176
- * stopPropagation here prevents the popover
177
- * from dismissing when dismiss-on-select="true".
178
- */
179
- eventName: 'click',
180
- callback: (ev) => ev.stopPropagation(),
181
- },
182
- {
183
- eventName: 'ionPopoverActivateTrigger',
184
- callback: (ev) => popoverEl.presentFromTrigger(ev, true),
185
- },
186
- ];
187
- break;
188
- case 'context-menu':
189
- triggerCallbacks = [
190
- {
191
- eventName: 'contextmenu',
192
- callback: (ev) => {
193
- /**
194
- * Prevents the platform context
195
- * menu from appearing.
196
- */
197
- ev.preventDefault();
198
- popoverEl.presentFromTrigger(ev);
199
- },
200
- },
201
- {
202
- eventName: 'click',
203
- callback: (ev) => ev.stopPropagation(),
204
- },
205
- {
206
- eventName: 'ionPopoverActivateTrigger',
207
- callback: (ev) => popoverEl.presentFromTrigger(ev, true),
208
- },
209
- ];
210
- break;
211
- case 'click':
212
- default:
213
- triggerCallbacks = [
214
- {
215
- /**
216
- * Do not do a stopPropagation() here
217
- * because if you had two click triggers
218
- * then clicking the first trigger and then
219
- * clicking the second trigger would not cause
220
- * the first popover to dismiss.
221
- */
222
- eventName: 'click',
223
- callback: (ev) => popoverEl.presentFromTrigger(ev),
224
- },
225
- {
226
- eventName: 'ionPopoverActivateTrigger',
227
- callback: (ev) => popoverEl.presentFromTrigger(ev, true),
228
- },
229
- ];
230
- break;
231
- }
232
- triggerCallbacks.forEach(({ eventName, callback }) => triggerEl.addEventListener(eventName, callback));
233
- triggerEl.setAttribute('data-ion-popover-trigger', 'true');
234
- return () => {
235
- triggerCallbacks.forEach(({ eventName, callback }) => triggerEl.removeEventListener(eventName, callback));
236
- triggerEl.removeAttribute('data-ion-popover-trigger');
237
- };
125
+ let triggerCallbacks = [];
126
+ /**
127
+ * Based upon the kind of trigger interaction
128
+ * the user wants, we setup the correct event
129
+ * listeners.
130
+ */
131
+ switch (triggerAction) {
132
+ case 'hover':
133
+ let hoverTimeout;
134
+ triggerCallbacks = [
135
+ {
136
+ eventName: 'mouseenter',
137
+ callback: async (ev) => {
138
+ ev.stopPropagation();
139
+ if (hoverTimeout) {
140
+ clearTimeout(hoverTimeout);
141
+ }
142
+ /**
143
+ * Hovering over a trigger should not
144
+ * immediately open the next popover.
145
+ */
146
+ hoverTimeout = setTimeout(() => {
147
+ helpers.raf(() => {
148
+ popoverEl.presentFromTrigger(ev);
149
+ hoverTimeout = undefined;
150
+ });
151
+ }, 100);
152
+ },
153
+ },
154
+ {
155
+ eventName: 'mouseleave',
156
+ callback: (ev) => {
157
+ if (hoverTimeout) {
158
+ clearTimeout(hoverTimeout);
159
+ }
160
+ /**
161
+ * If mouse is over another popover
162
+ * that is not this popover then we should
163
+ * close this popover.
164
+ */
165
+ const target = ev.relatedTarget;
166
+ if (!target) {
167
+ return;
168
+ }
169
+ if (target.closest('ion-popover') !== popoverEl) {
170
+ popoverEl.dismiss(undefined, undefined, false);
171
+ }
172
+ },
173
+ },
174
+ {
175
+ /**
176
+ * stopPropagation here prevents the popover
177
+ * from dismissing when dismiss-on-select="true".
178
+ */
179
+ eventName: 'click',
180
+ callback: (ev) => ev.stopPropagation(),
181
+ },
182
+ {
183
+ eventName: 'ionPopoverActivateTrigger',
184
+ callback: (ev) => popoverEl.presentFromTrigger(ev, true),
185
+ },
186
+ ];
187
+ break;
188
+ case 'context-menu':
189
+ triggerCallbacks = [
190
+ {
191
+ eventName: 'contextmenu',
192
+ callback: (ev) => {
193
+ /**
194
+ * Prevents the platform context
195
+ * menu from appearing.
196
+ */
197
+ ev.preventDefault();
198
+ popoverEl.presentFromTrigger(ev);
199
+ },
200
+ },
201
+ {
202
+ eventName: 'click',
203
+ callback: (ev) => ev.stopPropagation(),
204
+ },
205
+ {
206
+ eventName: 'ionPopoverActivateTrigger',
207
+ callback: (ev) => popoverEl.presentFromTrigger(ev, true),
208
+ },
209
+ ];
210
+ break;
211
+ case 'click':
212
+ default:
213
+ triggerCallbacks = [
214
+ {
215
+ /**
216
+ * Do not do a stopPropagation() here
217
+ * because if you had two click triggers
218
+ * then clicking the first trigger and then
219
+ * clicking the second trigger would not cause
220
+ * the first popover to dismiss.
221
+ */
222
+ eventName: 'click',
223
+ callback: (ev) => popoverEl.presentFromTrigger(ev),
224
+ },
225
+ {
226
+ eventName: 'ionPopoverActivateTrigger',
227
+ callback: (ev) => popoverEl.presentFromTrigger(ev, true),
228
+ },
229
+ ];
230
+ break;
231
+ }
232
+ triggerCallbacks.forEach(({ eventName, callback }) => triggerEl.addEventListener(eventName, callback));
233
+ triggerEl.setAttribute('data-ion-popover-trigger', 'true');
234
+ return () => {
235
+ triggerCallbacks.forEach(({ eventName, callback }) => triggerEl.removeEventListener(eventName, callback));
236
+ triggerEl.removeAttribute('data-ion-popover-trigger');
237
+ };
238
238
  };
239
239
  /**
240
240
  * Returns the index of an ion-item in an array of ion-items.
241
241
  */
242
242
  const getIndexOfItem = (items, item) => {
243
- if (!item || item.tagName !== 'ION-ITEM') {
244
- return -1;
245
- }
246
- return items.findIndex((el) => el === item);
243
+ if (!item || item.tagName !== 'ION-ITEM') {
244
+ return -1;
245
+ }
246
+ return items.findIndex((el) => el === item);
247
247
  };
248
248
  /**
249
249
  * Given an array of elements and a currently focused ion-item
@@ -251,8 +251,8 @@ const getIndexOfItem = (items, item) => {
251
251
  * undefined.
252
252
  */
253
253
  const getNextItem = (items, currentItem) => {
254
- const currentItemIndex = getIndexOfItem(items, currentItem);
255
- return items[currentItemIndex + 1];
254
+ const currentItemIndex = getIndexOfItem(items, currentItem);
255
+ return items[currentItemIndex + 1];
256
256
  };
257
257
  /**
258
258
  * Given an array of elements and a currently focused ion-item
@@ -260,16 +260,16 @@ const getNextItem = (items, currentItem) => {
260
260
  * undefined.
261
261
  */
262
262
  const getPrevItem = (items, currentItem) => {
263
- const currentItemIndex = getIndexOfItem(items, currentItem);
264
- return items[currentItemIndex - 1];
263
+ const currentItemIndex = getIndexOfItem(items, currentItem);
264
+ return items[currentItemIndex - 1];
265
265
  };
266
266
  /** Focus the internal button of the ion-item */
267
267
  const focusItem = (item) => {
268
- const root = helpers.getElementRoot(item);
269
- const button = root.querySelector('button');
270
- if (button) {
271
- helpers.raf(() => button.focus());
272
- }
268
+ const root = helpers.getElementRoot(item);
269
+ const button = root.querySelector('button');
270
+ if (button) {
271
+ helpers.raf(() => button.focus());
272
+ }
273
273
  };
274
274
  /**
275
275
  * Returns `true` if `el` has been designated
@@ -277,105 +277,105 @@ const focusItem = (item) => {
277
277
  */
278
278
  const isTriggerElement = (el) => el.hasAttribute('data-ion-popover-trigger');
279
279
  const configureKeyboardInteraction = (popoverEl) => {
280
- const callback = async (ev) => {
281
- var _a;
282
- const activeElement = document.activeElement;
283
- let items = [];
284
- const targetTagName = (_a = ev.target) === null || _a === void 0 ? void 0 : _a.tagName;
285
- /**
286
- * Only handle custom keyboard interactions for the host popover element
287
- * and children ion-item elements.
288
- */
289
- if (targetTagName !== 'ION-POPOVER' && targetTagName !== 'ION-ITEM') {
290
- return;
291
- }
292
- /**
293
- * Complex selectors with :not() are :not supported
294
- * in older versions of Chromium so we need to do a
295
- * try/catch here so errors are not thrown.
296
- */
297
- try {
298
- /**
299
- * Select all ion-items that are not children of child popovers.
300
- * i.e. only select ion-item elements that are part of this popover
301
- */
302
- items = Array.from(popoverEl.querySelectorAll('ion-item:not(ion-popover ion-popover *):not([disabled])'));
303
- /* eslint-disable-next-line */
304
- }
305
- catch (_b) { }
306
- switch (ev.key) {
307
- /**
308
- * If we are in a child popover
309
- * then pressing the left arrow key
310
- * should close this popover and move
311
- * focus to the popover that presented
312
- * this one.
313
- */
314
- case 'ArrowLeft':
315
- const parentPopover = await popoverEl.getParentPopover();
316
- if (parentPopover) {
317
- popoverEl.dismiss(undefined, undefined, false);
318
- }
319
- break;
320
- /**
321
- * ArrowDown should move focus to the next focusable ion-item.
322
- */
323
- case 'ArrowDown':
324
- // Disable movement/scroll with keyboard
325
- ev.preventDefault();
326
- const nextItem = getNextItem(items, activeElement);
327
- if (nextItem !== undefined) {
328
- focusItem(nextItem);
280
+ const callback = async (ev) => {
281
+ var _a;
282
+ const activeElement = document.activeElement;
283
+ let items = [];
284
+ const targetTagName = (_a = ev.target) === null || _a === void 0 ? void 0 : _a.tagName;
285
+ /**
286
+ * Only handle custom keyboard interactions for the host popover element
287
+ * and children ion-item elements.
288
+ */
289
+ if (targetTagName !== 'ION-POPOVER' && targetTagName !== 'ION-ITEM') {
290
+ return;
329
291
  }
330
- break;
331
- /**
332
- * ArrowUp should move focus to the previous focusable ion-item.
333
- */
334
- case 'ArrowUp':
335
- // Disable movement/scroll with keyboard
336
- ev.preventDefault();
337
- const prevItem = getPrevItem(items, activeElement);
338
- if (prevItem !== undefined) {
339
- focusItem(prevItem);
340
- }
341
- break;
342
- /**
343
- * Home should move focus to the first focusable ion-item.
344
- */
345
- case 'Home':
346
- ev.preventDefault();
347
- const firstItem = items[0];
348
- if (firstItem !== undefined) {
349
- focusItem(firstItem);
350
- }
351
- break;
352
- /**
353
- * End should move focus to the last focusable ion-item.
354
- */
355
- case 'End':
356
- ev.preventDefault();
357
- const lastItem = items[items.length - 1];
358
- if (lastItem !== undefined) {
359
- focusItem(lastItem);
292
+ /**
293
+ * Complex selectors with :not() are :not supported
294
+ * in older versions of Chromium so we need to do a
295
+ * try/catch here so errors are not thrown.
296
+ */
297
+ try {
298
+ /**
299
+ * Select all ion-items that are not children of child popovers.
300
+ * i.e. only select ion-item elements that are part of this popover
301
+ */
302
+ items = Array.from(popoverEl.querySelectorAll('ion-item:not(ion-popover ion-popover *):not([disabled])'));
303
+ /* eslint-disable-next-line */
360
304
  }
361
- break;
362
- /**
363
- * ArrowRight, Spacebar, or Enter should activate
364
- * the currently focused trigger item to open a
365
- * popover if the element is a trigger item.
366
- */
367
- case 'ArrowRight':
368
- case ' ':
369
- case 'Enter':
370
- if (activeElement && isTriggerElement(activeElement)) {
371
- const rightEvent = new CustomEvent('ionPopoverActivateTrigger');
372
- activeElement.dispatchEvent(rightEvent);
305
+ catch (_b) { }
306
+ switch (ev.key) {
307
+ /**
308
+ * If we are in a child popover
309
+ * then pressing the left arrow key
310
+ * should close this popover and move
311
+ * focus to the popover that presented
312
+ * this one.
313
+ */
314
+ case 'ArrowLeft':
315
+ const parentPopover = await popoverEl.getParentPopover();
316
+ if (parentPopover) {
317
+ popoverEl.dismiss(undefined, undefined, false);
318
+ }
319
+ break;
320
+ /**
321
+ * ArrowDown should move focus to the next focusable ion-item.
322
+ */
323
+ case 'ArrowDown':
324
+ // Disable movement/scroll with keyboard
325
+ ev.preventDefault();
326
+ const nextItem = getNextItem(items, activeElement);
327
+ if (nextItem !== undefined) {
328
+ focusItem(nextItem);
329
+ }
330
+ break;
331
+ /**
332
+ * ArrowUp should move focus to the previous focusable ion-item.
333
+ */
334
+ case 'ArrowUp':
335
+ // Disable movement/scroll with keyboard
336
+ ev.preventDefault();
337
+ const prevItem = getPrevItem(items, activeElement);
338
+ if (prevItem !== undefined) {
339
+ focusItem(prevItem);
340
+ }
341
+ break;
342
+ /**
343
+ * Home should move focus to the first focusable ion-item.
344
+ */
345
+ case 'Home':
346
+ ev.preventDefault();
347
+ const firstItem = items[0];
348
+ if (firstItem !== undefined) {
349
+ focusItem(firstItem);
350
+ }
351
+ break;
352
+ /**
353
+ * End should move focus to the last focusable ion-item.
354
+ */
355
+ case 'End':
356
+ ev.preventDefault();
357
+ const lastItem = items[items.length - 1];
358
+ if (lastItem !== undefined) {
359
+ focusItem(lastItem);
360
+ }
361
+ break;
362
+ /**
363
+ * ArrowRight, Spacebar, or Enter should activate
364
+ * the currently focused trigger item to open a
365
+ * popover if the element is a trigger item.
366
+ */
367
+ case 'ArrowRight':
368
+ case ' ':
369
+ case 'Enter':
370
+ if (activeElement && isTriggerElement(activeElement)) {
371
+ const rightEvent = new CustomEvent('ionPopoverActivateTrigger');
372
+ activeElement.dispatchEvent(rightEvent);
373
+ }
374
+ break;
373
375
  }
374
- break;
375
- }
376
- };
377
- popoverEl.addEventListener('keydown', callback);
378
- return () => popoverEl.removeEventListener('keydown', callback);
376
+ };
377
+ popoverEl.addEventListener('keydown', callback);
378
+ return () => popoverEl.removeEventListener('keydown', callback);
379
379
  };
380
380
  /**
381
381
  * Positions a popover by taking into account
@@ -383,82 +383,82 @@ const configureKeyboardInteraction = (popoverEl) => {
383
383
  * and viewport dimensions.
384
384
  */
385
385
  const getPopoverPosition = (isRTL, contentWidth, contentHeight, arrowWidth, arrowHeight, reference, side, align, defaultPosition, triggerEl, event) => {
386
- var _a;
387
- let referenceCoordinates = {
388
- top: 0,
389
- left: 0,
390
- width: 0,
391
- height: 0,
392
- };
393
- /**
394
- * Calculate position relative to the
395
- * x-y coordinates in the event that
396
- * was passed in
397
- */
398
- switch (reference) {
399
- case 'event':
400
- if (!event) {
401
- return defaultPosition;
402
- }
403
- const mouseEv = event;
404
- referenceCoordinates = {
405
- top: mouseEv.clientY,
406
- left: mouseEv.clientX,
407
- width: 1,
408
- height: 1,
409
- };
410
- break;
386
+ var _a;
387
+ let referenceCoordinates = {
388
+ top: 0,
389
+ left: 0,
390
+ width: 0,
391
+ height: 0,
392
+ };
411
393
  /**
412
- * Calculate position relative to the bounding
413
- * box on either the trigger element
414
- * specified via the `trigger` prop or
415
- * the target specified on the event
416
- * that was passed in.
394
+ * Calculate position relative to the
395
+ * x-y coordinates in the event that
396
+ * was passed in
417
397
  */
418
- case 'trigger':
419
- default:
420
- const customEv = event;
421
- /**
422
- * ionShadowTarget is used when we need to align the
423
- * popover with an element inside of the shadow root
424
- * of an Ionic component. Ex: Presenting a popover
425
- * by clicking on the collapsed indicator inside
426
- * of `ion-breadcrumb` and centering it relative
427
- * to the indicator rather than `ion-breadcrumb`
428
- * as a whole.
429
- */
430
- const actualTriggerEl = (triggerEl ||
431
- ((_a = customEv === null || customEv === void 0 ? void 0 : customEv.detail) === null || _a === void 0 ? void 0 : _a.ionShadowTarget) ||
432
- (customEv === null || customEv === void 0 ? void 0 : customEv.target));
433
- if (!actualTriggerEl) {
434
- return defaultPosition;
435
- }
436
- const triggerBoundingBox = actualTriggerEl.getBoundingClientRect();
437
- referenceCoordinates = {
438
- top: triggerBoundingBox.top,
439
- left: triggerBoundingBox.left,
440
- width: triggerBoundingBox.width,
441
- height: triggerBoundingBox.height,
442
- };
443
- break;
444
- }
445
- /**
446
- * Get top/left offset that would allow
447
- * popover to be positioned on the
448
- * preferred side of the reference.
449
- */
450
- const coordinates = calculatePopoverSide(side, referenceCoordinates, contentWidth, contentHeight, arrowWidth, arrowHeight, isRTL);
451
- /**
452
- * Get the top/left adjustments that
453
- * would allow the popover content
454
- * to have the correct alignment.
455
- */
456
- const alignedCoordinates = calculatePopoverAlign(align, side, referenceCoordinates, contentWidth, contentHeight);
457
- const top = coordinates.top + alignedCoordinates.top;
458
- const left = coordinates.left + alignedCoordinates.left;
459
- const { arrowTop, arrowLeft } = calculateArrowPosition(side, arrowWidth, arrowHeight, top, left, contentWidth, contentHeight, isRTL);
460
- const { originX, originY } = calculatePopoverOrigin(side, align, isRTL);
461
- return { top, left, referenceCoordinates, arrowTop, arrowLeft, originX, originY };
398
+ switch (reference) {
399
+ case 'event':
400
+ if (!event) {
401
+ return defaultPosition;
402
+ }
403
+ const mouseEv = event;
404
+ referenceCoordinates = {
405
+ top: mouseEv.clientY,
406
+ left: mouseEv.clientX,
407
+ width: 1,
408
+ height: 1,
409
+ };
410
+ break;
411
+ /**
412
+ * Calculate position relative to the bounding
413
+ * box on either the trigger element
414
+ * specified via the `trigger` prop or
415
+ * the target specified on the event
416
+ * that was passed in.
417
+ */
418
+ case 'trigger':
419
+ default:
420
+ const customEv = event;
421
+ /**
422
+ * ionShadowTarget is used when we need to align the
423
+ * popover with an element inside of the shadow root
424
+ * of an Ionic component. Ex: Presenting a popover
425
+ * by clicking on the collapsed indicator inside
426
+ * of `ion-breadcrumb` and centering it relative
427
+ * to the indicator rather than `ion-breadcrumb`
428
+ * as a whole.
429
+ */
430
+ const actualTriggerEl = (triggerEl ||
431
+ ((_a = customEv === null || customEv === void 0 ? void 0 : customEv.detail) === null || _a === void 0 ? void 0 : _a.ionShadowTarget) ||
432
+ (customEv === null || customEv === void 0 ? void 0 : customEv.target));
433
+ if (!actualTriggerEl) {
434
+ return defaultPosition;
435
+ }
436
+ const triggerBoundingBox = actualTriggerEl.getBoundingClientRect();
437
+ referenceCoordinates = {
438
+ top: triggerBoundingBox.top,
439
+ left: triggerBoundingBox.left,
440
+ width: triggerBoundingBox.width,
441
+ height: triggerBoundingBox.height,
442
+ };
443
+ break;
444
+ }
445
+ /**
446
+ * Get top/left offset that would allow
447
+ * popover to be positioned on the
448
+ * preferred side of the reference.
449
+ */
450
+ const coordinates = calculatePopoverSide(side, referenceCoordinates, contentWidth, contentHeight, arrowWidth, arrowHeight, isRTL);
451
+ /**
452
+ * Get the top/left adjustments that
453
+ * would allow the popover content
454
+ * to have the correct alignment.
455
+ */
456
+ const alignedCoordinates = calculatePopoverAlign(align, side, referenceCoordinates, contentWidth, contentHeight);
457
+ const top = coordinates.top + alignedCoordinates.top;
458
+ const left = coordinates.left + alignedCoordinates.left;
459
+ const { arrowTop, arrowLeft } = calculateArrowPosition(side, arrowWidth, arrowHeight, top, left, contentWidth, contentHeight, isRTL);
460
+ const { originX, originY } = calculatePopoverOrigin(side, align, isRTL);
461
+ return { top, left, referenceCoordinates, arrowTop, arrowLeft, originX, originY };
462
462
  };
463
463
  /**
464
464
  * Determines the transform-origin
@@ -468,77 +468,77 @@ const getPopoverPosition = (isRTL, contentWidth, contentHeight, arrowWidth, arro
468
468
  * with the MD animation.
469
469
  */
470
470
  const calculatePopoverOrigin = (side, align, isRTL) => {
471
- switch (side) {
472
- case 'top':
473
- return { originX: getOriginXAlignment(align), originY: 'bottom' };
474
- case 'bottom':
475
- return { originX: getOriginXAlignment(align), originY: 'top' };
476
- case 'left':
477
- return { originX: 'right', originY: getOriginYAlignment(align) };
478
- case 'right':
479
- return { originX: 'left', originY: getOriginYAlignment(align) };
480
- case 'start':
481
- return { originX: isRTL ? 'left' : 'right', originY: getOriginYAlignment(align) };
482
- case 'end':
483
- return { originX: isRTL ? 'right' : 'left', originY: getOriginYAlignment(align) };
484
- }
471
+ switch (side) {
472
+ case 'top':
473
+ return { originX: getOriginXAlignment(align), originY: 'bottom' };
474
+ case 'bottom':
475
+ return { originX: getOriginXAlignment(align), originY: 'top' };
476
+ case 'left':
477
+ return { originX: 'right', originY: getOriginYAlignment(align) };
478
+ case 'right':
479
+ return { originX: 'left', originY: getOriginYAlignment(align) };
480
+ case 'start':
481
+ return { originX: isRTL ? 'left' : 'right', originY: getOriginYAlignment(align) };
482
+ case 'end':
483
+ return { originX: isRTL ? 'right' : 'left', originY: getOriginYAlignment(align) };
484
+ }
485
485
  };
486
486
  const getOriginXAlignment = (align) => {
487
- switch (align) {
488
- case 'start':
489
- return 'left';
490
- case 'center':
491
- return 'center';
492
- case 'end':
493
- return 'right';
494
- }
487
+ switch (align) {
488
+ case 'start':
489
+ return 'left';
490
+ case 'center':
491
+ return 'center';
492
+ case 'end':
493
+ return 'right';
494
+ }
495
495
  };
496
496
  const getOriginYAlignment = (align) => {
497
- switch (align) {
498
- case 'start':
499
- return 'top';
500
- case 'center':
501
- return 'center';
502
- case 'end':
503
- return 'bottom';
504
- }
497
+ switch (align) {
498
+ case 'start':
499
+ return 'top';
500
+ case 'center':
501
+ return 'center';
502
+ case 'end':
503
+ return 'bottom';
504
+ }
505
505
  };
506
506
  /**
507
507
  * Calculates where the arrow positioning
508
508
  * should be relative to the popover content.
509
509
  */
510
510
  const calculateArrowPosition = (side, arrowWidth, arrowHeight, top, left, contentWidth, contentHeight, isRTL) => {
511
- /**
512
- * Note: When side is left, right, start, or end, the arrow is
513
- * been rotated using a `transform`, so to move the arrow up or down
514
- * by its dimension, you need to use `arrowWidth`.
515
- */
516
- const leftPosition = {
517
- arrowTop: top + contentHeight / 2 - arrowWidth / 2,
518
- arrowLeft: left + contentWidth - arrowWidth / 2,
519
- };
520
- /**
521
- * Move the arrow to the left by arrowWidth and then
522
- * again by half of its width because we have rotated
523
- * the arrow using a transform.
524
- */
525
- const rightPosition = { arrowTop: top + contentHeight / 2 - arrowWidth / 2, arrowLeft: left - arrowWidth * 1.5 };
526
- switch (side) {
527
- case 'top':
528
- return { arrowTop: top + contentHeight, arrowLeft: left + contentWidth / 2 - arrowWidth / 2 };
529
- case 'bottom':
530
- return { arrowTop: top - arrowHeight, arrowLeft: left + contentWidth / 2 - arrowWidth / 2 };
531
- case 'left':
532
- return leftPosition;
533
- case 'right':
534
- return rightPosition;
535
- case 'start':
536
- return isRTL ? rightPosition : leftPosition;
537
- case 'end':
538
- return isRTL ? leftPosition : rightPosition;
539
- default:
540
- return { arrowTop: 0, arrowLeft: 0 };
541
- }
511
+ /**
512
+ * Note: When side is left, right, start, or end, the arrow is
513
+ * been rotated using a `transform`, so to move the arrow up or down
514
+ * by its dimension, you need to use `arrowWidth`.
515
+ */
516
+ const leftPosition = {
517
+ arrowTop: top + contentHeight / 2 - arrowWidth / 2,
518
+ arrowLeft: left + contentWidth - arrowWidth / 2,
519
+ };
520
+ /**
521
+ * Move the arrow to the left by arrowWidth and then
522
+ * again by half of its width because we have rotated
523
+ * the arrow using a transform.
524
+ */
525
+ const rightPosition = { arrowTop: top + contentHeight / 2 - arrowWidth / 2, arrowLeft: left - arrowWidth * 1.5 };
526
+ switch (side) {
527
+ case 'top':
528
+ return { arrowTop: top + contentHeight, arrowLeft: left + contentWidth / 2 - arrowWidth / 2 };
529
+ case 'bottom':
530
+ return { arrowTop: top - arrowHeight, arrowLeft: left + contentWidth / 2 - arrowWidth / 2 };
531
+ case 'left':
532
+ return leftPosition;
533
+ case 'right':
534
+ return rightPosition;
535
+ case 'start':
536
+ return isRTL ? rightPosition : leftPosition;
537
+ case 'end':
538
+ return isRTL ? leftPosition : rightPosition;
539
+ default:
540
+ return { arrowTop: 0, arrowLeft: 0 };
541
+ }
542
542
  };
543
543
  /**
544
544
  * Calculates the required top/left
@@ -547,34 +547,34 @@ const calculateArrowPosition = (side, arrowWidth, arrowHeight, top, left, conten
547
547
  * `side` prop.
548
548
  */
549
549
  const calculatePopoverSide = (side, triggerBoundingBox, contentWidth, contentHeight, arrowWidth, arrowHeight, isRTL) => {
550
- const sideLeft = {
551
- top: triggerBoundingBox.top,
552
- left: triggerBoundingBox.left - contentWidth - arrowWidth,
553
- };
554
- const sideRight = {
555
- top: triggerBoundingBox.top,
556
- left: triggerBoundingBox.left + triggerBoundingBox.width + arrowWidth,
557
- };
558
- switch (side) {
559
- case 'top':
560
- return {
561
- top: triggerBoundingBox.top - contentHeight - arrowHeight,
562
- left: triggerBoundingBox.left,
563
- };
564
- case 'right':
565
- return sideRight;
566
- case 'bottom':
567
- return {
568
- top: triggerBoundingBox.top + triggerBoundingBox.height + arrowHeight,
569
- left: triggerBoundingBox.left,
570
- };
571
- case 'left':
572
- return sideLeft;
573
- case 'start':
574
- return isRTL ? sideRight : sideLeft;
575
- case 'end':
576
- return isRTL ? sideLeft : sideRight;
577
- }
550
+ const sideLeft = {
551
+ top: triggerBoundingBox.top,
552
+ left: triggerBoundingBox.left - contentWidth - arrowWidth,
553
+ };
554
+ const sideRight = {
555
+ top: triggerBoundingBox.top,
556
+ left: triggerBoundingBox.left + triggerBoundingBox.width + arrowWidth,
557
+ };
558
+ switch (side) {
559
+ case 'top':
560
+ return {
561
+ top: triggerBoundingBox.top - contentHeight - arrowHeight,
562
+ left: triggerBoundingBox.left,
563
+ };
564
+ case 'right':
565
+ return sideRight;
566
+ case 'bottom':
567
+ return {
568
+ top: triggerBoundingBox.top + triggerBoundingBox.height + arrowHeight,
569
+ left: triggerBoundingBox.left,
570
+ };
571
+ case 'left':
572
+ return sideLeft;
573
+ case 'start':
574
+ return isRTL ? sideRight : sideLeft;
575
+ case 'end':
576
+ return isRTL ? sideLeft : sideRight;
577
+ }
578
578
  };
579
579
  /**
580
580
  * Calculates the required top/left
@@ -583,15 +583,15 @@ const calculatePopoverSide = (side, triggerBoundingBox, contentWidth, contentHei
583
583
  * into account the side the popover is on.
584
584
  */
585
585
  const calculatePopoverAlign = (align, side, triggerBoundingBox, contentWidth, contentHeight) => {
586
- switch (align) {
587
- case 'center':
588
- return calculatePopoverCenterAlign(side, triggerBoundingBox, contentWidth, contentHeight);
589
- case 'end':
590
- return calculatePopoverEndAlign(side, triggerBoundingBox, contentWidth, contentHeight);
591
- case 'start':
592
- default:
593
- return { top: 0, left: 0 };
594
- }
586
+ switch (align) {
587
+ case 'center':
588
+ return calculatePopoverCenterAlign(side, triggerBoundingBox, contentWidth, contentHeight);
589
+ case 'end':
590
+ return calculatePopoverEndAlign(side, triggerBoundingBox, contentWidth, contentHeight);
591
+ case 'start':
592
+ default:
593
+ return { top: 0, left: 0 };
594
+ }
595
595
  };
596
596
  /**
597
597
  * Calculate the end alignment for
@@ -603,23 +603,23 @@ const calculatePopoverAlign = (align, side, triggerBoundingBox, contentWidth, co
603
603
  * margins of the content.
604
604
  */
605
605
  const calculatePopoverEndAlign = (side, triggerBoundingBox, contentWidth, contentHeight) => {
606
- switch (side) {
607
- case 'start':
608
- case 'end':
609
- case 'left':
610
- case 'right':
611
- return {
612
- top: -(contentHeight - triggerBoundingBox.height),
613
- left: 0,
614
- };
615
- case 'top':
616
- case 'bottom':
617
- default:
618
- return {
619
- top: 0,
620
- left: -(contentWidth - triggerBoundingBox.width),
621
- };
622
- }
606
+ switch (side) {
607
+ case 'start':
608
+ case 'end':
609
+ case 'left':
610
+ case 'right':
611
+ return {
612
+ top: -(contentHeight - triggerBoundingBox.height),
613
+ left: 0,
614
+ };
615
+ case 'top':
616
+ case 'bottom':
617
+ default:
618
+ return {
619
+ top: 0,
620
+ left: -(contentWidth - triggerBoundingBox.width),
621
+ };
622
+ }
623
623
  };
624
624
  /**
625
625
  * Calculate the center alignment for
@@ -631,23 +631,23 @@ const calculatePopoverEndAlign = (side, triggerBoundingBox, contentWidth, conten
631
631
  * margins of the content.
632
632
  */
633
633
  const calculatePopoverCenterAlign = (side, triggerBoundingBox, contentWidth, contentHeight) => {
634
- switch (side) {
635
- case 'start':
636
- case 'end':
637
- case 'left':
638
- case 'right':
639
- return {
640
- top: -(contentHeight / 2 - triggerBoundingBox.height / 2),
641
- left: 0,
642
- };
643
- case 'top':
644
- case 'bottom':
645
- default:
646
- return {
647
- top: 0,
648
- left: -(contentWidth / 2 - triggerBoundingBox.width / 2),
649
- };
650
- }
634
+ switch (side) {
635
+ case 'start':
636
+ case 'end':
637
+ case 'left':
638
+ case 'right':
639
+ return {
640
+ top: -(contentHeight / 2 - triggerBoundingBox.height / 2),
641
+ left: 0,
642
+ };
643
+ case 'top':
644
+ case 'bottom':
645
+ default:
646
+ return {
647
+ top: 0,
648
+ left: -(contentWidth / 2 - triggerBoundingBox.width / 2),
649
+ };
650
+ }
651
651
  };
652
652
  /**
653
653
  * Adjusts popover positioning coordinates
@@ -655,107 +655,107 @@ const calculatePopoverCenterAlign = (side, triggerBoundingBox, contentWidth, con
655
655
  * or overlapping safe area bounds.
656
656
  */
657
657
  const calculateWindowAdjustment = (side, coordTop, coordLeft, bodyPadding, bodyWidth, bodyHeight, contentWidth, contentHeight, safeAreaMargin, contentOriginX, contentOriginY, triggerCoordinates, coordArrowTop = 0, coordArrowLeft = 0, arrowHeight = 0) => {
658
- let arrowTop = coordArrowTop;
659
- const arrowLeft = coordArrowLeft;
660
- let left = coordLeft;
661
- let top = coordTop;
662
- let bottom;
663
- let originX = contentOriginX;
664
- let originY = contentOriginY;
665
- let checkSafeAreaLeft = false;
666
- let checkSafeAreaRight = false;
667
- const triggerTop = triggerCoordinates
668
- ? triggerCoordinates.top + triggerCoordinates.height
669
- : bodyHeight / 2 - contentHeight / 2;
670
- const triggerHeight = triggerCoordinates ? triggerCoordinates.height : 0;
671
- let addPopoverBottomClass = false;
672
- /**
673
- * Adjust popover so it does not
674
- * go off the left of the screen.
675
- */
676
- if (left < bodyPadding + safeAreaMargin) {
677
- left = bodyPadding;
678
- checkSafeAreaLeft = true;
679
- originX = 'left';
658
+ let arrowTop = coordArrowTop;
659
+ const arrowLeft = coordArrowLeft;
660
+ let left = coordLeft;
661
+ let top = coordTop;
662
+ let bottom;
663
+ let originX = contentOriginX;
664
+ let originY = contentOriginY;
665
+ let checkSafeAreaLeft = false;
666
+ let checkSafeAreaRight = false;
667
+ const triggerTop = triggerCoordinates
668
+ ? triggerCoordinates.top + triggerCoordinates.height
669
+ : bodyHeight / 2 - contentHeight / 2;
670
+ const triggerHeight = triggerCoordinates ? triggerCoordinates.height : 0;
671
+ let addPopoverBottomClass = false;
680
672
  /**
681
673
  * Adjust popover so it does not
682
- * go off the right of the screen.
674
+ * go off the left of the screen.
683
675
  */
684
- }
685
- else if (contentWidth + bodyPadding + left + safeAreaMargin > bodyWidth) {
686
- checkSafeAreaRight = true;
687
- left = bodyWidth - contentWidth - bodyPadding;
688
- originX = 'right';
689
- }
690
- /**
691
- * Adjust popover so it does not
692
- * go off the top of the screen.
693
- * If popover is on the left or the right of
694
- * the trigger, then we should not adjust top
695
- * margins.
696
- */
697
- if (triggerTop + triggerHeight + contentHeight > bodyHeight && (side === 'top' || side === 'bottom')) {
698
- if (triggerTop - contentHeight > 0) {
699
- /**
700
- * While we strive to align the popover with the trigger
701
- * on smaller screens this is not always possible. As a result,
702
- * we adjust the popover up so that it does not hang
703
- * off the bottom of the screen. However, we do not want to move
704
- * the popover up so much that it goes off the top of the screen.
705
- *
706
- * We chose 12 here so that the popover position looks a bit nicer as
707
- * it is not right up against the edge of the screen.
708
- */
709
- top = Math.max(12, triggerTop - contentHeight - triggerHeight - (arrowHeight - 1));
710
- arrowTop = top + contentHeight;
711
- originY = 'bottom';
712
- addPopoverBottomClass = true;
713
- /**
714
- * If not enough room for popover to appear
715
- * above trigger, then cut it off.
716
- */
676
+ if (left < bodyPadding + safeAreaMargin) {
677
+ left = bodyPadding;
678
+ checkSafeAreaLeft = true;
679
+ originX = 'left';
680
+ /**
681
+ * Adjust popover so it does not
682
+ * go off the right of the screen.
683
+ */
684
+ }
685
+ else if (contentWidth + bodyPadding + left + safeAreaMargin > bodyWidth) {
686
+ checkSafeAreaRight = true;
687
+ left = bodyWidth - contentWidth - bodyPadding;
688
+ originX = 'right';
717
689
  }
718
- else {
719
- bottom = bodyPadding;
690
+ /**
691
+ * Adjust popover so it does not
692
+ * go off the top of the screen.
693
+ * If popover is on the left or the right of
694
+ * the trigger, then we should not adjust top
695
+ * margins.
696
+ */
697
+ if (triggerTop + triggerHeight + contentHeight > bodyHeight && (side === 'top' || side === 'bottom')) {
698
+ if (triggerTop - contentHeight > 0) {
699
+ /**
700
+ * While we strive to align the popover with the trigger
701
+ * on smaller screens this is not always possible. As a result,
702
+ * we adjust the popover up so that it does not hang
703
+ * off the bottom of the screen. However, we do not want to move
704
+ * the popover up so much that it goes off the top of the screen.
705
+ *
706
+ * We chose 12 here so that the popover position looks a bit nicer as
707
+ * it is not right up against the edge of the screen.
708
+ */
709
+ top = Math.max(12, triggerTop - contentHeight - triggerHeight - (arrowHeight - 1));
710
+ arrowTop = top + contentHeight;
711
+ originY = 'bottom';
712
+ addPopoverBottomClass = true;
713
+ /**
714
+ * If not enough room for popover to appear
715
+ * above trigger, then cut it off.
716
+ */
717
+ }
718
+ else {
719
+ bottom = bodyPadding;
720
+ }
720
721
  }
721
- }
722
- return {
723
- top,
724
- left,
725
- bottom,
726
- originX,
727
- originY,
728
- checkSafeAreaLeft,
729
- checkSafeAreaRight,
730
- arrowTop,
731
- arrowLeft,
732
- addPopoverBottomClass,
733
- };
722
+ return {
723
+ top,
724
+ left,
725
+ bottom,
726
+ originX,
727
+ originY,
728
+ checkSafeAreaLeft,
729
+ checkSafeAreaRight,
730
+ arrowTop,
731
+ arrowLeft,
732
+ addPopoverBottomClass,
733
+ };
734
734
  };
735
735
  const shouldShowArrow = (side, didAdjustBounds = false, ev, trigger) => {
736
- /**
737
- * If no event provided and
738
- * we do not have a trigger,
739
- * then this popover was likely
740
- * presented via the popoverController
741
- * or users called `present` manually.
742
- * In this case, the arrow should not be
743
- * shown as we do not have a reference.
744
- */
745
- if (!ev && !trigger) {
746
- return false;
747
- }
748
- /**
749
- * If popover is on the left or the right
750
- * of a trigger, but we needed to adjust the
751
- * popover due to screen bounds, then we should
752
- * hide the arrow as it will never be pointing
753
- * at the trigger.
754
- */
755
- if (side !== 'top' && side !== 'bottom' && didAdjustBounds) {
756
- return false;
757
- }
758
- return true;
736
+ /**
737
+ * If no event provided and
738
+ * we do not have a trigger,
739
+ * then this popover was likely
740
+ * presented via the popoverController
741
+ * or users called `present` manually.
742
+ * In this case, the arrow should not be
743
+ * shown as we do not have a reference.
744
+ */
745
+ if (!ev && !trigger) {
746
+ return false;
747
+ }
748
+ /**
749
+ * If popover is on the left or the right
750
+ * of a trigger, but we needed to adjust the
751
+ * popover due to screen bounds, then we should
752
+ * hide the arrow as it will never be pointing
753
+ * at the trigger.
754
+ */
755
+ if (side !== 'top' && side !== 'bottom' && didAdjustBounds) {
756
+ return false;
757
+ }
758
+ return true;
759
759
  };
760
760
 
761
761
  const POPOVER_IOS_BODY_PADDING = 5;
@@ -764,119 +764,119 @@ const POPOVER_IOS_BODY_PADDING = 5;
764
764
  */
765
765
  // TODO(FW-2832): types
766
766
  const iosEnterAnimation = (baseEl, opts) => {
767
- var _a;
768
- const { event: ev, size, trigger, reference, side, align } = opts;
769
- const doc = baseEl.ownerDocument;
770
- const isRTL = doc.dir === 'rtl';
771
- const bodyWidth = doc.defaultView.innerWidth;
772
- const bodyHeight = doc.defaultView.innerHeight;
773
- const root = helpers.getElementRoot(baseEl);
774
- const contentEl = root.querySelector('.popover-content');
775
- const arrowEl = root.querySelector('.popover-arrow');
776
- const referenceSizeEl = trigger || ((_a = ev === null || ev === void 0 ? void 0 : ev.detail) === null || _a === void 0 ? void 0 : _a.ionShadowTarget) || (ev === null || ev === void 0 ? void 0 : ev.target);
777
- const { contentWidth, contentHeight } = getPopoverDimensions(size, contentEl, referenceSizeEl);
778
- const { arrowWidth, arrowHeight } = getArrowDimensions(arrowEl);
779
- const defaultPosition = {
780
- top: bodyHeight / 2 - contentHeight / 2,
781
- left: bodyWidth / 2 - contentWidth / 2,
782
- originX: isRTL ? 'right' : 'left',
783
- originY: 'top',
784
- };
785
- const results = getPopoverPosition(isRTL, contentWidth, contentHeight, arrowWidth, arrowHeight, reference, side, align, defaultPosition, trigger, ev);
786
- const padding = size === 'cover' ? 0 : POPOVER_IOS_BODY_PADDING;
787
- const margin = size === 'cover' ? 0 : 25;
788
- const { originX, originY, top, left, bottom, checkSafeAreaLeft, checkSafeAreaRight, arrowTop, arrowLeft, addPopoverBottomClass, } = calculateWindowAdjustment(side, results.top, results.left, padding, bodyWidth, bodyHeight, contentWidth, contentHeight, margin, results.originX, results.originY, results.referenceCoordinates, results.arrowTop, results.arrowLeft, arrowHeight);
789
- const baseAnimation = animation.createAnimation();
790
- const backdropAnimation = animation.createAnimation();
791
- const contentAnimation = animation.createAnimation();
792
- backdropAnimation
793
- .addElement(root.querySelector('ion-backdrop'))
794
- .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
795
- .beforeStyles({
796
- 'pointer-events': 'none',
797
- })
798
- .afterClearStyles(['pointer-events']);
799
- // In Chromium, if the wrapper animates, the backdrop filter doesn't work.
800
- // The Chromium team stated that this behavior is expected and not a bug. The element animating opacity creates a backdrop root for the backdrop-filter.
801
- // To get around this, instead of animating the wrapper, animate both the arrow and content.
802
- // https://bugs.chromium.org/p/chromium/issues/detail?id=1148826
803
- contentAnimation
804
- .addElement(root.querySelector('.popover-arrow'))
805
- .addElement(root.querySelector('.popover-content'))
806
- .fromTo('opacity', 0.01, 1);
807
- // TODO(FW-4376) Ensure that arrow also blurs when translucent
808
- return baseAnimation
809
- .easing('ease')
810
- .duration(100)
811
- .beforeAddWrite(() => {
812
- if (size === 'cover') {
813
- baseEl.style.setProperty('--width', `${contentWidth}px`);
814
- }
815
- if (addPopoverBottomClass) {
816
- baseEl.classList.add('popover-bottom');
817
- }
818
- if (bottom !== undefined) {
819
- contentEl.style.setProperty('bottom', `${bottom}px`);
820
- }
821
- const safeAreaLeft = ' + var(--ion-safe-area-left, 0)';
822
- const safeAreaRight = ' - var(--ion-safe-area-right, 0)';
823
- let leftValue = `${left}px`;
824
- if (checkSafeAreaLeft) {
825
- leftValue = `${left}px${safeAreaLeft}`;
826
- }
827
- if (checkSafeAreaRight) {
828
- leftValue = `${left}px${safeAreaRight}`;
829
- }
830
- contentEl.style.setProperty('top', `calc(${top}px + var(--offset-y, 0))`);
831
- contentEl.style.setProperty('left', `calc(${leftValue} + var(--offset-x, 0))`);
832
- contentEl.style.setProperty('transform-origin', `${originY} ${originX}`);
833
- if (arrowEl !== null) {
834
- const didAdjustBounds = results.top !== top || results.left !== left;
835
- const showArrow = shouldShowArrow(side, didAdjustBounds, ev, trigger);
836
- if (showArrow) {
837
- arrowEl.style.setProperty('top', `calc(${arrowTop}px + var(--offset-y, 0))`);
838
- arrowEl.style.setProperty('left', `calc(${arrowLeft}px + var(--offset-x, 0))`);
839
- }
840
- else {
841
- arrowEl.style.setProperty('display', 'none');
842
- }
843
- }
844
- })
845
- .addAnimation([backdropAnimation, contentAnimation]);
767
+ var _a;
768
+ const { event: ev, size, trigger, reference, side, align } = opts;
769
+ const doc = baseEl.ownerDocument;
770
+ const isRTL = doc.dir === 'rtl';
771
+ const bodyWidth = doc.defaultView.innerWidth;
772
+ const bodyHeight = doc.defaultView.innerHeight;
773
+ const root = helpers.getElementRoot(baseEl);
774
+ const contentEl = root.querySelector('.popover-content');
775
+ const arrowEl = root.querySelector('.popover-arrow');
776
+ const referenceSizeEl = trigger || ((_a = ev === null || ev === void 0 ? void 0 : ev.detail) === null || _a === void 0 ? void 0 : _a.ionShadowTarget) || (ev === null || ev === void 0 ? void 0 : ev.target);
777
+ const { contentWidth, contentHeight } = getPopoverDimensions(size, contentEl, referenceSizeEl);
778
+ const { arrowWidth, arrowHeight } = getArrowDimensions(arrowEl);
779
+ const defaultPosition = {
780
+ top: bodyHeight / 2 - contentHeight / 2,
781
+ left: bodyWidth / 2 - contentWidth / 2,
782
+ originX: isRTL ? 'right' : 'left',
783
+ originY: 'top',
784
+ };
785
+ const results = getPopoverPosition(isRTL, contentWidth, contentHeight, arrowWidth, arrowHeight, reference, side, align, defaultPosition, trigger, ev);
786
+ const padding = size === 'cover' ? 0 : POPOVER_IOS_BODY_PADDING;
787
+ const margin = size === 'cover' ? 0 : 25;
788
+ const { originX, originY, top, left, bottom, checkSafeAreaLeft, checkSafeAreaRight, arrowTop, arrowLeft, addPopoverBottomClass, } = calculateWindowAdjustment(side, results.top, results.left, padding, bodyWidth, bodyHeight, contentWidth, contentHeight, margin, results.originX, results.originY, results.referenceCoordinates, results.arrowTop, results.arrowLeft, arrowHeight);
789
+ const baseAnimation = animation.createAnimation();
790
+ const backdropAnimation = animation.createAnimation();
791
+ const contentAnimation = animation.createAnimation();
792
+ backdropAnimation
793
+ .addElement(root.querySelector('ion-backdrop'))
794
+ .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
795
+ .beforeStyles({
796
+ 'pointer-events': 'none',
797
+ })
798
+ .afterClearStyles(['pointer-events']);
799
+ // In Chromium, if the wrapper animates, the backdrop filter doesn't work.
800
+ // The Chromium team stated that this behavior is expected and not a bug. The element animating opacity creates a backdrop root for the backdrop-filter.
801
+ // To get around this, instead of animating the wrapper, animate both the arrow and content.
802
+ // https://bugs.chromium.org/p/chromium/issues/detail?id=1148826
803
+ contentAnimation
804
+ .addElement(root.querySelector('.popover-arrow'))
805
+ .addElement(root.querySelector('.popover-content'))
806
+ .fromTo('opacity', 0.01, 1);
807
+ // TODO(FW-4376) Ensure that arrow also blurs when translucent
808
+ return baseAnimation
809
+ .easing('ease')
810
+ .duration(100)
811
+ .beforeAddWrite(() => {
812
+ if (size === 'cover') {
813
+ baseEl.style.setProperty('--width', `${contentWidth}px`);
814
+ }
815
+ if (addPopoverBottomClass) {
816
+ baseEl.classList.add('popover-bottom');
817
+ }
818
+ if (bottom !== undefined) {
819
+ contentEl.style.setProperty('bottom', `${bottom}px`);
820
+ }
821
+ const safeAreaLeft = ' + var(--ion-safe-area-left, 0)';
822
+ const safeAreaRight = ' - var(--ion-safe-area-right, 0)';
823
+ let leftValue = `${left}px`;
824
+ if (checkSafeAreaLeft) {
825
+ leftValue = `${left}px${safeAreaLeft}`;
826
+ }
827
+ if (checkSafeAreaRight) {
828
+ leftValue = `${left}px${safeAreaRight}`;
829
+ }
830
+ contentEl.style.setProperty('top', `calc(${top}px + var(--offset-y, 0))`);
831
+ contentEl.style.setProperty('left', `calc(${leftValue} + var(--offset-x, 0))`);
832
+ contentEl.style.setProperty('transform-origin', `${originY} ${originX}`);
833
+ if (arrowEl !== null) {
834
+ const didAdjustBounds = results.top !== top || results.left !== left;
835
+ const showArrow = shouldShowArrow(side, didAdjustBounds, ev, trigger);
836
+ if (showArrow) {
837
+ arrowEl.style.setProperty('top', `calc(${arrowTop}px + var(--offset-y, 0))`);
838
+ arrowEl.style.setProperty('left', `calc(${arrowLeft}px + var(--offset-x, 0))`);
839
+ }
840
+ else {
841
+ arrowEl.style.setProperty('display', 'none');
842
+ }
843
+ }
844
+ })
845
+ .addAnimation([backdropAnimation, contentAnimation]);
846
846
  };
847
847
 
848
848
  /**
849
849
  * iOS Popover Leave Animation
850
850
  */
851
851
  const iosLeaveAnimation = (baseEl) => {
852
- const root = helpers.getElementRoot(baseEl);
853
- const contentEl = root.querySelector('.popover-content');
854
- const arrowEl = root.querySelector('.popover-arrow');
855
- const baseAnimation = animation.createAnimation();
856
- const backdropAnimation = animation.createAnimation();
857
- const contentAnimation = animation.createAnimation();
858
- backdropAnimation.addElement(root.querySelector('ion-backdrop')).fromTo('opacity', 'var(--backdrop-opacity)', 0);
859
- contentAnimation
860
- .addElement(root.querySelector('.popover-arrow'))
861
- .addElement(root.querySelector('.popover-content'))
862
- .fromTo('opacity', 0.99, 0);
863
- return baseAnimation
864
- .easing('ease')
865
- .afterAddWrite(() => {
866
- baseEl.style.removeProperty('--width');
867
- baseEl.classList.remove('popover-bottom');
868
- contentEl.style.removeProperty('top');
869
- contentEl.style.removeProperty('left');
870
- contentEl.style.removeProperty('bottom');
871
- contentEl.style.removeProperty('transform-origin');
872
- if (arrowEl) {
873
- arrowEl.style.removeProperty('top');
874
- arrowEl.style.removeProperty('left');
875
- arrowEl.style.removeProperty('display');
876
- }
877
- })
878
- .duration(300)
879
- .addAnimation([backdropAnimation, contentAnimation]);
852
+ const root = helpers.getElementRoot(baseEl);
853
+ const contentEl = root.querySelector('.popover-content');
854
+ const arrowEl = root.querySelector('.popover-arrow');
855
+ const baseAnimation = animation.createAnimation();
856
+ const backdropAnimation = animation.createAnimation();
857
+ const contentAnimation = animation.createAnimation();
858
+ backdropAnimation.addElement(root.querySelector('ion-backdrop')).fromTo('opacity', 'var(--backdrop-opacity)', 0);
859
+ contentAnimation
860
+ .addElement(root.querySelector('.popover-arrow'))
861
+ .addElement(root.querySelector('.popover-content'))
862
+ .fromTo('opacity', 0.99, 0);
863
+ return baseAnimation
864
+ .easing('ease')
865
+ .afterAddWrite(() => {
866
+ baseEl.style.removeProperty('--width');
867
+ baseEl.classList.remove('popover-bottom');
868
+ contentEl.style.removeProperty('top');
869
+ contentEl.style.removeProperty('left');
870
+ contentEl.style.removeProperty('bottom');
871
+ contentEl.style.removeProperty('transform-origin');
872
+ if (arrowEl) {
873
+ arrowEl.style.removeProperty('top');
874
+ arrowEl.style.removeProperty('left');
875
+ arrowEl.style.removeProperty('display');
876
+ }
877
+ })
878
+ .duration(300)
879
+ .addAnimation([backdropAnimation, contentAnimation]);
880
880
  };
881
881
 
882
882
  const POPOVER_MD_BODY_PADDING = 12;
@@ -885,420 +885,430 @@ const POPOVER_MD_BODY_PADDING = 12;
885
885
  */
886
886
  // TODO(FW-2832): types
887
887
  const mdEnterAnimation = (baseEl, opts) => {
888
- var _a;
889
- const { event: ev, size, trigger, reference, side, align } = opts;
890
- const doc = baseEl.ownerDocument;
891
- const isRTL = doc.dir === 'rtl';
892
- const bodyWidth = doc.defaultView.innerWidth;
893
- const bodyHeight = doc.defaultView.innerHeight;
894
- const root = helpers.getElementRoot(baseEl);
895
- const contentEl = root.querySelector('.popover-content');
896
- const referenceSizeEl = trigger || ((_a = ev === null || ev === void 0 ? void 0 : ev.detail) === null || _a === void 0 ? void 0 : _a.ionShadowTarget) || (ev === null || ev === void 0 ? void 0 : ev.target);
897
- const { contentWidth, contentHeight } = getPopoverDimensions(size, contentEl, referenceSizeEl);
898
- const defaultPosition = {
899
- top: bodyHeight / 2 - contentHeight / 2,
900
- left: bodyWidth / 2 - contentWidth / 2,
901
- originX: isRTL ? 'right' : 'left',
902
- originY: 'top',
903
- };
904
- const results = getPopoverPosition(isRTL, contentWidth, contentHeight, 0, 0, reference, side, align, defaultPosition, trigger, ev);
905
- const padding = size === 'cover' ? 0 : POPOVER_MD_BODY_PADDING;
906
- const { originX, originY, top, left, bottom } = calculateWindowAdjustment(side, results.top, results.left, padding, bodyWidth, bodyHeight, contentWidth, contentHeight, 0, results.originX, results.originY, results.referenceCoordinates);
907
- const baseAnimation = animation.createAnimation();
908
- const backdropAnimation = animation.createAnimation();
909
- const wrapperAnimation = animation.createAnimation();
910
- const contentAnimation = animation.createAnimation();
911
- const viewportAnimation = animation.createAnimation();
912
- backdropAnimation
913
- .addElement(root.querySelector('ion-backdrop'))
914
- .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
915
- .beforeStyles({
916
- 'pointer-events': 'none',
917
- })
918
- .afterClearStyles(['pointer-events']);
919
- wrapperAnimation.addElement(root.querySelector('.popover-wrapper')).duration(150).fromTo('opacity', 0.01, 1);
920
- contentAnimation
921
- .addElement(contentEl)
922
- .beforeStyles({
923
- top: `calc(${top}px + var(--offset-y, 0px))`,
924
- left: `calc(${left}px + var(--offset-x, 0px))`,
925
- 'transform-origin': `${originY} ${originX}`,
926
- })
927
- .beforeAddWrite(() => {
928
- if (bottom !== undefined) {
929
- contentEl.style.setProperty('bottom', `${bottom}px`);
930
- }
931
- })
932
- .fromTo('transform', 'scale(0.8)', 'scale(1)');
933
- viewportAnimation.addElement(root.querySelector('.popover-viewport')).fromTo('opacity', 0.01, 1);
934
- return baseAnimation
935
- .easing('cubic-bezier(0.36,0.66,0.04,1)')
936
- .duration(300)
937
- .beforeAddWrite(() => {
938
- if (size === 'cover') {
939
- baseEl.style.setProperty('--width', `${contentWidth}px`);
940
- }
941
- if (originY === 'bottom') {
942
- baseEl.classList.add('popover-bottom');
943
- }
944
- })
945
- .addAnimation([backdropAnimation, wrapperAnimation, contentAnimation, viewportAnimation]);
888
+ var _a;
889
+ const { event: ev, size, trigger, reference, side, align } = opts;
890
+ const doc = baseEl.ownerDocument;
891
+ const isRTL = doc.dir === 'rtl';
892
+ const bodyWidth = doc.defaultView.innerWidth;
893
+ const bodyHeight = doc.defaultView.innerHeight;
894
+ const root = helpers.getElementRoot(baseEl);
895
+ const contentEl = root.querySelector('.popover-content');
896
+ const referenceSizeEl = trigger || ((_a = ev === null || ev === void 0 ? void 0 : ev.detail) === null || _a === void 0 ? void 0 : _a.ionShadowTarget) || (ev === null || ev === void 0 ? void 0 : ev.target);
897
+ const { contentWidth, contentHeight } = getPopoverDimensions(size, contentEl, referenceSizeEl);
898
+ const defaultPosition = {
899
+ top: bodyHeight / 2 - contentHeight / 2,
900
+ left: bodyWidth / 2 - contentWidth / 2,
901
+ originX: isRTL ? 'right' : 'left',
902
+ originY: 'top',
903
+ };
904
+ const results = getPopoverPosition(isRTL, contentWidth, contentHeight, 0, 0, reference, side, align, defaultPosition, trigger, ev);
905
+ const padding = size === 'cover' ? 0 : POPOVER_MD_BODY_PADDING;
906
+ const { originX, originY, top, left, bottom } = calculateWindowAdjustment(side, results.top, results.left, padding, bodyWidth, bodyHeight, contentWidth, contentHeight, 0, results.originX, results.originY, results.referenceCoordinates);
907
+ const baseAnimation = animation.createAnimation();
908
+ const backdropAnimation = animation.createAnimation();
909
+ const wrapperAnimation = animation.createAnimation();
910
+ const contentAnimation = animation.createAnimation();
911
+ const viewportAnimation = animation.createAnimation();
912
+ backdropAnimation
913
+ .addElement(root.querySelector('ion-backdrop'))
914
+ .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
915
+ .beforeStyles({
916
+ 'pointer-events': 'none',
917
+ })
918
+ .afterClearStyles(['pointer-events']);
919
+ wrapperAnimation.addElement(root.querySelector('.popover-wrapper')).duration(150).fromTo('opacity', 0.01, 1);
920
+ contentAnimation
921
+ .addElement(contentEl)
922
+ .beforeStyles({
923
+ top: `calc(${top}px + var(--offset-y, 0px))`,
924
+ left: `calc(${left}px + var(--offset-x, 0px))`,
925
+ 'transform-origin': `${originY} ${originX}`,
926
+ })
927
+ .beforeAddWrite(() => {
928
+ if (bottom !== undefined) {
929
+ contentEl.style.setProperty('bottom', `${bottom}px`);
930
+ }
931
+ })
932
+ .fromTo('transform', 'scale(0.8)', 'scale(1)');
933
+ viewportAnimation.addElement(root.querySelector('.popover-viewport')).fromTo('opacity', 0.01, 1);
934
+ return baseAnimation
935
+ .easing('cubic-bezier(0.36,0.66,0.04,1)')
936
+ .duration(300)
937
+ .beforeAddWrite(() => {
938
+ if (size === 'cover') {
939
+ baseEl.style.setProperty('--width', `${contentWidth}px`);
940
+ }
941
+ if (originY === 'bottom') {
942
+ baseEl.classList.add('popover-bottom');
943
+ }
944
+ })
945
+ .addAnimation([backdropAnimation, wrapperAnimation, contentAnimation, viewportAnimation]);
946
946
  };
947
947
 
948
948
  /**
949
949
  * Md Popover Leave Animation
950
950
  */
951
951
  const mdLeaveAnimation = (baseEl) => {
952
- const root = helpers.getElementRoot(baseEl);
953
- const contentEl = root.querySelector('.popover-content');
954
- const baseAnimation = animation.createAnimation();
955
- const backdropAnimation = animation.createAnimation();
956
- const wrapperAnimation = animation.createAnimation();
957
- backdropAnimation.addElement(root.querySelector('ion-backdrop')).fromTo('opacity', 'var(--backdrop-opacity)', 0);
958
- wrapperAnimation.addElement(root.querySelector('.popover-wrapper')).fromTo('opacity', 0.99, 0);
959
- return baseAnimation
960
- .easing('ease')
961
- .afterAddWrite(() => {
962
- baseEl.style.removeProperty('--width');
963
- baseEl.classList.remove('popover-bottom');
964
- contentEl.style.removeProperty('top');
965
- contentEl.style.removeProperty('left');
966
- contentEl.style.removeProperty('bottom');
967
- contentEl.style.removeProperty('transform-origin');
968
- })
969
- .duration(150)
970
- .addAnimation([backdropAnimation, wrapperAnimation]);
952
+ const root = helpers.getElementRoot(baseEl);
953
+ const contentEl = root.querySelector('.popover-content');
954
+ const baseAnimation = animation.createAnimation();
955
+ const backdropAnimation = animation.createAnimation();
956
+ const wrapperAnimation = animation.createAnimation();
957
+ backdropAnimation.addElement(root.querySelector('ion-backdrop')).fromTo('opacity', 'var(--backdrop-opacity)', 0);
958
+ wrapperAnimation.addElement(root.querySelector('.popover-wrapper')).fromTo('opacity', 0.99, 0);
959
+ return baseAnimation
960
+ .easing('ease')
961
+ .afterAddWrite(() => {
962
+ baseEl.style.removeProperty('--width');
963
+ baseEl.classList.remove('popover-bottom');
964
+ contentEl.style.removeProperty('top');
965
+ contentEl.style.removeProperty('left');
966
+ contentEl.style.removeProperty('bottom');
967
+ contentEl.style.removeProperty('transform-origin');
968
+ })
969
+ .duration(150)
970
+ .addAnimation([backdropAnimation, wrapperAnimation]);
971
971
  };
972
972
 
973
- const popoverIosCss = ":host{--background:var(--ion-background-color, #fff);--min-width:0;--min-height:0;--max-width:auto;--height:auto;--offset-x:0px;--offset-y:0px;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;color:var(--ion-text-color, #000);z-index:1001}:host(.popover-nested){pointer-events:none}:host(.popover-nested) .popover-wrapper{pointer-events:auto}:host(.overlay-hidden){display:none}.popover-wrapper{z-index:10}.popover-content{display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);overflow:auto;z-index:10}.popover-viewport{--ion-safe-area-top:0px;--ion-safe-area-right:0px;--ion-safe-area-bottom:0px;--ion-safe-area-left:0px;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;overflow:hidden}:host(.popover-nested.popover-side-left){--offset-x:5px}:host(.popover-nested.popover-side-right){--offset-x:-5px}:host(.popover-nested.popover-side-start){--offset-x:5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-start),:host-context([dir=rtl]).popover-nested.popover-side-start{--offset-x:-5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-start):dir(rtl){--offset-x:-5px}}:host(.popover-nested.popover-side-end){--offset-x:-5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-end),:host-context([dir=rtl]).popover-nested.popover-side-end{--offset-x:5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-end):dir(rtl){--offset-x:5px}}:host{--width:200px;--max-height:90%;--box-shadow:none;--backdrop-opacity:var(--ion-backdrop-opacity, 0.08)}:host(.popover-desktop){--box-shadow:0px 4px 16px 0px rgba(0, 0, 0, 0.12)}.popover-content{border-radius:10px}:host(.popover-desktop) .popover-content{border:0.5px solid var(--ion-color-step-100, #e6e6e6)}.popover-arrow{display:block;position:absolute;width:20px;height:10px;overflow:hidden}.popover-arrow::after{top:3px;border-radius:3px;position:absolute;width:14px;height:14px;-webkit-transform:rotate(45deg);transform:rotate(45deg);background:var(--background);content:\"\";z-index:10}@supports (inset-inline-start: 0){.popover-arrow::after{inset-inline-start:3px}}@supports not (inset-inline-start: 0){.popover-arrow::after{left:3px}:host-context([dir=rtl]) .popover-arrow::after{left:unset;right:unset;right:3px}[dir=rtl] .popover-arrow::after{left:unset;right:unset;right:3px}@supports selector(:dir(rtl)){.popover-arrow::after:dir(rtl){left:unset;right:unset;right:3px}}}:host(.popover-bottom) .popover-arrow{top:auto;bottom:-10px}:host(.popover-bottom) .popover-arrow::after{top:-6px}:host(.popover-side-left) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}:host(.popover-side-right) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}:host(.popover-side-top) .popover-arrow{-webkit-transform:rotate(180deg);transform:rotate(180deg)}:host(.popover-side-start) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}:host-context([dir=rtl]):host(.popover-side-start) .popover-arrow,:host-context([dir=rtl]).popover-side-start .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}@supports selector(:dir(rtl)){:host(.popover-side-start) .popover-arrow:dir(rtl){-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}}:host(.popover-side-end) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}:host-context([dir=rtl]):host(.popover-side-end) .popover-arrow,:host-context([dir=rtl]).popover-side-end .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}@supports selector(:dir(rtl)){:host(.popover-side-end) .popover-arrow:dir(rtl){-webkit-transform:rotate(90deg);transform:rotate(90deg)}}.popover-arrow,.popover-content{opacity:0}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){:host(.popover-translucent) .popover-content,:host(.popover-translucent) .popover-arrow::after{background:rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}}";
973
+ const popoverIosCss = ":host{--background:var(--ion-background-color, #fff);--min-width:0;--min-height:0;--max-width:auto;--height:auto;--offset-x:0px;--offset-y:0px;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;color:var(--ion-text-color, #000);z-index:1001}:host(.popover-nested){pointer-events:none}:host(.popover-nested) .popover-wrapper{pointer-events:auto}:host(.overlay-hidden){display:none}.popover-wrapper{z-index:10}.popover-content{display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);overflow:auto;z-index:10}.popover-viewport{--ion-safe-area-top:0px;--ion-safe-area-right:0px;--ion-safe-area-bottom:0px;--ion-safe-area-left:0px;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;overflow:hidden}:host(.popover-nested.popover-side-left){--offset-x:5px}:host(.popover-nested.popover-side-right){--offset-x:-5px}:host(.popover-nested.popover-side-start){--offset-x:5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-start),:host-context([dir=rtl]).popover-nested.popover-side-start{--offset-x:-5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-start:dir(rtl)){--offset-x:-5px}}:host(.popover-nested.popover-side-end){--offset-x:-5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-end),:host-context([dir=rtl]).popover-nested.popover-side-end{--offset-x:5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-end:dir(rtl)){--offset-x:5px}}:host{--width:200px;--max-height:90%;--box-shadow:none;--backdrop-opacity:var(--ion-backdrop-opacity, 0.08)}:host(.popover-desktop){--box-shadow:0px 4px 16px 0px rgba(0, 0, 0, 0.12)}.popover-content{border-radius:10px}:host(.popover-desktop) .popover-content{border:0.5px solid var(--ion-color-step-100, #e6e6e6)}.popover-arrow{display:block;position:absolute;width:20px;height:10px;overflow:hidden}.popover-arrow::after{top:3px;border-radius:3px;position:absolute;width:14px;height:14px;-webkit-transform:rotate(45deg);transform:rotate(45deg);background:var(--background);content:\"\";z-index:10}@supports (inset-inline-start: 0){.popover-arrow::after{inset-inline-start:3px}}@supports not (inset-inline-start: 0){.popover-arrow::after{left:3px}:host-context([dir=rtl]) .popover-arrow::after{left:unset;right:unset;right:3px}[dir=rtl] .popover-arrow::after{left:unset;right:unset;right:3px}@supports selector(:dir(rtl)){.popover-arrow::after:dir(rtl){left:unset;right:unset;right:3px}}}:host(.popover-bottom) .popover-arrow{top:auto;bottom:-10px}:host(.popover-bottom) .popover-arrow::after{top:-6px}:host(.popover-side-left) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}:host(.popover-side-right) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}:host(.popover-side-top) .popover-arrow{-webkit-transform:rotate(180deg);transform:rotate(180deg)}:host(.popover-side-start) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}:host-context([dir=rtl]):host(.popover-side-start) .popover-arrow,:host-context([dir=rtl]).popover-side-start .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}@supports selector(:dir(rtl)){:host(.popover-side-start:dir(rtl)) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}}:host(.popover-side-end) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}:host-context([dir=rtl]):host(.popover-side-end) .popover-arrow,:host-context([dir=rtl]).popover-side-end .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}@supports selector(:dir(rtl)){:host(.popover-side-end:dir(rtl)) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}}.popover-arrow,.popover-content{opacity:0}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){:host(.popover-translucent) .popover-content,:host(.popover-translucent) .popover-arrow::after{background:rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}}";
974
974
 
975
- const popoverMdCss = ":host{--background:var(--ion-background-color, #fff);--min-width:0;--min-height:0;--max-width:auto;--height:auto;--offset-x:0px;--offset-y:0px;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;color:var(--ion-text-color, #000);z-index:1001}:host(.popover-nested){pointer-events:none}:host(.popover-nested) .popover-wrapper{pointer-events:auto}:host(.overlay-hidden){display:none}.popover-wrapper{z-index:10}.popover-content{display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);overflow:auto;z-index:10}.popover-viewport{--ion-safe-area-top:0px;--ion-safe-area-right:0px;--ion-safe-area-bottom:0px;--ion-safe-area-left:0px;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;overflow:hidden}:host(.popover-nested.popover-side-left){--offset-x:5px}:host(.popover-nested.popover-side-right){--offset-x:-5px}:host(.popover-nested.popover-side-start){--offset-x:5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-start),:host-context([dir=rtl]).popover-nested.popover-side-start{--offset-x:-5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-start):dir(rtl){--offset-x:-5px}}:host(.popover-nested.popover-side-end){--offset-x:-5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-end),:host-context([dir=rtl]).popover-nested.popover-side-end{--offset-x:5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-end):dir(rtl){--offset-x:5px}}:host{--width:250px;--max-height:90%;--box-shadow:0 5px 5px -3px rgba(0, 0, 0, 0.2), 0 8px 10px 1px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12);--backdrop-opacity:var(--ion-backdrop-opacity, 0.32)}.popover-content{border-radius:4px;-webkit-transform-origin:left top;transform-origin:left top}:host-context([dir=rtl]) .popover-content{-webkit-transform-origin:right top;transform-origin:right top}[dir=rtl] .popover-content{-webkit-transform-origin:right top;transform-origin:right top}@supports selector(:dir(rtl)){.popover-content:dir(rtl){-webkit-transform-origin:right top;transform-origin:right top}}.popover-viewport{-webkit-transition-delay:100ms;transition-delay:100ms}.popover-wrapper{opacity:0}";
975
+ const popoverMdCss = ":host{--background:var(--ion-background-color, #fff);--min-width:0;--min-height:0;--max-width:auto;--height:auto;--offset-x:0px;--offset-y:0px;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;color:var(--ion-text-color, #000);z-index:1001}:host(.popover-nested){pointer-events:none}:host(.popover-nested) .popover-wrapper{pointer-events:auto}:host(.overlay-hidden){display:none}.popover-wrapper{z-index:10}.popover-content{display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);overflow:auto;z-index:10}.popover-viewport{--ion-safe-area-top:0px;--ion-safe-area-right:0px;--ion-safe-area-bottom:0px;--ion-safe-area-left:0px;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;overflow:hidden}:host(.popover-nested.popover-side-left){--offset-x:5px}:host(.popover-nested.popover-side-right){--offset-x:-5px}:host(.popover-nested.popover-side-start){--offset-x:5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-start),:host-context([dir=rtl]).popover-nested.popover-side-start{--offset-x:-5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-start:dir(rtl)){--offset-x:-5px}}:host(.popover-nested.popover-side-end){--offset-x:-5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-end),:host-context([dir=rtl]).popover-nested.popover-side-end{--offset-x:5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-end:dir(rtl)){--offset-x:5px}}:host{--width:250px;--max-height:90%;--box-shadow:0 5px 5px -3px rgba(0, 0, 0, 0.2), 0 8px 10px 1px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12);--backdrop-opacity:var(--ion-backdrop-opacity, 0.32)}.popover-content{border-radius:4px;-webkit-transform-origin:left top;transform-origin:left top}:host-context([dir=rtl]) .popover-content{-webkit-transform-origin:right top;transform-origin:right top}[dir=rtl] .popover-content{-webkit-transform-origin:right top;transform-origin:right top}@supports selector(:dir(rtl)){.popover-content:dir(rtl){-webkit-transform-origin:right top;transform-origin:right top}}.popover-viewport{-webkit-transition-delay:100ms;transition-delay:100ms}.popover-wrapper{opacity:0}";
976
976
 
977
977
  const Popover = class {
978
- constructor(hostRef) {
979
- index.registerInstance(this, hostRef);
980
- this.didPresent = index.createEvent(this, "ionPopoverDidPresent", 7);
981
- this.willPresent = index.createEvent(this, "ionPopoverWillPresent", 7);
982
- this.willDismiss = index.createEvent(this, "ionPopoverWillDismiss", 7);
983
- this.didDismiss = index.createEvent(this, "ionPopoverDidDismiss", 7);
984
- this.didPresentShorthand = index.createEvent(this, "didPresent", 7);
985
- this.willPresentShorthand = index.createEvent(this, "willPresent", 7);
986
- this.willDismissShorthand = index.createEvent(this, "willDismiss", 7);
987
- this.didDismissShorthand = index.createEvent(this, "didDismiss", 7);
988
- this.ionMount = index.createEvent(this, "ionMount", 7);
989
- this.parentPopover = null;
990
- this.coreDelegate = frameworkDelegate.CoreDelegate();
991
- this.lockController = lockController.createLockController();
992
- this.inline = false;
993
- this.focusDescendantOnPresent = false;
994
- this.onBackdropTap = () => {
995
- this.dismiss(undefined, overlays.BACKDROP);
996
- };
997
- this.onLifecycle = (modalEvent) => {
998
- const el = this.usersElement;
999
- const name = LIFECYCLE_MAP[modalEvent.type];
1000
- if (el && name) {
1001
- const event = new CustomEvent(name, {
1002
- bubbles: false,
1003
- cancelable: false,
1004
- detail: modalEvent.detail,
1005
- });
1006
- el.dispatchEvent(event);
1007
- }
1008
- };
1009
- this.configureTriggerInteraction = () => {
1010
- const { trigger, triggerAction, el, destroyTriggerInteraction } = this;
1011
- if (destroyTriggerInteraction) {
1012
- destroyTriggerInteraction();
1013
- }
1014
- if (trigger === undefined) {
1015
- return;
1016
- }
1017
- const triggerEl = (this.triggerEl = trigger !== undefined ? document.getElementById(trigger) : null);
1018
- if (!triggerEl) {
1019
- index$1.printIonWarning(`A trigger element with the ID "${trigger}" was not found in the DOM. The trigger element must be in the DOM when the "trigger" property is set on ion-popover.`, this.el);
1020
- return;
1021
- }
1022
- this.destroyTriggerInteraction = configureTriggerInteraction(triggerEl, triggerAction, el);
1023
- };
1024
- this.configureKeyboardInteraction = () => {
1025
- const { destroyKeyboardInteraction, el } = this;
1026
- if (destroyKeyboardInteraction) {
1027
- destroyKeyboardInteraction();
1028
- }
1029
- this.destroyKeyboardInteraction = configureKeyboardInteraction(el);
1030
- };
1031
- this.configureDismissInteraction = () => {
1032
- const { destroyDismissInteraction, parentPopover, triggerAction, triggerEl, el } = this;
1033
- if (!parentPopover || !triggerEl) {
1034
- return;
1035
- }
1036
- if (destroyDismissInteraction) {
1037
- destroyDismissInteraction();
1038
- }
1039
- this.destroyDismissInteraction = configureDismissInteraction(triggerEl, triggerAction, el, parentPopover);
1040
- };
1041
- this.presented = false;
1042
- this.hasController = false;
1043
- this.delegate = undefined;
1044
- this.overlayIndex = undefined;
1045
- this.enterAnimation = undefined;
1046
- this.leaveAnimation = undefined;
1047
- this.component = undefined;
1048
- this.componentProps = undefined;
1049
- this.keyboardClose = true;
1050
- this.cssClass = undefined;
1051
- this.backdropDismiss = true;
1052
- this.event = undefined;
1053
- this.showBackdrop = true;
1054
- this.translucent = false;
1055
- this.animated = true;
1056
- this.htmlAttributes = undefined;
1057
- this.triggerAction = 'click';
1058
- this.trigger = undefined;
1059
- this.size = 'auto';
1060
- this.dismissOnSelect = false;
1061
- this.reference = 'trigger';
1062
- this.side = 'bottom';
1063
- this.alignment = undefined;
1064
- this.arrow = true;
1065
- this.isOpen = false;
1066
- this.keyboardEvents = false;
1067
- this.keepContentsMounted = false;
1068
- }
1069
- onTriggerChange() {
1070
- this.configureTriggerInteraction();
1071
- }
1072
- onIsOpenChange(newValue, oldValue) {
1073
- if (newValue === true && oldValue === false) {
1074
- this.present();
978
+ constructor(hostRef) {
979
+ index.registerInstance(this, hostRef);
980
+ this.didPresent = index.createEvent(this, "ionPopoverDidPresent", 7);
981
+ this.willPresent = index.createEvent(this, "ionPopoverWillPresent", 7);
982
+ this.willDismiss = index.createEvent(this, "ionPopoverWillDismiss", 7);
983
+ this.didDismiss = index.createEvent(this, "ionPopoverDidDismiss", 7);
984
+ this.didPresentShorthand = index.createEvent(this, "didPresent", 7);
985
+ this.willPresentShorthand = index.createEvent(this, "willPresent", 7);
986
+ this.willDismissShorthand = index.createEvent(this, "willDismiss", 7);
987
+ this.didDismissShorthand = index.createEvent(this, "didDismiss", 7);
988
+ this.ionMount = index.createEvent(this, "ionMount", 7);
989
+ this.parentPopover = null;
990
+ this.coreDelegate = frameworkDelegate.CoreDelegate();
991
+ this.lockController = lockController.createLockController();
992
+ this.inline = false;
993
+ this.focusDescendantOnPresent = false;
994
+ this.onBackdropTap = () => {
995
+ this.dismiss(undefined, overlays.BACKDROP);
996
+ };
997
+ this.onLifecycle = (modalEvent) => {
998
+ const el = this.usersElement;
999
+ const name = LIFECYCLE_MAP[modalEvent.type];
1000
+ if (el && name) {
1001
+ const event = new CustomEvent(name, {
1002
+ bubbles: false,
1003
+ cancelable: false,
1004
+ detail: modalEvent.detail,
1005
+ });
1006
+ el.dispatchEvent(event);
1007
+ }
1008
+ };
1009
+ this.configureTriggerInteraction = () => {
1010
+ const { trigger, triggerAction, el, destroyTriggerInteraction } = this;
1011
+ if (destroyTriggerInteraction) {
1012
+ destroyTriggerInteraction();
1013
+ }
1014
+ if (trigger === undefined) {
1015
+ return;
1016
+ }
1017
+ const triggerEl = (this.triggerEl = trigger !== undefined ? document.getElementById(trigger) : null);
1018
+ if (!triggerEl) {
1019
+ index$1.printIonWarning(`A trigger element with the ID "${trigger}" was not found in the DOM. The trigger element must be in the DOM when the "trigger" property is set on ion-popover.`, this.el);
1020
+ return;
1021
+ }
1022
+ this.destroyTriggerInteraction = configureTriggerInteraction(triggerEl, triggerAction, el);
1023
+ };
1024
+ this.configureKeyboardInteraction = () => {
1025
+ const { destroyKeyboardInteraction, el } = this;
1026
+ if (destroyKeyboardInteraction) {
1027
+ destroyKeyboardInteraction();
1028
+ }
1029
+ this.destroyKeyboardInteraction = configureKeyboardInteraction(el);
1030
+ };
1031
+ this.configureDismissInteraction = () => {
1032
+ const { destroyDismissInteraction, parentPopover, triggerAction, triggerEl, el } = this;
1033
+ if (!parentPopover || !triggerEl) {
1034
+ return;
1035
+ }
1036
+ if (destroyDismissInteraction) {
1037
+ destroyDismissInteraction();
1038
+ }
1039
+ this.destroyDismissInteraction = configureDismissInteraction(triggerEl, triggerAction, el, parentPopover);
1040
+ };
1041
+ this.presented = false;
1042
+ this.hasController = false;
1043
+ this.delegate = undefined;
1044
+ this.overlayIndex = undefined;
1045
+ this.enterAnimation = undefined;
1046
+ this.leaveAnimation = undefined;
1047
+ this.component = undefined;
1048
+ this.componentProps = undefined;
1049
+ this.keyboardClose = true;
1050
+ this.cssClass = undefined;
1051
+ this.backdropDismiss = true;
1052
+ this.event = undefined;
1053
+ this.showBackdrop = true;
1054
+ this.translucent = false;
1055
+ this.animated = true;
1056
+ this.htmlAttributes = undefined;
1057
+ this.triggerAction = 'click';
1058
+ this.trigger = undefined;
1059
+ this.size = 'auto';
1060
+ this.dismissOnSelect = false;
1061
+ this.reference = 'trigger';
1062
+ this.side = 'bottom';
1063
+ this.alignment = undefined;
1064
+ this.arrow = true;
1065
+ this.isOpen = false;
1066
+ this.keyboardEvents = false;
1067
+ this.keepContentsMounted = false;
1075
1068
  }
1076
- else if (newValue === false && oldValue === true) {
1077
- this.dismiss();
1069
+ onTriggerChange() {
1070
+ this.configureTriggerInteraction();
1078
1071
  }
1079
- }
1080
- connectedCallback() {
1081
- const { configureTriggerInteraction, el } = this;
1082
- overlays.prepareOverlay(el);
1083
- configureTriggerInteraction();
1084
- }
1085
- disconnectedCallback() {
1086
- const { destroyTriggerInteraction } = this;
1087
- if (destroyTriggerInteraction) {
1088
- destroyTriggerInteraction();
1072
+ onIsOpenChange(newValue, oldValue) {
1073
+ if (newValue === true && oldValue === false) {
1074
+ this.present();
1075
+ }
1076
+ else if (newValue === false && oldValue === true) {
1077
+ this.dismiss();
1078
+ }
1089
1079
  }
1090
- }
1091
- componentWillLoad() {
1092
- const { el } = this;
1093
- const popoverId = overlays.setOverlayId(el);
1094
- this.parentPopover = el.closest(`ion-popover:not(#${popoverId})`);
1095
- if (this.alignment === undefined) {
1096
- this.alignment = ionicGlobal.getIonMode(this) === 'ios' ? 'center' : 'start';
1080
+ connectedCallback() {
1081
+ const { configureTriggerInteraction, el } = this;
1082
+ overlays.prepareOverlay(el);
1083
+ configureTriggerInteraction();
1097
1084
  }
1098
- }
1099
- componentDidLoad() {
1100
- const { parentPopover, isOpen } = this;
1101
- /**
1102
- * If popover was rendered with isOpen="true"
1103
- * then we should open popover immediately.
1104
- */
1105
- if (isOpen === true) {
1106
- helpers.raf(() => this.present());
1085
+ disconnectedCallback() {
1086
+ const { destroyTriggerInteraction } = this;
1087
+ if (destroyTriggerInteraction) {
1088
+ destroyTriggerInteraction();
1089
+ }
1090
+ }
1091
+ componentWillLoad() {
1092
+ const { el } = this;
1093
+ const popoverId = overlays.setOverlayId(el);
1094
+ this.parentPopover = el.closest(`ion-popover:not(#${popoverId})`);
1095
+ if (this.alignment === undefined) {
1096
+ this.alignment = ionicGlobal.getIonMode(this) === 'ios' ? 'center' : 'start';
1097
+ }
1107
1098
  }
1108
- if (parentPopover) {
1109
- helpers.addEventListener(parentPopover, 'ionPopoverWillDismiss', () => {
1110
- this.dismiss(undefined, undefined, false);
1111
- });
1099
+ componentDidLoad() {
1100
+ const { parentPopover, isOpen } = this;
1101
+ /**
1102
+ * If popover was rendered with isOpen="true"
1103
+ * then we should open popover immediately.
1104
+ */
1105
+ if (isOpen === true) {
1106
+ helpers.raf(() => this.present());
1107
+ }
1108
+ if (parentPopover) {
1109
+ helpers.addEventListener(parentPopover, 'ionPopoverWillDismiss', () => {
1110
+ this.dismiss(undefined, undefined, false);
1111
+ });
1112
+ }
1113
+ /**
1114
+ * When binding values in frameworks such as Angular
1115
+ * it is possible for the value to be set after the Web Component
1116
+ * initializes but before the value watcher is set up in Stencil.
1117
+ * As a result, the watcher callback may not be fired.
1118
+ * We work around this by manually calling the watcher
1119
+ * callback when the component has loaded and the watcher
1120
+ * is configured.
1121
+ */
1122
+ this.configureTriggerInteraction();
1112
1123
  }
1113
- }
1114
- /**
1115
- * When opening a popover from a trigger, we should not be
1116
- * modifying the `event` prop from inside the component.
1117
- * Additionally, when pressing the "Right" arrow key, we need
1118
- * to shift focus to the first descendant in the newly presented
1119
- * popover.
1120
- *
1121
- * @internal
1122
- */
1123
- async presentFromTrigger(event, focusDescendant = false) {
1124
- this.focusDescendantOnPresent = focusDescendant;
1125
- await this.present(event);
1126
- this.focusDescendantOnPresent = false;
1127
- }
1128
- /**
1129
- * Determines whether or not an overlay
1130
- * is being used inline or via a controller/JS
1131
- * and returns the correct delegate.
1132
- * By default, subsequent calls to getDelegate
1133
- * will use a cached version of the delegate.
1134
- * This is useful for calling dismiss after
1135
- * present so that the correct delegate is given.
1136
- */
1137
- getDelegate(force = false) {
1138
- if (this.workingDelegate && !force) {
1139
- return {
1140
- delegate: this.workingDelegate,
1141
- inline: this.inline,
1142
- };
1124
+ /**
1125
+ * When opening a popover from a trigger, we should not be
1126
+ * modifying the `event` prop from inside the component.
1127
+ * Additionally, when pressing the "Right" arrow key, we need
1128
+ * to shift focus to the first descendant in the newly presented
1129
+ * popover.
1130
+ *
1131
+ * @internal
1132
+ */
1133
+ async presentFromTrigger(event, focusDescendant = false) {
1134
+ this.focusDescendantOnPresent = focusDescendant;
1135
+ await this.present(event);
1136
+ this.focusDescendantOnPresent = false;
1143
1137
  }
1144
1138
  /**
1145
- * If using overlay inline
1146
- * we potentially need to use the coreDelegate
1147
- * so that this works in vanilla JS apps.
1148
- * If a developer has presented this component
1149
- * via a controller, then we can assume
1150
- * the component is already in the
1151
- * correct place.
1139
+ * Determines whether or not an overlay
1140
+ * is being used inline or via a controller/JS
1141
+ * and returns the correct delegate.
1142
+ * By default, subsequent calls to getDelegate
1143
+ * will use a cached version of the delegate.
1144
+ * This is useful for calling dismiss after
1145
+ * present so that the correct delegate is given.
1152
1146
  */
1153
- const parentEl = this.el.parentNode;
1154
- const inline = (this.inline = parentEl !== null && !this.hasController);
1155
- const delegate = (this.workingDelegate = inline ? this.delegate || this.coreDelegate : this.delegate);
1156
- return { inline, delegate };
1157
- }
1158
- /**
1159
- * Present the popover overlay after it has been created.
1160
- * Developers can pass a mouse, touch, or pointer event
1161
- * to position the popover relative to where that event
1162
- * was dispatched.
1163
- */
1164
- async present(event) {
1165
- const unlock = await this.lockController.lock();
1166
- if (this.presented) {
1167
- unlock();
1168
- return;
1147
+ getDelegate(force = false) {
1148
+ if (this.workingDelegate && !force) {
1149
+ return {
1150
+ delegate: this.workingDelegate,
1151
+ inline: this.inline,
1152
+ };
1153
+ }
1154
+ /**
1155
+ * If using overlay inline
1156
+ * we potentially need to use the coreDelegate
1157
+ * so that this works in vanilla JS apps.
1158
+ * If a developer has presented this component
1159
+ * via a controller, then we can assume
1160
+ * the component is already in the
1161
+ * correct place.
1162
+ */
1163
+ const parentEl = this.el.parentNode;
1164
+ const inline = (this.inline = parentEl !== null && !this.hasController);
1165
+ const delegate = (this.workingDelegate = inline ? this.delegate || this.coreDelegate : this.delegate);
1166
+ return { inline, delegate };
1169
1167
  }
1170
- const { el } = this;
1171
- const { inline, delegate } = this.getDelegate(true);
1172
1168
  /**
1173
- * Emit ionMount so JS Frameworks have an opportunity
1174
- * to add the child component to the DOM. The child
1175
- * component will be assigned to this.usersElement below.
1169
+ * Present the popover overlay after it has been created.
1170
+ * Developers can pass a mouse, touch, or pointer event
1171
+ * to position the popover relative to where that event
1172
+ * was dispatched.
1176
1173
  */
1177
- this.ionMount.emit();
1178
- this.usersElement = await frameworkDelegate.attachComponent(delegate, el, this.component, ['popover-viewport'], this.componentProps, inline);
1179
- if (!this.keyboardEvents) {
1180
- this.configureKeyboardInteraction();
1174
+ async present(event) {
1175
+ const unlock = await this.lockController.lock();
1176
+ if (this.presented) {
1177
+ unlock();
1178
+ return;
1179
+ }
1180
+ const { el } = this;
1181
+ const { inline, delegate } = this.getDelegate(true);
1182
+ /**
1183
+ * Emit ionMount so JS Frameworks have an opportunity
1184
+ * to add the child component to the DOM. The child
1185
+ * component will be assigned to this.usersElement below.
1186
+ */
1187
+ this.ionMount.emit();
1188
+ this.usersElement = await frameworkDelegate.attachComponent(delegate, el, this.component, ['popover-viewport'], this.componentProps, inline);
1189
+ if (!this.keyboardEvents) {
1190
+ this.configureKeyboardInteraction();
1191
+ }
1192
+ this.configureDismissInteraction();
1193
+ /**
1194
+ * When using the lazy loaded build of Stencil, we need to wait
1195
+ * for every Stencil component instance to be ready before presenting
1196
+ * otherwise there can be a flash of unstyled content. With the
1197
+ * custom elements bundle we need to wait for the JS framework
1198
+ * mount the inner contents of the overlay otherwise WebKit may
1199
+ * get the transition incorrect.
1200
+ */
1201
+ if (helpers.hasLazyBuild(el)) {
1202
+ await index$2.deepReady(this.usersElement);
1203
+ /**
1204
+ * If keepContentsMounted="true" then the
1205
+ * JS Framework has already mounted the inner
1206
+ * contents so there is no need to wait.
1207
+ * Otherwise, we need to wait for the JS
1208
+ * Framework to mount the inner contents
1209
+ * of this component.
1210
+ */
1211
+ }
1212
+ else if (!this.keepContentsMounted) {
1213
+ await index$2.waitForMount();
1214
+ }
1215
+ await overlays.present(this, 'popoverEnter', iosEnterAnimation, mdEnterAnimation, {
1216
+ event: event || this.event,
1217
+ size: this.size,
1218
+ trigger: this.triggerEl,
1219
+ reference: this.reference,
1220
+ side: this.side,
1221
+ align: this.alignment,
1222
+ });
1223
+ /**
1224
+ * If popover is nested and was
1225
+ * presented using the "Right" arrow key,
1226
+ * we need to move focus to the first
1227
+ * descendant inside of the popover.
1228
+ */
1229
+ if (this.focusDescendantOnPresent) {
1230
+ overlays.focusFirstDescendant(this.el, this.el);
1231
+ }
1232
+ unlock();
1181
1233
  }
1182
- this.configureDismissInteraction();
1183
1234
  /**
1184
- * When using the lazy loaded build of Stencil, we need to wait
1185
- * for every Stencil component instance to be ready before presenting
1186
- * otherwise there can be a flash of unstyled content. With the
1187
- * custom elements bundle we need to wait for the JS framework
1188
- * mount the inner contents of the overlay otherwise WebKit may
1189
- * get the transition incorrect.
1235
+ * Dismiss the popover overlay after it has been presented.
1236
+ *
1237
+ * @param data Any data to emit in the dismiss events.
1238
+ * @param role The role of the element that is dismissing the popover. For example, 'cancel' or 'backdrop'.
1239
+ * @param dismissParentPopover If `true`, dismissing this popover will also dismiss
1240
+ * a parent popover if this popover is nested. Defaults to `true`.
1190
1241
  */
1191
- if (helpers.hasLazyBuild(el)) {
1192
- await index$2.deepReady(this.usersElement);
1193
- /**
1194
- * If keepContentsMounted="true" then the
1195
- * JS Framework has already mounted the inner
1196
- * contents so there is no need to wait.
1197
- * Otherwise, we need to wait for the JS
1198
- * Framework to mount the inner contents
1199
- * of this component.
1200
- */
1242
+ async dismiss(data, role, dismissParentPopover = true) {
1243
+ const unlock = await this.lockController.lock();
1244
+ const { destroyKeyboardInteraction, destroyDismissInteraction } = this;
1245
+ if (dismissParentPopover && this.parentPopover) {
1246
+ this.parentPopover.dismiss(data, role, dismissParentPopover);
1247
+ }
1248
+ const shouldDismiss = await overlays.dismiss(this, data, role, 'popoverLeave', iosLeaveAnimation, mdLeaveAnimation, this.event);
1249
+ if (shouldDismiss) {
1250
+ if (destroyKeyboardInteraction) {
1251
+ destroyKeyboardInteraction();
1252
+ this.destroyKeyboardInteraction = undefined;
1253
+ }
1254
+ if (destroyDismissInteraction) {
1255
+ destroyDismissInteraction();
1256
+ this.destroyDismissInteraction = undefined;
1257
+ }
1258
+ /**
1259
+ * If using popover inline
1260
+ * we potentially need to use the coreDelegate
1261
+ * so that this works in vanilla JS apps
1262
+ */
1263
+ const { delegate } = this.getDelegate();
1264
+ await frameworkDelegate.detachComponent(delegate, this.usersElement);
1265
+ }
1266
+ unlock();
1267
+ return shouldDismiss;
1201
1268
  }
1202
- else if (!this.keepContentsMounted) {
1203
- await index$2.waitForMount();
1269
+ /**
1270
+ * @internal
1271
+ */
1272
+ async getParentPopover() {
1273
+ return this.parentPopover;
1204
1274
  }
1205
- await overlays.present(this, 'popoverEnter', iosEnterAnimation, mdEnterAnimation, {
1206
- event: event || this.event,
1207
- size: this.size,
1208
- trigger: this.triggerEl,
1209
- reference: this.reference,
1210
- side: this.side,
1211
- align: this.alignment,
1212
- });
1213
1275
  /**
1214
- * If popover is nested and was
1215
- * presented using the "Right" arrow key,
1216
- * we need to move focus to the first
1217
- * descendant inside of the popover.
1276
+ * Returns a promise that resolves when the popover did dismiss.
1218
1277
  */
1219
- if (this.focusDescendantOnPresent) {
1220
- overlays.focusFirstDescendant(this.el, this.el);
1278
+ onDidDismiss() {
1279
+ return overlays.eventMethod(this.el, 'ionPopoverDidDismiss');
1221
1280
  }
1222
- unlock();
1223
- }
1224
- /**
1225
- * Dismiss the popover overlay after it has been presented.
1226
- *
1227
- * @param data Any data to emit in the dismiss events.
1228
- * @param role The role of the element that is dismissing the popover. For example, 'cancel' or 'backdrop'.
1229
- * @param dismissParentPopover If `true`, dismissing this popover will also dismiss
1230
- * a parent popover if this popover is nested. Defaults to `true`.
1231
- */
1232
- async dismiss(data, role, dismissParentPopover = true) {
1233
- const unlock = await this.lockController.lock();
1234
- const { destroyKeyboardInteraction, destroyDismissInteraction } = this;
1235
- if (dismissParentPopover && this.parentPopover) {
1236
- this.parentPopover.dismiss(data, role, dismissParentPopover);
1281
+ /**
1282
+ * Returns a promise that resolves when the popover will dismiss.
1283
+ */
1284
+ onWillDismiss() {
1285
+ return overlays.eventMethod(this.el, 'ionPopoverWillDismiss');
1237
1286
  }
1238
- const shouldDismiss = await overlays.dismiss(this, data, role, 'popoverLeave', iosLeaveAnimation, mdLeaveAnimation, this.event);
1239
- if (shouldDismiss) {
1240
- if (destroyKeyboardInteraction) {
1241
- destroyKeyboardInteraction();
1242
- this.destroyKeyboardInteraction = undefined;
1243
- }
1244
- if (destroyDismissInteraction) {
1245
- destroyDismissInteraction();
1246
- this.destroyDismissInteraction = undefined;
1247
- }
1248
- /**
1249
- * If using popover inline
1250
- * we potentially need to use the coreDelegate
1251
- * so that this works in vanilla JS apps
1252
- */
1253
- const { delegate } = this.getDelegate();
1254
- await frameworkDelegate.detachComponent(delegate, this.usersElement);
1287
+ render() {
1288
+ const mode = ionicGlobal.getIonMode(this);
1289
+ const { onLifecycle, parentPopover, dismissOnSelect, side, arrow, htmlAttributes } = this;
1290
+ const desktop = ionicGlobal.isPlatform('desktop');
1291
+ const enableArrow = arrow && !parentPopover;
1292
+ return (index.h(index.Host, Object.assign({ "aria-modal": "true", "no-router": true, tabindex: "-1" }, htmlAttributes, { style: {
1293
+ zIndex: `${20000 + this.overlayIndex}`,
1294
+ }, class: Object.assign(Object.assign({}, theme.getClassMap(this.cssClass)), { [mode]: true, 'popover-translucent': this.translucent, 'overlay-hidden': true, 'popover-desktop': desktop, [`popover-side-${side}`]: true, 'popover-nested': !!parentPopover }), onIonPopoverDidPresent: onLifecycle, onIonPopoverWillPresent: onLifecycle, onIonPopoverWillDismiss: onLifecycle, onIonPopoverDidDismiss: onLifecycle, onIonBackdropTap: this.onBackdropTap }), !parentPopover && index.h("ion-backdrop", { tappable: this.backdropDismiss, visible: this.showBackdrop, part: "backdrop" }), index.h("div", { class: "popover-wrapper ion-overlay-wrapper", onClick: dismissOnSelect ? () => this.dismiss() : undefined }, enableArrow && index.h("div", { class: "popover-arrow", part: "arrow" }), index.h("div", { class: "popover-content", part: "content" }, index.h("slot", null)))));
1255
1295
  }
1256
- unlock();
1257
- return shouldDismiss;
1258
- }
1259
- /**
1260
- * @internal
1261
- */
1262
- async getParentPopover() {
1263
- return this.parentPopover;
1264
- }
1265
- /**
1266
- * Returns a promise that resolves when the popover did dismiss.
1267
- */
1268
- onDidDismiss() {
1269
- return overlays.eventMethod(this.el, 'ionPopoverDidDismiss');
1270
- }
1271
- /**
1272
- * Returns a promise that resolves when the popover will dismiss.
1273
- */
1274
- onWillDismiss() {
1275
- return overlays.eventMethod(this.el, 'ionPopoverWillDismiss');
1276
- }
1277
- render() {
1278
- const mode = ionicGlobal.getIonMode(this);
1279
- const { onLifecycle, parentPopover, dismissOnSelect, side, arrow, htmlAttributes } = this;
1280
- const desktop = ionicGlobal.isPlatform('desktop');
1281
- const enableArrow = arrow && !parentPopover;
1282
- return (index.h(index.Host, Object.assign({ "aria-modal": "true", "no-router": true, tabindex: "-1" }, htmlAttributes, { style: {
1283
- zIndex: `${20000 + this.overlayIndex}`,
1284
- }, class: Object.assign(Object.assign({}, theme.getClassMap(this.cssClass)), { [mode]: true, 'popover-translucent': this.translucent, 'overlay-hidden': true, 'popover-desktop': desktop, [`popover-side-${side}`]: true, 'popover-nested': !!parentPopover }), onIonPopoverDidPresent: onLifecycle, onIonPopoverWillPresent: onLifecycle, onIonPopoverWillDismiss: onLifecycle, onIonPopoverDidDismiss: onLifecycle, onIonBackdropTap: this.onBackdropTap }), !parentPopover && index.h("ion-backdrop", { tappable: this.backdropDismiss, visible: this.showBackdrop, part: "backdrop" }), index.h("div", { class: "popover-wrapper ion-overlay-wrapper", onClick: dismissOnSelect ? () => this.dismiss() : undefined }, enableArrow && index.h("div", { class: "popover-arrow", part: "arrow" }), index.h("div", { class: "popover-content", part: "content" }, index.h("slot", null)))));
1285
- }
1286
- get el() { return index.getElement(this); }
1287
- static get watchers() { return {
1288
- "trigger": ["onTriggerChange"],
1289
- "triggerAction": ["onTriggerChange"],
1290
- "isOpen": ["onIsOpenChange"]
1291
- }; }
1296
+ get el() { return index.getElement(this); }
1297
+ static get watchers() { return {
1298
+ "trigger": ["onTriggerChange"],
1299
+ "triggerAction": ["onTriggerChange"],
1300
+ "isOpen": ["onIsOpenChange"]
1301
+ }; }
1292
1302
  };
1293
1303
  const LIFECYCLE_MAP = {
1294
- ionPopoverDidPresent: 'ionViewDidEnter',
1295
- ionPopoverWillPresent: 'ionViewWillEnter',
1296
- ionPopoverWillDismiss: 'ionViewWillLeave',
1297
- ionPopoverDidDismiss: 'ionViewDidLeave',
1304
+ ionPopoverDidPresent: 'ionViewDidEnter',
1305
+ ionPopoverWillPresent: 'ionViewWillEnter',
1306
+ ionPopoverWillDismiss: 'ionViewWillLeave',
1307
+ ionPopoverDidDismiss: 'ionViewDidLeave',
1298
1308
  };
1299
1309
  Popover.style = {
1300
- ios: popoverIosCss,
1301
- md: popoverMdCss
1310
+ ios: popoverIosCss,
1311
+ md: popoverMdCss
1302
1312
  };
1303
1313
 
1304
1314
  exports.ion_popover = Popover;