@ionic/core 8.7.18 → 8.7.19-dev.11772655618.1af0949f

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 (587) hide show
  1. package/components/index.d.ts +2 -0
  2. package/components/index.js +1 -114
  3. package/components/ion-accordion-group.js +1 -268
  4. package/components/ion-accordion.js +1 -456
  5. package/components/ion-action-sheet.js +1 -6
  6. package/components/ion-alert.js +1 -6
  7. package/components/ion-app.js +1 -132
  8. package/components/ion-avatar.js +1 -41
  9. package/components/ion-back-button.js +1 -130
  10. package/components/ion-backdrop.js +1 -6
  11. package/components/ion-badge.js +1 -47
  12. package/components/ion-breadcrumb.js +1 -137
  13. package/components/ion-breadcrumbs.js +1 -164
  14. package/components/ion-button.js +1 -6
  15. package/components/ion-buttons.js +1 -6
  16. package/components/ion-card-content.js +1 -45
  17. package/components/ion-card-header.js +1 -56
  18. package/components/ion-card-subtitle.js +1 -48
  19. package/components/ion-card-title.js +1 -48
  20. package/components/ion-card.js +1 -107
  21. package/components/ion-checkbox.js +1 -6
  22. package/components/ion-chip.js +1 -66
  23. package/components/ion-col.js +1 -163
  24. package/components/ion-content.js +1 -6
  25. package/components/ion-datetime-button.js +1 -383
  26. package/components/ion-datetime.js +1 -2047
  27. package/components/ion-fab-button.js +1 -151
  28. package/components/ion-fab-list.js +1 -73
  29. package/components/ion-fab.js +1 -101
  30. package/components/ion-footer.js +1 -179
  31. package/components/ion-grid.js +1 -46
  32. package/components/ion-header.js +1 -6
  33. package/components/ion-icon.js +1 -6
  34. package/components/ion-img.js +1 -133
  35. package/components/ion-infinite-scroll-content.js +1 -69
  36. package/components/ion-infinite-scroll.js +1 -236
  37. package/components/ion-input-otp.js +1 -682
  38. package/components/ion-input-password-toggle.js +1 -128
  39. package/components/ion-input.js +1 -646
  40. package/components/ion-item-divider.js +1 -59
  41. package/components/ion-item-group.js +1 -46
  42. package/components/ion-item-option.js +1 -91
  43. package/components/ion-item-options.js +1 -73
  44. package/components/ion-item-sliding.js +1 -457
  45. package/components/ion-item.js +1 -6
  46. package/components/ion-label.js +1 -6
  47. package/components/ion-list-header.js +1 -6
  48. package/components/ion-list.js +1 -6
  49. package/components/ion-loading.js +1 -343
  50. package/components/ion-menu-button.js +1 -109
  51. package/components/ion-menu-toggle.js +1 -64
  52. package/components/ion-menu.js +1 -741
  53. package/components/ion-modal.js +1 -6
  54. package/components/ion-nav-link.js +1 -64
  55. package/components/ion-nav.js +1 -951
  56. package/components/ion-note.js +1 -47
  57. package/components/ion-picker-column-option.js +1 -6
  58. package/components/ion-picker-column.js +1 -6
  59. package/components/ion-picker-legacy-column.js +1 -6
  60. package/components/ion-picker-legacy.js +1 -342
  61. package/components/ion-picker.js +1 -6
  62. package/components/ion-popover.js +1 -6
  63. package/components/ion-progress-bar.js +1 -100
  64. package/components/ion-radio-group.js +1 -6
  65. package/components/ion-radio.js +1 -6
  66. package/components/ion-range.js +1 -844
  67. package/components/ion-refresher-content.js +1 -88
  68. package/components/ion-refresher.js +1 -750
  69. package/components/ion-reorder-group.js +1 -322
  70. package/components/ion-reorder.js +1 -60
  71. package/components/ion-ripple-effect.js +1 -6
  72. package/components/ion-route-redirect.js +1 -45
  73. package/components/ion-route.js +1 -74
  74. package/components/ion-router-link.js +1 -61
  75. package/components/ion-router-outlet.js +1 -226
  76. package/components/ion-router.js +1 -840
  77. package/components/ion-row.js +1 -36
  78. package/components/ion-searchbar.js +1 -540
  79. package/components/ion-segment-button.js +1 -173
  80. package/components/ion-segment-content.js +1 -35
  81. package/components/ion-segment-view.js +1 -142
  82. package/components/ion-segment.js +1 -602
  83. package/components/ion-select-modal.js +1 -6
  84. package/components/ion-select-option.js +1 -46
  85. package/components/ion-select-popover.js +1 -6
  86. package/components/ion-select.js +1 -1035
  87. package/components/ion-skeleton-text.js +1 -64
  88. package/components/ion-spinner.js +1 -6
  89. package/components/ion-split-pane.js +1 -190
  90. package/components/ion-tab-bar.js +1 -135
  91. package/components/ion-tab-button.js +1 -127
  92. package/components/ion-tab.js +1 -82
  93. package/components/ion-tabs.js +1 -204
  94. package/components/ion-text.js +1 -42
  95. package/components/ion-textarea.js +1 -554
  96. package/components/ion-thumbnail.js +1 -36
  97. package/components/ion-title.js +1 -6
  98. package/components/ion-toast.js +1 -938
  99. package/components/ion-toggle.js +1 -360
  100. package/components/ion-toolbar.js +1 -6
  101. package/components/p-1KVKSLu5.js +4 -0
  102. package/{dist/ionic/p-DUt5fQmA.js → components/p-9VcRUwdB.js} +1 -1
  103. package/components/p-ApmKVjaE.js +4 -0
  104. package/components/p-B-hirT0v.js +1 -35
  105. package/components/p-B6FQ0cKR.js +4 -0
  106. package/components/p-B6HaBl3o.js +4 -0
  107. package/components/p-B8b1Ukl9.js +4 -0
  108. package/components/p-BFxT89Wl.js +4 -0
  109. package/components/p-BJoMtgfR.js +4 -0
  110. package/components/p-BNAG-aVv.js +4 -0
  111. package/{dist/ionic/p-D-eFFUkA.js → components/p-BR3tZJmu.js} +1 -1
  112. package/{dist/ionic/p-D0dMcSkw.js → components/p-BS1TtEiJ.js} +1 -1
  113. package/components/p-BSB38Tek.js +4 -0
  114. package/components/p-BTEOs1at.js +1 -192
  115. package/components/p-BTeL5HCK.js +4 -0
  116. package/{dist/ionic/p-DbQ5QkTP.js → components/p-BUbsoBOV.js} +1 -1
  117. package/components/p-BVnB3eEn.js +4 -0
  118. package/components/p-BYDc3hSE.js +4 -0
  119. package/components/p-BagjAGC0.js +4 -0
  120. package/components/p-BegtE7nr.js +4 -0
  121. package/components/p-BgwEQWW6.js +4 -0
  122. package/components/p-Bk2zuNWT.js +4 -0
  123. package/components/p-BmVRXR1y.js +1 -72
  124. package/components/p-Bum_LjMh.js +4 -0
  125. package/components/p-BxwWvu-b.js +4 -0
  126. package/components/p-C4jPsTQa.js +4 -0
  127. package/components/p-C53feagD.js +1 -15
  128. package/{dist/ionic/p-CwgG81ZD.js → components/p-C59ryAuS.js} +1 -1
  129. package/components/p-C7AoMl7c.js +4 -0
  130. package/components/p-CBzELu-H.js +4 -0
  131. package/components/p-CDfQnFrd.js +4 -0
  132. package/components/p-CH0NYjKq.js +4 -0
  133. package/components/p-CIGNaXM1.js +1 -10
  134. package/components/p-CO7fmmxt.js +1 -29
  135. package/components/p-CU1SSH8_.js +4 -0
  136. package/components/p-CVF7ukTk.js +4 -0
  137. package/components/p-CgfaEEem.js +4 -0
  138. package/components/p-CgqKJg96.js +4 -0
  139. package/components/p-Cl0B-RWe.js +1 -452
  140. package/components/p-CneGxKsZ.js +4 -0
  141. package/components/p-CoA-aqGF.js +4 -0
  142. package/{dist/ionic/p-DdR6rpbR.js → components/p-Cq8cQ0NL.js} +1 -1
  143. package/components/p-Csw8xuz4.js +4 -0
  144. package/components/p-CtWGkNnJ.js +1 -162
  145. package/components/p-Cwv-vmkN.js +4 -0
  146. package/{dist/ionic/p-BYEqWnSg.js → components/p-Cy5XSfIk.js} +1 -1
  147. package/components/p-Cyxa_4PV.js +4 -0
  148. package/components/p-Cz5nLPGT.js +4 -0
  149. package/components/p-D13Eaw-8.js +1 -76
  150. package/components/p-D6NJwNJN.js +4 -0
  151. package/components/p-D6Ynv7Xh.js +1 -141
  152. package/components/p-DHsZWn1l.js +4 -0
  153. package/components/p-DJMZehmW.js +4 -0
  154. package/components/p-DJztqcrH.js +1 -14
  155. package/components/p-DYdpXONG.js +4 -0
  156. package/components/p-DgbT0exM.js +4 -0
  157. package/components/p-DiVJyqlX.js +1 -40
  158. package/components/p-Dtdm8lKC.js +1 -44
  159. package/components/p-YLXPWgVj.js +4 -0
  160. package/components/p-ZjP4CjeZ.js +1 -4
  161. package/{dist/ionic/p-DCv9sLH2.js → components/p-ak_d-z48.js} +1 -1
  162. package/components/p-cyNmxje6.js +1 -155
  163. package/components/p-fpbh6w3f.js +4 -0
  164. package/components/p-hHmYLOfE.js +1 -87
  165. package/components/p-kvaDs24J.js +4 -0
  166. package/components/p-vEbVo2hO.js +4 -0
  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-CuMghsQ-.js → input-shims-Dl5cnc_e.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 +48 -43
  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 +75 -46
  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 +19 -17
  205. package/dist/cjs/ion-item_8.cjs.entry.js +48 -42
  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 +237 -59
  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 +205 -57
  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 +13 -8
  224. package/dist/cjs/ion-segment_2.cjs.entry.js +26 -16
  225. package/dist/cjs/ion-select-modal.cjs.entry.js +17 -13
  226. package/dist/cjs/ion-select_3.cjs.entry.js +33 -24
  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 +20 -14
  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 +12 -7
  260. package/dist/collection/components/datetime/datetime.js +43 -22
  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 +10 -5
  268. package/dist/collection/components/item-divider/item-divider.js +7 -3
  269. package/dist/collection/components/item-option/item-option.js +6 -3
  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 +6 -3
  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 +120 -12
  278. package/dist/collection/components/modal/gestures/swipe-to-close.js +54 -1
  279. package/dist/collection/components/modal/modal.js +127 -45
  280. package/dist/collection/components/nav/nav.js +89 -45
  281. package/dist/collection/components/nav-link/nav-link.js +9 -5
  282. package/dist/collection/components/note/note.js +2 -1
  283. package/dist/collection/components/picker/picker.js +2 -1
  284. package/dist/collection/components/picker-column/picker-column.js +6 -3
  285. package/dist/collection/components/picker-column-option/picker-column-option.js +2 -1
  286. package/dist/collection/components/picker-legacy/picker.js +24 -12
  287. package/dist/collection/components/picker-legacy-column/picker-column.js +4 -2
  288. package/dist/collection/components/popover/popover.js +33 -17
  289. package/dist/collection/components/progress-bar/progress-bar.js +2 -1
  290. package/dist/collection/components/radio/radio.js +2 -1
  291. package/dist/collection/components/radio-group/radio-group.js +6 -3
  292. package/dist/collection/components/range/range.js +214 -53
  293. package/dist/collection/components/refresher/refresher.js +73 -5
  294. package/dist/collection/components/refresher-content/refresher-content.js +8 -4
  295. package/dist/collection/components/reorder-group/reorder-group.js +6 -3
  296. package/dist/collection/components/route/route.js +4 -2
  297. package/dist/collection/components/router/router.js +10 -5
  298. package/dist/collection/components/router-link/router-link.js +6 -3
  299. package/dist/collection/components/router-outlet/router-outlet.js +18 -9
  300. package/dist/collection/components/searchbar/searchbar.js +11 -6
  301. package/dist/collection/components/segment/segment.js +10 -5
  302. package/dist/collection/components/segment-button/segment-button.js +4 -2
  303. package/dist/collection/components/segment-view/segment-view.ios.css +2 -1
  304. package/dist/collection/components/segment-view/segment-view.js +30 -4
  305. package/dist/collection/components/segment-view/segment-view.md.css +2 -1
  306. package/dist/collection/components/select/select.js +17 -8
  307. package/dist/collection/components/select-modal/select-modal.js +27 -2
  308. package/dist/collection/components/select-popover/select-popover.js +2 -1
  309. package/dist/collection/components/skeleton-text/skeleton-text.js +2 -1
  310. package/dist/collection/components/spinner/spinner.js +4 -2
  311. package/dist/collection/components/tab/tab.js +4 -2
  312. package/dist/collection/components/tab-bar/tab-bar.js +4 -2
  313. package/dist/collection/components/tab-button/tab-button.js +4 -2
  314. package/dist/collection/components/tabs/tabs.js +4 -2
  315. package/dist/collection/components/text/text.js +2 -1
  316. package/dist/collection/components/textarea/textarea.js +10 -7
  317. package/dist/collection/components/title/title.js +4 -2
  318. package/dist/collection/components/toast/toast.js +34 -17
  319. package/dist/collection/components/toggle/toggle.js +4 -2
  320. package/dist/collection/components/toolbar/toolbar.js +2 -1
  321. package/dist/docs.d.ts +37 -0
  322. package/dist/docs.json +1186 -389
  323. package/dist/esm/{animation-Dt8bGnA-.js → animation-CnGMT4ji.js} +1 -1
  324. package/dist/esm/app-globals-DhZjtldk.js +9 -0
  325. package/dist/esm/{button-active-L570Swow.js → button-active-BBx21brx.js} +1 -1
  326. package/dist/esm/{config-mCdtaoPe.js → config-TO1rZH52.js} +1 -1
  327. package/dist/esm/{data-DCORV9FH.js → data-B9iGR5YO.js} +1 -1
  328. package/dist/esm/{framework-delegate-BYawdMXj.js → framework-delegate-CyxE1S_P.js} +1 -1
  329. package/dist/esm/{hardware-back-button-CPLxO-Ev.js → hardware-back-button-CTe4XmL7.js} +1 -1
  330. package/dist/esm/{helpers-DEn3pfjm.js → helpers-Tl8jw6S2.js} +1 -1
  331. package/dist/esm/{index-r2D9DEro.js → index-B-hkiOUh.js} +4 -4
  332. package/dist/esm/{index-CvDIirVx.js → index-B2KwgBLx.js} +5 -5
  333. package/dist/esm/{index-ceb5RaMT.js → index-BtUdxPjv.js} +2 -2
  334. package/dist/esm/{index-C8IsBmNU.js → index-IGIE5vDm.js} +503 -382
  335. package/dist/esm/{index-Bs3kT4bc.js → index-hW6eNZ3o.js} +2 -2
  336. package/dist/esm/index.js +12 -12
  337. package/dist/esm/{input-shims-D6H3ZaWt.js → input-shims-AaDhOpKN.js} +3 -3
  338. package/dist/esm/{input.utils-DrvTa8gz.js → input.utils-Bxa_DQ7-.js} +2 -2
  339. package/dist/esm/ion-accordion_2.entry.js +23 -15
  340. package/dist/esm/ion-action-sheet.entry.js +21 -15
  341. package/dist/esm/ion-alert.entry.js +25 -17
  342. package/dist/esm/ion-app_8.entry.js +48 -43
  343. package/dist/esm/ion-avatar_3.entry.js +12 -12
  344. package/dist/esm/ion-back-button.entry.js +7 -7
  345. package/dist/esm/ion-backdrop.entry.js +6 -6
  346. package/dist/esm/ion-breadcrumb_2.entry.js +20 -14
  347. package/dist/esm/ion-button_2.entry.js +36 -18
  348. package/dist/esm/ion-card_5.entry.js +23 -23
  349. package/dist/esm/ion-checkbox.entry.js +7 -7
  350. package/dist/esm/ion-chip.entry.js +6 -6
  351. package/dist/esm/ion-col_3.entry.js +8 -8
  352. package/dist/esm/ion-datetime-button.entry.js +8 -8
  353. package/dist/esm/ion-datetime_3.entry.js +75 -46
  354. package/dist/esm/ion-fab_3.entry.js +17 -13
  355. package/dist/esm/ion-img.entry.js +8 -6
  356. package/dist/esm/ion-infinite-scroll_2.entry.js +17 -13
  357. package/dist/esm/ion-input-otp.entry.js +16 -10
  358. package/dist/esm/ion-input-password-toggle.entry.js +9 -7
  359. package/dist/esm/ion-input.entry.js +21 -13
  360. package/dist/esm/ion-item-option_3.entry.js +19 -17
  361. package/dist/esm/ion-item_8.entry.js +48 -42
  362. package/dist/esm/ion-loading.entry.js +18 -14
  363. package/dist/esm/ion-menu_3.entry.js +30 -22
  364. package/dist/esm/ion-modal.entry.js +237 -59
  365. package/dist/esm/ion-nav_2.entry.js +14 -10
  366. package/dist/esm/ion-picker-column-option.entry.js +10 -8
  367. package/dist/esm/ion-picker-column.entry.js +11 -7
  368. package/dist/esm/ion-picker.entry.js +6 -6
  369. package/dist/esm/ion-popover.entry.js +21 -15
  370. package/dist/esm/ion-progress-bar.entry.js +7 -7
  371. package/dist/esm/ion-radio_2.entry.js +17 -13
  372. package/dist/esm/ion-range.entry.js +205 -57
  373. package/dist/esm/ion-refresher_2.entry.js +45 -14
  374. package/dist/esm/ion-reorder_2.entry.js +13 -11
  375. package/dist/esm/ion-ripple-effect.entry.js +4 -4
  376. package/dist/esm/ion-route_4.entry.js +20 -10
  377. package/dist/esm/ion-searchbar.entry.js +22 -12
  378. package/dist/esm/ion-segment-content.entry.js +3 -3
  379. package/dist/esm/ion-segment-view.entry.js +13 -8
  380. package/dist/esm/ion-segment_2.entry.js +26 -16
  381. package/dist/esm/ion-select-modal.entry.js +17 -13
  382. package/dist/esm/ion-select_3.entry.js +33 -24
  383. package/dist/esm/ion-spinner.entry.js +4 -4
  384. package/dist/esm/ion-split-pane.entry.js +15 -9
  385. package/dist/esm/ion-tab-bar_2.entry.js +14 -12
  386. package/dist/esm/ion-tab_2.entry.js +10 -8
  387. package/dist/esm/ion-text.entry.js +4 -4
  388. package/dist/esm/ion-textarea.entry.js +20 -14
  389. package/dist/esm/ion-toast.entry.js +21 -15
  390. package/dist/esm/ion-toggle.entry.js +10 -8
  391. package/dist/esm/{ionic-global-CDrldh-5.js → ionic-global-DfbeLwcV.js} +1 -1
  392. package/dist/esm/ionic.js +6 -6
  393. package/dist/esm/{ios.transition-BDzw0_Hm.js → ios.transition--aMF-pDH.js} +4 -4
  394. package/dist/esm/loader.js +5 -5
  395. package/dist/esm/{md.transition-BzDYi3qq.js → md.transition-BEVbfm8j.js} +4 -4
  396. package/dist/esm/{notch-controller-BwelN_JM.js → notch-controller-DAcvKU57.js} +1 -1
  397. package/dist/esm/{overlays-D5YkFThA.js → overlays-F8GHPo-e.js} +5 -5
  398. package/dist/esm/{status-tap-5DQ7Fc4V.js → status-tap-BfJqFSLF.js} +3 -3
  399. package/dist/esm/{swipe-back-BKw2CAHc.js → swipe-back-BZBFwTQV.js} +2 -2
  400. package/dist/html.html-data.json +117 -109
  401. package/dist/ionic/index.esm.js +1 -1
  402. package/dist/ionic/ionic.esm.js +1 -1
  403. package/dist/ionic/p-031b76f7.entry.js +4 -0
  404. package/dist/ionic/p-045a6a42.entry.js +4 -0
  405. package/dist/ionic/p-07506134.entry.js +4 -0
  406. package/dist/ionic/p-084c25b2.entry.js +4 -0
  407. package/dist/ionic/p-0d8b5c38.entry.js +4 -0
  408. package/dist/ionic/p-16813ce7.entry.js +4 -0
  409. package/dist/ionic/p-16b65553.entry.js +4 -0
  410. package/dist/ionic/p-1b02923f.entry.js +4 -0
  411. package/dist/ionic/{p-5c8f7253.entry.js → p-1b169fb6.entry.js} +1 -1
  412. package/dist/ionic/{p-915b3e3d.entry.js → p-23fac490.entry.js} +1 -1
  413. package/dist/ionic/{p-b8551510.entry.js → p-294f4bb5.entry.js} +1 -1
  414. package/dist/ionic/p-2a68388b.entry.js +4 -0
  415. package/dist/ionic/p-2f5a8140.entry.js +4 -0
  416. package/dist/ionic/{p-49d06882.entry.js → p-301c43f8.entry.js} +1 -1
  417. package/dist/ionic/{p-79bd78f9.entry.js → p-370a60ee.entry.js} +1 -1
  418. package/dist/ionic/p-3e143d1d.entry.js +4 -0
  419. package/dist/ionic/p-4819b469.entry.js +4 -0
  420. package/dist/ionic/p-4dd5e8e0.entry.js +4 -0
  421. package/dist/ionic/p-51c11c47.entry.js +4 -0
  422. package/dist/ionic/p-53f750a5.entry.js +4 -0
  423. package/dist/ionic/{p-7cad388a.entry.js → p-6af16209.entry.js} +1 -1
  424. package/dist/ionic/{p-7f98e710.entry.js → p-6b701daa.entry.js} +1 -1
  425. package/dist/ionic/p-6b97f2a3.entry.js +4 -0
  426. package/dist/ionic/p-71e322f7.entry.js +4 -0
  427. package/dist/ionic/p-7620be24.entry.js +4 -0
  428. package/dist/ionic/p-771b27a5.entry.js +4 -0
  429. package/dist/ionic/{p-906bb44d.entry.js → p-7ca71c83.entry.js} +1 -1
  430. package/dist/ionic/{p-11aa58d6.entry.js → p-80cac7a2.entry.js} +1 -1
  431. package/dist/ionic/p-96a2e768.entry.js +4 -0
  432. package/dist/ionic/{p-582824c5.entry.js → p-9833cf63.entry.js} +1 -1
  433. package/dist/ionic/p-9cbc6f1f.entry.js +4 -0
  434. package/dist/ionic/p-9cdbabbb.entry.js +4 -0
  435. package/dist/ionic/p-9eac4eb1.entry.js +4 -0
  436. package/dist/ionic/{p-675b1a31.entry.js → p-9fae83d8.entry.js} +1 -1
  437. package/dist/ionic/p-B8xlpH8p.js +4 -0
  438. package/dist/ionic/{p-C7hRNDhM.js → p-BAt5H1ac.js} +1 -1
  439. package/dist/ionic/p-BW_TRJm8.js +4 -0
  440. package/dist/ionic/{p-DDb5r57F.js → p-Bum7H1fw.js} +1 -1
  441. package/dist/ionic/p-BvFYtOdE.js +4 -0
  442. package/dist/ionic/{p-Dc45iWE4.js → p-BxIcPWoV.js} +1 -1
  443. package/dist/ionic/p-C0JvVFMv.js +4 -0
  444. package/dist/ionic/{p-CTfR9YZG.js → p-CGmVTdWh.js} +1 -1
  445. package/dist/ionic/{p-BOVrCkpJ.js → p-CYbRmDdy.js} +1 -1
  446. package/dist/ionic/{p-MUoJJJwd.js → p-CYvM5g3q.js} +1 -1
  447. package/dist/ionic/p-CmFz1Mjc.js +4 -0
  448. package/dist/ionic/p-CtA-yJYy.js +4 -0
  449. package/dist/ionic/p-D8HJQ1qq.js +4 -0
  450. package/dist/ionic/{p-B0q1YL7N.js → p-DB_iPQC-.js} +1 -1
  451. package/dist/ionic/{p-DNcfiJwE.js → p-DLbbmF9h.js} +1 -1
  452. package/dist/ionic/p-DTPR1Wpn.js +4 -0
  453. package/dist/ionic/p-DjriolRs.js +4 -0
  454. package/dist/ionic/p-DtVZDHlS.js +4 -0
  455. package/dist/ionic/p-IGIE5vDm.js +5 -0
  456. package/dist/ionic/{p-BFvmZNyx.js → p-NFFyoJ4Q.js} +1 -1
  457. package/dist/ionic/p-a805674e.entry.js +4 -0
  458. package/dist/ionic/{p-da7d04cc.entry.js → p-a84f2d21.entry.js} +1 -1
  459. package/dist/ionic/p-aa47f46e.entry.js +4 -0
  460. package/dist/ionic/{p-2668188b.entry.js → p-b325a113.entry.js} +1 -1
  461. package/dist/ionic/{p-d1f54e28.entry.js → p-b440381f.entry.js} +1 -1
  462. package/dist/ionic/p-b6e0ff03.entry.js +4 -0
  463. package/dist/ionic/{p-6f37536a.entry.js → p-bcaa827e.entry.js} +1 -1
  464. package/dist/ionic/{p-fb0271ae.entry.js → p-c3cce9d8.entry.js} +1 -1
  465. package/dist/ionic/{p-b0a7585c.entry.js → p-ca31010f.entry.js} +1 -1
  466. package/dist/ionic/p-d4e8b473.entry.js +4 -0
  467. package/dist/ionic/{p-9575b654.entry.js → p-e663bc5a.entry.js} +1 -1
  468. package/dist/ionic/p-e6c5f060.entry.js +4 -0
  469. package/dist/ionic/{p-652318c3.entry.js → p-e6cedcd7.entry.js} +1 -1
  470. package/dist/ionic/{p-fbb00634.entry.js → p-e863ffe8.entry.js} +1 -1
  471. package/dist/ionic/{p-0ca0fe9c.entry.js → p-f2deaceb.entry.js} +1 -1
  472. package/dist/ionic/{p-ac4eb91d.entry.js → p-f5dfb9a3.entry.js} +1 -1
  473. package/dist/ionic/{p-bce86e56.entry.js → p-f8186550.entry.js} +1 -1
  474. package/dist/ionic/p-fdbc90d4.entry.js +4 -0
  475. package/dist/ionic/p-gbVXD275.js +4 -0
  476. package/dist/ionic/p-hNN3VvaC.js +4 -0
  477. package/dist/types/components/datetime/datetime.d.ts +10 -0
  478. package/dist/types/components/header/header.utils.d.ts +2 -1
  479. package/dist/types/components/item/item.d.ts +2 -0
  480. package/dist/types/components/item-divider/item-divider.d.ts +3 -0
  481. package/dist/types/components/item-option/item-option.d.ts +2 -0
  482. package/dist/types/components/list-header/list-header.d.ts +2 -0
  483. package/dist/types/components/modal/gestures/sheet.d.ts +2 -2
  484. package/dist/types/components/modal/gestures/swipe-to-close.d.ts +2 -2
  485. package/dist/types/components/modal/modal-interface.d.ts +25 -0
  486. package/dist/types/components/modal/modal.d.ts +22 -1
  487. package/dist/types/components/range/range-interface.d.ts +1 -0
  488. package/dist/types/components/range/range.d.ts +44 -4
  489. package/dist/types/components/refresher/refresher-interface.d.ts +7 -0
  490. package/dist/types/components/refresher/refresher.d.ts +16 -3
  491. package/dist/types/components/segment-view/segment-view.d.ts +4 -0
  492. package/dist/types/components/select/select.d.ts +3 -0
  493. package/dist/types/components/select-modal/select-modal.d.ts +4 -0
  494. package/dist/types/components.d.ts +964 -191
  495. package/dist/types/interface.d.ts +2 -2
  496. package/dist/types/stencil-public-runtime.d.ts +126 -14
  497. package/dist/types/utils/gesture/listener.d.ts +2 -1
  498. package/hydrate/index.d.ts +12 -0
  499. package/hydrate/index.js +5632 -1421
  500. package/hydrate/index.mjs +5631 -1422
  501. package/package.json +2 -2
  502. package/components/p-B25GjpND.js +0 -71
  503. package/components/p-BANeLH_G.js +0 -290
  504. package/components/p-BBFQmhcD.js +0 -59
  505. package/components/p-BC-awmYt.js +0 -306
  506. package/components/p-BHbOsu99.js +0 -501
  507. package/components/p-BTlwXR9e.js +0 -73
  508. package/components/p-BcazQttQ.js +0 -612
  509. package/components/p-BdGshsIJ.js +0 -226
  510. package/components/p-BfS7vSpC.js +0 -147
  511. package/components/p-BhRFCLuX.js +0 -675
  512. package/components/p-Bhnhnzjz.js +0 -75
  513. package/components/p-BmcqD0EN.js +0 -153
  514. package/components/p-Boi6hecl.js +0 -115
  515. package/components/p-Bt_moUyl.js +0 -232
  516. package/components/p-Bxl5etF4.js +0 -146
  517. package/components/p-ByjmWt3s.js +0 -139
  518. package/components/p-C04oPyjT.js +0 -54
  519. package/components/p-C6dkQWq2.js +0 -1626
  520. package/components/p-CFZWrvIQ.js +0 -194
  521. package/components/p-CIJwkzL6.js +0 -195
  522. package/components/p-CL12ApCQ.js +0 -820
  523. package/components/p-CXJR56Oq.js +0 -564
  524. package/components/p-Cdm3dKWf.js +0 -108
  525. package/components/p-CslsoGzv.js +0 -192
  526. package/components/p-Cyd00tgZ.js +0 -167
  527. package/components/p-CzAJ3ArC.js +0 -380
  528. package/components/p-CzW34QBh.js +0 -12
  529. package/components/p-D0zXRwcr.js +0 -196
  530. package/components/p-D5hF6rwn.js +0 -339
  531. package/components/p-D8eD2iBA.js +0 -67
  532. package/components/p-DGOrLIyS.js +0 -481
  533. package/components/p-DK2Bn1Mc.js +0 -305
  534. package/components/p-DKRQWlK2.js +0 -598
  535. package/components/p-DNDUsygf.js +0 -128
  536. package/components/p-DTWZF6wg.js +0 -418
  537. package/components/p-DWoUQeZ3.js +0 -3012
  538. package/components/p-DX0w75a9.js +0 -420
  539. package/components/p-Dt8zaCLQ.js +0 -92
  540. package/components/p-DyFBFrV7.js +0 -264
  541. package/components/p-DyHPCMyn.js +0 -39
  542. package/components/p-LgLeKTkH.js +0 -112
  543. package/components/p-NhiRFRn9.js +0 -50
  544. package/components/p-OuiHmXO5.js +0 -646
  545. package/components/p-Wro9IPHE.js +0 -459
  546. package/components/p-aIWC4ZEV.js +0 -305
  547. package/components/p-c-XJ9XhZ.js +0 -915
  548. package/components/p-fVuFT3Wd.js +0 -78
  549. package/components/p-iyo0Toaz.js +0 -2822
  550. package/components/p-l_lso3Zl.js +0 -140
  551. package/components/p-mQp4lwQD.js +0 -1638
  552. package/dist/cjs/app-globals-Ciccnk9_.js +0 -10
  553. package/dist/esm/app-globals-BDSf8fOA.js +0 -8
  554. package/dist/ionic/p-11518b31.entry.js +0 -4
  555. package/dist/ionic/p-221a3d8c.entry.js +0 -4
  556. package/dist/ionic/p-2ac254dc.entry.js +0 -4
  557. package/dist/ionic/p-2bd1ea35.entry.js +0 -4
  558. package/dist/ionic/p-30333874.entry.js +0 -4
  559. package/dist/ionic/p-31db96da.entry.js +0 -4
  560. package/dist/ionic/p-34642fa1.entry.js +0 -4
  561. package/dist/ionic/p-35696017.entry.js +0 -4
  562. package/dist/ionic/p-363d1209.entry.js +0 -4
  563. package/dist/ionic/p-46a38cfd.entry.js +0 -4
  564. package/dist/ionic/p-4eec1a5e.entry.js +0 -4
  565. package/dist/ionic/p-530fcd71.entry.js +0 -4
  566. package/dist/ionic/p-5d6fb6e3.entry.js +0 -4
  567. package/dist/ionic/p-66fbe052.entry.js +0 -4
  568. package/dist/ionic/p-7babec72.entry.js +0 -4
  569. package/dist/ionic/p-82d5bb3d.entry.js +0 -4
  570. package/dist/ionic/p-97eb0812.entry.js +0 -4
  571. package/dist/ionic/p-9b6d46f2.entry.js +0 -4
  572. package/dist/ionic/p-BKc55Xev.js +0 -4
  573. package/dist/ionic/p-Bmgaetn_.js +0 -4
  574. package/dist/ionic/p-C8IsBmNU.js +0 -5
  575. package/dist/ionic/p-CJxh_yLS.js +0 -4
  576. package/dist/ionic/p-DZRJwG4S.js +0 -4
  577. package/dist/ionic/p-a4a9f5ae.entry.js +0 -4
  578. package/dist/ionic/p-b0ebf9f8.entry.js +0 -4
  579. package/dist/ionic/p-be263062.entry.js +0 -4
  580. package/dist/ionic/p-c175d792.entry.js +0 -4
  581. package/dist/ionic/p-cc2a9936.entry.js +0 -4
  582. package/dist/ionic/p-cc45bcbc.entry.js +0 -4
  583. package/dist/ionic/p-d0a2a1ab.entry.js +0 -4
  584. package/dist/ionic/p-e4c57008.entry.js +0 -4
  585. package/dist/ionic/p-e5d6d0f0.entry.js +0 -4
  586. package/dist/ionic/p-f1dfee25.entry.js +0 -4
  587. package/dist/ionic/p-f9f7b9db.entry.js +0 -4
@@ -1,675 +0,0 @@
1
- /*!
2
- * (C) Ionic http://ionicframework.com - MIT License
3
- */
4
- import { c as createAnimation } from './p-CL12ApCQ.js';
5
- import { g as getIonPageElement } from './p-DTWZF6wg.js';
6
-
7
- const DURATION = 540;
8
- // TODO(FW-2832): types
9
- const getClonedElement = (tagName) => {
10
- return document.querySelector(`${tagName}.ion-cloned-element`);
11
- };
12
- const shadow = (el) => {
13
- return el.shadowRoot || el;
14
- };
15
- const getLargeTitle = (refEl) => {
16
- const tabs = refEl.tagName === 'ION-TABS' ? refEl : refEl.querySelector('ion-tabs');
17
- const query = 'ion-content ion-header:not(.header-collapse-condense-inactive) ion-title.title-large';
18
- if (tabs != null) {
19
- const activeTab = tabs.querySelector('ion-tab:not(.tab-hidden), .ion-page:not(.ion-page-hidden)');
20
- return activeTab != null ? activeTab.querySelector(query) : null;
21
- }
22
- return refEl.querySelector(query);
23
- };
24
- const getBackButton = (refEl, backDirection) => {
25
- const tabs = refEl.tagName === 'ION-TABS' ? refEl : refEl.querySelector('ion-tabs');
26
- let buttonsList = [];
27
- if (tabs != null) {
28
- const activeTab = tabs.querySelector('ion-tab:not(.tab-hidden), .ion-page:not(.ion-page-hidden)');
29
- if (activeTab != null) {
30
- buttonsList = activeTab.querySelectorAll('ion-buttons');
31
- }
32
- }
33
- else {
34
- buttonsList = refEl.querySelectorAll('ion-buttons');
35
- }
36
- for (const buttons of buttonsList) {
37
- const parentHeader = buttons.closest('ion-header');
38
- const activeHeader = parentHeader && !parentHeader.classList.contains('header-collapse-condense-inactive');
39
- const backButton = buttons.querySelector('ion-back-button');
40
- const buttonsCollapse = buttons.classList.contains('buttons-collapse');
41
- const startSlot = buttons.slot === 'start' || buttons.slot === '';
42
- if (backButton !== null && startSlot && ((buttonsCollapse && activeHeader && backDirection) || !buttonsCollapse)) {
43
- return backButton;
44
- }
45
- }
46
- return null;
47
- };
48
- const createLargeTitleTransition = (rootAnimation, rtl, backDirection, enteringEl, leavingEl) => {
49
- const enteringBackButton = getBackButton(enteringEl, backDirection);
50
- const leavingLargeTitle = getLargeTitle(leavingEl);
51
- const enteringLargeTitle = getLargeTitle(enteringEl);
52
- const leavingBackButton = getBackButton(leavingEl, backDirection);
53
- const shouldAnimationForward = enteringBackButton !== null && leavingLargeTitle !== null && !backDirection;
54
- const shouldAnimationBackward = enteringLargeTitle !== null && leavingBackButton !== null && backDirection;
55
- if (shouldAnimationForward) {
56
- const leavingLargeTitleBox = leavingLargeTitle.getBoundingClientRect();
57
- const enteringBackButtonBox = enteringBackButton.getBoundingClientRect();
58
- const enteringBackButtonTextEl = shadow(enteringBackButton).querySelector('.button-text');
59
- // Text element not rendered if developers pass text="" to the back button
60
- const enteringBackButtonTextBox = enteringBackButtonTextEl === null || enteringBackButtonTextEl === void 0 ? void 0 : enteringBackButtonTextEl.getBoundingClientRect();
61
- const leavingLargeTitleTextEl = shadow(leavingLargeTitle).querySelector('.toolbar-title');
62
- const leavingLargeTitleTextBox = leavingLargeTitleTextEl.getBoundingClientRect();
63
- animateLargeTitle(rootAnimation, rtl, backDirection, leavingLargeTitle, leavingLargeTitleBox, leavingLargeTitleTextBox, enteringBackButtonBox, enteringBackButtonTextEl, enteringBackButtonTextBox);
64
- animateBackButton(rootAnimation, rtl, backDirection, enteringBackButton, enteringBackButtonBox, enteringBackButtonTextEl, enteringBackButtonTextBox, leavingLargeTitle, leavingLargeTitleTextBox);
65
- }
66
- else if (shouldAnimationBackward) {
67
- const enteringLargeTitleBox = enteringLargeTitle.getBoundingClientRect();
68
- const leavingBackButtonBox = leavingBackButton.getBoundingClientRect();
69
- const leavingBackButtonTextEl = shadow(leavingBackButton).querySelector('.button-text');
70
- // Text element not rendered if developers pass text="" to the back button
71
- const leavingBackButtonTextBox = leavingBackButtonTextEl === null || leavingBackButtonTextEl === void 0 ? void 0 : leavingBackButtonTextEl.getBoundingClientRect();
72
- const enteringLargeTitleTextEl = shadow(enteringLargeTitle).querySelector('.toolbar-title');
73
- const enteringLargeTitleTextBox = enteringLargeTitleTextEl.getBoundingClientRect();
74
- animateLargeTitle(rootAnimation, rtl, backDirection, enteringLargeTitle, enteringLargeTitleBox, enteringLargeTitleTextBox, leavingBackButtonBox, leavingBackButtonTextEl, leavingBackButtonTextBox);
75
- animateBackButton(rootAnimation, rtl, backDirection, leavingBackButton, leavingBackButtonBox, leavingBackButtonTextEl, leavingBackButtonTextBox, enteringLargeTitle, enteringLargeTitleTextBox);
76
- }
77
- return {
78
- forward: shouldAnimationForward,
79
- backward: shouldAnimationBackward,
80
- };
81
- };
82
- const animateBackButton = (rootAnimation, rtl, backDirection, backButtonEl, backButtonBox, backButtonTextEl, backButtonTextBox, largeTitleEl, largeTitleTextBox) => {
83
- var _a, _b;
84
- const BACK_BUTTON_START_OFFSET = rtl ? `calc(100% - ${backButtonBox.right + 4}px)` : `${backButtonBox.left - 4}px`;
85
- const TEXT_ORIGIN_X = rtl ? 'right' : 'left';
86
- const ICON_ORIGIN_X = rtl ? 'left' : 'right';
87
- const CONTAINER_ORIGIN_X = rtl ? 'right' : 'left';
88
- let WIDTH_SCALE = 1;
89
- let HEIGHT_SCALE = 1;
90
- let TEXT_START_SCALE = `scale(${HEIGHT_SCALE})`;
91
- const TEXT_END_SCALE = 'scale(1)';
92
- if (backButtonTextEl && backButtonTextBox) {
93
- /**
94
- * When the title and back button texts match then they should overlap during the
95
- * page transition. If the texts do not match up then the back button text scale
96
- * adjusts to not perfectly match the large title text otherwise the proportions
97
- * will be incorrect. When the texts match we scale both the width and height to
98
- * account for font weight differences between the title and back button.
99
- */
100
- const doTitleAndButtonTextsMatch = ((_a = backButtonTextEl.textContent) === null || _a === void 0 ? void 0 : _a.trim()) === ((_b = largeTitleEl.textContent) === null || _b === void 0 ? void 0 : _b.trim());
101
- WIDTH_SCALE = largeTitleTextBox.width / backButtonTextBox.width;
102
- /**
103
- * Subtract an offset to account for slight sizing/padding differences between the
104
- * title and the back button.
105
- */
106
- HEIGHT_SCALE = (largeTitleTextBox.height - LARGE_TITLE_SIZE_OFFSET) / backButtonTextBox.height;
107
- /**
108
- * Even though we set TEXT_START_SCALE to HEIGHT_SCALE above, we potentially need
109
- * to re-compute this here since the HEIGHT_SCALE may have changed.
110
- */
111
- TEXT_START_SCALE = doTitleAndButtonTextsMatch ? `scale(${WIDTH_SCALE}, ${HEIGHT_SCALE})` : `scale(${HEIGHT_SCALE})`;
112
- }
113
- const backButtonIconEl = shadow(backButtonEl).querySelector('ion-icon');
114
- const backButtonIconBox = backButtonIconEl.getBoundingClientRect();
115
- /**
116
- * We need to offset the container by the icon dimensions
117
- * so that the back button text aligns with the large title
118
- * text. Otherwise, the back button icon will align with the
119
- * large title text but the back button text will not.
120
- */
121
- const CONTAINER_START_TRANSLATE_X = rtl
122
- ? `${backButtonIconBox.width / 2 - (backButtonIconBox.right - backButtonBox.right)}px`
123
- : `${backButtonBox.left - backButtonIconBox.width / 2}px`;
124
- const CONTAINER_END_TRANSLATE_X = rtl ? `-${window.innerWidth - backButtonBox.right}px` : `${backButtonBox.left}px`;
125
- /**
126
- * Back button container should be
127
- * aligned to the top of the title container
128
- * so the texts overlap as the back button
129
- * text begins to fade in.
130
- */
131
- const CONTAINER_START_TRANSLATE_Y = `${largeTitleTextBox.top}px`;
132
- /**
133
- * The cloned back button should align exactly with the
134
- * real back button on the entering page otherwise there will
135
- * be a layout shift.
136
- */
137
- const CONTAINER_END_TRANSLATE_Y = `${backButtonBox.top}px`;
138
- /**
139
- * In the forward direction, the cloned back button
140
- * container should translate from over the large title
141
- * to over the back button. In the backward direction,
142
- * it should translate from over the back button to over
143
- * the large title.
144
- */
145
- const FORWARD_CONTAINER_KEYFRAMES = [
146
- { offset: 0, transform: `translate3d(${CONTAINER_START_TRANSLATE_X}, ${CONTAINER_START_TRANSLATE_Y}, 0)` },
147
- { offset: 1, transform: `translate3d(${CONTAINER_END_TRANSLATE_X}, ${CONTAINER_END_TRANSLATE_Y}, 0)` },
148
- ];
149
- const BACKWARD_CONTAINER_KEYFRAMES = [
150
- { offset: 0, transform: `translate3d(${CONTAINER_END_TRANSLATE_X}, ${CONTAINER_END_TRANSLATE_Y}, 0)` },
151
- { offset: 1, transform: `translate3d(${CONTAINER_START_TRANSLATE_X}, ${CONTAINER_START_TRANSLATE_Y}, 0)` },
152
- ];
153
- const CONTAINER_KEYFRAMES = backDirection ? BACKWARD_CONTAINER_KEYFRAMES : FORWARD_CONTAINER_KEYFRAMES;
154
- /**
155
- * In the forward direction, the text in the cloned back button
156
- * should start to be (roughly) the size of the large title
157
- * and then scale down to be the size of the actual back button.
158
- * The text should also translate, but that translate is handled
159
- * by the container keyframes.
160
- */
161
- const FORWARD_TEXT_KEYFRAMES = [
162
- { offset: 0, opacity: 0, transform: TEXT_START_SCALE },
163
- { offset: 1, opacity: 1, transform: TEXT_END_SCALE },
164
- ];
165
- const BACKWARD_TEXT_KEYFRAMES = [
166
- { offset: 0, opacity: 1, transform: TEXT_END_SCALE },
167
- { offset: 1, opacity: 0, transform: TEXT_START_SCALE },
168
- ];
169
- const TEXT_KEYFRAMES = backDirection ? BACKWARD_TEXT_KEYFRAMES : FORWARD_TEXT_KEYFRAMES;
170
- /**
171
- * The icon should scale in/out in the second
172
- * half of the animation. The icon should also
173
- * translate, but that translate is handled by the
174
- * container keyframes.
175
- */
176
- const FORWARD_ICON_KEYFRAMES = [
177
- { offset: 0, opacity: 0, transform: 'scale(0.6)' },
178
- { offset: 0.6, opacity: 0, transform: 'scale(0.6)' },
179
- { offset: 1, opacity: 1, transform: 'scale(1)' },
180
- ];
181
- const BACKWARD_ICON_KEYFRAMES = [
182
- { offset: 0, opacity: 1, transform: 'scale(1)' },
183
- { offset: 0.2, opacity: 0, transform: 'scale(0.6)' },
184
- { offset: 1, opacity: 0, transform: 'scale(0.6)' },
185
- ];
186
- const ICON_KEYFRAMES = backDirection ? BACKWARD_ICON_KEYFRAMES : FORWARD_ICON_KEYFRAMES;
187
- const enteringBackButtonTextAnimation = createAnimation();
188
- const enteringBackButtonIconAnimation = createAnimation();
189
- const enteringBackButtonAnimation = createAnimation();
190
- const clonedBackButtonEl = getClonedElement('ion-back-button');
191
- const clonedBackButtonTextEl = shadow(clonedBackButtonEl).querySelector('.button-text');
192
- const clonedBackButtonIconEl = shadow(clonedBackButtonEl).querySelector('ion-icon');
193
- clonedBackButtonEl.text = backButtonEl.text;
194
- clonedBackButtonEl.mode = backButtonEl.mode;
195
- clonedBackButtonEl.icon = backButtonEl.icon;
196
- clonedBackButtonEl.color = backButtonEl.color;
197
- clonedBackButtonEl.disabled = backButtonEl.disabled;
198
- clonedBackButtonEl.style.setProperty('display', 'block');
199
- clonedBackButtonEl.style.setProperty('position', 'fixed');
200
- enteringBackButtonIconAnimation.addElement(clonedBackButtonIconEl);
201
- enteringBackButtonTextAnimation.addElement(clonedBackButtonTextEl);
202
- enteringBackButtonAnimation.addElement(clonedBackButtonEl);
203
- enteringBackButtonAnimation
204
- .beforeStyles({
205
- position: 'absolute',
206
- top: '0px',
207
- [CONTAINER_ORIGIN_X]: '0px',
208
- })
209
- /**
210
- * The write hooks must be set on this animation as it is guaranteed to run. Other
211
- * animations such as the back button text animation will not run if the back button
212
- * has no visible text.
213
- */
214
- .beforeAddWrite(() => {
215
- backButtonEl.style.setProperty('display', 'none');
216
- clonedBackButtonEl.style.setProperty(TEXT_ORIGIN_X, BACK_BUTTON_START_OFFSET);
217
- })
218
- .afterAddWrite(() => {
219
- backButtonEl.style.setProperty('display', '');
220
- clonedBackButtonEl.style.setProperty('display', 'none');
221
- clonedBackButtonEl.style.removeProperty(TEXT_ORIGIN_X);
222
- })
223
- .keyframes(CONTAINER_KEYFRAMES);
224
- enteringBackButtonTextAnimation
225
- .beforeStyles({
226
- 'transform-origin': `${TEXT_ORIGIN_X} top`,
227
- })
228
- .keyframes(TEXT_KEYFRAMES);
229
- enteringBackButtonIconAnimation
230
- .beforeStyles({
231
- 'transform-origin': `${ICON_ORIGIN_X} center`,
232
- })
233
- .keyframes(ICON_KEYFRAMES);
234
- rootAnimation.addAnimation([
235
- enteringBackButtonTextAnimation,
236
- enteringBackButtonIconAnimation,
237
- enteringBackButtonAnimation,
238
- ]);
239
- };
240
- const animateLargeTitle = (rootAnimation, rtl, backDirection, largeTitleEl, largeTitleBox, largeTitleTextBox, backButtonBox, backButtonTextEl, backButtonTextBox) => {
241
- var _a, _b;
242
- /**
243
- * The horizontal transform origin for the large title
244
- */
245
- const ORIGIN_X = rtl ? 'right' : 'left';
246
- const TITLE_START_OFFSET = rtl ? `calc(100% - ${largeTitleBox.right}px)` : `${largeTitleBox.left}px`;
247
- /**
248
- * The cloned large should align exactly with the
249
- * real large title on the leaving page otherwise there will
250
- * be a layout shift.
251
- */
252
- const START_TRANSLATE_X = '0px';
253
- const START_TRANSLATE_Y = `${largeTitleBox.top}px`;
254
- /**
255
- * How much to offset the large title translation by.
256
- * This accounts for differences in sizing between the large
257
- * title and the back button due to padding and font weight.
258
- */
259
- const LARGE_TITLE_TRANSLATION_OFFSET = 8;
260
- let END_TRANSLATE_X = rtl
261
- ? `-${window.innerWidth - backButtonBox.right - LARGE_TITLE_TRANSLATION_OFFSET}px`
262
- : `${backButtonBox.x + LARGE_TITLE_TRANSLATION_OFFSET}px`;
263
- /**
264
- * How much to scale the large title up/down by.
265
- */
266
- let HEIGHT_SCALE = 0.5;
267
- /**
268
- * The large title always starts full size.
269
- */
270
- const START_SCALE = 'scale(1)';
271
- /**
272
- * By default, we don't worry about having the large title scaled to perfectly
273
- * match the back button because we don't know if the back button's text matches
274
- * the large title's text.
275
- */
276
- let END_SCALE = `scale(${HEIGHT_SCALE})`;
277
- // Text element not rendered if developers pass text="" to the back button
278
- if (backButtonTextEl && backButtonTextBox) {
279
- /**
280
- * The scaled title should (roughly) overlap the back button. This ensures that
281
- * the back button and title overlap during the animation. Note that since both
282
- * elements either fade in or fade out over the course of the animation, neither
283
- * element will be fully visible on top of the other. As a result, the overlap
284
- * does not need to be perfect, so approximate values are acceptable here.
285
- */
286
- END_TRANSLATE_X = rtl
287
- ? `-${window.innerWidth - backButtonTextBox.right - LARGE_TITLE_TRANSLATION_OFFSET}px`
288
- : `${backButtonTextBox.x - LARGE_TITLE_TRANSLATION_OFFSET}px`;
289
- /**
290
- * In the forward direction, the large title should start at its normal size and
291
- * then scale down to be (roughly) the size of the back button on the other view.
292
- * In the backward direction, the large title should start at (roughly) the size
293
- * of the back button and then scale up to its original size.
294
- * Note that since both elements either fade in or fade out over the course of the
295
- * animation, neither element will be fully visible on top of the other. As a result,
296
- * the overlap does not need to be perfect, so approximate values are acceptable here.
297
- */
298
- /**
299
- * When the title and back button texts match then they should overlap during the
300
- * page transition. If the texts do not match up then the large title text scale
301
- * adjusts to not perfectly match the back button text otherwise the proportions
302
- * will be incorrect. When the texts match we scale both the width and height to
303
- * account for font weight differences between the title and back button.
304
- */
305
- const doTitleAndButtonTextsMatch = ((_a = backButtonTextEl.textContent) === null || _a === void 0 ? void 0 : _a.trim()) === ((_b = largeTitleEl.textContent) === null || _b === void 0 ? void 0 : _b.trim());
306
- const WIDTH_SCALE = backButtonTextBox.width / largeTitleTextBox.width;
307
- HEIGHT_SCALE = backButtonTextBox.height / (largeTitleTextBox.height - LARGE_TITLE_SIZE_OFFSET);
308
- /**
309
- * Even though we set TEXT_START_SCALE to HEIGHT_SCALE above, we potentially need
310
- * to re-compute this here since the HEIGHT_SCALE may have changed.
311
- */
312
- END_SCALE = doTitleAndButtonTextsMatch ? `scale(${WIDTH_SCALE}, ${HEIGHT_SCALE})` : `scale(${HEIGHT_SCALE})`;
313
- }
314
- /**
315
- * The midpoints of the back button and the title should align such that the back
316
- * button and title appear to be centered with each other.
317
- */
318
- const backButtonMidPoint = backButtonBox.top + backButtonBox.height / 2;
319
- const titleMidPoint = (largeTitleBox.height * HEIGHT_SCALE) / 2;
320
- const END_TRANSLATE_Y = `${backButtonMidPoint - titleMidPoint}px`;
321
- const BACKWARDS_KEYFRAMES = [
322
- { offset: 0, opacity: 0, transform: `translate3d(${END_TRANSLATE_X}, ${END_TRANSLATE_Y}, 0) ${END_SCALE}` },
323
- { offset: 0.1, opacity: 0 },
324
- { offset: 1, opacity: 1, transform: `translate3d(${START_TRANSLATE_X}, ${START_TRANSLATE_Y}, 0) ${START_SCALE}` },
325
- ];
326
- const FORWARDS_KEYFRAMES = [
327
- {
328
- offset: 0,
329
- opacity: 0.99,
330
- transform: `translate3d(${START_TRANSLATE_X}, ${START_TRANSLATE_Y}, 0) ${START_SCALE}`,
331
- },
332
- { offset: 0.6, opacity: 0 },
333
- { offset: 1, opacity: 0, transform: `translate3d(${END_TRANSLATE_X}, ${END_TRANSLATE_Y}, 0) ${END_SCALE}` },
334
- ];
335
- const KEYFRAMES = backDirection ? BACKWARDS_KEYFRAMES : FORWARDS_KEYFRAMES;
336
- const clonedTitleEl = getClonedElement('ion-title');
337
- const clonedLargeTitleAnimation = createAnimation();
338
- clonedTitleEl.innerText = largeTitleEl.innerText;
339
- clonedTitleEl.size = largeTitleEl.size;
340
- clonedTitleEl.color = largeTitleEl.color;
341
- clonedLargeTitleAnimation.addElement(clonedTitleEl);
342
- clonedLargeTitleAnimation
343
- .beforeStyles({
344
- 'transform-origin': `${ORIGIN_X} top`,
345
- /**
346
- * Since font size changes will cause
347
- * the dimension of the large title to change
348
- * we need to set the cloned title height
349
- * equal to that of the original large title height.
350
- */
351
- height: `${largeTitleBox.height}px`,
352
- display: '',
353
- position: 'relative',
354
- [ORIGIN_X]: TITLE_START_OFFSET,
355
- })
356
- .beforeAddWrite(() => {
357
- largeTitleEl.style.setProperty('opacity', '0');
358
- })
359
- .afterAddWrite(() => {
360
- largeTitleEl.style.setProperty('opacity', '');
361
- clonedTitleEl.style.setProperty('display', 'none');
362
- })
363
- .keyframes(KEYFRAMES);
364
- rootAnimation.addAnimation(clonedLargeTitleAnimation);
365
- };
366
- const iosTransitionAnimation = (navEl, opts) => {
367
- var _a;
368
- try {
369
- const EASING = 'cubic-bezier(0.32,0.72,0,1)';
370
- const OPACITY = 'opacity';
371
- const TRANSFORM = 'transform';
372
- const CENTER = '0%';
373
- const OFF_OPACITY = 0.8;
374
- const isRTL = navEl.ownerDocument.dir === 'rtl';
375
- const OFF_RIGHT = isRTL ? '-99.5%' : '99.5%';
376
- const OFF_LEFT = isRTL ? '33%' : '-33%';
377
- const enteringEl = opts.enteringEl;
378
- const leavingEl = opts.leavingEl;
379
- const backDirection = opts.direction === 'back';
380
- const contentEl = enteringEl.querySelector(':scope > ion-content');
381
- const headerEls = enteringEl.querySelectorAll(':scope > ion-header > *:not(ion-toolbar), :scope > ion-footer > *');
382
- const enteringToolBarEls = enteringEl.querySelectorAll(':scope > ion-header > ion-toolbar');
383
- const rootAnimation = createAnimation();
384
- const enteringContentAnimation = createAnimation();
385
- rootAnimation
386
- .addElement(enteringEl)
387
- .duration(((_a = opts.duration) !== null && _a !== void 0 ? _a : 0) || DURATION)
388
- .easing(opts.easing || EASING)
389
- .fill('both')
390
- .beforeRemoveClass('ion-page-invisible');
391
- // eslint-disable-next-line @typescript-eslint/prefer-optional-chain
392
- if (leavingEl && navEl !== null && navEl !== undefined) {
393
- const navDecorAnimation = createAnimation();
394
- navDecorAnimation.addElement(navEl);
395
- rootAnimation.addAnimation(navDecorAnimation);
396
- }
397
- if (!contentEl && enteringToolBarEls.length === 0 && headerEls.length === 0) {
398
- enteringContentAnimation.addElement(enteringEl.querySelector(':scope > .ion-page, :scope > ion-nav, :scope > ion-tabs')); // REVIEW
399
- }
400
- else {
401
- enteringContentAnimation.addElement(contentEl); // REVIEW
402
- enteringContentAnimation.addElement(headerEls);
403
- }
404
- rootAnimation.addAnimation(enteringContentAnimation);
405
- if (backDirection) {
406
- enteringContentAnimation
407
- .beforeClearStyles([OPACITY])
408
- .fromTo('transform', `translateX(${OFF_LEFT})`, `translateX(${CENTER})`)
409
- .fromTo(OPACITY, OFF_OPACITY, 1);
410
- }
411
- else {
412
- // entering content, forward direction
413
- enteringContentAnimation
414
- .beforeClearStyles([OPACITY])
415
- .fromTo('transform', `translateX(${OFF_RIGHT})`, `translateX(${CENTER})`);
416
- }
417
- if (contentEl) {
418
- const enteringTransitionEffectEl = shadow(contentEl).querySelector('.transition-effect');
419
- if (enteringTransitionEffectEl) {
420
- const enteringTransitionCoverEl = enteringTransitionEffectEl.querySelector('.transition-cover');
421
- const enteringTransitionShadowEl = enteringTransitionEffectEl.querySelector('.transition-shadow');
422
- const enteringTransitionEffect = createAnimation();
423
- const enteringTransitionCover = createAnimation();
424
- const enteringTransitionShadow = createAnimation();
425
- enteringTransitionEffect
426
- .addElement(enteringTransitionEffectEl)
427
- .beforeStyles({ opacity: '1', display: 'block' })
428
- .afterStyles({ opacity: '', display: '' });
429
- enteringTransitionCover
430
- .addElement(enteringTransitionCoverEl) // REVIEW
431
- .beforeClearStyles([OPACITY])
432
- .fromTo(OPACITY, 0, 0.1);
433
- enteringTransitionShadow
434
- .addElement(enteringTransitionShadowEl) // REVIEW
435
- .beforeClearStyles([OPACITY])
436
- .fromTo(OPACITY, 0.03, 0.7);
437
- enteringTransitionEffect.addAnimation([enteringTransitionCover, enteringTransitionShadow]);
438
- enteringContentAnimation.addAnimation([enteringTransitionEffect]);
439
- }
440
- }
441
- const enteringContentHasLargeTitle = enteringEl.querySelector('ion-header.header-collapse-condense');
442
- const { forward, backward } = createLargeTitleTransition(rootAnimation, isRTL, backDirection, enteringEl, leavingEl);
443
- enteringToolBarEls.forEach((enteringToolBarEl) => {
444
- const enteringToolBar = createAnimation();
445
- enteringToolBar.addElement(enteringToolBarEl);
446
- rootAnimation.addAnimation(enteringToolBar);
447
- const enteringTitle = createAnimation();
448
- enteringTitle.addElement(enteringToolBarEl.querySelector('ion-title')); // REVIEW
449
- const enteringToolBarButtons = createAnimation();
450
- const buttons = Array.from(enteringToolBarEl.querySelectorAll('ion-buttons,[menuToggle]'));
451
- const parentHeader = enteringToolBarEl.closest('ion-header');
452
- const inactiveHeader = parentHeader === null || parentHeader === void 0 ? void 0 : parentHeader.classList.contains('header-collapse-condense-inactive');
453
- let buttonsToAnimate;
454
- if (backDirection) {
455
- buttonsToAnimate = buttons.filter((button) => {
456
- const isCollapseButton = button.classList.contains('buttons-collapse');
457
- return (isCollapseButton && !inactiveHeader) || !isCollapseButton;
458
- });
459
- }
460
- else {
461
- buttonsToAnimate = buttons.filter((button) => !button.classList.contains('buttons-collapse'));
462
- }
463
- enteringToolBarButtons.addElement(buttonsToAnimate);
464
- const enteringToolBarItems = createAnimation();
465
- enteringToolBarItems.addElement(enteringToolBarEl.querySelectorAll(':scope > *:not(ion-title):not(ion-buttons):not([menuToggle])'));
466
- const enteringToolBarBg = createAnimation();
467
- enteringToolBarBg.addElement(shadow(enteringToolBarEl).querySelector('.toolbar-background')); // REVIEW
468
- const enteringBackButton = createAnimation();
469
- const backButtonEl = enteringToolBarEl.querySelector('ion-back-button');
470
- if (backButtonEl) {
471
- enteringBackButton.addElement(backButtonEl);
472
- }
473
- enteringToolBar.addAnimation([
474
- enteringTitle,
475
- enteringToolBarButtons,
476
- enteringToolBarItems,
477
- enteringToolBarBg,
478
- enteringBackButton,
479
- ]);
480
- enteringToolBarButtons.fromTo(OPACITY, 0.01, 1);
481
- enteringToolBarItems.fromTo(OPACITY, 0.01, 1);
482
- if (backDirection) {
483
- if (!inactiveHeader) {
484
- enteringTitle
485
- .fromTo('transform', `translateX(${OFF_LEFT})`, `translateX(${CENTER})`)
486
- .fromTo(OPACITY, 0.01, 1);
487
- }
488
- enteringToolBarItems.fromTo('transform', `translateX(${OFF_LEFT})`, `translateX(${CENTER})`);
489
- // back direction, entering page has a back button
490
- enteringBackButton.fromTo(OPACITY, 0.01, 1);
491
- }
492
- else {
493
- // entering toolbar, forward direction
494
- if (!enteringContentHasLargeTitle) {
495
- enteringTitle
496
- .fromTo('transform', `translateX(${OFF_RIGHT})`, `translateX(${CENTER})`)
497
- .fromTo(OPACITY, 0.01, 1);
498
- }
499
- enteringToolBarItems.fromTo('transform', `translateX(${OFF_RIGHT})`, `translateX(${CENTER})`);
500
- enteringToolBarBg.beforeClearStyles([OPACITY, 'transform']);
501
- const translucentHeader = parentHeader === null || parentHeader === void 0 ? void 0 : parentHeader.translucent;
502
- if (!translucentHeader) {
503
- enteringToolBarBg.fromTo(OPACITY, 0.01, 'var(--opacity)');
504
- }
505
- else {
506
- enteringToolBarBg.fromTo('transform', isRTL ? 'translateX(-100%)' : 'translateX(100%)', 'translateX(0px)');
507
- }
508
- // forward direction, entering page has a back button
509
- if (!forward) {
510
- enteringBackButton.fromTo(OPACITY, 0.01, 1);
511
- }
512
- if (backButtonEl && !forward) {
513
- const enteringBackBtnText = createAnimation();
514
- enteringBackBtnText
515
- .addElement(shadow(backButtonEl).querySelector('.button-text')) // REVIEW
516
- .fromTo(`transform`, isRTL ? 'translateX(-100px)' : 'translateX(100px)', 'translateX(0px)');
517
- enteringToolBar.addAnimation(enteringBackBtnText);
518
- }
519
- }
520
- });
521
- // setup leaving view
522
- if (leavingEl) {
523
- const leavingContent = createAnimation();
524
- const leavingContentEl = leavingEl.querySelector(':scope > ion-content');
525
- const leavingToolBarEls = leavingEl.querySelectorAll(':scope > ion-header > ion-toolbar');
526
- const leavingHeaderEls = leavingEl.querySelectorAll(':scope > ion-header > *:not(ion-toolbar), :scope > ion-footer > *');
527
- if (!leavingContentEl && leavingToolBarEls.length === 0 && leavingHeaderEls.length === 0) {
528
- leavingContent.addElement(leavingEl.querySelector(':scope > .ion-page, :scope > ion-nav, :scope > ion-tabs')); // REVIEW
529
- }
530
- else {
531
- leavingContent.addElement(leavingContentEl); // REVIEW
532
- leavingContent.addElement(leavingHeaderEls);
533
- }
534
- rootAnimation.addAnimation(leavingContent);
535
- if (backDirection) {
536
- // leaving content, back direction
537
- leavingContent
538
- .beforeClearStyles([OPACITY])
539
- .fromTo('transform', `translateX(${CENTER})`, isRTL ? 'translateX(-100%)' : 'translateX(100%)');
540
- const leavingPage = getIonPageElement(leavingEl);
541
- rootAnimation.afterAddWrite(() => {
542
- if (rootAnimation.getDirection() === 'normal') {
543
- leavingPage.style.setProperty('display', 'none');
544
- }
545
- });
546
- }
547
- else {
548
- // leaving content, forward direction
549
- leavingContent
550
- .fromTo('transform', `translateX(${CENTER})`, `translateX(${OFF_LEFT})`)
551
- .fromTo(OPACITY, 1, OFF_OPACITY);
552
- }
553
- if (leavingContentEl) {
554
- const leavingTransitionEffectEl = shadow(leavingContentEl).querySelector('.transition-effect');
555
- if (leavingTransitionEffectEl) {
556
- const leavingTransitionCoverEl = leavingTransitionEffectEl.querySelector('.transition-cover');
557
- const leavingTransitionShadowEl = leavingTransitionEffectEl.querySelector('.transition-shadow');
558
- const leavingTransitionEffect = createAnimation();
559
- const leavingTransitionCover = createAnimation();
560
- const leavingTransitionShadow = createAnimation();
561
- leavingTransitionEffect
562
- .addElement(leavingTransitionEffectEl)
563
- .beforeStyles({ opacity: '1', display: 'block' })
564
- .afterStyles({ opacity: '', display: '' });
565
- leavingTransitionCover
566
- .addElement(leavingTransitionCoverEl) // REVIEW
567
- .beforeClearStyles([OPACITY])
568
- .fromTo(OPACITY, 0.1, 0);
569
- leavingTransitionShadow
570
- .addElement(leavingTransitionShadowEl) // REVIEW
571
- .beforeClearStyles([OPACITY])
572
- .fromTo(OPACITY, 0.7, 0.03);
573
- leavingTransitionEffect.addAnimation([leavingTransitionCover, leavingTransitionShadow]);
574
- leavingContent.addAnimation([leavingTransitionEffect]);
575
- }
576
- }
577
- leavingToolBarEls.forEach((leavingToolBarEl) => {
578
- const leavingToolBar = createAnimation();
579
- leavingToolBar.addElement(leavingToolBarEl);
580
- const leavingTitle = createAnimation();
581
- leavingTitle.addElement(leavingToolBarEl.querySelector('ion-title')); // REVIEW
582
- const leavingToolBarButtons = createAnimation();
583
- const buttons = leavingToolBarEl.querySelectorAll('ion-buttons,[menuToggle]');
584
- const parentHeader = leavingToolBarEl.closest('ion-header');
585
- const inactiveHeader = parentHeader === null || parentHeader === void 0 ? void 0 : parentHeader.classList.contains('header-collapse-condense-inactive');
586
- const buttonsToAnimate = Array.from(buttons).filter((button) => {
587
- const isCollapseButton = button.classList.contains('buttons-collapse');
588
- return (isCollapseButton && !inactiveHeader) || !isCollapseButton;
589
- });
590
- leavingToolBarButtons.addElement(buttonsToAnimate);
591
- const leavingToolBarItems = createAnimation();
592
- const leavingToolBarItemEls = leavingToolBarEl.querySelectorAll(':scope > *:not(ion-title):not(ion-buttons):not([menuToggle])');
593
- if (leavingToolBarItemEls.length > 0) {
594
- leavingToolBarItems.addElement(leavingToolBarItemEls);
595
- }
596
- const leavingToolBarBg = createAnimation();
597
- leavingToolBarBg.addElement(shadow(leavingToolBarEl).querySelector('.toolbar-background')); // REVIEW
598
- const leavingBackButton = createAnimation();
599
- const backButtonEl = leavingToolBarEl.querySelector('ion-back-button');
600
- if (backButtonEl) {
601
- leavingBackButton.addElement(backButtonEl);
602
- }
603
- leavingToolBar.addAnimation([
604
- leavingTitle,
605
- leavingToolBarButtons,
606
- leavingToolBarItems,
607
- leavingBackButton,
608
- leavingToolBarBg,
609
- ]);
610
- rootAnimation.addAnimation(leavingToolBar);
611
- // fade out leaving toolbar items
612
- leavingBackButton.fromTo(OPACITY, 0.99, 0);
613
- leavingToolBarButtons.fromTo(OPACITY, 0.99, 0);
614
- leavingToolBarItems.fromTo(OPACITY, 0.99, 0);
615
- if (backDirection) {
616
- if (!inactiveHeader) {
617
- // leaving toolbar, back direction
618
- leavingTitle
619
- .fromTo('transform', `translateX(${CENTER})`, isRTL ? 'translateX(-100%)' : 'translateX(100%)')
620
- .fromTo(OPACITY, 0.99, 0);
621
- }
622
- leavingToolBarItems.fromTo('transform', `translateX(${CENTER})`, isRTL ? 'translateX(-100%)' : 'translateX(100%)');
623
- leavingToolBarBg.beforeClearStyles([OPACITY, 'transform']);
624
- // leaving toolbar, back direction, and there's no entering toolbar
625
- // should just slide out, no fading out
626
- const translucentHeader = parentHeader === null || parentHeader === void 0 ? void 0 : parentHeader.translucent;
627
- if (!translucentHeader) {
628
- leavingToolBarBg.fromTo(OPACITY, 'var(--opacity)', 0);
629
- }
630
- else {
631
- leavingToolBarBg.fromTo('transform', 'translateX(0px)', isRTL ? 'translateX(-100%)' : 'translateX(100%)');
632
- }
633
- if (backButtonEl && !backward) {
634
- const leavingBackBtnText = createAnimation();
635
- leavingBackBtnText
636
- .addElement(shadow(backButtonEl).querySelector('.button-text')) // REVIEW
637
- .fromTo('transform', `translateX(${CENTER})`, `translateX(${(isRTL ? -124 : 124) + 'px'})`);
638
- leavingToolBar.addAnimation(leavingBackBtnText);
639
- }
640
- }
641
- else {
642
- // leaving toolbar, forward direction
643
- if (!inactiveHeader) {
644
- leavingTitle
645
- .fromTo('transform', `translateX(${CENTER})`, `translateX(${OFF_LEFT})`)
646
- .fromTo(OPACITY, 0.99, 0)
647
- .afterClearStyles([TRANSFORM, OPACITY]);
648
- }
649
- leavingToolBarItems
650
- .fromTo('transform', `translateX(${CENTER})`, `translateX(${OFF_LEFT})`)
651
- .afterClearStyles([TRANSFORM, OPACITY]);
652
- leavingBackButton.afterClearStyles([OPACITY]);
653
- leavingTitle.afterClearStyles([OPACITY]);
654
- leavingToolBarButtons.afterClearStyles([OPACITY]);
655
- }
656
- });
657
- }
658
- return rootAnimation;
659
- }
660
- catch (err) {
661
- throw err;
662
- }
663
- };
664
- /**
665
- * The scale of the back button during the animation
666
- * is computed based on the scale of the large title
667
- * and vice versa. However, we need to account for slight
668
- * variations in the size of the large title due to
669
- * padding and font weight. This value should be used to subtract
670
- * a small amount from the large title height when computing scales
671
- * to get more accurate scale results.
672
- */
673
- const LARGE_TITLE_SIZE_OFFSET = 10;
674
-
675
- export { iosTransitionAnimation, shadow };