@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,11 +1,13 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-DncWzXDA.js');
4
- var cubicBezier = require('./cubic-bezier-Bv3PvaRI.js');
5
- var helpers = require('./helpers-B4vhh9gt.js');
6
- var index$1 = require('./index-DZA7ogU0.js');
7
- var ionicGlobal = require('./ionic-global-DRLi5Iq3.js');
8
- var frameworkDelegate = require('./framework-delegate-D-6PUvOi.js');
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-7522b3a9.js');
6
+ const cubicBezier = require('./cubic-bezier-5ff9b04e.js');
7
+ const helpers = require('./helpers-72ba682d.js');
8
+ const index$1 = require('./index-2cd1a895.js');
9
+ const ionicGlobal = require('./ionic-global-3915f1f1.js');
10
+ const frameworkDelegate = require('./framework-delegate-ab2cc190.js');
9
11
 
10
12
  /*!
11
13
  * (C) Ionic http://ionicframework.com - MIT License
@@ -77,837 +79,833 @@ const convertToViews = (pages) => {
77
79
  .filter((v) => v !== null);
78
80
  };
79
81
 
80
- const navCss = () => `:host{left:0;right:0;top:0;bottom:0;position:absolute;contain:layout size style;z-index:0}`;
82
+ const navCss = ":host{left:0;right:0;top:0;bottom:0;position:absolute;contain:layout size style;z-index:0}";
81
83
 
82
84
  const Nav = class {
83
- constructor(hostRef) {
84
- index.registerInstance(this, hostRef);
85
- this.ionNavWillLoad = index.createEvent(this, "ionNavWillLoad", 7);
86
- this.ionNavWillChange = index.createEvent(this, "ionNavWillChange", 3);
87
- this.ionNavDidChange = index.createEvent(this, "ionNavDidChange", 3);
88
- this.transInstr = [];
89
- this.gestureOrAnimationInProgress = false;
90
- this.useRouter = false;
91
- this.isTransitioning = false;
92
- this.destroyed = false;
93
- this.views = [];
94
- this.didLoad = false;
95
- this.delegate = undefined;
96
- this.swipeGesture = undefined;
97
- this.animated = true;
98
- this.animation = undefined;
99
- this.rootParams = undefined;
100
- this.root = undefined;
101
- }
102
- swipeGestureChanged() {
103
- if (this.gesture) {
104
- this.gesture.enable(this.swipeGesture === true);
105
- }
106
- }
107
- rootChanged() {
108
- if (this.root === undefined) {
109
- return;
110
- }
111
- if (this.didLoad === false) {
112
- /**
113
- * If the component has not loaded yet, we can skip setting up the root component.
114
- * It will be called when `componentDidLoad` fires.
115
- */
116
- return;
117
- }
118
- if (!this.useRouter) {
119
- if (this.root !== undefined) {
120
- this.setRoot(this.root, this.rootParams);
121
- }
122
- }
123
- }
124
- componentWillLoad() {
125
- this.useRouter = document.querySelector('ion-router') !== null && this.el.closest('[no-router]') === null;
126
- if (this.swipeGesture === undefined) {
127
- const mode = ionicGlobal.getIonMode(this);
128
- this.swipeGesture = ionicGlobal.config.getBoolean('swipeBackEnabled', mode === 'ios');
129
- }
130
- this.ionNavWillLoad.emit();
131
- }
132
- async componentDidLoad() {
133
- // We want to set this flag before any watch callbacks are manually called
134
- this.didLoad = true;
135
- this.rootChanged();
136
- this.gesture = (await Promise.resolve().then(function () { return require('./swipe-back-C9j0kufI.js'); })).createSwipeBackGesture(this.el, this.canStart.bind(this), this.onStart.bind(this), this.onMove.bind(this), this.onEnd.bind(this));
137
- this.swipeGestureChanged();
138
- }
139
- connectedCallback() {
140
- this.destroyed = false;
141
- }
142
- disconnectedCallback() {
143
- for (const view of this.views) {
144
- index$1.lifecycle(view.element, index$1.LIFECYCLE_WILL_UNLOAD);
145
- view._destroy();
146
- }
147
- // Release swipe back gesture and transition.
148
- if (this.gesture) {
149
- this.gesture.destroy();
150
- this.gesture = undefined;
151
- }
152
- this.transInstr.length = 0;
153
- this.views.length = 0;
154
- this.destroyed = true;
155
- }
156
- /**
157
- * Push a new component onto the current navigation stack. Pass any additional
158
- * information along as an object. This additional information is accessible
159
- * through NavParams.
160
- *
161
- * @param component The component to push onto the navigation stack.
162
- * @param componentProps Any properties of the component.
163
- * @param opts The navigation options.
164
- * @param done The transition complete function.
165
- */
166
- push(component, componentProps, opts, done) {
167
- return this.insert(-1, component, componentProps, opts, done);
168
- }
169
- /**
170
- * Inserts a component into the navigation stack at the specified index.
171
- * This is useful to add a component at any point in the navigation stack.
172
- *
173
- * @param insertIndex The index to insert the component at in the stack.
174
- * @param component The component to insert into the navigation stack.
175
- * @param componentProps Any properties of the component.
176
- * @param opts The navigation options.
177
- * @param done The transition complete function.
178
- */
179
- insert(insertIndex, component, componentProps, opts, done) {
180
- return this.insertPages(insertIndex, [{ component, componentProps }], opts, done);
181
- }
182
- /**
183
- * Inserts an array of components into the navigation stack at the specified index.
184
- * The last component in the array will become instantiated as a view, and animate
185
- * in to become the active view.
186
- *
187
- * @param insertIndex The index to insert the components at in the stack.
188
- * @param insertComponents The components to insert into the navigation stack.
189
- * @param opts The navigation options.
190
- * @param done The transition complete function.
191
- */
192
- insertPages(insertIndex, insertComponents, opts, done) {
193
- return this.queueTrns({
194
- insertStart: insertIndex,
195
- insertViews: insertComponents,
196
- opts,
197
- }, done);
198
- }
199
- /**
200
- * Pop a component off of the navigation stack. Navigates back from the current
201
- * component.
202
- *
203
- * @param opts The navigation options.
204
- * @param done The transition complete function.
205
- */
206
- pop(opts, done) {
207
- return this.removeIndex(-1, 1, opts, done);
208
- }
209
- /**
210
- * Pop to a specific index in the navigation stack.
211
- *
212
- * @param indexOrViewCtrl The index or view controller to pop to.
213
- * @param opts The navigation options.
214
- * @param done The transition complete function.
215
- */
216
- popTo(indexOrViewCtrl, opts, done) {
217
- const ti = {
218
- removeStart: -1,
219
- removeCount: -1,
220
- opts,
221
- };
222
- if (typeof indexOrViewCtrl === 'object' && indexOrViewCtrl.component) {
223
- ti.removeView = indexOrViewCtrl;
224
- ti.removeStart = 1;
225
- }
226
- else if (typeof indexOrViewCtrl === 'number') {
227
- ti.removeStart = indexOrViewCtrl + 1;
228
- }
229
- return this.queueTrns(ti, done);
230
- }
231
- /**
232
- * Navigate back to the root of the stack, no matter how far back that is.
233
- *
234
- * @param opts The navigation options.
235
- * @param done The transition complete function.
236
- */
237
- popToRoot(opts, done) {
238
- return this.removeIndex(1, -1, opts, done);
239
- }
240
- /**
241
- * Removes a component from the navigation stack at the specified index.
242
- *
243
- * @param startIndex The number to begin removal at.
244
- * @param removeCount The number of components to remove.
245
- * @param opts The navigation options.
246
- * @param done The transition complete function.
247
- */
248
- removeIndex(startIndex, removeCount = 1, opts, done) {
249
- return this.queueTrns({
250
- removeStart: startIndex,
251
- removeCount,
252
- opts,
253
- }, done);
254
- }
255
- /**
256
- * Set the root for the current navigation stack to a component.
257
- *
258
- * @param component The component to set as the root of the navigation stack.
259
- * @param componentProps Any properties of the component.
260
- * @param opts The navigation options.
261
- * @param done The transition complete function.
262
- */
263
- setRoot(component, componentProps, opts, done) {
264
- return this.setPages([{ component, componentProps }], opts, done);
265
- }
266
- /**
267
- * Set the views of the current navigation stack and navigate to the last view.
268
- * By default animations are disabled, but they can be enabled by passing options
269
- * to the navigation controller. Navigation parameters can also be passed to the
270
- * individual pages in the array.
271
- *
272
- * @param views The list of views to set as the navigation stack.
273
- * @param opts The navigation options.
274
- * @param done The transition complete function.
275
- */
276
- setPages(views, opts, done) {
277
- opts !== null && opts !== void 0 ? opts : (opts = {});
278
- // if animation wasn't set to true then default it to NOT animate
279
- if (opts.animated !== true) {
280
- opts.animated = false;
281
- }
282
- return this.queueTrns({
283
- insertStart: 0,
284
- insertViews: views,
285
- removeStart: 0,
286
- removeCount: -1,
287
- opts,
288
- }, done);
289
- }
290
- /**
291
- * Called by the router to update the view.
292
- *
293
- * @param id The component tag.
294
- * @param params The component params.
295
- * @param direction A direction hint.
296
- * @param animation an AnimationBuilder.
297
- *
298
- * @return the status.
299
- * @internal
300
- */
301
- setRouteId(id, params, direction, animation) {
302
- const active = this.getActiveSync();
303
- if (matches(active, id, params)) {
304
- return Promise.resolve({
305
- changed: false,
306
- element: active.element,
307
- });
308
- }
309
- let resolve;
310
- const promise = new Promise((r) => (resolve = r));
311
- let finish;
312
- const commonOpts = {
313
- updateURL: false,
314
- viewIsReady: (enteringEl) => {
315
- let mark;
316
- const p = new Promise((r) => (mark = r));
317
- resolve({
318
- changed: true,
319
- element: enteringEl,
320
- markVisible: async () => {
321
- mark();
322
- await finish;
323
- },
324
- });
325
- return p;
326
- },
327
- };
328
- if (direction === 'root') {
329
- finish = this.setRoot(id, params, commonOpts);
330
- }
331
- else {
332
- // Look for a view matching the target in the view stack.
333
- const viewController = this.views.find((v) => matches(v, id, params));
334
- if (viewController) {
335
- finish = this.popTo(viewController, Object.assign(Object.assign({}, commonOpts), { direction: 'back', animationBuilder: animation }));
336
- }
337
- else if (direction === 'forward') {
338
- finish = this.push(id, params, Object.assign(Object.assign({}, commonOpts), { animationBuilder: animation }));
339
- }
340
- else if (direction === 'back') {
341
- finish = this.setRoot(id, params, Object.assign(Object.assign({}, commonOpts), { direction: 'back', animated: true, animationBuilder: animation }));
342
- }
343
- }
344
- return promise;
345
- }
346
- /**
347
- * Called by <ion-router> to retrieve the current component.
348
- *
349
- * @internal
350
- */
351
- async getRouteId() {
352
- const active = this.getActiveSync();
353
- if (active) {
354
- return {
355
- id: active.element.tagName,
356
- params: active.params,
357
- element: active.element,
358
- };
359
- }
360
- return undefined;
361
- }
362
- /**
363
- * Get the active view.
364
- */
365
- async getActive() {
366
- return this.getActiveSync();
367
- }
368
- /**
369
- * Get the view at the specified index.
370
- *
371
- * @param index The index of the view.
372
- */
373
- async getByIndex(index) {
374
- return this.views[index];
375
- }
376
- /**
377
- * Returns `true` if the current view can go back.
378
- *
379
- * @param view The view to check.
380
- */
381
- async canGoBack(view) {
382
- return this.canGoBackSync(view);
383
- }
384
- /**
385
- * Get the previous view.
386
- *
387
- * @param view The view to get.
388
- */
389
- async getPrevious(view) {
390
- return this.getPreviousSync(view);
391
- }
392
- getLength() {
393
- return this.views.length;
394
- }
395
- getActiveSync() {
396
- return this.views[this.views.length - 1];
397
- }
398
- canGoBackSync(view = this.getActiveSync()) {
399
- return !!(view && this.getPreviousSync(view));
400
- }
401
- getPreviousSync(view = this.getActiveSync()) {
402
- if (!view) {
403
- return undefined;
404
- }
405
- const views = this.views;
406
- const index = views.indexOf(view);
407
- return index > 0 ? views[index - 1] : undefined;
408
- }
409
- /**
410
- * Adds a navigation stack change to the queue and schedules it to run.
411
- *
412
- * @returns Whether the transition succeeds.
413
- */
414
- async queueTrns(ti, done) {
415
- var _a, _b;
416
- if (this.isTransitioning && ((_a = ti.opts) === null || _a === void 0 ? void 0 : _a.skipIfBusy)) {
417
- return false;
418
- }
419
- const promise = new Promise((resolve, reject) => {
420
- ti.resolve = resolve;
421
- ti.reject = reject;
85
+ constructor(hostRef) {
86
+ index.registerInstance(this, hostRef);
87
+ this.ionNavWillLoad = index.createEvent(this, "ionNavWillLoad", 7);
88
+ this.ionNavWillChange = index.createEvent(this, "ionNavWillChange", 3);
89
+ this.ionNavDidChange = index.createEvent(this, "ionNavDidChange", 3);
90
+ this.transInstr = [];
91
+ this.gestureOrAnimationInProgress = false;
92
+ this.useRouter = false;
93
+ this.isTransitioning = false;
94
+ this.destroyed = false;
95
+ this.views = [];
96
+ this.didLoad = false;
97
+ this.delegate = undefined;
98
+ this.swipeGesture = undefined;
99
+ this.animated = true;
100
+ this.animation = undefined;
101
+ this.rootParams = undefined;
102
+ this.root = undefined;
103
+ }
104
+ swipeGestureChanged() {
105
+ if (this.gesture) {
106
+ this.gesture.enable(this.swipeGesture === true);
107
+ }
108
+ }
109
+ rootChanged() {
110
+ if (this.root === undefined) {
111
+ return;
112
+ }
113
+ if (this.didLoad === false) {
114
+ /**
115
+ * If the component has not loaded yet, we can skip setting up the root component.
116
+ * It will be called when `componentDidLoad` fires.
117
+ */
118
+ return;
119
+ }
120
+ if (!this.useRouter) {
121
+ if (this.root !== undefined) {
122
+ this.setRoot(this.root, this.rootParams);
123
+ }
124
+ }
125
+ }
126
+ componentWillLoad() {
127
+ this.useRouter = document.querySelector('ion-router') !== null && this.el.closest('[no-router]') === null;
128
+ if (this.swipeGesture === undefined) {
129
+ const mode = ionicGlobal.getIonMode(this);
130
+ this.swipeGesture = ionicGlobal.config.getBoolean('swipeBackEnabled', mode === 'ios');
131
+ }
132
+ this.ionNavWillLoad.emit();
133
+ }
134
+ async componentDidLoad() {
135
+ // We want to set this flag before any watch callbacks are manually called
136
+ this.didLoad = true;
137
+ this.rootChanged();
138
+ this.gesture = (await Promise.resolve().then(function () { return require('./swipe-back-3d3a5129.js'); })).createSwipeBackGesture(this.el, this.canStart.bind(this), this.onStart.bind(this), this.onMove.bind(this), this.onEnd.bind(this));
139
+ this.swipeGestureChanged();
140
+ }
141
+ connectedCallback() {
142
+ this.destroyed = false;
143
+ }
144
+ disconnectedCallback() {
145
+ for (const view of this.views) {
146
+ index$1.lifecycle(view.element, index$1.LIFECYCLE_WILL_UNLOAD);
147
+ view._destroy();
148
+ }
149
+ // Release swipe back gesture and transition.
150
+ if (this.gesture) {
151
+ this.gesture.destroy();
152
+ this.gesture = undefined;
153
+ }
154
+ this.transInstr.length = 0;
155
+ this.views.length = 0;
156
+ this.destroyed = true;
157
+ }
158
+ /**
159
+ * Push a new component onto the current navigation stack. Pass any additional
160
+ * information along as an object. This additional information is accessible
161
+ * through NavParams.
162
+ *
163
+ * @param component The component to push onto the navigation stack.
164
+ * @param componentProps Any properties of the component.
165
+ * @param opts The navigation options.
166
+ * @param done The transition complete function.
167
+ */
168
+ push(component, componentProps, opts, done) {
169
+ return this.insert(-1, component, componentProps, opts, done);
170
+ }
171
+ /**
172
+ * Inserts a component into the navigation stack at the specified index.
173
+ * This is useful to add a component at any point in the navigation stack.
174
+ *
175
+ * @param insertIndex The index to insert the component at in the stack.
176
+ * @param component The component to insert into the navigation stack.
177
+ * @param componentProps Any properties of the component.
178
+ * @param opts The navigation options.
179
+ * @param done The transition complete function.
180
+ */
181
+ insert(insertIndex, component, componentProps, opts, done) {
182
+ return this.insertPages(insertIndex, [{ component, componentProps }], opts, done);
183
+ }
184
+ /**
185
+ * Inserts an array of components into the navigation stack at the specified index.
186
+ * The last component in the array will become instantiated as a view, and animate
187
+ * in to become the active view.
188
+ *
189
+ * @param insertIndex The index to insert the components at in the stack.
190
+ * @param insertComponents The components to insert into the navigation stack.
191
+ * @param opts The navigation options.
192
+ * @param done The transition complete function.
193
+ */
194
+ insertPages(insertIndex, insertComponents, opts, done) {
195
+ return this.queueTrns({
196
+ insertStart: insertIndex,
197
+ insertViews: insertComponents,
198
+ opts,
199
+ }, done);
200
+ }
201
+ /**
202
+ * Pop a component off of the navigation stack. Navigates back from the current
203
+ * component.
204
+ *
205
+ * @param opts The navigation options.
206
+ * @param done The transition complete function.
207
+ */
208
+ pop(opts, done) {
209
+ return this.removeIndex(-1, 1, opts, done);
210
+ }
211
+ /**
212
+ * Pop to a specific index in the navigation stack.
213
+ *
214
+ * @param indexOrViewCtrl The index or view controller to pop to.
215
+ * @param opts The navigation options.
216
+ * @param done The transition complete function.
217
+ */
218
+ popTo(indexOrViewCtrl, opts, done) {
219
+ const ti = {
220
+ removeStart: -1,
221
+ removeCount: -1,
222
+ opts,
223
+ };
224
+ if (typeof indexOrViewCtrl === 'object' && indexOrViewCtrl.component) {
225
+ ti.removeView = indexOrViewCtrl;
226
+ ti.removeStart = 1;
227
+ }
228
+ else if (typeof indexOrViewCtrl === 'number') {
229
+ ti.removeStart = indexOrViewCtrl + 1;
230
+ }
231
+ return this.queueTrns(ti, done);
232
+ }
233
+ /**
234
+ * Navigate back to the root of the stack, no matter how far back that is.
235
+ *
236
+ * @param opts The navigation options.
237
+ * @param done The transition complete function.
238
+ */
239
+ popToRoot(opts, done) {
240
+ return this.removeIndex(1, -1, opts, done);
241
+ }
242
+ /**
243
+ * Removes a component from the navigation stack at the specified index.
244
+ *
245
+ * @param startIndex The number to begin removal at.
246
+ * @param removeCount The number of components to remove.
247
+ * @param opts The navigation options.
248
+ * @param done The transition complete function.
249
+ */
250
+ removeIndex(startIndex, removeCount = 1, opts, done) {
251
+ return this.queueTrns({
252
+ removeStart: startIndex,
253
+ removeCount,
254
+ opts,
255
+ }, done);
256
+ }
257
+ /**
258
+ * Set the root for the current navigation stack to a component.
259
+ *
260
+ * @param component The component to set as the root of the navigation stack.
261
+ * @param componentProps Any properties of the component.
262
+ * @param opts The navigation options.
263
+ * @param done The transition complete function.
264
+ */
265
+ setRoot(component, componentProps, opts, done) {
266
+ return this.setPages([{ component, componentProps }], opts, done);
267
+ }
268
+ /**
269
+ * Set the views of the current navigation stack and navigate to the last view.
270
+ * By default animations are disabled, but they can be enabled by passing options
271
+ * to the navigation controller. Navigation parameters can also be passed to the
272
+ * individual pages in the array.
273
+ *
274
+ * @param views The list of views to set as the navigation stack.
275
+ * @param opts The navigation options.
276
+ * @param done The transition complete function.
277
+ */
278
+ setPages(views, opts, done) {
279
+ opts !== null && opts !== void 0 ? opts : (opts = {});
280
+ // if animation wasn't set to true then default it to NOT animate
281
+ if (opts.animated !== true) {
282
+ opts.animated = false;
283
+ }
284
+ return this.queueTrns({
285
+ insertStart: 0,
286
+ insertViews: views,
287
+ removeStart: 0,
288
+ removeCount: -1,
289
+ opts,
290
+ }, done);
291
+ }
292
+ /**
293
+ * Called by the router to update the view.
294
+ *
295
+ * @param id The component tag.
296
+ * @param params The component params.
297
+ * @param direction A direction hint.
298
+ * @param animation an AnimationBuilder.
299
+ *
300
+ * @return the status.
301
+ * @internal
302
+ */
303
+ setRouteId(id, params, direction, animation) {
304
+ const active = this.getActiveSync();
305
+ if (matches(active, id, params)) {
306
+ return Promise.resolve({
307
+ changed: false,
308
+ element: active.element,
309
+ });
310
+ }
311
+ let resolve;
312
+ const promise = new Promise((r) => (resolve = r));
313
+ let finish;
314
+ const commonOpts = {
315
+ updateURL: false,
316
+ viewIsReady: (enteringEl) => {
317
+ let mark;
318
+ const p = new Promise((r) => (mark = r));
319
+ resolve({
320
+ changed: true,
321
+ element: enteringEl,
322
+ markVisible: async () => {
323
+ mark();
324
+ await finish;
325
+ },
422
326
  });
423
- ti.done = done;
424
- /**
425
- * If using router, check to see if navigation hooks
426
- * will allow us to perform this transition. This
427
- * is required in order for hooks to work with
428
- * the ion-back-button or swipe to go back.
429
- */
430
- if (ti.opts && ti.opts.updateURL !== false && this.useRouter) {
431
- const router = document.querySelector('ion-router');
432
- if (router) {
433
- const canTransition = await router.canTransition();
434
- if (canTransition === false) {
435
- return false;
436
- }
437
- if (typeof canTransition === 'string') {
438
- router.push(canTransition, ti.opts.direction || 'back');
439
- return false;
440
- }
441
- }
442
- }
443
- // Normalize empty
444
- if (((_b = ti.insertViews) === null || _b === void 0 ? void 0 : _b.length) === 0) {
445
- ti.insertViews = undefined;
446
- }
447
- // Enqueue transition instruction
448
- this.transInstr.push(ti);
449
- // if there isn't a transition already happening
450
- // then this will kick off this transition
451
- this.nextTrns();
452
- return promise;
453
- }
454
- success(result, ti) {
455
- if (this.destroyed) {
456
- this.fireError('nav controller was destroyed', ti);
457
- return;
458
- }
459
- if (ti.done) {
460
- ti.done(result.hasCompleted, result.requiresTransition, result.enteringView, result.leavingView, result.direction);
461
- }
462
- ti.resolve(result.hasCompleted);
463
- if (ti.opts.updateURL !== false && this.useRouter) {
464
- const router = document.querySelector('ion-router');
465
- if (router) {
466
- const direction = result.direction === 'back' ? 'back' : 'forward';
467
- router.navChanged(direction);
468
- }
469
- }
470
- }
471
- failed(rejectReason, ti) {
472
- if (this.destroyed) {
473
- this.fireError('nav controller was destroyed', ti);
474
- return;
475
- }
476
- this.transInstr.length = 0;
477
- this.fireError(rejectReason, ti);
478
- }
479
- fireError(rejectReason, ti) {
480
- if (ti.done) {
481
- ti.done(false, false, rejectReason);
482
- }
483
- if (ti.reject && !this.destroyed) {
484
- ti.reject(rejectReason);
485
- }
486
- else {
487
- ti.resolve(false);
488
- }
489
- }
490
- /**
491
- * Consumes the next transition in the queue.
492
- *
493
- * @returns whether the transition is executed.
494
- */
495
- nextTrns() {
496
- // this is the framework's bread 'n butta function
497
- // only one transition is allowed at any given time
498
- if (this.isTransitioning) {
499
- return false;
500
- }
501
- // there is no transition happening right now, executes the next instructions.
502
- const ti = this.transInstr.shift();
503
- if (!ti) {
504
- return false;
505
- }
506
- this.runTransition(ti);
507
- return true;
508
- }
509
- /** Executes all the transition instruction from the queue. */
510
- async runTransition(ti) {
511
- try {
512
- // set that this nav is actively transitioning
513
- this.ionNavWillChange.emit();
514
- this.isTransitioning = true;
515
- this.prepareTI(ti);
516
- const leavingView = this.getActiveSync();
517
- const enteringView = this.getEnteringView(ti, leavingView);
518
- if (!leavingView && !enteringView) {
519
- throw new Error('no views in the stack to be removed');
520
- }
521
- if (enteringView && enteringView.state === VIEW_STATE_NEW) {
522
- await enteringView.init(this.el);
523
- }
524
- this.postViewInit(enteringView, leavingView, ti);
525
- // Needs transition?
526
- const requiresTransition = (ti.enteringRequiresTransition || ti.leavingRequiresTransition) && enteringView !== leavingView;
527
- if (requiresTransition && ti.opts && leavingView) {
528
- const isBackDirection = ti.opts.direction === 'back';
529
- /**
530
- * If heading back, use the entering page's animation
531
- * unless otherwise specified by the developer.
532
- */
533
- if (isBackDirection) {
534
- ti.opts.animationBuilder = ti.opts.animationBuilder || (enteringView === null || enteringView === void 0 ? void 0 : enteringView.animationBuilder);
535
- }
536
- leavingView.animationBuilder = ti.opts.animationBuilder;
537
- }
538
- let result;
539
- if (requiresTransition) {
540
- result = await this.transition(enteringView, leavingView, ti);
541
- }
542
- else {
543
- // transition is not required, so we are already done!
544
- // they're inserting/removing the views somewhere in the middle or
545
- // beginning, so visually nothing needs to animate/transition
546
- // resolve immediately because there's no animation that's happening
547
- result = {
548
- hasCompleted: true,
549
- requiresTransition: false,
550
- };
551
- }
552
- this.success(result, ti);
553
- this.ionNavDidChange.emit();
554
- }
555
- catch (rejectReason) {
556
- this.failed(rejectReason, ti);
557
- }
558
- this.isTransitioning = false;
559
- this.nextTrns();
560
- }
561
- prepareTI(ti) {
562
- var _a, _b;
563
- var _c;
564
- const viewsLength = this.views.length;
565
- (_a = ti.opts) !== null && _a !== void 0 ? _a : (ti.opts = {});
566
- (_b = (_c = ti.opts).delegate) !== null && _b !== void 0 ? _b : (_c.delegate = this.delegate);
567
- if (ti.removeView !== undefined) {
568
- helpers.assert(ti.removeStart !== undefined, 'removeView needs removeStart');
569
- helpers.assert(ti.removeCount !== undefined, 'removeView needs removeCount');
570
- const index = this.views.indexOf(ti.removeView);
571
- if (index < 0) {
572
- throw new Error('removeView was not found');
573
- }
574
- ti.removeStart += index;
575
- }
576
- if (ti.removeStart !== undefined) {
577
- if (ti.removeStart < 0) {
578
- ti.removeStart = viewsLength - 1;
579
- }
580
- if (ti.removeCount < 0) {
581
- ti.removeCount = viewsLength - ti.removeStart;
582
- }
583
- ti.leavingRequiresTransition = ti.removeCount > 0 && ti.removeStart + ti.removeCount === viewsLength;
584
- }
585
- if (ti.insertViews) {
586
- // allow -1 to be passed in to auto push it on the end
587
- // and clean up the index if it's larger then the size of the stack
588
- if (ti.insertStart < 0 || ti.insertStart > viewsLength) {
589
- ti.insertStart = viewsLength;
590
- }
591
- ti.enteringRequiresTransition = ti.insertStart === viewsLength;
592
- }
593
- const insertViews = ti.insertViews;
594
- if (!insertViews) {
595
- return;
596
- }
597
- helpers.assert(insertViews.length > 0, 'length can not be zero');
598
- const viewControllers = convertToViews(insertViews);
599
- if (viewControllers.length === 0) {
600
- throw new Error('invalid views to insert');
601
- }
602
- // Check all the inserted view are correct
603
- for (const view of viewControllers) {
604
- view.delegate = ti.opts.delegate;
605
- const nav = view.nav;
606
- if (nav && nav !== this) {
607
- throw new Error('inserted view was already inserted');
608
- }
609
- if (view.state === VIEW_STATE_DESTROYED) {
610
- throw new Error('inserted view was already destroyed');
611
- }
612
- }
613
- ti.insertViews = viewControllers;
614
- }
615
- /**
616
- * Returns the view that will be entered considering the transition instructions.
617
- *
618
- * @param ti The instructions.
619
- * @param leavingView The view being left or undefined if none.
620
- *
621
- * @returns The view that will be entered, undefined if none.
622
- */
623
- getEnteringView(ti, leavingView) {
624
- // The last inserted view will be entered when view are inserted.
625
- const insertViews = ti.insertViews;
626
- if (insertViews !== undefined) {
627
- return insertViews[insertViews.length - 1];
628
- }
629
- // When views are deleted, we will enter the last view that is not removed and not the view being left.
630
- const removeStart = ti.removeStart;
631
- if (removeStart !== undefined) {
632
- const views = this.views;
633
- const removeEnd = removeStart + ti.removeCount;
634
- for (let i = views.length - 1; i >= 0; i--) {
635
- const view = views[i];
636
- if ((i < removeStart || i >= removeEnd) && view !== leavingView) {
637
- return view;
638
- }
639
- }
640
- }
641
- return undefined;
642
- }
327
+ return p;
328
+ },
329
+ };
330
+ if (direction === 'root') {
331
+ finish = this.setRoot(id, params, commonOpts);
332
+ }
333
+ else {
334
+ // Look for a view matching the target in the view stack.
335
+ const viewController = this.views.find((v) => matches(v, id, params));
336
+ if (viewController) {
337
+ finish = this.popTo(viewController, Object.assign(Object.assign({}, commonOpts), { direction: 'back', animationBuilder: animation }));
338
+ }
339
+ else if (direction === 'forward') {
340
+ finish = this.push(id, params, Object.assign(Object.assign({}, commonOpts), { animationBuilder: animation }));
341
+ }
342
+ else if (direction === 'back') {
343
+ finish = this.setRoot(id, params, Object.assign(Object.assign({}, commonOpts), { direction: 'back', animated: true, animationBuilder: animation }));
344
+ }
345
+ }
346
+ return promise;
347
+ }
348
+ /**
349
+ * Called by <ion-router> to retrieve the current component.
350
+ *
351
+ * @internal
352
+ */
353
+ async getRouteId() {
354
+ const active = this.getActiveSync();
355
+ if (active) {
356
+ return {
357
+ id: active.element.tagName,
358
+ params: active.params,
359
+ element: active.element,
360
+ };
361
+ }
362
+ return undefined;
363
+ }
364
+ /**
365
+ * Get the active view.
366
+ */
367
+ async getActive() {
368
+ return this.getActiveSync();
369
+ }
370
+ /**
371
+ * Get the view at the specified index.
372
+ *
373
+ * @param index The index of the view.
374
+ */
375
+ async getByIndex(index) {
376
+ return this.views[index];
377
+ }
378
+ /**
379
+ * Returns `true` if the current view can go back.
380
+ *
381
+ * @param view The view to check.
382
+ */
383
+ async canGoBack(view) {
384
+ return this.canGoBackSync(view);
385
+ }
386
+ /**
387
+ * Get the previous view.
388
+ *
389
+ * @param view The view to get.
390
+ */
391
+ async getPrevious(view) {
392
+ return this.getPreviousSync(view);
393
+ }
394
+ getLength() {
395
+ return this.views.length;
396
+ }
397
+ getActiveSync() {
398
+ return this.views[this.views.length - 1];
399
+ }
400
+ canGoBackSync(view = this.getActiveSync()) {
401
+ return !!(view && this.getPreviousSync(view));
402
+ }
403
+ getPreviousSync(view = this.getActiveSync()) {
404
+ if (!view) {
405
+ return undefined;
406
+ }
407
+ const views = this.views;
408
+ const index = views.indexOf(view);
409
+ return index > 0 ? views[index - 1] : undefined;
410
+ }
411
+ /**
412
+ * Adds a navigation stack change to the queue and schedules it to run.
413
+ *
414
+ * @returns Whether the transition succeeds.
415
+ */
416
+ async queueTrns(ti, done) {
417
+ var _a, _b;
418
+ if (this.isTransitioning && ((_a = ti.opts) === null || _a === void 0 ? void 0 : _a.skipIfBusy)) {
419
+ return false;
420
+ }
421
+ const promise = new Promise((resolve, reject) => {
422
+ ti.resolve = resolve;
423
+ ti.reject = reject;
424
+ });
425
+ ti.done = done;
643
426
  /**
644
- * Adds and Removes the views from the navigation stack.
645
- *
646
- * @param enteringView The view being entered.
647
- * @param leavingView The view being left.
648
- * @param ti The instructions.
427
+ * If using router, check to see if navigation hooks
428
+ * will allow us to perform this transition. This
429
+ * is required in order for hooks to work with
430
+ * the ion-back-button or swipe to go back.
649
431
  */
650
- postViewInit(enteringView, leavingView, ti) {
651
- var _a, _b, _c;
652
- helpers.assert(leavingView || enteringView, 'Both leavingView and enteringView are null');
653
- helpers.assert(ti.resolve, 'resolve must be valid');
654
- helpers.assert(ti.reject, 'reject must be valid');
655
- // Compute the views to remove.
656
- const opts = ti.opts;
657
- const { insertViews, removeStart, removeCount } = ti;
658
- /** Records the view to destroy */
659
- let destroyQueue;
660
- // there are views to remove
661
- if (removeStart !== undefined && removeCount !== undefined) {
662
- helpers.assert(removeStart >= 0, 'removeStart can not be negative');
663
- helpers.assert(removeCount >= 0, 'removeCount can not be negative');
664
- destroyQueue = [];
665
- for (let i = removeStart; i < removeStart + removeCount; i++) {
666
- const view = this.views[i];
667
- if (view !== undefined && view !== enteringView && view !== leavingView) {
668
- destroyQueue.push(view);
669
- }
670
- }
671
- // default the direction to "back"
672
- (_a = opts.direction) !== null && _a !== void 0 ? _a : (opts.direction = 'back');
673
- }
674
- 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);
675
- helpers.assert(finalNumViews >= 0, 'final balance can not be negative');
676
- if (finalNumViews === 0) {
677
- console.warn(`You can't remove all the pages in the navigation stack. nav.pop() is probably called too many times.`, this, this.el);
678
- throw new Error('navigation stack needs at least one root page');
679
- }
680
- // At this point the transition can not be rejected, any throw should be an error
681
- // Insert the new views in the stack.
682
- if (insertViews) {
683
- // add the views to the
684
- let insertIndex = ti.insertStart;
685
- for (const view of insertViews) {
686
- this.insertViewAt(view, insertIndex);
687
- insertIndex++;
688
- }
689
- if (ti.enteringRequiresTransition) {
690
- // default to forward if not already set
691
- (_c = opts.direction) !== null && _c !== void 0 ? _c : (opts.direction = 'forward');
692
- }
693
- }
694
- // if the views to be removed are in the beginning or middle
695
- // and there is not a view that needs to visually transition out
696
- // then just destroy them and don't transition anything
697
- // batch all of lifecycles together
698
- // let's make sure, callbacks are zoned
699
- if (destroyQueue && destroyQueue.length > 0) {
700
- for (const view of destroyQueue) {
701
- index$1.lifecycle(view.element, index$1.LIFECYCLE_WILL_LEAVE);
702
- index$1.lifecycle(view.element, index$1.LIFECYCLE_DID_LEAVE);
703
- index$1.lifecycle(view.element, index$1.LIFECYCLE_WILL_UNLOAD);
704
- }
705
- // once all lifecycle events has been delivered, we can safely detroy the views
706
- for (const view of destroyQueue) {
707
- this.destroyView(view);
708
- }
709
- }
710
- }
711
- async transition(enteringView, leavingView, ti) {
712
- // we should animate (duration > 0) if the pushed page is not the first one (startup)
713
- // or if it is a portal (modal, actionsheet, etc.)
714
- const opts = ti.opts;
715
- const progressCallback = opts.progressAnimation
716
- ? (ani) => {
717
- /**
718
- * Because this progress callback is called asynchronously
719
- * it is possible for the gesture to start and end before
720
- * the animation is ever set. In that scenario, we should
721
- * immediately call progressEnd so that the transition promise
722
- * resolves and the gesture does not get locked up.
723
- */
724
- if (ani !== undefined && !this.gestureOrAnimationInProgress) {
725
- this.gestureOrAnimationInProgress = true;
726
- ani.onFinish(() => {
727
- this.gestureOrAnimationInProgress = false;
728
- }, { oneTimeCallback: true });
729
- /**
730
- * Playing animation to beginning
731
- * with a duration of 0 prevents
732
- * any flickering when the animation
733
- * is later cleaned up.
734
- */
735
- ani.progressEnd(0, 0, 0);
736
- }
737
- else {
738
- this.sbAni = ani;
739
- }
740
- }
741
- : undefined;
742
- const mode = ionicGlobal.getIonMode(this);
743
- const enteringEl = enteringView.element;
744
- // eslint-disable-next-line @typescript-eslint/prefer-optional-chain
745
- const leavingEl = leavingView && leavingView.element;
746
- const animationOpts = Object.assign(Object.assign({ mode, showGoBack: this.canGoBackSync(enteringView), baseEl: this.el, progressCallback, animated: this.animated && ionicGlobal.config.getBoolean('animated', true), enteringEl,
747
- leavingEl }, opts), { animationBuilder: opts.animationBuilder || this.animation || ionicGlobal.config.get('navAnimation') });
748
- const { hasCompleted } = await index$1.transition(animationOpts);
749
- return this.transitionFinish(hasCompleted, enteringView, leavingView, opts);
750
- }
751
- transitionFinish(hasCompleted, enteringView, leavingView, opts) {
432
+ if (ti.opts && ti.opts.updateURL !== false && this.useRouter) {
433
+ const router = document.querySelector('ion-router');
434
+ if (router) {
435
+ const canTransition = await router.canTransition();
436
+ if (canTransition === false) {
437
+ return false;
438
+ }
439
+ if (typeof canTransition === 'string') {
440
+ router.push(canTransition, ti.opts.direction || 'back');
441
+ return false;
442
+ }
443
+ }
444
+ }
445
+ // Normalize empty
446
+ if (((_b = ti.insertViews) === null || _b === void 0 ? void 0 : _b.length) === 0) {
447
+ ti.insertViews = undefined;
448
+ }
449
+ // Enqueue transition instruction
450
+ this.transInstr.push(ti);
451
+ // if there isn't a transition already happening
452
+ // then this will kick off this transition
453
+ this.nextTrns();
454
+ return promise;
455
+ }
456
+ success(result, ti) {
457
+ if (this.destroyed) {
458
+ this.fireError('nav controller was destroyed', ti);
459
+ return;
460
+ }
461
+ if (ti.done) {
462
+ ti.done(result.hasCompleted, result.requiresTransition, result.enteringView, result.leavingView, result.direction);
463
+ }
464
+ ti.resolve(result.hasCompleted);
465
+ if (ti.opts.updateURL !== false && this.useRouter) {
466
+ const router = document.querySelector('ion-router');
467
+ if (router) {
468
+ const direction = result.direction === 'back' ? 'back' : 'forward';
469
+ router.navChanged(direction);
470
+ }
471
+ }
472
+ }
473
+ failed(rejectReason, ti) {
474
+ if (this.destroyed) {
475
+ this.fireError('nav controller was destroyed', ti);
476
+ return;
477
+ }
478
+ this.transInstr.length = 0;
479
+ this.fireError(rejectReason, ti);
480
+ }
481
+ fireError(rejectReason, ti) {
482
+ if (ti.done) {
483
+ ti.done(false, false, rejectReason);
484
+ }
485
+ if (ti.reject && !this.destroyed) {
486
+ ti.reject(rejectReason);
487
+ }
488
+ else {
489
+ ti.resolve(false);
490
+ }
491
+ }
492
+ /**
493
+ * Consumes the next transition in the queue.
494
+ *
495
+ * @returns whether the transition is executed.
496
+ */
497
+ nextTrns() {
498
+ // this is the framework's bread 'n butta function
499
+ // only one transition is allowed at any given time
500
+ if (this.isTransitioning) {
501
+ return false;
502
+ }
503
+ // there is no transition happening right now, executes the next instructions.
504
+ const ti = this.transInstr.shift();
505
+ if (!ti) {
506
+ return false;
507
+ }
508
+ this.runTransition(ti);
509
+ return true;
510
+ }
511
+ /** Executes all the transition instruction from the queue. */
512
+ async runTransition(ti) {
513
+ try {
514
+ // set that this nav is actively transitioning
515
+ this.ionNavWillChange.emit();
516
+ this.isTransitioning = true;
517
+ this.prepareTI(ti);
518
+ const leavingView = this.getActiveSync();
519
+ const enteringView = this.getEnteringView(ti, leavingView);
520
+ if (!leavingView && !enteringView) {
521
+ throw new Error('no views in the stack to be removed');
522
+ }
523
+ if (enteringView && enteringView.state === VIEW_STATE_NEW) {
524
+ await enteringView.init(this.el);
525
+ }
526
+ this.postViewInit(enteringView, leavingView, ti);
527
+ // Needs transition?
528
+ const requiresTransition = (ti.enteringRequiresTransition || ti.leavingRequiresTransition) && enteringView !== leavingView;
529
+ if (requiresTransition && ti.opts && leavingView) {
530
+ const isBackDirection = ti.opts.direction === 'back';
752
531
  /**
753
- * If the transition did not complete, the leavingView will still be the active
754
- * view on the stack. Otherwise unmount all the views after the enteringView.
532
+ * If heading back, use the entering page's animation
533
+ * unless otherwise specified by the developer.
755
534
  */
756
- const activeView = hasCompleted ? enteringView : leavingView;
757
- if (activeView) {
758
- this.unmountInactiveViews(activeView);
759
- }
760
- return {
761
- hasCompleted,
762
- requiresTransition: true,
763
- enteringView,
764
- leavingView,
765
- direction: opts.direction,
535
+ if (isBackDirection) {
536
+ ti.opts.animationBuilder = ti.opts.animationBuilder || (enteringView === null || enteringView === void 0 ? void 0 : enteringView.animationBuilder);
537
+ }
538
+ leavingView.animationBuilder = ti.opts.animationBuilder;
539
+ }
540
+ let result;
541
+ if (requiresTransition) {
542
+ result = await this.transition(enteringView, leavingView, ti);
543
+ }
544
+ else {
545
+ // transition is not required, so we are already done!
546
+ // they're inserting/removing the views somewhere in the middle or
547
+ // beginning, so visually nothing needs to animate/transition
548
+ // resolve immediately because there's no animation that's happening
549
+ result = {
550
+ hasCompleted: true,
551
+ requiresTransition: false,
766
552
  };
767
- }
768
- /**
769
- * Inserts a view at the specified index.
770
- *
771
- * When the view already is in the stack it will be moved to the new position.
772
- *
773
- * @param view The view to insert.
774
- * @param index The index where to insert the view.
775
- */
776
- insertViewAt(view, index) {
777
- const views = this.views;
778
- const existingIndex = views.indexOf(view);
779
- if (existingIndex > -1) {
780
- helpers.assert(view.nav === this, 'view is not part of the nav');
781
- // The view already in the stack, removes it.
782
- views.splice(existingIndex, 1);
783
- // and add it back at the requested index.
784
- views.splice(index, 0, view);
553
+ }
554
+ this.success(result, ti);
555
+ this.ionNavDidChange.emit();
556
+ }
557
+ catch (rejectReason) {
558
+ this.failed(rejectReason, ti);
559
+ }
560
+ this.isTransitioning = false;
561
+ this.nextTrns();
562
+ }
563
+ prepareTI(ti) {
564
+ var _a, _b;
565
+ var _c;
566
+ const viewsLength = this.views.length;
567
+ (_a = ti.opts) !== null && _a !== void 0 ? _a : (ti.opts = {});
568
+ (_b = (_c = ti.opts).delegate) !== null && _b !== void 0 ? _b : (_c.delegate = this.delegate);
569
+ if (ti.removeView !== undefined) {
570
+ helpers.assert(ti.removeStart !== undefined, 'removeView needs removeStart');
571
+ helpers.assert(ti.removeCount !== undefined, 'removeView needs removeCount');
572
+ const index = this.views.indexOf(ti.removeView);
573
+ if (index < 0) {
574
+ throw new Error('removeView was not found');
575
+ }
576
+ ti.removeStart += index;
577
+ }
578
+ if (ti.removeStart !== undefined) {
579
+ if (ti.removeStart < 0) {
580
+ ti.removeStart = viewsLength - 1;
581
+ }
582
+ if (ti.removeCount < 0) {
583
+ ti.removeCount = viewsLength - ti.removeStart;
584
+ }
585
+ ti.leavingRequiresTransition = ti.removeCount > 0 && ti.removeStart + ti.removeCount === viewsLength;
586
+ }
587
+ if (ti.insertViews) {
588
+ // allow -1 to be passed in to auto push it on the end
589
+ // and clean up the index if it's larger then the size of the stack
590
+ if (ti.insertStart < 0 || ti.insertStart > viewsLength) {
591
+ ti.insertStart = viewsLength;
592
+ }
593
+ ti.enteringRequiresTransition = ti.insertStart === viewsLength;
594
+ }
595
+ const insertViews = ti.insertViews;
596
+ if (!insertViews) {
597
+ return;
598
+ }
599
+ helpers.assert(insertViews.length > 0, 'length can not be zero');
600
+ const viewControllers = convertToViews(insertViews);
601
+ if (viewControllers.length === 0) {
602
+ throw new Error('invalid views to insert');
603
+ }
604
+ // Check all the inserted view are correct
605
+ for (const view of viewControllers) {
606
+ view.delegate = ti.opts.delegate;
607
+ const nav = view.nav;
608
+ if (nav && nav !== this) {
609
+ throw new Error('inserted view was already inserted');
610
+ }
611
+ if (view.state === VIEW_STATE_DESTROYED) {
612
+ throw new Error('inserted view was already destroyed');
613
+ }
614
+ }
615
+ ti.insertViews = viewControllers;
616
+ }
617
+ /**
618
+ * Returns the view that will be entered considering the transition instructions.
619
+ *
620
+ * @param ti The instructions.
621
+ * @param leavingView The view being left or undefined if none.
622
+ *
623
+ * @returns The view that will be entered, undefined if none.
624
+ */
625
+ getEnteringView(ti, leavingView) {
626
+ // The last inserted view will be entered when view are inserted.
627
+ const insertViews = ti.insertViews;
628
+ if (insertViews !== undefined) {
629
+ return insertViews[insertViews.length - 1];
630
+ }
631
+ // When views are deleted, we will enter the last view that is not removed and not the view being left.
632
+ const removeStart = ti.removeStart;
633
+ if (removeStart !== undefined) {
634
+ const views = this.views;
635
+ const removeEnd = removeStart + ti.removeCount;
636
+ for (let i = views.length - 1; i >= 0; i--) {
637
+ const view = views[i];
638
+ if ((i < removeStart || i >= removeEnd) && view !== leavingView) {
639
+ return view;
640
+ }
641
+ }
642
+ }
643
+ return undefined;
644
+ }
645
+ /**
646
+ * Adds and Removes the views from the navigation stack.
647
+ *
648
+ * @param enteringView The view being entered.
649
+ * @param leavingView The view being left.
650
+ * @param ti The instructions.
651
+ */
652
+ postViewInit(enteringView, leavingView, ti) {
653
+ var _a, _b, _c;
654
+ helpers.assert(leavingView || enteringView, 'Both leavingView and enteringView are null');
655
+ helpers.assert(ti.resolve, 'resolve must be valid');
656
+ helpers.assert(ti.reject, 'reject must be valid');
657
+ // Compute the views to remove.
658
+ const opts = ti.opts;
659
+ const { insertViews, removeStart, removeCount } = ti;
660
+ /** Records the view to destroy */
661
+ let destroyQueue;
662
+ // there are views to remove
663
+ if (removeStart !== undefined && removeCount !== undefined) {
664
+ helpers.assert(removeStart >= 0, 'removeStart can not be negative');
665
+ helpers.assert(removeCount >= 0, 'removeCount can not be negative');
666
+ destroyQueue = [];
667
+ for (let i = removeStart; i < removeStart + removeCount; i++) {
668
+ const view = this.views[i];
669
+ if (view !== undefined && view !== enteringView && view !== leavingView) {
670
+ destroyQueue.push(view);
671
+ }
672
+ }
673
+ // default the direction to "back"
674
+ (_a = opts.direction) !== null && _a !== void 0 ? _a : (opts.direction = 'back');
675
+ }
676
+ 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);
677
+ helpers.assert(finalNumViews >= 0, 'final balance can not be negative');
678
+ if (finalNumViews === 0) {
679
+ console.warn(`You can't remove all the pages in the navigation stack. nav.pop() is probably called too many times.`, this, this.el);
680
+ throw new Error('navigation stack needs at least one root page');
681
+ }
682
+ // At this point the transition can not be rejected, any throw should be an error
683
+ // Insert the new views in the stack.
684
+ if (insertViews) {
685
+ // add the views to the
686
+ let insertIndex = ti.insertStart;
687
+ for (const view of insertViews) {
688
+ this.insertViewAt(view, insertIndex);
689
+ insertIndex++;
690
+ }
691
+ if (ti.enteringRequiresTransition) {
692
+ // default to forward if not already set
693
+ (_c = opts.direction) !== null && _c !== void 0 ? _c : (opts.direction = 'forward');
694
+ }
695
+ }
696
+ // if the views to be removed are in the beginning or middle
697
+ // and there is not a view that needs to visually transition out
698
+ // then just destroy them and don't transition anything
699
+ // batch all of lifecycles together
700
+ // let's make sure, callbacks are zoned
701
+ if (destroyQueue && destroyQueue.length > 0) {
702
+ for (const view of destroyQueue) {
703
+ index$1.lifecycle(view.element, index$1.LIFECYCLE_WILL_LEAVE);
704
+ index$1.lifecycle(view.element, index$1.LIFECYCLE_DID_LEAVE);
705
+ index$1.lifecycle(view.element, index$1.LIFECYCLE_WILL_UNLOAD);
706
+ }
707
+ // once all lifecycle events has been delivered, we can safely detroy the views
708
+ for (const view of destroyQueue) {
709
+ this.destroyView(view);
710
+ }
711
+ }
712
+ }
713
+ async transition(enteringView, leavingView, ti) {
714
+ // we should animate (duration > 0) if the pushed page is not the first one (startup)
715
+ // or if it is a portal (modal, actionsheet, etc.)
716
+ const opts = ti.opts;
717
+ const progressCallback = opts.progressAnimation
718
+ ? (ani) => {
719
+ /**
720
+ * Because this progress callback is called asynchronously
721
+ * it is possible for the gesture to start and end before
722
+ * the animation is ever set. In that scenario, we should
723
+ * immediately call progressEnd so that the transition promise
724
+ * resolves and the gesture does not get locked up.
725
+ */
726
+ if (ani !== undefined && !this.gestureOrAnimationInProgress) {
727
+ this.gestureOrAnimationInProgress = true;
728
+ ani.onFinish(() => {
729
+ this.gestureOrAnimationInProgress = false;
730
+ }, { oneTimeCallback: true });
731
+ /**
732
+ * Playing animation to beginning
733
+ * with a duration of 0 prevents
734
+ * any flickering when the animation
735
+ * is later cleaned up.
736
+ */
737
+ ani.progressEnd(0, 0, 0);
785
738
  }
786
739
  else {
787
- helpers.assert(!view.nav, 'nav is used');
788
- // this is a new view to add to the stack
789
- // create the new entering view
790
- view.nav = this;
791
- views.splice(index, 0, view);
792
- }
793
- }
794
- /**
795
- * Removes a view from the stack.
796
- *
797
- * @param view The view to remove.
798
- */
799
- removeView(view) {
800
- helpers.assert(view.state === VIEW_STATE_ATTACHED || view.state === VIEW_STATE_DESTROYED, 'view state should be loaded or destroyed');
801
- const views = this.views;
802
- const index = views.indexOf(view);
803
- helpers.assert(index > -1, 'view must be part of the stack');
804
- if (index >= 0) {
805
- views.splice(index, 1);
806
- }
807
- }
808
- destroyView(view) {
809
- view._destroy();
810
- this.removeView(view);
811
- }
740
+ this.sbAni = ani;
741
+ }
742
+ }
743
+ : undefined;
744
+ const mode = ionicGlobal.getIonMode(this);
745
+ const enteringEl = enteringView.element;
746
+ // eslint-disable-next-line @typescript-eslint/prefer-optional-chain
747
+ const leavingEl = leavingView && leavingView.element;
748
+ const animationOpts = Object.assign(Object.assign({ mode, showGoBack: this.canGoBackSync(enteringView), baseEl: this.el, progressCallback, animated: this.animated && ionicGlobal.config.getBoolean('animated', true), enteringEl,
749
+ leavingEl }, opts), { animationBuilder: opts.animationBuilder || this.animation || ionicGlobal.config.get('navAnimation') });
750
+ const { hasCompleted } = await index$1.transition(animationOpts);
751
+ return this.transitionFinish(hasCompleted, enteringView, leavingView, opts);
752
+ }
753
+ transitionFinish(hasCompleted, enteringView, leavingView, opts) {
812
754
  /**
813
- * Unmounts all inactive views after the specified active view.
814
- *
815
- * DOM WRITE
816
- *
817
- * @param activeView The view that is actively visible in the stack. Used to calculate which views to unmount.
755
+ * If the transition did not complete, the leavingView will still be the active
756
+ * view on the stack. Otherwise unmount all the views after the enteringView.
818
757
  */
819
- unmountInactiveViews(activeView) {
820
- // ok, cleanup time!! Destroy all of the views that are
821
- // INACTIVE and come after the active view
822
- // only do this if the views exist, though
823
- if (this.destroyed) {
824
- return;
825
- }
826
- const views = this.views;
827
- const activeViewIndex = views.indexOf(activeView);
828
- for (let i = views.length - 1; i >= 0; i--) {
829
- const view = views[i];
830
- /**
831
- * When inserting multiple views via insertPages
832
- * the last page will be transitioned to, but the
833
- * others will not be. As a result, a DOM element
834
- * will only be created for the last page inserted.
835
- * As a result, it is possible to have views in the
836
- * stack that do not have `view.element` yet.
837
- */
838
- const element = view.element;
839
- if (element) {
840
- if (i > activeViewIndex) {
841
- // this view comes after the active view
842
- // let's unload it
843
- index$1.lifecycle(element, index$1.LIFECYCLE_WILL_UNLOAD);
844
- this.destroyView(view);
845
- }
846
- else if (i < activeViewIndex) {
847
- // this view comes before the active view
848
- // and it is not a portal then ensure it is hidden
849
- index$1.setPageHidden(element, true);
850
- }
851
- }
852
- }
853
- }
854
- canStart() {
855
- return (!this.gestureOrAnimationInProgress &&
856
- !!this.swipeGesture &&
857
- !this.isTransitioning &&
858
- this.transInstr.length === 0 &&
859
- this.canGoBackSync());
860
- }
861
- onStart() {
862
- this.gestureOrAnimationInProgress = true;
863
- this.pop({ direction: 'back', progressAnimation: true });
864
- }
865
- onMove(stepValue) {
866
- if (this.sbAni) {
867
- this.sbAni.progressStep(stepValue);
868
- }
869
- }
870
- onEnd(shouldComplete, stepValue, dur) {
871
- if (this.sbAni) {
872
- this.sbAni.onFinish(() => {
873
- this.gestureOrAnimationInProgress = false;
874
- }, { oneTimeCallback: true });
875
- // Account for rounding errors in JS
876
- let newStepValue = shouldComplete ? -1e-3 : 0.001;
877
- /**
878
- * Animation will be reversed here, so need to
879
- * reverse the easing curve as well
880
- *
881
- * Additionally, we need to account for the time relative
882
- * to the new easing curve, as `stepValue` is going to be given
883
- * in terms of a linear curve.
884
- */
885
- if (!shouldComplete) {
886
- this.sbAni.easing('cubic-bezier(1, 0, 0.68, 0.28)');
887
- newStepValue += cubicBezier.getTimeGivenProgression([0, 0], [1, 0], [0.68, 0.28], [1, 1], stepValue)[0];
888
- }
889
- else {
890
- newStepValue += cubicBezier.getTimeGivenProgression([0, 0], [0.32, 0.72], [0, 1], [1, 1], stepValue)[0];
891
- }
892
- this.sbAni.progressEnd(shouldComplete ? 1 : 0, newStepValue, dur);
893
- }
894
- else {
895
- this.gestureOrAnimationInProgress = false;
896
- }
897
- }
898
- render() {
899
- return index.h("slot", { key: '6894eccc60e446294b01261477691ea1e88348ab' });
900
- }
901
- get el() { return index.getElement(this); }
902
- static get watchers() { return {
903
- "swipeGesture": [{
904
- "swipeGestureChanged": 0
905
- }],
906
- "root": [{
907
- "rootChanged": 0
908
- }]
909
- }; }
758
+ const activeView = hasCompleted ? enteringView : leavingView;
759
+ if (activeView) {
760
+ this.unmountInactiveViews(activeView);
761
+ }
762
+ return {
763
+ hasCompleted,
764
+ requiresTransition: true,
765
+ enteringView,
766
+ leavingView,
767
+ direction: opts.direction,
768
+ };
769
+ }
770
+ /**
771
+ * Inserts a view at the specified index.
772
+ *
773
+ * When the view already is in the stack it will be moved to the new position.
774
+ *
775
+ * @param view The view to insert.
776
+ * @param index The index where to insert the view.
777
+ */
778
+ insertViewAt(view, index) {
779
+ const views = this.views;
780
+ const existingIndex = views.indexOf(view);
781
+ if (existingIndex > -1) {
782
+ helpers.assert(view.nav === this, 'view is not part of the nav');
783
+ // The view already in the stack, removes it.
784
+ views.splice(existingIndex, 1);
785
+ // and add it back at the requested index.
786
+ views.splice(index, 0, view);
787
+ }
788
+ else {
789
+ helpers.assert(!view.nav, 'nav is used');
790
+ // this is a new view to add to the stack
791
+ // create the new entering view
792
+ view.nav = this;
793
+ views.splice(index, 0, view);
794
+ }
795
+ }
796
+ /**
797
+ * Removes a view from the stack.
798
+ *
799
+ * @param view The view to remove.
800
+ */
801
+ removeView(view) {
802
+ helpers.assert(view.state === VIEW_STATE_ATTACHED || view.state === VIEW_STATE_DESTROYED, 'view state should be loaded or destroyed');
803
+ const views = this.views;
804
+ const index = views.indexOf(view);
805
+ helpers.assert(index > -1, 'view must be part of the stack');
806
+ if (index >= 0) {
807
+ views.splice(index, 1);
808
+ }
809
+ }
810
+ destroyView(view) {
811
+ view._destroy();
812
+ this.removeView(view);
813
+ }
814
+ /**
815
+ * Unmounts all inactive views after the specified active view.
816
+ *
817
+ * DOM WRITE
818
+ *
819
+ * @param activeView The view that is actively visible in the stack. Used to calculate which views to unmount.
820
+ */
821
+ unmountInactiveViews(activeView) {
822
+ // ok, cleanup time!! Destroy all of the views that are
823
+ // INACTIVE and come after the active view
824
+ // only do this if the views exist, though
825
+ if (this.destroyed) {
826
+ return;
827
+ }
828
+ const views = this.views;
829
+ const activeViewIndex = views.indexOf(activeView);
830
+ for (let i = views.length - 1; i >= 0; i--) {
831
+ const view = views[i];
832
+ /**
833
+ * When inserting multiple views via insertPages
834
+ * the last page will be transitioned to, but the
835
+ * others will not be. As a result, a DOM element
836
+ * will only be created for the last page inserted.
837
+ * As a result, it is possible to have views in the
838
+ * stack that do not have `view.element` yet.
839
+ */
840
+ const element = view.element;
841
+ if (element) {
842
+ if (i > activeViewIndex) {
843
+ // this view comes after the active view
844
+ // let's unload it
845
+ index$1.lifecycle(element, index$1.LIFECYCLE_WILL_UNLOAD);
846
+ this.destroyView(view);
847
+ }
848
+ else if (i < activeViewIndex) {
849
+ // this view comes before the active view
850
+ // and it is not a portal then ensure it is hidden
851
+ index$1.setPageHidden(element, true);
852
+ }
853
+ }
854
+ }
855
+ }
856
+ canStart() {
857
+ return (!this.gestureOrAnimationInProgress &&
858
+ !!this.swipeGesture &&
859
+ !this.isTransitioning &&
860
+ this.transInstr.length === 0 &&
861
+ this.canGoBackSync());
862
+ }
863
+ onStart() {
864
+ this.gestureOrAnimationInProgress = true;
865
+ this.pop({ direction: 'back', progressAnimation: true });
866
+ }
867
+ onMove(stepValue) {
868
+ if (this.sbAni) {
869
+ this.sbAni.progressStep(stepValue);
870
+ }
871
+ }
872
+ onEnd(shouldComplete, stepValue, dur) {
873
+ if (this.sbAni) {
874
+ this.sbAni.onFinish(() => {
875
+ this.gestureOrAnimationInProgress = false;
876
+ }, { oneTimeCallback: true });
877
+ // Account for rounding errors in JS
878
+ let newStepValue = shouldComplete ? -0.001 : 0.001;
879
+ /**
880
+ * Animation will be reversed here, so need to
881
+ * reverse the easing curve as well
882
+ *
883
+ * Additionally, we need to account for the time relative
884
+ * to the new easing curve, as `stepValue` is going to be given
885
+ * in terms of a linear curve.
886
+ */
887
+ if (!shouldComplete) {
888
+ this.sbAni.easing('cubic-bezier(1, 0, 0.68, 0.28)');
889
+ newStepValue += cubicBezier.getTimeGivenProgression([0, 0], [1, 0], [0.68, 0.28], [1, 1], stepValue)[0];
890
+ }
891
+ else {
892
+ newStepValue += cubicBezier.getTimeGivenProgression([0, 0], [0.32, 0.72], [0, 1], [1, 1], stepValue)[0];
893
+ }
894
+ this.sbAni.progressEnd(shouldComplete ? 1 : 0, newStepValue, dur);
895
+ }
896
+ else {
897
+ this.gestureOrAnimationInProgress = false;
898
+ }
899
+ }
900
+ render() {
901
+ return index.h("slot", { key: '6894eccc60e446294b01261477691ea1e88348ab' });
902
+ }
903
+ get el() { return index.getElement(this); }
904
+ static get watchers() { return {
905
+ "swipeGesture": ["swipeGestureChanged"],
906
+ "root": ["rootChanged"]
907
+ }; }
910
908
  };
911
- Nav.style = navCss();
909
+ Nav.style = navCss;
912
910
 
913
911
  exports.ion_nav = Nav;