voyager-ionic-core 8.0.1 → 8.1.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 (554) hide show
  1. package/components/checkbox.js +3 -3
  2. package/components/index2.js +119 -1
  3. package/components/ion-accordion-group.js +2 -2
  4. package/components/ion-content.js +6 -4
  5. package/components/ion-datetime-button.js +2 -2
  6. package/components/ion-datetime.js +17 -14
  7. package/components/ion-fab-button.js +2 -2
  8. package/components/ion-fab-list.js +2 -2
  9. package/components/ion-fab.js +2 -2
  10. package/components/ion-footer.js +2 -2
  11. package/components/ion-grid.js +2 -2
  12. package/components/ion-header.js +2 -2
  13. package/components/ion-img.js +1 -1
  14. package/components/ion-infinite-scroll-content.js +2 -2
  15. package/components/ion-infinite-scroll.js +1 -1
  16. package/components/ion-input-password-toggle.js +3 -3
  17. package/components/ion-input.js +8 -4
  18. package/components/ion-item-divider.js +2 -2
  19. package/components/ion-item-group.js +1 -1
  20. package/components/ion-item-option.js +2 -2
  21. package/components/ion-item-options.js +1 -1
  22. package/components/ion-item-sliding.js +1 -1
  23. package/components/ion-loading.js +2 -2
  24. package/components/ion-menu-button.js +2 -2
  25. package/components/ion-menu-toggle.js +2 -2
  26. package/components/ion-menu.js +2 -2
  27. package/components/ion-modal.js +10 -8
  28. package/components/ion-nav-link.js +1 -1
  29. package/components/ion-nav.js +1 -1
  30. package/components/ion-note.js +2 -2
  31. package/components/ion-picker-legacy.js +2 -2
  32. package/components/ion-progress-bar.js +1 -1
  33. package/components/ion-range.js +3 -3
  34. package/components/ion-refresher-content.js +1 -1
  35. package/components/ion-refresher.js +1 -1
  36. package/components/ion-reorder-group.js +1 -1
  37. package/components/ion-reorder.js +1 -1
  38. package/components/ion-router-link.js +2 -2
  39. package/components/ion-router-outlet.js +1 -1
  40. package/components/ion-row.js +1 -1
  41. package/components/ion-searchbar.js +4 -4
  42. package/components/ion-segment-button.js +3 -3
  43. package/components/ion-segment.js +2 -2
  44. package/components/ion-select-option.js +1 -1
  45. package/components/ion-select.js +2 -2
  46. package/components/ion-skeleton-text.js +2 -2
  47. package/components/ion-split-pane.js +2 -2
  48. package/components/ion-tab-bar.js +2 -2
  49. package/components/ion-tab-button.js +2 -2
  50. package/components/ion-tab.js +2 -2
  51. package/components/ion-tabs.js +1 -1
  52. package/components/ion-text.js +2 -2
  53. package/components/ion-textarea.js +2 -2
  54. package/components/ion-thumbnail.js +1 -1
  55. package/components/ion-title.js +2 -2
  56. package/components/ion-toast.js +2 -2
  57. package/components/ion-toggle.js +3 -3
  58. package/components/ion-toolbar.js +2 -2
  59. package/components/ios.transition.js +94 -67
  60. package/components/label.js +3 -3
  61. package/components/list-header.js +2 -2
  62. package/components/list.js +1 -1
  63. package/components/overlays.js +3 -2
  64. package/components/picker-column-option.js +2 -2
  65. package/components/picker-column.js +156 -4
  66. package/components/picker-column2.js +2 -2
  67. package/components/picker.js +2 -2
  68. package/components/popover.js +6 -4
  69. package/components/radio-group.js +1 -1
  70. package/components/radio.js +3 -3
  71. package/components/ripple-effect.js +1 -1
  72. package/components/select-popover.js +2 -2
  73. package/components/spinner.js +1 -1
  74. package/css/core.css +1 -1
  75. package/css/core.css.map +1 -1
  76. package/css/global.bundle.css.map +1 -1
  77. package/css/ionic.bundle.css +1 -1
  78. package/css/ionic.bundle.css.map +1 -1
  79. package/css/palettes/dark.always.css +1 -1
  80. package/css/palettes/dark.always.css.map +1 -1
  81. package/css/palettes/dark.class.css +1 -1
  82. package/css/palettes/dark.class.css.map +1 -1
  83. package/css/palettes/dark.system.css +1 -1
  84. package/css/palettes/dark.system.css.map +1 -1
  85. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  86. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  87. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  88. package/css/palettes/high-contrast.always.css.map +1 -1
  89. package/css/palettes/high-contrast.class.css.map +1 -1
  90. package/css/palettes/high-contrast.system.css.map +1 -1
  91. package/css/typography.css.map +1 -1
  92. package/dist/cjs/{app-globals-542c4d91.js → app-globals-66b7dc06.js} +1 -1
  93. package/dist/cjs/{button-active-47528f4c.js → button-active-9135c809.js} +1 -1
  94. package/dist/cjs/{hardware-back-button-06ae4d9c.js → hardware-back-button-ed931127.js} +2 -2
  95. package/dist/cjs/index-8709af32.js +2234 -0
  96. package/dist/cjs/{index-c76a1d14.js → index-c0b7f8f4.js} +124 -6
  97. package/dist/cjs/{index-57b504ac.js → index-c54654c6.js} +2 -2
  98. package/dist/cjs/index.cjs.js +9 -9
  99. package/dist/cjs/ion-accordion_2.cjs.entry.js +4 -4
  100. package/dist/cjs/ion-action-sheet.cjs.entry.js +5 -5
  101. package/dist/cjs/ion-alert.cjs.entry.js +5 -5
  102. package/dist/cjs/ion-app_8.cjs.entry.js +20 -19
  103. package/dist/cjs/ion-avatar_3.cjs.entry.js +3 -3
  104. package/dist/cjs/ion-back-button.cjs.entry.js +2 -2
  105. package/dist/cjs/ion-backdrop.cjs.entry.js +2 -2
  106. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +2 -2
  107. package/dist/cjs/ion-button_2.cjs.entry.js +2 -2
  108. package/dist/cjs/ion-card_5.cjs.entry.js +2 -2
  109. package/dist/cjs/ion-checkbox.cjs.entry.js +5 -5
  110. package/dist/cjs/ion-chip.cjs.entry.js +2 -2
  111. package/dist/cjs/ion-col_3.cjs.entry.js +5 -5
  112. package/dist/cjs/ion-datetime-button.cjs.entry.js +4 -4
  113. package/dist/cjs/ion-datetime_3.cjs.entry.js +25 -22
  114. package/dist/cjs/ion-fab_3.cjs.entry.js +8 -8
  115. package/dist/cjs/ion-img.cjs.entry.js +3 -3
  116. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +5 -5
  117. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +5 -5
  118. package/dist/cjs/ion-input.cjs.entry.js +9 -6
  119. package/dist/cjs/ion-item-option_3.cjs.entry.js +6 -6
  120. package/dist/cjs/ion-item_8.cjs.entry.js +15 -15
  121. package/dist/cjs/ion-loading.cjs.entry.js +6 -6
  122. package/dist/cjs/ion-menu_3.cjs.entry.js +11 -11
  123. package/dist/cjs/ion-modal.cjs.entry.js +13 -12
  124. package/dist/cjs/ion-nav_2.cjs.entry.js +6 -5
  125. package/dist/cjs/ion-picker-column-option.cjs.entry.js +4 -4
  126. package/dist/cjs/ion-picker-column.cjs.entry.js +156 -6
  127. package/dist/cjs/ion-picker.cjs.entry.js +3 -3
  128. package/dist/cjs/ion-popover.cjs.entry.js +9 -8
  129. package/dist/cjs/ion-progress-bar.cjs.entry.js +3 -3
  130. package/dist/cjs/ion-radio_2.cjs.entry.js +6 -6
  131. package/dist/cjs/ion-range.cjs.entry.js +5 -5
  132. package/dist/cjs/ion-refresher_2.cjs.entry.js +4 -4
  133. package/dist/cjs/ion-reorder_2.cjs.entry.js +4 -4
  134. package/dist/cjs/ion-ripple-effect.cjs.entry.js +3 -3
  135. package/dist/cjs/ion-route_4.cjs.entry.js +4 -4
  136. package/dist/cjs/ion-searchbar.cjs.entry.js +6 -6
  137. package/dist/cjs/ion-segment_2.cjs.entry.js +7 -7
  138. package/dist/cjs/ion-select_3.cjs.entry.js +9 -9
  139. package/dist/cjs/ion-spinner.cjs.entry.js +3 -3
  140. package/dist/cjs/ion-split-pane.cjs.entry.js +4 -4
  141. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +6 -6
  142. package/dist/cjs/ion-tab_2.cjs.entry.js +4 -4
  143. package/dist/cjs/ion-text.cjs.entry.js +4 -4
  144. package/dist/cjs/ion-textarea.cjs.entry.js +4 -4
  145. package/dist/cjs/ion-toast.cjs.entry.js +6 -6
  146. package/dist/cjs/ion-toggle.cjs.entry.js +5 -5
  147. package/dist/cjs/{ionic-global-f3622afe.js → ionic-global-35b86a09.js} +1 -1
  148. package/dist/cjs/ionic.cjs.js +5 -5
  149. package/dist/cjs/{ios.transition-288dfa83.js → ios.transition-5ddf92f1.js} +98 -69
  150. package/dist/cjs/loader.cjs.js +4 -4
  151. package/dist/cjs/{md.transition-6e5f6a8d.js → md.transition-047c18c5.js} +4 -2
  152. package/dist/cjs/{overlays-32cfd236.js → overlays-cb04d075.js} +5 -3
  153. package/dist/cjs/{status-tap-c47ff5f5.js → status-tap-5b2775cd.js} +1 -1
  154. package/dist/collection/collection-manifest.json +1 -1
  155. package/dist/collection/components/accordion-group/accordion-group.js +3 -3
  156. package/dist/collection/components/checkbox/checkbox.js +4 -4
  157. package/dist/collection/components/content/content.js +23 -4
  158. package/dist/collection/components/content/test/content.spec.js +27 -0
  159. package/dist/collection/components/datetime/datetime.js +18 -15
  160. package/dist/collection/components/datetime/test/overlay-roles/datetime.e2e.js +34 -0
  161. package/dist/collection/components/datetime-button/datetime-button.js +2 -2
  162. package/dist/collection/components/fab/fab.js +2 -2
  163. package/dist/collection/components/fab-button/fab-button.js +2 -2
  164. package/dist/collection/components/fab-list/fab-list.js +2 -2
  165. package/dist/collection/components/footer/footer.js +2 -2
  166. package/dist/collection/components/grid/grid.js +2 -2
  167. package/dist/collection/components/header/header.js +2 -2
  168. package/dist/collection/components/img/img.js +1 -1
  169. package/dist/collection/components/infinite-scroll/infinite-scroll.js +1 -1
  170. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +2 -2
  171. package/dist/collection/components/input/input.js +25 -5
  172. package/dist/collection/components/input/test/input.spec.js +13 -0
  173. package/dist/collection/components/input-password-toggle/input-password-toggle.js +3 -3
  174. package/dist/collection/components/item/test/a11y/item.e2e.js +24 -4
  175. package/dist/collection/components/item-divider/item-divider.js +2 -2
  176. package/dist/collection/components/item-group/item-group.js +1 -1
  177. package/dist/collection/components/item-option/item-option.js +2 -2
  178. package/dist/collection/components/item-options/item-options.js +1 -1
  179. package/dist/collection/components/item-sliding/item-sliding.js +1 -1
  180. package/dist/collection/components/label/label.ios.css +1 -1
  181. package/dist/collection/components/label/label.js +2 -2
  182. package/dist/collection/components/list/list.js +1 -1
  183. package/dist/collection/components/list-header/list-header.js +2 -2
  184. package/dist/collection/components/loading/loading.js +2 -2
  185. package/dist/collection/components/menu/menu.js +2 -2
  186. package/dist/collection/components/menu-button/menu-button.js +2 -2
  187. package/dist/collection/components/menu-toggle/menu-toggle.js +2 -2
  188. package/dist/collection/components/modal/gestures/sheet.js +3 -2
  189. package/dist/collection/components/modal/modal.js +25 -6
  190. package/dist/collection/components/modal/test/basic/modal.spec.js +19 -0
  191. package/dist/collection/components/nav/nav.js +1 -1
  192. package/dist/collection/components/nav-link/nav-link.js +1 -1
  193. package/dist/collection/components/note/note.js +2 -2
  194. package/dist/collection/components/picker/picker.js +2 -2
  195. package/dist/collection/components/picker-column/picker-column.css +19 -0
  196. package/dist/collection/components/picker-column/picker-column.js +159 -4
  197. package/dist/collection/components/picker-column/test/picker-column.spec.js +83 -0
  198. package/dist/collection/components/picker-column-option/picker-column-option.js +2 -2
  199. package/dist/collection/components/picker-legacy/picker.js +2 -2
  200. package/dist/collection/components/picker-legacy-column/picker-column.js +2 -2
  201. package/dist/collection/components/popover/popover.js +23 -4
  202. package/dist/collection/components/popover/test/basic/popover.spec.js +19 -0
  203. package/dist/collection/components/progress-bar/progress-bar.js +1 -1
  204. package/dist/collection/components/radio/radio.js +3 -3
  205. package/dist/collection/components/radio-group/radio-group.js +2 -2
  206. package/dist/collection/components/range/range.js +4 -4
  207. package/dist/collection/components/refresher/refresher.js +1 -1
  208. package/dist/collection/components/refresher-content/refresher-content.js +1 -1
  209. package/dist/collection/components/reorder/reorder.js +1 -1
  210. package/dist/collection/components/reorder-group/reorder-group.js +1 -1
  211. package/dist/collection/components/ripple-effect/ripple-effect.js +1 -1
  212. package/dist/collection/components/router-link/router-link.js +2 -2
  213. package/dist/collection/components/router-outlet/router-outlet.js +1 -1
  214. package/dist/collection/components/row/row.js +1 -1
  215. package/dist/collection/components/searchbar/searchbar.js +5 -5
  216. package/dist/collection/components/segment/segment.js +3 -3
  217. package/dist/collection/components/segment-button/segment-button.js +3 -3
  218. package/dist/collection/components/select/select.js +3 -3
  219. package/dist/collection/components/select/test/fill/select.e2e.js +25 -0
  220. package/dist/collection/components/select-option/select-option.js +1 -1
  221. package/dist/collection/components/select-popover/select-popover.js +1 -1
  222. package/dist/collection/components/select-popover/select-popover.md.css +8 -1
  223. package/dist/collection/components/skeleton-text/skeleton-text.js +2 -2
  224. package/dist/collection/components/spinner/spinner.js +1 -1
  225. package/dist/collection/components/split-pane/split-pane.js +2 -2
  226. package/dist/collection/components/tab/tab.js +2 -2
  227. package/dist/collection/components/tab-bar/tab-bar.js +2 -2
  228. package/dist/collection/components/tab-button/tab-button.js +2 -2
  229. package/dist/collection/components/tabs/tabs.js +1 -1
  230. package/dist/collection/components/text/text.js +2 -2
  231. package/dist/collection/components/textarea/textarea.js +3 -3
  232. package/dist/collection/components/thumbnail/thumbnail.js +1 -1
  233. package/dist/collection/components/title/title.js +2 -2
  234. package/dist/collection/components/toast/toast.js +2 -2
  235. package/dist/collection/components/toggle/toggle.js +4 -4
  236. package/dist/collection/components/toolbar/toolbar.js +2 -2
  237. package/dist/collection/utils/focus-controller/index.js +112 -0
  238. package/dist/collection/utils/focus-controller/test/generic/focus-controller.e2e.js +52 -0
  239. package/dist/collection/utils/focus-controller/test/ionic/focus-controller.e2e.js +52 -0
  240. package/dist/collection/utils/overlays.js +2 -1
  241. package/dist/collection/utils/transition/index.js +11 -1
  242. package/dist/collection/utils/transition/ios.transition.js +94 -67
  243. package/dist/docs.json +109 -14
  244. package/dist/esm/{app-globals-3cbaf9d9.js → app-globals-b99e6d29.js} +1 -1
  245. package/dist/esm/{button-active-9e3c1f3b.js → button-active-920addb8.js} +1 -1
  246. package/dist/esm/{hardware-back-button-804f43bb.js → hardware-back-button-2d9760b6.js} +2 -2
  247. package/dist/esm/{index-8dbae644.js → index-7ae7186a.js} +2 -2
  248. package/dist/esm/{index-f7fbe1fb.js → index-8e6b6a24.js} +122 -4
  249. package/dist/esm/index-9aab3bcf.js +2196 -0
  250. package/dist/esm/index.js +9 -9
  251. package/dist/esm/ion-accordion_2.entry.js +4 -4
  252. package/dist/esm/ion-action-sheet.entry.js +5 -5
  253. package/dist/esm/ion-alert.entry.js +5 -5
  254. package/dist/esm/ion-app_8.entry.js +20 -19
  255. package/dist/esm/ion-avatar_3.entry.js +3 -3
  256. package/dist/esm/ion-back-button.entry.js +2 -2
  257. package/dist/esm/ion-backdrop.entry.js +2 -2
  258. package/dist/esm/ion-breadcrumb_2.entry.js +2 -2
  259. package/dist/esm/ion-button_2.entry.js +2 -2
  260. package/dist/esm/ion-card_5.entry.js +2 -2
  261. package/dist/esm/ion-checkbox.entry.js +5 -5
  262. package/dist/esm/ion-chip.entry.js +2 -2
  263. package/dist/esm/ion-col_3.entry.js +5 -5
  264. package/dist/esm/ion-datetime-button.entry.js +4 -4
  265. package/dist/esm/ion-datetime_3.entry.js +25 -22
  266. package/dist/esm/ion-fab_3.entry.js +8 -8
  267. package/dist/esm/ion-img.entry.js +3 -3
  268. package/dist/esm/ion-infinite-scroll_2.entry.js +5 -5
  269. package/dist/esm/ion-input-password-toggle.entry.js +5 -5
  270. package/dist/esm/ion-input.entry.js +9 -6
  271. package/dist/esm/ion-item-option_3.entry.js +6 -6
  272. package/dist/esm/ion-item_8.entry.js +15 -15
  273. package/dist/esm/ion-loading.entry.js +6 -6
  274. package/dist/esm/ion-menu_3.entry.js +11 -11
  275. package/dist/esm/ion-modal.entry.js +13 -12
  276. package/dist/esm/ion-nav_2.entry.js +6 -5
  277. package/dist/esm/ion-picker-column-option.entry.js +4 -4
  278. package/dist/esm/ion-picker-column.entry.js +156 -6
  279. package/dist/esm/ion-picker.entry.js +3 -3
  280. package/dist/esm/ion-popover.entry.js +9 -8
  281. package/dist/esm/ion-progress-bar.entry.js +3 -3
  282. package/dist/esm/ion-radio_2.entry.js +6 -6
  283. package/dist/esm/ion-range.entry.js +5 -5
  284. package/dist/esm/ion-refresher_2.entry.js +4 -4
  285. package/dist/esm/ion-reorder_2.entry.js +4 -4
  286. package/dist/esm/ion-ripple-effect.entry.js +3 -3
  287. package/dist/esm/ion-route_4.entry.js +4 -4
  288. package/dist/esm/ion-searchbar.entry.js +6 -6
  289. package/dist/esm/ion-segment_2.entry.js +7 -7
  290. package/dist/esm/ion-select_3.entry.js +9 -9
  291. package/dist/esm/ion-spinner.entry.js +3 -3
  292. package/dist/esm/ion-split-pane.entry.js +4 -4
  293. package/dist/esm/ion-tab-bar_2.entry.js +6 -6
  294. package/dist/esm/ion-tab_2.entry.js +4 -4
  295. package/dist/esm/ion-text.entry.js +4 -4
  296. package/dist/esm/ion-textarea.entry.js +4 -4
  297. package/dist/esm/ion-toast.entry.js +6 -6
  298. package/dist/esm/ion-toggle.entry.js +5 -5
  299. package/dist/esm/{ionic-global-d2d8f882.js → ionic-global-4528d288.js} +1 -1
  300. package/dist/esm/ionic.js +6 -6
  301. package/dist/esm/{ios.transition-a0041e41.js → ios.transition-e35d0940.js} +98 -69
  302. package/dist/esm/loader.js +5 -5
  303. package/dist/esm/{md.transition-0c0602d9.js → md.transition-4b90a1f0.js} +4 -2
  304. package/dist/esm/{overlays-696d25f5.js → overlays-df2c06b2.js} +5 -4
  305. package/dist/esm/{status-tap-37a74d1c.js → status-tap-12c27922.js} +1 -1
  306. package/dist/esm-es5/app-globals-b99e6d29.js +4 -0
  307. package/dist/esm-es5/{button-active-9e3c1f3b.js → button-active-920addb8.js} +1 -1
  308. package/dist/esm-es5/{hardware-back-button-804f43bb.js → hardware-back-button-2d9760b6.js} +1 -1
  309. package/dist/esm-es5/{index-8dbae644.js → index-7ae7186a.js} +1 -1
  310. package/dist/esm-es5/index-8e6b6a24.js +4 -0
  311. package/dist/esm-es5/index-9aab3bcf.js +5 -0
  312. package/dist/esm-es5/index.js +1 -1
  313. package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
  314. package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
  315. package/dist/esm-es5/ion-alert.entry.js +1 -1
  316. package/dist/esm-es5/ion-app_8.entry.js +1 -1
  317. package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
  318. package/dist/esm-es5/ion-back-button.entry.js +1 -1
  319. package/dist/esm-es5/ion-backdrop.entry.js +1 -1
  320. package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
  321. package/dist/esm-es5/ion-button_2.entry.js +1 -1
  322. package/dist/esm-es5/ion-card_5.entry.js +1 -1
  323. package/dist/esm-es5/ion-checkbox.entry.js +1 -1
  324. package/dist/esm-es5/ion-chip.entry.js +1 -1
  325. package/dist/esm-es5/ion-col_3.entry.js +1 -1
  326. package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
  327. package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
  328. package/dist/esm-es5/ion-fab_3.entry.js +1 -1
  329. package/dist/esm-es5/ion-img.entry.js +1 -1
  330. package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
  331. package/dist/esm-es5/ion-input-password-toggle.entry.js +1 -1
  332. package/dist/esm-es5/ion-input.entry.js +1 -1
  333. package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
  334. package/dist/esm-es5/ion-item_8.entry.js +1 -1
  335. package/dist/esm-es5/ion-loading.entry.js +1 -1
  336. package/dist/esm-es5/ion-menu_3.entry.js +1 -1
  337. package/dist/esm-es5/ion-modal.entry.js +1 -1
  338. package/dist/esm-es5/ion-nav_2.entry.js +1 -1
  339. package/dist/esm-es5/ion-picker-column-option.entry.js +1 -1
  340. package/dist/esm-es5/ion-picker-column.entry.js +1 -1
  341. package/dist/esm-es5/ion-picker.entry.js +1 -1
  342. package/dist/esm-es5/ion-popover.entry.js +1 -1
  343. package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
  344. package/dist/esm-es5/ion-radio_2.entry.js +1 -1
  345. package/dist/esm-es5/ion-range.entry.js +1 -1
  346. package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
  347. package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
  348. package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
  349. package/dist/esm-es5/ion-route_4.entry.js +1 -1
  350. package/dist/esm-es5/ion-searchbar.entry.js +1 -1
  351. package/dist/esm-es5/ion-segment_2.entry.js +1 -1
  352. package/dist/esm-es5/ion-select_3.entry.js +1 -1
  353. package/dist/esm-es5/ion-spinner.entry.js +1 -1
  354. package/dist/esm-es5/ion-split-pane.entry.js +1 -1
  355. package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
  356. package/dist/esm-es5/ion-tab_2.entry.js +1 -1
  357. package/dist/esm-es5/ion-text.entry.js +1 -1
  358. package/dist/esm-es5/ion-textarea.entry.js +1 -1
  359. package/dist/esm-es5/ion-toast.entry.js +1 -1
  360. package/dist/esm-es5/ion-toggle.entry.js +1 -1
  361. package/dist/esm-es5/{ionic-global-d2d8f882.js → ionic-global-4528d288.js} +1 -1
  362. package/dist/esm-es5/ionic.js +1 -1
  363. package/dist/esm-es5/ios.transition-e35d0940.js +4 -0
  364. package/dist/esm-es5/loader.js +1 -1
  365. package/dist/esm-es5/md.transition-4b90a1f0.js +4 -0
  366. package/dist/esm-es5/{overlays-696d25f5.js → overlays-df2c06b2.js} +1 -1
  367. package/dist/esm-es5/{status-tap-37a74d1c.js → status-tap-12c27922.js} +1 -1
  368. package/dist/html.html-data.json +24 -0
  369. package/dist/ionic/index.esm.js +1 -1
  370. package/dist/ionic/ionic.esm.js +1 -1
  371. package/dist/ionic/ionic.js +1 -1
  372. package/dist/ionic/{p-94731a92.system.entry.js → p-01a27023.system.entry.js} +1 -1
  373. package/dist/ionic/p-0395be73.entry.js +4 -0
  374. package/dist/ionic/p-03b86a5e.js +4 -0
  375. package/dist/ionic/{p-057b5866.entry.js → p-049d43bd.entry.js} +1 -1
  376. package/dist/ionic/p-0536574e.entry.js +4 -0
  377. package/dist/ionic/{p-e3005be4.system.entry.js → p-08ea3402.system.entry.js} +1 -1
  378. package/dist/ionic/{p-3f5b86b4.entry.js → p-09538818.entry.js} +1 -1
  379. package/dist/ionic/{p-470f73c4.entry.js → p-09b4e9ec.entry.js} +1 -1
  380. package/dist/ionic/{p-aa0ed22b.system.entry.js → p-0a6d801e.system.entry.js} +1 -1
  381. package/dist/ionic/{p-53a3b33c.system.entry.js → p-0b007acc.system.entry.js} +1 -1
  382. package/dist/ionic/{p-b76bcd9e.system.entry.js → p-10feef7e.system.entry.js} +1 -1
  383. package/dist/ionic/p-130299c9.entry.js +4 -0
  384. package/dist/ionic/p-15d1ddba.js +4 -0
  385. package/dist/ionic/{p-c3ca0292.system.entry.js → p-199f826f.system.entry.js} +1 -1
  386. package/dist/ionic/p-1b435d20.entry.js +4 -0
  387. package/dist/ionic/{p-c671b28e.js → p-1cc0b31f.js} +1 -1
  388. package/dist/ionic/{p-c4676693.entry.js → p-1eb63fa4.entry.js} +1 -1
  389. package/dist/ionic/{p-9b31ebfa.entry.js → p-207e11dc.entry.js} +1 -1
  390. package/dist/ionic/p-26bb6bb8.entry.js +4 -0
  391. package/dist/ionic/{p-5d3a8503.system.entry.js → p-279f3bac.system.entry.js} +1 -1
  392. package/dist/ionic/{p-e49099b0.entry.js → p-29de09dd.entry.js} +1 -1
  393. package/dist/ionic/{p-6730a2f1.entry.js → p-2c588aa2.entry.js} +1 -1
  394. package/dist/ionic/p-2ff0e0aa.system.js +4 -0
  395. package/dist/ionic/p-30baae57.system.js +4 -0
  396. package/dist/ionic/{p-806aad8f.system.js → p-31d27232.system.js} +1 -1
  397. package/dist/ionic/p-33e10509.system.js +4 -0
  398. package/dist/ionic/{p-a592f1b8.system.entry.js → p-380efbfa.system.entry.js} +1 -1
  399. package/dist/ionic/p-3c27be4a.entry.js +4 -0
  400. package/dist/ionic/p-3d015cdb.system.js +5 -0
  401. package/dist/ionic/{p-70181008.entry.js → p-3f53a0b1.entry.js} +1 -1
  402. package/dist/ionic/p-433157a4.entry.js +4 -0
  403. package/dist/ionic/{p-fc94e18f.entry.js → p-4824398b.entry.js} +1 -1
  404. package/dist/ionic/p-498eb648.system.entry.js +4 -0
  405. package/dist/ionic/{p-8caca06c.system.entry.js → p-4d8f408d.system.entry.js} +1 -1
  406. package/dist/ionic/{p-4c153abb.entry.js → p-5091f63c.entry.js} +1 -1
  407. package/dist/ionic/{p-42f00e72.system.entry.js → p-509620b8.system.entry.js} +1 -1
  408. package/dist/ionic/{p-d1a8f599.entry.js → p-5109a566.entry.js} +1 -1
  409. package/dist/ionic/{p-7f59064a.entry.js → p-52ce473d.entry.js} +1 -1
  410. package/dist/ionic/{p-33d926c3.entry.js → p-52f53904.entry.js} +1 -1
  411. package/dist/ionic/{p-4e548bd7.system.entry.js → p-55f99a39.system.entry.js} +1 -1
  412. package/dist/ionic/{p-1e4d7975.system.js → p-5734ac17.system.js} +1 -1
  413. package/dist/ionic/{p-2b1e669d.system.entry.js → p-57bc32e2.system.entry.js} +1 -1
  414. package/dist/ionic/{p-d11c336d.js → p-5cc6dcf5.js} +1 -1
  415. package/dist/ionic/p-5dc9f99a.entry.js +4 -0
  416. package/dist/ionic/p-5ec3bb70.system.entry.js +4 -0
  417. package/dist/ionic/{p-ebe0aa6d.entry.js → p-606f069c.entry.js} +1 -1
  418. package/dist/ionic/{p-93e43f42.system.entry.js → p-628967e3.system.entry.js} +1 -1
  419. package/dist/ionic/{p-5fbc2eae.system.entry.js → p-62e44e4a.system.entry.js} +1 -1
  420. package/dist/ionic/p-66ed603b.js +4 -0
  421. package/dist/ionic/{p-a801da4b.system.entry.js → p-670c9f57.system.entry.js} +1 -1
  422. package/dist/ionic/{p-fd392e7f.system.entry.js → p-6a2cf398.system.entry.js} +1 -1
  423. package/dist/ionic/{p-5a3a3373.entry.js → p-6c3666d5.entry.js} +1 -1
  424. package/dist/ionic/{p-1a5227b3.system.entry.js → p-6df12af0.system.entry.js} +1 -1
  425. package/dist/ionic/{p-bd6d9610.entry.js → p-6ec88301.entry.js} +1 -1
  426. package/dist/ionic/p-6f008ad2.js +4 -0
  427. package/dist/ionic/{p-2ab5db0d.system.entry.js → p-700567ab.system.entry.js} +1 -1
  428. package/dist/ionic/p-712d54ae.js +4 -0
  429. package/dist/ionic/{p-94180ecc.entry.js → p-7349de07.entry.js} +1 -1
  430. package/dist/ionic/p-7402fcdf.entry.js +4 -0
  431. package/dist/ionic/{p-5ff497dc.system.entry.js → p-77731f19.system.entry.js} +1 -1
  432. package/dist/ionic/{p-c07e7a5d.entry.js → p-78405458.entry.js} +1 -1
  433. package/dist/ionic/{p-748e6b2b.system.entry.js → p-7d6fd45f.system.entry.js} +1 -1
  434. package/dist/ionic/{p-720927ad.entry.js → p-7eb47906.entry.js} +1 -1
  435. package/dist/ionic/p-80265a58.entry.js +4 -0
  436. package/dist/ionic/{p-8627f783.system.entry.js → p-83d748f8.system.entry.js} +2 -2
  437. package/dist/ionic/p-842c9fca.system.js +4 -0
  438. package/dist/ionic/{p-c7e0b81a.entry.js → p-8a03fbee.entry.js} +1 -1
  439. package/dist/ionic/{p-576786c0.system.entry.js → p-8cb80f83.system.entry.js} +1 -1
  440. package/dist/ionic/{p-cdee3a44.system.entry.js → p-8d14ee8c.system.entry.js} +2 -2
  441. package/dist/ionic/p-90dfc454.system.entry.js +4 -0
  442. package/dist/ionic/{p-819e8479.system.entry.js → p-9213681c.system.entry.js} +1 -1
  443. package/dist/ionic/p-92d7e99d.system.js +4 -0
  444. package/dist/ionic/{p-d6229f05.system.entry.js → p-9664a1a2.system.entry.js} +1 -1
  445. package/dist/ionic/{p-b799a007.entry.js → p-9797f6eb.entry.js} +1 -1
  446. package/dist/ionic/{p-5d4d89e0.system.entry.js → p-9848d7be.system.entry.js} +1 -1
  447. package/dist/ionic/{p-9384565a.entry.js → p-98f6116f.entry.js} +1 -1
  448. package/dist/ionic/{p-c62571da.entry.js → p-99884813.entry.js} +1 -1
  449. package/dist/ionic/{p-48888af6.system.entry.js → p-99ca9787.system.entry.js} +1 -1
  450. package/dist/ionic/{p-45034312.system.entry.js → p-9bfd7cda.system.entry.js} +1 -1
  451. package/dist/ionic/p-9c6dcf78.system.entry.js +4 -0
  452. package/dist/ionic/{p-051d2d23.js → p-9da86308.js} +1 -1
  453. package/dist/ionic/{p-34511b1d.js → p-9ec42be0.js} +1 -1
  454. package/dist/ionic/{p-0d960144.system.entry.js → p-a2e94ade.system.entry.js} +1 -1
  455. package/dist/ionic/{p-1980c728.system.js → p-a39d3482.system.js} +1 -1
  456. package/dist/ionic/p-a488b7ab.system.js +4 -0
  457. package/dist/ionic/{p-5d80b741.entry.js → p-a4ab7449.entry.js} +1 -1
  458. package/dist/ionic/{p-2c3c7cb9.system.entry.js → p-a50f23bf.system.entry.js} +2 -2
  459. package/dist/ionic/{p-80f85095.system.entry.js → p-a76ab3ea.system.entry.js} +1 -1
  460. package/dist/ionic/{p-77ce6034.js → p-a953ef66.js} +1 -1
  461. package/dist/ionic/{p-08c4d048.entry.js → p-aaaaaea1.entry.js} +1 -1
  462. package/dist/ionic/{p-c23627c3.entry.js → p-b02eda30.entry.js} +1 -1
  463. package/dist/ionic/{p-49cdc4f2.entry.js → p-b04c27d8.entry.js} +1 -1
  464. package/dist/ionic/{p-0b12d1ee.system.entry.js → p-b07affd5.system.entry.js} +1 -1
  465. package/dist/ionic/{p-2f308f7f.system.entry.js → p-b28d3ccb.system.entry.js} +2 -2
  466. package/dist/ionic/{p-320cfcab.entry.js → p-b563b6ac.entry.js} +1 -1
  467. package/dist/ionic/p-b62ae60a.system.entry.js +4 -0
  468. package/dist/ionic/p-b9181033.system.entry.js +4 -0
  469. package/dist/ionic/{p-1930d8e7.entry.js → p-ba70039f.entry.js} +1 -1
  470. package/dist/ionic/{p-b571cab1.entry.js → p-bbbe869e.entry.js} +1 -1
  471. package/dist/ionic/{p-283fd4e1.system.entry.js → p-c41435e6.system.entry.js} +1 -1
  472. package/dist/ionic/p-cec8589b.system.js +4 -0
  473. package/dist/ionic/{p-bbbe3138.system.entry.js → p-d69b26d9.system.entry.js} +1 -1
  474. package/dist/ionic/p-d73a16e6.system.entry.js +4 -0
  475. package/dist/ionic/p-dba5cb84.js +5 -0
  476. package/dist/ionic/{p-63265e00.system.entry.js → p-dc0d9ff5.system.entry.js} +2 -2
  477. package/dist/ionic/{p-f5c42f72.entry.js → p-dc1e363a.entry.js} +1 -1
  478. package/dist/ionic/{p-c9ba1908.entry.js → p-df517d1f.entry.js} +1 -1
  479. package/dist/ionic/{p-2a3e98fb.system.entry.js → p-e0a8ffd0.system.entry.js} +1 -1
  480. package/dist/ionic/{p-e9ef13be.system.entry.js → p-e6e197f5.system.entry.js} +1 -1
  481. package/dist/ionic/{p-0af79ebd.entry.js → p-e6e88ab9.entry.js} +1 -1
  482. package/dist/ionic/{p-4e5288de.system.js → p-e81f22e3.system.js} +1 -1
  483. package/dist/ionic/{p-aa0f60b2.system.js → p-eb3023c9.system.js} +1 -1
  484. package/dist/ionic/p-ecbdbf25.system.entry.js +4 -0
  485. package/dist/ionic/{p-26d33af2.system.entry.js → p-ed5aebaa.system.entry.js} +1 -1
  486. package/dist/ionic/{p-23e440b6.entry.js → p-f357707e.entry.js} +1 -1
  487. package/dist/ionic/{p-e885f3c4.entry.js → p-f53bcebd.entry.js} +1 -1
  488. package/dist/ionic/p-f9baf25c.entry.js +4 -0
  489. package/dist/ionic/{p-ee3bbaf2.entry.js → p-fa8f2e62.entry.js} +1 -1
  490. package/dist/ionic/{p-6e9bd6ba.system.entry.js → p-fb21fd1c.system.entry.js} +1 -1
  491. package/dist/ionic/{p-bdd3053f.entry.js → p-fcecca8f.entry.js} +1 -1
  492. package/dist/types/components/accordion-group/accordion-group.d.ts +3 -4
  493. package/dist/types/components/checkbox/checkbox.d.ts +3 -4
  494. package/dist/types/components/content/content.d.ts +8 -0
  495. package/dist/types/components/datetime/datetime.d.ts +2 -0
  496. package/dist/types/components/input/input.d.ts +6 -0
  497. package/dist/types/components/modal/modal-interface.d.ts +1 -0
  498. package/dist/types/components/modal/modal.d.ts +18 -0
  499. package/dist/types/components/picker-column/picker-column.d.ts +37 -0
  500. package/dist/types/components/popover/popover-interface.d.ts +1 -0
  501. package/dist/types/components/popover/popover.d.ts +18 -0
  502. package/dist/types/components/radio-group/radio-group.d.ts +2 -0
  503. package/dist/types/components/range/range.d.ts +1 -1
  504. package/dist/types/components/searchbar/searchbar.d.ts +2 -0
  505. package/dist/types/components/segment/segment.d.ts +3 -2
  506. package/dist/types/components/select/select.d.ts +2 -0
  507. package/dist/types/components/textarea/textarea.d.ts +2 -0
  508. package/dist/types/components/toggle/toggle.d.ts +3 -2
  509. package/dist/types/components.d.ts +44 -12
  510. package/dist/types/utils/config.d.ts +9 -0
  511. package/dist/types/utils/focus-controller/index.d.ts +13 -0
  512. package/dist/types/utils/overlays.d.ts +1 -0
  513. package/hydrate/index.js +43566 -39256
  514. package/package.json +6 -6
  515. package/dist/cjs/index-1437d080.js +0 -11980
  516. package/dist/esm/index-5dc2b88e.js +0 -11942
  517. package/dist/esm-es5/app-globals-3cbaf9d9.js +0 -4
  518. package/dist/esm-es5/index-5dc2b88e.js +0 -18
  519. package/dist/esm-es5/index-f7fbe1fb.js +0 -4
  520. package/dist/esm-es5/ios.transition-a0041e41.js +0 -4
  521. package/dist/esm-es5/md.transition-0c0602d9.js +0 -4
  522. package/dist/ionic/p-06d5221c.js +0 -4
  523. package/dist/ionic/p-06fad524.system.js +0 -4
  524. package/dist/ionic/p-0d56dea9.entry.js +0 -4
  525. package/dist/ionic/p-13bfcef4.system.entry.js +0 -4
  526. package/dist/ionic/p-16016625.system.js +0 -4
  527. package/dist/ionic/p-20304962.js +0 -4
  528. package/dist/ionic/p-2dfdda15.system.entry.js +0 -4
  529. package/dist/ionic/p-2fa34b5c.entry.js +0 -4
  530. package/dist/ionic/p-32048e4c.system.js +0 -18
  531. package/dist/ionic/p-385964e6.entry.js +0 -4
  532. package/dist/ionic/p-4324e8a4.entry.js +0 -4
  533. package/dist/ionic/p-45664cb9.system.js +0 -4
  534. package/dist/ionic/p-4ad48ec9.system.entry.js +0 -4
  535. package/dist/ionic/p-4af0b730.js +0 -8
  536. package/dist/ionic/p-4fcef939.entry.js +0 -4
  537. package/dist/ionic/p-567a21a2.system.entry.js +0 -4
  538. package/dist/ionic/p-583f8865.system.entry.js +0 -4
  539. package/dist/ionic/p-58f89707.js +0 -4
  540. package/dist/ionic/p-7536b4b3.system.js +0 -4
  541. package/dist/ionic/p-7ef5bb32.entry.js +0 -4
  542. package/dist/ionic/p-8664c316.entry.js +0 -4
  543. package/dist/ionic/p-8c4fc85f.system.js +0 -4
  544. package/dist/ionic/p-8e031d97.entry.js +0 -4
  545. package/dist/ionic/p-8f48c966.system.entry.js +0 -4
  546. package/dist/ionic/p-adb896a0.entry.js +0 -4
  547. package/dist/ionic/p-b0093947.system.js +0 -4
  548. package/dist/ionic/p-cb4f96f3.system.js +0 -4
  549. package/dist/ionic/p-cc856712.entry.js +0 -4
  550. package/dist/ionic/p-cd1b9056.js +0 -4
  551. package/dist/ionic/p-d918e7ef.system.entry.js +0 -4
  552. package/dist/ionic/p-df062892.system.entry.js +0 -4
  553. package/dist/ionic/p-f0be340f.entry.js +0 -4
  554. package/dist/ionic/p-fdf40b09.js +0 -4
@@ -1,15 +1,15 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-5dc2b88e.js';
4
+ import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-9aab3bcf.js';
5
5
  import { d as doc } from './index-a5d50daf.js';
6
6
  import { r as raf, g as getElementRoot } from './helpers-da915de8.js';
7
7
  import { a as hapticSelectionStart, b as hapticSelectionChanged, h as hapticSelectionEnd } from './haptic-ac164e4c.js';
8
- import { a as isPlatform, b as getIonMode } from './ionic-global-d2d8f882.js';
8
+ import { a as isPlatform, b as getIonMode } from './ionic-global-4528d288.js';
9
9
  import { c as createColorClasses } from './theme-01f3f29c.js';
10
10
  import './capacitor-59395cbd.js';
11
11
 
12
- const pickerColumnCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;max-width:100%;height:200px;font-size:22px;text-align:center}.picker-opts{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0px;padding-bottom:0px;min-width:26px;max-height:200px;outline:none;text-align:inherit;-webkit-scroll-snap-type:y mandatory;-ms-scroll-snap-type:y mandatory;scroll-snap-type:y mandatory;overflow-x:hidden;overflow-y:scroll;scrollbar-width:none}.picker-item-empty{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;display:block;width:100%;height:34px;border:0px;outline:none;background:transparent;color:inherit;font-family:var(--ion-font-family, inherit);font-size:inherit;line-height:34px;text-align:inherit;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.picker-opts::-webkit-scrollbar{display:none}::slotted(ion-picker-column-option){display:block;scroll-snap-align:center}.picker-item-empty,:host(:not([disabled])) ::slotted(ion-picker-column-option.option-disabled){scroll-snap-align:none}::slotted([slot=prefix]),::slotted([slot=suffix]){max-width:200px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::slotted([slot=prefix]){-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0;padding-bottom:0;-ms-flex-pack:end;justify-content:end}::slotted([slot=suffix]){-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0;padding-bottom:0;-ms-flex-pack:start;justify-content:start}:host(.picker-column-disabled) .picker-opts{overflow-y:hidden}:host(.picker-column-disabled) ::slotted(ion-picker-column-option){cursor:default;opacity:0.4;pointer-events:none}@media (any-hover: hover){:host(:focus) .picker-opts{outline:none;background:rgba(var(--ion-color-base-rgb), 0.2)}}";
12
+ const pickerColumnCss = ":host{display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;max-width:100%;height:200px;font-size:22px;text-align:center}.assistive-focusable{left:0;right:0;top:0;bottom:0;position:absolute;z-index:1;pointer-events:none}.assistive-focusable:focus{outline:none}.picker-opts{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0px;padding-bottom:0px;min-width:26px;max-height:200px;outline:none;text-align:inherit;-webkit-scroll-snap-type:y mandatory;-ms-scroll-snap-type:y mandatory;scroll-snap-type:y mandatory;overflow-x:hidden;overflow-y:scroll;scrollbar-width:none}.picker-item-empty{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;display:block;width:100%;height:34px;border:0px;outline:none;background:transparent;color:inherit;font-family:var(--ion-font-family, inherit);font-size:inherit;line-height:34px;text-align:inherit;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.picker-opts::-webkit-scrollbar{display:none}::slotted(ion-picker-column-option){display:block;scroll-snap-align:center}.picker-item-empty,:host(:not([disabled])) ::slotted(ion-picker-column-option.option-disabled){scroll-snap-align:none}::slotted([slot=prefix]),::slotted([slot=suffix]){max-width:200px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::slotted([slot=prefix]){-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0;padding-bottom:0;-ms-flex-pack:end;justify-content:end}::slotted([slot=suffix]){-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0;padding-bottom:0;-ms-flex-pack:start;justify-content:start}:host(.picker-column-disabled) .picker-opts{overflow-y:hidden}:host(.picker-column-disabled) ::slotted(ion-picker-column-option){cursor:default;opacity:0.4;pointer-events:none}@media (any-hover: hover){:host(:focus) .picker-opts{outline:none;background:rgba(var(--ion-color-base-rgb), 0.2)}}";
13
13
  const IonPickerColumnStyle0 = pickerColumnCss;
14
14
 
15
15
  const PickerColumn = class {
@@ -19,6 +19,7 @@ const PickerColumn = class {
19
19
  this.isScrolling = false;
20
20
  this.isColumnVisible = false;
21
21
  this.canExitInputMode = true;
22
+ this.updateValueTextOnScroll = false;
22
23
  this.centerPickerItemInView = (target, smooth = true, canExitInputMode = true) => {
23
24
  const { isColumnVisible, scrollEl } = this;
24
25
  if (isColumnVisible && scrollEl) {
@@ -33,6 +34,7 @@ const PickerColumn = class {
33
34
  * of these can cause a scroll to occur.
34
35
  */
35
36
  this.canExitInputMode = canExitInputMode;
37
+ this.updateValueTextOnScroll = false;
36
38
  scrollEl.scroll({
37
39
  top,
38
40
  left: 0,
@@ -105,6 +107,7 @@ const PickerColumn = class {
105
107
  let activeEl = this.activeItem;
106
108
  const scrollCallback = () => {
107
109
  raf(() => {
110
+ var _a;
108
111
  if (!scrollEl)
109
112
  return;
110
113
  if (timeout) {
@@ -185,8 +188,23 @@ const PickerColumn = class {
185
188
  }
186
189
  activeEl = newActiveElement;
187
190
  this.setPickerItemActiveState(newActiveElement, true);
191
+ /**
192
+ * Set the aria-valuetext even though the value prop has not been updated yet.
193
+ * This enables some screen readers to announce the value as the users drag
194
+ * as opposed to when their release their pointer from the screen.
195
+ *
196
+ * When the value is programmatically updated, we will smoothly scroll
197
+ * to the new option. However, we do not want to update aria-valuetext mid-scroll
198
+ * as that can cause the old value to be briefly set before being set to the
199
+ * correct option. This will cause some screen readers to announce the old value
200
+ * again before announcing the new value. The correct valuetext will be set on render.
201
+ */
202
+ if (this.updateValueTextOnScroll) {
203
+ (_a = this.assistiveFocusable) === null || _a === void 0 ? void 0 : _a.setAttribute('aria-valuetext', this.getOptionValueText(newActiveElement));
204
+ }
188
205
  timeout = setTimeout(() => {
189
206
  this.isScrolling = false;
207
+ this.updateValueTextOnScroll = true;
190
208
  enableHaptics && hapticSelectionEnd();
191
209
  /**
192
210
  * Certain tasks (such as those that
@@ -245,12 +263,139 @@ const PickerColumn = class {
245
263
  */
246
264
  this.el.classList.remove('picker-column-active');
247
265
  };
266
+ /**
267
+ * Find the next enabled option after the active option.
268
+ * @param stride - How many options to "jump" over in order to select the next option.
269
+ * This can be used to implement PageUp/PageDown behaviors where pressing these keys
270
+ * scrolls the picker by more than 1 option. For example, a stride of 5 means select
271
+ * the enabled option 5 options after the active one. Note that the actual option selected
272
+ * may be past the stride if the option at the stride is disabled.
273
+ */
274
+ this.findNextOption = (stride = 1) => {
275
+ const { activeItem } = this;
276
+ if (!activeItem)
277
+ return null;
278
+ let prevNode = activeItem;
279
+ let node = activeItem.nextElementSibling;
280
+ while (node != null) {
281
+ if (stride > 0) {
282
+ stride--;
283
+ }
284
+ if (node.tagName === 'ION-PICKER-COLUMN-OPTION' && !node.disabled && stride === 0) {
285
+ return node;
286
+ }
287
+ prevNode = node;
288
+ // Use nextElementSibling instead of nextSibling to avoid text/comment nodes
289
+ node = node.nextElementSibling;
290
+ }
291
+ return prevNode;
292
+ };
293
+ /**
294
+ * Find the next enabled option after the active option.
295
+ * @param stride - How many options to "jump" over in order to select the next option.
296
+ * This can be used to implement PageUp/PageDown behaviors where pressing these keys
297
+ * scrolls the picker by more than 1 option. For example, a stride of 5 means select
298
+ * the enabled option 5 options before the active one. Note that the actual option selected
299
+ * may be past the stride if the option at the stride is disabled.
300
+ */
301
+ this.findPreviousOption = (stride = 1) => {
302
+ const { activeItem } = this;
303
+ if (!activeItem)
304
+ return null;
305
+ let nextNode = activeItem;
306
+ let node = activeItem.previousElementSibling;
307
+ while (node != null) {
308
+ if (stride > 0) {
309
+ stride--;
310
+ }
311
+ if (node.tagName === 'ION-PICKER-COLUMN-OPTION' && !node.disabled && stride === 0) {
312
+ return node;
313
+ }
314
+ nextNode = node;
315
+ // Use previousElementSibling instead of previousSibling to avoid text/comment nodes
316
+ node = node.previousElementSibling;
317
+ }
318
+ return nextNode;
319
+ };
320
+ this.onKeyDown = (ev) => {
321
+ /**
322
+ * The below operations should be inverted when running on a mobile device.
323
+ * For example, swiping up will dispatch an "ArrowUp" event. On desktop,
324
+ * this should cause the previous option to be selected. On mobile, swiping
325
+ * up causes a view to scroll down. As a result, swiping up on mobile should
326
+ * cause the next option to be selected. The Home/End operations remain
327
+ * unchanged because those always represent the first/last options, respectively.
328
+ */
329
+ const mobile = isPlatform('mobile');
330
+ let newOption = null;
331
+ switch (ev.key) {
332
+ case 'ArrowDown':
333
+ newOption = mobile ? this.findPreviousOption() : this.findNextOption();
334
+ break;
335
+ case 'ArrowUp':
336
+ newOption = mobile ? this.findNextOption() : this.findPreviousOption();
337
+ break;
338
+ case 'PageUp':
339
+ newOption = mobile ? this.findNextOption(5) : this.findPreviousOption(5);
340
+ break;
341
+ case 'PageDown':
342
+ newOption = mobile ? this.findPreviousOption(5) : this.findNextOption(5);
343
+ break;
344
+ case 'Home':
345
+ /**
346
+ * There is no guarantee that the first child will be an ion-picker-column-option,
347
+ * so we do not use firstElementChild.
348
+ */
349
+ newOption = this.el.querySelector('ion-picker-column-option:first-of-type');
350
+ break;
351
+ case 'End':
352
+ /**
353
+ * There is no guarantee that the last child will be an ion-picker-column-option,
354
+ * so we do not use lastElementChild.
355
+ */
356
+ newOption = this.el.querySelector('ion-picker-column-option:last-of-type');
357
+ break;
358
+ }
359
+ if (newOption !== null) {
360
+ this.value = newOption.value;
361
+ // This stops any default browser behavior such as scrolling
362
+ ev.preventDefault();
363
+ }
364
+ };
365
+ /**
366
+ * Utility to generate the correct text for aria-valuetext.
367
+ */
368
+ this.getOptionValueText = (el) => {
369
+ var _a;
370
+ return el ? (_a = el.getAttribute('aria-label')) !== null && _a !== void 0 ? _a : el.innerText : '';
371
+ };
372
+ /**
373
+ * Render an element that overlays the column. This element is for assistive
374
+ * tech to allow users to navigate the column up/down. This element should receive
375
+ * focus as it listens for synthesized keyboard events as required by the
376
+ * slider role: https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/slider_role
377
+ */
378
+ this.renderAssistiveFocusable = () => {
379
+ const { activeItem } = this;
380
+ const valueText = this.getOptionValueText(activeItem);
381
+ /**
382
+ * When using the picker, the valuetext provides important context that valuenow
383
+ * does not. Additionally, using non-zero valuemin/valuemax values can cause
384
+ * WebKit to incorrectly announce numeric valuetext values (such as a year
385
+ * like "2024") as percentages: https://bugs.webkit.org/show_bug.cgi?id=273126
386
+ */
387
+ return (h("div", { ref: (el) => (this.assistiveFocusable = el), class: "assistive-focusable", role: "slider", tabindex: this.disabled ? undefined : 0, "aria-label": this.ariaLabel, "aria-valuemin": 0, "aria-valuemax": 0, "aria-valuenow": 0, "aria-valuetext": valueText, "aria-orientation": "vertical", onKeyDown: (ev) => this.onKeyDown(ev) }));
388
+ };
389
+ this.ariaLabel = null;
248
390
  this.isActive = false;
249
391
  this.disabled = false;
250
392
  this.value = undefined;
251
393
  this.color = 'primary';
252
394
  this.numericInput = false;
253
395
  }
396
+ ariaLabelChanged(newValue) {
397
+ this.ariaLabel = newValue;
398
+ }
254
399
  valueChange() {
255
400
  if (this.isColumnVisible) {
256
401
  /**
@@ -366,6 +511,10 @@ const PickerColumn = class {
366
511
  this.scrollEl.focus();
367
512
  }
368
513
  }
514
+ connectedCallback() {
515
+ var _a;
516
+ this.ariaLabel = (_a = this.el.getAttribute('aria-label')) !== null && _a !== void 0 ? _a : 'Select a value';
517
+ }
369
518
  get activeItem() {
370
519
  const { value } = this;
371
520
  const options = Array.from(this.el.querySelectorAll('ion-picker-column-option'));
@@ -383,17 +532,18 @@ const PickerColumn = class {
383
532
  render() {
384
533
  const { color, disabled, isActive, numericInput } = this;
385
534
  const mode = getIonMode(this);
386
- return (h(Host, { key: '59648ef23cef1ab6d30955bb95bc23e670ec7256', class: createColorClasses(color, {
535
+ return (h(Host, { key: 'ced35afc6326a20dbac68193921a807a9c10bb99', class: createColorClasses(color, {
387
536
  [mode]: true,
388
537
  ['picker-column-active']: isActive,
389
538
  ['picker-column-numeric-input']: numericInput,
390
539
  ['picker-column-disabled']: disabled,
391
- }) }, h("slot", { key: 'fd93192d4945b2c33e0fe93cc90b505f2cec12fc', name: "prefix" }), h("div", { key: '99e49c6d58badd2fe5e75f0ebcd4bc00eb50aa58', class: "picker-opts", tabindex: disabled ? undefined : 0, ref: (el) => {
540
+ }) }, this.renderAssistiveFocusable(), h("slot", { key: '41e290dcc44dacb4237eb674ce2dedc7db66eb7d', name: "prefix" }), h("div", { key: '1fd869b063900103deadefc40929a1e8f02ec084', "aria-hidden": "true", class: "picker-opts", ref: (el) => {
392
541
  this.scrollEl = el;
393
- } }, h("div", { key: 'bb44892ef179b25373e45e4b4bc4d1fa617b1ea1', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '9ee7aeb8468bbb03f7192d56849dae089b7a0250', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '0baa4bda4bf02a8d06dbf3392b1516ca8ea8d26a', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("slot", { key: 'ff4cad20fd82ab66599473f60d10c18dc1dc76d8' }), h("div", { key: '04dcb0390209081e6223b90e45b8f2ef0fdf94bd', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '734e3b431a30ce93957e1452516efc86e29ff9c9', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '1c68dcf9a029e607bb6bc9c19cd02214914eb6d7', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0")), h("slot", { key: 'd85210cc99c8c1bf83eb1cd51540ebe875d4adeb', name: "suffix" })));
542
+ } }, h("div", { key: '0d2087f775b240c9b2534650eb27f3d99e7690a9', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '1245b2bb2b6314c3ec4e0ab3ece4e42beb360fc9', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '503b08f6bbe27fa7d34c165a93ec38ce7f1ad590', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("slot", { key: 'ec401a2b2d56546fb3f10239b71320ce7dc6a77d' }), h("div", { key: '97a234018291c5a6ca7a56bb1a9a417cac0b3e6f', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '0197711f71486a8fa3c184b593cebe1c1e54c585', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '961304f0a2a10afb3502ce4c5fbdceef0aa933cf', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0")), h("slot", { key: 'f38b83d26c3c2ba8ef00da7caf7f0be518b2007d', name: "suffix" })));
394
543
  }
395
544
  get el() { return getElement(this); }
396
545
  static get watchers() { return {
546
+ "aria-label": ["ariaLabelChanged"],
397
547
  "value": ["valueChange"]
398
548
  }; }
399
549
  };
@@ -1,7 +1,7 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-5dc2b88e.js';
4
+ import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-9aab3bcf.js';
5
5
  import { g as getElementRoot } from './helpers-da915de8.js';
6
6
 
7
7
  const pickerIosCss = ":host{display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:200px;direction:ltr;z-index:0}:host .picker-before,:host .picker-after{position:absolute;width:100%;-webkit-transform:translateZ(0);transform:translateZ(0);z-index:1;pointer-events:none}:host .picker-before{top:0;height:83px}:host .picker-before{inset-inline-start:0}:host .picker-after{top:116px;height:84px}:host .picker-after{inset-inline-start:0}:host .picker-highlight{border-radius:var(--highlight-border-radius, 8px);left:0;right:0;top:50%;bottom:0;-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0;position:absolute;width:calc(100% - 16px);height:34px;-webkit-transform:translateY(-50%);transform:translateY(-50%);background:var(--highlight-background);z-index:-1}:host input{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;margin:0;padding:0;border:0;outline:0;clip:rect(0 0 0 0);opacity:0;overflow:hidden;-webkit-appearance:none;-moz-appearance:none}:host ::slotted(ion-picker-column:first-of-type){text-align:start}:host ::slotted(ion-picker-column:last-of-type){text-align:end}:host ::slotted(ion-picker-column:only-child){text-align:center}:host .picker-before{background:-webkit-gradient(linear, left top, left bottom, color-stop(20%, rgba(var(--fade-background-rgb, var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255))), 1)), to(rgba(var(--fade-background-rgb, var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255))), 0.8)));background:linear-gradient(to bottom, rgba(var(--fade-background-rgb, var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255))), 1) 20%, rgba(var(--fade-background-rgb, var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255))), 0.8) 100%)}:host .picker-after{background:-webkit-gradient(linear, left bottom, left top, color-stop(20%, rgba(var(--fade-background-rgb, var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255))), 1)), to(rgba(var(--fade-background-rgb, var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255))), 0.8)));background:linear-gradient(to top, rgba(var(--fade-background-rgb, var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255))), 1) 20%, rgba(var(--fade-background-rgb, var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255))), 0.8) 100%)}:host .picker-highlight{background:var(--highlight-background, var(--ion-color-step-150, var(--ion-background-color-step-150, #eeeeef)))}";
@@ -480,7 +480,7 @@ const Picker = class {
480
480
  this.emitInputModeChange();
481
481
  }
482
482
  render() {
483
- return (h(Host, { key: 'f92214a09dc85b65873676f40fde2b802960e704', onPointerDown: (ev) => this.onPointerDown(ev), onClick: () => this.onClick() }, h("input", { key: '6da37f75aca4ea1c9cb3bc733ebda2116279f313', "aria-hidden": "true", tabindex: -1, inputmode: "numeric", type: "number", onKeyDown: (ev) => {
483
+ return (h(Host, { key: '02b0687b1f80ba295a965dfba76dd59e2d1de5d3', onPointerDown: (ev) => this.onPointerDown(ev), onClick: () => this.onClick() }, h("input", { key: 'f83ed84bcf9e02539c00d8a4e63e6a0d7fc4ac71', "aria-hidden": "true", tabindex: -1, inputmode: "numeric", type: "number", onKeyDown: (ev) => {
484
484
  var _a;
485
485
  /**
486
486
  * The "Enter" key represents
@@ -495,7 +495,7 @@ const Picker = class {
495
495
  if (ev.key === 'Enter') {
496
496
  (_a = this.inputEl) === null || _a === void 0 ? void 0 : _a.blur();
497
497
  }
498
- }, ref: (el) => (this.inputEl = el), onInput: () => this.onInputChange(), onBlur: () => this.exitInputMode() }), h("div", { key: '298e99d83dd3f5bf2798150bab0bb4024af472fa', class: "picker-before" }), h("div", { key: 'ea578f04eb562a4dc6d6cc92de133dcb9fb7f42a', class: "picker-after" }), h("div", { key: '84567824956dfe967992a629904836ba8b75b3ec', class: "picker-highlight", ref: (el) => (this.highlightEl = el) }), h("slot", { key: 'df81f8fb90e1f649b608328034528f5c31c70c3b' })));
498
+ }, ref: (el) => (this.inputEl = el), onInput: () => this.onInputChange(), onBlur: () => this.exitInputMode() }), h("div", { key: '45b07fb0617d8e006712776bf78302288edb3ff4', class: "picker-before" }), h("div", { key: '73009229368e0d62b09c913aacade26f068a7aa9', class: "picker-after" }), h("div", { key: 'b73da00e446cd1cfd511c39212e14a00d355752e', class: "picker-highlight", ref: (el) => (this.highlightEl = el) }), h("slot", { key: 'd969f5efc5ddb9eda6c4828702efd1ceeb69f767' })));
499
499
  }
500
500
  get el() { return getElement(this); }
501
501
  };
@@ -1,18 +1,18 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-5dc2b88e.js';
5
- import { B as BACKDROP, j as prepareOverlay, k as setOverlayId, f as present, n as focusFirstDescendant, g as dismiss, h as eventMethod } from './overlays-696d25f5.js';
4
+ import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-9aab3bcf.js';
5
+ import { B as BACKDROP, j as prepareOverlay, k as setOverlayId, f as present, n as focusFirstDescendant, g as dismiss, h as eventMethod, F as FOCUS_TRAP_DISABLE_CLASS } from './overlays-df2c06b2.js';
6
6
  import { C as CoreDelegate, a as attachComponent, d as detachComponent } from './framework-delegate-63d1a679.js';
7
7
  import { r as raf, g as getElementRoot, a as addEventListener, k as hasLazyBuild } from './helpers-da915de8.js';
8
8
  import { c as createLockController } from './lock-controller-316928be.js';
9
9
  import { p as printIonWarning } from './index-9b0d46f4.js';
10
- import { b as getIonMode, a as isPlatform } from './ionic-global-d2d8f882.js';
10
+ import { b as getIonMode, a as isPlatform } from './ionic-global-4528d288.js';
11
11
  import { g as getClassMap } from './theme-01f3f29c.js';
12
- import { e as deepReady, w as waitForMount } from './index-f7fbe1fb.js';
12
+ import { e as deepReady, w as waitForMount } from './index-8e6b6a24.js';
13
13
  import { c as createAnimation } from './animation-eab5a4ca.js';
14
14
  import './index-a5d50daf.js';
15
- import './hardware-back-button-804f43bb.js';
15
+ import './hardware-back-button-2d9760b6.js';
16
16
  import './gesture-controller-314a54f6.js';
17
17
 
18
18
  /**
@@ -1063,6 +1063,7 @@ const Popover = class {
1063
1063
  this.arrow = true;
1064
1064
  this.isOpen = false;
1065
1065
  this.keyboardEvents = false;
1066
+ this.focusTrap = true;
1066
1067
  this.keepContentsMounted = false;
1067
1068
  }
1068
1069
  onTriggerChange() {
@@ -1289,12 +1290,12 @@ const Popover = class {
1289
1290
  }
1290
1291
  render() {
1291
1292
  const mode = getIonMode(this);
1292
- const { onLifecycle, parentPopover, dismissOnSelect, side, arrow, htmlAttributes } = this;
1293
+ const { onLifecycle, parentPopover, dismissOnSelect, side, arrow, htmlAttributes, focusTrap } = this;
1293
1294
  const desktop = isPlatform('desktop');
1294
1295
  const enableArrow = arrow && !parentPopover;
1295
- return (h(Host, Object.assign({ key: '4bccccf57df72e1196c6a28e803831c0520aef53', "aria-modal": "true", "no-router": true, tabindex: "-1" }, htmlAttributes, { style: {
1296
+ return (h(Host, Object.assign({ key: '17e5e8b3e7ba5e251665fb9d0ade10c781f82f0e', "aria-modal": "true", "no-router": true, tabindex: "-1" }, htmlAttributes, { style: {
1296
1297
  zIndex: `${20000 + this.overlayIndex}`,
1297
- }, class: Object.assign(Object.assign({}, 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 && h("ion-backdrop", { key: 'e42f4f61150b7b41093d37d187d1b7bb4187a00e', tappable: this.backdropDismiss, visible: this.showBackdrop, part: "backdrop" }), h("div", { key: '386ac3247b0f82566aae07b6dbf5e97d243ce367', class: "popover-wrapper ion-overlay-wrapper", onClick: dismissOnSelect ? () => this.dismiss() : undefined }, enableArrow && h("div", { key: '28f0e5ea2fa099b808ffb77a9a0d78b8b46c1513', class: "popover-arrow", part: "arrow" }), h("div", { key: '7ba2e3dee529015c4e07ce78ec10dc59985ec6a2', class: "popover-content", part: "content" }, h("slot", { key: '915cdc8e389fda210f83aec8b7bbbfa6f830a884' })))));
1298
+ }, class: Object.assign(Object.assign({}, getClassMap(this.cssClass)), { [mode]: true, 'popover-translucent': this.translucent, 'overlay-hidden': true, 'popover-desktop': desktop, [`popover-side-${side}`]: true, [FOCUS_TRAP_DISABLE_CLASS]: focusTrap === false, 'popover-nested': !!parentPopover }), onIonPopoverDidPresent: onLifecycle, onIonPopoverWillPresent: onLifecycle, onIonPopoverWillDismiss: onLifecycle, onIonPopoverDidDismiss: onLifecycle, onIonBackdropTap: this.onBackdropTap }), !parentPopover && h("ion-backdrop", { key: 'c12fb94b375d7e88a0c5d715440c0f66ad7ee817', tappable: this.backdropDismiss, visible: this.showBackdrop, part: "backdrop" }), h("div", { key: '478b388cc9a5a382003a2863e968e77a174914ab', class: "popover-wrapper ion-overlay-wrapper", onClick: dismissOnSelect ? () => this.dismiss() : undefined }, enableArrow && h("div", { key: 'f1c63a0079f197a8d4577e7c00a654871fb9d816', class: "popover-arrow", part: "arrow" }), h("div", { key: '08b62a321c09ad4b0f90460468ecbc1d56320bf1', class: "popover-content", part: "content" }, h("slot", { key: '55645ff597f64d434219caa28015cf2a4ceb0ee5' })))));
1298
1299
  }
1299
1300
  get el() { return getElement(this); }
1300
1301
  static get watchers() { return {
@@ -1,10 +1,10 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, h, f as Host } from './index-5dc2b88e.js';
4
+ import { r as registerInstance, h, f as Host } from './index-9aab3bcf.js';
5
5
  import { j as clamp } from './helpers-da915de8.js';
6
6
  import { c as createColorClasses } from './theme-01f3f29c.js';
7
- import { c as config, b as getIonMode } from './ionic-global-d2d8f882.js';
7
+ import { c as config, b as getIonMode } from './ionic-global-4528d288.js';
8
8
 
9
9
  const progressBarIosCss = ":host{--background:rgba(var(--ion-color-primary-rgb, 0, 84, 233), 0.3);--progress-background:var(--ion-color-primary, #0054e9);display:block;position:relative;width:100%;contain:strict;direction:ltr;overflow:hidden}.progress,.progress-indeterminate,.indeterminate-bar-primary,.indeterminate-bar-secondary,.progress-buffer-bar{left:0;right:0;top:0;bottom:0;position:absolute;width:100%;height:100%}.buffer-circles-container,.buffer-circles{left:0;right:0;top:0;bottom:0;position:absolute}.buffer-circles{right:-10px;left:-10px;}.progress,.progress-buffer-bar,.buffer-circles-container{-webkit-transform-origin:left top;transform-origin:left top;-webkit-transition:-webkit-transform 150ms linear;transition:-webkit-transform 150ms linear;transition:transform 150ms linear;transition:transform 150ms linear, -webkit-transform 150ms linear}.progress,.progress-indeterminate{background:var(--progress-background);z-index:2}.progress-buffer-bar{background:var(--background);z-index:1}.buffer-circles-container{overflow:hidden}.indeterminate-bar-primary{top:0;right:0;bottom:0;left:-145.166611%;-webkit-animation:primary-indeterminate-translate 2s infinite linear;animation:primary-indeterminate-translate 2s infinite linear}.indeterminate-bar-primary .progress-indeterminate{-webkit-animation:primary-indeterminate-scale 2s infinite linear;animation:primary-indeterminate-scale 2s infinite linear;-webkit-animation-play-state:inherit;animation-play-state:inherit}.indeterminate-bar-secondary{top:0;right:0;bottom:0;left:-54.888891%;-webkit-animation:secondary-indeterminate-translate 2s infinite linear;animation:secondary-indeterminate-translate 2s infinite linear}.indeterminate-bar-secondary .progress-indeterminate{-webkit-animation:secondary-indeterminate-scale 2s infinite linear;animation:secondary-indeterminate-scale 2s infinite linear;-webkit-animation-play-state:inherit;animation-play-state:inherit}.buffer-circles{background-image:radial-gradient(ellipse at center, var(--background) 0%, var(--background) 30%, transparent 30%);background-repeat:repeat-x;background-position:5px center;background-size:10px 10px;z-index:0;-webkit-animation:buffering 450ms infinite linear;animation:buffering 450ms infinite linear}:host(.progress-bar-reversed){-webkit-transform:scaleX(-1);transform:scaleX(-1)}:host(.progress-paused) .indeterminate-bar-secondary,:host(.progress-paused) .indeterminate-bar-primary,:host(.progress-paused) .buffer-circles{-webkit-animation-play-state:paused;animation-play-state:paused}:host(.ion-color) .buffer-circles{background-image:radial-gradient(ellipse at center, rgba(var(--ion-color-base-rgb), 0.3) 0%, rgba(var(--ion-color-base-rgb), 0.3) 30%, transparent 30%)}:host(.ion-color) .progress,:host(.ion-color) .progress-indeterminate{background:var(--ion-color-base)}@-webkit-keyframes primary-indeterminate-translate{0%{-webkit-transform:translateX(0);transform:translateX(0)}20%{-webkit-animation-timing-function:cubic-bezier(0.5, 0, 0.701732, 0.495819);animation-timing-function:cubic-bezier(0.5, 0, 0.701732, 0.495819);-webkit-transform:translateX(0);transform:translateX(0)}59.15%{-webkit-animation-timing-function:cubic-bezier(0.302435, 0.381352, 0.55, 0.956352);animation-timing-function:cubic-bezier(0.302435, 0.381352, 0.55, 0.956352);-webkit-transform:translateX(83.67142%);transform:translateX(83.67142%)}100%{-webkit-transform:translateX(200.611057%);transform:translateX(200.611057%)}}@keyframes primary-indeterminate-translate{0%{-webkit-transform:translateX(0);transform:translateX(0)}20%{-webkit-animation-timing-function:cubic-bezier(0.5, 0, 0.701732, 0.495819);animation-timing-function:cubic-bezier(0.5, 0, 0.701732, 0.495819);-webkit-transform:translateX(0);transform:translateX(0)}59.15%{-webkit-animation-timing-function:cubic-bezier(0.302435, 0.381352, 0.55, 0.956352);animation-timing-function:cubic-bezier(0.302435, 0.381352, 0.55, 0.956352);-webkit-transform:translateX(83.67142%);transform:translateX(83.67142%)}100%{-webkit-transform:translateX(200.611057%);transform:translateX(200.611057%)}}@-webkit-keyframes primary-indeterminate-scale{0%{-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}36.65%{-webkit-animation-timing-function:cubic-bezier(0.334731, 0.12482, 0.785844, 1);animation-timing-function:cubic-bezier(0.334731, 0.12482, 0.785844, 1);-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}69.15%{-webkit-animation-timing-function:cubic-bezier(0.06, 0.11, 0.6, 1);animation-timing-function:cubic-bezier(0.06, 0.11, 0.6, 1);-webkit-transform:scaleX(0.661479);transform:scaleX(0.661479)}100%{-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}}@keyframes primary-indeterminate-scale{0%{-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}36.65%{-webkit-animation-timing-function:cubic-bezier(0.334731, 0.12482, 0.785844, 1);animation-timing-function:cubic-bezier(0.334731, 0.12482, 0.785844, 1);-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}69.15%{-webkit-animation-timing-function:cubic-bezier(0.06, 0.11, 0.6, 1);animation-timing-function:cubic-bezier(0.06, 0.11, 0.6, 1);-webkit-transform:scaleX(0.661479);transform:scaleX(0.661479)}100%{-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}}@-webkit-keyframes secondary-indeterminate-translate{0%{-webkit-animation-timing-function:cubic-bezier(0.15, 0, 0.515058, 0.409685);animation-timing-function:cubic-bezier(0.15, 0, 0.515058, 0.409685);-webkit-transform:translateX(0);transform:translateX(0)}25%{-webkit-animation-timing-function:cubic-bezier(0.31033, 0.284058, 0.8, 0.733712);animation-timing-function:cubic-bezier(0.31033, 0.284058, 0.8, 0.733712);-webkit-transform:translateX(37.651913%);transform:translateX(37.651913%)}48.35%{-webkit-animation-timing-function:cubic-bezier(0.4, 0.627035, 0.6, 0.902026);animation-timing-function:cubic-bezier(0.4, 0.627035, 0.6, 0.902026);-webkit-transform:translateX(84.386165%);transform:translateX(84.386165%)}100%{-webkit-transform:translateX(160.277782%);transform:translateX(160.277782%)}}@keyframes secondary-indeterminate-translate{0%{-webkit-animation-timing-function:cubic-bezier(0.15, 0, 0.515058, 0.409685);animation-timing-function:cubic-bezier(0.15, 0, 0.515058, 0.409685);-webkit-transform:translateX(0);transform:translateX(0)}25%{-webkit-animation-timing-function:cubic-bezier(0.31033, 0.284058, 0.8, 0.733712);animation-timing-function:cubic-bezier(0.31033, 0.284058, 0.8, 0.733712);-webkit-transform:translateX(37.651913%);transform:translateX(37.651913%)}48.35%{-webkit-animation-timing-function:cubic-bezier(0.4, 0.627035, 0.6, 0.902026);animation-timing-function:cubic-bezier(0.4, 0.627035, 0.6, 0.902026);-webkit-transform:translateX(84.386165%);transform:translateX(84.386165%)}100%{-webkit-transform:translateX(160.277782%);transform:translateX(160.277782%)}}@-webkit-keyframes secondary-indeterminate-scale{0%{-webkit-animation-timing-function:cubic-bezier(0.205028, 0.057051, 0.57661, 0.453971);animation-timing-function:cubic-bezier(0.205028, 0.057051, 0.57661, 0.453971);-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}19.15%{-webkit-animation-timing-function:cubic-bezier(0.152313, 0.196432, 0.648374, 1.004315);animation-timing-function:cubic-bezier(0.152313, 0.196432, 0.648374, 1.004315);-webkit-transform:scaleX(0.457104);transform:scaleX(0.457104)}44.15%{-webkit-animation-timing-function:cubic-bezier(0.257759, -0.003163, 0.211762, 1.38179);animation-timing-function:cubic-bezier(0.257759, -0.003163, 0.211762, 1.38179);-webkit-transform:scaleX(0.72796);transform:scaleX(0.72796)}100%{-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}}@keyframes secondary-indeterminate-scale{0%{-webkit-animation-timing-function:cubic-bezier(0.205028, 0.057051, 0.57661, 0.453971);animation-timing-function:cubic-bezier(0.205028, 0.057051, 0.57661, 0.453971);-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}19.15%{-webkit-animation-timing-function:cubic-bezier(0.152313, 0.196432, 0.648374, 1.004315);animation-timing-function:cubic-bezier(0.152313, 0.196432, 0.648374, 1.004315);-webkit-transform:scaleX(0.457104);transform:scaleX(0.457104)}44.15%{-webkit-animation-timing-function:cubic-bezier(0.257759, -0.003163, 0.211762, 1.38179);animation-timing-function:cubic-bezier(0.257759, -0.003163, 0.211762, 1.38179);-webkit-transform:scaleX(0.72796);transform:scaleX(0.72796)}100%{-webkit-transform:scaleX(0.08);transform:scaleX(0.08)}}@-webkit-keyframes buffering{to{-webkit-transform:translateX(-10px);transform:translateX(-10px)}}@keyframes buffering{to{-webkit-transform:translateX(-10px);transform:translateX(-10px)}}:host{border-radius:9999px;height:4px}:host(.progress-bar-solid){--background:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}";
10
10
  const IonProgressBarIosStyle0 = progressBarIosCss;
@@ -27,7 +27,7 @@ const ProgressBar = class {
27
27
  const mode = getIonMode(this);
28
28
  // If the progress is displayed as a solid bar.
29
29
  const progressSolid = buffer === 1;
30
- return (h(Host, { key: '8d8ddf0b26fe33803d3a6168cbedd523d1a888e7', role: "progressbar", "aria-valuenow": type === 'determinate' ? value : null, "aria-valuemin": "0", "aria-valuemax": "1", class: createColorClasses(color, {
30
+ return (h(Host, { key: 'b293f4475bcdaa7851b41ebfda659037f0365120', role: "progressbar", "aria-valuenow": type === 'determinate' ? value : null, "aria-valuemin": "0", "aria-valuemax": "1", class: createColorClasses(color, {
31
31
  [mode]: true,
32
32
  [`progress-bar-${type}`]: true,
33
33
  'progress-paused': paused,
@@ -1,11 +1,11 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-5dc2b88e.js';
4
+ import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-9aab3bcf.js';
5
5
  import { a as addEventListener, b as removeEventListener, d as renderHiddenInput } from './helpers-da915de8.js';
6
6
  import { i as isOptionSelected } from './compare-with-utils-a96ff2ea.js';
7
7
  import { h as hostContext, c as createColorClasses } from './theme-01f3f29c.js';
8
- import { b as getIonMode } from './ionic-global-d2d8f882.js';
8
+ import { b as getIonMode } from './ionic-global-4528d288.js';
9
9
 
10
10
  const radioIosCss = ":host{--inner-border-radius:50%;display:inline-block;position:relative;max-width:100%;min-height:inherit;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:2;-webkit-box-sizing:border-box;box-sizing:border-box}:host(.radio-disabled){pointer-events:none}.radio-icon{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%;contain:layout size style}.radio-icon,.radio-inner{-webkit-box-sizing:border-box;box-sizing:border-box}input{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;margin:0;padding:0;border:0;outline:0;clip:rect(0 0 0 0);opacity:0;overflow:hidden;-webkit-appearance:none;-moz-appearance:none}:host(:focus){outline:none}:host(.in-item){-ms-flex:1 1 0px;flex:1 1 0;width:100%;height:100%}:host([slot=start]),:host([slot=end]){width:auto}.radio-wrapper{display:-ms-flexbox;display:flex;position:relative;-ms-flex-positive:1;flex-grow:1;-ms-flex-align:center;align-items:center;height:inherit;min-height:inherit;cursor:inherit}.label-text-wrapper{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host(.in-item) .label-text-wrapper{margin-top:10px;margin-bottom:10px}:host(.in-item.radio-label-placement-stacked) .label-text-wrapper{margin-top:10px;margin-bottom:16px}:host(.in-item.radio-label-placement-stacked) .native-wrapper{margin-bottom:10px}.label-text-wrapper-hidden{display:none}.native-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host(.radio-justify-space-between) .radio-wrapper{-ms-flex-pack:justify;justify-content:space-between}:host(.radio-justify-start) .radio-wrapper{-ms-flex-pack:start;justify-content:start}:host(.radio-justify-end) .radio-wrapper{-ms-flex-pack:end;justify-content:end}:host(.radio-alignment-start) .radio-wrapper{-ms-flex-align:start;align-items:start}:host(.radio-alignment-center) .radio-wrapper{-ms-flex-align:center;align-items:center}:host(.radio-label-placement-start) .radio-wrapper{-ms-flex-direction:row;flex-direction:row}:host(.radio-label-placement-start) .label-text-wrapper{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:16px;margin-inline-end:16px}:host(.radio-label-placement-end) .radio-wrapper{-ms-flex-direction:row-reverse;flex-direction:row-reverse}:host(.radio-label-placement-end) .label-text-wrapper{-webkit-margin-start:16px;margin-inline-start:16px;-webkit-margin-end:0;margin-inline-end:0}:host(.radio-label-placement-fixed) .label-text-wrapper{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:16px;margin-inline-end:16px}:host(.radio-label-placement-fixed) .label-text-wrapper{-ms-flex:0 0 100px;flex:0 0 100px;width:100px;min-width:100px}:host(.radio-label-placement-stacked) .radio-wrapper{-ms-flex-direction:column;flex-direction:column}:host(.radio-label-placement-stacked) .label-text-wrapper{-webkit-transform:scale(0.75);transform:scale(0.75);margin-left:0;margin-right:0;margin-bottom:16px;max-width:calc(100% / 0.75)}:host(.radio-label-placement-stacked.radio-alignment-start) .label-text-wrapper{-webkit-transform-origin:left top;transform-origin:left top}:host-context([dir=rtl]):host(.radio-label-placement-stacked.radio-alignment-start) .label-text-wrapper,:host-context([dir=rtl]).radio-label-placement-stacked.radio-alignment-start .label-text-wrapper{-webkit-transform-origin:right top;transform-origin:right top}@supports selector(:dir(rtl)){:host(.radio-label-placement-stacked.radio-alignment-start:dir(rtl)) .label-text-wrapper{-webkit-transform-origin:right top;transform-origin:right top}}:host(.radio-label-placement-stacked.radio-alignment-center) .label-text-wrapper{-webkit-transform-origin:center top;transform-origin:center top}:host-context([dir=rtl]):host(.radio-label-placement-stacked.radio-alignment-center) .label-text-wrapper,:host-context([dir=rtl]).radio-label-placement-stacked.radio-alignment-center .label-text-wrapper{-webkit-transform-origin:calc(100% - center) top;transform-origin:calc(100% - center) top}@supports selector(:dir(rtl)){:host(.radio-label-placement-stacked.radio-alignment-center:dir(rtl)) .label-text-wrapper{-webkit-transform-origin:calc(100% - center) top;transform-origin:calc(100% - center) top}}:host{--color-checked:var(--ion-color-primary, #0054e9)}:host(.ion-color.radio-checked) .radio-inner{border-color:var(--ion-color-base)}.item-radio.item-ios ion-label{-webkit-margin-start:0;margin-inline-start:0}.radio-inner{width:33%;height:50%}:host(.radio-checked) .radio-inner{-webkit-transform:rotate(45deg);transform:rotate(45deg);border-width:0.125rem;border-top-width:0;border-left-width:0;border-style:solid;border-color:var(--color-checked)}:host(.radio-disabled){opacity:0.3}:host(.ion-focused) .radio-icon::after{border-radius:var(--inner-border-radius);top:-8px;display:block;position:absolute;width:36px;height:36px;background:var(--ion-color-primary-tint, #1a65eb);content:\"\";opacity:0.2}:host(.ion-focused) .radio-icon::after{inset-inline-start:-9px}.native-wrapper .radio-icon{width:0.9375rem;height:1.5rem}";
11
11
  const IonRadioIosStyle0 = radioIosCss;
@@ -108,7 +108,7 @@ const Radio = class {
108
108
  const { checked, disabled, color, el, justify, labelPlacement, hasLabel, buttonTabindex, alignment } = this;
109
109
  const mode = getIonMode(this);
110
110
  const inItem = hostContext('ion-item', el);
111
- return (h(Host, { key: 'cb00934d052260e97462e97a1669045cbb0b963a', onFocus: this.onFocus, onBlur: this.onBlur, onClick: this.onClick, class: createColorClasses(color, {
111
+ return (h(Host, { key: 'e44cade8aa8415bdc825f9d17fc8562487cf5d35', onFocus: this.onFocus, onBlur: this.onBlur, onClick: this.onClick, class: createColorClasses(color, {
112
112
  [mode]: true,
113
113
  'in-item': inItem,
114
114
  'radio-checked': checked,
@@ -119,10 +119,10 @@ const Radio = class {
119
119
  // Focus and active styling should not apply when the radio is in an item
120
120
  'ion-activatable': !inItem,
121
121
  'ion-focusable': !inItem,
122
- }), role: "radio", "aria-checked": checked ? 'true' : 'false', "aria-disabled": disabled ? 'true' : null, tabindex: buttonTabindex }, h("label", { key: '05613f89400469692442bf3c02c27f9299c5d6ef', class: "radio-wrapper" }, h("div", { key: '89b5d7668c3856f417c318629086cf46a072efbe', class: {
122
+ }), role: "radio", "aria-checked": checked ? 'true' : 'false', "aria-disabled": disabled ? 'true' : null, tabindex: buttonTabindex }, h("label", { key: '48a99aa80a7d7b4085ef26faf3167903c975517c', class: "radio-wrapper" }, h("div", { key: 'a8d74e0603b41215ea3e867356a9be0dcf3722d8', class: {
123
123
  'label-text-wrapper': true,
124
124
  'label-text-wrapper-hidden': !hasLabel,
125
- }, part: "label" }, h("slot", { key: 'd5e43a8d0fe5a7fc323887d310fd64d6f87deef7' })), h("div", { key: '7fd221189adcfccca1ed18dcd0a60cde6261120b', class: "native-wrapper" }, this.renderRadioControl()))));
125
+ }, part: "label" }, h("slot", { key: '9e3cce6254e70b02d50381537438a70435b031cc' })), h("div", { key: 'bfa3ee188d911e056a3e60178eac41362efb94b3', class: "native-wrapper" }, this.renderRadioControl()))));
126
126
  }
127
127
  get el() { return getElement(this); }
128
128
  static get watchers() { return {
@@ -287,7 +287,7 @@ const RadioGroup = class {
287
287
  const { label, labelId, el, name, value } = this;
288
288
  const mode = getIonMode(this);
289
289
  renderHiddenInput(true, el, name, value, false);
290
- return h(Host, { key: 'b6b439d6d53d17a5a4d9853a7cf6065b28213338', role: "radiogroup", "aria-labelledby": label ? labelId : null, onClick: this.onClick, class: mode });
290
+ return h(Host, { key: '7a8ad7eb6a05c6f96a348dcf30fd0c610a95688c', role: "radiogroup", "aria-labelledby": label ? labelId : null, onClick: this.onClick, class: mode });
291
291
  }
292
292
  get el() { return getElement(this); }
293
293
  static get watchers() { return {
@@ -1,13 +1,13 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-5dc2b88e.js';
4
+ import { r as registerInstance, d as createEvent, h, f as Host, i as getElement } from './index-9aab3bcf.js';
5
5
  import { f as findClosestIonContent, d as disableContentScrollY, r as resetContentScrollY } from './index-5cc724f3.js';
6
6
  import { j as clamp, e as debounceEvent, i as inheritAriaAttributes, d as renderHiddenInput } from './helpers-da915de8.js';
7
7
  import { p as printIonWarning } from './index-9b0d46f4.js';
8
8
  import { i as isRTL } from './dir-babeabeb.js';
9
9
  import { h as hostContext, c as createColorClasses } from './theme-01f3f29c.js';
10
- import { b as getIonMode } from './ionic-global-d2d8f882.js';
10
+ import { b as getIonMode } from './ionic-global-4528d288.js';
11
11
 
12
12
  function getDecimalPlaces(n) {
13
13
  if (n % 1 === 0)
@@ -600,7 +600,7 @@ const Range = class {
600
600
  const needsEndAdjustment = inItem && !hasEndContent;
601
601
  const mode = getIonMode(this);
602
602
  renderHiddenInput(true, el, this.name, JSON.stringify(this.getValue()), disabled);
603
- return (h(Host, { key: 'cd70b5db9eae808a644643d7095a1b5264cbc5fe', onFocusin: this.onFocus, onFocusout: this.onBlur, id: rangeId, class: createColorClasses(this.color, {
603
+ return (h(Host, { key: '7ad5ca892fd46c64ce5583e91e6812410a869921', onFocusin: this.onFocus, onFocusout: this.onBlur, id: rangeId, class: createColorClasses(this.color, {
604
604
  [mode]: true,
605
605
  'in-item': inItem,
606
606
  'range-disabled': disabled,
@@ -609,10 +609,10 @@ const Range = class {
609
609
  [`range-label-placement-${labelPlacement}`]: true,
610
610
  'range-item-start-adjustment': needsStartAdjustment,
611
611
  'range-item-end-adjustment': needsEndAdjustment,
612
- }) }, h("label", { key: '78ef0523f0064d6b268ae17ef72f90094511d897', class: "range-wrapper", id: "range-label" }, h("div", { key: '6e4b2051e770dabe80dcb9f412e9aae1859e9f33', class: {
612
+ }) }, h("label", { key: 'eb8d46a9572341b4cc3c91d8a5de0667bd166ca4', class: "range-wrapper", id: "range-label" }, h("div", { key: '21acd6ff6eba17bf6923bf723fea055b95fd29ca', class: {
613
613
  'label-text-wrapper': true,
614
614
  'label-text-wrapper-hidden': !hasLabel,
615
- }, part: "label" }, label !== undefined ? h("div", { class: "label-text" }, label) : h("slot", { name: "label" })), h("div", { key: '72cdb8f6657a3b84f759743cedd600020c954c6a', class: "native-wrapper" }, h("slot", { key: 'f7a38d6bd63df5dc8b4470f1f4acaaf3e5c80514', name: "start" }), this.renderRangeSlider(), h("slot", { key: 'ae74ac8c1da691e3be1b2f00dfd3c8419b9566ec', name: "end" })))));
615
+ }, part: "label" }, label !== undefined ? h("div", { class: "label-text" }, label) : h("slot", { name: "label" })), h("div", { key: '7644c86a6ad3edf2c27f02dd2a14795b3720ea0d', class: "native-wrapper" }, h("slot", { key: '1bbeccee57addc126b36de395e28ba655248695b', name: "start" }), this.renderRangeSlider(), h("slot", { key: '2963dd84e4116fc3956c304eb53deefd0d1291df', name: "end" })))));
616
616
  }
617
617
  get el() { return getElement(this); }
618
618
  static get watchers() { return {
@@ -1,12 +1,12 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { w as writeTask, r as registerInstance, d as createEvent, e as readTask, h, i as getElement, f as Host } from './index-5dc2b88e.js';
4
+ import { w as writeTask, r as registerInstance, d as createEvent, e as readTask, h, i as getElement, f as Host } from './index-9aab3bcf.js';
5
5
  import { g as getTimeGivenProgression } from './cubic-bezier-fe2083dc.js';
6
6
  import { I as ION_CONTENT_CLASS_SELECTOR, b as ION_CONTENT_ELEMENT_SELECTOR, p as printIonContentErrorMsg, g as getScrollElement } from './index-5cc724f3.js';
7
7
  import { t as transitionEndAsync, c as componentOnReady, j as clamp, g as getElementRoot, r as raf } from './helpers-da915de8.js';
8
8
  import { d as hapticImpact, I as ImpactStyle } from './haptic-ac164e4c.js';
9
- import { b as getIonMode, c as config } from './ionic-global-d2d8f882.js';
9
+ import { b as getIonMode, c as config } from './ionic-global-4528d288.js';
10
10
  import { c as createAnimation } from './animation-eab5a4ca.js';
11
11
  import { E as ENABLE_HTML_CONTENT_DEFAULT, a as sanitizeDOMString } from './config-49c88215.js';
12
12
  import { h as caretBackSharp, i as arrowDown } from './index-e2cf2ceb.js';
@@ -796,7 +796,7 @@ const Refresher = class {
796
796
  }
797
797
  render() {
798
798
  const mode = getIonMode(this);
799
- return (h(Host, { key: 'e7f4f2f96de7e80430bf54967ebc12e7216b2ca9', slot: "fixed", class: {
799
+ return (h(Host, { key: '1696f66f62d18c9075294f17cb24263325fcf35d', slot: "fixed", class: {
800
800
  [mode]: true,
801
801
  // Used internally for styling
802
802
  [`refresher-${mode}`]: true,
@@ -863,7 +863,7 @@ const RefresherContent = class {
863
863
  const pullingIcon = this.pullingIcon;
864
864
  const hasSpinner = pullingIcon != null && SPINNERS[pullingIcon] !== undefined;
865
865
  const mode = getIonMode(this);
866
- return (h(Host, { key: '19633bbcf02e3dba885d6bdcdaf2269bf4c8e2f5', class: mode }, h("div", { key: '28922e434a55a6cac0476fe2bee56941ce0d1c02', class: "refresher-pulling" }, this.pullingIcon && hasSpinner && (h("div", { key: 'fe575bf996021884677e9b23a3215d63caf894f5', class: "refresher-pulling-icon" }, h("div", { key: '59fe12297fd95bc33b8df8cd35316e2a1c084d91', class: "spinner-arrow-container" }, h("ion-spinner", { key: 'af9cc013ae04945c140b2865610ca73edb52ab48', name: this.pullingIcon, paused: true }), mode === 'md' && this.pullingIcon === 'circular' && (h("div", { key: '34df66ad1b0f706a0532957251aa2c20bf4587d8', class: "arrow-container" }, h("ion-icon", { key: 'ffdb5c123e606b823491c6c51cc2b497f62581bb', icon: caretBackSharp, "aria-hidden": "true" })))))), this.pullingIcon && !hasSpinner && (h("div", { key: 'ac3a2032bb969264d20fa057e9123441005d7a9d', class: "refresher-pulling-icon" }, h("ion-icon", { key: 'd969d10915548e72aae289b52154366f3dd39b31', icon: this.pullingIcon, lazy: false, "aria-hidden": "true" }))), this.pullingText !== undefined && this.renderPullingText()), h("div", { key: 'a8f854f81a94812d7bef8ce088331d94f49ff53d', class: "refresher-refreshing" }, this.refreshingSpinner && (h("div", { key: 'a1f646945370e40c844d62bc0c647443ae9dfbe7', class: "refresher-refreshing-icon" }, h("ion-spinner", { key: 'ab3ff4047769b6436e222b46d193c1e8b23e2fce', name: this.refreshingSpinner }))), this.refreshingText !== undefined && this.renderRefreshingText())));
866
+ return (h(Host, { key: '1bec5b4da221c69d856f3f5ddf40f2e03ebf2a4c', class: mode }, h("div", { key: '4fcc526c4f1881e9368d9cd16bd7030919bd3841', class: "refresher-pulling" }, this.pullingIcon && hasSpinner && (h("div", { key: 'a4e9e2e12c2d7faefc8303ec8c021f999ddf308e', class: "refresher-pulling-icon" }, h("div", { key: '5a2d215feb7fb4b64d540d3a65c0f24b415a2433', class: "spinner-arrow-container" }, h("ion-spinner", { key: 'abef2621d671ac6ff0abac43a702cbd825b7f127', name: this.pullingIcon, paused: true }), mode === 'md' && this.pullingIcon === 'circular' && (h("div", { key: '30087d672c3780672a05874cd93cd099b2855462', class: "arrow-container" }, h("ion-icon", { key: '5e30333dee469aec0d8efc8c4e6dabb619c6f363', icon: caretBackSharp, "aria-hidden": "true" })))))), this.pullingIcon && !hasSpinner && (h("div", { key: '48fe72b5ce8ded633c6ee799cebb520b9c8be528', class: "refresher-pulling-icon" }, h("ion-icon", { key: 'd8dfd5d42056b1c0a436c5006affb255407816c0', icon: this.pullingIcon, lazy: false, "aria-hidden": "true" }))), this.pullingText !== undefined && this.renderPullingText()), h("div", { key: 'c2cbfb94f157c82601ffe7bb815ff82ebc7c0a49', class: "refresher-refreshing" }, this.refreshingSpinner && (h("div", { key: '17f3ebe6a31768d5e389f45a2c12f68600185db9', class: "refresher-refreshing-icon" }, h("ion-spinner", { key: 'e8e61f8d7189c9939bba184201c9509d1d5b0fad', name: this.refreshingSpinner }))), this.refreshingText !== undefined && this.renderRefreshingText())));
867
867
  }
868
868
  get el() { return getElement(this); }
869
869
  };
@@ -1,9 +1,9 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, h, f as Host, i as getElement, d as createEvent } from './index-5dc2b88e.js';
4
+ import { r as registerInstance, h, f as Host, i as getElement, d as createEvent } from './index-9aab3bcf.js';
5
5
  import { j as reorderThreeOutline, k as reorderTwoSharp } from './index-e2cf2ceb.js';
6
- import { b as getIonMode } from './ionic-global-d2d8f882.js';
6
+ import { b as getIonMode } from './ionic-global-4528d288.js';
7
7
  import { f as findClosestIonContent, g as getScrollElement } from './index-5cc724f3.js';
8
8
  import { r as raf } from './helpers-da915de8.js';
9
9
  import { a as hapticSelectionStart, b as hapticSelectionChanged, h as hapticSelectionEnd } from './haptic-ac164e4c.js';
@@ -33,7 +33,7 @@ const Reorder = class {
33
33
  render() {
34
34
  const mode = getIonMode(this);
35
35
  const reorderIcon = mode === 'ios' ? reorderThreeOutline : reorderTwoSharp;
36
- return (h(Host, { key: '27266e30bcb7e10c57fb6d546399cfb1f1c93b23', class: mode }, h("slot", { key: '8745cb9a31458e884c27eed1fb90d104fe9a79eb' }, h("ion-icon", { key: '6c4b9631a2f5610f1e21b2db025b6702d0d593bf', icon: reorderIcon, lazy: false, class: "reorder-icon", part: "icon", "aria-hidden": "true" }))));
36
+ return (h(Host, { key: '663d74e231e3af56b6298ee2539fdac9c8465839', class: mode }, h("slot", { key: 'c7c384ab8c9ca8abdc89cd984a39dfde70e342ca' }, h("ion-icon", { key: 'c8b6052db03d4b9e33a90e600c20861c73ee73ce', icon: reorderIcon, lazy: false, class: "reorder-icon", part: "icon", "aria-hidden": "true" }))));
37
37
  }
38
38
  get el() { return getElement(this); }
39
39
  };
@@ -279,7 +279,7 @@ const ReorderGroup = class {
279
279
  }
280
280
  render() {
281
281
  const mode = getIonMode(this);
282
- return (h(Host, { key: 'a38c7fbceb677201330a602273d5b55abb32da19', class: {
282
+ return (h(Host, { key: '491f3e5843cf728ff4589e58bd86b8ce6709b293', class: {
283
283
  [mode]: true,
284
284
  'reorder-enabled': !this.disabled,
285
285
  'reorder-list-active': this.state !== 0 /* ReorderGroupState.Idle */,
@@ -1,8 +1,8 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, e as readTask, w as writeTask, h, i as getElement, f as Host } from './index-5dc2b88e.js';
5
- import { b as getIonMode } from './ionic-global-d2d8f882.js';
4
+ import { r as registerInstance, e as readTask, w as writeTask, h, i as getElement, f as Host } from './index-9aab3bcf.js';
5
+ import { b as getIonMode } from './ionic-global-4528d288.js';
6
6
 
7
7
  const rippleEffectCss = ":host{left:0;right:0;top:0;bottom:0;position:absolute;contain:strict;pointer-events:none}:host(.unbounded){contain:layout size style}.ripple-effect{border-radius:50%;position:absolute;background-color:currentColor;color:inherit;contain:strict;opacity:0;-webkit-animation:225ms rippleAnimation forwards, 75ms fadeInAnimation forwards;animation:225ms rippleAnimation forwards, 75ms fadeInAnimation forwards;will-change:transform, opacity;pointer-events:none}.fade-out{-webkit-transform:translate(var(--translate-end)) scale(var(--final-scale, 1));transform:translate(var(--translate-end)) scale(var(--final-scale, 1));-webkit-animation:150ms fadeOutAnimation forwards;animation:150ms fadeOutAnimation forwards}@-webkit-keyframes rippleAnimation{from{-webkit-animation-timing-function:cubic-bezier(0.4, 0, 0.2, 1);animation-timing-function:cubic-bezier(0.4, 0, 0.2, 1);-webkit-transform:scale(1);transform:scale(1)}to{-webkit-transform:translate(var(--translate-end)) scale(var(--final-scale, 1));transform:translate(var(--translate-end)) scale(var(--final-scale, 1))}}@keyframes rippleAnimation{from{-webkit-animation-timing-function:cubic-bezier(0.4, 0, 0.2, 1);animation-timing-function:cubic-bezier(0.4, 0, 0.2, 1);-webkit-transform:scale(1);transform:scale(1)}to{-webkit-transform:translate(var(--translate-end)) scale(var(--final-scale, 1));transform:translate(var(--translate-end)) scale(var(--final-scale, 1))}}@-webkit-keyframes fadeInAnimation{from{-webkit-animation-timing-function:linear;animation-timing-function:linear;opacity:0}to{opacity:0.16}}@keyframes fadeInAnimation{from{-webkit-animation-timing-function:linear;animation-timing-function:linear;opacity:0}to{opacity:0.16}}@-webkit-keyframes fadeOutAnimation{from{-webkit-animation-timing-function:linear;animation-timing-function:linear;opacity:0.16}to{opacity:0}}@keyframes fadeOutAnimation{from{-webkit-animation-timing-function:linear;animation-timing-function:linear;opacity:0.16}to{opacity:0}}";
8
8
  const IonRippleEffectStyle0 = rippleEffectCss;
@@ -64,7 +64,7 @@ const RippleEffect = class {
64
64
  }
65
65
  render() {
66
66
  const mode = getIonMode(this);
67
- return (h(Host, { key: '7ae559bda5d2c1856a45bfa150c2cb4f83373f8e', role: "presentation", class: {
67
+ return (h(Host, { key: '2302f087ab1c6755355736e4ca77309c5fdcf185', role: "presentation", class: {
68
68
  [mode]: true,
69
69
  unbounded: this.unbounded,
70
70
  } }));
@@ -1,10 +1,10 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, d as createEvent, i as getElement, h, f as Host } from './index-5dc2b88e.js';
4
+ import { r as registerInstance, d as createEvent, i as getElement, h, f as Host } from './index-9aab3bcf.js';
5
5
  import { c as componentOnReady, o as debounce } from './helpers-da915de8.js';
6
6
  import { o as openURL, c as createColorClasses } from './theme-01f3f29c.js';
7
- import { b as getIonMode } from './ionic-global-d2d8f882.js';
7
+ import { b as getIonMode } from './ionic-global-4528d288.js';
8
8
 
9
9
  const Route = class {
10
10
  constructor(hostRef) {
@@ -878,10 +878,10 @@ const RouterLink = class {
878
878
  rel: this.rel,
879
879
  target: this.target,
880
880
  };
881
- return (h(Host, { key: '529ceed5beaf92d7b4cc315c82f449eac18310e8', onClick: this.onClick, class: createColorClasses(this.color, {
881
+ return (h(Host, { key: 'f876442cab5b14b7e83c6d6ad2c2d878a9c57439', onClick: this.onClick, class: createColorClasses(this.color, {
882
882
  [mode]: true,
883
883
  'ion-activatable': true,
884
- }) }, h("a", Object.assign({ key: 'd5f1f8b256695d70bdafd20ff3d1b625963fa2da' }, attrs), h("slot", { key: '613fcdb36a71e076f989551ea21f1d5c118b1cd2' }))));
884
+ }) }, h("a", Object.assign({ key: 'c44b78ec1fd10a40c23bfe548860ac2b346646a8' }, attrs), h("slot", { key: 'd32180a567613f79f89885135bd0d776ffc1eb8e' }))));
885
885
  }
886
886
  };
887
887
  RouterLink.style = IonRouterLinkStyle0;