@amwaljs/checkout-button 0.3.1 → 0.3.2

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 (888) hide show
  1. package/README.md +1 -1
  2. package/dist/checkout/checkout.esm.js +1 -1
  3. package/dist/checkout/{p-c03b6161.entry.js → p-00045a8c.entry.js} +1 -1
  4. package/dist/checkout/p-01bbe74f.entry.js +1 -0
  5. package/dist/checkout/p-051412fa.entry.js +1 -0
  6. package/dist/checkout/p-09cbe586.entry.js +4 -0
  7. package/dist/checkout/{p-439ad699.entry.js → p-0a85a01f.entry.js} +2 -2
  8. package/dist/checkout/{p-d5652cd4.entry.js → p-0bbfeb3c.entry.js} +1 -1
  9. package/dist/checkout/{p-4ae1a390.entry.js → p-0d96b482.entry.js} +1 -1
  10. package/dist/checkout/{p-DUa_5Mmb.js → p-0f03cd28.js} +2 -2
  11. package/dist/checkout/p-104d7733.entry.js +1 -0
  12. package/dist/checkout/{p-8036cf49.entry.js → p-10ad151a.entry.js} +5 -5
  13. package/dist/checkout/p-112455b1.js +1 -0
  14. package/dist/checkout/p-11beffea.entry.js +1 -0
  15. package/dist/checkout/p-13245fd4.js +1 -0
  16. package/dist/checkout/p-13741a94.entry.js +1 -0
  17. package/dist/checkout/p-14ea2c82.entry.js +1 -0
  18. package/dist/checkout/p-167dc7a7.entry.js +4 -0
  19. package/dist/checkout/p-1a749b59.entry.js +1 -0
  20. package/dist/checkout/p-1c718939.entry.js +1 -0
  21. package/dist/checkout/{p-11205aeb.entry.js → p-1cbb13f2.entry.js} +1 -1
  22. package/dist/checkout/{p-46ff73b3.entry.js → p-20df5234.entry.js} +1 -1
  23. package/dist/checkout/p-24068b1c.entry.js +1 -0
  24. package/dist/checkout/{p-7006753a.entry.js → p-28ccecc7.entry.js} +2 -2
  25. package/dist/checkout/p-361649c3.js +4 -0
  26. package/dist/{components/p-DoR35tr_.js → checkout/p-39ad94cf.js} +2 -2
  27. package/dist/checkout/p-3b75b22a.js +5 -0
  28. package/dist/checkout/p-3b80783d.js +8 -0
  29. package/dist/checkout/p-3d3eefc3.js +4 -0
  30. package/dist/checkout/p-3e1e3453.js +4 -0
  31. package/dist/checkout/p-3e681e57.js +4 -0
  32. package/dist/checkout/{p-bf933eb6.entry.js → p-3e8da476.entry.js} +1 -1
  33. package/dist/checkout/{p-1dc08181.entry.js → p-4028c0d2.entry.js} +1 -1
  34. package/dist/checkout/p-44c91c42.entry.js +1 -0
  35. package/dist/checkout/p-464f5a60.entry.js +1 -0
  36. package/dist/checkout/p-46b7ee7f.entry.js +1 -0
  37. package/dist/checkout/p-48784250.entry.js +1 -0
  38. package/dist/{components/p-wiOwkFtc.js → checkout/p-4be20bf2.js} +1 -1
  39. package/dist/{components/p-Dl_WhQZu.js → checkout/p-4f78d3a0.js} +2 -2
  40. package/dist/checkout/{p-4da4ecc4.entry.js → p-529bce3f.entry.js} +1 -1
  41. package/dist/checkout/p-536a0294.js +4 -0
  42. package/dist/checkout/{p-eae2d3f2.entry.js → p-5eecd5ef.entry.js} +1 -1
  43. package/dist/checkout/p-64257c8d.entry.js +1 -0
  44. package/dist/checkout/{p-5903b3af.entry.js → p-64bd1dd3.entry.js} +1 -1
  45. package/dist/checkout/{p-9b7d7231.entry.js → p-68a4caba.entry.js} +1 -1
  46. package/dist/checkout/{p-978b3762.entry.js → p-69242ed6.entry.js} +1 -1
  47. package/dist/checkout/{p-62b7c8b0.entry.js → p-6d886d7e.entry.js} +1 -1
  48. package/dist/checkout/{p-ofaUly0p.js → p-6fa979e3.js} +2 -2
  49. package/dist/checkout/p-6fb474f3.entry.js +1 -0
  50. package/dist/checkout/p-77104220.js +7 -0
  51. package/dist/checkout/{p-aba43d04.entry.js → p-79ec3e4b.entry.js} +1 -1
  52. package/dist/checkout/{p-cd2c344b.entry.js → p-7b51bf67.entry.js} +2 -2
  53. package/dist/checkout/p-7f0004c9.js +4 -0
  54. package/dist/checkout/p-7fe50ab4.entry.js +1 -0
  55. package/dist/checkout/p-880b451c.entry.js +4 -0
  56. package/dist/checkout/p-886dad62.entry.js +1 -0
  57. package/dist/checkout/p-886e8746.entry.js +1 -0
  58. package/dist/checkout/p-88abdf59.js +4 -0
  59. package/dist/checkout/{p-f845e91b.entry.js → p-8a97a411.entry.js} +1 -1
  60. package/dist/checkout/p-8af3c6cc.entry.js +1 -0
  61. package/dist/checkout/{p-8b015c21.entry.js → p-8c022f5d.entry.js} +1 -1
  62. package/dist/checkout/{p-56e307eb.entry.js → p-91855eae.entry.js} +1 -1
  63. package/dist/checkout/{p-ca257d45.entry.js → p-9185e55b.entry.js} +1 -1
  64. package/dist/checkout/{p-4b34896c.entry.js → p-926eda98.entry.js} +1 -1
  65. package/dist/checkout/p-93e5b313.entry.js +4 -0
  66. package/dist/checkout/{p-4a86b731.entry.js → p-97024acb.entry.js} +1 -1
  67. package/dist/checkout/p-99e447f9.js +1 -0
  68. package/dist/{components/p-BgOwfqIY.js → checkout/p-9b519de5.js} +2 -2
  69. package/dist/checkout/{p-b8245f6a.entry.js → p-9b65a6e5.entry.js} +1 -1
  70. package/dist/checkout/{p-53ae9dd0.entry.js → p-9cc1fdfb.entry.js} +1 -1
  71. package/dist/checkout/{p-8fc1287a.entry.js → p-9f26fb71.entry.js} +1 -1
  72. package/dist/checkout/p-9f41a631.entry.js +1 -0
  73. package/dist/checkout/{p-5f005b5e.entry.js → p-a2ce8858.entry.js} +1 -1
  74. package/dist/checkout/{p-e4d0702d.entry.js → p-a3fca65c.entry.js} +1 -1
  75. package/dist/checkout/{p-d370e756.entry.js → p-a6056eb1.entry.js} +2 -2
  76. package/dist/checkout/{p-c929d6ea.entry.js → p-a7b2cbb9.entry.js} +1 -1
  77. package/dist/{components/p-Dwo-QLgs.js → checkout/p-ab16e6ce.js} +1 -1
  78. package/dist/checkout/{p-63db3363.entry.js → p-ab9a18c4.entry.js} +1 -1
  79. package/dist/checkout/p-b038db20.js +4 -0
  80. package/dist/checkout/p-b4ad8642.entry.js +1 -0
  81. package/dist/checkout/p-b4cf78ad.entry.js +1 -0
  82. package/dist/checkout/p-b7be2ec0.js +4 -0
  83. package/dist/checkout/p-b84d9e44.js +4 -0
  84. package/dist/{components/p-CwRU9ccI.js → checkout/p-b8fdd517.js} +1 -1
  85. package/dist/checkout/{p-d799009b.entry.js → p-b9d8ab12.entry.js} +1 -1
  86. package/dist/checkout/p-bb1f698e.js +4 -0
  87. package/dist/checkout/p-bd17be25.js +4 -0
  88. package/dist/checkout/p-bd4df0bc.entry.js +1 -0
  89. package/dist/checkout/p-c152bdea.js +4 -0
  90. package/dist/checkout/{p-f22v7XAM.js → p-c30e2b28.js} +2 -2
  91. package/dist/checkout/{p-c2296aa1.entry.js → p-c61a3d5d.entry.js} +1 -1
  92. package/dist/checkout/p-c6ee4bb6.entry.js +1 -0
  93. package/dist/checkout/p-c771a565.entry.js +1 -0
  94. package/dist/checkout/{p-3c9a8bee.entry.js → p-c82b2823.entry.js} +1 -1
  95. package/dist/checkout/p-c8f7d1b5.entry.js +1 -0
  96. package/dist/checkout/p-ceef30cd.entry.js +1 -0
  97. package/dist/checkout/p-d5733333.entry.js +1 -0
  98. package/dist/checkout/p-d5bba69c.entry.js +1 -0
  99. package/dist/checkout/p-d60b2328.js +4 -0
  100. package/dist/checkout/p-d60e05e2.entry.js +1 -0
  101. package/dist/checkout/p-d6b04157.entry.js +1 -0
  102. package/dist/checkout/p-d7a430bf.js +2 -0
  103. package/dist/checkout/{p-B3WORC1a.js → p-d839c693.js} +1 -1
  104. package/dist/checkout/{p-141f2eab.entry.js → p-d9dfb3ae.entry.js} +3 -3
  105. package/dist/checkout/p-dc51d318.js +5 -0
  106. package/dist/checkout/p-ddbe30b8.entry.js +1 -0
  107. package/dist/checkout/p-de418dd1.entry.js +1 -0
  108. package/dist/checkout/{p-b4000357.entry.js → p-defa5f72.entry.js} +2 -2
  109. package/dist/checkout/{p-b90c064e.entry.js → p-df0fa5e1.entry.js} +2 -2
  110. package/dist/checkout/{p-c8740acc.entry.js → p-e0f073f1.entry.js} +3 -3
  111. package/dist/checkout/p-e237d611.entry.js +1 -0
  112. package/dist/checkout/p-ea71fb8d.entry.js +1 -0
  113. package/dist/checkout/{p-95563c4c.entry.js → p-eda93a0b.entry.js} +1 -1
  114. package/dist/checkout/p-eee05053.entry.js +1 -0
  115. package/dist/checkout/{p-95431a73.entry.js → p-f8460dc4.entry.js} +1 -1
  116. package/dist/checkout/p-f875507d.entry.js +1 -0
  117. package/dist/checkout/p-faf06441.js +4 -0
  118. package/dist/checkout/p-fb147065.entry.js +1 -0
  119. package/dist/checkout/{p-af32124b.entry.js → p-fb45cdd1.entry.js} +1 -1
  120. package/dist/cjs/_commonjsHelpers-537d719a.js +20 -0
  121. package/dist/cjs/amwal-checkout-button_5.cjs.entry.js +1298 -2881
  122. package/dist/cjs/amwal-installments-guide.cjs.entry.js +42 -43
  123. package/dist/cjs/amwal-pos.cjs.entry.js +3180 -3452
  124. package/dist/cjs/amwal-widget-modal.cjs.entry.js +162 -175
  125. package/dist/cjs/amwal-widget.cjs.entry.js +314 -343
  126. package/dist/cjs/{animation-BhN-MT4J.js → animation-26241cb2.js} +2 -2
  127. package/dist/cjs/{app-globals-NtXImkuk.js → app-globals-42a13029.js} +1 -1
  128. package/dist/cjs/{ar-CbT6TM-Q.js → ar-3a6829a4.js} +10 -4
  129. package/dist/cjs/{capacitor-CqhugS19.js → capacitor-a9365f60.js} +1 -1
  130. package/dist/cjs/checkout.cjs.js +19 -16
  131. package/dist/cjs/{data-UgkxeXMB.js → data-19081291.js} +1 -1
  132. package/dist/cjs/{form-controller-DRf0gBOg.js → form-controller-3ffb27b1.js} +1 -1
  133. package/dist/cjs/{framework-delegate-D-6PUvOi.js → framework-delegate-ab2cc190.js} +1 -1
  134. package/dist/cjs/{gesture-controller-IMq9Cgi2.js → gesture-controller-b1c0efac.js} +1 -1
  135. package/dist/cjs/{haptic-CC9tl6g8.js → haptic-80174512.js} +1 -1
  136. package/dist/cjs/{hardware-back-button-C2D2eOk8.js → hardware-back-button-ddfefd22.js} +3 -3
  137. package/dist/cjs/{helpers-B4vhh9gt.js → helpers-72ba682d.js} +4 -1
  138. package/dist/cjs/i18n-18ad02d5.js +13 -0
  139. package/dist/cjs/{index-CKcQE8Zg.js → index-0d0b84fb.js} +4 -3
  140. package/dist/cjs/{index-6eOg4xTk.js → index-2602a653.js} +0 -1
  141. package/dist/cjs/{index-DZA7ogU0.js → index-2cd1a895.js} +4 -4
  142. package/dist/cjs/index-7522b3a9.js +2256 -0
  143. package/dist/cjs/{index-bc_r9XRf.js → index-9b7d2c31.js} +9 -9
  144. package/dist/cjs/{index-q1ImtF5k.js → index-ce06e6a3.js} +3 -3
  145. package/dist/cjs/{index-XMjUjboS.js → index-da554121.js} +3 -3
  146. package/dist/cjs/{input-shims-CCRbO2DB.js → input-shims-1a8ed779.js} +6 -6
  147. package/dist/cjs/{input.utils-CyVgmmWQ.js → input.utils-67143876.js} +3 -3
  148. package/dist/cjs/ion-accordion-group.cjs.entry.js +199 -203
  149. package/dist/cjs/ion-accordion.cjs.entry.js +305 -305
  150. package/dist/cjs/ion-action-sheet_3.cjs.entry.js +695 -705
  151. package/dist/cjs/ion-app.cjs.entry.js +95 -93
  152. package/dist/cjs/ion-avatar.cjs.entry.js +14 -12
  153. package/dist/cjs/ion-back-button.cjs.entry.js +78 -76
  154. package/dist/cjs/ion-backdrop.cjs.entry.js +44 -42
  155. package/dist/cjs/ion-badge.cjs.entry.js +19 -17
  156. package/dist/cjs/ion-breadcrumb.cjs.entry.js +86 -84
  157. package/dist/cjs/ion-breadcrumbs.cjs.entry.js +120 -124
  158. package/dist/cjs/ion-buttons_3.cjs.entry.js +822 -822
  159. package/dist/cjs/ion-card-content.cjs.entry.js +19 -17
  160. package/dist/cjs/ion-card-header.cjs.entry.js +22 -20
  161. package/dist/cjs/ion-card-subtitle.cjs.entry.js +20 -18
  162. package/dist/cjs/ion-card-title.cjs.entry.js +20 -18
  163. package/dist/cjs/ion-card.cjs.entry.js +55 -53
  164. package/dist/cjs/ion-checkbox_7.cjs.entry.js +862 -882
  165. package/dist/cjs/ion-chip.cjs.entry.js +24 -22
  166. package/dist/cjs/ion-col.cjs.entry.js +110 -108
  167. package/dist/cjs/ion-content.cjs.entry.js +376 -374
  168. package/dist/cjs/ion-datetime-button.cjs.entry.js +330 -328
  169. package/dist/cjs/ion-datetime.cjs.entry.js +1547 -1567
  170. package/dist/cjs/ion-fab-button.cjs.entry.js +78 -76
  171. package/dist/cjs/ion-fab-list.cjs.entry.js +31 -31
  172. package/dist/cjs/ion-fab.cjs.entry.js +58 -58
  173. package/dist/cjs/ion-footer.cjs.entry.js +94 -92
  174. package/dist/cjs/ion-grid.cjs.entry.js +17 -15
  175. package/dist/cjs/ion-header.cjs.entry.js +143 -141
  176. package/dist/cjs/ion-icon.cjs.entry.js +104 -112
  177. package/dist/cjs/ion-img.cjs.entry.js +83 -83
  178. package/dist/cjs/ion-infinite-scroll-content.cjs.entry.js +34 -32
  179. package/dist/cjs/ion-infinite-scroll.cjs.entry.js +174 -176
  180. package/dist/cjs/ion-input.cjs.entry.js +447 -453
  181. package/dist/cjs/ion-item-divider.cjs.entry.js +23 -21
  182. package/dist/cjs/ion-item-group.cjs.entry.js +20 -18
  183. package/dist/cjs/ion-item-option.cjs.entry.js +45 -43
  184. package/dist/cjs/ion-item-options.cjs.entry.js +40 -38
  185. package/dist/cjs/ion-item-sliding.cjs.entry.js +391 -391
  186. package/dist/cjs/ion-loading.cjs.entry.js +162 -164
  187. package/dist/cjs/ion-menu-button.cjs.entry.js +60 -58
  188. package/dist/cjs/ion-menu-toggle.cjs.entry.js +36 -34
  189. package/dist/cjs/ion-menu.cjs.entry.js +606 -612
  190. package/dist/cjs/ion-modal.cjs.entry.js +551 -553
  191. package/dist/cjs/ion-nav-link.cjs.entry.js +17 -15
  192. package/dist/cjs/ion-nav.cjs.entry.js +823 -825
  193. package/dist/cjs/ion-note.cjs.entry.js +19 -17
  194. package/dist/cjs/ion-picker-column.cjs.entry.js +327 -327
  195. package/dist/cjs/ion-picker.cjs.entry.js +198 -200
  196. package/dist/cjs/ion-popover.cjs.entry.js +326 -330
  197. package/dist/cjs/ion-progress-bar.cjs.entry.js +44 -42
  198. package/dist/cjs/ion-range.cjs.entry.js +644 -654
  199. package/dist/cjs/ion-refresher-content.cjs.entry.js +53 -51
  200. package/dist/cjs/ion-refresher.cjs.entry.js +586 -586
  201. package/dist/cjs/ion-reorder-group.cjs.entry.js +252 -252
  202. package/dist/cjs/ion-reorder.cjs.entry.js +26 -24
  203. package/dist/cjs/ion-route-redirect.cjs.entry.js +19 -21
  204. package/dist/cjs/ion-route.cjs.entry.js +37 -41
  205. package/dist/cjs/ion-router-link.cjs.entry.js +31 -29
  206. package/dist/cjs/ion-router-outlet.cjs.entry.js +178 -178
  207. package/dist/cjs/ion-router.cjs.entry.js +266 -264
  208. package/dist/cjs/ion-row.cjs.entry.js +12 -10
  209. package/dist/cjs/ion-searchbar.cjs.entry.js +388 -396
  210. package/dist/cjs/ion-segment-button.cjs.entry.js +96 -96
  211. package/dist/cjs/ion-segment.cjs.entry.js +414 -420
  212. package/dist/cjs/ion-select-option.cjs.entry.js +16 -14
  213. package/dist/cjs/ion-select.cjs.entry.js +693 -699
  214. package/dist/cjs/ion-skeleton-text.cjs.entry.js +35 -33
  215. package/dist/cjs/ion-spinner.cjs.entry.js +50 -48
  216. package/dist/cjs/ion-split-pane.cjs.entry.js +120 -124
  217. package/dist/cjs/ion-tab-bar.cjs.entry.js +66 -66
  218. package/dist/cjs/ion-tab-button.cjs.entry.js +82 -80
  219. package/dist/cjs/ion-tab.cjs.entry.js +50 -50
  220. package/dist/cjs/ion-tabs.cjs.entry.js +134 -132
  221. package/dist/cjs/ion-textarea.cjs.entry.js +396 -400
  222. package/dist/cjs/ion-thumbnail.cjs.entry.js +12 -10
  223. package/dist/cjs/ion-title.cjs.entry.js +43 -43
  224. package/dist/cjs/ion-toast.cjs.entry.js +371 -375
  225. package/dist/cjs/ion-toggle.cjs.entry.js +230 -230
  226. package/dist/cjs/ion-toolbar.cjs.entry.js +61 -59
  227. package/dist/cjs/{ionic-global-DRLi5Iq3.js → ionic-global-3915f1f1.js} +55 -58
  228. package/dist/cjs/{ios.transition-D4vyO_a_.js → ios.transition-b9c0b967.js} +5 -5
  229. package/dist/cjs/{keyboard-iyHR2ZF4.js → keyboard-5d4b83b3.js} +3 -3
  230. package/dist/cjs/{keyboard-DuKzsHsS.js → keyboard-bc8ebbf7.js} +1 -1
  231. package/dist/cjs/{keyboard-controller-rH21qC_2.js → keyboard-controller-c6633754.js} +2 -2
  232. package/dist/cjs/loader.cjs.js +19 -8
  233. package/dist/cjs/{md.transition-Dkxy3kpE.js → md.transition-830acbb7.js} +5 -5
  234. package/dist/cjs/{menu-toggle-util-CmPuayU0.js → menu-toggle-util-315c26b3.js} +1 -1
  235. package/dist/cjs/{notch-controller-Dtpow1eD.js → notch-controller-dcf09601.js} +2 -2
  236. package/dist/cjs/{overlays-Bc8tk6t5.js → overlays-08819e3f.js} +6 -6
  237. package/dist/cjs/{refresher.utils-CPl6gciv.js → refresher.utils-e41509f7.js} +3 -3
  238. package/dist/cjs/{status-tap-XtIhF72O.js → status-tap-ec021cb4.js} +4 -4
  239. package/dist/cjs/{swipe-back-C9j0kufI.js → swipe-back-3d3a5129.js} +4 -4
  240. package/dist/collection/collection-manifest.json +8 -8
  241. package/dist/collection/components/amwal-checkout-button/amwal-checkout-button.js +1714 -1888
  242. package/dist/collection/components/amwal-checkout-button/amwal-checkout-button.stories.js +84 -84
  243. package/dist/collection/components/amwal-installments-guide/amwal-installments-guide.js +75 -80
  244. package/dist/collection/components/amwal-installments-guide/amwal-installments-guide.stories.js +25 -25
  245. package/dist/collection/components/amwal-installments-timeline/amwal-installments-timeline.js +506 -569
  246. package/dist/collection/components/amwal-installments-timeline/amwal-installments-timeline.stories.js +80 -80
  247. package/dist/collection/components/amwal-pos/amwal-pos.js +1022 -1094
  248. package/dist/collection/components/amwal-pos/amwal-pos.stories.js +209 -209
  249. package/dist/collection/components/amwal-widget/amwal-widget-modal.js +326 -350
  250. package/dist/collection/components/amwal-widget/amwal-widget.js +673 -736
  251. package/dist/collection/components/amwal-widget/amwal-widget.stories.js +184 -184
  252. package/dist/collection/lang/i18n.js +7 -7
  253. package/dist/components/amwal-checkout-button.d.ts +2 -2
  254. package/dist/components/amwal-checkout-button.js +3811 -1
  255. package/dist/components/amwal-installments-guide.d.ts +2 -2
  256. package/dist/components/amwal-installments-guide.js +75 -1
  257. package/dist/components/amwal-installments-timeline.d.ts +2 -2
  258. package/dist/components/amwal-installments-timeline.js +6 -1
  259. package/dist/components/amwal-pos.d.ts +2 -2
  260. package/dist/components/amwal-pos.js +3391 -1
  261. package/dist/components/amwal-widget-modal.d.ts +2 -2
  262. package/dist/components/amwal-widget-modal.js +6 -1
  263. package/dist/components/amwal-widget.d.ts +2 -2
  264. package/dist/components/amwal-widget.js +389 -1
  265. package/dist/components/index.d.ts +0 -6
  266. package/dist/components/index.js +6 -1
  267. package/dist/components/ion-accordion-group.js +248 -1
  268. package/dist/components/ion-accordion.js +353 -1
  269. package/dist/components/ion-action-sheet.js +6 -1
  270. package/dist/components/ion-alert.js +6 -1
  271. package/dist/components/ion-app.js +125 -1
  272. package/dist/components/ion-avatar.js +39 -1
  273. package/dist/components/ion-back-button.js +127 -1
  274. package/dist/components/ion-backdrop.js +6 -1
  275. package/dist/components/ion-badge.js +46 -1
  276. package/dist/components/ion-breadcrumb.js +131 -1
  277. package/dist/components/ion-breadcrumbs.js +152 -1
  278. package/dist/components/ion-button.js +6 -1
  279. package/dist/components/ion-buttons.js +6 -1
  280. package/dist/components/ion-card-content.js +43 -1
  281. package/dist/components/ion-card-header.js +50 -1
  282. package/dist/components/ion-card-subtitle.js +47 -1
  283. package/dist/components/ion-card-title.js +47 -1
  284. package/dist/components/ion-card.js +98 -1
  285. package/dist/components/ion-checkbox.js +6 -1
  286. package/dist/components/ion-chip.js +59 -1
  287. package/dist/components/ion-col.js +186 -2
  288. package/dist/components/ion-content.js +440 -1
  289. package/dist/components/ion-datetime-button.js +378 -1
  290. package/dist/components/ion-datetime.js +1961 -2
  291. package/dist/components/ion-fab-button.js +130 -1
  292. package/dist/components/ion-fab-list.js +56 -1
  293. package/dist/components/ion-fab.js +90 -1
  294. package/dist/components/ion-footer.js +152 -2
  295. package/dist/components/ion-grid.js +41 -1
  296. package/dist/components/ion-header.js +356 -2
  297. package/dist/components/ion-icon.js +6 -1
  298. package/dist/components/ion-img.js +124 -1
  299. package/dist/components/ion-infinite-scroll-content.js +69 -1
  300. package/dist/components/ion-infinite-scroll.js +209 -1
  301. package/dist/components/ion-input.js +564 -1
  302. package/dist/components/ion-item-divider.js +51 -1
  303. package/dist/components/ion-item-group.js +44 -1
  304. package/dist/components/ion-item-option.js +85 -1
  305. package/dist/components/ion-item-options.js +67 -1
  306. package/dist/components/ion-item-sliding.js +449 -1
  307. package/dist/components/ion-item.js +6 -1
  308. package/dist/components/ion-label.js +6 -1
  309. package/dist/components/ion-list-header.js +6 -1
  310. package/dist/components/ion-list.js +6 -1
  311. package/dist/components/ion-loading.js +325 -3
  312. package/dist/components/ion-menu-button.js +100 -1
  313. package/dist/components/ion-menu-toggle.js +57 -1
  314. package/dist/components/ion-menu.js +679 -1
  315. package/dist/components/ion-modal.js +1775 -3
  316. package/dist/components/ion-nav-link.js +63 -2
  317. package/dist/components/ion-nav.js +945 -2
  318. package/dist/components/ion-note.js +6 -1
  319. package/dist/components/ion-picker-column-internal.js +6 -1
  320. package/dist/components/ion-picker-column.js +6 -1
  321. package/dist/components/ion-picker-internal.js +6 -1
  322. package/dist/components/ion-picker.js +317 -3
  323. package/dist/components/ion-popover.js +6 -1
  324. package/dist/components/ion-progress-bar.js +79 -1
  325. package/dist/components/ion-radio-group.js +6 -1
  326. package/dist/components/ion-radio.js +6 -1
  327. package/dist/components/ion-range.js +778 -2
  328. package/dist/components/ion-refresher-content.js +90 -1
  329. package/dist/components/ion-refresher.js +652 -1
  330. package/dist/components/ion-reorder-group.js +300 -1
  331. package/dist/components/ion-reorder.js +58 -1
  332. package/dist/components/ion-ripple-effect.js +6 -1
  333. package/dist/components/ion-route-redirect.js +42 -1
  334. package/dist/components/ion-route.js +66 -1
  335. package/dist/components/ion-router-link.js +60 -1
  336. package/dist/components/ion-router-outlet.js +219 -1
  337. package/dist/components/ion-router.js +833 -3
  338. package/dist/components/ion-row.js +34 -1
  339. package/dist/components/ion-searchbar.js +472 -1
  340. package/dist/components/ion-segment-button.js +139 -1
  341. package/dist/components/ion-segment.js +472 -1
  342. package/dist/components/ion-select-option.js +42 -1
  343. package/dist/components/ion-select-popover.js +6 -1
  344. package/dist/components/ion-select.js +864 -1
  345. package/dist/components/ion-skeleton-text.js +59 -1
  346. package/dist/components/ion-spinner.js +6 -1
  347. package/dist/components/ion-split-pane.js +166 -1
  348. package/dist/components/ion-tab-bar.js +95 -1
  349. package/dist/components/ion-tab-button.js +125 -1
  350. package/dist/components/ion-tab.js +80 -1
  351. package/dist/components/ion-tabs.js +176 -1
  352. package/dist/components/ion-text.js +6 -1
  353. package/dist/components/ion-textarea.js +496 -1
  354. package/dist/components/ion-thumbnail.js +34 -1
  355. package/dist/components/ion-title.js +71 -1
  356. package/dist/components/ion-toast.js +914 -3
  357. package/dist/components/ion-toggle.js +282 -1
  358. package/dist/components/ion-toolbar.js +91 -1
  359. package/dist/components/p-01b49f83.js +269 -0
  360. package/dist/{esm/ios.transition-DMsViooj.js → components/p-02b77441.js} +2 -5
  361. package/dist/components/p-02bc6b21.js +203 -0
  362. package/dist/components/p-031ed92d.js +389 -0
  363. package/dist/components/p-03803c7d.js +369 -0
  364. package/dist/components/p-089e034e.js +234 -0
  365. package/dist/components/p-0dc7a5ff.js +512 -0
  366. package/dist/components/p-110f8490.js +566 -0
  367. package/dist/components/p-112455b1.js +17 -0
  368. package/dist/{esm/index-BMJhFU53.js → components/p-1596e301.js} +4 -4
  369. package/dist/components/p-1785e30a.js +318 -0
  370. package/dist/{esm/helpers-C6kqtbmV.js → components/p-2bb89b46.js} +5 -2
  371. package/dist/components/p-2d7d745d.js +224 -0
  372. package/dist/components/p-2fc99fef.js +262 -0
  373. package/dist/{esm/input-shims-DSFPFhb7.js → components/p-3296ebd9.js} +4 -6
  374. package/dist/{esm/data-Cl-_yBA0.js → components/p-39ad94cf.js} +2 -2
  375. package/dist/{esm/capacitor-CG3xQUND.js → components/p-3d3eefc3.js} +1 -1
  376. package/dist/{esm/form-controller-xetTxjL6.js → components/p-3e1d2896.js} +1 -1
  377. package/dist/{esm/keyboard-controller-CqGCg8tB.js → components/p-3e1e3453.js} +2 -2
  378. package/dist/{esm/md.transition-BQT2r4ED.js → components/p-503328f2.js} +2 -5
  379. package/dist/components/p-51c44f42.js +98 -0
  380. package/dist/components/p-5280b372.js +42 -0
  381. package/dist/{esm/index-DuUXGZp2.js → components/p-53e2dbe4.js} +3 -3
  382. package/dist/components/p-5441c730.js +851 -0
  383. package/dist/{esm/refresher.utils-D4tPnZsM.js → components/p-74e68924.js} +4 -4
  384. package/dist/{esm/framework-delegate-D_uGiYYw.js → components/p-76525f0f.js} +1 -1
  385. package/dist/{esm/index-CcopIPA0.js → components/p-77104220.js} +6 -4
  386. package/dist/components/p-77ccb793.js +185 -0
  387. package/dist/components/p-83e529db.js +380 -0
  388. package/dist/{esm/animation-DRf3dwMu.js → components/p-89c4c5cb.js} +2 -2
  389. package/dist/components/p-8b3d1e06.js +67 -0
  390. package/dist/components/p-901c16c5.js +210 -0
  391. package/dist/components/p-93e2a608.js +374 -0
  392. package/dist/components/p-95c79593.js +43 -0
  393. package/dist/components/p-96073863.js +82 -0
  394. package/dist/components/p-99e447f9.js +13 -0
  395. package/dist/{esm/keyboard-DgiyREKb.js → components/p-9b519de5.js} +1 -1
  396. package/dist/{esm/input.utils-BuIvhxo3.js → components/p-9d350d61.js} +3 -3
  397. package/dist/{esm/notch-controller-CQeDnZLe.js → components/p-9df67c24.js} +2 -2
  398. package/dist/components/p-a0e691dd.js +39 -0
  399. package/dist/components/p-ab10d1ae.js +47 -0
  400. package/dist/components/p-abc01c5d.js +194 -0
  401. package/dist/components/p-abd248d1.js +196 -0
  402. package/dist/{esm/haptic-D5jGzBs8.js → components/p-af073aaf.js} +2 -2
  403. package/dist/{esm/swipe-back-DE05lWQD.js → components/p-b32529b9.js} +3 -4
  404. package/dist/{esm/index-C75BfBAE.js → components/p-b8fdd517.js} +1 -2
  405. package/dist/components/p-cebc113f.js +38 -0
  406. package/dist/components/p-d25fd077.js +331 -0
  407. package/dist/{esm/menu-toggle-util-wdO31cdC.js → components/p-d3596f64.js} +1 -1
  408. package/dist/{esm/keyboard-DcbqYXj5.js → components/p-d60b2328.js} +1 -3
  409. package/dist/components/p-d69dc32f.js +97 -0
  410. package/dist/{esm/hardware-back-button-CzxcJiYO.js → components/p-d72e8d7b.js} +2 -3
  411. package/dist/{esm/ar-B3WORC1a.js → components/p-d839c693.js} +12 -5
  412. package/dist/{esm/index-D8d_89Nl.js → components/p-e187a77c.js} +1 -1
  413. package/dist/components/p-e65ea9fb.js +1379 -0
  414. package/dist/components/p-ec0e3f3f.js +2040 -0
  415. package/dist/components/p-ecb4db1c.js +64 -0
  416. package/dist/{esm/gesture-controller-CukVBo5-.js → components/p-f728a68f.js} +1 -1
  417. package/dist/components/p-f7e3c502.js +73 -0
  418. package/dist/components/p-fe463a42.js +272 -0
  419. package/dist/esm/_commonjsHelpers-9943807e.js +17 -0
  420. package/dist/esm/amwal-checkout-button_5.entry.js +1296 -2881
  421. package/dist/esm/amwal-installments-guide.entry.js +40 -43
  422. package/dist/esm/amwal-pos.entry.js +3178 -3452
  423. package/dist/esm/amwal-widget-modal.entry.js +160 -175
  424. package/dist/esm/amwal-widget.entry.js +312 -343
  425. package/dist/esm/animation-a6d5c3b1.js +1063 -0
  426. package/dist/esm/{app-globals-BHnkZZiH.js → app-globals-c817b28b.js} +1 -1
  427. package/dist/esm/ar-7d2629bf.js +51 -0
  428. package/dist/esm/capacitor-ba4337da.js +13 -0
  429. package/dist/esm/checkout.js +18 -16
  430. package/dist/esm/config-8e06237c.js +171 -0
  431. package/dist/esm/cubic-bezier-874f336d.js +90 -0
  432. package/dist/esm/data-8916315d.js +1628 -0
  433. package/dist/esm/dir-1d4aa386.js +18 -0
  434. package/dist/esm/focus-visible-32968d3d.js +75 -0
  435. package/dist/esm/form-controller-b1aa7393.js +64 -0
  436. package/dist/esm/framework-delegate-de1aa369.js +140 -0
  437. package/dist/esm/gesture-controller-58ffa500.js +195 -0
  438. package/dist/esm/haptic-4d4d8eb1.js +206 -0
  439. package/dist/esm/hardware-back-button-f93acff0.js +116 -0
  440. package/dist/esm/helpers-f0dcbd72.js +418 -0
  441. package/dist/esm/i18n-53f85411.js +13 -0
  442. package/dist/esm/{index-CNcx43L8.js → index-0b560278.js} +4 -4
  443. package/dist/esm/index-5894dd63.js +196 -0
  444. package/dist/esm/{index-DUF6JAQL.js → index-5a126e54.js} +6 -6
  445. package/dist/esm/index-5e663431.js +128 -0
  446. package/dist/esm/index-8cc94b11.js +2219 -0
  447. package/dist/esm/index-afdf867c.js +26 -0
  448. package/dist/esm/index-d9b41a43.js +34 -0
  449. package/dist/esm/index-f6dce931.js +466 -0
  450. package/dist/esm/index-fb97e55c.js +7 -0
  451. package/dist/esm/input-shims-75d4750d.js +617 -0
  452. package/dist/esm/input.utils-79bde07f.js +138 -0
  453. package/dist/esm/ion-accordion-group.entry.js +197 -203
  454. package/dist/esm/ion-accordion.entry.js +303 -305
  455. package/dist/esm/ion-action-sheet_3.entry.js +693 -705
  456. package/dist/esm/ion-app.entry.js +93 -93
  457. package/dist/esm/ion-avatar.entry.js +12 -12
  458. package/dist/esm/ion-back-button.entry.js +76 -76
  459. package/dist/esm/ion-backdrop.entry.js +42 -42
  460. package/dist/esm/ion-badge.entry.js +17 -17
  461. package/dist/esm/ion-breadcrumb.entry.js +84 -84
  462. package/dist/esm/ion-breadcrumbs.entry.js +118 -124
  463. package/dist/esm/ion-buttons_3.entry.js +820 -822
  464. package/dist/esm/ion-card-content.entry.js +17 -17
  465. package/dist/esm/ion-card-header.entry.js +20 -20
  466. package/dist/esm/ion-card-subtitle.entry.js +18 -18
  467. package/dist/esm/ion-card-title.entry.js +18 -18
  468. package/dist/esm/ion-card.entry.js +53 -53
  469. package/dist/esm/ion-checkbox_7.entry.js +860 -882
  470. package/dist/esm/ion-chip.entry.js +22 -22
  471. package/dist/esm/ion-col.entry.js +108 -108
  472. package/dist/esm/ion-content.entry.js +374 -374
  473. package/dist/esm/ion-datetime-button.entry.js +328 -328
  474. package/dist/esm/ion-datetime.entry.js +1545 -1567
  475. package/dist/esm/ion-fab-button.entry.js +76 -76
  476. package/dist/esm/ion-fab-list.entry.js +29 -31
  477. package/dist/esm/ion-fab.entry.js +56 -58
  478. package/dist/esm/ion-footer.entry.js +92 -92
  479. package/dist/esm/ion-grid.entry.js +15 -15
  480. package/dist/esm/ion-header.entry.js +141 -141
  481. package/dist/esm/ion-icon.entry.js +102 -112
  482. package/dist/esm/ion-img.entry.js +81 -83
  483. package/dist/esm/ion-infinite-scroll-content.entry.js +32 -32
  484. package/dist/esm/ion-infinite-scroll.entry.js +172 -176
  485. package/dist/esm/ion-input.entry.js +445 -453
  486. package/dist/esm/ion-item-divider.entry.js +21 -21
  487. package/dist/esm/ion-item-group.entry.js +18 -18
  488. package/dist/esm/ion-item-option.entry.js +43 -43
  489. package/dist/esm/ion-item-options.entry.js +38 -38
  490. package/dist/esm/ion-item-sliding.entry.js +389 -391
  491. package/dist/esm/ion-loading.entry.js +160 -164
  492. package/dist/esm/ion-menu-button.entry.js +58 -58
  493. package/dist/esm/ion-menu-toggle.entry.js +34 -34
  494. package/dist/esm/ion-menu.entry.js +604 -612
  495. package/dist/esm/ion-modal.entry.js +549 -553
  496. package/dist/esm/ion-nav-link.entry.js +15 -15
  497. package/dist/esm/ion-nav.entry.js +821 -825
  498. package/dist/esm/ion-note.entry.js +17 -17
  499. package/dist/esm/ion-picker-column.entry.js +325 -327
  500. package/dist/esm/ion-picker.entry.js +196 -200
  501. package/dist/esm/ion-popover.entry.js +324 -330
  502. package/dist/esm/ion-progress-bar.entry.js +42 -42
  503. package/dist/esm/ion-range.entry.js +642 -654
  504. package/dist/esm/ion-refresher-content.entry.js +51 -51
  505. package/dist/esm/ion-refresher.entry.js +584 -586
  506. package/dist/esm/ion-reorder-group.entry.js +250 -252
  507. package/dist/esm/ion-reorder.entry.js +24 -24
  508. package/dist/esm/ion-route-redirect.entry.js +17 -21
  509. package/dist/esm/ion-route.entry.js +35 -41
  510. package/dist/esm/ion-router-link.entry.js +29 -29
  511. package/dist/esm/ion-router-outlet.entry.js +176 -178
  512. package/dist/esm/ion-router.entry.js +264 -264
  513. package/dist/esm/ion-row.entry.js +10 -10
  514. package/dist/esm/ion-searchbar.entry.js +386 -396
  515. package/dist/esm/ion-segment-button.entry.js +94 -96
  516. package/dist/esm/ion-segment.entry.js +412 -420
  517. package/dist/esm/ion-select-option.entry.js +14 -14
  518. package/dist/esm/ion-select.entry.js +691 -699
  519. package/dist/esm/ion-skeleton-text.entry.js +33 -33
  520. package/dist/esm/ion-spinner.entry.js +48 -48
  521. package/dist/esm/ion-split-pane.entry.js +118 -124
  522. package/dist/esm/ion-tab-bar.entry.js +64 -66
  523. package/dist/esm/ion-tab-button.entry.js +80 -80
  524. package/dist/esm/ion-tab.entry.js +48 -50
  525. package/dist/esm/ion-tabs.entry.js +132 -132
  526. package/dist/esm/ion-textarea.entry.js +394 -400
  527. package/dist/esm/ion-thumbnail.entry.js +10 -10
  528. package/dist/esm/ion-title.entry.js +41 -43
  529. package/dist/esm/ion-toast.entry.js +369 -375
  530. package/dist/esm/ion-toggle.entry.js +228 -230
  531. package/dist/esm/ion-toolbar.entry.js +59 -59
  532. package/dist/esm/{ionic-global-DXXzPLPc.js → ionic-global-0b7766cb.js} +55 -58
  533. package/dist/esm/ios.transition-22fb53bc.js +651 -0
  534. package/dist/esm/keyboard-1f073554.js +82 -0
  535. package/dist/esm/keyboard-96b6e80b.js +146 -0
  536. package/dist/esm/keyboard-controller-5a2f625f.js +165 -0
  537. package/dist/esm/loader.js +17 -8
  538. package/dist/esm/lock-controller-632e3c10.js +38 -0
  539. package/dist/esm/md.transition-f6ff9834.js +57 -0
  540. package/dist/esm/menu-toggle-util-594849ff.js +12 -0
  541. package/dist/esm/notch-controller-d511b3b3.js +153 -0
  542. package/dist/esm/{overlays-SBLrmFy6.js → overlays-642a91df.js} +7 -7
  543. package/dist/esm/polyfills/core-js.js +11 -0
  544. package/dist/esm/polyfills/css-shim.js +1 -0
  545. package/dist/esm/polyfills/dom.js +79 -0
  546. package/dist/esm/polyfills/es5-html-element.js +1 -0
  547. package/dist/esm/polyfills/index.js +34 -0
  548. package/dist/esm/polyfills/system.js +6 -0
  549. package/dist/esm/refresher.utils-19137568.js +196 -0
  550. package/dist/esm/{status-tap-CjxQA4Bj.js → status-tap-bb6959a8.js} +4 -4
  551. package/dist/esm/swipe-back-6cec4c33.js +79 -0
  552. package/dist/esm/theme-35c700b7.js +43 -0
  553. package/dist/esm/watch-options-7bf43687.js +47 -0
  554. package/dist/node_modules/@ionic/core/dist/collection/components/accordion/accordion.ios.css +193 -0
  555. package/dist/node_modules/@ionic/core/dist/collection/components/accordion/accordion.md.css +135 -0
  556. package/dist/node_modules/@ionic/core/dist/collection/components/accordion-group/accordion-group.ios.css +127 -0
  557. package/dist/node_modules/@ionic/core/dist/collection/components/accordion-group/accordion-group.md.css +229 -0
  558. package/dist/node_modules/@ionic/core/dist/collection/components/action-sheet/action-sheet.ios.css +456 -0
  559. package/dist/node_modules/@ionic/core/dist/collection/components/action-sheet/action-sheet.md.css +384 -0
  560. package/dist/node_modules/@ionic/core/dist/collection/components/alert/alert.ios.css +755 -0
  561. package/dist/node_modules/@ionic/core/dist/collection/components/alert/alert.md.css +770 -0
  562. package/dist/node_modules/@ionic/core/dist/collection/components/app/app.css +17 -0
  563. package/dist/node_modules/@ionic/core/dist/collection/components/avatar/avatar.ios.css +132 -0
  564. package/dist/node_modules/@ionic/core/dist/collection/components/avatar/avatar.md.css +132 -0
  565. package/dist/node_modules/@ionic/core/dist/collection/components/back-button/back-button.ios.css +372 -0
  566. package/dist/node_modules/@ionic/core/dist/collection/components/back-button/back-button.md.css +385 -0
  567. package/dist/node_modules/@ionic/core/dist/collection/components/backdrop/backdrop.ios.css +136 -0
  568. package/dist/node_modules/@ionic/core/dist/collection/components/backdrop/backdrop.md.css +136 -0
  569. package/dist/node_modules/@ionic/core/dist/collection/components/badge/badge.ios.css +168 -0
  570. package/dist/node_modules/@ionic/core/dist/collection/components/badge/badge.md.css +164 -0
  571. package/dist/node_modules/@ionic/core/dist/collection/components/breadcrumb/breadcrumb.ios.css +326 -0
  572. package/dist/node_modules/@ionic/core/dist/collection/components/breadcrumb/breadcrumb.md.css +310 -0
  573. package/dist/node_modules/@ionic/core/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +81 -0
  574. package/dist/node_modules/@ionic/core/dist/collection/components/breadcrumbs/breadcrumbs.md.css +80 -0
  575. package/dist/node_modules/@ionic/core/dist/collection/components/button/button.ios.css +596 -0
  576. package/dist/node_modules/@ionic/core/dist/collection/components/button/button.md.css +517 -0
  577. package/dist/node_modules/@ionic/core/dist/collection/components/buttons/buttons.ios.css +279 -0
  578. package/dist/node_modules/@ionic/core/dist/collection/components/buttons/buttons.md.css +299 -0
  579. package/dist/node_modules/@ionic/core/dist/collection/components/card/card.ios.css +203 -0
  580. package/dist/node_modules/@ionic/core/dist/collection/components/card/card.md.css +198 -0
  581. package/dist/node_modules/@ionic/core/dist/collection/components/card-content/card-content.ios.css +163 -0
  582. package/dist/node_modules/@ionic/core/dist/collection/components/card-content/card-content.md.css +165 -0
  583. package/dist/node_modules/@ionic/core/dist/collection/components/card-header/card-header.ios.css +141 -0
  584. package/dist/node_modules/@ionic/core/dist/collection/components/card-header/card-header.md.css +138 -0
  585. package/dist/node_modules/@ionic/core/dist/collection/components/card-subtitle/card-subtitle.ios.css +138 -0
  586. package/dist/node_modules/@ionic/core/dist/collection/components/card-subtitle/card-subtitle.md.css +136 -0
  587. package/dist/node_modules/@ionic/core/dist/collection/components/card-title/card-title.ios.css +137 -0
  588. package/dist/node_modules/@ionic/core/dist/collection/components/card-title/card-title.md.css +137 -0
  589. package/dist/node_modules/@ionic/core/dist/collection/components/checkbox/checkbox.ios.css +536 -0
  590. package/dist/node_modules/@ionic/core/dist/collection/components/checkbox/checkbox.md.css +552 -0
  591. package/dist/node_modules/@ionic/core/dist/collection/components/chip/chip.ios.css +212 -0
  592. package/dist/node_modules/@ionic/core/dist/collection/components/chip/chip.md.css +207 -0
  593. package/dist/node_modules/@ionic/core/dist/collection/components/col/col.css +200 -0
  594. package/dist/node_modules/@ionic/core/dist/collection/components/content/content.css +282 -0
  595. package/dist/node_modules/@ionic/core/dist/collection/components/datetime/datetime.ios.css +850 -0
  596. package/dist/node_modules/@ionic/core/dist/collection/components/datetime/datetime.md.css +706 -0
  597. package/dist/node_modules/@ionic/core/dist/collection/components/datetime-button/datetime-button.css +100 -0
  598. package/dist/node_modules/@ionic/core/dist/collection/components/fab/fab.css +366 -0
  599. package/dist/node_modules/@ionic/core/dist/collection/components/fab-button/fab-button.ios.css +422 -0
  600. package/dist/node_modules/@ionic/core/dist/collection/components/fab-button/fab-button.md.css +393 -0
  601. package/dist/node_modules/@ionic/core/dist/collection/components/fab-list/fab-list.css +240 -0
  602. package/dist/node_modules/@ionic/core/dist/collection/components/footer/footer.ios.css +146 -0
  603. package/dist/node_modules/@ionic/core/dist/collection/components/footer/footer.md.css +129 -0
  604. package/dist/node_modules/@ionic/core/dist/collection/components/grid/grid.css +235 -0
  605. package/dist/node_modules/@ionic/core/dist/collection/components/header/header.ios.css +250 -0
  606. package/dist/node_modules/@ionic/core/dist/collection/components/header/header.md.css +133 -0
  607. package/dist/node_modules/@ionic/core/dist/collection/components/img/img.css +12 -0
  608. package/dist/node_modules/@ionic/core/dist/collection/components/infinite-scroll/infinite-scroll.css +8 -0
  609. package/dist/node_modules/@ionic/core/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +156 -0
  610. package/dist/node_modules/@ionic/core/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +156 -0
  611. package/dist/node_modules/@ionic/core/dist/collection/components/input/input.ios.css +833 -0
  612. package/dist/node_modules/@ionic/core/dist/collection/components/input/input.md.css +1446 -0
  613. package/dist/node_modules/@ionic/core/dist/collection/components/item/item.ios.css +815 -0
  614. package/dist/node_modules/@ionic/core/dist/collection/components/item/item.md.css +1187 -0
  615. package/dist/node_modules/@ionic/core/dist/collection/components/item-divider/item-divider.ios.css +351 -0
  616. package/dist/node_modules/@ionic/core/dist/collection/components/item-divider/item-divider.md.css +417 -0
  617. package/dist/node_modules/@ionic/core/dist/collection/components/item-group/item-group.ios.css +114 -0
  618. package/dist/node_modules/@ionic/core/dist/collection/components/item-group/item-group.md.css +114 -0
  619. package/dist/node_modules/@ionic/core/dist/collection/components/item-option/item-option.ios.css +242 -0
  620. package/dist/node_modules/@ionic/core/dist/collection/components/item-option/item-option.md.css +236 -0
  621. package/dist/node_modules/@ionic/core/dist/collection/components/item-options/item-options.ios.css +287 -0
  622. package/dist/node_modules/@ionic/core/dist/collection/components/item-options/item-options.md.css +284 -0
  623. package/dist/node_modules/@ionic/core/dist/collection/components/item-sliding/item-sliding.css +121 -0
  624. package/dist/node_modules/@ionic/core/dist/collection/components/label/label.ios.css +334 -0
  625. package/dist/node_modules/@ionic/core/dist/collection/components/label/label.md.css +421 -0
  626. package/dist/node_modules/@ionic/core/dist/collection/components/list/list.ios.css +242 -0
  627. package/dist/node_modules/@ionic/core/dist/collection/components/list/list.md.css +287 -0
  628. package/dist/node_modules/@ionic/core/dist/collection/components/list-header/list-header.ios.css +285 -0
  629. package/dist/node_modules/@ionic/core/dist/collection/components/list-header/list-header.md.css +266 -0
  630. package/dist/node_modules/@ionic/core/dist/collection/components/loading/loading.ios.css +205 -0
  631. package/dist/node_modules/@ionic/core/dist/collection/components/loading/loading.md.css +196 -0
  632. package/dist/node_modules/@ionic/core/dist/collection/components/menu/menu.ios.css +378 -0
  633. package/dist/node_modules/@ionic/core/dist/collection/components/menu/menu.md.css +374 -0
  634. package/dist/node_modules/@ionic/core/dist/collection/components/menu-button/menu-button.ios.css +279 -0
  635. package/dist/node_modules/@ionic/core/dist/collection/components/menu-button/menu-button.md.css +282 -0
  636. package/dist/node_modules/@ionic/core/dist/collection/components/menu-toggle/menu-toggle.css +3 -0
  637. package/dist/node_modules/@ionic/core/dist/collection/components/modal/modal.ios.css +357 -0
  638. package/dist/node_modules/@ionic/core/dist/collection/components/modal/modal.md.css +272 -0
  639. package/dist/node_modules/@ionic/core/dist/collection/components/nav/nav.css +64 -0
  640. package/dist/node_modules/@ionic/core/dist/collection/components/note/note.ios.css +127 -0
  641. package/dist/node_modules/@ionic/core/dist/collection/components/note/note.md.css +127 -0
  642. package/dist/node_modules/@ionic/core/dist/collection/components/picker/picker.ios.css +367 -0
  643. package/dist/node_modules/@ionic/core/dist/collection/components/picker/picker.md.css +354 -0
  644. package/dist/node_modules/@ionic/core/dist/collection/components/picker-column/picker-column.ios.css +255 -0
  645. package/dist/node_modules/@ionic/core/dist/collection/components/picker-column/picker-column.md.css +246 -0
  646. package/dist/node_modules/@ionic/core/dist/collection/components/picker-column-internal/picker-column-internal.ios.css +138 -0
  647. package/dist/node_modules/@ionic/core/dist/collection/components/picker-column-internal/picker-column-internal.md.css +196 -0
  648. package/dist/node_modules/@ionic/core/dist/collection/components/picker-internal/picker-internal.ios.css +262 -0
  649. package/dist/node_modules/@ionic/core/dist/collection/components/picker-internal/picker-internal.md.css +258 -0
  650. package/dist/node_modules/@ionic/core/dist/collection/components/popover/popover.ios.css +366 -0
  651. package/dist/node_modules/@ionic/core/dist/collection/components/popover/popover.md.css +266 -0
  652. package/dist/node_modules/@ionic/core/dist/collection/components/progress-bar/progress-bar.ios.css +261 -0
  653. package/dist/node_modules/@ionic/core/dist/collection/components/progress-bar/progress-bar.md.css +261 -0
  654. package/dist/node_modules/@ionic/core/dist/collection/components/radio/radio.ios.css +557 -0
  655. package/dist/node_modules/@ionic/core/dist/collection/components/radio/radio.md.css +580 -0
  656. package/dist/node_modules/@ionic/core/dist/collection/components/range/range.ios.css +660 -0
  657. package/dist/node_modules/@ionic/core/dist/collection/components/range/range.md.css +819 -0
  658. package/dist/node_modules/@ionic/core/dist/collection/components/refresher/refresher.ios.css +321 -0
  659. package/dist/node_modules/@ionic/core/dist/collection/components/refresher/refresher.md.css +316 -0
  660. package/dist/node_modules/@ionic/core/dist/collection/components/reorder/reorder.ios.css +77 -0
  661. package/dist/node_modules/@ionic/core/dist/collection/components/reorder/reorder.md.css +77 -0
  662. package/dist/node_modules/@ionic/core/dist/collection/components/reorder-group/reorder-group.css +89 -0
  663. package/dist/node_modules/@ionic/core/dist/collection/components/ripple-effect/ripple-effect.css +113 -0
  664. package/dist/node_modules/@ionic/core/dist/collection/components/router-link/router-link.css +84 -0
  665. package/dist/node_modules/@ionic/core/dist/collection/components/router-outlet/router-outlet.css +64 -0
  666. package/dist/node_modules/@ionic/core/dist/collection/components/row/row.css +136 -0
  667. package/dist/node_modules/@ionic/core/dist/collection/components/searchbar/searchbar.ios.css +477 -0
  668. package/dist/node_modules/@ionic/core/dist/collection/components/searchbar/searchbar.md.css +456 -0
  669. package/dist/node_modules/@ionic/core/dist/collection/components/segment/segment.ios.css +224 -0
  670. package/dist/node_modules/@ionic/core/dist/collection/components/segment/segment.md.css +214 -0
  671. package/dist/node_modules/@ionic/core/dist/collection/components/segment-button/segment-button.ios.css +520 -0
  672. package/dist/node_modules/@ionic/core/dist/collection/components/segment-button/segment-button.md.css +506 -0
  673. package/dist/node_modules/@ionic/core/dist/collection/components/select/select.ios.css +787 -0
  674. package/dist/node_modules/@ionic/core/dist/collection/components/select/select.md.css +1374 -0
  675. package/dist/node_modules/@ionic/core/dist/collection/components/select-option/select-option.css +3 -0
  676. package/dist/node_modules/@ionic/core/dist/collection/components/select-popover/select-popover.ios.css +190 -0
  677. package/dist/node_modules/@ionic/core/dist/collection/components/select-popover/select-popover.md.css +212 -0
  678. package/dist/node_modules/@ionic/core/dist/collection/components/skeleton-text/skeleton-text.css +108 -0
  679. package/dist/node_modules/@ionic/core/dist/collection/components/spinner/spinner.css +232 -0
  680. package/dist/node_modules/@ionic/core/dist/collection/components/split-pane/split-pane.ios.css +265 -0
  681. package/dist/node_modules/@ionic/core/dist/collection/components/split-pane/split-pane.md.css +265 -0
  682. package/dist/node_modules/@ionic/core/dist/collection/components/tab/tab.css +4 -0
  683. package/dist/node_modules/@ionic/core/dist/collection/components/tab-bar/tab-bar.ios.css +252 -0
  684. package/dist/node_modules/@ionic/core/dist/collection/components/tab-bar/tab-bar.md.css +239 -0
  685. package/dist/node_modules/@ionic/core/dist/collection/components/tab-button/tab-button.ios.css +477 -0
  686. package/dist/node_modules/@ionic/core/dist/collection/components/tab-button/tab-button.md.css +501 -0
  687. package/dist/node_modules/@ionic/core/dist/collection/components/tabs/tabs.css +74 -0
  688. package/dist/node_modules/@ionic/core/dist/collection/components/text/text.css +58 -0
  689. package/dist/node_modules/@ionic/core/dist/collection/components/textarea/textarea.ios.css +987 -0
  690. package/dist/node_modules/@ionic/core/dist/collection/components/textarea/textarea.md.css +1553 -0
  691. package/dist/node_modules/@ionic/core/dist/collection/components/thumbnail/thumbnail.css +76 -0
  692. package/dist/node_modules/@ionic/core/dist/collection/components/title/title.ios.css +183 -0
  693. package/dist/node_modules/@ionic/core/dist/collection/components/title/title.md.css +102 -0
  694. package/dist/node_modules/@ionic/core/dist/collection/components/toast/toast.ios.css +399 -0
  695. package/dist/node_modules/@ionic/core/dist/collection/components/toast/toast.md.css +429 -0
  696. package/dist/node_modules/@ionic/core/dist/collection/components/toggle/toggle.ios.css +680 -0
  697. package/dist/node_modules/@ionic/core/dist/collection/components/toggle/toggle.md.css +625 -0
  698. package/dist/node_modules/@ionic/core/dist/collection/components/toolbar/toolbar.ios.css +265 -0
  699. package/dist/node_modules/@ionic/core/dist/collection/components/toolbar/toolbar.md.css +244 -0
  700. package/dist/node_modules/ionicons/dist/collection/components/icon/icon.css +144 -0
  701. package/dist/types/components/amwal-checkout-button/amwal-checkout-button.d.ts +327 -327
  702. package/dist/types/components/amwal-checkout-button/amwal-checkout-button.stories.d.ts +34 -34
  703. package/dist/types/components/amwal-installments-guide/amwal-installments-guide.d.ts +14 -14
  704. package/dist/types/components/amwal-installments-guide/amwal-installments-guide.stories.d.ts +17 -17
  705. package/dist/types/components/amwal-installments-timeline/amwal-installments-timeline.d.ts +106 -106
  706. package/dist/types/components/amwal-installments-timeline/amwal-installments-timeline.stories.d.ts +67 -67
  707. package/dist/types/components/amwal-pos/amwal-pos.d.ts +228 -228
  708. package/dist/types/components/amwal-pos/amwal-pos.stories.d.ts +185 -185
  709. package/dist/types/components/amwal-widget/amwal-widget-modal.d.ts +56 -56
  710. package/dist/types/components/amwal-widget/amwal-widget.d.ts +165 -165
  711. package/dist/types/components/amwal-widget/amwal-widget.stories.d.ts +101 -101
  712. package/dist/types/components.d.ts +0 -206
  713. package/dist/types/lang/i18n.d.ts +1 -1
  714. package/dist/types/stencil-public-runtime.d.ts +21 -191
  715. package/loader/cdn.js +3 -1
  716. package/loader/index.cjs.js +3 -1
  717. package/loader/index.d.ts +1 -4
  718. package/loader/index.es2017.js +3 -1
  719. package/loader/index.js +3 -1
  720. package/loader/package.json +11 -0
  721. package/package.json +28 -34
  722. package/dist/checkout/p-0161d109.entry.js +0 -1
  723. package/dist/checkout/p-0a8ef1ec.entry.js +0 -1
  724. package/dist/checkout/p-10a72fbe.entry.js +0 -1
  725. package/dist/checkout/p-12ed4081.entry.js +0 -1
  726. package/dist/checkout/p-13c36adc.entry.js +0 -1
  727. package/dist/checkout/p-194b17d8.entry.js +0 -1
  728. package/dist/checkout/p-272a1ffd.entry.js +0 -1
  729. package/dist/checkout/p-307af48b.entry.js +0 -1
  730. package/dist/checkout/p-3207674d.entry.js +0 -1
  731. package/dist/checkout/p-3208e56f.entry.js +0 -1
  732. package/dist/checkout/p-4426eb3b.entry.js +0 -1
  733. package/dist/checkout/p-458da59f.entry.js +0 -1
  734. package/dist/checkout/p-46e69508.entry.js +0 -1
  735. package/dist/checkout/p-49046c16.entry.js +0 -4
  736. package/dist/checkout/p-53dc0e86.entry.js +0 -1
  737. package/dist/checkout/p-5a6fc9fd.entry.js +0 -1
  738. package/dist/checkout/p-5e65653a.entry.js +0 -1
  739. package/dist/checkout/p-5f124c24.entry.js +0 -1
  740. package/dist/checkout/p-6a8ad104.entry.js +0 -1
  741. package/dist/checkout/p-76fb4325.entry.js +0 -1
  742. package/dist/checkout/p-78db60fb.entry.js +0 -1
  743. package/dist/checkout/p-8e34a1bb.entry.js +0 -1
  744. package/dist/checkout/p-91474b10.entry.js +0 -1
  745. package/dist/checkout/p-93OyAGoo.js +0 -2
  746. package/dist/checkout/p-94a57258.entry.js +0 -1
  747. package/dist/checkout/p-BEVStXwd.js +0 -7
  748. package/dist/checkout/p-BQu7QPd5.js +0 -4
  749. package/dist/checkout/p-BR7SJd-v.js +0 -4
  750. package/dist/checkout/p-BcFRJSFv.js +0 -4
  751. package/dist/checkout/p-BcUxrseY.js +0 -1
  752. package/dist/checkout/p-BdG893XR.js +0 -4
  753. package/dist/checkout/p-BgOwfqIY.js +0 -4
  754. package/dist/checkout/p-Bm9bMvCb.js +0 -4
  755. package/dist/checkout/p-C03M5ZSM.js +0 -1
  756. package/dist/checkout/p-C6kqtbmV.js +0 -4
  757. package/dist/checkout/p-C75BfBAE.js +0 -1
  758. package/dist/checkout/p-CVrvo9Qz.js +0 -4
  759. package/dist/checkout/p-ChixdDt6.js +0 -4
  760. package/dist/checkout/p-Cjnmql4G.js +0 -8
  761. package/dist/checkout/p-D0I0TqZU.js +0 -4
  762. package/dist/checkout/p-D2NxOvQ8.js +0 -4
  763. package/dist/checkout/p-D8d_89Nl.js +0 -4
  764. package/dist/checkout/p-DAhcxcAh.js +0 -4
  765. package/dist/checkout/p-DDtPO7yO.js +0 -4
  766. package/dist/checkout/p-DKg_dYcq.js +0 -4
  767. package/dist/checkout/p-DMAPbDyG.js +0 -4
  768. package/dist/checkout/p-DihS-5gH.js +0 -4
  769. package/dist/checkout/p-DkrNcwKK.js +0 -5
  770. package/dist/checkout/p-Dzj_jqIY.js +0 -4
  771. package/dist/checkout/p-E8AXUhZ3.js +0 -7
  772. package/dist/checkout/p-Ufaww5Lq.js +0 -4
  773. package/dist/checkout/p-a90efa79.entry.js +0 -1
  774. package/dist/checkout/p-abd12b84.entry.js +0 -1
  775. package/dist/checkout/p-abe1becc.entry.js +0 -1
  776. package/dist/checkout/p-b2f66c60.entry.js +0 -4
  777. package/dist/checkout/p-b45f5952.entry.js +0 -1
  778. package/dist/checkout/p-c2240d19.entry.js +0 -1
  779. package/dist/checkout/p-c28b4374.entry.js +0 -1
  780. package/dist/checkout/p-cb2db223.entry.js +0 -1
  781. package/dist/checkout/p-cb3967fc.entry.js +0 -1
  782. package/dist/checkout/p-cef16f11.entry.js +0 -1
  783. package/dist/checkout/p-df1b4347.entry.js +0 -4
  784. package/dist/checkout/p-e4bc42fb.entry.js +0 -1
  785. package/dist/checkout/p-e785fb8a.entry.js +0 -1
  786. package/dist/checkout/p-e8bd206a.entry.js +0 -1
  787. package/dist/checkout/p-ef749875.entry.js +0 -1
  788. package/dist/checkout/p-f157b6b2.entry.js +0 -4
  789. package/dist/checkout/p-f351a19a.entry.js +0 -1
  790. package/dist/checkout/p-ff2e59e3.entry.js +0 -1
  791. package/dist/checkout/p-hAETByzF.js +0 -5
  792. package/dist/checkout/p-vn1iXXUO.js +0 -9
  793. package/dist/cjs/i18n-uGNv9SLK.js +0 -13
  794. package/dist/cjs/index-DncWzXDA.js +0 -3738
  795. package/dist/components/p-55BwDerf.js +0 -8
  796. package/dist/components/p-B-M4K7iJ.js +0 -7
  797. package/dist/components/p-B-hirT0v.js +0 -4
  798. package/dist/components/p-B3WORC1a.js +0 -1
  799. package/dist/components/p-B5XH2zAk.js +0 -1
  800. package/dist/components/p-B5ZghgSh.js +0 -4
  801. package/dist/components/p-BEVStXwd.js +0 -7
  802. package/dist/components/p-BH0TCnxk.js +0 -4
  803. package/dist/components/p-BIA8A9ZO.js +0 -1
  804. package/dist/components/p-BOkYKP6F.js +0 -1
  805. package/dist/components/p-BOm0KT2x.js +0 -1
  806. package/dist/components/p-Bb_Zji0h.js +0 -4
  807. package/dist/components/p-BmVRXR1y.js +0 -4
  808. package/dist/components/p-BnQDByf2.js +0 -1
  809. package/dist/components/p-BoxjYI-Q.js +0 -4
  810. package/dist/components/p-BriBxgcM.js +0 -1
  811. package/dist/components/p-BwKjt_Dc.js +0 -4
  812. package/dist/components/p-Bx78uXfc.js +0 -5
  813. package/dist/components/p-C-20JWsp.js +0 -4
  814. package/dist/components/p-C03M5ZSM.js +0 -1
  815. package/dist/components/p-C53feagD.js +0 -4
  816. package/dist/components/p-CLrB3zV0.js +0 -4
  817. package/dist/components/p-CN34uOrj.js +0 -9
  818. package/dist/components/p-CQmcNwZM.js +0 -4
  819. package/dist/components/p-CYd0Smt1.js +0 -1
  820. package/dist/components/p-CgPXSjzI.js +0 -4
  821. package/dist/components/p-Cho32MPa.js +0 -4
  822. package/dist/components/p-ClE6rMJs.js +0 -4
  823. package/dist/components/p-Cm9b7fIl.js +0 -1
  824. package/dist/components/p-CukVBo5-.js +0 -4
  825. package/dist/components/p-D2NxOvQ8.js +0 -4
  826. package/dist/components/p-D4DqwBlW.js +0 -4
  827. package/dist/components/p-D7YY0NXg.js +0 -4
  828. package/dist/components/p-D8OVJo1v.js +0 -7
  829. package/dist/components/p-DKg_dYcq.js +0 -4
  830. package/dist/components/p-DLVYPrYs.js +0 -1
  831. package/dist/components/p-DMmSL7_l.js +0 -1
  832. package/dist/components/p-DOPF2QRF.js +0 -1
  833. package/dist/components/p-DTgJTJD6.js +0 -1
  834. package/dist/components/p-DiVJyqlX.js +0 -4
  835. package/dist/components/p-DrS88eFz.js +0 -1
  836. package/dist/components/p-Dtdm8lKC.js +0 -4
  837. package/dist/components/p-DuZ7hY1a.js +0 -4
  838. package/dist/components/p-Dx-C8Ob_.js +0 -7
  839. package/dist/components/p-DxEgz9x_.js +0 -1
  840. package/dist/components/p-DxSo4SXG.js +0 -1
  841. package/dist/components/p-HSPzo8it.js +0 -1
  842. package/dist/components/p-OrwCUtWu.js +0 -4
  843. package/dist/components/p-UgkI2Wa4.js +0 -1
  844. package/dist/components/p-VeNdmYSo.js +0 -1
  845. package/dist/components/p-YbpebnFS.js +0 -4
  846. package/dist/components/p-ZjP4CjeZ.js +0 -4
  847. package/dist/components/p-_VuKPdkD.js +0 -4
  848. package/dist/components/p-aWL6BxTN.js +0 -4
  849. package/dist/components/p-hHmYLOfE.js +0 -4
  850. package/dist/components/p-qoI-S7yk.js +0 -4
  851. package/dist/components/p-uXV7tzS3.js +0 -1
  852. package/dist/components/p-yu3xCFhr.js +0 -7
  853. package/dist/components/p-zp5f483d.js +0 -1
  854. package/dist/esm/i18n-C_AfxZ5D.js +0 -13
  855. package/dist/esm/index-93OyAGoo.js +0 -3721
  856. /package/dist/checkout/{p-B-hirT0v.js → p-01ad898f.js} +0 -0
  857. /package/dist/checkout/{p-DiVJyqlX.js → p-350e7423.js} +0 -0
  858. /package/dist/checkout/{p-sObYyvOy.js → p-52b4c112.js} +0 -0
  859. /package/dist/checkout/{p-BmVRXR1y.js → p-620fa0ec.js} +0 -0
  860. /package/dist/checkout/{p-hHmYLOfE.js → p-94286cc3.js} +0 -0
  861. /package/dist/checkout/{p-D4RIp70E.js → p-9efbca93.js} +0 -0
  862. /package/dist/checkout/{p-Dtdm8lKC.js → p-9f4ac833.js} +0 -0
  863. /package/dist/checkout/{p-yu3xCFhr.js → p-b2289937.js} +0 -0
  864. /package/dist/checkout/{p-C53feagD.js → p-d5862637.js} +0 -0
  865. /package/dist/checkout/{p-ZjP4CjeZ.js → p-d7fe59ee.js} +0 -0
  866. /package/dist/{components/p-CYPPT3AE.js → checkout/p-e187a77c.js} +0 -0
  867. /package/dist/checkout/{p-CukVBo5-.js → p-f728a68f.js} +0 -0
  868. /package/dist/cjs/{compare-with-utils-JlLIkecm.js → compare-with-utils-adbe64a6.js} +0 -0
  869. /package/dist/cjs/{config-ptk2Lf4l.js → config-e2a8c0c7.js} +0 -0
  870. /package/dist/cjs/{cubic-bezier-Bv3PvaRI.js → cubic-bezier-5ff9b04e.js} +0 -0
  871. /package/dist/cjs/{dir-Br-7_bel.js → dir-374f13f2.js} +0 -0
  872. /package/dist/cjs/{focus-visible-Da2o6bTP.js → focus-visible-b7381162.js} +0 -0
  873. /package/dist/cjs/{index-CH3IFTaK.js → index-071786b4.js} +0 -0
  874. /package/dist/cjs/{index-D3mJ1Cix.js → index-a281cac3.js} +0 -0
  875. /package/dist/cjs/{lock-controller-58TZFRHC.js → lock-controller-e2dfece6.js} +0 -0
  876. /package/dist/cjs/{spinner-configs-BN41iw42.js → spinner-configs-036ebfd8.js} +0 -0
  877. /package/dist/cjs/{theme-DbHdw1Nx.js → theme-12dec869.js} +0 -0
  878. /package/dist/cjs/{watch-options-DOFUPyuf.js → watch-options-1cccbe6a.js} +0 -0
  879. /package/dist/{esm/lock-controller-B-hirT0v.js → components/p-01ad898f.js} +0 -0
  880. /package/dist/{esm/theme-DiVJyqlX.js → components/p-350e7423.js} +0 -0
  881. /package/dist/{esm/focus-visible-BmVRXR1y.js → components/p-620fa0ec.js} +0 -0
  882. /package/dist/{esm/cubic-bezier-hHmYLOfE.js → components/p-94286cc3.js} +0 -0
  883. /package/dist/{esm/watch-options-Dtdm8lKC.js → components/p-9f4ac833.js} +0 -0
  884. /package/dist/{esm/config-yu3xCFhr.js → components/p-b2289937.js} +0 -0
  885. /package/dist/{esm/dir-C53feagD.js → components/p-d5862637.js} +0 -0
  886. /package/dist/{esm/index-ZjP4CjeZ.js → components/p-d7fe59ee.js} +0 -0
  887. /package/dist/esm/{compare-with-utils-sObYyvOy.js → compare-with-utils-d58be312.js} +0 -0
  888. /package/dist/esm/{spinner-configs-D4RIp70E.js → spinner-configs-c9fb0813.js} +0 -0
@@ -1,9 +1,9 @@
1
- import { r as registerInstance, c as createEvent, h, g as getElement } from './index-93OyAGoo.js';
2
- import { g as getTimeGivenProgression } from './cubic-bezier-hHmYLOfE.js';
3
- import { s as shallowEqualStringMap, m as assert } from './helpers-C6kqtbmV.js';
4
- import { l as lifecycle, t as transition, s as setPageHidden, L as LIFECYCLE_WILL_UNLOAD, a as LIFECYCLE_WILL_LEAVE, b as LIFECYCLE_DID_LEAVE } from './index-CNcx43L8.js';
5
- import { g as getIonMode, c as config } from './ionic-global-DXXzPLPc.js';
6
- import { a as attachComponent } from './framework-delegate-D_uGiYYw.js';
1
+ import { r as registerInstance, d as createEvent, h, e as getElement } from './index-8cc94b11.js';
2
+ import { g as getTimeGivenProgression } from './cubic-bezier-874f336d.js';
3
+ import { o as assert, s as shallowEqualStringMap } from './helpers-f0dcbd72.js';
4
+ import { l as lifecycle, t as transition, s as setPageHidden, L as LIFECYCLE_WILL_UNLOAD, a as LIFECYCLE_WILL_LEAVE, b as LIFECYCLE_DID_LEAVE } from './index-0b560278.js';
5
+ import { g as getIonMode, c as config } from './ionic-global-0b7766cb.js';
6
+ import { a as attachComponent } from './framework-delegate-de1aa369.js';
7
7
 
8
8
  /*!
9
9
  * (C) Ionic http://ionicframework.com - MIT License
@@ -75,837 +75,833 @@ const convertToViews = (pages) => {
75
75
  .filter((v) => v !== null);
76
76
  };
77
77
 
78
- const navCss = () => `:host{left:0;right:0;top:0;bottom:0;position:absolute;contain:layout size style;z-index:0}`;
78
+ const navCss = ":host{left:0;right:0;top:0;bottom:0;position:absolute;contain:layout size style;z-index:0}";
79
79
 
80
80
  const Nav = class {
81
- constructor(hostRef) {
82
- registerInstance(this, hostRef);
83
- this.ionNavWillLoad = createEvent(this, "ionNavWillLoad", 7);
84
- this.ionNavWillChange = createEvent(this, "ionNavWillChange", 3);
85
- this.ionNavDidChange = createEvent(this, "ionNavDidChange", 3);
86
- this.transInstr = [];
87
- this.gestureOrAnimationInProgress = false;
88
- this.useRouter = false;
89
- this.isTransitioning = false;
90
- this.destroyed = false;
91
- this.views = [];
92
- this.didLoad = false;
93
- this.delegate = undefined;
94
- this.swipeGesture = undefined;
95
- this.animated = true;
96
- this.animation = undefined;
97
- this.rootParams = undefined;
98
- this.root = undefined;
99
- }
100
- swipeGestureChanged() {
101
- if (this.gesture) {
102
- this.gesture.enable(this.swipeGesture === true);
103
- }
104
- }
105
- rootChanged() {
106
- if (this.root === undefined) {
107
- return;
108
- }
109
- if (this.didLoad === false) {
110
- /**
111
- * If the component has not loaded yet, we can skip setting up the root component.
112
- * It will be called when `componentDidLoad` fires.
113
- */
114
- return;
115
- }
116
- if (!this.useRouter) {
117
- if (this.root !== undefined) {
118
- this.setRoot(this.root, this.rootParams);
119
- }
120
- }
121
- }
122
- componentWillLoad() {
123
- this.useRouter = document.querySelector('ion-router') !== null && this.el.closest('[no-router]') === null;
124
- if (this.swipeGesture === undefined) {
125
- const mode = getIonMode(this);
126
- this.swipeGesture = config.getBoolean('swipeBackEnabled', mode === 'ios');
127
- }
128
- this.ionNavWillLoad.emit();
129
- }
130
- async componentDidLoad() {
131
- // We want to set this flag before any watch callbacks are manually called
132
- this.didLoad = true;
133
- this.rootChanged();
134
- this.gesture = (await import('./swipe-back-DE05lWQD.js')).createSwipeBackGesture(this.el, this.canStart.bind(this), this.onStart.bind(this), this.onMove.bind(this), this.onEnd.bind(this));
135
- this.swipeGestureChanged();
136
- }
137
- connectedCallback() {
138
- this.destroyed = false;
139
- }
140
- disconnectedCallback() {
141
- for (const view of this.views) {
142
- lifecycle(view.element, LIFECYCLE_WILL_UNLOAD);
143
- view._destroy();
144
- }
145
- // Release swipe back gesture and transition.
146
- if (this.gesture) {
147
- this.gesture.destroy();
148
- this.gesture = undefined;
149
- }
150
- this.transInstr.length = 0;
151
- this.views.length = 0;
152
- this.destroyed = true;
153
- }
154
- /**
155
- * Push a new component onto the current navigation stack. Pass any additional
156
- * information along as an object. This additional information is accessible
157
- * through NavParams.
158
- *
159
- * @param component The component to push onto the navigation stack.
160
- * @param componentProps Any properties of the component.
161
- * @param opts The navigation options.
162
- * @param done The transition complete function.
163
- */
164
- push(component, componentProps, opts, done) {
165
- return this.insert(-1, component, componentProps, opts, done);
166
- }
167
- /**
168
- * Inserts a component into the navigation stack at the specified index.
169
- * This is useful to add a component at any point in the navigation stack.
170
- *
171
- * @param insertIndex The index to insert the component at in the stack.
172
- * @param component The component to insert into the navigation stack.
173
- * @param componentProps Any properties of the component.
174
- * @param opts The navigation options.
175
- * @param done The transition complete function.
176
- */
177
- insert(insertIndex, component, componentProps, opts, done) {
178
- return this.insertPages(insertIndex, [{ component, componentProps }], opts, done);
179
- }
180
- /**
181
- * Inserts an array of components into the navigation stack at the specified index.
182
- * The last component in the array will become instantiated as a view, and animate
183
- * in to become the active view.
184
- *
185
- * @param insertIndex The index to insert the components at in the stack.
186
- * @param insertComponents The components to insert into the navigation stack.
187
- * @param opts The navigation options.
188
- * @param done The transition complete function.
189
- */
190
- insertPages(insertIndex, insertComponents, opts, done) {
191
- return this.queueTrns({
192
- insertStart: insertIndex,
193
- insertViews: insertComponents,
194
- opts,
195
- }, done);
196
- }
197
- /**
198
- * Pop a component off of the navigation stack. Navigates back from the current
199
- * component.
200
- *
201
- * @param opts The navigation options.
202
- * @param done The transition complete function.
203
- */
204
- pop(opts, done) {
205
- return this.removeIndex(-1, 1, opts, done);
206
- }
207
- /**
208
- * Pop to a specific index in the navigation stack.
209
- *
210
- * @param indexOrViewCtrl The index or view controller to pop to.
211
- * @param opts The navigation options.
212
- * @param done The transition complete function.
213
- */
214
- popTo(indexOrViewCtrl, opts, done) {
215
- const ti = {
216
- removeStart: -1,
217
- removeCount: -1,
218
- opts,
219
- };
220
- if (typeof indexOrViewCtrl === 'object' && indexOrViewCtrl.component) {
221
- ti.removeView = indexOrViewCtrl;
222
- ti.removeStart = 1;
223
- }
224
- else if (typeof indexOrViewCtrl === 'number') {
225
- ti.removeStart = indexOrViewCtrl + 1;
226
- }
227
- return this.queueTrns(ti, done);
228
- }
229
- /**
230
- * Navigate back to the root of the stack, no matter how far back that is.
231
- *
232
- * @param opts The navigation options.
233
- * @param done The transition complete function.
234
- */
235
- popToRoot(opts, done) {
236
- return this.removeIndex(1, -1, opts, done);
237
- }
238
- /**
239
- * Removes a component from the navigation stack at the specified index.
240
- *
241
- * @param startIndex The number to begin removal at.
242
- * @param removeCount The number of components to remove.
243
- * @param opts The navigation options.
244
- * @param done The transition complete function.
245
- */
246
- removeIndex(startIndex, removeCount = 1, opts, done) {
247
- return this.queueTrns({
248
- removeStart: startIndex,
249
- removeCount,
250
- opts,
251
- }, done);
252
- }
253
- /**
254
- * Set the root for the current navigation stack to a component.
255
- *
256
- * @param component The component to set as the root of the navigation stack.
257
- * @param componentProps Any properties of the component.
258
- * @param opts The navigation options.
259
- * @param done The transition complete function.
260
- */
261
- setRoot(component, componentProps, opts, done) {
262
- return this.setPages([{ component, componentProps }], opts, done);
263
- }
264
- /**
265
- * Set the views of the current navigation stack and navigate to the last view.
266
- * By default animations are disabled, but they can be enabled by passing options
267
- * to the navigation controller. Navigation parameters can also be passed to the
268
- * individual pages in the array.
269
- *
270
- * @param views The list of views to set as the navigation stack.
271
- * @param opts The navigation options.
272
- * @param done The transition complete function.
273
- */
274
- setPages(views, opts, done) {
275
- opts !== null && opts !== void 0 ? opts : (opts = {});
276
- // if animation wasn't set to true then default it to NOT animate
277
- if (opts.animated !== true) {
278
- opts.animated = false;
279
- }
280
- return this.queueTrns({
281
- insertStart: 0,
282
- insertViews: views,
283
- removeStart: 0,
284
- removeCount: -1,
285
- opts,
286
- }, done);
287
- }
288
- /**
289
- * Called by the router to update the view.
290
- *
291
- * @param id The component tag.
292
- * @param params The component params.
293
- * @param direction A direction hint.
294
- * @param animation an AnimationBuilder.
295
- *
296
- * @return the status.
297
- * @internal
298
- */
299
- setRouteId(id, params, direction, animation) {
300
- const active = this.getActiveSync();
301
- if (matches(active, id, params)) {
302
- return Promise.resolve({
303
- changed: false,
304
- element: active.element,
305
- });
306
- }
307
- let resolve;
308
- const promise = new Promise((r) => (resolve = r));
309
- let finish;
310
- const commonOpts = {
311
- updateURL: false,
312
- viewIsReady: (enteringEl) => {
313
- let mark;
314
- const p = new Promise((r) => (mark = r));
315
- resolve({
316
- changed: true,
317
- element: enteringEl,
318
- markVisible: async () => {
319
- mark();
320
- await finish;
321
- },
322
- });
323
- return p;
324
- },
325
- };
326
- if (direction === 'root') {
327
- finish = this.setRoot(id, params, commonOpts);
328
- }
329
- else {
330
- // Look for a view matching the target in the view stack.
331
- const viewController = this.views.find((v) => matches(v, id, params));
332
- if (viewController) {
333
- finish = this.popTo(viewController, Object.assign(Object.assign({}, commonOpts), { direction: 'back', animationBuilder: animation }));
334
- }
335
- else if (direction === 'forward') {
336
- finish = this.push(id, params, Object.assign(Object.assign({}, commonOpts), { animationBuilder: animation }));
337
- }
338
- else if (direction === 'back') {
339
- finish = this.setRoot(id, params, Object.assign(Object.assign({}, commonOpts), { direction: 'back', animated: true, animationBuilder: animation }));
340
- }
341
- }
342
- return promise;
343
- }
344
- /**
345
- * Called by <ion-router> to retrieve the current component.
346
- *
347
- * @internal
348
- */
349
- async getRouteId() {
350
- const active = this.getActiveSync();
351
- if (active) {
352
- return {
353
- id: active.element.tagName,
354
- params: active.params,
355
- element: active.element,
356
- };
357
- }
358
- return undefined;
359
- }
360
- /**
361
- * Get the active view.
362
- */
363
- async getActive() {
364
- return this.getActiveSync();
365
- }
366
- /**
367
- * Get the view at the specified index.
368
- *
369
- * @param index The index of the view.
370
- */
371
- async getByIndex(index) {
372
- return this.views[index];
373
- }
374
- /**
375
- * Returns `true` if the current view can go back.
376
- *
377
- * @param view The view to check.
378
- */
379
- async canGoBack(view) {
380
- return this.canGoBackSync(view);
381
- }
382
- /**
383
- * Get the previous view.
384
- *
385
- * @param view The view to get.
386
- */
387
- async getPrevious(view) {
388
- return this.getPreviousSync(view);
389
- }
390
- getLength() {
391
- return this.views.length;
392
- }
393
- getActiveSync() {
394
- return this.views[this.views.length - 1];
395
- }
396
- canGoBackSync(view = this.getActiveSync()) {
397
- return !!(view && this.getPreviousSync(view));
398
- }
399
- getPreviousSync(view = this.getActiveSync()) {
400
- if (!view) {
401
- return undefined;
402
- }
403
- const views = this.views;
404
- const index = views.indexOf(view);
405
- return index > 0 ? views[index - 1] : undefined;
406
- }
407
- /**
408
- * Adds a navigation stack change to the queue and schedules it to run.
409
- *
410
- * @returns Whether the transition succeeds.
411
- */
412
- async queueTrns(ti, done) {
413
- var _a, _b;
414
- if (this.isTransitioning && ((_a = ti.opts) === null || _a === void 0 ? void 0 : _a.skipIfBusy)) {
415
- return false;
416
- }
417
- const promise = new Promise((resolve, reject) => {
418
- ti.resolve = resolve;
419
- ti.reject = reject;
81
+ constructor(hostRef) {
82
+ registerInstance(this, hostRef);
83
+ this.ionNavWillLoad = createEvent(this, "ionNavWillLoad", 7);
84
+ this.ionNavWillChange = createEvent(this, "ionNavWillChange", 3);
85
+ this.ionNavDidChange = createEvent(this, "ionNavDidChange", 3);
86
+ this.transInstr = [];
87
+ this.gestureOrAnimationInProgress = false;
88
+ this.useRouter = false;
89
+ this.isTransitioning = false;
90
+ this.destroyed = false;
91
+ this.views = [];
92
+ this.didLoad = false;
93
+ this.delegate = undefined;
94
+ this.swipeGesture = undefined;
95
+ this.animated = true;
96
+ this.animation = undefined;
97
+ this.rootParams = undefined;
98
+ this.root = undefined;
99
+ }
100
+ swipeGestureChanged() {
101
+ if (this.gesture) {
102
+ this.gesture.enable(this.swipeGesture === true);
103
+ }
104
+ }
105
+ rootChanged() {
106
+ if (this.root === undefined) {
107
+ return;
108
+ }
109
+ if (this.didLoad === false) {
110
+ /**
111
+ * If the component has not loaded yet, we can skip setting up the root component.
112
+ * It will be called when `componentDidLoad` fires.
113
+ */
114
+ return;
115
+ }
116
+ if (!this.useRouter) {
117
+ if (this.root !== undefined) {
118
+ this.setRoot(this.root, this.rootParams);
119
+ }
120
+ }
121
+ }
122
+ componentWillLoad() {
123
+ this.useRouter = document.querySelector('ion-router') !== null && this.el.closest('[no-router]') === null;
124
+ if (this.swipeGesture === undefined) {
125
+ const mode = getIonMode(this);
126
+ this.swipeGesture = config.getBoolean('swipeBackEnabled', mode === 'ios');
127
+ }
128
+ this.ionNavWillLoad.emit();
129
+ }
130
+ async componentDidLoad() {
131
+ // We want to set this flag before any watch callbacks are manually called
132
+ this.didLoad = true;
133
+ this.rootChanged();
134
+ this.gesture = (await import('./swipe-back-6cec4c33.js')).createSwipeBackGesture(this.el, this.canStart.bind(this), this.onStart.bind(this), this.onMove.bind(this), this.onEnd.bind(this));
135
+ this.swipeGestureChanged();
136
+ }
137
+ connectedCallback() {
138
+ this.destroyed = false;
139
+ }
140
+ disconnectedCallback() {
141
+ for (const view of this.views) {
142
+ lifecycle(view.element, LIFECYCLE_WILL_UNLOAD);
143
+ view._destroy();
144
+ }
145
+ // Release swipe back gesture and transition.
146
+ if (this.gesture) {
147
+ this.gesture.destroy();
148
+ this.gesture = undefined;
149
+ }
150
+ this.transInstr.length = 0;
151
+ this.views.length = 0;
152
+ this.destroyed = true;
153
+ }
154
+ /**
155
+ * Push a new component onto the current navigation stack. Pass any additional
156
+ * information along as an object. This additional information is accessible
157
+ * through NavParams.
158
+ *
159
+ * @param component The component to push onto the navigation stack.
160
+ * @param componentProps Any properties of the component.
161
+ * @param opts The navigation options.
162
+ * @param done The transition complete function.
163
+ */
164
+ push(component, componentProps, opts, done) {
165
+ return this.insert(-1, component, componentProps, opts, done);
166
+ }
167
+ /**
168
+ * Inserts a component into the navigation stack at the specified index.
169
+ * This is useful to add a component at any point in the navigation stack.
170
+ *
171
+ * @param insertIndex The index to insert the component at in the stack.
172
+ * @param component The component to insert into the navigation stack.
173
+ * @param componentProps Any properties of the component.
174
+ * @param opts The navigation options.
175
+ * @param done The transition complete function.
176
+ */
177
+ insert(insertIndex, component, componentProps, opts, done) {
178
+ return this.insertPages(insertIndex, [{ component, componentProps }], opts, done);
179
+ }
180
+ /**
181
+ * Inserts an array of components into the navigation stack at the specified index.
182
+ * The last component in the array will become instantiated as a view, and animate
183
+ * in to become the active view.
184
+ *
185
+ * @param insertIndex The index to insert the components at in the stack.
186
+ * @param insertComponents The components to insert into the navigation stack.
187
+ * @param opts The navigation options.
188
+ * @param done The transition complete function.
189
+ */
190
+ insertPages(insertIndex, insertComponents, opts, done) {
191
+ return this.queueTrns({
192
+ insertStart: insertIndex,
193
+ insertViews: insertComponents,
194
+ opts,
195
+ }, done);
196
+ }
197
+ /**
198
+ * Pop a component off of the navigation stack. Navigates back from the current
199
+ * component.
200
+ *
201
+ * @param opts The navigation options.
202
+ * @param done The transition complete function.
203
+ */
204
+ pop(opts, done) {
205
+ return this.removeIndex(-1, 1, opts, done);
206
+ }
207
+ /**
208
+ * Pop to a specific index in the navigation stack.
209
+ *
210
+ * @param indexOrViewCtrl The index or view controller to pop to.
211
+ * @param opts The navigation options.
212
+ * @param done The transition complete function.
213
+ */
214
+ popTo(indexOrViewCtrl, opts, done) {
215
+ const ti = {
216
+ removeStart: -1,
217
+ removeCount: -1,
218
+ opts,
219
+ };
220
+ if (typeof indexOrViewCtrl === 'object' && indexOrViewCtrl.component) {
221
+ ti.removeView = indexOrViewCtrl;
222
+ ti.removeStart = 1;
223
+ }
224
+ else if (typeof indexOrViewCtrl === 'number') {
225
+ ti.removeStart = indexOrViewCtrl + 1;
226
+ }
227
+ return this.queueTrns(ti, done);
228
+ }
229
+ /**
230
+ * Navigate back to the root of the stack, no matter how far back that is.
231
+ *
232
+ * @param opts The navigation options.
233
+ * @param done The transition complete function.
234
+ */
235
+ popToRoot(opts, done) {
236
+ return this.removeIndex(1, -1, opts, done);
237
+ }
238
+ /**
239
+ * Removes a component from the navigation stack at the specified index.
240
+ *
241
+ * @param startIndex The number to begin removal at.
242
+ * @param removeCount The number of components to remove.
243
+ * @param opts The navigation options.
244
+ * @param done The transition complete function.
245
+ */
246
+ removeIndex(startIndex, removeCount = 1, opts, done) {
247
+ return this.queueTrns({
248
+ removeStart: startIndex,
249
+ removeCount,
250
+ opts,
251
+ }, done);
252
+ }
253
+ /**
254
+ * Set the root for the current navigation stack to a component.
255
+ *
256
+ * @param component The component to set as the root of the navigation stack.
257
+ * @param componentProps Any properties of the component.
258
+ * @param opts The navigation options.
259
+ * @param done The transition complete function.
260
+ */
261
+ setRoot(component, componentProps, opts, done) {
262
+ return this.setPages([{ component, componentProps }], opts, done);
263
+ }
264
+ /**
265
+ * Set the views of the current navigation stack and navigate to the last view.
266
+ * By default animations are disabled, but they can be enabled by passing options
267
+ * to the navigation controller. Navigation parameters can also be passed to the
268
+ * individual pages in the array.
269
+ *
270
+ * @param views The list of views to set as the navigation stack.
271
+ * @param opts The navigation options.
272
+ * @param done The transition complete function.
273
+ */
274
+ setPages(views, opts, done) {
275
+ opts !== null && opts !== void 0 ? opts : (opts = {});
276
+ // if animation wasn't set to true then default it to NOT animate
277
+ if (opts.animated !== true) {
278
+ opts.animated = false;
279
+ }
280
+ return this.queueTrns({
281
+ insertStart: 0,
282
+ insertViews: views,
283
+ removeStart: 0,
284
+ removeCount: -1,
285
+ opts,
286
+ }, done);
287
+ }
288
+ /**
289
+ * Called by the router to update the view.
290
+ *
291
+ * @param id The component tag.
292
+ * @param params The component params.
293
+ * @param direction A direction hint.
294
+ * @param animation an AnimationBuilder.
295
+ *
296
+ * @return the status.
297
+ * @internal
298
+ */
299
+ setRouteId(id, params, direction, animation) {
300
+ const active = this.getActiveSync();
301
+ if (matches(active, id, params)) {
302
+ return Promise.resolve({
303
+ changed: false,
304
+ element: active.element,
305
+ });
306
+ }
307
+ let resolve;
308
+ const promise = new Promise((r) => (resolve = r));
309
+ let finish;
310
+ const commonOpts = {
311
+ updateURL: false,
312
+ viewIsReady: (enteringEl) => {
313
+ let mark;
314
+ const p = new Promise((r) => (mark = r));
315
+ resolve({
316
+ changed: true,
317
+ element: enteringEl,
318
+ markVisible: async () => {
319
+ mark();
320
+ await finish;
321
+ },
420
322
  });
421
- ti.done = done;
422
- /**
423
- * If using router, check to see if navigation hooks
424
- * will allow us to perform this transition. This
425
- * is required in order for hooks to work with
426
- * the ion-back-button or swipe to go back.
427
- */
428
- if (ti.opts && ti.opts.updateURL !== false && this.useRouter) {
429
- const router = document.querySelector('ion-router');
430
- if (router) {
431
- const canTransition = await router.canTransition();
432
- if (canTransition === false) {
433
- return false;
434
- }
435
- if (typeof canTransition === 'string') {
436
- router.push(canTransition, ti.opts.direction || 'back');
437
- return false;
438
- }
439
- }
440
- }
441
- // Normalize empty
442
- if (((_b = ti.insertViews) === null || _b === void 0 ? void 0 : _b.length) === 0) {
443
- ti.insertViews = undefined;
444
- }
445
- // Enqueue transition instruction
446
- this.transInstr.push(ti);
447
- // if there isn't a transition already happening
448
- // then this will kick off this transition
449
- this.nextTrns();
450
- return promise;
451
- }
452
- success(result, ti) {
453
- if (this.destroyed) {
454
- this.fireError('nav controller was destroyed', ti);
455
- return;
456
- }
457
- if (ti.done) {
458
- ti.done(result.hasCompleted, result.requiresTransition, result.enteringView, result.leavingView, result.direction);
459
- }
460
- ti.resolve(result.hasCompleted);
461
- if (ti.opts.updateURL !== false && this.useRouter) {
462
- const router = document.querySelector('ion-router');
463
- if (router) {
464
- const direction = result.direction === 'back' ? 'back' : 'forward';
465
- router.navChanged(direction);
466
- }
467
- }
468
- }
469
- failed(rejectReason, ti) {
470
- if (this.destroyed) {
471
- this.fireError('nav controller was destroyed', ti);
472
- return;
473
- }
474
- this.transInstr.length = 0;
475
- this.fireError(rejectReason, ti);
476
- }
477
- fireError(rejectReason, ti) {
478
- if (ti.done) {
479
- ti.done(false, false, rejectReason);
480
- }
481
- if (ti.reject && !this.destroyed) {
482
- ti.reject(rejectReason);
483
- }
484
- else {
485
- ti.resolve(false);
486
- }
487
- }
488
- /**
489
- * Consumes the next transition in the queue.
490
- *
491
- * @returns whether the transition is executed.
492
- */
493
- nextTrns() {
494
- // this is the framework's bread 'n butta function
495
- // only one transition is allowed at any given time
496
- if (this.isTransitioning) {
497
- return false;
498
- }
499
- // there is no transition happening right now, executes the next instructions.
500
- const ti = this.transInstr.shift();
501
- if (!ti) {
502
- return false;
503
- }
504
- this.runTransition(ti);
505
- return true;
506
- }
507
- /** Executes all the transition instruction from the queue. */
508
- async runTransition(ti) {
509
- try {
510
- // set that this nav is actively transitioning
511
- this.ionNavWillChange.emit();
512
- this.isTransitioning = true;
513
- this.prepareTI(ti);
514
- const leavingView = this.getActiveSync();
515
- const enteringView = this.getEnteringView(ti, leavingView);
516
- if (!leavingView && !enteringView) {
517
- throw new Error('no views in the stack to be removed');
518
- }
519
- if (enteringView && enteringView.state === VIEW_STATE_NEW) {
520
- await enteringView.init(this.el);
521
- }
522
- this.postViewInit(enteringView, leavingView, ti);
523
- // Needs transition?
524
- const requiresTransition = (ti.enteringRequiresTransition || ti.leavingRequiresTransition) && enteringView !== leavingView;
525
- if (requiresTransition && ti.opts && leavingView) {
526
- const isBackDirection = ti.opts.direction === 'back';
527
- /**
528
- * If heading back, use the entering page's animation
529
- * unless otherwise specified by the developer.
530
- */
531
- if (isBackDirection) {
532
- ti.opts.animationBuilder = ti.opts.animationBuilder || (enteringView === null || enteringView === void 0 ? void 0 : enteringView.animationBuilder);
533
- }
534
- leavingView.animationBuilder = ti.opts.animationBuilder;
535
- }
536
- let result;
537
- if (requiresTransition) {
538
- result = await this.transition(enteringView, leavingView, ti);
539
- }
540
- else {
541
- // transition is not required, so we are already done!
542
- // they're inserting/removing the views somewhere in the middle or
543
- // beginning, so visually nothing needs to animate/transition
544
- // resolve immediately because there's no animation that's happening
545
- result = {
546
- hasCompleted: true,
547
- requiresTransition: false,
548
- };
549
- }
550
- this.success(result, ti);
551
- this.ionNavDidChange.emit();
552
- }
553
- catch (rejectReason) {
554
- this.failed(rejectReason, ti);
555
- }
556
- this.isTransitioning = false;
557
- this.nextTrns();
558
- }
559
- prepareTI(ti) {
560
- var _a, _b;
561
- var _c;
562
- const viewsLength = this.views.length;
563
- (_a = ti.opts) !== null && _a !== void 0 ? _a : (ti.opts = {});
564
- (_b = (_c = ti.opts).delegate) !== null && _b !== void 0 ? _b : (_c.delegate = this.delegate);
565
- if (ti.removeView !== undefined) {
566
- assert(ti.removeStart !== undefined, 'removeView needs removeStart');
567
- assert(ti.removeCount !== undefined, 'removeView needs removeCount');
568
- const index = this.views.indexOf(ti.removeView);
569
- if (index < 0) {
570
- throw new Error('removeView was not found');
571
- }
572
- ti.removeStart += index;
573
- }
574
- if (ti.removeStart !== undefined) {
575
- if (ti.removeStart < 0) {
576
- ti.removeStart = viewsLength - 1;
577
- }
578
- if (ti.removeCount < 0) {
579
- ti.removeCount = viewsLength - ti.removeStart;
580
- }
581
- ti.leavingRequiresTransition = ti.removeCount > 0 && ti.removeStart + ti.removeCount === viewsLength;
582
- }
583
- if (ti.insertViews) {
584
- // allow -1 to be passed in to auto push it on the end
585
- // and clean up the index if it's larger then the size of the stack
586
- if (ti.insertStart < 0 || ti.insertStart > viewsLength) {
587
- ti.insertStart = viewsLength;
588
- }
589
- ti.enteringRequiresTransition = ti.insertStart === viewsLength;
590
- }
591
- const insertViews = ti.insertViews;
592
- if (!insertViews) {
593
- return;
594
- }
595
- assert(insertViews.length > 0, 'length can not be zero');
596
- const viewControllers = convertToViews(insertViews);
597
- if (viewControllers.length === 0) {
598
- throw new Error('invalid views to insert');
599
- }
600
- // Check all the inserted view are correct
601
- for (const view of viewControllers) {
602
- view.delegate = ti.opts.delegate;
603
- const nav = view.nav;
604
- if (nav && nav !== this) {
605
- throw new Error('inserted view was already inserted');
606
- }
607
- if (view.state === VIEW_STATE_DESTROYED) {
608
- throw new Error('inserted view was already destroyed');
609
- }
610
- }
611
- ti.insertViews = viewControllers;
612
- }
613
- /**
614
- * Returns the view that will be entered considering the transition instructions.
615
- *
616
- * @param ti The instructions.
617
- * @param leavingView The view being left or undefined if none.
618
- *
619
- * @returns The view that will be entered, undefined if none.
620
- */
621
- getEnteringView(ti, leavingView) {
622
- // The last inserted view will be entered when view are inserted.
623
- const insertViews = ti.insertViews;
624
- if (insertViews !== undefined) {
625
- return insertViews[insertViews.length - 1];
626
- }
627
- // When views are deleted, we will enter the last view that is not removed and not the view being left.
628
- const removeStart = ti.removeStart;
629
- if (removeStart !== undefined) {
630
- const views = this.views;
631
- const removeEnd = removeStart + ti.removeCount;
632
- for (let i = views.length - 1; i >= 0; i--) {
633
- const view = views[i];
634
- if ((i < removeStart || i >= removeEnd) && view !== leavingView) {
635
- return view;
636
- }
637
- }
638
- }
639
- return undefined;
640
- }
323
+ return p;
324
+ },
325
+ };
326
+ if (direction === 'root') {
327
+ finish = this.setRoot(id, params, commonOpts);
328
+ }
329
+ else {
330
+ // Look for a view matching the target in the view stack.
331
+ const viewController = this.views.find((v) => matches(v, id, params));
332
+ if (viewController) {
333
+ finish = this.popTo(viewController, Object.assign(Object.assign({}, commonOpts), { direction: 'back', animationBuilder: animation }));
334
+ }
335
+ else if (direction === 'forward') {
336
+ finish = this.push(id, params, Object.assign(Object.assign({}, commonOpts), { animationBuilder: animation }));
337
+ }
338
+ else if (direction === 'back') {
339
+ finish = this.setRoot(id, params, Object.assign(Object.assign({}, commonOpts), { direction: 'back', animated: true, animationBuilder: animation }));
340
+ }
341
+ }
342
+ return promise;
343
+ }
344
+ /**
345
+ * Called by <ion-router> to retrieve the current component.
346
+ *
347
+ * @internal
348
+ */
349
+ async getRouteId() {
350
+ const active = this.getActiveSync();
351
+ if (active) {
352
+ return {
353
+ id: active.element.tagName,
354
+ params: active.params,
355
+ element: active.element,
356
+ };
357
+ }
358
+ return undefined;
359
+ }
360
+ /**
361
+ * Get the active view.
362
+ */
363
+ async getActive() {
364
+ return this.getActiveSync();
365
+ }
366
+ /**
367
+ * Get the view at the specified index.
368
+ *
369
+ * @param index The index of the view.
370
+ */
371
+ async getByIndex(index) {
372
+ return this.views[index];
373
+ }
374
+ /**
375
+ * Returns `true` if the current view can go back.
376
+ *
377
+ * @param view The view to check.
378
+ */
379
+ async canGoBack(view) {
380
+ return this.canGoBackSync(view);
381
+ }
382
+ /**
383
+ * Get the previous view.
384
+ *
385
+ * @param view The view to get.
386
+ */
387
+ async getPrevious(view) {
388
+ return this.getPreviousSync(view);
389
+ }
390
+ getLength() {
391
+ return this.views.length;
392
+ }
393
+ getActiveSync() {
394
+ return this.views[this.views.length - 1];
395
+ }
396
+ canGoBackSync(view = this.getActiveSync()) {
397
+ return !!(view && this.getPreviousSync(view));
398
+ }
399
+ getPreviousSync(view = this.getActiveSync()) {
400
+ if (!view) {
401
+ return undefined;
402
+ }
403
+ const views = this.views;
404
+ const index = views.indexOf(view);
405
+ return index > 0 ? views[index - 1] : undefined;
406
+ }
407
+ /**
408
+ * Adds a navigation stack change to the queue and schedules it to run.
409
+ *
410
+ * @returns Whether the transition succeeds.
411
+ */
412
+ async queueTrns(ti, done) {
413
+ var _a, _b;
414
+ if (this.isTransitioning && ((_a = ti.opts) === null || _a === void 0 ? void 0 : _a.skipIfBusy)) {
415
+ return false;
416
+ }
417
+ const promise = new Promise((resolve, reject) => {
418
+ ti.resolve = resolve;
419
+ ti.reject = reject;
420
+ });
421
+ ti.done = done;
641
422
  /**
642
- * Adds and Removes the views from the navigation stack.
643
- *
644
- * @param enteringView The view being entered.
645
- * @param leavingView The view being left.
646
- * @param ti The instructions.
423
+ * If using router, check to see if navigation hooks
424
+ * will allow us to perform this transition. This
425
+ * is required in order for hooks to work with
426
+ * the ion-back-button or swipe to go back.
647
427
  */
648
- postViewInit(enteringView, leavingView, ti) {
649
- var _a, _b, _c;
650
- assert(leavingView || enteringView, 'Both leavingView and enteringView are null');
651
- assert(ti.resolve, 'resolve must be valid');
652
- assert(ti.reject, 'reject must be valid');
653
- // Compute the views to remove.
654
- const opts = ti.opts;
655
- const { insertViews, removeStart, removeCount } = ti;
656
- /** Records the view to destroy */
657
- let destroyQueue;
658
- // there are views to remove
659
- if (removeStart !== undefined && removeCount !== undefined) {
660
- assert(removeStart >= 0, 'removeStart can not be negative');
661
- assert(removeCount >= 0, 'removeCount can not be negative');
662
- destroyQueue = [];
663
- for (let i = removeStart; i < removeStart + removeCount; i++) {
664
- const view = this.views[i];
665
- if (view !== undefined && view !== enteringView && view !== leavingView) {
666
- destroyQueue.push(view);
667
- }
668
- }
669
- // default the direction to "back"
670
- (_a = opts.direction) !== null && _a !== void 0 ? _a : (opts.direction = 'back');
671
- }
672
- const finalNumViews = this.views.length + ((_b = insertViews === null || insertViews === void 0 ? void 0 : insertViews.length) !== null && _b !== void 0 ? _b : 0) - (removeCount !== null && removeCount !== void 0 ? removeCount : 0);
673
- assert(finalNumViews >= 0, 'final balance can not be negative');
674
- if (finalNumViews === 0) {
675
- console.warn(`You can't remove all the pages in the navigation stack. nav.pop() is probably called too many times.`, this, this.el);
676
- throw new Error('navigation stack needs at least one root page');
677
- }
678
- // At this point the transition can not be rejected, any throw should be an error
679
- // Insert the new views in the stack.
680
- if (insertViews) {
681
- // add the views to the
682
- let insertIndex = ti.insertStart;
683
- for (const view of insertViews) {
684
- this.insertViewAt(view, insertIndex);
685
- insertIndex++;
686
- }
687
- if (ti.enteringRequiresTransition) {
688
- // default to forward if not already set
689
- (_c = opts.direction) !== null && _c !== void 0 ? _c : (opts.direction = 'forward');
690
- }
691
- }
692
- // if the views to be removed are in the beginning or middle
693
- // and there is not a view that needs to visually transition out
694
- // then just destroy them and don't transition anything
695
- // batch all of lifecycles together
696
- // let's make sure, callbacks are zoned
697
- if (destroyQueue && destroyQueue.length > 0) {
698
- for (const view of destroyQueue) {
699
- lifecycle(view.element, LIFECYCLE_WILL_LEAVE);
700
- lifecycle(view.element, LIFECYCLE_DID_LEAVE);
701
- lifecycle(view.element, LIFECYCLE_WILL_UNLOAD);
702
- }
703
- // once all lifecycle events has been delivered, we can safely detroy the views
704
- for (const view of destroyQueue) {
705
- this.destroyView(view);
706
- }
707
- }
708
- }
709
- async transition(enteringView, leavingView, ti) {
710
- // we should animate (duration > 0) if the pushed page is not the first one (startup)
711
- // or if it is a portal (modal, actionsheet, etc.)
712
- const opts = ti.opts;
713
- const progressCallback = opts.progressAnimation
714
- ? (ani) => {
715
- /**
716
- * Because this progress callback is called asynchronously
717
- * it is possible for the gesture to start and end before
718
- * the animation is ever set. In that scenario, we should
719
- * immediately call progressEnd so that the transition promise
720
- * resolves and the gesture does not get locked up.
721
- */
722
- if (ani !== undefined && !this.gestureOrAnimationInProgress) {
723
- this.gestureOrAnimationInProgress = true;
724
- ani.onFinish(() => {
725
- this.gestureOrAnimationInProgress = false;
726
- }, { oneTimeCallback: true });
727
- /**
728
- * Playing animation to beginning
729
- * with a duration of 0 prevents
730
- * any flickering when the animation
731
- * is later cleaned up.
732
- */
733
- ani.progressEnd(0, 0, 0);
734
- }
735
- else {
736
- this.sbAni = ani;
737
- }
738
- }
739
- : undefined;
740
- const mode = getIonMode(this);
741
- const enteringEl = enteringView.element;
742
- // eslint-disable-next-line @typescript-eslint/prefer-optional-chain
743
- const leavingEl = leavingView && leavingView.element;
744
- const animationOpts = Object.assign(Object.assign({ mode, showGoBack: this.canGoBackSync(enteringView), baseEl: this.el, progressCallback, animated: this.animated && config.getBoolean('animated', true), enteringEl,
745
- leavingEl }, opts), { animationBuilder: opts.animationBuilder || this.animation || config.get('navAnimation') });
746
- const { hasCompleted } = await transition(animationOpts);
747
- return this.transitionFinish(hasCompleted, enteringView, leavingView, opts);
748
- }
749
- transitionFinish(hasCompleted, enteringView, leavingView, opts) {
428
+ if (ti.opts && ti.opts.updateURL !== false && this.useRouter) {
429
+ const router = document.querySelector('ion-router');
430
+ if (router) {
431
+ const canTransition = await router.canTransition();
432
+ if (canTransition === false) {
433
+ return false;
434
+ }
435
+ if (typeof canTransition === 'string') {
436
+ router.push(canTransition, ti.opts.direction || 'back');
437
+ return false;
438
+ }
439
+ }
440
+ }
441
+ // Normalize empty
442
+ if (((_b = ti.insertViews) === null || _b === void 0 ? void 0 : _b.length) === 0) {
443
+ ti.insertViews = undefined;
444
+ }
445
+ // Enqueue transition instruction
446
+ this.transInstr.push(ti);
447
+ // if there isn't a transition already happening
448
+ // then this will kick off this transition
449
+ this.nextTrns();
450
+ return promise;
451
+ }
452
+ success(result, ti) {
453
+ if (this.destroyed) {
454
+ this.fireError('nav controller was destroyed', ti);
455
+ return;
456
+ }
457
+ if (ti.done) {
458
+ ti.done(result.hasCompleted, result.requiresTransition, result.enteringView, result.leavingView, result.direction);
459
+ }
460
+ ti.resolve(result.hasCompleted);
461
+ if (ti.opts.updateURL !== false && this.useRouter) {
462
+ const router = document.querySelector('ion-router');
463
+ if (router) {
464
+ const direction = result.direction === 'back' ? 'back' : 'forward';
465
+ router.navChanged(direction);
466
+ }
467
+ }
468
+ }
469
+ failed(rejectReason, ti) {
470
+ if (this.destroyed) {
471
+ this.fireError('nav controller was destroyed', ti);
472
+ return;
473
+ }
474
+ this.transInstr.length = 0;
475
+ this.fireError(rejectReason, ti);
476
+ }
477
+ fireError(rejectReason, ti) {
478
+ if (ti.done) {
479
+ ti.done(false, false, rejectReason);
480
+ }
481
+ if (ti.reject && !this.destroyed) {
482
+ ti.reject(rejectReason);
483
+ }
484
+ else {
485
+ ti.resolve(false);
486
+ }
487
+ }
488
+ /**
489
+ * Consumes the next transition in the queue.
490
+ *
491
+ * @returns whether the transition is executed.
492
+ */
493
+ nextTrns() {
494
+ // this is the framework's bread 'n butta function
495
+ // only one transition is allowed at any given time
496
+ if (this.isTransitioning) {
497
+ return false;
498
+ }
499
+ // there is no transition happening right now, executes the next instructions.
500
+ const ti = this.transInstr.shift();
501
+ if (!ti) {
502
+ return false;
503
+ }
504
+ this.runTransition(ti);
505
+ return true;
506
+ }
507
+ /** Executes all the transition instruction from the queue. */
508
+ async runTransition(ti) {
509
+ try {
510
+ // set that this nav is actively transitioning
511
+ this.ionNavWillChange.emit();
512
+ this.isTransitioning = true;
513
+ this.prepareTI(ti);
514
+ const leavingView = this.getActiveSync();
515
+ const enteringView = this.getEnteringView(ti, leavingView);
516
+ if (!leavingView && !enteringView) {
517
+ throw new Error('no views in the stack to be removed');
518
+ }
519
+ if (enteringView && enteringView.state === VIEW_STATE_NEW) {
520
+ await enteringView.init(this.el);
521
+ }
522
+ this.postViewInit(enteringView, leavingView, ti);
523
+ // Needs transition?
524
+ const requiresTransition = (ti.enteringRequiresTransition || ti.leavingRequiresTransition) && enteringView !== leavingView;
525
+ if (requiresTransition && ti.opts && leavingView) {
526
+ const isBackDirection = ti.opts.direction === 'back';
750
527
  /**
751
- * If the transition did not complete, the leavingView will still be the active
752
- * view on the stack. Otherwise unmount all the views after the enteringView.
528
+ * If heading back, use the entering page's animation
529
+ * unless otherwise specified by the developer.
753
530
  */
754
- const activeView = hasCompleted ? enteringView : leavingView;
755
- if (activeView) {
756
- this.unmountInactiveViews(activeView);
757
- }
758
- return {
759
- hasCompleted,
760
- requiresTransition: true,
761
- enteringView,
762
- leavingView,
763
- direction: opts.direction,
531
+ if (isBackDirection) {
532
+ ti.opts.animationBuilder = ti.opts.animationBuilder || (enteringView === null || enteringView === void 0 ? void 0 : enteringView.animationBuilder);
533
+ }
534
+ leavingView.animationBuilder = ti.opts.animationBuilder;
535
+ }
536
+ let result;
537
+ if (requiresTransition) {
538
+ result = await this.transition(enteringView, leavingView, ti);
539
+ }
540
+ else {
541
+ // transition is not required, so we are already done!
542
+ // they're inserting/removing the views somewhere in the middle or
543
+ // beginning, so visually nothing needs to animate/transition
544
+ // resolve immediately because there's no animation that's happening
545
+ result = {
546
+ hasCompleted: true,
547
+ requiresTransition: false,
764
548
  };
765
- }
766
- /**
767
- * Inserts a view at the specified index.
768
- *
769
- * When the view already is in the stack it will be moved to the new position.
770
- *
771
- * @param view The view to insert.
772
- * @param index The index where to insert the view.
773
- */
774
- insertViewAt(view, index) {
775
- const views = this.views;
776
- const existingIndex = views.indexOf(view);
777
- if (existingIndex > -1) {
778
- assert(view.nav === this, 'view is not part of the nav');
779
- // The view already in the stack, removes it.
780
- views.splice(existingIndex, 1);
781
- // and add it back at the requested index.
782
- views.splice(index, 0, view);
549
+ }
550
+ this.success(result, ti);
551
+ this.ionNavDidChange.emit();
552
+ }
553
+ catch (rejectReason) {
554
+ this.failed(rejectReason, ti);
555
+ }
556
+ this.isTransitioning = false;
557
+ this.nextTrns();
558
+ }
559
+ prepareTI(ti) {
560
+ var _a, _b;
561
+ var _c;
562
+ const viewsLength = this.views.length;
563
+ (_a = ti.opts) !== null && _a !== void 0 ? _a : (ti.opts = {});
564
+ (_b = (_c = ti.opts).delegate) !== null && _b !== void 0 ? _b : (_c.delegate = this.delegate);
565
+ if (ti.removeView !== undefined) {
566
+ assert(ti.removeStart !== undefined, 'removeView needs removeStart');
567
+ assert(ti.removeCount !== undefined, 'removeView needs removeCount');
568
+ const index = this.views.indexOf(ti.removeView);
569
+ if (index < 0) {
570
+ throw new Error('removeView was not found');
571
+ }
572
+ ti.removeStart += index;
573
+ }
574
+ if (ti.removeStart !== undefined) {
575
+ if (ti.removeStart < 0) {
576
+ ti.removeStart = viewsLength - 1;
577
+ }
578
+ if (ti.removeCount < 0) {
579
+ ti.removeCount = viewsLength - ti.removeStart;
580
+ }
581
+ ti.leavingRequiresTransition = ti.removeCount > 0 && ti.removeStart + ti.removeCount === viewsLength;
582
+ }
583
+ if (ti.insertViews) {
584
+ // allow -1 to be passed in to auto push it on the end
585
+ // and clean up the index if it's larger then the size of the stack
586
+ if (ti.insertStart < 0 || ti.insertStart > viewsLength) {
587
+ ti.insertStart = viewsLength;
588
+ }
589
+ ti.enteringRequiresTransition = ti.insertStart === viewsLength;
590
+ }
591
+ const insertViews = ti.insertViews;
592
+ if (!insertViews) {
593
+ return;
594
+ }
595
+ assert(insertViews.length > 0, 'length can not be zero');
596
+ const viewControllers = convertToViews(insertViews);
597
+ if (viewControllers.length === 0) {
598
+ throw new Error('invalid views to insert');
599
+ }
600
+ // Check all the inserted view are correct
601
+ for (const view of viewControllers) {
602
+ view.delegate = ti.opts.delegate;
603
+ const nav = view.nav;
604
+ if (nav && nav !== this) {
605
+ throw new Error('inserted view was already inserted');
606
+ }
607
+ if (view.state === VIEW_STATE_DESTROYED) {
608
+ throw new Error('inserted view was already destroyed');
609
+ }
610
+ }
611
+ ti.insertViews = viewControllers;
612
+ }
613
+ /**
614
+ * Returns the view that will be entered considering the transition instructions.
615
+ *
616
+ * @param ti The instructions.
617
+ * @param leavingView The view being left or undefined if none.
618
+ *
619
+ * @returns The view that will be entered, undefined if none.
620
+ */
621
+ getEnteringView(ti, leavingView) {
622
+ // The last inserted view will be entered when view are inserted.
623
+ const insertViews = ti.insertViews;
624
+ if (insertViews !== undefined) {
625
+ return insertViews[insertViews.length - 1];
626
+ }
627
+ // When views are deleted, we will enter the last view that is not removed and not the view being left.
628
+ const removeStart = ti.removeStart;
629
+ if (removeStart !== undefined) {
630
+ const views = this.views;
631
+ const removeEnd = removeStart + ti.removeCount;
632
+ for (let i = views.length - 1; i >= 0; i--) {
633
+ const view = views[i];
634
+ if ((i < removeStart || i >= removeEnd) && view !== leavingView) {
635
+ return view;
636
+ }
637
+ }
638
+ }
639
+ return undefined;
640
+ }
641
+ /**
642
+ * Adds and Removes the views from the navigation stack.
643
+ *
644
+ * @param enteringView The view being entered.
645
+ * @param leavingView The view being left.
646
+ * @param ti The instructions.
647
+ */
648
+ postViewInit(enteringView, leavingView, ti) {
649
+ var _a, _b, _c;
650
+ assert(leavingView || enteringView, 'Both leavingView and enteringView are null');
651
+ assert(ti.resolve, 'resolve must be valid');
652
+ assert(ti.reject, 'reject must be valid');
653
+ // Compute the views to remove.
654
+ const opts = ti.opts;
655
+ const { insertViews, removeStart, removeCount } = ti;
656
+ /** Records the view to destroy */
657
+ let destroyQueue;
658
+ // there are views to remove
659
+ if (removeStart !== undefined && removeCount !== undefined) {
660
+ assert(removeStart >= 0, 'removeStart can not be negative');
661
+ assert(removeCount >= 0, 'removeCount can not be negative');
662
+ destroyQueue = [];
663
+ for (let i = removeStart; i < removeStart + removeCount; i++) {
664
+ const view = this.views[i];
665
+ if (view !== undefined && view !== enteringView && view !== leavingView) {
666
+ destroyQueue.push(view);
667
+ }
668
+ }
669
+ // default the direction to "back"
670
+ (_a = opts.direction) !== null && _a !== void 0 ? _a : (opts.direction = 'back');
671
+ }
672
+ const finalNumViews = this.views.length + ((_b = insertViews === null || insertViews === void 0 ? void 0 : insertViews.length) !== null && _b !== void 0 ? _b : 0) - (removeCount !== null && removeCount !== void 0 ? removeCount : 0);
673
+ assert(finalNumViews >= 0, 'final balance can not be negative');
674
+ if (finalNumViews === 0) {
675
+ console.warn(`You can't remove all the pages in the navigation stack. nav.pop() is probably called too many times.`, this, this.el);
676
+ throw new Error('navigation stack needs at least one root page');
677
+ }
678
+ // At this point the transition can not be rejected, any throw should be an error
679
+ // Insert the new views in the stack.
680
+ if (insertViews) {
681
+ // add the views to the
682
+ let insertIndex = ti.insertStart;
683
+ for (const view of insertViews) {
684
+ this.insertViewAt(view, insertIndex);
685
+ insertIndex++;
686
+ }
687
+ if (ti.enteringRequiresTransition) {
688
+ // default to forward if not already set
689
+ (_c = opts.direction) !== null && _c !== void 0 ? _c : (opts.direction = 'forward');
690
+ }
691
+ }
692
+ // if the views to be removed are in the beginning or middle
693
+ // and there is not a view that needs to visually transition out
694
+ // then just destroy them and don't transition anything
695
+ // batch all of lifecycles together
696
+ // let's make sure, callbacks are zoned
697
+ if (destroyQueue && destroyQueue.length > 0) {
698
+ for (const view of destroyQueue) {
699
+ lifecycle(view.element, LIFECYCLE_WILL_LEAVE);
700
+ lifecycle(view.element, LIFECYCLE_DID_LEAVE);
701
+ lifecycle(view.element, LIFECYCLE_WILL_UNLOAD);
702
+ }
703
+ // once all lifecycle events has been delivered, we can safely detroy the views
704
+ for (const view of destroyQueue) {
705
+ this.destroyView(view);
706
+ }
707
+ }
708
+ }
709
+ async transition(enteringView, leavingView, ti) {
710
+ // we should animate (duration > 0) if the pushed page is not the first one (startup)
711
+ // or if it is a portal (modal, actionsheet, etc.)
712
+ const opts = ti.opts;
713
+ const progressCallback = opts.progressAnimation
714
+ ? (ani) => {
715
+ /**
716
+ * Because this progress callback is called asynchronously
717
+ * it is possible for the gesture to start and end before
718
+ * the animation is ever set. In that scenario, we should
719
+ * immediately call progressEnd so that the transition promise
720
+ * resolves and the gesture does not get locked up.
721
+ */
722
+ if (ani !== undefined && !this.gestureOrAnimationInProgress) {
723
+ this.gestureOrAnimationInProgress = true;
724
+ ani.onFinish(() => {
725
+ this.gestureOrAnimationInProgress = false;
726
+ }, { oneTimeCallback: true });
727
+ /**
728
+ * Playing animation to beginning
729
+ * with a duration of 0 prevents
730
+ * any flickering when the animation
731
+ * is later cleaned up.
732
+ */
733
+ ani.progressEnd(0, 0, 0);
783
734
  }
784
735
  else {
785
- assert(!view.nav, 'nav is used');
786
- // this is a new view to add to the stack
787
- // create the new entering view
788
- view.nav = this;
789
- views.splice(index, 0, view);
790
- }
791
- }
792
- /**
793
- * Removes a view from the stack.
794
- *
795
- * @param view The view to remove.
796
- */
797
- removeView(view) {
798
- assert(view.state === VIEW_STATE_ATTACHED || view.state === VIEW_STATE_DESTROYED, 'view state should be loaded or destroyed');
799
- const views = this.views;
800
- const index = views.indexOf(view);
801
- assert(index > -1, 'view must be part of the stack');
802
- if (index >= 0) {
803
- views.splice(index, 1);
804
- }
805
- }
806
- destroyView(view) {
807
- view._destroy();
808
- this.removeView(view);
809
- }
736
+ this.sbAni = ani;
737
+ }
738
+ }
739
+ : undefined;
740
+ const mode = getIonMode(this);
741
+ const enteringEl = enteringView.element;
742
+ // eslint-disable-next-line @typescript-eslint/prefer-optional-chain
743
+ const leavingEl = leavingView && leavingView.element;
744
+ const animationOpts = Object.assign(Object.assign({ mode, showGoBack: this.canGoBackSync(enteringView), baseEl: this.el, progressCallback, animated: this.animated && config.getBoolean('animated', true), enteringEl,
745
+ leavingEl }, opts), { animationBuilder: opts.animationBuilder || this.animation || config.get('navAnimation') });
746
+ const { hasCompleted } = await transition(animationOpts);
747
+ return this.transitionFinish(hasCompleted, enteringView, leavingView, opts);
748
+ }
749
+ transitionFinish(hasCompleted, enteringView, leavingView, opts) {
810
750
  /**
811
- * Unmounts all inactive views after the specified active view.
812
- *
813
- * DOM WRITE
814
- *
815
- * @param activeView The view that is actively visible in the stack. Used to calculate which views to unmount.
751
+ * If the transition did not complete, the leavingView will still be the active
752
+ * view on the stack. Otherwise unmount all the views after the enteringView.
816
753
  */
817
- unmountInactiveViews(activeView) {
818
- // ok, cleanup time!! Destroy all of the views that are
819
- // INACTIVE and come after the active view
820
- // only do this if the views exist, though
821
- if (this.destroyed) {
822
- return;
823
- }
824
- const views = this.views;
825
- const activeViewIndex = views.indexOf(activeView);
826
- for (let i = views.length - 1; i >= 0; i--) {
827
- const view = views[i];
828
- /**
829
- * When inserting multiple views via insertPages
830
- * the last page will be transitioned to, but the
831
- * others will not be. As a result, a DOM element
832
- * will only be created for the last page inserted.
833
- * As a result, it is possible to have views in the
834
- * stack that do not have `view.element` yet.
835
- */
836
- const element = view.element;
837
- if (element) {
838
- if (i > activeViewIndex) {
839
- // this view comes after the active view
840
- // let's unload it
841
- lifecycle(element, LIFECYCLE_WILL_UNLOAD);
842
- this.destroyView(view);
843
- }
844
- else if (i < activeViewIndex) {
845
- // this view comes before the active view
846
- // and it is not a portal then ensure it is hidden
847
- setPageHidden(element, true);
848
- }
849
- }
850
- }
851
- }
852
- canStart() {
853
- return (!this.gestureOrAnimationInProgress &&
854
- !!this.swipeGesture &&
855
- !this.isTransitioning &&
856
- this.transInstr.length === 0 &&
857
- this.canGoBackSync());
858
- }
859
- onStart() {
860
- this.gestureOrAnimationInProgress = true;
861
- this.pop({ direction: 'back', progressAnimation: true });
862
- }
863
- onMove(stepValue) {
864
- if (this.sbAni) {
865
- this.sbAni.progressStep(stepValue);
866
- }
867
- }
868
- onEnd(shouldComplete, stepValue, dur) {
869
- if (this.sbAni) {
870
- this.sbAni.onFinish(() => {
871
- this.gestureOrAnimationInProgress = false;
872
- }, { oneTimeCallback: true });
873
- // Account for rounding errors in JS
874
- let newStepValue = shouldComplete ? -1e-3 : 0.001;
875
- /**
876
- * Animation will be reversed here, so need to
877
- * reverse the easing curve as well
878
- *
879
- * Additionally, we need to account for the time relative
880
- * to the new easing curve, as `stepValue` is going to be given
881
- * in terms of a linear curve.
882
- */
883
- if (!shouldComplete) {
884
- this.sbAni.easing('cubic-bezier(1, 0, 0.68, 0.28)');
885
- newStepValue += getTimeGivenProgression([0, 0], [1, 0], [0.68, 0.28], [1, 1], stepValue)[0];
886
- }
887
- else {
888
- newStepValue += getTimeGivenProgression([0, 0], [0.32, 0.72], [0, 1], [1, 1], stepValue)[0];
889
- }
890
- this.sbAni.progressEnd(shouldComplete ? 1 : 0, newStepValue, dur);
891
- }
892
- else {
893
- this.gestureOrAnimationInProgress = false;
894
- }
895
- }
896
- render() {
897
- return h("slot", { key: '6894eccc60e446294b01261477691ea1e88348ab' });
898
- }
899
- get el() { return getElement(this); }
900
- static get watchers() { return {
901
- "swipeGesture": [{
902
- "swipeGestureChanged": 0
903
- }],
904
- "root": [{
905
- "rootChanged": 0
906
- }]
907
- }; }
754
+ const activeView = hasCompleted ? enteringView : leavingView;
755
+ if (activeView) {
756
+ this.unmountInactiveViews(activeView);
757
+ }
758
+ return {
759
+ hasCompleted,
760
+ requiresTransition: true,
761
+ enteringView,
762
+ leavingView,
763
+ direction: opts.direction,
764
+ };
765
+ }
766
+ /**
767
+ * Inserts a view at the specified index.
768
+ *
769
+ * When the view already is in the stack it will be moved to the new position.
770
+ *
771
+ * @param view The view to insert.
772
+ * @param index The index where to insert the view.
773
+ */
774
+ insertViewAt(view, index) {
775
+ const views = this.views;
776
+ const existingIndex = views.indexOf(view);
777
+ if (existingIndex > -1) {
778
+ assert(view.nav === this, 'view is not part of the nav');
779
+ // The view already in the stack, removes it.
780
+ views.splice(existingIndex, 1);
781
+ // and add it back at the requested index.
782
+ views.splice(index, 0, view);
783
+ }
784
+ else {
785
+ assert(!view.nav, 'nav is used');
786
+ // this is a new view to add to the stack
787
+ // create the new entering view
788
+ view.nav = this;
789
+ views.splice(index, 0, view);
790
+ }
791
+ }
792
+ /**
793
+ * Removes a view from the stack.
794
+ *
795
+ * @param view The view to remove.
796
+ */
797
+ removeView(view) {
798
+ assert(view.state === VIEW_STATE_ATTACHED || view.state === VIEW_STATE_DESTROYED, 'view state should be loaded or destroyed');
799
+ const views = this.views;
800
+ const index = views.indexOf(view);
801
+ assert(index > -1, 'view must be part of the stack');
802
+ if (index >= 0) {
803
+ views.splice(index, 1);
804
+ }
805
+ }
806
+ destroyView(view) {
807
+ view._destroy();
808
+ this.removeView(view);
809
+ }
810
+ /**
811
+ * Unmounts all inactive views after the specified active view.
812
+ *
813
+ * DOM WRITE
814
+ *
815
+ * @param activeView The view that is actively visible in the stack. Used to calculate which views to unmount.
816
+ */
817
+ unmountInactiveViews(activeView) {
818
+ // ok, cleanup time!! Destroy all of the views that are
819
+ // INACTIVE and come after the active view
820
+ // only do this if the views exist, though
821
+ if (this.destroyed) {
822
+ return;
823
+ }
824
+ const views = this.views;
825
+ const activeViewIndex = views.indexOf(activeView);
826
+ for (let i = views.length - 1; i >= 0; i--) {
827
+ const view = views[i];
828
+ /**
829
+ * When inserting multiple views via insertPages
830
+ * the last page will be transitioned to, but the
831
+ * others will not be. As a result, a DOM element
832
+ * will only be created for the last page inserted.
833
+ * As a result, it is possible to have views in the
834
+ * stack that do not have `view.element` yet.
835
+ */
836
+ const element = view.element;
837
+ if (element) {
838
+ if (i > activeViewIndex) {
839
+ // this view comes after the active view
840
+ // let's unload it
841
+ lifecycle(element, LIFECYCLE_WILL_UNLOAD);
842
+ this.destroyView(view);
843
+ }
844
+ else if (i < activeViewIndex) {
845
+ // this view comes before the active view
846
+ // and it is not a portal then ensure it is hidden
847
+ setPageHidden(element, true);
848
+ }
849
+ }
850
+ }
851
+ }
852
+ canStart() {
853
+ return (!this.gestureOrAnimationInProgress &&
854
+ !!this.swipeGesture &&
855
+ !this.isTransitioning &&
856
+ this.transInstr.length === 0 &&
857
+ this.canGoBackSync());
858
+ }
859
+ onStart() {
860
+ this.gestureOrAnimationInProgress = true;
861
+ this.pop({ direction: 'back', progressAnimation: true });
862
+ }
863
+ onMove(stepValue) {
864
+ if (this.sbAni) {
865
+ this.sbAni.progressStep(stepValue);
866
+ }
867
+ }
868
+ onEnd(shouldComplete, stepValue, dur) {
869
+ if (this.sbAni) {
870
+ this.sbAni.onFinish(() => {
871
+ this.gestureOrAnimationInProgress = false;
872
+ }, { oneTimeCallback: true });
873
+ // Account for rounding errors in JS
874
+ let newStepValue = shouldComplete ? -0.001 : 0.001;
875
+ /**
876
+ * Animation will be reversed here, so need to
877
+ * reverse the easing curve as well
878
+ *
879
+ * Additionally, we need to account for the time relative
880
+ * to the new easing curve, as `stepValue` is going to be given
881
+ * in terms of a linear curve.
882
+ */
883
+ if (!shouldComplete) {
884
+ this.sbAni.easing('cubic-bezier(1, 0, 0.68, 0.28)');
885
+ newStepValue += getTimeGivenProgression([0, 0], [1, 0], [0.68, 0.28], [1, 1], stepValue)[0];
886
+ }
887
+ else {
888
+ newStepValue += getTimeGivenProgression([0, 0], [0.32, 0.72], [0, 1], [1, 1], stepValue)[0];
889
+ }
890
+ this.sbAni.progressEnd(shouldComplete ? 1 : 0, newStepValue, dur);
891
+ }
892
+ else {
893
+ this.gestureOrAnimationInProgress = false;
894
+ }
895
+ }
896
+ render() {
897
+ return h("slot", { key: '6894eccc60e446294b01261477691ea1e88348ab' });
898
+ }
899
+ get el() { return getElement(this); }
900
+ static get watchers() { return {
901
+ "swipeGesture": ["swipeGestureChanged"],
902
+ "root": ["rootChanged"]
903
+ }; }
908
904
  };
909
- Nav.style = navCss();
905
+ Nav.style = navCss;
910
906
 
911
907
  export { Nav as ion_nav };