@ionic/core 8.7.17-dev.11772118942.181221d4 → 8.7.17-dev.11772568074.1d7a4aea

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 (520) hide show
  1. package/components/action-sheet.js +1 -561
  2. package/components/alert.js +1 -610
  3. package/components/animation.js +1 -817
  4. package/components/backdrop.js +1 -72
  5. package/components/button-active.js +1 -64
  6. package/components/button.js +1 -303
  7. package/components/buttons.js +1 -56
  8. package/components/capacitor.js +1 -10
  9. package/components/checkbox.js +1 -261
  10. package/components/config.js +1 -192
  11. package/components/content.js +1 -475
  12. package/components/cubic-bezier.js +1 -87
  13. package/components/data.js +1 -1635
  14. package/components/dir.js +1 -15
  15. package/components/focus-visible.js +1 -72
  16. package/components/framework-delegate.js +1 -137
  17. package/components/gesture-controller.js +1 -192
  18. package/components/haptic.js +1 -155
  19. package/components/hardware-back-button.js +1 -112
  20. package/components/header.js +1 -417
  21. package/components/helpers.js +1 -336
  22. package/components/icon.js +1 -456
  23. package/components/index.d.ts +2 -0
  24. package/components/index.js +1 -115
  25. package/components/index2.js +1 -416
  26. package/components/index3.js +1 -452
  27. package/components/index4.js +1 -118
  28. package/components/index5.js +1 -303
  29. package/components/index6.js +1 -29
  30. package/components/index7.js +1 -164
  31. package/components/index8.js +1 -125
  32. package/components/index9.js +1 -4
  33. package/components/input-shims.js +1 -624
  34. package/components/input.utils.js +1 -144
  35. package/components/ion-accordion-group.js +1 -269
  36. package/components/ion-accordion.js +1 -457
  37. package/components/ion-action-sheet.js +1 -6
  38. package/components/ion-alert.js +1 -6
  39. package/components/ion-app.js +1 -128
  40. package/components/ion-avatar.js +1 -41
  41. package/components/ion-back-button.js +1 -131
  42. package/components/ion-backdrop.js +1 -6
  43. package/components/ion-badge.js +1 -47
  44. package/components/ion-breadcrumb.js +1 -137
  45. package/components/ion-breadcrumbs.js +1 -164
  46. package/components/ion-button.js +1 -6
  47. package/components/ion-buttons.js +1 -6
  48. package/components/ion-card-content.js +1 -45
  49. package/components/ion-card-header.js +1 -56
  50. package/components/ion-card-subtitle.js +1 -48
  51. package/components/ion-card-title.js +1 -48
  52. package/components/ion-card.js +1 -107
  53. package/components/ion-checkbox.js +1 -6
  54. package/components/ion-chip.js +1 -66
  55. package/components/ion-col.js +1 -163
  56. package/components/ion-content.js +1 -6
  57. package/components/ion-datetime-button.js +1 -384
  58. package/components/ion-datetime.js +1 -2046
  59. package/components/ion-fab-button.js +1 -151
  60. package/components/ion-fab-list.js +1 -66
  61. package/components/ion-fab.js +1 -101
  62. package/components/ion-footer.js +1 -159
  63. package/components/ion-grid.js +1 -46
  64. package/components/ion-header.js +1 -6
  65. package/components/ion-icon.js +1 -6
  66. package/components/ion-img.js +1 -124
  67. package/components/ion-infinite-scroll-content.js +1 -70
  68. package/components/ion-infinite-scroll.js +1 -236
  69. package/components/ion-input-otp.js +1 -683
  70. package/components/ion-input-password-toggle.js +1 -129
  71. package/components/ion-input.js +1 -617
  72. package/components/ion-item-divider.js +1 -59
  73. package/components/ion-item-group.js +1 -46
  74. package/components/ion-item-option.js +1 -91
  75. package/components/ion-item-options.js +1 -73
  76. package/components/ion-item-sliding.js +1 -458
  77. package/components/ion-item.js +1 -6
  78. package/components/ion-label.js +1 -6
  79. package/components/ion-list-header.js +1 -6
  80. package/components/ion-list.js +1 -6
  81. package/components/ion-loading.js +1 -344
  82. package/components/ion-menu-button.js +1 -110
  83. package/components/ion-menu-toggle.js +1 -64
  84. package/components/ion-menu.js +1 -745
  85. package/components/ion-modal.js +1 -6
  86. package/components/ion-nav-link.js +1 -64
  87. package/components/ion-nav.js +1 -956
  88. package/components/ion-note.js +1 -47
  89. package/components/ion-picker-column-option.js +1 -6
  90. package/components/ion-picker-column.js +1 -6
  91. package/components/ion-picker-legacy-column.js +1 -6
  92. package/components/ion-picker-legacy.js +1 -343
  93. package/components/ion-picker.js +1 -6
  94. package/components/ion-popover.js +1 -6
  95. package/components/ion-progress-bar.js +1 -101
  96. package/components/ion-radio-group.js +1 -6
  97. package/components/ion-radio.js +1 -6
  98. package/components/ion-range.js +1 -853
  99. package/components/ion-refresher-content.js +1 -89
  100. package/components/ion-refresher.js +1 -751
  101. package/components/ion-reorder-group.js +1 -322
  102. package/components/ion-reorder.js +1 -60
  103. package/components/ion-ripple-effect.js +1 -6
  104. package/components/ion-route-redirect.js +1 -45
  105. package/components/ion-route.js +1 -74
  106. package/components/ion-router-link.js +1 -61
  107. package/components/ion-router-outlet.js +1 -227
  108. package/components/ion-router.js +1 -841
  109. package/components/ion-row.js +1 -36
  110. package/components/ion-searchbar.js +1 -530
  111. package/components/ion-segment-button.js +1 -174
  112. package/components/ion-segment-content.js +1 -35
  113. package/components/ion-segment-view.js +1 -148
  114. package/components/ion-segment.js +1 -602
  115. package/components/ion-select-modal.js +1 -6
  116. package/components/ion-select-option.js +1 -46
  117. package/components/ion-select-popover.js +1 -6
  118. package/components/ion-select.js +1 -1037
  119. package/components/ion-skeleton-text.js +1 -65
  120. package/components/ion-spinner.js +1 -6
  121. package/components/ion-split-pane.js +1 -197
  122. package/components/ion-tab-bar.js +1 -115
  123. package/components/ion-tab-button.js +1 -128
  124. package/components/ion-tab.js +1 -91
  125. package/components/ion-tabs.js +1 -205
  126. package/components/ion-text.js +1 -42
  127. package/components/ion-textarea.js +1 -554
  128. package/components/ion-thumbnail.js +1 -36
  129. package/components/ion-title.js +1 -6
  130. package/components/ion-toast.js +1 -941
  131. package/components/ion-toggle.js +1 -361
  132. package/components/ion-toolbar.js +1 -6
  133. package/components/ionic-global.js +1 -144
  134. package/components/ios.transition.js +1 -672
  135. package/components/item.js +1 -302
  136. package/components/keyboard-controller.js +1 -162
  137. package/components/keyboard.js +1 -141
  138. package/components/keyboard2.js +1 -76
  139. package/components/label.js +1 -100
  140. package/components/list-header.js +1 -47
  141. package/components/list.js +1 -68
  142. package/components/lock-controller.js +1 -35
  143. package/components/md.transition.js +1 -51
  144. package/components/menu-toggle-util.js +1 -9
  145. package/components/modal.js +1 -2674
  146. package/components/notch-controller.js +1 -150
  147. package/components/overlays.js +1 -912
  148. package/components/picker-column-option.js +1 -136
  149. package/components/picker-column.js +1 -595
  150. package/components/picker-column2.js +1 -377
  151. package/components/picker.js +1 -498
  152. package/components/popover.js +1 -1502
  153. package/components/radio-group.js +1 -287
  154. package/components/radio.js +1 -229
  155. package/components/refresher.utils.js +1 -193
  156. package/components/ripple-effect.js +1 -109
  157. package/components/select-modal.js +1 -196
  158. package/components/select-popover.js +1 -189
  159. package/components/spinner.js +1 -224
  160. package/components/status-tap.js +1 -36
  161. package/components/swipe-back.js +1 -75
  162. package/components/theme.js +1 -40
  163. package/components/title.js +1 -70
  164. package/components/toolbar.js +1 -89
  165. package/components/validity.js +1 -14
  166. package/components/watch-options.js +1 -44
  167. package/dist/cjs/{animation-Bt3H9L1C.js → animation-Dg4yiuR2.js} +1 -1
  168. package/dist/cjs/app-globals-CLI8xCmk.js +11 -0
  169. package/dist/cjs/{button-active-CMc8cD90.js → button-active-FscMI17-.js} +1 -1
  170. package/dist/cjs/{config-C5fsO43a.js → config-BukYi_pW.js} +1 -1
  171. package/dist/cjs/{data-JwZKaIQB.js → data-BYlBjkMU.js} +1 -1
  172. package/dist/cjs/{framework-delegate-DMJRBuDi.js → framework-delegate-CRgp8o_p.js} +1 -1
  173. package/dist/cjs/{hardware-back-button-VCK4V3mG.js → hardware-back-button-C4rMJ5uI.js} +1 -1
  174. package/dist/cjs/{helpers-DrTqNghc.js → helpers-CxTYJdbT.js} +1 -1
  175. package/dist/cjs/{index-094mMFB-.js → index-C845Ti6K.js} +4 -4
  176. package/dist/cjs/{index-DrMUZJj6.js → index-CFUwM5x_.js} +5 -5
  177. package/dist/cjs/{index-D6Wc6v08.js → index-CqT-2gKy.js} +503 -382
  178. package/dist/cjs/{index-CO6eryBo.js → index-MbaBbWXk.js} +2 -2
  179. package/dist/cjs/{index-C534ULug.js → index-YcSftOMz.js} +2 -2
  180. package/dist/cjs/index.cjs.js +12 -12
  181. package/dist/cjs/{input-shims-CW0KUFTQ.js → input-shims-DlFhYYTs.js} +3 -3
  182. package/dist/cjs/{input.utils-B_QROI2g.js → input.utils-DmeJ8dmo.js} +2 -2
  183. package/dist/cjs/ion-accordion_2.cjs.entry.js +23 -15
  184. package/dist/cjs/ion-action-sheet.cjs.entry.js +21 -15
  185. package/dist/cjs/ion-alert.cjs.entry.js +25 -17
  186. package/dist/cjs/ion-app_8.cjs.entry.js +44 -40
  187. package/dist/cjs/ion-avatar_3.cjs.entry.js +12 -12
  188. package/dist/cjs/ion-back-button.cjs.entry.js +7 -7
  189. package/dist/cjs/ion-backdrop.cjs.entry.js +6 -6
  190. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +20 -14
  191. package/dist/cjs/ion-button_2.cjs.entry.js +36 -18
  192. package/dist/cjs/ion-card_5.cjs.entry.js +23 -23
  193. package/dist/cjs/ion-checkbox.cjs.entry.js +7 -7
  194. package/dist/cjs/ion-chip.cjs.entry.js +6 -6
  195. package/dist/cjs/ion-col_3.cjs.entry.js +8 -8
  196. package/dist/cjs/ion-datetime-button.cjs.entry.js +8 -8
  197. package/dist/cjs/ion-datetime_3.cjs.entry.js +67 -39
  198. package/dist/cjs/ion-fab_3.cjs.entry.js +17 -13
  199. package/dist/cjs/ion-img.cjs.entry.js +8 -6
  200. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +17 -13
  201. package/dist/cjs/ion-input-otp.cjs.entry.js +16 -10
  202. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +9 -7
  203. package/dist/cjs/ion-input.cjs.entry.js +21 -13
  204. package/dist/cjs/ion-item-option_3.cjs.entry.js +17 -15
  205. package/dist/cjs/ion-item_8.cjs.entry.js +42 -36
  206. package/dist/cjs/ion-loading.cjs.entry.js +18 -14
  207. package/dist/cjs/ion-menu_3.cjs.entry.js +30 -22
  208. package/dist/cjs/ion-modal.cjs.entry.js +55 -40
  209. package/dist/cjs/ion-nav_2.cjs.entry.js +14 -10
  210. package/dist/cjs/ion-picker-column-option.cjs.entry.js +10 -8
  211. package/dist/cjs/ion-picker-column.cjs.entry.js +11 -7
  212. package/dist/cjs/ion-picker.cjs.entry.js +6 -6
  213. package/dist/cjs/ion-popover.cjs.entry.js +21 -15
  214. package/dist/cjs/ion-progress-bar.cjs.entry.js +7 -7
  215. package/dist/cjs/ion-radio_2.cjs.entry.js +17 -13
  216. package/dist/cjs/ion-range.cjs.entry.js +29 -15
  217. package/dist/cjs/ion-refresher_2.cjs.entry.js +45 -14
  218. package/dist/cjs/ion-reorder_2.cjs.entry.js +13 -11
  219. package/dist/cjs/ion-ripple-effect.cjs.entry.js +4 -4
  220. package/dist/cjs/ion-route_4.cjs.entry.js +20 -10
  221. package/dist/cjs/ion-searchbar.cjs.entry.js +22 -12
  222. package/dist/cjs/ion-segment-content.cjs.entry.js +3 -3
  223. package/dist/cjs/ion-segment-view.cjs.entry.js +5 -5
  224. package/dist/cjs/ion-segment_2.cjs.entry.js +26 -16
  225. package/dist/cjs/ion-select-modal.cjs.entry.js +12 -12
  226. package/dist/cjs/ion-select_3.cjs.entry.js +29 -21
  227. package/dist/cjs/ion-spinner.cjs.entry.js +4 -4
  228. package/dist/cjs/ion-split-pane.cjs.entry.js +15 -9
  229. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +14 -12
  230. package/dist/cjs/ion-tab_2.cjs.entry.js +10 -8
  231. package/dist/cjs/ion-text.cjs.entry.js +4 -4
  232. package/dist/cjs/ion-textarea.cjs.entry.js +18 -12
  233. package/dist/cjs/ion-toast.cjs.entry.js +21 -15
  234. package/dist/cjs/ion-toggle.cjs.entry.js +10 -8
  235. package/dist/cjs/{ionic-global-HMVqOFGO.js → ionic-global-Bc3kJi1Z.js} +1 -1
  236. package/dist/cjs/ionic.cjs.js +5 -5
  237. package/dist/cjs/{ios.transition-BOt_uW73.js → ios.transition-trBiC95R.js} +4 -4
  238. package/dist/cjs/loader.cjs.js +4 -4
  239. package/dist/cjs/{md.transition-Dt968VXB.js → md.transition-CUQECuvD.js} +4 -4
  240. package/dist/cjs/{notch-controller-Bzqhjm4f.js → notch-controller-sD-lTpdc.js} +1 -1
  241. package/dist/cjs/{overlays-B2b-TTbl.js → overlays-C2jiBSNQ.js} +5 -5
  242. package/dist/cjs/{status-tap-g0sWWkXk.js → status-tap-CCJk5VgT.js} +3 -3
  243. package/dist/cjs/{swipe-back-BIayeNOD.js → swipe-back-BGhTQ1CU.js} +2 -2
  244. package/dist/collection/collection-manifest.json +2 -2
  245. package/dist/collection/components/accordion-group/accordion-group.js +4 -2
  246. package/dist/collection/components/action-sheet/action-sheet.js +20 -10
  247. package/dist/collection/components/alert/alert.js +24 -12
  248. package/dist/collection/components/back-button/back-button.js +4 -2
  249. package/dist/collection/components/badge/badge.js +2 -1
  250. package/dist/collection/components/breadcrumb/breadcrumb.js +8 -4
  251. package/dist/collection/components/breadcrumbs/breadcrumbs.js +4 -2
  252. package/dist/collection/components/button/button.js +6 -3
  253. package/dist/collection/components/card/card.js +6 -3
  254. package/dist/collection/components/card-header/card-header.js +2 -1
  255. package/dist/collection/components/card-subtitle/card-subtitle.js +2 -1
  256. package/dist/collection/components/card-title/card-title.js +2 -1
  257. package/dist/collection/components/checkbox/checkbox.js +4 -2
  258. package/dist/collection/components/chip/chip.js +2 -1
  259. package/dist/collection/components/content/content.js +8 -4
  260. package/dist/collection/components/datetime/datetime.js +34 -15
  261. package/dist/collection/components/datetime-button/datetime-button.js +2 -1
  262. package/dist/collection/components/fab-button/fab-button.js +6 -3
  263. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +4 -2
  264. package/dist/collection/components/input/input.js +11 -6
  265. package/dist/collection/components/input-otp/input-otp.js +8 -4
  266. package/dist/collection/components/input-password-toggle/input-password-toggle.js +4 -2
  267. package/dist/collection/components/item/item.js +6 -3
  268. package/dist/collection/components/item-divider/item-divider.js +2 -1
  269. package/dist/collection/components/item-option/item-option.js +2 -1
  270. package/dist/collection/components/item-options/item-options.js +2 -1
  271. package/dist/collection/components/item-sliding/item-sliding.js +2 -1
  272. package/dist/collection/components/label/label.js +6 -3
  273. package/dist/collection/components/list-header/list-header.js +2 -1
  274. package/dist/collection/components/loading/loading.js +22 -11
  275. package/dist/collection/components/menu/menu.js +10 -5
  276. package/dist/collection/components/menu-button/menu-button.js +2 -1
  277. package/dist/collection/components/modal/gestures/sheet.js +32 -21
  278. package/dist/collection/components/modal/modal.js +35 -20
  279. package/dist/collection/components/nav/nav.js +89 -45
  280. package/dist/collection/components/nav-link/nav-link.js +9 -5
  281. package/dist/collection/components/note/note.js +2 -1
  282. package/dist/collection/components/picker/picker.js +2 -1
  283. package/dist/collection/components/picker-column/picker-column.js +6 -3
  284. package/dist/collection/components/picker-column-option/picker-column-option.js +2 -1
  285. package/dist/collection/components/picker-legacy/picker.js +24 -12
  286. package/dist/collection/components/picker-legacy-column/picker-column.js +4 -2
  287. package/dist/collection/components/popover/popover.js +33 -17
  288. package/dist/collection/components/progress-bar/progress-bar.js +2 -1
  289. package/dist/collection/components/radio/radio.js +2 -1
  290. package/dist/collection/components/radio-group/radio-group.js +6 -3
  291. package/dist/collection/components/range/range.js +14 -7
  292. package/dist/collection/components/refresher/refresher.js +73 -5
  293. package/dist/collection/components/refresher-content/refresher-content.js +8 -4
  294. package/dist/collection/components/reorder-group/reorder-group.js +6 -3
  295. package/dist/collection/components/route/route.js +4 -2
  296. package/dist/collection/components/router/router.js +10 -5
  297. package/dist/collection/components/router-link/router-link.js +6 -3
  298. package/dist/collection/components/router-outlet/router-outlet.js +18 -9
  299. package/dist/collection/components/searchbar/searchbar.js +11 -6
  300. package/dist/collection/components/segment/segment.js +10 -5
  301. package/dist/collection/components/segment-button/segment-button.js +4 -2
  302. package/dist/collection/components/segment-view/segment-view.js +2 -1
  303. package/dist/collection/components/select/select.js +10 -5
  304. package/dist/collection/components/select-modal/select-modal.js +2 -1
  305. package/dist/collection/components/select-popover/select-popover.js +2 -1
  306. package/dist/collection/components/skeleton-text/skeleton-text.js +2 -1
  307. package/dist/collection/components/spinner/spinner.js +4 -2
  308. package/dist/collection/components/tab/tab.js +4 -2
  309. package/dist/collection/components/tab-bar/tab-bar.js +4 -2
  310. package/dist/collection/components/tab-button/tab-button.js +4 -2
  311. package/dist/collection/components/tabs/tabs.js +4 -2
  312. package/dist/collection/components/text/text.js +2 -1
  313. package/dist/collection/components/textarea/textarea.js +6 -3
  314. package/dist/collection/components/title/title.js +4 -2
  315. package/dist/collection/components/toast/toast.js +34 -17
  316. package/dist/collection/components/toggle/toggle.js +4 -2
  317. package/dist/collection/components/toolbar/toolbar.js +2 -1
  318. package/dist/docs.d.ts +37 -0
  319. package/dist/docs.json +835 -381
  320. package/dist/esm/{animation-Dt8bGnA-.js → animation-CnGMT4ji.js} +1 -1
  321. package/dist/esm/app-globals-DhZjtldk.js +9 -0
  322. package/dist/esm/{button-active-L570Swow.js → button-active-BBx21brx.js} +1 -1
  323. package/dist/esm/{config-mCdtaoPe.js → config-TO1rZH52.js} +1 -1
  324. package/dist/esm/{data-DCORV9FH.js → data-B9iGR5YO.js} +1 -1
  325. package/dist/esm/{framework-delegate-BYawdMXj.js → framework-delegate-CyxE1S_P.js} +1 -1
  326. package/dist/esm/{hardware-back-button-CPLxO-Ev.js → hardware-back-button-CTe4XmL7.js} +1 -1
  327. package/dist/esm/{helpers-DEn3pfjm.js → helpers-Tl8jw6S2.js} +1 -1
  328. package/dist/esm/{index-r2D9DEro.js → index-B-hkiOUh.js} +4 -4
  329. package/dist/esm/{index-CvDIirVx.js → index-B2KwgBLx.js} +5 -5
  330. package/dist/esm/{index-ceb5RaMT.js → index-BtUdxPjv.js} +2 -2
  331. package/dist/esm/{index-C8IsBmNU.js → index-IGIE5vDm.js} +503 -382
  332. package/dist/esm/{index-Bs3kT4bc.js → index-hW6eNZ3o.js} +2 -2
  333. package/dist/esm/index.js +12 -12
  334. package/dist/esm/{input-shims-DyOpfTg6.js → input-shims-C1hAaHcP.js} +3 -3
  335. package/dist/esm/{input.utils-DrvTa8gz.js → input.utils-Bxa_DQ7-.js} +2 -2
  336. package/dist/esm/ion-accordion_2.entry.js +23 -15
  337. package/dist/esm/ion-action-sheet.entry.js +21 -15
  338. package/dist/esm/ion-alert.entry.js +25 -17
  339. package/dist/esm/ion-app_8.entry.js +44 -40
  340. package/dist/esm/ion-avatar_3.entry.js +12 -12
  341. package/dist/esm/ion-back-button.entry.js +7 -7
  342. package/dist/esm/ion-backdrop.entry.js +6 -6
  343. package/dist/esm/ion-breadcrumb_2.entry.js +20 -14
  344. package/dist/esm/ion-button_2.entry.js +36 -18
  345. package/dist/esm/ion-card_5.entry.js +23 -23
  346. package/dist/esm/ion-checkbox.entry.js +7 -7
  347. package/dist/esm/ion-chip.entry.js +6 -6
  348. package/dist/esm/ion-col_3.entry.js +8 -8
  349. package/dist/esm/ion-datetime-button.entry.js +8 -8
  350. package/dist/esm/ion-datetime_3.entry.js +67 -39
  351. package/dist/esm/ion-fab_3.entry.js +17 -13
  352. package/dist/esm/ion-img.entry.js +8 -6
  353. package/dist/esm/ion-infinite-scroll_2.entry.js +17 -13
  354. package/dist/esm/ion-input-otp.entry.js +16 -10
  355. package/dist/esm/ion-input-password-toggle.entry.js +9 -7
  356. package/dist/esm/ion-input.entry.js +21 -13
  357. package/dist/esm/ion-item-option_3.entry.js +17 -15
  358. package/dist/esm/ion-item_8.entry.js +42 -36
  359. package/dist/esm/ion-loading.entry.js +18 -14
  360. package/dist/esm/ion-menu_3.entry.js +30 -22
  361. package/dist/esm/ion-modal.entry.js +55 -40
  362. package/dist/esm/ion-nav_2.entry.js +14 -10
  363. package/dist/esm/ion-picker-column-option.entry.js +10 -8
  364. package/dist/esm/ion-picker-column.entry.js +11 -7
  365. package/dist/esm/ion-picker.entry.js +6 -6
  366. package/dist/esm/ion-popover.entry.js +21 -15
  367. package/dist/esm/ion-progress-bar.entry.js +7 -7
  368. package/dist/esm/ion-radio_2.entry.js +17 -13
  369. package/dist/esm/ion-range.entry.js +29 -15
  370. package/dist/esm/ion-refresher_2.entry.js +45 -14
  371. package/dist/esm/ion-reorder_2.entry.js +13 -11
  372. package/dist/esm/ion-ripple-effect.entry.js +4 -4
  373. package/dist/esm/ion-route_4.entry.js +20 -10
  374. package/dist/esm/ion-searchbar.entry.js +22 -12
  375. package/dist/esm/ion-segment-content.entry.js +3 -3
  376. package/dist/esm/ion-segment-view.entry.js +5 -5
  377. package/dist/esm/ion-segment_2.entry.js +26 -16
  378. package/dist/esm/ion-select-modal.entry.js +12 -12
  379. package/dist/esm/ion-select_3.entry.js +29 -21
  380. package/dist/esm/ion-spinner.entry.js +4 -4
  381. package/dist/esm/ion-split-pane.entry.js +15 -9
  382. package/dist/esm/ion-tab-bar_2.entry.js +14 -12
  383. package/dist/esm/ion-tab_2.entry.js +10 -8
  384. package/dist/esm/ion-text.entry.js +4 -4
  385. package/dist/esm/ion-textarea.entry.js +18 -12
  386. package/dist/esm/ion-toast.entry.js +21 -15
  387. package/dist/esm/ion-toggle.entry.js +10 -8
  388. package/dist/esm/{ionic-global-CDrldh-5.js → ionic-global-DfbeLwcV.js} +1 -1
  389. package/dist/esm/ionic.js +6 -6
  390. package/dist/esm/{ios.transition-BDzw0_Hm.js → ios.transition--aMF-pDH.js} +4 -4
  391. package/dist/esm/loader.js +5 -5
  392. package/dist/esm/{md.transition-BzDYi3qq.js → md.transition-BEVbfm8j.js} +4 -4
  393. package/dist/esm/{notch-controller-BwelN_JM.js → notch-controller-DAcvKU57.js} +1 -1
  394. package/dist/esm/{overlays-D5YkFThA.js → overlays-F8GHPo-e.js} +5 -5
  395. package/dist/esm/{status-tap-5DQ7Fc4V.js → status-tap-BfJqFSLF.js} +3 -3
  396. package/dist/esm/{swipe-back-BKw2CAHc.js → swipe-back-BZBFwTQV.js} +2 -2
  397. package/dist/html.html-data.json +109 -109
  398. package/dist/ionic/index.esm.js +1 -1
  399. package/dist/ionic/ionic.esm.js +1 -1
  400. package/dist/ionic/{p-316c0420.entry.js → p-025d2d32.entry.js} +1 -1
  401. package/dist/ionic/p-02acdef4.entry.js +4 -0
  402. package/dist/ionic/p-04e2c388.entry.js +4 -0
  403. package/dist/ionic/{p-370e4237.entry.js → p-074344b8.entry.js} +1 -1
  404. package/dist/ionic/p-0761b4d3.entry.js +4 -0
  405. package/dist/ionic/p-13ade5c8.entry.js +4 -0
  406. package/dist/ionic/p-1b02923f.entry.js +4 -0
  407. package/dist/ionic/p-1bd477a9.entry.js +4 -0
  408. package/dist/ionic/{p-d2489bf2.entry.js → p-1fa1406c.entry.js} +1 -1
  409. package/dist/ionic/{p-46d74291.entry.js → p-1fd588a7.entry.js} +1 -1
  410. package/dist/ionic/p-239a27a4.entry.js +4 -0
  411. package/dist/ionic/{p-94de5cfa.entry.js → p-277abec1.entry.js} +1 -1
  412. package/dist/ionic/{p-dd1aef77.entry.js → p-28d7852f.entry.js} +1 -1
  413. package/dist/ionic/{p-49d06882.entry.js → p-301c43f8.entry.js} +1 -1
  414. package/dist/ionic/{p-79bd78f9.entry.js → p-370a60ee.entry.js} +1 -1
  415. package/dist/ionic/p-3e143d1d.entry.js +4 -0
  416. package/dist/ionic/p-4431ef7e.entry.js +4 -0
  417. package/dist/ionic/p-463767ce.entry.js +4 -0
  418. package/dist/ionic/p-4f888343.entry.js +4 -0
  419. package/dist/ionic/p-51c11c47.entry.js +4 -0
  420. package/dist/ionic/p-56050077.entry.js +4 -0
  421. package/dist/ionic/p-6a3a5aae.entry.js +4 -0
  422. package/dist/ionic/p-6b97f2a3.entry.js +4 -0
  423. package/dist/ionic/{p-51a60e0f.entry.js → p-7c72d482.entry.js} +1 -1
  424. package/dist/ionic/p-7d20f4f8.entry.js +4 -0
  425. package/dist/ionic/{p-11aa58d6.entry.js → p-80cac7a2.entry.js} +1 -1
  426. package/dist/ionic/p-91fc7352.entry.js +4 -0
  427. package/dist/ionic/p-93845421.entry.js +4 -0
  428. package/dist/ionic/{p-3a6caca9.entry.js → p-964090ef.entry.js} +1 -1
  429. package/dist/ionic/p-96a2e768.entry.js +4 -0
  430. package/dist/ionic/{p-d126e8d3.entry.js → p-9745651b.entry.js} +1 -1
  431. package/dist/ionic/{p-f9061316.entry.js → p-9802c88e.entry.js} +1 -1
  432. package/dist/ionic/{p-582824c5.entry.js → p-9833cf63.entry.js} +1 -1
  433. package/dist/ionic/{p-675b1a31.entry.js → p-9fae83d8.entry.js} +1 -1
  434. package/dist/ionic/{p-CwgG81ZD.js → p-B8xlpH8p.js} +1 -1
  435. package/dist/ionic/{p-C7hRNDhM.js → p-BAt5H1ac.js} +1 -1
  436. package/dist/ionic/p-BW_TRJm8.js +4 -0
  437. package/dist/ionic/{p-DDb5r57F.js → p-Bum7H1fw.js} +1 -1
  438. package/dist/ionic/{p-D0dMcSkw.js → p-BvFYtOdE.js} +1 -1
  439. package/dist/ionic/{p-Dc45iWE4.js → p-BxIcPWoV.js} +1 -1
  440. package/dist/ionic/{p-BYEqWnSg.js → p-C0JvVFMv.js} +1 -1
  441. package/dist/ionic/{p-CTfR9YZG.js → p-CGmVTdWh.js} +1 -1
  442. package/dist/ionic/{p-BOVrCkpJ.js → p-CYbRmDdy.js} +1 -1
  443. package/dist/ionic/{p-D-eFFUkA.js → p-CmFz1Mjc.js} +1 -1
  444. package/dist/ionic/p-CtA-yJYy.js +4 -0
  445. package/dist/ionic/p-D8HJQ1qq.js +4 -0
  446. package/dist/ionic/{p-B0q1YL7N.js → p-DB_iPQC-.js} +1 -1
  447. package/dist/ionic/{p-DNcfiJwE.js → p-DLbbmF9h.js} +1 -1
  448. package/dist/ionic/{p-DdR6rpbR.js → p-DTPR1Wpn.js} +1 -1
  449. package/dist/ionic/{p-DCv9sLH2.js → p-DjriolRs.js} +1 -1
  450. package/dist/ionic/p-DtVZDHlS.js +4 -0
  451. package/dist/ionic/{p-QHYY4sjU.js → p-GWUGgWx6.js} +1 -1
  452. package/dist/ionic/p-IGIE5vDm.js +5 -0
  453. package/dist/ionic/{p-BFvmZNyx.js → p-NFFyoJ4Q.js} +1 -1
  454. package/dist/ionic/{p-86f53961.entry.js → p-a287e18e.entry.js} +1 -1
  455. package/dist/ionic/p-a805674e.entry.js +4 -0
  456. package/dist/ionic/p-a81ae2cd.entry.js +4 -0
  457. package/dist/ionic/{p-da7d04cc.entry.js → p-a84f2d21.entry.js} +1 -1
  458. package/dist/ionic/{p-dbbe606a.entry.js → p-b2d5238b.entry.js} +1 -1
  459. package/dist/ionic/{p-d1f54e28.entry.js → p-b440381f.entry.js} +1 -1
  460. package/dist/ionic/{p-72c38b88.entry.js → p-b4d52b58.entry.js} +1 -1
  461. package/dist/ionic/{p-2a939845.entry.js → p-b67a2114.entry.js} +1 -1
  462. package/dist/ionic/{p-c73627c8.entry.js → p-bced1f3e.entry.js} +1 -1
  463. package/dist/ionic/{p-9a2d390d.entry.js → p-c1c9b2bb.entry.js} +1 -1
  464. package/dist/ionic/{p-f8f22cc0.entry.js → p-c3e65e45.entry.js} +1 -1
  465. package/dist/ionic/p-c76cc21d.entry.js +4 -0
  466. package/dist/ionic/{p-b0a7585c.entry.js → p-ca31010f.entry.js} +1 -1
  467. package/dist/ionic/p-cbf245b5.entry.js +4 -0
  468. package/dist/ionic/p-d68b665a.entry.js +4 -0
  469. package/dist/ionic/{p-9575b654.entry.js → p-e663bc5a.entry.js} +1 -1
  470. package/dist/ionic/p-efe86ed9.entry.js +4 -0
  471. package/dist/ionic/{p-ac4eb91d.entry.js → p-f5dfb9a3.entry.js} +1 -1
  472. package/dist/ionic/{p-DbQ5QkTP.js → p-gbVXD275.js} +1 -1
  473. package/dist/ionic/p-hNN3VvaC.js +4 -0
  474. package/dist/types/components/datetime/datetime.d.ts +9 -0
  475. package/dist/types/components/header/header.utils.d.ts +2 -1
  476. package/dist/types/components/modal/modal-interface.d.ts +5 -1
  477. package/dist/types/components/modal/modal.d.ts +5 -0
  478. package/dist/types/components/refresher/refresher-interface.d.ts +7 -0
  479. package/dist/types/components/refresher/refresher.d.ts +16 -3
  480. package/dist/types/components.d.ts +927 -189
  481. package/dist/types/interface.d.ts +1 -1
  482. package/dist/types/stencil-public-runtime.d.ts +126 -14
  483. package/dist/types/utils/gesture/listener.d.ts +2 -1
  484. package/hydrate/index.d.ts +12 -0
  485. package/hydrate/index.js +5202 -1327
  486. package/hydrate/index.mjs +5201 -1328
  487. package/package.json +2 -2
  488. package/dist/cjs/app-globals-Ciccnk9_.js +0 -10
  489. package/dist/esm/app-globals-BDSf8fOA.js +0 -8
  490. package/dist/ionic/p-012212e4.entry.js +0 -4
  491. package/dist/ionic/p-074839fc.entry.js +0 -4
  492. package/dist/ionic/p-0dfa5a37.entry.js +0 -4
  493. package/dist/ionic/p-0f418a37.entry.js +0 -4
  494. package/dist/ionic/p-11518b31.entry.js +0 -4
  495. package/dist/ionic/p-1838bed5.entry.js +0 -4
  496. package/dist/ionic/p-29721c43.entry.js +0 -4
  497. package/dist/ionic/p-31f7095f.entry.js +0 -4
  498. package/dist/ionic/p-34642fa1.entry.js +0 -4
  499. package/dist/ionic/p-35696017.entry.js +0 -4
  500. package/dist/ionic/p-40c261a3.entry.js +0 -4
  501. package/dist/ionic/p-4e41ea20.entry.js +0 -4
  502. package/dist/ionic/p-6241ce47.entry.js +0 -4
  503. package/dist/ionic/p-639dd543.entry.js +0 -4
  504. package/dist/ionic/p-6444c606.entry.js +0 -4
  505. package/dist/ionic/p-6d070558.entry.js +0 -4
  506. package/dist/ionic/p-7268efa5.entry.js +0 -4
  507. package/dist/ionic/p-7babec72.entry.js +0 -4
  508. package/dist/ionic/p-BKc55Xev.js +0 -4
  509. package/dist/ionic/p-Bmgaetn_.js +0 -4
  510. package/dist/ionic/p-C8IsBmNU.js +0 -5
  511. package/dist/ionic/p-CJxh_yLS.js +0 -4
  512. package/dist/ionic/p-DUt5fQmA.js +0 -4
  513. package/dist/ionic/p-DZRJwG4S.js +0 -4
  514. package/dist/ionic/p-a127bee2.entry.js +0 -4
  515. package/dist/ionic/p-b3d44509.entry.js +0 -4
  516. package/dist/ionic/p-cc45bcbc.entry.js +0 -4
  517. package/dist/ionic/p-d0a2a1ab.entry.js +0 -4
  518. package/dist/ionic/p-d3014190.entry.js +0 -4
  519. package/dist/ionic/p-db82892c.entry.js +0 -4
  520. package/dist/ionic/p-e1d1f3cc.entry.js +0 -4
@@ -1,605 +1,4 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { proxyCustomElement, HTMLElement, createEvent, writeTask, h, Host } from '@stencil/core/internal/client';
5
- import { r as raf } from './helpers.js';
6
- import { i as isRTL } from './dir.js';
7
- import { c as createColorClasses, h as hostContext } from './theme.js';
8
- import { b as getIonMode } from './ionic-global.js';
9
-
10
- const segmentIosCss = ":host{--ripple-color:currentColor;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:grid;grid-auto-columns:1fr;position:relative;-ms-flex-align:stretch;align-items:stretch;-ms-flex-pack:center;justify-content:center;width:100%;background:var(--background);font-family:var(--ion-font-family, inherit);text-align:center;contain:paint;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host(.segment-scrollable){-ms-flex-pack:start;justify-content:start;width:auto;overflow-x:auto;grid-auto-columns:minmax(-webkit-min-content, 1fr);grid-auto-columns:minmax(min-content, 1fr)}:host(.segment-scrollable::-webkit-scrollbar){display:none}:host{--background:rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.065);border-radius:8px;overflow:hidden;z-index:0}:host(.ion-color){background:rgba(var(--ion-color-base-rgb), 0.065)}:host(.in-toolbar){-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0;width:auto}:host(.in-toolbar:not(.ion-color)){background:var(--ion-toolbar-segment-background, var(--background))}:host(.in-toolbar-color:not(.ion-color)){background:rgba(var(--ion-color-contrast-rgb), 0.11)}";
11
-
12
- const segmentMdCss = ":host{--ripple-color:currentColor;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:grid;grid-auto-columns:1fr;position:relative;-ms-flex-align:stretch;align-items:stretch;-ms-flex-pack:center;justify-content:center;width:100%;background:var(--background);font-family:var(--ion-font-family, inherit);text-align:center;contain:paint;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host(.segment-scrollable){-ms-flex-pack:start;justify-content:start;width:auto;overflow-x:auto;grid-auto-columns:minmax(-webkit-min-content, 1fr);grid-auto-columns:minmax(min-content, 1fr)}:host(.segment-scrollable::-webkit-scrollbar){display:none}:host{--background:transparent;grid-auto-columns:minmax(auto, 360px)}:host(.in-toolbar){min-height:var(--min-height)}:host(.segment-scrollable) ::slotted(ion-segment-button){min-width:auto}";
13
-
14
- const Segment = /*@__PURE__*/ proxyCustomElement(class Segment extends HTMLElement {
15
- constructor(registerHost) {
16
- super();
17
- if (registerHost !== false) {
18
- this.__registerHost();
19
- }
20
- this.__attachShadow();
21
- this.ionChange = createEvent(this, "ionChange", 7);
22
- this.ionSelect = createEvent(this, "ionSelect", 7);
23
- this.ionStyle = createEvent(this, "ionStyle", 7);
24
- this.segmentViewEl = null;
25
- this.activated = false;
26
- /**
27
- * If `true`, the user cannot interact with the segment.
28
- */
29
- this.disabled = false;
30
- /**
31
- * If `true`, the segment buttons will overflow and the user can swipe to see them.
32
- * In addition, this will disable the gesture to drag the indicator between the buttons
33
- * in order to swipe to see hidden buttons.
34
- */
35
- this.scrollable = false;
36
- /**
37
- * If `true`, users will be able to swipe between segment buttons to activate them.
38
- */
39
- this.swipeGesture = true;
40
- /**
41
- * If `true`, navigating to an `ion-segment-button` with the keyboard will focus and select the element.
42
- * If `false`, keyboard navigation will only focus the `ion-segment-button` element.
43
- */
44
- this.selectOnFocus = false;
45
- this.onClick = (ev) => {
46
- const current = ev.target;
47
- const previous = this.checked;
48
- // If the current element is a segment then that means
49
- // the user tried to swipe to a segment button and
50
- // click a segment button at the same time so we should
51
- // not update the checked segment button
52
- if (current.tagName === 'ION-SEGMENT') {
53
- return;
54
- }
55
- this.value = current.value;
56
- if (current !== previous) {
57
- this.emitValueChange();
58
- }
59
- if (this.segmentViewEl) {
60
- this.updateSegmentView();
61
- if (this.scrollable && previous) {
62
- this.checkButton(previous, current);
63
- }
64
- }
65
- else if (this.scrollable || !this.swipeGesture) {
66
- if (previous) {
67
- this.checkButton(previous, current);
68
- }
69
- else {
70
- this.setCheckedClasses();
71
- }
72
- }
73
- };
74
- this.onSlottedItemsChange = () => {
75
- /**
76
- * When the slotted segment buttons change we need to
77
- * ensure that the new segment buttons are checked if
78
- * the value matches the segment button value.
79
- */
80
- this.valueChanged(this.value);
81
- };
82
- this.getSegmentButton = (selector) => {
83
- var _a, _b;
84
- const buttons = this.getButtons().filter((button) => !button.disabled);
85
- const currIndex = buttons.findIndex((button) => button === document.activeElement);
86
- switch (selector) {
87
- case 'first':
88
- return buttons[0];
89
- case 'last':
90
- return buttons[buttons.length - 1];
91
- case 'next':
92
- return (_a = buttons[currIndex + 1]) !== null && _a !== void 0 ? _a : buttons[0];
93
- case 'previous':
94
- return (_b = buttons[currIndex - 1]) !== null && _b !== void 0 ? _b : buttons[buttons.length - 1];
95
- default:
96
- return null;
97
- }
98
- };
99
- }
100
- colorChanged(value, oldValue) {
101
- /**
102
- * If color is set after not having
103
- * previously been set (or vice versa),
104
- * we need to emit style so the segment-buttons
105
- * can apply their color classes properly.
106
- */
107
- if ((oldValue === undefined && value !== undefined) || (oldValue !== undefined && value === undefined)) {
108
- this.emitStyle();
109
- }
110
- }
111
- swipeGestureChanged() {
112
- this.gestureChanged();
113
- }
114
- valueChanged(value, oldValue) {
115
- // Force a value to exist if we're using a segment view
116
- if (this.segmentViewEl && value === undefined) {
117
- this.value = this.getButtons()[0].value;
118
- return;
119
- }
120
- if (oldValue !== undefined && value !== undefined) {
121
- const buttons = this.getButtons();
122
- const previous = buttons.find((button) => button.value === oldValue);
123
- const current = buttons.find((button) => button.value === value);
124
- if (previous && current) {
125
- if (!this.segmentViewEl) {
126
- this.checkButton(previous, current);
127
- }
128
- else if (this.triggerScrollOnValueChange !== false) {
129
- this.updateSegmentView();
130
- }
131
- }
132
- }
133
- else if (value !== undefined && oldValue === undefined && this.segmentViewEl) {
134
- this.updateSegmentView();
135
- }
136
- /**
137
- * `ionSelect` is emitted every time the value changes (internal or external changes).
138
- * Used by `ion-segment-button` to determine if the button should be checked.
139
- */
140
- this.ionSelect.emit({ value });
141
- // The scroll listener should handle scrolling the active button into view as needed
142
- if (!this.segmentViewEl) {
143
- this.scrollActiveButtonIntoView();
144
- }
145
- this.triggerScrollOnValueChange = undefined;
146
- }
147
- disabledChanged() {
148
- this.gestureChanged();
149
- if (!this.segmentViewEl) {
150
- const buttons = this.getButtons();
151
- for (const button of buttons) {
152
- button.disabled = this.disabled;
153
- }
154
- }
155
- else {
156
- this.segmentViewEl.disabled = this.disabled;
157
- }
158
- }
159
- gestureChanged() {
160
- if (this.gesture) {
161
- this.gesture.enable(!this.scrollable && !this.disabled && this.swipeGesture);
162
- }
163
- }
164
- connectedCallback() {
165
- this.emitStyle();
166
- this.segmentViewEl = this.getSegmentView();
167
- }
168
- disconnectedCallback() {
169
- this.segmentViewEl = null;
170
- }
171
- componentWillLoad() {
172
- this.emitStyle();
173
- }
174
- async componentDidLoad() {
175
- this.segmentViewEl = this.getSegmentView();
176
- this.setCheckedClasses();
177
- /**
178
- * We need to wait for the buttons to all be rendered
179
- * before we can scroll.
180
- */
181
- raf(() => {
182
- /**
183
- * When the segment loads for the first
184
- * time we just want to snap the active button into
185
- * place instead of scroll. Smooth scrolling should only
186
- * happen when the user interacts with the segment.
187
- */
188
- this.scrollActiveButtonIntoView(false);
189
- });
190
- this.gesture = (await import('./index3.js')).createGesture({
191
- el: this.el,
192
- gestureName: 'segment',
193
- gesturePriority: 100,
194
- threshold: 0,
195
- passive: false,
196
- onStart: (ev) => this.onStart(ev),
197
- onMove: (ev) => this.onMove(ev),
198
- onEnd: (ev) => this.onEnd(ev),
199
- });
200
- this.gestureChanged();
201
- if (this.disabled) {
202
- this.disabledChanged();
203
- }
204
- // Update segment view based on the initial value,
205
- // but do not animate the scroll
206
- this.updateSegmentView(false);
207
- }
208
- onStart(detail) {
209
- this.valueBeforeGesture = this.value;
210
- this.activate(detail);
211
- }
212
- onMove(detail) {
213
- this.setNextIndex(detail);
214
- }
215
- onEnd(detail) {
216
- this.setActivated(false);
217
- this.setNextIndex(detail, true);
218
- detail.event.stopImmediatePropagation();
219
- const value = this.value;
220
- if (value !== undefined) {
221
- if (this.valueBeforeGesture !== value) {
222
- this.emitValueChange();
223
- this.updateSegmentView();
224
- }
225
- }
226
- this.valueBeforeGesture = undefined;
227
- }
228
- /**
229
- * Emits an `ionChange` event.
230
- *
231
- * This API should be called for user committed changes.
232
- * This API should not be used for external value changes.
233
- */
234
- emitValueChange() {
235
- const { value } = this;
236
- this.ionChange.emit({ value });
237
- }
238
- getButtons() {
239
- return Array.from(this.el.querySelectorAll('ion-segment-button'));
240
- }
241
- get checked() {
242
- return this.getButtons().find((button) => button.value === this.value);
243
- }
244
- /*
245
- * Activate both the segment and the buttons
246
- * due to a bug with ::slotted in Safari
247
- */
248
- setActivated(activated) {
249
- const buttons = this.getButtons();
250
- buttons.forEach((button) => {
251
- button.classList.toggle('segment-button-activated', activated);
252
- });
253
- this.activated = activated;
254
- }
255
- activate(detail) {
256
- const clicked = detail.event.target;
257
- const buttons = this.getButtons();
258
- const checked = buttons.find((button) => button.value === this.value);
259
- // Make sure we are only checking for activation on a segment button
260
- // since disabled buttons will get the click on the segment
261
- if (clicked.tagName !== 'ION-SEGMENT-BUTTON') {
262
- return;
263
- }
264
- // If there are no checked buttons, set the current button to checked
265
- if (!checked) {
266
- this.value = clicked.value;
267
- this.setCheckedClasses();
268
- }
269
- // If the gesture began on the clicked button with the indicator
270
- // then we should activate the indicator
271
- if (this.value === clicked.value) {
272
- this.setActivated(true);
273
- }
274
- }
275
- getIndicator(button) {
276
- const root = button.shadowRoot || button;
277
- return root.querySelector('.segment-button-indicator');
278
- }
279
- checkButton(previous, current) {
280
- const previousIndicator = this.getIndicator(previous);
281
- const currentIndicator = this.getIndicator(current);
282
- if (previousIndicator === null || currentIndicator === null) {
283
- return;
284
- }
285
- const previousClientRect = previousIndicator.getBoundingClientRect();
286
- const currentClientRect = currentIndicator.getBoundingClientRect();
287
- const widthDelta = previousClientRect.width / currentClientRect.width;
288
- const xPosition = previousClientRect.left - currentClientRect.left;
289
- // Scale the indicator width to match the previous indicator width
290
- // and translate it on top of the previous indicator
291
- const transform = `translate3d(${xPosition}px, 0, 0) scaleX(${widthDelta})`;
292
- writeTask(() => {
293
- // Remove the transition before positioning on top of the previous indicator
294
- currentIndicator.classList.remove('segment-button-indicator-animated');
295
- currentIndicator.style.setProperty('transform', transform);
296
- // Force a repaint to ensure the transform happens
297
- currentIndicator.getBoundingClientRect();
298
- // Add the transition to move the indicator into place
299
- currentIndicator.classList.add('segment-button-indicator-animated');
300
- // Remove the transform to slide the indicator back to the button clicked
301
- currentIndicator.style.setProperty('transform', '');
302
- this.scrollActiveButtonIntoView(true);
303
- });
304
- this.value = current.value;
305
- this.setCheckedClasses();
306
- }
307
- setCheckedClasses() {
308
- const buttons = this.getButtons();
309
- const index = buttons.findIndex((button) => button.value === this.value);
310
- const next = index + 1;
311
- for (const button of buttons) {
312
- button.classList.remove('segment-button-after-checked');
313
- }
314
- if (next < buttons.length) {
315
- buttons[next].classList.add('segment-button-after-checked');
316
- }
317
- }
318
- getSegmentView() {
319
- const buttons = this.getButtons();
320
- // Get the first button with a contentId
321
- const firstContentId = buttons.find((button) => button.contentId);
322
- // Get the segment content with an id matching the button's contentId
323
- const segmentContent = document.querySelector(`ion-segment-content[id="${firstContentId === null || firstContentId === void 0 ? void 0 : firstContentId.contentId}"]`);
324
- // Return the segment view for that matching segment content
325
- return segmentContent === null || segmentContent === void 0 ? void 0 : segmentContent.closest('ion-segment-view');
326
- }
327
- handleSegmentViewScroll(ev) {
328
- const { scrollRatio, isManualScroll } = ev.detail;
329
- if (!isManualScroll) {
330
- return;
331
- }
332
- const dispatchedFrom = ev.target;
333
- const segmentViewEl = this.segmentViewEl;
334
- const segmentEl = this.el;
335
- // Only update the indicator if the event was dispatched from the correct segment view
336
- if (ev.composedPath().includes(segmentViewEl) || (dispatchedFrom === null || dispatchedFrom === void 0 ? void 0 : dispatchedFrom.contains(segmentEl))) {
337
- const buttons = this.getButtons();
338
- // If no buttons are found or there is no value set then do nothing
339
- if (!buttons.length)
340
- return;
341
- const index = buttons.findIndex((button) => button.value === this.value);
342
- const current = buttons[index];
343
- const nextIndex = Math.round(scrollRatio * (buttons.length - 1));
344
- if (this.lastNextIndex === undefined || this.lastNextIndex !== nextIndex) {
345
- this.lastNextIndex = nextIndex;
346
- this.triggerScrollOnValueChange = false;
347
- this.checkButton(current, buttons[nextIndex]);
348
- this.emitValueChange();
349
- }
350
- }
351
- }
352
- /**
353
- * Finds the related segment view and sets its current content
354
- * based on the selected segment button. This method
355
- * should be called on initial load of the segment,
356
- * after the gesture is completed (if dragging between segments)
357
- * and when a segment button is clicked directly.
358
- */
359
- updateSegmentView(smoothScroll = true) {
360
- const buttons = this.getButtons();
361
- const button = buttons.find((btn) => btn.value === this.value);
362
- // If the button does not have a contentId then there is
363
- // no associated segment view to update
364
- if (!(button === null || button === void 0 ? void 0 : button.contentId)) {
365
- return;
366
- }
367
- const segmentView = this.segmentViewEl;
368
- if (segmentView) {
369
- segmentView.setContent(button.contentId, smoothScroll);
370
- }
371
- }
372
- scrollActiveButtonIntoView(smoothScroll = true) {
373
- const { scrollable, value, el } = this;
374
- if (scrollable) {
375
- const buttons = this.getButtons();
376
- const activeButton = buttons.find((button) => button.value === value);
377
- if (activeButton !== undefined) {
378
- const scrollContainerBox = el.getBoundingClientRect();
379
- const activeButtonBox = activeButton.getBoundingClientRect();
380
- /**
381
- * Subtract the active button x position from the scroll
382
- * container x position. This will give us the x position
383
- * of the active button within the scroll container.
384
- */
385
- const activeButtonLeft = activeButtonBox.x - scrollContainerBox.x;
386
- /**
387
- * If we just used activeButtonLeft, then the active button
388
- * would be aligned with the left edge of the scroll container.
389
- * Instead, we want the segment button to be centered. As a result,
390
- * we subtract half of the scroll container width. This will position
391
- * the left edge of the active button at the midpoint of the scroll container.
392
- * We then add half of the active button width. This will position the active
393
- * button such that the midpoint of the active button is at the midpoint of the
394
- * scroll container.
395
- */
396
- const centeredX = activeButtonLeft - scrollContainerBox.width / 2 + activeButtonBox.width / 2;
397
- /**
398
- * newScrollPosition is the absolute scroll position that the
399
- * container needs to move to in order to center the active button.
400
- * It is calculated by adding the current scroll position
401
- * (scrollLeft) to the offset needed to center the button
402
- * (centeredX).
403
- */
404
- const newScrollPosition = el.scrollLeft + centeredX;
405
- /**
406
- * We intentionally use scrollTo here instead of scrollIntoView
407
- * to avoid a WebKit bug where accelerated animations break
408
- * when using scrollIntoView. Using scrollIntoView will cause the
409
- * segment container to jump during the transition and then snap into place.
410
- * This is because scrollIntoView can potentially cause parent element
411
- * containers to also scroll. scrollTo does not have this same behavior, so
412
- * we use this API instead.
413
- *
414
- * scrollTo is used instead of scrollBy because there is a
415
- * Webkit bug that causes scrollBy to not work smoothly when
416
- * the active button is near the edge of the scroll container.
417
- * This leads to the buttons to jump around during the transition.
418
- *
419
- * Note that if there is not enough scrolling space to center the element
420
- * within the scroll container, the browser will attempt
421
- * to center by as much as it can.
422
- */
423
- el.scrollTo({
424
- top: 0,
425
- left: newScrollPosition,
426
- behavior: smoothScroll ? 'smooth' : 'instant',
427
- });
428
- }
429
- }
430
- }
431
- setNextIndex(detail, isEnd = false) {
432
- const rtl = isRTL(this.el);
433
- const activated = this.activated;
434
- const buttons = this.getButtons();
435
- const index = buttons.findIndex((button) => button.value === this.value);
436
- const previous = buttons[index];
437
- let current;
438
- let nextIndex;
439
- if (index === -1) {
440
- return;
441
- }
442
- // Get the element that the touch event started on in case
443
- // it was the checked button, then we will move the indicator
444
- const rect = previous.getBoundingClientRect();
445
- const left = rect.left;
446
- const width = rect.width;
447
- // Get the element that the gesture is on top of based on the currentX of the
448
- // gesture event and the Y coordinate of the starting element, since the gesture
449
- // can move up and down off of the segment
450
- const currentX = detail.currentX;
451
- const previousY = rect.top + rect.height / 2;
452
- /**
453
- * Segment can be used inside the shadow dom
454
- * so doing document.elementFromPoint would never
455
- * return a segment button in that instance.
456
- * We use getRootNode to which will return the parent
457
- * shadow root if used inside a shadow component and
458
- * returns document otherwise.
459
- */
460
- const root = this.el.getRootNode();
461
- const nextEl = root.elementFromPoint(currentX, previousY);
462
- const decreaseIndex = rtl ? currentX > left + width : currentX < left;
463
- const increaseIndex = rtl ? currentX < left : currentX > left + width;
464
- // If the indicator is currently activated then we have started the gesture
465
- // on top of the checked button so we need to slide the indicator
466
- // by checking the button next to it as we move
467
- if (activated && !isEnd) {
468
- // Decrease index, move left in LTR & right in RTL
469
- if (decreaseIndex) {
470
- const newIndex = index - 1;
471
- if (newIndex >= 0) {
472
- nextIndex = newIndex;
473
- }
474
- // Increase index, moves right in LTR & left in RTL
475
- }
476
- else if (increaseIndex) {
477
- if (activated && !isEnd) {
478
- const newIndex = index + 1;
479
- if (newIndex < buttons.length) {
480
- nextIndex = newIndex;
481
- }
482
- }
483
- }
484
- if (nextIndex !== undefined && !buttons[nextIndex].disabled) {
485
- current = buttons[nextIndex];
486
- }
487
- }
488
- // If the indicator is not activated then we will just set the indicator
489
- // to the element where the gesture ended
490
- if (!activated && isEnd) {
491
- current = nextEl;
492
- }
493
- if (current != null) {
494
- /**
495
- * If current element is ion-segment then that means
496
- * user tried to select a disabled ion-segment-button,
497
- * and we should not update the ripple.
498
- */
499
- if (current.tagName === 'ION-SEGMENT') {
500
- return false;
501
- }
502
- if (previous !== current) {
503
- this.checkButton(previous, current);
504
- }
505
- }
506
- return true;
507
- }
508
- emitStyle() {
509
- this.ionStyle.emit({
510
- segment: true,
511
- });
512
- }
513
- onKeyDown(ev) {
514
- const rtl = isRTL(this.el);
515
- let keyDownSelectsButton = this.selectOnFocus;
516
- let current;
517
- switch (ev.key) {
518
- case 'ArrowRight':
519
- ev.preventDefault();
520
- current = rtl ? this.getSegmentButton('previous') : this.getSegmentButton('next');
521
- break;
522
- case 'ArrowLeft':
523
- ev.preventDefault();
524
- current = rtl ? this.getSegmentButton('next') : this.getSegmentButton('previous');
525
- break;
526
- case 'Home':
527
- ev.preventDefault();
528
- current = this.getSegmentButton('first');
529
- break;
530
- case 'End':
531
- ev.preventDefault();
532
- current = this.getSegmentButton('last');
533
- break;
534
- case ' ':
535
- case 'Enter':
536
- ev.preventDefault();
537
- current = document.activeElement;
538
- keyDownSelectsButton = true;
539
- }
540
- if (!current) {
541
- return;
542
- }
543
- if (keyDownSelectsButton) {
544
- const previous = this.checked;
545
- this.checkButton(previous || current, current);
546
- if (current !== previous) {
547
- this.emitValueChange();
548
- }
549
- }
550
- current.setFocus();
551
- }
552
- render() {
553
- const mode = getIonMode(this);
554
- return (h(Host, { key: 'e67ed512739cf2cfe657b0c44ebc3dfb1e9fbb79', role: "tablist", onClick: this.onClick, class: createColorClasses(this.color, {
555
- [mode]: true,
556
- 'in-toolbar': hostContext('ion-toolbar', this.el),
557
- 'in-toolbar-color': hostContext('ion-toolbar[color]', this.el),
558
- 'segment-activated': this.activated,
559
- 'segment-disabled': this.disabled,
560
- 'segment-scrollable': this.scrollable,
561
- }) }, h("slot", { key: '804d8acfcb9abfeeee38244b015fbc5c36330b9e', onSlotchange: this.onSlottedItemsChange })));
562
- }
563
- get el() { return this; }
564
- static get watchers() { return {
565
- "color": ["colorChanged"],
566
- "swipeGesture": ["swipeGestureChanged"],
567
- "value": ["valueChanged"],
568
- "disabled": ["disabledChanged"]
569
- }; }
570
- static get style() { return {
571
- ios: segmentIosCss,
572
- md: segmentMdCss
573
- }; }
574
- }, [289, "ion-segment", {
575
- "color": [513],
576
- "disabled": [4],
577
- "scrollable": [4],
578
- "swipeGesture": [4, "swipe-gesture"],
579
- "value": [1032],
580
- "selectOnFocus": [4, "select-on-focus"],
581
- "activated": [32]
582
- }, [[16, "ionSegmentViewScroll", "handleSegmentViewScroll"], [0, "keydown", "onKeyDown"]], {
583
- "color": ["colorChanged"],
584
- "swipeGesture": ["swipeGestureChanged"],
585
- "value": ["valueChanged"],
586
- "disabled": ["disabledChanged"]
587
- }]);
588
- function defineCustomElement$1() {
589
- if (typeof customElements === "undefined") {
590
- return;
591
- }
592
- const components = ["ion-segment"];
593
- components.forEach(tagName => { switch (tagName) {
594
- case "ion-segment":
595
- if (!customElements.get(tagName)) {
596
- customElements.define(tagName, Segment);
597
- }
598
- break;
599
- } });
600
- }
601
-
602
- const IonSegment = Segment;
603
- const defineCustomElement = defineCustomElement$1;
604
-
605
- export { IonSegment, defineCustomElement };
4
+ import{proxyCustomElement as t,HTMLElement as e,createEvent as s,writeTask as i,h as o,Host as n,transformTag as r}from"@stencil/core/internal/client";import{r as a}from"./helpers.js";import{i as h}from"./dir.js";import{c as l,h as c}from"./theme.js";import{b as d}from"./ionic-global.js";const u=t(class extends e{constructor(t){super(),!1!==t&&this.__registerHost(),this.__attachShadow(),this.ionChange=s(this,"ionChange",7),this.ionSelect=s(this,"ionSelect",7),this.ionStyle=s(this,"ionStyle",7),this.segmentViewEl=null,this.activated=!1,this.disabled=!1,this.scrollable=!1,this.swipeGesture=!0,this.selectOnFocus=!1,this.onClick=t=>{const e=t.target,s=this.checked;"ION-SEGMENT"!==e.tagName&&(this.value=e.value,e!==s&&this.emitValueChange(),this.segmentViewEl?(this.updateSegmentView(),this.scrollable&&s&&this.checkButton(s,e)):!this.scrollable&&this.swipeGesture||(s?this.checkButton(s,e):this.setCheckedClasses()))},this.onSlottedItemsChange=()=>{this.valueChanged(this.value)},this.getSegmentButton=t=>{var e,s;const i=this.getButtons().filter((t=>!t.disabled)),o=i.findIndex((t=>t===document.activeElement));switch(t){case"first":return i[0];case"last":return i[i.length-1];case"next":return null!==(e=i[o+1])&&void 0!==e?e:i[0];case"previous":return null!==(s=i[o-1])&&void 0!==s?s:i[i.length-1];default:return null}}}colorChanged(t,e){(void 0===e&&void 0!==t||void 0!==e&&void 0===t)&&this.emitStyle()}swipeGestureChanged(){this.gestureChanged()}valueChanged(t,e){if(this.segmentViewEl&&void 0===t)this.value=this.getButtons()[0].value;else{if(void 0!==e&&void 0!==t){const s=this.getButtons(),i=s.find((t=>t.value===e)),o=s.find((e=>e.value===t));i&&o&&(this.segmentViewEl?!1!==this.triggerScrollOnValueChange&&this.updateSegmentView():this.checkButton(i,o))}else void 0!==t&&void 0===e&&this.segmentViewEl&&this.updateSegmentView();this.ionSelect.emit({value:t}),this.segmentViewEl||this.scrollActiveButtonIntoView(),this.triggerScrollOnValueChange=void 0}}disabledChanged(){if(this.gestureChanged(),this.segmentViewEl)this.segmentViewEl.disabled=this.disabled;else{const t=this.getButtons();for(const e of t)e.disabled=this.disabled}}gestureChanged(){this.gesture&&this.gesture.enable(!this.scrollable&&!this.disabled&&this.swipeGesture)}connectedCallback(){this.emitStyle(),this.segmentViewEl=this.getSegmentView()}disconnectedCallback(){this.segmentViewEl=null}componentWillLoad(){this.emitStyle()}async componentDidLoad(){this.segmentViewEl=this.getSegmentView(),this.setCheckedClasses(),a((()=>{this.scrollActiveButtonIntoView(!1)})),this.gesture=(await import("./index3.js")).createGesture({el:this.el,gestureName:"segment",gesturePriority:100,threshold:0,passive:!1,onStart:t=>this.onStart(t),onMove:t=>this.onMove(t),onEnd:t=>this.onEnd(t)}),this.gestureChanged(),this.disabled&&this.disabledChanged(),this.updateSegmentView(!1)}onStart(t){this.valueBeforeGesture=this.value,this.activate(t)}onMove(t){this.setNextIndex(t)}onEnd(t){this.setActivated(!1),this.setNextIndex(t,!0),t.event.stopImmediatePropagation();const e=this.value;void 0!==e&&this.valueBeforeGesture!==e&&(this.emitValueChange(),this.updateSegmentView()),this.valueBeforeGesture=void 0}emitValueChange(){const{value:t}=this;this.ionChange.emit({value:t})}getButtons(){return Array.from(this.el.querySelectorAll("ion-segment-button"))}get checked(){return this.getButtons().find((t=>t.value===this.value))}setActivated(t){this.getButtons().forEach((e=>{e.classList.toggle("segment-button-activated",t)})),this.activated=t}activate(t){const e=t.event.target,s=this.getButtons().find((t=>t.value===this.value));"ION-SEGMENT-BUTTON"===e.tagName&&(s||(this.value=e.value,this.setCheckedClasses()),this.value===e.value&&this.setActivated(!0))}getIndicator(t){return(t.shadowRoot||t).querySelector(".segment-button-indicator")}checkButton(t,e){const s=this.getIndicator(t),o=this.getIndicator(e);if(null===s||null===o)return;const n=s.getBoundingClientRect(),r=o.getBoundingClientRect(),a=`translate3d(${n.left-r.left}px, 0, 0) scaleX(${n.width/r.width})`;i((()=>{o.classList.remove("segment-button-indicator-animated"),o.style.setProperty("transform",a),o.getBoundingClientRect(),o.classList.add("segment-button-indicator-animated"),o.style.setProperty("transform",""),this.scrollActiveButtonIntoView(!0)})),this.value=e.value,this.setCheckedClasses()}setCheckedClasses(){const t=this.getButtons(),e=t.findIndex((t=>t.value===this.value))+1;for(const e of t)e.classList.remove("segment-button-after-checked");e<t.length&&t[e].classList.add("segment-button-after-checked")}getSegmentView(){const t=this.getButtons().find((t=>t.contentId)),e=document.querySelector(`ion-segment-content[id="${null==t?void 0:t.contentId}"]`);return null==e?void 0:e.closest("ion-segment-view")}handleSegmentViewScroll(t){const{scrollRatio:e,isManualScroll:s}=t.detail;if(!s)return;const i=t.target,o=this.segmentViewEl,n=this.el;if(t.composedPath().includes(o)||(null==i?void 0:i.contains(n))){const t=this.getButtons();if(!t.length)return;const s=t.findIndex((t=>t.value===this.value)),i=t[s],o=Math.round(e*(t.length-1));void 0!==this.lastNextIndex&&this.lastNextIndex===o||(this.lastNextIndex=o,this.triggerScrollOnValueChange=!1,this.checkButton(i,t[o]),this.emitValueChange())}}updateSegmentView(t=!0){const e=this.getButtons().find((t=>t.value===this.value));if(!(null==e?void 0:e.contentId))return;const s=this.segmentViewEl;s&&s.setContent(e.contentId,t)}scrollActiveButtonIntoView(t=!0){const{scrollable:e,value:s,el:i}=this;if(e){const e=this.getButtons().find((t=>t.value===s));if(void 0!==e){const s=i.getBoundingClientRect(),o=e.getBoundingClientRect();i.scrollTo({top:0,left:i.scrollLeft+(o.x-s.x-s.width/2+o.width/2),behavior:t?"smooth":"instant"})}}}setNextIndex(t,e=!1){const s=h(this.el),i=this.activated,o=this.getButtons(),n=o.findIndex((t=>t.value===this.value)),r=o[n];let a,l;if(-1===n)return;const c=r.getBoundingClientRect(),d=c.left,u=c.width,m=t.currentX,g=c.top+c.height/2,b=this.el.getRootNode().elementFromPoint(m,g);if(i&&!e){if(s?m>d+u:m<d){const t=n-1;t>=0&&(l=t)}else if((s?m<d:m>d+u)&&i&&!e){const t=n+1;t<o.length&&(l=t)}void 0===l||o[l].disabled||(a=o[l])}if(!i&&e&&(a=b),null!=a){if("ION-SEGMENT"===a.tagName)return!1;r!==a&&this.checkButton(r,a)}return!0}emitStyle(){this.ionStyle.emit({segment:!0})}onKeyDown(t){const e=h(this.el);let s,i=this.selectOnFocus;switch(t.key){case"ArrowRight":t.preventDefault(),s=this.getSegmentButton(e?"previous":"next");break;case"ArrowLeft":t.preventDefault(),s=this.getSegmentButton(e?"next":"previous");break;case"Home":t.preventDefault(),s=this.getSegmentButton("first");break;case"End":t.preventDefault(),s=this.getSegmentButton("last");break;case" ":case"Enter":t.preventDefault(),s=document.activeElement,i=!0}if(s){if(i){const t=this.checked;this.checkButton(t||s,s),s!==t&&this.emitValueChange()}s.setFocus()}}render(){const t=d(this);return o(n,{key:"e67ed512739cf2cfe657b0c44ebc3dfb1e9fbb79",role:"tablist",onClick:this.onClick,class:l(this.color,{[t]:!0,"in-toolbar":c("ion-toolbar",this.el),"in-toolbar-color":c("ion-toolbar[color]",this.el),"segment-activated":this.activated,"segment-disabled":this.disabled,"segment-scrollable":this.scrollable})},o("slot",{key:"804d8acfcb9abfeeee38244b015fbc5c36330b9e",onSlotchange:this.onSlottedItemsChange}))}get el(){return this}static get watchers(){return{color:[{colorChanged:0}],swipeGesture:[{swipeGestureChanged:0}],value:[{valueChanged:0}],disabled:[{disabledChanged:0}]}}static get style(){return{ios:":host{--ripple-color:currentColor;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:grid;grid-auto-columns:1fr;position:relative;-ms-flex-align:stretch;align-items:stretch;-ms-flex-pack:center;justify-content:center;width:100%;background:var(--background);font-family:var(--ion-font-family, inherit);text-align:center;contain:paint;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host(.segment-scrollable){-ms-flex-pack:start;justify-content:start;width:auto;overflow-x:auto;grid-auto-columns:minmax(-webkit-min-content, 1fr);grid-auto-columns:minmax(min-content, 1fr)}:host(.segment-scrollable::-webkit-scrollbar){display:none}:host{--background:rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.065);border-radius:8px;overflow:hidden;z-index:0}:host(.ion-color){background:rgba(var(--ion-color-base-rgb), 0.065)}:host(.in-toolbar){-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0;width:auto}:host(.in-toolbar:not(.ion-color)){background:var(--ion-toolbar-segment-background, var(--background))}:host(.in-toolbar-color:not(.ion-color)){background:rgba(var(--ion-color-contrast-rgb), 0.11)}",md:":host{--ripple-color:currentColor;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:grid;grid-auto-columns:1fr;position:relative;-ms-flex-align:stretch;align-items:stretch;-ms-flex-pack:center;justify-content:center;width:100%;background:var(--background);font-family:var(--ion-font-family, inherit);text-align:center;contain:paint;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host(.segment-scrollable){-ms-flex-pack:start;justify-content:start;width:auto;overflow-x:auto;grid-auto-columns:minmax(-webkit-min-content, 1fr);grid-auto-columns:minmax(min-content, 1fr)}:host(.segment-scrollable::-webkit-scrollbar){display:none}:host{--background:transparent;grid-auto-columns:minmax(auto, 360px)}:host(.in-toolbar){min-height:var(--min-height)}:host(.segment-scrollable) ::slotted(ion-segment-button){min-width:auto}"}}},[289,"ion-segment",{color:[513],disabled:[4],scrollable:[4],swipeGesture:[4,"swipe-gesture"],value:[1032],selectOnFocus:[4,"select-on-focus"],activated:[32]},[[16,"ionSegmentViewScroll","handleSegmentViewScroll"],[0,"keydown","onKeyDown"]],{color:[{colorChanged:0}],swipeGesture:[{swipeGestureChanged:0}],value:[{valueChanged:0}],disabled:[{disabledChanged:0}]}]),m=u,g=function(){"undefined"!=typeof customElements&&["ion-segment"].forEach((t=>{"ion-segment"===t&&(customElements.get(r(t))||customElements.define(r(t),u))}))};export{m as IonSegment,g as defineCustomElement}
@@ -1,9 +1,4 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { S as SelectModal, d as defineCustomElement$1 } from './select-modal.js';
5
-
6
- const IonSelectModal = SelectModal;
7
- const defineCustomElement = defineCustomElement$1;
8
-
9
- export { IonSelectModal, defineCustomElement };
4
+ import{S as o,d as s}from"./select-modal.js";const t=o,a=s;export{t as IonSelectModal,a as defineCustomElement}