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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (520) hide show
  1. package/components/action-sheet.js +1 -561
  2. package/components/alert.js +1 -610
  3. package/components/animation.js +1 -817
  4. package/components/backdrop.js +1 -72
  5. package/components/button-active.js +1 -64
  6. package/components/button.js +1 -303
  7. package/components/buttons.js +1 -56
  8. package/components/capacitor.js +1 -10
  9. package/components/checkbox.js +1 -261
  10. package/components/config.js +1 -192
  11. package/components/content.js +1 -475
  12. package/components/cubic-bezier.js +1 -87
  13. package/components/data.js +1 -1635
  14. package/components/dir.js +1 -15
  15. package/components/focus-visible.js +1 -72
  16. package/components/framework-delegate.js +1 -137
  17. package/components/gesture-controller.js +1 -192
  18. package/components/haptic.js +1 -155
  19. package/components/hardware-back-button.js +1 -112
  20. package/components/header.js +1 -417
  21. package/components/helpers.js +1 -336
  22. package/components/icon.js +1 -456
  23. package/components/index.d.ts +2 -0
  24. package/components/index.js +1 -115
  25. package/components/index2.js +1 -416
  26. package/components/index3.js +1 -452
  27. package/components/index4.js +1 -118
  28. package/components/index5.js +1 -303
  29. package/components/index6.js +1 -29
  30. package/components/index7.js +1 -164
  31. package/components/index8.js +1 -125
  32. package/components/index9.js +1 -4
  33. package/components/input-shims.js +1 -624
  34. package/components/input.utils.js +1 -144
  35. package/components/ion-accordion-group.js +1 -269
  36. package/components/ion-accordion.js +1 -457
  37. package/components/ion-action-sheet.js +1 -6
  38. package/components/ion-alert.js +1 -6
  39. package/components/ion-app.js +1 -128
  40. package/components/ion-avatar.js +1 -41
  41. package/components/ion-back-button.js +1 -131
  42. package/components/ion-backdrop.js +1 -6
  43. package/components/ion-badge.js +1 -47
  44. package/components/ion-breadcrumb.js +1 -137
  45. package/components/ion-breadcrumbs.js +1 -164
  46. package/components/ion-button.js +1 -6
  47. package/components/ion-buttons.js +1 -6
  48. package/components/ion-card-content.js +1 -45
  49. package/components/ion-card-header.js +1 -56
  50. package/components/ion-card-subtitle.js +1 -48
  51. package/components/ion-card-title.js +1 -48
  52. package/components/ion-card.js +1 -107
  53. package/components/ion-checkbox.js +1 -6
  54. package/components/ion-chip.js +1 -66
  55. package/components/ion-col.js +1 -163
  56. package/components/ion-content.js +1 -6
  57. package/components/ion-datetime-button.js +1 -384
  58. package/components/ion-datetime.js +1 -2046
  59. package/components/ion-fab-button.js +1 -151
  60. package/components/ion-fab-list.js +1 -66
  61. package/components/ion-fab.js +1 -101
  62. package/components/ion-footer.js +1 -159
  63. package/components/ion-grid.js +1 -46
  64. package/components/ion-header.js +1 -6
  65. package/components/ion-icon.js +1 -6
  66. package/components/ion-img.js +1 -124
  67. package/components/ion-infinite-scroll-content.js +1 -70
  68. package/components/ion-infinite-scroll.js +1 -236
  69. package/components/ion-input-otp.js +1 -683
  70. package/components/ion-input-password-toggle.js +1 -129
  71. package/components/ion-input.js +1 -617
  72. package/components/ion-item-divider.js +1 -59
  73. package/components/ion-item-group.js +1 -46
  74. package/components/ion-item-option.js +1 -91
  75. package/components/ion-item-options.js +1 -73
  76. package/components/ion-item-sliding.js +1 -458
  77. package/components/ion-item.js +1 -6
  78. package/components/ion-label.js +1 -6
  79. package/components/ion-list-header.js +1 -6
  80. package/components/ion-list.js +1 -6
  81. package/components/ion-loading.js +1 -344
  82. package/components/ion-menu-button.js +1 -110
  83. package/components/ion-menu-toggle.js +1 -64
  84. package/components/ion-menu.js +1 -745
  85. package/components/ion-modal.js +1 -6
  86. package/components/ion-nav-link.js +1 -64
  87. package/components/ion-nav.js +1 -956
  88. package/components/ion-note.js +1 -47
  89. package/components/ion-picker-column-option.js +1 -6
  90. package/components/ion-picker-column.js +1 -6
  91. package/components/ion-picker-legacy-column.js +1 -6
  92. package/components/ion-picker-legacy.js +1 -343
  93. package/components/ion-picker.js +1 -6
  94. package/components/ion-popover.js +1 -6
  95. package/components/ion-progress-bar.js +1 -101
  96. package/components/ion-radio-group.js +1 -6
  97. package/components/ion-radio.js +1 -6
  98. package/components/ion-range.js +1 -853
  99. package/components/ion-refresher-content.js +1 -89
  100. package/components/ion-refresher.js +1 -751
  101. package/components/ion-reorder-group.js +1 -322
  102. package/components/ion-reorder.js +1 -60
  103. package/components/ion-ripple-effect.js +1 -6
  104. package/components/ion-route-redirect.js +1 -45
  105. package/components/ion-route.js +1 -74
  106. package/components/ion-router-link.js +1 -61
  107. package/components/ion-router-outlet.js +1 -227
  108. package/components/ion-router.js +1 -841
  109. package/components/ion-row.js +1 -36
  110. package/components/ion-searchbar.js +1 -530
  111. package/components/ion-segment-button.js +1 -174
  112. package/components/ion-segment-content.js +1 -35
  113. package/components/ion-segment-view.js +1 -148
  114. package/components/ion-segment.js +1 -602
  115. package/components/ion-select-modal.js +1 -6
  116. package/components/ion-select-option.js +1 -46
  117. package/components/ion-select-popover.js +1 -6
  118. package/components/ion-select.js +1 -1037
  119. package/components/ion-skeleton-text.js +1 -65
  120. package/components/ion-spinner.js +1 -6
  121. package/components/ion-split-pane.js +1 -197
  122. package/components/ion-tab-bar.js +1 -115
  123. package/components/ion-tab-button.js +1 -128
  124. package/components/ion-tab.js +1 -91
  125. package/components/ion-tabs.js +1 -205
  126. package/components/ion-text.js +1 -42
  127. package/components/ion-textarea.js +1 -554
  128. package/components/ion-thumbnail.js +1 -36
  129. package/components/ion-title.js +1 -6
  130. package/components/ion-toast.js +1 -941
  131. package/components/ion-toggle.js +1 -361
  132. package/components/ion-toolbar.js +1 -6
  133. package/components/ionic-global.js +1 -144
  134. package/components/ios.transition.js +1 -672
  135. package/components/item.js +1 -302
  136. package/components/keyboard-controller.js +1 -162
  137. package/components/keyboard.js +1 -141
  138. package/components/keyboard2.js +1 -76
  139. package/components/label.js +1 -100
  140. package/components/list-header.js +1 -47
  141. package/components/list.js +1 -68
  142. package/components/lock-controller.js +1 -35
  143. package/components/md.transition.js +1 -51
  144. package/components/menu-toggle-util.js +1 -9
  145. package/components/modal.js +1 -2674
  146. package/components/notch-controller.js +1 -150
  147. package/components/overlays.js +1 -912
  148. package/components/picker-column-option.js +1 -136
  149. package/components/picker-column.js +1 -595
  150. package/components/picker-column2.js +1 -377
  151. package/components/picker.js +1 -498
  152. package/components/popover.js +1 -1502
  153. package/components/radio-group.js +1 -287
  154. package/components/radio.js +1 -229
  155. package/components/refresher.utils.js +1 -193
  156. package/components/ripple-effect.js +1 -109
  157. package/components/select-modal.js +1 -196
  158. package/components/select-popover.js +1 -189
  159. package/components/spinner.js +1 -224
  160. package/components/status-tap.js +1 -36
  161. package/components/swipe-back.js +1 -75
  162. package/components/theme.js +1 -40
  163. package/components/title.js +1 -70
  164. package/components/toolbar.js +1 -89
  165. package/components/validity.js +1 -14
  166. package/components/watch-options.js +1 -44
  167. package/dist/cjs/{animation-Bt3H9L1C.js → animation-Dg4yiuR2.js} +1 -1
  168. package/dist/cjs/app-globals-CLI8xCmk.js +11 -0
  169. package/dist/cjs/{button-active-CMc8cD90.js → button-active-FscMI17-.js} +1 -1
  170. package/dist/cjs/{config-C5fsO43a.js → config-BukYi_pW.js} +1 -1
  171. package/dist/cjs/{data-JwZKaIQB.js → data-BYlBjkMU.js} +1 -1
  172. package/dist/cjs/{framework-delegate-DMJRBuDi.js → framework-delegate-CRgp8o_p.js} +1 -1
  173. package/dist/cjs/{hardware-back-button-VCK4V3mG.js → hardware-back-button-C4rMJ5uI.js} +1 -1
  174. package/dist/cjs/{helpers-DrTqNghc.js → helpers-CxTYJdbT.js} +1 -1
  175. package/dist/cjs/{index-094mMFB-.js → index-C845Ti6K.js} +4 -4
  176. package/dist/cjs/{index-DrMUZJj6.js → index-CFUwM5x_.js} +5 -5
  177. package/dist/cjs/{index-D6Wc6v08.js → index-CqT-2gKy.js} +503 -382
  178. package/dist/cjs/{index-CO6eryBo.js → index-MbaBbWXk.js} +2 -2
  179. package/dist/cjs/{index-C534ULug.js → index-YcSftOMz.js} +2 -2
  180. package/dist/cjs/index.cjs.js +12 -12
  181. package/dist/cjs/{input-shims-CW0KUFTQ.js → input-shims-DlFhYYTs.js} +3 -3
  182. package/dist/cjs/{input.utils-B_QROI2g.js → input.utils-DmeJ8dmo.js} +2 -2
  183. package/dist/cjs/ion-accordion_2.cjs.entry.js +23 -15
  184. package/dist/cjs/ion-action-sheet.cjs.entry.js +21 -15
  185. package/dist/cjs/ion-alert.cjs.entry.js +25 -17
  186. package/dist/cjs/ion-app_8.cjs.entry.js +44 -40
  187. package/dist/cjs/ion-avatar_3.cjs.entry.js +12 -12
  188. package/dist/cjs/ion-back-button.cjs.entry.js +7 -7
  189. package/dist/cjs/ion-backdrop.cjs.entry.js +6 -6
  190. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +20 -14
  191. package/dist/cjs/ion-button_2.cjs.entry.js +36 -18
  192. package/dist/cjs/ion-card_5.cjs.entry.js +23 -23
  193. package/dist/cjs/ion-checkbox.cjs.entry.js +7 -7
  194. package/dist/cjs/ion-chip.cjs.entry.js +6 -6
  195. package/dist/cjs/ion-col_3.cjs.entry.js +8 -8
  196. package/dist/cjs/ion-datetime-button.cjs.entry.js +8 -8
  197. package/dist/cjs/ion-datetime_3.cjs.entry.js +67 -39
  198. package/dist/cjs/ion-fab_3.cjs.entry.js +17 -13
  199. package/dist/cjs/ion-img.cjs.entry.js +8 -6
  200. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +17 -13
  201. package/dist/cjs/ion-input-otp.cjs.entry.js +16 -10
  202. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +9 -7
  203. package/dist/cjs/ion-input.cjs.entry.js +21 -13
  204. package/dist/cjs/ion-item-option_3.cjs.entry.js +17 -15
  205. package/dist/cjs/ion-item_8.cjs.entry.js +42 -36
  206. package/dist/cjs/ion-loading.cjs.entry.js +18 -14
  207. package/dist/cjs/ion-menu_3.cjs.entry.js +30 -22
  208. package/dist/cjs/ion-modal.cjs.entry.js +55 -40
  209. package/dist/cjs/ion-nav_2.cjs.entry.js +14 -10
  210. package/dist/cjs/ion-picker-column-option.cjs.entry.js +10 -8
  211. package/dist/cjs/ion-picker-column.cjs.entry.js +11 -7
  212. package/dist/cjs/ion-picker.cjs.entry.js +6 -6
  213. package/dist/cjs/ion-popover.cjs.entry.js +21 -15
  214. package/dist/cjs/ion-progress-bar.cjs.entry.js +7 -7
  215. package/dist/cjs/ion-radio_2.cjs.entry.js +17 -13
  216. package/dist/cjs/ion-range.cjs.entry.js +29 -15
  217. package/dist/cjs/ion-refresher_2.cjs.entry.js +45 -14
  218. package/dist/cjs/ion-reorder_2.cjs.entry.js +13 -11
  219. package/dist/cjs/ion-ripple-effect.cjs.entry.js +4 -4
  220. package/dist/cjs/ion-route_4.cjs.entry.js +20 -10
  221. package/dist/cjs/ion-searchbar.cjs.entry.js +22 -12
  222. package/dist/cjs/ion-segment-content.cjs.entry.js +3 -3
  223. package/dist/cjs/ion-segment-view.cjs.entry.js +5 -5
  224. package/dist/cjs/ion-segment_2.cjs.entry.js +26 -16
  225. package/dist/cjs/ion-select-modal.cjs.entry.js +12 -12
  226. package/dist/cjs/ion-select_3.cjs.entry.js +29 -21
  227. package/dist/cjs/ion-spinner.cjs.entry.js +4 -4
  228. package/dist/cjs/ion-split-pane.cjs.entry.js +15 -9
  229. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +14 -12
  230. package/dist/cjs/ion-tab_2.cjs.entry.js +10 -8
  231. package/dist/cjs/ion-text.cjs.entry.js +4 -4
  232. package/dist/cjs/ion-textarea.cjs.entry.js +18 -12
  233. package/dist/cjs/ion-toast.cjs.entry.js +21 -15
  234. package/dist/cjs/ion-toggle.cjs.entry.js +10 -8
  235. package/dist/cjs/{ionic-global-HMVqOFGO.js → ionic-global-Bc3kJi1Z.js} +1 -1
  236. package/dist/cjs/ionic.cjs.js +5 -5
  237. package/dist/cjs/{ios.transition-BOt_uW73.js → ios.transition-trBiC95R.js} +4 -4
  238. package/dist/cjs/loader.cjs.js +4 -4
  239. package/dist/cjs/{md.transition-Dt968VXB.js → md.transition-CUQECuvD.js} +4 -4
  240. package/dist/cjs/{notch-controller-Bzqhjm4f.js → notch-controller-sD-lTpdc.js} +1 -1
  241. package/dist/cjs/{overlays-B2b-TTbl.js → overlays-C2jiBSNQ.js} +5 -5
  242. package/dist/cjs/{status-tap-g0sWWkXk.js → status-tap-CCJk5VgT.js} +3 -3
  243. package/dist/cjs/{swipe-back-BIayeNOD.js → swipe-back-BGhTQ1CU.js} +2 -2
  244. package/dist/collection/collection-manifest.json +2 -2
  245. package/dist/collection/components/accordion-group/accordion-group.js +4 -2
  246. package/dist/collection/components/action-sheet/action-sheet.js +20 -10
  247. package/dist/collection/components/alert/alert.js +24 -12
  248. package/dist/collection/components/back-button/back-button.js +4 -2
  249. package/dist/collection/components/badge/badge.js +2 -1
  250. package/dist/collection/components/breadcrumb/breadcrumb.js +8 -4
  251. package/dist/collection/components/breadcrumbs/breadcrumbs.js +4 -2
  252. package/dist/collection/components/button/button.js +6 -3
  253. package/dist/collection/components/card/card.js +6 -3
  254. package/dist/collection/components/card-header/card-header.js +2 -1
  255. package/dist/collection/components/card-subtitle/card-subtitle.js +2 -1
  256. package/dist/collection/components/card-title/card-title.js +2 -1
  257. package/dist/collection/components/checkbox/checkbox.js +4 -2
  258. package/dist/collection/components/chip/chip.js +2 -1
  259. package/dist/collection/components/content/content.js +8 -4
  260. package/dist/collection/components/datetime/datetime.js +34 -15
  261. package/dist/collection/components/datetime-button/datetime-button.js +2 -1
  262. package/dist/collection/components/fab-button/fab-button.js +6 -3
  263. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +4 -2
  264. package/dist/collection/components/input/input.js +11 -6
  265. package/dist/collection/components/input-otp/input-otp.js +8 -4
  266. package/dist/collection/components/input-password-toggle/input-password-toggle.js +4 -2
  267. package/dist/collection/components/item/item.js +6 -3
  268. package/dist/collection/components/item-divider/item-divider.js +2 -1
  269. package/dist/collection/components/item-option/item-option.js +2 -1
  270. package/dist/collection/components/item-options/item-options.js +2 -1
  271. package/dist/collection/components/item-sliding/item-sliding.js +2 -1
  272. package/dist/collection/components/label/label.js +6 -3
  273. package/dist/collection/components/list-header/list-header.js +2 -1
  274. package/dist/collection/components/loading/loading.js +22 -11
  275. package/dist/collection/components/menu/menu.js +10 -5
  276. package/dist/collection/components/menu-button/menu-button.js +2 -1
  277. package/dist/collection/components/modal/gestures/sheet.js +32 -21
  278. package/dist/collection/components/modal/modal.js +35 -20
  279. package/dist/collection/components/nav/nav.js +89 -45
  280. package/dist/collection/components/nav-link/nav-link.js +9 -5
  281. package/dist/collection/components/note/note.js +2 -1
  282. package/dist/collection/components/picker/picker.js +2 -1
  283. package/dist/collection/components/picker-column/picker-column.js +6 -3
  284. package/dist/collection/components/picker-column-option/picker-column-option.js +2 -1
  285. package/dist/collection/components/picker-legacy/picker.js +24 -12
  286. package/dist/collection/components/picker-legacy-column/picker-column.js +4 -2
  287. package/dist/collection/components/popover/popover.js +33 -17
  288. package/dist/collection/components/progress-bar/progress-bar.js +2 -1
  289. package/dist/collection/components/radio/radio.js +2 -1
  290. package/dist/collection/components/radio-group/radio-group.js +6 -3
  291. package/dist/collection/components/range/range.js +14 -7
  292. package/dist/collection/components/refresher/refresher.js +73 -5
  293. package/dist/collection/components/refresher-content/refresher-content.js +8 -4
  294. package/dist/collection/components/reorder-group/reorder-group.js +6 -3
  295. package/dist/collection/components/route/route.js +4 -2
  296. package/dist/collection/components/router/router.js +10 -5
  297. package/dist/collection/components/router-link/router-link.js +6 -3
  298. package/dist/collection/components/router-outlet/router-outlet.js +18 -9
  299. package/dist/collection/components/searchbar/searchbar.js +11 -6
  300. package/dist/collection/components/segment/segment.js +10 -5
  301. package/dist/collection/components/segment-button/segment-button.js +4 -2
  302. package/dist/collection/components/segment-view/segment-view.js +2 -1
  303. package/dist/collection/components/select/select.js +10 -5
  304. package/dist/collection/components/select-modal/select-modal.js +2 -1
  305. package/dist/collection/components/select-popover/select-popover.js +2 -1
  306. package/dist/collection/components/skeleton-text/skeleton-text.js +2 -1
  307. package/dist/collection/components/spinner/spinner.js +4 -2
  308. package/dist/collection/components/tab/tab.js +4 -2
  309. package/dist/collection/components/tab-bar/tab-bar.js +4 -2
  310. package/dist/collection/components/tab-button/tab-button.js +4 -2
  311. package/dist/collection/components/tabs/tabs.js +4 -2
  312. package/dist/collection/components/text/text.js +2 -1
  313. package/dist/collection/components/textarea/textarea.js +6 -3
  314. package/dist/collection/components/title/title.js +4 -2
  315. package/dist/collection/components/toast/toast.js +34 -17
  316. package/dist/collection/components/toggle/toggle.js +4 -2
  317. package/dist/collection/components/toolbar/toolbar.js +2 -1
  318. package/dist/docs.d.ts +37 -0
  319. package/dist/docs.json +835 -381
  320. package/dist/esm/{animation-Dt8bGnA-.js → animation-CnGMT4ji.js} +1 -1
  321. package/dist/esm/app-globals-DhZjtldk.js +9 -0
  322. package/dist/esm/{button-active-L570Swow.js → button-active-BBx21brx.js} +1 -1
  323. package/dist/esm/{config-mCdtaoPe.js → config-TO1rZH52.js} +1 -1
  324. package/dist/esm/{data-DCORV9FH.js → data-B9iGR5YO.js} +1 -1
  325. package/dist/esm/{framework-delegate-BYawdMXj.js → framework-delegate-CyxE1S_P.js} +1 -1
  326. package/dist/esm/{hardware-back-button-CPLxO-Ev.js → hardware-back-button-CTe4XmL7.js} +1 -1
  327. package/dist/esm/{helpers-DEn3pfjm.js → helpers-Tl8jw6S2.js} +1 -1
  328. package/dist/esm/{index-r2D9DEro.js → index-B-hkiOUh.js} +4 -4
  329. package/dist/esm/{index-CvDIirVx.js → index-B2KwgBLx.js} +5 -5
  330. package/dist/esm/{index-ceb5RaMT.js → index-BtUdxPjv.js} +2 -2
  331. package/dist/esm/{index-C8IsBmNU.js → index-IGIE5vDm.js} +503 -382
  332. package/dist/esm/{index-Bs3kT4bc.js → index-hW6eNZ3o.js} +2 -2
  333. package/dist/esm/index.js +12 -12
  334. package/dist/esm/{input-shims-DyOpfTg6.js → input-shims-C1hAaHcP.js} +3 -3
  335. package/dist/esm/{input.utils-DrvTa8gz.js → input.utils-Bxa_DQ7-.js} +2 -2
  336. package/dist/esm/ion-accordion_2.entry.js +23 -15
  337. package/dist/esm/ion-action-sheet.entry.js +21 -15
  338. package/dist/esm/ion-alert.entry.js +25 -17
  339. package/dist/esm/ion-app_8.entry.js +44 -40
  340. package/dist/esm/ion-avatar_3.entry.js +12 -12
  341. package/dist/esm/ion-back-button.entry.js +7 -7
  342. package/dist/esm/ion-backdrop.entry.js +6 -6
  343. package/dist/esm/ion-breadcrumb_2.entry.js +20 -14
  344. package/dist/esm/ion-button_2.entry.js +36 -18
  345. package/dist/esm/ion-card_5.entry.js +23 -23
  346. package/dist/esm/ion-checkbox.entry.js +7 -7
  347. package/dist/esm/ion-chip.entry.js +6 -6
  348. package/dist/esm/ion-col_3.entry.js +8 -8
  349. package/dist/esm/ion-datetime-button.entry.js +8 -8
  350. package/dist/esm/ion-datetime_3.entry.js +67 -39
  351. package/dist/esm/ion-fab_3.entry.js +17 -13
  352. package/dist/esm/ion-img.entry.js +8 -6
  353. package/dist/esm/ion-infinite-scroll_2.entry.js +17 -13
  354. package/dist/esm/ion-input-otp.entry.js +16 -10
  355. package/dist/esm/ion-input-password-toggle.entry.js +9 -7
  356. package/dist/esm/ion-input.entry.js +21 -13
  357. package/dist/esm/ion-item-option_3.entry.js +17 -15
  358. package/dist/esm/ion-item_8.entry.js +42 -36
  359. package/dist/esm/ion-loading.entry.js +18 -14
  360. package/dist/esm/ion-menu_3.entry.js +30 -22
  361. package/dist/esm/ion-modal.entry.js +55 -40
  362. package/dist/esm/ion-nav_2.entry.js +14 -10
  363. package/dist/esm/ion-picker-column-option.entry.js +10 -8
  364. package/dist/esm/ion-picker-column.entry.js +11 -7
  365. package/dist/esm/ion-picker.entry.js +6 -6
  366. package/dist/esm/ion-popover.entry.js +21 -15
  367. package/dist/esm/ion-progress-bar.entry.js +7 -7
  368. package/dist/esm/ion-radio_2.entry.js +17 -13
  369. package/dist/esm/ion-range.entry.js +29 -15
  370. package/dist/esm/ion-refresher_2.entry.js +45 -14
  371. package/dist/esm/ion-reorder_2.entry.js +13 -11
  372. package/dist/esm/ion-ripple-effect.entry.js +4 -4
  373. package/dist/esm/ion-route_4.entry.js +20 -10
  374. package/dist/esm/ion-searchbar.entry.js +22 -12
  375. package/dist/esm/ion-segment-content.entry.js +3 -3
  376. package/dist/esm/ion-segment-view.entry.js +5 -5
  377. package/dist/esm/ion-segment_2.entry.js +26 -16
  378. package/dist/esm/ion-select-modal.entry.js +12 -12
  379. package/dist/esm/ion-select_3.entry.js +29 -21
  380. package/dist/esm/ion-spinner.entry.js +4 -4
  381. package/dist/esm/ion-split-pane.entry.js +15 -9
  382. package/dist/esm/ion-tab-bar_2.entry.js +14 -12
  383. package/dist/esm/ion-tab_2.entry.js +10 -8
  384. package/dist/esm/ion-text.entry.js +4 -4
  385. package/dist/esm/ion-textarea.entry.js +18 -12
  386. package/dist/esm/ion-toast.entry.js +21 -15
  387. package/dist/esm/ion-toggle.entry.js +10 -8
  388. package/dist/esm/{ionic-global-CDrldh-5.js → ionic-global-DfbeLwcV.js} +1 -1
  389. package/dist/esm/ionic.js +6 -6
  390. package/dist/esm/{ios.transition-BDzw0_Hm.js → ios.transition--aMF-pDH.js} +4 -4
  391. package/dist/esm/loader.js +5 -5
  392. package/dist/esm/{md.transition-BzDYi3qq.js → md.transition-BEVbfm8j.js} +4 -4
  393. package/dist/esm/{notch-controller-BwelN_JM.js → notch-controller-DAcvKU57.js} +1 -1
  394. package/dist/esm/{overlays-D5YkFThA.js → overlays-F8GHPo-e.js} +5 -5
  395. package/dist/esm/{status-tap-5DQ7Fc4V.js → status-tap-BfJqFSLF.js} +3 -3
  396. package/dist/esm/{swipe-back-BKw2CAHc.js → swipe-back-BZBFwTQV.js} +2 -2
  397. package/dist/html.html-data.json +109 -109
  398. package/dist/ionic/index.esm.js +1 -1
  399. package/dist/ionic/ionic.esm.js +1 -1
  400. package/dist/ionic/{p-316c0420.entry.js → p-025d2d32.entry.js} +1 -1
  401. package/dist/ionic/p-02acdef4.entry.js +4 -0
  402. package/dist/ionic/p-04e2c388.entry.js +4 -0
  403. package/dist/ionic/{p-370e4237.entry.js → p-074344b8.entry.js} +1 -1
  404. package/dist/ionic/p-0761b4d3.entry.js +4 -0
  405. package/dist/ionic/p-13ade5c8.entry.js +4 -0
  406. package/dist/ionic/p-1b02923f.entry.js +4 -0
  407. package/dist/ionic/p-1bd477a9.entry.js +4 -0
  408. package/dist/ionic/{p-d2489bf2.entry.js → p-1fa1406c.entry.js} +1 -1
  409. package/dist/ionic/{p-46d74291.entry.js → p-1fd588a7.entry.js} +1 -1
  410. package/dist/ionic/p-239a27a4.entry.js +4 -0
  411. package/dist/ionic/{p-94de5cfa.entry.js → p-277abec1.entry.js} +1 -1
  412. package/dist/ionic/{p-dd1aef77.entry.js → p-28d7852f.entry.js} +1 -1
  413. package/dist/ionic/{p-49d06882.entry.js → p-301c43f8.entry.js} +1 -1
  414. package/dist/ionic/{p-79bd78f9.entry.js → p-370a60ee.entry.js} +1 -1
  415. package/dist/ionic/p-3e143d1d.entry.js +4 -0
  416. package/dist/ionic/p-4431ef7e.entry.js +4 -0
  417. package/dist/ionic/p-463767ce.entry.js +4 -0
  418. package/dist/ionic/p-4f888343.entry.js +4 -0
  419. package/dist/ionic/p-51c11c47.entry.js +4 -0
  420. package/dist/ionic/p-56050077.entry.js +4 -0
  421. package/dist/ionic/p-6a3a5aae.entry.js +4 -0
  422. package/dist/ionic/p-6b97f2a3.entry.js +4 -0
  423. package/dist/ionic/{p-51a60e0f.entry.js → p-7c72d482.entry.js} +1 -1
  424. package/dist/ionic/p-7d20f4f8.entry.js +4 -0
  425. package/dist/ionic/{p-11aa58d6.entry.js → p-80cac7a2.entry.js} +1 -1
  426. package/dist/ionic/p-91fc7352.entry.js +4 -0
  427. package/dist/ionic/p-93845421.entry.js +4 -0
  428. package/dist/ionic/{p-3a6caca9.entry.js → p-964090ef.entry.js} +1 -1
  429. package/dist/ionic/p-96a2e768.entry.js +4 -0
  430. package/dist/ionic/{p-d126e8d3.entry.js → p-9745651b.entry.js} +1 -1
  431. package/dist/ionic/{p-f9061316.entry.js → p-9802c88e.entry.js} +1 -1
  432. package/dist/ionic/{p-582824c5.entry.js → p-9833cf63.entry.js} +1 -1
  433. package/dist/ionic/{p-675b1a31.entry.js → p-9fae83d8.entry.js} +1 -1
  434. package/dist/ionic/{p-CwgG81ZD.js → p-B8xlpH8p.js} +1 -1
  435. package/dist/ionic/{p-C7hRNDhM.js → p-BAt5H1ac.js} +1 -1
  436. package/dist/ionic/p-BW_TRJm8.js +4 -0
  437. package/dist/ionic/{p-DDb5r57F.js → p-Bum7H1fw.js} +1 -1
  438. package/dist/ionic/{p-D0dMcSkw.js → p-BvFYtOdE.js} +1 -1
  439. package/dist/ionic/{p-Dc45iWE4.js → p-BxIcPWoV.js} +1 -1
  440. package/dist/ionic/{p-BYEqWnSg.js → p-C0JvVFMv.js} +1 -1
  441. package/dist/ionic/{p-CTfR9YZG.js → p-CGmVTdWh.js} +1 -1
  442. package/dist/ionic/{p-BOVrCkpJ.js → p-CYbRmDdy.js} +1 -1
  443. package/dist/ionic/{p-D-eFFUkA.js → p-CmFz1Mjc.js} +1 -1
  444. package/dist/ionic/p-CtA-yJYy.js +4 -0
  445. package/dist/ionic/p-D8HJQ1qq.js +4 -0
  446. package/dist/ionic/{p-B0q1YL7N.js → p-DB_iPQC-.js} +1 -1
  447. package/dist/ionic/{p-DNcfiJwE.js → p-DLbbmF9h.js} +1 -1
  448. package/dist/ionic/{p-DdR6rpbR.js → p-DTPR1Wpn.js} +1 -1
  449. package/dist/ionic/{p-DCv9sLH2.js → p-DjriolRs.js} +1 -1
  450. package/dist/ionic/p-DtVZDHlS.js +4 -0
  451. package/dist/ionic/{p-QHYY4sjU.js → p-GWUGgWx6.js} +1 -1
  452. package/dist/ionic/p-IGIE5vDm.js +5 -0
  453. package/dist/ionic/{p-BFvmZNyx.js → p-NFFyoJ4Q.js} +1 -1
  454. package/dist/ionic/{p-86f53961.entry.js → p-a287e18e.entry.js} +1 -1
  455. package/dist/ionic/p-a805674e.entry.js +4 -0
  456. package/dist/ionic/p-a81ae2cd.entry.js +4 -0
  457. package/dist/ionic/{p-da7d04cc.entry.js → p-a84f2d21.entry.js} +1 -1
  458. package/dist/ionic/{p-dbbe606a.entry.js → p-b2d5238b.entry.js} +1 -1
  459. package/dist/ionic/{p-d1f54e28.entry.js → p-b440381f.entry.js} +1 -1
  460. package/dist/ionic/{p-72c38b88.entry.js → p-b4d52b58.entry.js} +1 -1
  461. package/dist/ionic/{p-2a939845.entry.js → p-b67a2114.entry.js} +1 -1
  462. package/dist/ionic/{p-c73627c8.entry.js → p-bced1f3e.entry.js} +1 -1
  463. package/dist/ionic/{p-9a2d390d.entry.js → p-c1c9b2bb.entry.js} +1 -1
  464. package/dist/ionic/{p-f8f22cc0.entry.js → p-c3e65e45.entry.js} +1 -1
  465. package/dist/ionic/p-c76cc21d.entry.js +4 -0
  466. package/dist/ionic/{p-b0a7585c.entry.js → p-ca31010f.entry.js} +1 -1
  467. package/dist/ionic/p-cbf245b5.entry.js +4 -0
  468. package/dist/ionic/p-d68b665a.entry.js +4 -0
  469. package/dist/ionic/{p-9575b654.entry.js → p-e663bc5a.entry.js} +1 -1
  470. package/dist/ionic/p-efe86ed9.entry.js +4 -0
  471. package/dist/ionic/{p-ac4eb91d.entry.js → p-f5dfb9a3.entry.js} +1 -1
  472. package/dist/ionic/{p-DbQ5QkTP.js → p-gbVXD275.js} +1 -1
  473. package/dist/ionic/p-hNN3VvaC.js +4 -0
  474. package/dist/types/components/datetime/datetime.d.ts +9 -0
  475. package/dist/types/components/header/header.utils.d.ts +2 -1
  476. package/dist/types/components/modal/modal-interface.d.ts +5 -1
  477. package/dist/types/components/modal/modal.d.ts +5 -0
  478. package/dist/types/components/refresher/refresher-interface.d.ts +7 -0
  479. package/dist/types/components/refresher/refresher.d.ts +16 -3
  480. package/dist/types/components.d.ts +927 -189
  481. package/dist/types/interface.d.ts +1 -1
  482. package/dist/types/stencil-public-runtime.d.ts +126 -14
  483. package/dist/types/utils/gesture/listener.d.ts +2 -1
  484. package/hydrate/index.d.ts +12 -0
  485. package/hydrate/index.js +5202 -1327
  486. package/hydrate/index.mjs +5201 -1328
  487. package/package.json +2 -2
  488. package/dist/cjs/app-globals-Ciccnk9_.js +0 -10
  489. package/dist/esm/app-globals-BDSf8fOA.js +0 -8
  490. package/dist/ionic/p-012212e4.entry.js +0 -4
  491. package/dist/ionic/p-074839fc.entry.js +0 -4
  492. package/dist/ionic/p-0dfa5a37.entry.js +0 -4
  493. package/dist/ionic/p-0f418a37.entry.js +0 -4
  494. package/dist/ionic/p-11518b31.entry.js +0 -4
  495. package/dist/ionic/p-1838bed5.entry.js +0 -4
  496. package/dist/ionic/p-29721c43.entry.js +0 -4
  497. package/dist/ionic/p-31f7095f.entry.js +0 -4
  498. package/dist/ionic/p-34642fa1.entry.js +0 -4
  499. package/dist/ionic/p-35696017.entry.js +0 -4
  500. package/dist/ionic/p-40c261a3.entry.js +0 -4
  501. package/dist/ionic/p-4e41ea20.entry.js +0 -4
  502. package/dist/ionic/p-6241ce47.entry.js +0 -4
  503. package/dist/ionic/p-639dd543.entry.js +0 -4
  504. package/dist/ionic/p-6444c606.entry.js +0 -4
  505. package/dist/ionic/p-6d070558.entry.js +0 -4
  506. package/dist/ionic/p-7268efa5.entry.js +0 -4
  507. package/dist/ionic/p-7babec72.entry.js +0 -4
  508. package/dist/ionic/p-BKc55Xev.js +0 -4
  509. package/dist/ionic/p-Bmgaetn_.js +0 -4
  510. package/dist/ionic/p-C8IsBmNU.js +0 -5
  511. package/dist/ionic/p-CJxh_yLS.js +0 -4
  512. package/dist/ionic/p-DUt5fQmA.js +0 -4
  513. package/dist/ionic/p-DZRJwG4S.js +0 -4
  514. package/dist/ionic/p-a127bee2.entry.js +0 -4
  515. package/dist/ionic/p-b3d44509.entry.js +0 -4
  516. package/dist/ionic/p-cc45bcbc.entry.js +0 -4
  517. package/dist/ionic/p-d0a2a1ab.entry.js +0 -4
  518. package/dist/ionic/p-d3014190.entry.js +0 -4
  519. package/dist/ionic/p-db82892c.entry.js +0 -4
  520. package/dist/ionic/p-e1d1f3cc.entry.js +0 -4
@@ -1,1505 +1,4 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
5
- import { B as BACKDROP, j as prepareOverlay, k as setOverlayId, f as present, n as focusFirstDescendant, g as dismiss, h as eventMethod, F as FOCUS_TRAP_DISABLE_CLASS } from './overlays.js';
6
- import { C as CoreDelegate, a as attachComponent, d as detachComponent } from './framework-delegate.js';
7
- import { g as getElementRoot, r as raf, a as addEventListener, k as hasLazyBuild } from './helpers.js';
8
- import { c as createLockController } from './lock-controller.js';
9
- import { p as printIonWarning } from './index4.js';
10
- import { b as getIonMode, a as isPlatform } from './ionic-global.js';
11
- import { g as getClassMap } from './theme.js';
12
- import { e as deepReady, w as waitForMount } from './index2.js';
13
- import { c as createAnimation } from './animation.js';
14
- import { d as defineCustomElement$1 } from './backdrop.js';
15
-
16
- /**
17
- * Returns the dimensions of the popover
18
- * arrow on `ios` mode. If arrow is disabled
19
- * returns (0, 0).
20
- */
21
- const getArrowDimensions = (arrowEl) => {
22
- if (!arrowEl) {
23
- return { arrowWidth: 0, arrowHeight: 0 };
24
- }
25
- const { width, height } = arrowEl.getBoundingClientRect();
26
- return { arrowWidth: width, arrowHeight: height };
27
- };
28
- /**
29
- * Returns the recommended dimensions of the popover
30
- * that takes into account whether or not the width
31
- * should match the trigger width.
32
- */
33
- const getPopoverDimensions = (size, contentEl, triggerEl) => {
34
- const contentDimentions = contentEl.getBoundingClientRect();
35
- const contentHeight = contentDimentions.height;
36
- let contentWidth = contentDimentions.width;
37
- if (size === 'cover' && triggerEl) {
38
- const triggerDimensions = triggerEl.getBoundingClientRect();
39
- contentWidth = triggerDimensions.width;
40
- }
41
- return {
42
- contentWidth,
43
- contentHeight,
44
- };
45
- };
46
- const configureDismissInteraction = (triggerEl, triggerAction, popoverEl, parentPopoverEl) => {
47
- let dismissCallbacks = [];
48
- const root = getElementRoot(parentPopoverEl);
49
- const parentContentEl = root.querySelector('.popover-content');
50
- switch (triggerAction) {
51
- case 'hover':
52
- dismissCallbacks = [
53
- {
54
- /**
55
- * Do not use mouseover here
56
- * as this will causes the event to
57
- * be dispatched on each underlying
58
- * element rather than on the popover
59
- * content as a whole.
60
- */
61
- eventName: 'mouseenter',
62
- callback: (ev) => {
63
- /**
64
- * Do not dismiss the popover is we
65
- * are hovering over its trigger.
66
- * This would be easier if we used mouseover
67
- * but this would cause the event to be dispatched
68
- * more often than we would like, potentially
69
- * causing performance issues.
70
- */
71
- const element = document.elementFromPoint(ev.clientX, ev.clientY);
72
- if (element === triggerEl) {
73
- return;
74
- }
75
- popoverEl.dismiss(undefined, undefined, false);
76
- },
77
- },
78
- ];
79
- break;
80
- case 'context-menu':
81
- case 'click':
82
- default:
83
- dismissCallbacks = [
84
- {
85
- eventName: 'click',
86
- callback: (ev) => {
87
- /**
88
- * Do not dismiss the popover is we
89
- * are hovering over its trigger.
90
- */
91
- const target = ev.target;
92
- const closestTrigger = target.closest('[data-ion-popover-trigger]');
93
- if (closestTrigger === triggerEl) {
94
- /**
95
- * stopPropagation here so if the
96
- * popover has dismissOnSelect="true"
97
- * the popover does not dismiss since
98
- * we just clicked a trigger element.
99
- */
100
- ev.stopPropagation();
101
- return;
102
- }
103
- popoverEl.dismiss(undefined, undefined, false);
104
- },
105
- },
106
- ];
107
- break;
108
- }
109
- dismissCallbacks.forEach(({ eventName, callback }) => parentContentEl.addEventListener(eventName, callback));
110
- return () => {
111
- dismissCallbacks.forEach(({ eventName, callback }) => parentContentEl.removeEventListener(eventName, callback));
112
- };
113
- };
114
- /**
115
- * Configures the triggerEl to respond
116
- * to user interaction based upon the triggerAction
117
- * prop that devs have defined.
118
- */
119
- const configureTriggerInteraction = (triggerEl, triggerAction, popoverEl) => {
120
- let triggerCallbacks = [];
121
- /**
122
- * Based upon the kind of trigger interaction
123
- * the user wants, we setup the correct event
124
- * listeners.
125
- */
126
- switch (triggerAction) {
127
- case 'hover':
128
- let hoverTimeout;
129
- triggerCallbacks = [
130
- {
131
- eventName: 'mouseenter',
132
- callback: async (ev) => {
133
- ev.stopPropagation();
134
- if (hoverTimeout) {
135
- clearTimeout(hoverTimeout);
136
- }
137
- /**
138
- * Hovering over a trigger should not
139
- * immediately open the next popover.
140
- */
141
- hoverTimeout = setTimeout(() => {
142
- raf(() => {
143
- popoverEl.presentFromTrigger(ev);
144
- hoverTimeout = undefined;
145
- });
146
- }, 100);
147
- },
148
- },
149
- {
150
- eventName: 'mouseleave',
151
- callback: (ev) => {
152
- if (hoverTimeout) {
153
- clearTimeout(hoverTimeout);
154
- }
155
- /**
156
- * If mouse is over another popover
157
- * that is not this popover then we should
158
- * close this popover.
159
- */
160
- const target = ev.relatedTarget;
161
- if (!target) {
162
- return;
163
- }
164
- if (target.closest('ion-popover') !== popoverEl) {
165
- popoverEl.dismiss(undefined, undefined, false);
166
- }
167
- },
168
- },
169
- {
170
- /**
171
- * stopPropagation here prevents the popover
172
- * from dismissing when dismiss-on-select="true".
173
- */
174
- eventName: 'click',
175
- callback: (ev) => ev.stopPropagation(),
176
- },
177
- {
178
- eventName: 'ionPopoverActivateTrigger',
179
- callback: (ev) => popoverEl.presentFromTrigger(ev, true),
180
- },
181
- ];
182
- break;
183
- case 'context-menu':
184
- triggerCallbacks = [
185
- {
186
- eventName: 'contextmenu',
187
- callback: (ev) => {
188
- /**
189
- * Prevents the platform context
190
- * menu from appearing.
191
- */
192
- ev.preventDefault();
193
- popoverEl.presentFromTrigger(ev);
194
- },
195
- },
196
- {
197
- eventName: 'click',
198
- callback: (ev) => ev.stopPropagation(),
199
- },
200
- {
201
- eventName: 'ionPopoverActivateTrigger',
202
- callback: (ev) => popoverEl.presentFromTrigger(ev, true),
203
- },
204
- ];
205
- break;
206
- case 'click':
207
- default:
208
- triggerCallbacks = [
209
- {
210
- /**
211
- * Do not do a stopPropagation() here
212
- * because if you had two click triggers
213
- * then clicking the first trigger and then
214
- * clicking the second trigger would not cause
215
- * the first popover to dismiss.
216
- */
217
- eventName: 'click',
218
- callback: (ev) => popoverEl.presentFromTrigger(ev),
219
- },
220
- {
221
- eventName: 'ionPopoverActivateTrigger',
222
- callback: (ev) => popoverEl.presentFromTrigger(ev, true),
223
- },
224
- ];
225
- break;
226
- }
227
- triggerCallbacks.forEach(({ eventName, callback }) => triggerEl.addEventListener(eventName, callback));
228
- triggerEl.setAttribute('data-ion-popover-trigger', 'true');
229
- return () => {
230
- triggerCallbacks.forEach(({ eventName, callback }) => triggerEl.removeEventListener(eventName, callback));
231
- triggerEl.removeAttribute('data-ion-popover-trigger');
232
- };
233
- };
234
- /**
235
- * Returns the index of an ion-item in an array of ion-items.
236
- */
237
- const getIndexOfItem = (items, item) => {
238
- if (!item || item.tagName !== 'ION-ITEM') {
239
- return -1;
240
- }
241
- return items.findIndex((el) => el === item);
242
- };
243
- /**
244
- * Given an array of elements and a currently focused ion-item
245
- * returns the next ion-item relative to the focused one or
246
- * undefined.
247
- */
248
- const getNextItem = (items, currentItem) => {
249
- const currentItemIndex = getIndexOfItem(items, currentItem);
250
- return items[currentItemIndex + 1];
251
- };
252
- /**
253
- * Given an array of elements and a currently focused ion-item
254
- * returns the previous ion-item relative to the focused one or
255
- * undefined.
256
- */
257
- const getPrevItem = (items, currentItem) => {
258
- const currentItemIndex = getIndexOfItem(items, currentItem);
259
- return items[currentItemIndex - 1];
260
- };
261
- /** Focus the internal button of the ion-item */
262
- const focusItem = (item) => {
263
- const root = getElementRoot(item);
264
- const button = root.querySelector('button');
265
- if (button) {
266
- raf(() => button.focus());
267
- }
268
- };
269
- /**
270
- * Returns `true` if `el` has been designated
271
- * as a trigger element for an ion-popover.
272
- */
273
- const isTriggerElement = (el) => el.hasAttribute('data-ion-popover-trigger');
274
- const configureKeyboardInteraction = (popoverEl) => {
275
- const callback = async (ev) => {
276
- var _a;
277
- const activeElement = document.activeElement;
278
- let items = [];
279
- const targetTagName = (_a = ev.target) === null || _a === void 0 ? void 0 : _a.tagName;
280
- /**
281
- * Only handle custom keyboard interactions for the host popover element
282
- * and children ion-item elements.
283
- */
284
- if (targetTagName !== 'ION-POPOVER' && targetTagName !== 'ION-ITEM') {
285
- return;
286
- }
287
- /**
288
- * Complex selectors with :not() are :not supported
289
- * in older versions of Chromium so we need to do a
290
- * try/catch here so errors are not thrown.
291
- */
292
- try {
293
- /**
294
- * Select all ion-items that are not children of child popovers.
295
- * i.e. only select ion-item elements that are part of this popover
296
- */
297
- items = Array.from(popoverEl.querySelectorAll('ion-item:not(ion-popover ion-popover *):not([disabled])'));
298
- /* eslint-disable-next-line */
299
- }
300
- catch (_b) { }
301
- switch (ev.key) {
302
- /**
303
- * If we are in a child popover
304
- * then pressing the left arrow key
305
- * should close this popover and move
306
- * focus to the popover that presented
307
- * this one.
308
- */
309
- case 'ArrowLeft':
310
- const parentPopover = await popoverEl.getParentPopover();
311
- if (parentPopover) {
312
- popoverEl.dismiss(undefined, undefined, false);
313
- }
314
- break;
315
- /**
316
- * ArrowDown should move focus to the next focusable ion-item.
317
- */
318
- case 'ArrowDown':
319
- // Disable movement/scroll with keyboard
320
- ev.preventDefault();
321
- const nextItem = getNextItem(items, activeElement);
322
- if (nextItem !== undefined) {
323
- focusItem(nextItem);
324
- }
325
- break;
326
- /**
327
- * ArrowUp should move focus to the previous focusable ion-item.
328
- */
329
- case 'ArrowUp':
330
- // Disable movement/scroll with keyboard
331
- ev.preventDefault();
332
- const prevItem = getPrevItem(items, activeElement);
333
- if (prevItem !== undefined) {
334
- focusItem(prevItem);
335
- }
336
- break;
337
- /**
338
- * Home should move focus to the first focusable ion-item.
339
- */
340
- case 'Home':
341
- ev.preventDefault();
342
- const firstItem = items[0];
343
- if (firstItem !== undefined) {
344
- focusItem(firstItem);
345
- }
346
- break;
347
- /**
348
- * End should move focus to the last focusable ion-item.
349
- */
350
- case 'End':
351
- ev.preventDefault();
352
- const lastItem = items[items.length - 1];
353
- if (lastItem !== undefined) {
354
- focusItem(lastItem);
355
- }
356
- break;
357
- /**
358
- * ArrowRight, Spacebar, or Enter should activate
359
- * the currently focused trigger item to open a
360
- * popover if the element is a trigger item.
361
- */
362
- case 'ArrowRight':
363
- case ' ':
364
- case 'Enter':
365
- if (activeElement && isTriggerElement(activeElement)) {
366
- const rightEvent = new CustomEvent('ionPopoverActivateTrigger');
367
- activeElement.dispatchEvent(rightEvent);
368
- }
369
- break;
370
- }
371
- };
372
- popoverEl.addEventListener('keydown', callback);
373
- return () => popoverEl.removeEventListener('keydown', callback);
374
- };
375
- /**
376
- * Positions a popover by taking into account
377
- * the reference point, preferred side, alignment
378
- * and viewport dimensions.
379
- */
380
- const getPopoverPosition = (isRTL, contentWidth, contentHeight, arrowWidth, arrowHeight, reference, side, align, defaultPosition, triggerEl, event) => {
381
- var _a;
382
- let referenceCoordinates = {
383
- top: 0,
384
- left: 0,
385
- width: 0,
386
- height: 0,
387
- };
388
- /**
389
- * Calculate position relative to the
390
- * x-y coordinates in the event that
391
- * was passed in
392
- */
393
- switch (reference) {
394
- case 'event':
395
- if (!event) {
396
- return defaultPosition;
397
- }
398
- const mouseEv = event;
399
- referenceCoordinates = {
400
- top: mouseEv.clientY,
401
- left: mouseEv.clientX,
402
- width: 1,
403
- height: 1,
404
- };
405
- break;
406
- /**
407
- * Calculate position relative to the bounding
408
- * box on either the trigger element
409
- * specified via the `trigger` prop or
410
- * the target specified on the event
411
- * that was passed in.
412
- */
413
- case 'trigger':
414
- default:
415
- const customEv = event;
416
- /**
417
- * ionShadowTarget is used when we need to align the
418
- * popover with an element inside of the shadow root
419
- * of an Ionic component. Ex: Presenting a popover
420
- * by clicking on the collapsed indicator inside
421
- * of `ion-breadcrumb` and centering it relative
422
- * to the indicator rather than `ion-breadcrumb`
423
- * as a whole.
424
- */
425
- const actualTriggerEl = (triggerEl ||
426
- ((_a = customEv === null || customEv === void 0 ? void 0 : customEv.detail) === null || _a === void 0 ? void 0 : _a.ionShadowTarget) ||
427
- (customEv === null || customEv === void 0 ? void 0 : customEv.target));
428
- if (!actualTriggerEl) {
429
- return defaultPosition;
430
- }
431
- const triggerBoundingBox = actualTriggerEl.getBoundingClientRect();
432
- referenceCoordinates = {
433
- top: triggerBoundingBox.top,
434
- left: triggerBoundingBox.left,
435
- width: triggerBoundingBox.width,
436
- height: triggerBoundingBox.height,
437
- };
438
- break;
439
- }
440
- /**
441
- * Get top/left offset that would allow
442
- * popover to be positioned on the
443
- * preferred side of the reference.
444
- */
445
- const coordinates = calculatePopoverSide(side, referenceCoordinates, contentWidth, contentHeight, arrowWidth, arrowHeight, isRTL);
446
- /**
447
- * Get the top/left adjustments that
448
- * would allow the popover content
449
- * to have the correct alignment.
450
- */
451
- const alignedCoordinates = calculatePopoverAlign(align, side, referenceCoordinates, contentWidth, contentHeight);
452
- const top = coordinates.top + alignedCoordinates.top;
453
- const left = coordinates.left + alignedCoordinates.left;
454
- const { arrowTop, arrowLeft } = calculateArrowPosition(side, arrowWidth, arrowHeight, top, left, contentWidth, contentHeight, isRTL);
455
- const { originX, originY } = calculatePopoverOrigin(side, align, isRTL);
456
- return { top, left, referenceCoordinates, arrowTop, arrowLeft, originX, originY };
457
- };
458
- /**
459
- * Determines the transform-origin
460
- * of the popover animation so that it
461
- * is in line with what the side and alignment
462
- * prop values are. Currently only used
463
- * with the MD animation.
464
- */
465
- const calculatePopoverOrigin = (side, align, isRTL) => {
466
- switch (side) {
467
- case 'top':
468
- return { originX: getOriginXAlignment(align), originY: 'bottom' };
469
- case 'bottom':
470
- return { originX: getOriginXAlignment(align), originY: 'top' };
471
- case 'left':
472
- return { originX: 'right', originY: getOriginYAlignment(align) };
473
- case 'right':
474
- return { originX: 'left', originY: getOriginYAlignment(align) };
475
- case 'start':
476
- return { originX: isRTL ? 'left' : 'right', originY: getOriginYAlignment(align) };
477
- case 'end':
478
- return { originX: isRTL ? 'right' : 'left', originY: getOriginYAlignment(align) };
479
- }
480
- };
481
- const getOriginXAlignment = (align) => {
482
- switch (align) {
483
- case 'start':
484
- return 'left';
485
- case 'center':
486
- return 'center';
487
- case 'end':
488
- return 'right';
489
- }
490
- };
491
- const getOriginYAlignment = (align) => {
492
- switch (align) {
493
- case 'start':
494
- return 'top';
495
- case 'center':
496
- return 'center';
497
- case 'end':
498
- return 'bottom';
499
- }
500
- };
501
- /**
502
- * Calculates where the arrow positioning
503
- * should be relative to the popover content.
504
- */
505
- const calculateArrowPosition = (side, arrowWidth, arrowHeight, top, left, contentWidth, contentHeight, isRTL) => {
506
- /**
507
- * Note: When side is left, right, start, or end, the arrow is
508
- * been rotated using a `transform`, so to move the arrow up or down
509
- * by its dimension, you need to use `arrowWidth`.
510
- */
511
- const leftPosition = {
512
- arrowTop: top + contentHeight / 2 - arrowWidth / 2,
513
- arrowLeft: left + contentWidth - arrowWidth / 2,
514
- };
515
- /**
516
- * Move the arrow to the left by arrowWidth and then
517
- * again by half of its width because we have rotated
518
- * the arrow using a transform.
519
- */
520
- const rightPosition = { arrowTop: top + contentHeight / 2 - arrowWidth / 2, arrowLeft: left - arrowWidth * 1.5 };
521
- switch (side) {
522
- case 'top':
523
- return { arrowTop: top + contentHeight, arrowLeft: left + contentWidth / 2 - arrowWidth / 2 };
524
- case 'bottom':
525
- return { arrowTop: top - arrowHeight, arrowLeft: left + contentWidth / 2 - arrowWidth / 2 };
526
- case 'left':
527
- return leftPosition;
528
- case 'right':
529
- return rightPosition;
530
- case 'start':
531
- return isRTL ? rightPosition : leftPosition;
532
- case 'end':
533
- return isRTL ? leftPosition : rightPosition;
534
- default:
535
- return { arrowTop: 0, arrowLeft: 0 };
536
- }
537
- };
538
- /**
539
- * Calculates the required top/left
540
- * values needed to position the popover
541
- * content on the side specified in the
542
- * `side` prop.
543
- */
544
- const calculatePopoverSide = (side, triggerBoundingBox, contentWidth, contentHeight, arrowWidth, arrowHeight, isRTL) => {
545
- const sideLeft = {
546
- top: triggerBoundingBox.top,
547
- left: triggerBoundingBox.left - contentWidth - arrowWidth,
548
- };
549
- const sideRight = {
550
- top: triggerBoundingBox.top,
551
- left: triggerBoundingBox.left + triggerBoundingBox.width + arrowWidth,
552
- };
553
- switch (side) {
554
- case 'top':
555
- return {
556
- top: triggerBoundingBox.top - contentHeight - arrowHeight,
557
- left: triggerBoundingBox.left,
558
- };
559
- case 'right':
560
- return sideRight;
561
- case 'bottom':
562
- return {
563
- top: triggerBoundingBox.top + triggerBoundingBox.height + arrowHeight,
564
- left: triggerBoundingBox.left,
565
- };
566
- case 'left':
567
- return sideLeft;
568
- case 'start':
569
- return isRTL ? sideRight : sideLeft;
570
- case 'end':
571
- return isRTL ? sideLeft : sideRight;
572
- }
573
- };
574
- /**
575
- * Calculates the required top/left
576
- * offset values needed to provide the
577
- * correct alignment regardless while taking
578
- * into account the side the popover is on.
579
- */
580
- const calculatePopoverAlign = (align, side, triggerBoundingBox, contentWidth, contentHeight) => {
581
- switch (align) {
582
- case 'center':
583
- return calculatePopoverCenterAlign(side, triggerBoundingBox, contentWidth, contentHeight);
584
- case 'end':
585
- return calculatePopoverEndAlign(side, triggerBoundingBox, contentWidth, contentHeight);
586
- case 'start':
587
- default:
588
- return { top: 0, left: 0 };
589
- }
590
- };
591
- /**
592
- * Calculate the end alignment for
593
- * the popover. If side is on the x-axis
594
- * then the align values refer to the top
595
- * and bottom margins of the content.
596
- * If side is on the y-axis then the
597
- * align values refer to the left and right
598
- * margins of the content.
599
- */
600
- const calculatePopoverEndAlign = (side, triggerBoundingBox, contentWidth, contentHeight) => {
601
- switch (side) {
602
- case 'start':
603
- case 'end':
604
- case 'left':
605
- case 'right':
606
- return {
607
- top: -(contentHeight - triggerBoundingBox.height),
608
- left: 0,
609
- };
610
- case 'top':
611
- case 'bottom':
612
- default:
613
- return {
614
- top: 0,
615
- left: -(contentWidth - triggerBoundingBox.width),
616
- };
617
- }
618
- };
619
- /**
620
- * Calculate the center alignment for
621
- * the popover. If side is on the x-axis
622
- * then the align values refer to the top
623
- * and bottom margins of the content.
624
- * If side is on the y-axis then the
625
- * align values refer to the left and right
626
- * margins of the content.
627
- */
628
- const calculatePopoverCenterAlign = (side, triggerBoundingBox, contentWidth, contentHeight) => {
629
- switch (side) {
630
- case 'start':
631
- case 'end':
632
- case 'left':
633
- case 'right':
634
- return {
635
- top: -(contentHeight / 2 - triggerBoundingBox.height / 2),
636
- left: 0,
637
- };
638
- case 'top':
639
- case 'bottom':
640
- default:
641
- return {
642
- top: 0,
643
- left: -(contentWidth / 2 - triggerBoundingBox.width / 2),
644
- };
645
- }
646
- };
647
- /**
648
- * Adjusts popover positioning coordinates
649
- * such that popover does not appear offscreen
650
- * or overlapping safe area bounds.
651
- */
652
- const calculateWindowAdjustment = (side, coordTop, coordLeft, bodyPadding, bodyWidth, bodyHeight, contentWidth, contentHeight, safeAreaMargin, contentOriginX, contentOriginY, triggerCoordinates, coordArrowTop = 0, coordArrowLeft = 0, arrowHeight = 0) => {
653
- let arrowTop = coordArrowTop;
654
- const arrowLeft = coordArrowLeft;
655
- let left = coordLeft;
656
- let top = coordTop;
657
- let bottom;
658
- let originX = contentOriginX;
659
- let originY = contentOriginY;
660
- let checkSafeAreaLeft = false;
661
- let checkSafeAreaRight = false;
662
- const triggerTop = triggerCoordinates
663
- ? triggerCoordinates.top + triggerCoordinates.height
664
- : bodyHeight / 2 - contentHeight / 2;
665
- const triggerHeight = triggerCoordinates ? triggerCoordinates.height : 0;
666
- let addPopoverBottomClass = false;
667
- /**
668
- * Adjust popover so it does not
669
- * go off the left of the screen.
670
- */
671
- if (left < bodyPadding + safeAreaMargin) {
672
- left = bodyPadding;
673
- checkSafeAreaLeft = true;
674
- originX = 'left';
675
- /**
676
- * Adjust popover so it does not
677
- * go off the right of the screen.
678
- */
679
- }
680
- else if (contentWidth + bodyPadding + left + safeAreaMargin > bodyWidth) {
681
- checkSafeAreaRight = true;
682
- left = bodyWidth - contentWidth - bodyPadding;
683
- originX = 'right';
684
- }
685
- /**
686
- * Adjust popover so it does not
687
- * go off the top of the screen.
688
- * If popover is on the left or the right of
689
- * the trigger, then we should not adjust top
690
- * margins.
691
- */
692
- if (triggerTop + triggerHeight + contentHeight > bodyHeight && (side === 'top' || side === 'bottom')) {
693
- if (triggerTop - contentHeight > 0) {
694
- /**
695
- * While we strive to align the popover with the trigger
696
- * on smaller screens this is not always possible. As a result,
697
- * we adjust the popover up so that it does not hang
698
- * off the bottom of the screen. However, we do not want to move
699
- * the popover up so much that it goes off the top of the screen.
700
- *
701
- * We chose 12 here so that the popover position looks a bit nicer as
702
- * it is not right up against the edge of the screen.
703
- */
704
- top = Math.max(12, triggerTop - contentHeight - triggerHeight - (arrowHeight - 1));
705
- arrowTop = top + contentHeight;
706
- originY = 'bottom';
707
- addPopoverBottomClass = true;
708
- /**
709
- * If not enough room for popover to appear
710
- * above trigger, then cut it off.
711
- */
712
- }
713
- else {
714
- bottom = bodyPadding;
715
- }
716
- }
717
- return {
718
- top,
719
- left,
720
- bottom,
721
- originX,
722
- originY,
723
- checkSafeAreaLeft,
724
- checkSafeAreaRight,
725
- arrowTop,
726
- arrowLeft,
727
- addPopoverBottomClass,
728
- };
729
- };
730
- const shouldShowArrow = (side, didAdjustBounds = false, ev, trigger) => {
731
- /**
732
- * If no event provided and
733
- * we do not have a trigger,
734
- * then this popover was likely
735
- * presented via the popoverController
736
- * or users called `present` manually.
737
- * In this case, the arrow should not be
738
- * shown as we do not have a reference.
739
- */
740
- if (!ev && !trigger) {
741
- return false;
742
- }
743
- /**
744
- * If popover is on the left or the right
745
- * of a trigger, but we needed to adjust the
746
- * popover due to screen bounds, then we should
747
- * hide the arrow as it will never be pointing
748
- * at the trigger.
749
- */
750
- if (side !== 'top' && side !== 'bottom' && didAdjustBounds) {
751
- return false;
752
- }
753
- return true;
754
- };
755
-
756
- const POPOVER_IOS_BODY_PADDING = 5;
757
- /**
758
- * iOS Popover Enter Animation
759
- */
760
- // TODO(FW-2832): types
761
- const iosEnterAnimation = (baseEl, opts) => {
762
- var _a;
763
- const { event: ev, size, trigger, reference, side, align } = opts;
764
- const doc = baseEl.ownerDocument;
765
- const isRTL = doc.dir === 'rtl';
766
- const bodyWidth = doc.defaultView.innerWidth;
767
- const bodyHeight = doc.defaultView.innerHeight;
768
- const root = getElementRoot(baseEl);
769
- const contentEl = root.querySelector('.popover-content');
770
- const arrowEl = root.querySelector('.popover-arrow');
771
- const referenceSizeEl = trigger || ((_a = ev === null || ev === void 0 ? void 0 : ev.detail) === null || _a === void 0 ? void 0 : _a.ionShadowTarget) || (ev === null || ev === void 0 ? void 0 : ev.target);
772
- const { contentWidth, contentHeight } = getPopoverDimensions(size, contentEl, referenceSizeEl);
773
- const { arrowWidth, arrowHeight } = getArrowDimensions(arrowEl);
774
- const defaultPosition = {
775
- top: bodyHeight / 2 - contentHeight / 2,
776
- left: bodyWidth / 2 - contentWidth / 2,
777
- originX: isRTL ? 'right' : 'left',
778
- originY: 'top',
779
- };
780
- const results = getPopoverPosition(isRTL, contentWidth, contentHeight, arrowWidth, arrowHeight, reference, side, align, defaultPosition, trigger, ev);
781
- const padding = size === 'cover' ? 0 : POPOVER_IOS_BODY_PADDING;
782
- const margin = size === 'cover' ? 0 : 25;
783
- const { originX, originY, top, left, bottom, checkSafeAreaLeft, checkSafeAreaRight, arrowTop, arrowLeft, addPopoverBottomClass, } = calculateWindowAdjustment(side, results.top, results.left, padding, bodyWidth, bodyHeight, contentWidth, contentHeight, margin, results.originX, results.originY, results.referenceCoordinates, results.arrowTop, results.arrowLeft, arrowHeight);
784
- const baseAnimation = createAnimation();
785
- const backdropAnimation = createAnimation();
786
- const contentAnimation = createAnimation();
787
- backdropAnimation
788
- .addElement(root.querySelector('ion-backdrop'))
789
- .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
790
- .beforeStyles({
791
- 'pointer-events': 'none',
792
- })
793
- .afterClearStyles(['pointer-events']);
794
- // In Chromium, if the wrapper animates, the backdrop filter doesn't work.
795
- // The Chromium team stated that this behavior is expected and not a bug. The element animating opacity creates a backdrop root for the backdrop-filter.
796
- // To get around this, instead of animating the wrapper, animate both the arrow and content.
797
- // https://bugs.chromium.org/p/chromium/issues/detail?id=1148826
798
- contentAnimation
799
- .addElement(root.querySelector('.popover-arrow'))
800
- .addElement(root.querySelector('.popover-content'))
801
- .fromTo('opacity', 0.01, 1);
802
- // TODO(FW-4376) Ensure that arrow also blurs when translucent
803
- return baseAnimation
804
- .easing('ease')
805
- .duration(100)
806
- .beforeAddWrite(() => {
807
- if (size === 'cover') {
808
- baseEl.style.setProperty('--width', `${contentWidth}px`);
809
- }
810
- if (addPopoverBottomClass) {
811
- baseEl.classList.add('popover-bottom');
812
- }
813
- if (bottom !== undefined) {
814
- contentEl.style.setProperty('bottom', `${bottom}px`);
815
- }
816
- const safeAreaLeft = ' + var(--ion-safe-area-left, 0)';
817
- const safeAreaRight = ' - var(--ion-safe-area-right, 0)';
818
- let leftValue = `${left}px`;
819
- if (checkSafeAreaLeft) {
820
- leftValue = `${left}px${safeAreaLeft}`;
821
- }
822
- if (checkSafeAreaRight) {
823
- leftValue = `${left}px${safeAreaRight}`;
824
- }
825
- contentEl.style.setProperty('top', `calc(${top}px + var(--offset-y, 0))`);
826
- contentEl.style.setProperty('left', `calc(${leftValue} + var(--offset-x, 0))`);
827
- contentEl.style.setProperty('transform-origin', `${originY} ${originX}`);
828
- if (arrowEl !== null) {
829
- const didAdjustBounds = results.top !== top || results.left !== left;
830
- const showArrow = shouldShowArrow(side, didAdjustBounds, ev, trigger);
831
- if (showArrow) {
832
- arrowEl.style.setProperty('top', `calc(${arrowTop}px + var(--offset-y, 0))`);
833
- arrowEl.style.setProperty('left', `calc(${arrowLeft}px + var(--offset-x, 0))`);
834
- }
835
- else {
836
- arrowEl.style.setProperty('display', 'none');
837
- }
838
- }
839
- })
840
- .addAnimation([backdropAnimation, contentAnimation]);
841
- };
842
-
843
- /**
844
- * iOS Popover Leave Animation
845
- */
846
- const iosLeaveAnimation = (baseEl) => {
847
- const root = getElementRoot(baseEl);
848
- const contentEl = root.querySelector('.popover-content');
849
- const arrowEl = root.querySelector('.popover-arrow');
850
- const baseAnimation = createAnimation();
851
- const backdropAnimation = createAnimation();
852
- const contentAnimation = createAnimation();
853
- backdropAnimation.addElement(root.querySelector('ion-backdrop')).fromTo('opacity', 'var(--backdrop-opacity)', 0);
854
- contentAnimation
855
- .addElement(root.querySelector('.popover-arrow'))
856
- .addElement(root.querySelector('.popover-content'))
857
- .fromTo('opacity', 0.99, 0);
858
- return baseAnimation
859
- .easing('ease')
860
- .afterAddWrite(() => {
861
- baseEl.style.removeProperty('--width');
862
- baseEl.classList.remove('popover-bottom');
863
- contentEl.style.removeProperty('top');
864
- contentEl.style.removeProperty('left');
865
- contentEl.style.removeProperty('bottom');
866
- contentEl.style.removeProperty('transform-origin');
867
- if (arrowEl) {
868
- arrowEl.style.removeProperty('top');
869
- arrowEl.style.removeProperty('left');
870
- arrowEl.style.removeProperty('display');
871
- }
872
- })
873
- .duration(300)
874
- .addAnimation([backdropAnimation, contentAnimation]);
875
- };
876
-
877
- const POPOVER_MD_BODY_PADDING = 12;
878
- /**
879
- * Md Popover Enter Animation
880
- */
881
- // TODO(FW-2832): types
882
- const mdEnterAnimation = (baseEl, opts) => {
883
- var _a;
884
- const { event: ev, size, trigger, reference, side, align } = opts;
885
- const doc = baseEl.ownerDocument;
886
- const isRTL = doc.dir === 'rtl';
887
- const bodyWidth = doc.defaultView.innerWidth;
888
- const bodyHeight = doc.defaultView.innerHeight;
889
- const root = getElementRoot(baseEl);
890
- const contentEl = root.querySelector('.popover-content');
891
- const referenceSizeEl = trigger || ((_a = ev === null || ev === void 0 ? void 0 : ev.detail) === null || _a === void 0 ? void 0 : _a.ionShadowTarget) || (ev === null || ev === void 0 ? void 0 : ev.target);
892
- const { contentWidth, contentHeight } = getPopoverDimensions(size, contentEl, referenceSizeEl);
893
- const defaultPosition = {
894
- top: bodyHeight / 2 - contentHeight / 2,
895
- left: bodyWidth / 2 - contentWidth / 2,
896
- originX: isRTL ? 'right' : 'left',
897
- originY: 'top',
898
- };
899
- const results = getPopoverPosition(isRTL, contentWidth, contentHeight, 0, 0, reference, side, align, defaultPosition, trigger, ev);
900
- const padding = size === 'cover' ? 0 : POPOVER_MD_BODY_PADDING;
901
- const { originX, originY, top, left, bottom } = calculateWindowAdjustment(side, results.top, results.left, padding, bodyWidth, bodyHeight, contentWidth, contentHeight, 0, results.originX, results.originY, results.referenceCoordinates);
902
- const baseAnimation = createAnimation();
903
- const backdropAnimation = createAnimation();
904
- const wrapperAnimation = createAnimation();
905
- const contentAnimation = createAnimation();
906
- const viewportAnimation = createAnimation();
907
- backdropAnimation
908
- .addElement(root.querySelector('ion-backdrop'))
909
- .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
910
- .beforeStyles({
911
- 'pointer-events': 'none',
912
- })
913
- .afterClearStyles(['pointer-events']);
914
- wrapperAnimation.addElement(root.querySelector('.popover-wrapper')).duration(150).fromTo('opacity', 0.01, 1);
915
- contentAnimation
916
- .addElement(contentEl)
917
- .beforeStyles({
918
- top: `calc(${top}px + var(--offset-y, 0px))`,
919
- left: `calc(${left}px + var(--offset-x, 0px))`,
920
- 'transform-origin': `${originY} ${originX}`,
921
- })
922
- .beforeAddWrite(() => {
923
- if (bottom !== undefined) {
924
- contentEl.style.setProperty('bottom', `${bottom}px`);
925
- }
926
- })
927
- .fromTo('transform', 'scale(0.8)', 'scale(1)');
928
- viewportAnimation.addElement(root.querySelector('.popover-viewport')).fromTo('opacity', 0.01, 1);
929
- return baseAnimation
930
- .easing('cubic-bezier(0.36,0.66,0.04,1)')
931
- .duration(300)
932
- .beforeAddWrite(() => {
933
- if (size === 'cover') {
934
- baseEl.style.setProperty('--width', `${contentWidth}px`);
935
- }
936
- if (originY === 'bottom') {
937
- baseEl.classList.add('popover-bottom');
938
- }
939
- })
940
- .addAnimation([backdropAnimation, wrapperAnimation, contentAnimation, viewportAnimation]);
941
- };
942
-
943
- /**
944
- * Md Popover Leave Animation
945
- */
946
- const mdLeaveAnimation = (baseEl) => {
947
- const root = getElementRoot(baseEl);
948
- const contentEl = root.querySelector('.popover-content');
949
- const baseAnimation = createAnimation();
950
- const backdropAnimation = createAnimation();
951
- const wrapperAnimation = createAnimation();
952
- backdropAnimation.addElement(root.querySelector('ion-backdrop')).fromTo('opacity', 'var(--backdrop-opacity)', 0);
953
- wrapperAnimation.addElement(root.querySelector('.popover-wrapper')).fromTo('opacity', 0.99, 0);
954
- return baseAnimation
955
- .easing('ease')
956
- .afterAddWrite(() => {
957
- baseEl.style.removeProperty('--width');
958
- baseEl.classList.remove('popover-bottom');
959
- contentEl.style.removeProperty('top');
960
- contentEl.style.removeProperty('left');
961
- contentEl.style.removeProperty('bottom');
962
- contentEl.style.removeProperty('transform-origin');
963
- })
964
- .duration(150)
965
- .addAnimation([backdropAnimation, wrapperAnimation]);
966
- };
967
-
968
- const popoverIosCss = ":host{--background:var(--ion-background-color, #fff);--min-width:0;--min-height:0;--max-width:auto;--height:auto;--offset-x:0px;--offset-y:0px;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;color:var(--ion-text-color, #000);z-index:1001}:host(.popover-nested){pointer-events:none}:host(.popover-nested) .popover-wrapper{pointer-events:auto}:host(.overlay-hidden){display:none}.popover-wrapper{z-index:10}.popover-content{display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);overflow:auto;z-index:10}::slotted(.popover-viewport){--ion-safe-area-top:0px;--ion-safe-area-right:0px;--ion-safe-area-bottom:0px;--ion-safe-area-left:0px;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}:host(.popover-nested.popover-side-left){--offset-x:5px}:host(.popover-nested.popover-side-right){--offset-x:-5px}:host(.popover-nested.popover-side-start){--offset-x:5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-start),:host-context([dir=rtl]).popover-nested.popover-side-start{--offset-x:-5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-start:dir(rtl)){--offset-x:-5px}}:host(.popover-nested.popover-side-end){--offset-x:-5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-end),:host-context([dir=rtl]).popover-nested.popover-side-end{--offset-x:5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-end:dir(rtl)){--offset-x:5px}}:host{--width:200px;--max-height:90%;--box-shadow:none;--backdrop-opacity:var(--ion-backdrop-opacity, 0.08)}:host(.popover-desktop){--box-shadow:0px 4px 16px 0px rgba(0, 0, 0, 0.12)}.popover-content{border-radius:10px}:host(.popover-desktop) .popover-content{border:0.5px solid var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}.popover-arrow{display:block;position:absolute;width:20px;height:10px;overflow:hidden;z-index:11}.popover-arrow::after{top:3px;border-radius:3px;position:absolute;width:14px;height:14px;-webkit-transform:rotate(45deg);transform:rotate(45deg);background:var(--background);content:\"\";z-index:10}.popover-arrow::after{inset-inline-start:3px}:host(.popover-bottom) .popover-arrow{top:auto;bottom:-10px}:host(.popover-bottom) .popover-arrow::after{top:-6px}:host(.popover-side-left) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}:host(.popover-side-right) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}:host(.popover-side-top) .popover-arrow{-webkit-transform:rotate(180deg);transform:rotate(180deg)}:host(.popover-side-start) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}:host-context([dir=rtl]):host(.popover-side-start) .popover-arrow,:host-context([dir=rtl]).popover-side-start .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}@supports selector(:dir(rtl)){:host(.popover-side-start:dir(rtl)) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}}:host(.popover-side-end) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}:host-context([dir=rtl]):host(.popover-side-end) .popover-arrow,:host-context([dir=rtl]).popover-side-end .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}@supports selector(:dir(rtl)){:host(.popover-side-end:dir(rtl)) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}}.popover-arrow,.popover-content{opacity:0}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){:host(.popover-translucent) .popover-content,:host(.popover-translucent) .popover-arrow::after{background:rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}}";
969
-
970
- const popoverMdCss = ":host{--background:var(--ion-background-color, #fff);--min-width:0;--min-height:0;--max-width:auto;--height:auto;--offset-x:0px;--offset-y:0px;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;color:var(--ion-text-color, #000);z-index:1001}:host(.popover-nested){pointer-events:none}:host(.popover-nested) .popover-wrapper{pointer-events:auto}:host(.overlay-hidden){display:none}.popover-wrapper{z-index:10}.popover-content{display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);overflow:auto;z-index:10}::slotted(.popover-viewport){--ion-safe-area-top:0px;--ion-safe-area-right:0px;--ion-safe-area-bottom:0px;--ion-safe-area-left:0px;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}:host(.popover-nested.popover-side-left){--offset-x:5px}:host(.popover-nested.popover-side-right){--offset-x:-5px}:host(.popover-nested.popover-side-start){--offset-x:5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-start),:host-context([dir=rtl]).popover-nested.popover-side-start{--offset-x:-5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-start:dir(rtl)){--offset-x:-5px}}:host(.popover-nested.popover-side-end){--offset-x:-5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-end),:host-context([dir=rtl]).popover-nested.popover-side-end{--offset-x:5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-end:dir(rtl)){--offset-x:5px}}:host{--width:250px;--max-height:90%;--box-shadow:0 5px 5px -3px rgba(0, 0, 0, 0.2), 0 8px 10px 1px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12);--backdrop-opacity:var(--ion-backdrop-opacity, 0.32)}.popover-content{border-radius:4px;-webkit-transform-origin:left top;transform-origin:left top}:host-context([dir=rtl]) .popover-content{-webkit-transform-origin:right top;transform-origin:right top}[dir=rtl] .popover-content{-webkit-transform-origin:right top;transform-origin:right top}@supports selector(:dir(rtl)){.popover-content:dir(rtl){-webkit-transform-origin:right top;transform-origin:right top}}.popover-viewport{-webkit-transition-delay:100ms;transition-delay:100ms}.popover-wrapper{opacity:0}";
971
-
972
- const Popover = /*@__PURE__*/ proxyCustomElement(class Popover extends HTMLElement {
973
- constructor(registerHost) {
974
- super();
975
- if (registerHost !== false) {
976
- this.__registerHost();
977
- }
978
- this.__attachShadow();
979
- this.didPresent = createEvent(this, "ionPopoverDidPresent", 7);
980
- this.willPresent = createEvent(this, "ionPopoverWillPresent", 7);
981
- this.willDismiss = createEvent(this, "ionPopoverWillDismiss", 7);
982
- this.didDismiss = createEvent(this, "ionPopoverDidDismiss", 7);
983
- this.didPresentShorthand = createEvent(this, "didPresent", 7);
984
- this.willPresentShorthand = createEvent(this, "willPresent", 7);
985
- this.willDismissShorthand = createEvent(this, "willDismiss", 7);
986
- this.didDismissShorthand = createEvent(this, "didDismiss", 7);
987
- this.ionMount = createEvent(this, "ionMount", 7);
988
- this.parentPopover = null;
989
- this.coreDelegate = CoreDelegate();
990
- this.lockController = createLockController();
991
- this.inline = false;
992
- this.focusDescendantOnPresent = false;
993
- this.presented = false;
994
- /** @internal */
995
- this.hasController = false;
996
- /**
997
- * If `true`, the keyboard will be automatically dismissed when the overlay is presented.
998
- */
999
- this.keyboardClose = true;
1000
- /**
1001
- * If `true`, the popover will be dismissed when the backdrop is clicked.
1002
- */
1003
- this.backdropDismiss = true;
1004
- /**
1005
- * If `true`, a backdrop will be displayed behind the popover.
1006
- * This property controls whether or not the backdrop
1007
- * darkens the screen when the popover is presented.
1008
- * It does not control whether or not the backdrop
1009
- * is active or present in the DOM.
1010
- */
1011
- this.showBackdrop = true;
1012
- /**
1013
- * If `true`, the popover will be translucent.
1014
- * Only applies when the mode is `"ios"` and the device supports
1015
- * [`backdrop-filter`](https://developer.mozilla.org/en-US/docs/Web/CSS/backdrop-filter#Browser_compatibility).
1016
- */
1017
- this.translucent = false;
1018
- /**
1019
- * If `true`, the popover will animate.
1020
- */
1021
- this.animated = true;
1022
- /**
1023
- * Describes what kind of interaction with the trigger that
1024
- * should cause the popover to open. Does not apply when the `trigger`
1025
- * property is `undefined`.
1026
- * If `"click"`, the popover will be presented when the trigger is left clicked.
1027
- * If `"hover"`, the popover will be presented when a pointer hovers over the trigger.
1028
- * If `"context-menu"`, the popover will be presented when the trigger is right
1029
- * clicked on desktop and long pressed on mobile. This will also prevent your
1030
- * device's normal context menu from appearing.
1031
- */
1032
- this.triggerAction = 'click';
1033
- /**
1034
- * Describes how to calculate the popover width.
1035
- * If `"cover"`, the popover width will match the width of the trigger.
1036
- * If `"auto"`, the popover width will be set to a static default value.
1037
- */
1038
- this.size = 'auto';
1039
- /**
1040
- * If `true`, the popover will be automatically
1041
- * dismissed when the content has been clicked.
1042
- */
1043
- this.dismissOnSelect = false;
1044
- /**
1045
- * Describes what to position the popover relative to.
1046
- * If `"trigger"`, the popover will be positioned relative
1047
- * to the trigger button. If passing in an event, this is
1048
- * determined via event.target.
1049
- * If `"event"`, the popover will be positioned relative
1050
- * to the x/y coordinates of the trigger action. If passing
1051
- * in an event, this is determined via event.clientX and event.clientY.
1052
- */
1053
- this.reference = 'trigger';
1054
- /**
1055
- * Describes which side of the `reference` point to position
1056
- * the popover on. The `"start"` and `"end"` values are RTL-aware,
1057
- * and the `"left"` and `"right"` values are not.
1058
- */
1059
- this.side = 'bottom';
1060
- /**
1061
- * If `true`, the popover will display an arrow that points at the
1062
- * `reference` when running in `ios` mode. Does not apply in `md` mode.
1063
- */
1064
- this.arrow = true;
1065
- /**
1066
- * If `true`, the popover will open. If `false`, the popover will close.
1067
- * Use this if you need finer grained control over presentation, otherwise
1068
- * just use the popoverController or the `trigger` property.
1069
- * Note: `isOpen` will not automatically be set back to `false` when
1070
- * the popover dismisses. You will need to do that in your code.
1071
- */
1072
- this.isOpen = false;
1073
- /**
1074
- * @internal
1075
- *
1076
- * If `true` the popover will not register its own keyboard event handlers.
1077
- * This allows the contents of the popover to handle their own keyboard interactions.
1078
- *
1079
- * If `false`, the popover will register its own keyboard event handlers for
1080
- * navigating `ion-list` items within a popover (up/down/home/end/etc.).
1081
- * This will also cancel browser keyboard event bindings to prevent scroll
1082
- * behavior in a popover using a list of items.
1083
- */
1084
- this.keyboardEvents = false;
1085
- /**
1086
- * If `true`, focus will not be allowed to move outside of this overlay.
1087
- * If `false`, focus will be allowed to move outside of the overlay.
1088
- *
1089
- * In most scenarios this property should remain set to `true`. Setting
1090
- * this property to `false` can cause severe accessibility issues as users
1091
- * relying on assistive technologies may be able to move focus into
1092
- * a confusing state. We recommend only setting this to `false` when
1093
- * absolutely necessary.
1094
- *
1095
- * Developers may want to consider disabling focus trapping if this
1096
- * overlay presents a non-Ionic overlay from a 3rd party library.
1097
- * Developers would disable focus trapping on the Ionic overlay
1098
- * when presenting the 3rd party overlay and then re-enable
1099
- * focus trapping when dismissing the 3rd party overlay and moving
1100
- * focus back to the Ionic overlay.
1101
- */
1102
- this.focusTrap = true;
1103
- /**
1104
- * If `true`, the component passed into `ion-popover` will
1105
- * automatically be mounted when the popover is created. The
1106
- * component will remain mounted even when the popover is dismissed.
1107
- * However, the component will be destroyed when the popover is
1108
- * destroyed. This property is not reactive and should only be
1109
- * used when initially creating a popover.
1110
- *
1111
- * Note: This feature only applies to inline popovers in JavaScript
1112
- * frameworks such as Angular, React, and Vue.
1113
- */
1114
- this.keepContentsMounted = false;
1115
- this.onBackdropTap = () => {
1116
- this.dismiss(undefined, BACKDROP);
1117
- };
1118
- this.onLifecycle = (modalEvent) => {
1119
- const el = this.usersElement;
1120
- const name = LIFECYCLE_MAP[modalEvent.type];
1121
- if (el && name) {
1122
- const event = new CustomEvent(name, {
1123
- bubbles: false,
1124
- cancelable: false,
1125
- detail: modalEvent.detail,
1126
- });
1127
- el.dispatchEvent(event);
1128
- }
1129
- };
1130
- this.configureTriggerInteraction = () => {
1131
- const { trigger, triggerAction, el, destroyTriggerInteraction } = this;
1132
- if (destroyTriggerInteraction) {
1133
- destroyTriggerInteraction();
1134
- }
1135
- if (trigger === undefined) {
1136
- return;
1137
- }
1138
- const triggerEl = (this.triggerEl = trigger !== undefined ? document.getElementById(trigger) : null);
1139
- if (!triggerEl) {
1140
- printIonWarning(`[ion-popover] - A trigger element with the ID "${trigger}" was not found in the DOM. The trigger element must be in the DOM when the "trigger" property is set on ion-popover.`, this.el);
1141
- return;
1142
- }
1143
- this.destroyTriggerInteraction = configureTriggerInteraction(triggerEl, triggerAction, el);
1144
- };
1145
- this.configureKeyboardInteraction = () => {
1146
- const { destroyKeyboardInteraction, el } = this;
1147
- if (destroyKeyboardInteraction) {
1148
- destroyKeyboardInteraction();
1149
- }
1150
- this.destroyKeyboardInteraction = configureKeyboardInteraction(el);
1151
- };
1152
- this.configureDismissInteraction = () => {
1153
- const { destroyDismissInteraction, parentPopover, triggerAction, triggerEl, el } = this;
1154
- if (!parentPopover || !triggerEl) {
1155
- return;
1156
- }
1157
- if (destroyDismissInteraction) {
1158
- destroyDismissInteraction();
1159
- }
1160
- this.destroyDismissInteraction = configureDismissInteraction(triggerEl, triggerAction, el, parentPopover);
1161
- };
1162
- }
1163
- onTriggerChange() {
1164
- this.configureTriggerInteraction();
1165
- }
1166
- onIsOpenChange(newValue, oldValue) {
1167
- if (newValue === true && oldValue === false) {
1168
- this.present();
1169
- }
1170
- else if (newValue === false && oldValue === true) {
1171
- this.dismiss();
1172
- }
1173
- }
1174
- connectedCallback() {
1175
- const { configureTriggerInteraction, el } = this;
1176
- prepareOverlay(el);
1177
- configureTriggerInteraction();
1178
- }
1179
- disconnectedCallback() {
1180
- const { destroyTriggerInteraction } = this;
1181
- if (destroyTriggerInteraction) {
1182
- destroyTriggerInteraction();
1183
- }
1184
- if (this.headerResizeObserver) {
1185
- this.headerResizeObserver.disconnect();
1186
- this.headerResizeObserver = undefined;
1187
- }
1188
- }
1189
- componentWillLoad() {
1190
- var _a, _b;
1191
- const { el } = this;
1192
- const popoverId = (_b = (_a = this.htmlAttributes) === null || _a === void 0 ? void 0 : _a.id) !== null && _b !== void 0 ? _b : setOverlayId(el);
1193
- this.parentPopover = el.closest(`ion-popover:not(#${popoverId})`);
1194
- if (this.alignment === undefined) {
1195
- this.alignment = getIonMode(this) === 'ios' ? 'center' : 'start';
1196
- }
1197
- }
1198
- componentDidLoad() {
1199
- const { parentPopover, isOpen } = this;
1200
- /**
1201
- * If popover was rendered with isOpen="true"
1202
- * then we should open popover immediately.
1203
- */
1204
- if (isOpen === true) {
1205
- raf(() => this.present());
1206
- }
1207
- if (parentPopover) {
1208
- addEventListener(parentPopover, 'ionPopoverWillDismiss', () => {
1209
- this.dismiss(undefined, undefined, false);
1210
- });
1211
- }
1212
- /**
1213
- * When binding values in frameworks such as Angular
1214
- * it is possible for the value to be set after the Web Component
1215
- * initializes but before the value watcher is set up in Stencil.
1216
- * As a result, the watcher callback may not be fired.
1217
- * We work around this by manually calling the watcher
1218
- * callback when the component has loaded and the watcher
1219
- * is configured.
1220
- */
1221
- this.configureTriggerInteraction();
1222
- }
1223
- /**
1224
- * When opening a popover from a trigger, we should not be
1225
- * modifying the `event` prop from inside the component.
1226
- * Additionally, when pressing the "Right" arrow key, we need
1227
- * to shift focus to the first descendant in the newly presented
1228
- * popover.
1229
- *
1230
- * @internal
1231
- */
1232
- async presentFromTrigger(event, focusDescendant = false) {
1233
- this.focusDescendantOnPresent = focusDescendant;
1234
- await this.present(event);
1235
- this.focusDescendantOnPresent = false;
1236
- }
1237
- /**
1238
- * Determines whether or not an overlay
1239
- * is being used inline or via a controller/JS
1240
- * and returns the correct delegate.
1241
- * By default, subsequent calls to getDelegate
1242
- * will use a cached version of the delegate.
1243
- * This is useful for calling dismiss after
1244
- * present so that the correct delegate is given.
1245
- */
1246
- getDelegate(force = false) {
1247
- if (this.workingDelegate && !force) {
1248
- return {
1249
- delegate: this.workingDelegate,
1250
- inline: this.inline,
1251
- };
1252
- }
1253
- /**
1254
- * If using overlay inline
1255
- * we potentially need to use the coreDelegate
1256
- * so that this works in vanilla JS apps.
1257
- * If a developer has presented this component
1258
- * via a controller, then we can assume
1259
- * the component is already in the
1260
- * correct place.
1261
- */
1262
- const parentEl = this.el.parentNode;
1263
- const inline = (this.inline = parentEl !== null && !this.hasController);
1264
- const delegate = (this.workingDelegate = inline ? this.delegate || this.coreDelegate : this.delegate);
1265
- return { inline, delegate };
1266
- }
1267
- /**
1268
- * Present the popover overlay after it has been created.
1269
- * Developers can pass a mouse, touch, or pointer event
1270
- * to position the popover relative to where that event
1271
- * was dispatched.
1272
- *
1273
- * @param event The event to position the popover relative to.
1274
- */
1275
- async present(event) {
1276
- const unlock = await this.lockController.lock();
1277
- if (this.presented) {
1278
- unlock();
1279
- return;
1280
- }
1281
- const { el } = this;
1282
- const { inline, delegate } = this.getDelegate(true);
1283
- /**
1284
- * Emit ionMount so JS Frameworks have an opportunity
1285
- * to add the child component to the DOM. The child
1286
- * component will be assigned to this.usersElement below.
1287
- */
1288
- this.ionMount.emit();
1289
- this.usersElement = await attachComponent(delegate, el, this.component, ['popover-viewport'], this.componentProps, inline);
1290
- this.recalculateContentOnHeaderReady();
1291
- if (!this.keyboardEvents) {
1292
- this.configureKeyboardInteraction();
1293
- }
1294
- this.configureDismissInteraction();
1295
- /**
1296
- * When using the lazy loaded build of Stencil, we need to wait
1297
- * for every Stencil component instance to be ready before presenting
1298
- * otherwise there can be a flash of unstyled content. With the
1299
- * custom elements bundle we need to wait for the JS framework
1300
- * mount the inner contents of the overlay otherwise WebKit may
1301
- * get the transition incorrect.
1302
- */
1303
- if (hasLazyBuild(el)) {
1304
- await deepReady(this.usersElement);
1305
- /**
1306
- * If keepContentsMounted="true" then the
1307
- * JS Framework has already mounted the inner
1308
- * contents so there is no need to wait.
1309
- * Otherwise, we need to wait for the JS
1310
- * Framework to mount the inner contents
1311
- * of this component.
1312
- */
1313
- }
1314
- else if (!this.keepContentsMounted) {
1315
- await waitForMount();
1316
- }
1317
- await present(this, 'popoverEnter', iosEnterAnimation, mdEnterAnimation, {
1318
- event: event || this.event,
1319
- size: this.size,
1320
- trigger: this.triggerEl,
1321
- reference: this.reference,
1322
- side: this.side,
1323
- align: this.alignment,
1324
- });
1325
- /**
1326
- * If popover is nested and was
1327
- * presented using the "Right" arrow key,
1328
- * we need to move focus to the first
1329
- * descendant inside of the popover.
1330
- */
1331
- if (this.focusDescendantOnPresent) {
1332
- focusFirstDescendant(el);
1333
- }
1334
- unlock();
1335
- }
1336
- /**
1337
- * Watch the header for height changes and trigger content dimension
1338
- * recalculation when the header has a height > 0. This sets the offset-top
1339
- * of the content to the height of the header correctly.
1340
- */
1341
- recalculateContentOnHeaderReady() {
1342
- var _a;
1343
- const popoverContent = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.popover-content');
1344
- if (!popoverContent) {
1345
- return;
1346
- }
1347
- const contentContainer = this.usersElement || popoverContent;
1348
- const header = contentContainer.querySelector('ion-header');
1349
- const contentElements = contentContainer.querySelectorAll('ion-content');
1350
- if (!header || contentElements.length === 0) {
1351
- return;
1352
- }
1353
- this.headerResizeObserver = new ResizeObserver(async () => {
1354
- var _a;
1355
- if (header.offsetHeight > 0) {
1356
- (_a = this.headerResizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
1357
- this.headerResizeObserver = undefined;
1358
- for (const contentEl of contentElements) {
1359
- await contentEl.recalculateDimensions();
1360
- }
1361
- }
1362
- });
1363
- this.headerResizeObserver.observe(header);
1364
- }
1365
- /**
1366
- * Dismiss the popover overlay after it has been presented.
1367
- * This is a no-op if the overlay has not been presented yet. If you want
1368
- * to remove an overlay from the DOM that was never presented, use the
1369
- * [remove](https://developer.mozilla.org/en-US/docs/Web/API/Element/remove) method.
1370
- *
1371
- * @param data Any data to emit in the dismiss events.
1372
- * @param role The role of the element that is dismissing the popover. For example, `cancel` or `backdrop`.
1373
- * @param dismissParentPopover If `true`, dismissing this popover will also dismiss
1374
- * a parent popover if this popover is nested. Defaults to `true`.
1375
- */
1376
- async dismiss(data, role, dismissParentPopover = true) {
1377
- const unlock = await this.lockController.lock();
1378
- const { destroyKeyboardInteraction, destroyDismissInteraction } = this;
1379
- if (dismissParentPopover && this.parentPopover) {
1380
- this.parentPopover.dismiss(data, role, dismissParentPopover);
1381
- }
1382
- const shouldDismiss = await dismiss(this, data, role, 'popoverLeave', iosLeaveAnimation, mdLeaveAnimation, this.event);
1383
- if (shouldDismiss) {
1384
- if (destroyKeyboardInteraction) {
1385
- destroyKeyboardInteraction();
1386
- this.destroyKeyboardInteraction = undefined;
1387
- }
1388
- if (destroyDismissInteraction) {
1389
- destroyDismissInteraction();
1390
- this.destroyDismissInteraction = undefined;
1391
- }
1392
- /**
1393
- * If using popover inline
1394
- * we potentially need to use the coreDelegate
1395
- * so that this works in vanilla JS apps
1396
- */
1397
- const { delegate } = this.getDelegate();
1398
- await detachComponent(delegate, this.usersElement);
1399
- }
1400
- unlock();
1401
- return shouldDismiss;
1402
- }
1403
- /**
1404
- * @internal
1405
- */
1406
- async getParentPopover() {
1407
- return this.parentPopover;
1408
- }
1409
- /**
1410
- * Returns a promise that resolves when the popover did dismiss.
1411
- */
1412
- onDidDismiss() {
1413
- return eventMethod(this.el, 'ionPopoverDidDismiss');
1414
- }
1415
- /**
1416
- * Returns a promise that resolves when the popover will dismiss.
1417
- */
1418
- onWillDismiss() {
1419
- return eventMethod(this.el, 'ionPopoverWillDismiss');
1420
- }
1421
- render() {
1422
- const mode = getIonMode(this);
1423
- const { onLifecycle, parentPopover, dismissOnSelect, side, arrow, htmlAttributes, focusTrap } = this;
1424
- const desktop = isPlatform('desktop');
1425
- const enableArrow = arrow && !parentPopover;
1426
- return (h(Host, Object.assign({ key: '42863f748c93f709d433931d969230137b37d42d', "aria-modal": "true", "no-router": true, tabindex: "-1" }, htmlAttributes, { style: {
1427
- zIndex: `${20000 + this.overlayIndex}`,
1428
- }, class: Object.assign(Object.assign({}, getClassMap(this.cssClass)), { [mode]: true, 'popover-translucent': this.translucent, 'overlay-hidden': true, 'popover-desktop': desktop, [`popover-side-${side}`]: true, [FOCUS_TRAP_DISABLE_CLASS]: focusTrap === false, 'popover-nested': !!parentPopover }), onIonPopoverDidPresent: onLifecycle, onIonPopoverWillPresent: onLifecycle, onIonPopoverWillDismiss: onLifecycle, onIonPopoverDidDismiss: onLifecycle, onIonBackdropTap: this.onBackdropTap }), !parentPopover && h("ion-backdrop", { key: '22b6d82178b52158b76ab3fd9a7dd738fd6e4bbf', tappable: this.backdropDismiss, visible: this.showBackdrop, part: "backdrop" }), h("div", { key: 'b76335c64e992a964ed3fb91d17a992c3474b4cd', class: "popover-wrapper ion-overlay-wrapper", onClick: dismissOnSelect ? () => this.dismiss() : undefined }, enableArrow && h("div", { key: '018c846c32e7ff7fa010528e6b37a17e5f03c84c', class: "popover-arrow", part: "arrow" }), h("div", { key: '350c468c80052da3a07768bceab98fe159c35a43', class: "popover-content", part: "content" }, h("slot", { key: '686443c17ac9873d33905c1cdb67e6d6da675282' })))));
1429
- }
1430
- get el() { return this; }
1431
- static get watchers() { return {
1432
- "trigger": ["onTriggerChange"],
1433
- "triggerAction": ["onTriggerChange"],
1434
- "isOpen": ["onIsOpenChange"]
1435
- }; }
1436
- static get style() { return {
1437
- ios: popoverIosCss,
1438
- md: popoverMdCss
1439
- }; }
1440
- }, [289, "ion-popover", {
1441
- "hasController": [4, "has-controller"],
1442
- "delegate": [16],
1443
- "overlayIndex": [2, "overlay-index"],
1444
- "enterAnimation": [16],
1445
- "leaveAnimation": [16],
1446
- "component": [1],
1447
- "componentProps": [16],
1448
- "keyboardClose": [4, "keyboard-close"],
1449
- "cssClass": [1, "css-class"],
1450
- "backdropDismiss": [4, "backdrop-dismiss"],
1451
- "event": [8],
1452
- "showBackdrop": [4, "show-backdrop"],
1453
- "translucent": [4],
1454
- "animated": [4],
1455
- "htmlAttributes": [16],
1456
- "triggerAction": [1, "trigger-action"],
1457
- "trigger": [1],
1458
- "size": [1],
1459
- "dismissOnSelect": [4, "dismiss-on-select"],
1460
- "reference": [1],
1461
- "side": [1],
1462
- "alignment": [1025],
1463
- "arrow": [4],
1464
- "isOpen": [4, "is-open"],
1465
- "keyboardEvents": [4, "keyboard-events"],
1466
- "focusTrap": [4, "focus-trap"],
1467
- "keepContentsMounted": [4, "keep-contents-mounted"],
1468
- "presented": [32],
1469
- "presentFromTrigger": [64],
1470
- "present": [64],
1471
- "dismiss": [64],
1472
- "getParentPopover": [64],
1473
- "onDidDismiss": [64],
1474
- "onWillDismiss": [64]
1475
- }, undefined, {
1476
- "trigger": ["onTriggerChange"],
1477
- "triggerAction": ["onTriggerChange"],
1478
- "isOpen": ["onIsOpenChange"]
1479
- }]);
1480
- const LIFECYCLE_MAP = {
1481
- ionPopoverDidPresent: 'ionViewDidEnter',
1482
- ionPopoverWillPresent: 'ionViewWillEnter',
1483
- ionPopoverWillDismiss: 'ionViewWillLeave',
1484
- ionPopoverDidDismiss: 'ionViewDidLeave',
1485
- };
1486
- function defineCustomElement() {
1487
- if (typeof customElements === "undefined") {
1488
- return;
1489
- }
1490
- const components = ["ion-popover", "ion-backdrop"];
1491
- components.forEach(tagName => { switch (tagName) {
1492
- case "ion-popover":
1493
- if (!customElements.get(tagName)) {
1494
- customElements.define(tagName, Popover);
1495
- }
1496
- break;
1497
- case "ion-backdrop":
1498
- if (!customElements.get(tagName)) {
1499
- defineCustomElement$1();
1500
- }
1501
- break;
1502
- } });
1503
- }
1504
-
1505
- export { Popover as P, defineCustomElement as d };
4
+ import{proxyCustomElement as t,HTMLElement as e,createEvent as o,h as r,Host as i,transformTag as s}from"@stencil/core/internal/client";import{B as n,j as a,k as p,f as c,n as d,g as l,h,F as v}from"./overlays.js";import{C as f,a as g,d as m}from"./framework-delegate.js";import{g as b,r as u,a as x,k as w}from"./helpers.js";import{c as k}from"./lock-controller.js";import{p as y}from"./index4.js";import{b as P,a as D}from"./ionic-global.js";import{g as T}from"./theme.js";import{e as A,w as I}from"./index2.js";import{c as C}from"./animation.js";import{d as O}from"./backdrop.js";const $=(t,e,o)=>{const r=e.getBoundingClientRect(),i=r.height;let s=r.width;return"cover"===t&&o&&(s=o.getBoundingClientRect().width),{contentWidth:s,contentHeight:i}},W=(t,e)=>e&&"ION-ITEM"===e.tagName?t.findIndex((t=>t===e)):-1,L=t=>{const e=b(t).querySelector("button");e&&u((()=>e.focus()))},N=(t,e,o,r,i,s,n,a,p,c,d)=>{var l;let h={top:0,left:0,width:0,height:0};if("event"===s){if(!d)return p;h={top:d.clientY,left:d.clientX,width:1,height:1}}else{const t=c||(null===(l=null==d?void 0:d.detail)||void 0===l?void 0:l.ionShadowTarget)||(null==d?void 0:d.target);if(!t)return p;const e=t.getBoundingClientRect();h={top:e.top,left:e.left,width:e.width,height:e.height}}const v=Y(n,h,e,o,r,i,t),f=H(a,n,h,e,o),g=v.top+f.top,m=v.left+f.left,{arrowTop:b,arrowLeft:u}=X(n,r,i,g,m,e,o,t),{originX:x,originY:w}=j(n,a,t);return{top:g,left:m,referenceCoordinates:h,arrowTop:b,arrowLeft:u,originX:x,originY:w}},j=(t,e,o)=>{switch(t){case"top":return{originX:E(e),originY:"bottom"};case"bottom":return{originX:E(e),originY:"top"};case"left":return{originX:"right",originY:z(e)};case"right":return{originX:"left",originY:z(e)};case"start":return{originX:o?"left":"right",originY:z(e)};case"end":return{originX:o?"right":"left",originY:z(e)}}},E=t=>{switch(t){case"start":return"left";case"center":return"center";case"end":return"right"}},z=t=>{switch(t){case"start":return"top";case"center":return"center";case"end":return"bottom"}},X=(t,e,o,r,i,s,n,a)=>{const p={arrowTop:r+n/2-e/2,arrowLeft:i+s-e/2},c={arrowTop:r+n/2-e/2,arrowLeft:i-1.5*e};switch(t){case"top":return{arrowTop:r+n,arrowLeft:i+s/2-e/2};case"bottom":return{arrowTop:r-o,arrowLeft:i+s/2-e/2};case"left":return p;case"right":return c;case"start":return a?c:p;case"end":return a?p:c;default:return{arrowTop:0,arrowLeft:0}}},Y=(t,e,o,r,i,s,n)=>{const a={top:e.top,left:e.left-o-i},p={top:e.top,left:e.left+e.width+i};switch(t){case"top":return{top:e.top-r-s,left:e.left};case"right":return p;case"bottom":return{top:e.top+e.height+s,left:e.left};case"left":return a;case"start":return n?p:a;case"end":return n?a:p}},H=(t,e,o,r,i)=>{switch(t){case"center":return R(e,o,r,i);case"end":return M(e,o,r,i);default:return{top:0,left:0}}},M=(t,e,o,r)=>{switch(t){case"start":case"end":case"left":case"right":return{top:-(r-e.height),left:0};default:return{top:0,left:-(o-e.width)}}},R=(t,e,o,r)=>{switch(t){case"start":case"end":case"left":case"right":return{top:-(r/2-e.height/2),left:0};default:return{top:0,left:-(o/2-e.width/2)}}},S=(t,e,o,r,i,s,n,a,p,c,d,l,h=0,v=0,f=0)=>{let g=h;const m=v;let b,u=o,x=e,w=c,k=d,y=!1,P=!1;const D=l?l.top+l.height:s/2-a/2,T=l?l.height:0;let A=!1;return u<r+p?(u=r,y=!0,w="left"):n+r+u+p>i&&(P=!0,u=i-n-r,w="right"),D+T+a>s&&("top"===t||"bottom"===t)&&(D-a>0?(x=Math.max(12,D-a-T-(f-1)),g=x+a,k="bottom",A=!0):b=r),{top:x,left:u,bottom:b,originX:w,originY:k,checkSafeAreaLeft:y,checkSafeAreaRight:P,arrowTop:g,arrowLeft:m,addPopoverBottomClass:A}},B=(t,e)=>{var o;const{event:r,size:i,trigger:s,reference:n,side:a,align:p}=e,c=t.ownerDocument,d="rtl"===c.dir,l=c.defaultView.innerWidth,h=c.defaultView.innerHeight,v=b(t),f=v.querySelector(".popover-content"),g=v.querySelector(".popover-arrow"),m=s||(null===(o=null==r?void 0:r.detail)||void 0===o?void 0:o.ionShadowTarget)||(null==r?void 0:r.target),{contentWidth:u,contentHeight:x}=$(i,f,m),{arrowWidth:w,arrowHeight:k}=(t=>{if(!t)return{arrowWidth:0,arrowHeight:0};const{width:e,height:o}=t.getBoundingClientRect();return{arrowWidth:e,arrowHeight:o}})(g),y=N(d,u,x,w,k,n,a,p,{top:h/2-x/2,left:l/2-u/2,originX:d?"right":"left",originY:"top"},s,r),P="cover"===i?0:5,D="cover"===i?0:25,{originX:T,originY:A,top:I,left:O,bottom:W,checkSafeAreaLeft:L,checkSafeAreaRight:j,arrowTop:E,arrowLeft:z,addPopoverBottomClass:X}=S(a,y.top,y.left,P,l,h,u,x,D,y.originX,y.originY,y.referenceCoordinates,y.arrowTop,y.arrowLeft,k),Y=C(),H=C(),M=C();return H.addElement(v.querySelector("ion-backdrop")).fromTo("opacity",.01,"var(--backdrop-opacity)").beforeStyles({"pointer-events":"none"}).afterClearStyles(["pointer-events"]),M.addElement(v.querySelector(".popover-arrow")).addElement(v.querySelector(".popover-content")).fromTo("opacity",.01,1),Y.easing("ease").duration(100).beforeAddWrite((()=>{"cover"===i&&t.style.setProperty("--width",`${u}px`),X&&t.classList.add("popover-bottom"),void 0!==W&&f.style.setProperty("bottom",`${W}px`);let e=`${O}px`;if(L&&(e=`${O}px + var(--ion-safe-area-left, 0)`),j&&(e=`${O}px - var(--ion-safe-area-right, 0)`),f.style.setProperty("top",`calc(${I}px + var(--offset-y, 0))`),f.style.setProperty("left",`calc(${e} + var(--offset-x, 0))`),f.style.setProperty("transform-origin",`${A} ${T}`),null!==g){const t=((t,e=!1,o,r)=>!(!o&&!r||"top"!==t&&"bottom"!==t&&e))(a,y.top!==I||y.left!==O,r,s);t?(g.style.setProperty("top",`calc(${E}px + var(--offset-y, 0))`),g.style.setProperty("left",`calc(${z}px + var(--offset-x, 0))`)):g.style.setProperty("display","none")}})).addAnimation([H,M])},V=t=>{const e=b(t),o=e.querySelector(".popover-content"),r=e.querySelector(".popover-arrow"),i=C(),s=C(),n=C();return s.addElement(e.querySelector("ion-backdrop")).fromTo("opacity","var(--backdrop-opacity)",0),n.addElement(e.querySelector(".popover-arrow")).addElement(e.querySelector(".popover-content")).fromTo("opacity",.99,0),i.easing("ease").afterAddWrite((()=>{t.style.removeProperty("--width"),t.classList.remove("popover-bottom"),o.style.removeProperty("top"),o.style.removeProperty("left"),o.style.removeProperty("bottom"),o.style.removeProperty("transform-origin"),r&&(r.style.removeProperty("top"),r.style.removeProperty("left"),r.style.removeProperty("display"))})).duration(300).addAnimation([s,n])},F=(t,e)=>{var o;const{event:r,size:i,trigger:s,reference:n,side:a,align:p}=e,c=t.ownerDocument,d="rtl"===c.dir,l=c.defaultView.innerWidth,h=c.defaultView.innerHeight,v=b(t),f=v.querySelector(".popover-content"),g=s||(null===(o=null==r?void 0:r.detail)||void 0===o?void 0:o.ionShadowTarget)||(null==r?void 0:r.target),{contentWidth:m,contentHeight:u}=$(i,f,g),x=N(d,m,u,0,0,n,a,p,{top:h/2-u/2,left:l/2-m/2,originX:d?"right":"left",originY:"top"},s,r),w="cover"===i?0:12,{originX:k,originY:y,top:P,left:D,bottom:T}=S(a,x.top,x.left,w,l,h,m,u,0,x.originX,x.originY,x.referenceCoordinates),A=C(),I=C(),O=C(),W=C(),L=C();return I.addElement(v.querySelector("ion-backdrop")).fromTo("opacity",.01,"var(--backdrop-opacity)").beforeStyles({"pointer-events":"none"}).afterClearStyles(["pointer-events"]),O.addElement(v.querySelector(".popover-wrapper")).duration(150).fromTo("opacity",.01,1),W.addElement(f).beforeStyles({top:`calc(${P}px + var(--offset-y, 0px))`,left:`calc(${D}px + var(--offset-x, 0px))`,"transform-origin":`${y} ${k}`}).beforeAddWrite((()=>{void 0!==T&&f.style.setProperty("bottom",`${T}px`)})).fromTo("transform","scale(0.8)","scale(1)"),L.addElement(v.querySelector(".popover-viewport")).fromTo("opacity",.01,1),A.easing("cubic-bezier(0.36,0.66,0.04,1)").duration(300).beforeAddWrite((()=>{"cover"===i&&t.style.setProperty("--width",`${m}px`),"bottom"===y&&t.classList.add("popover-bottom")})).addAnimation([I,O,W,L])},K=t=>{const e=b(t),o=e.querySelector(".popover-content"),r=C(),i=C(),s=C();return i.addElement(e.querySelector("ion-backdrop")).fromTo("opacity","var(--backdrop-opacity)",0),s.addElement(e.querySelector(".popover-wrapper")).fromTo("opacity",.99,0),r.easing("ease").afterAddWrite((()=>{t.style.removeProperty("--width"),t.classList.remove("popover-bottom"),o.style.removeProperty("top"),o.style.removeProperty("left"),o.style.removeProperty("bottom"),o.style.removeProperty("transform-origin")})).duration(150).addAnimation([i,s])},U=t(class extends e{constructor(t){super(),!1!==t&&this.__registerHost(),this.__attachShadow(),this.didPresent=o(this,"ionPopoverDidPresent",7),this.willPresent=o(this,"ionPopoverWillPresent",7),this.willDismiss=o(this,"ionPopoverWillDismiss",7),this.didDismiss=o(this,"ionPopoverDidDismiss",7),this.didPresentShorthand=o(this,"didPresent",7),this.willPresentShorthand=o(this,"willPresent",7),this.willDismissShorthand=o(this,"willDismiss",7),this.didDismissShorthand=o(this,"didDismiss",7),this.ionMount=o(this,"ionMount",7),this.parentPopover=null,this.coreDelegate=f(),this.lockController=k(),this.inline=!1,this.focusDescendantOnPresent=!1,this.presented=!1,this.hasController=!1,this.keyboardClose=!0,this.backdropDismiss=!0,this.showBackdrop=!0,this.translucent=!1,this.animated=!0,this.triggerAction="click",this.size="auto",this.dismissOnSelect=!1,this.reference="trigger",this.side="bottom",this.arrow=!0,this.isOpen=!1,this.keyboardEvents=!1,this.focusTrap=!0,this.keepContentsMounted=!1,this.onBackdropTap=()=>{this.dismiss(void 0,n)},this.onLifecycle=t=>{const e=this.usersElement,o=q[t.type];if(e&&o){const r=new CustomEvent(o,{bubbles:!1,cancelable:!1,detail:t.detail});e.dispatchEvent(r)}},this.configureTriggerInteraction=()=>{const{trigger:t,triggerAction:e,el:o,destroyTriggerInteraction:r}=this;if(r&&r(),void 0===t)return;const i=this.triggerEl=void 0!==t?document.getElementById(t):null;i?this.destroyTriggerInteraction=((t,e,o)=>{let r=[];switch(e){case"hover":let t;r=[{eventName:"mouseenter",callback:async e=>{e.stopPropagation(),t&&clearTimeout(t),t=setTimeout((()=>{u((()=>{o.presentFromTrigger(e),t=void 0}))}),100)}},{eventName:"mouseleave",callback:e=>{t&&clearTimeout(t);const r=e.relatedTarget;r&&r.closest("ion-popover")!==o&&o.dismiss(void 0,void 0,!1)}},{eventName:"click",callback:t=>t.stopPropagation()},{eventName:"ionPopoverActivateTrigger",callback:t=>o.presentFromTrigger(t,!0)}];break;case"context-menu":r=[{eventName:"contextmenu",callback:t=>{t.preventDefault(),o.presentFromTrigger(t)}},{eventName:"click",callback:t=>t.stopPropagation()},{eventName:"ionPopoverActivateTrigger",callback:t=>o.presentFromTrigger(t,!0)}];break;default:r=[{eventName:"click",callback:t=>o.presentFromTrigger(t)},{eventName:"ionPopoverActivateTrigger",callback:t=>o.presentFromTrigger(t,!0)}]}return r.forEach((({eventName:e,callback:o})=>t.addEventListener(e,o))),t.setAttribute("data-ion-popover-trigger","true"),()=>{r.forEach((({eventName:e,callback:o})=>t.removeEventListener(e,o))),t.removeAttribute("data-ion-popover-trigger")}})(i,e,o):y(`[ion-popover] - A trigger element with the ID "${t}" was not found in the DOM. The trigger element must be in the DOM when the "trigger" property is set on ion-popover.`,this.el)},this.configureKeyboardInteraction=()=>{const{destroyKeyboardInteraction:t,el:e}=this;t&&t(),this.destroyKeyboardInteraction=(t=>{const e=async e=>{var o;const r=document.activeElement;let i=[];const s=null===(o=e.target)||void 0===o?void 0:o.tagName;if("ION-POPOVER"===s||"ION-ITEM"===s){try{i=Array.from(t.querySelectorAll("ion-item:not(ion-popover ion-popover *):not([disabled])"))}catch(t){}switch(e.key){case"ArrowLeft":await t.getParentPopover()&&t.dismiss(void 0,void 0,!1);break;case"ArrowDown":e.preventDefault();const o=((t,e)=>t[W(t,e)+1])(i,r);void 0!==o&&L(o);break;case"ArrowUp":e.preventDefault();const s=((t,e)=>t[W(t,e)-1])(i,r);void 0!==s&&L(s);break;case"Home":e.preventDefault();const n=i[0];void 0!==n&&L(n);break;case"End":e.preventDefault();const a=i[i.length-1];void 0!==a&&L(a);break;case"ArrowRight":case" ":case"Enter":if(r&&r.hasAttribute("data-ion-popover-trigger")){const t=new CustomEvent("ionPopoverActivateTrigger");r.dispatchEvent(t)}}}};return t.addEventListener("keydown",e),()=>t.removeEventListener("keydown",e)})(e)},this.configureDismissInteraction=()=>{const{destroyDismissInteraction:t,parentPopover:e,triggerAction:o,triggerEl:r,el:i}=this;e&&r&&(t&&t(),this.destroyDismissInteraction=((t,e,o,r)=>{let i=[];const s=b(r).querySelector(".popover-content");return i="hover"===e?[{eventName:"mouseenter",callback:e=>{document.elementFromPoint(e.clientX,e.clientY)!==t&&o.dismiss(void 0,void 0,!1)}}]:[{eventName:"click",callback:e=>{e.target.closest("[data-ion-popover-trigger]")!==t?o.dismiss(void 0,void 0,!1):e.stopPropagation()}}],i.forEach((({eventName:t,callback:e})=>s.addEventListener(t,e))),()=>{i.forEach((({eventName:t,callback:e})=>s.removeEventListener(t,e)))}})(r,o,i,e))}}onTriggerChange(){this.configureTriggerInteraction()}onIsOpenChange(t,e){!0===t&&!1===e?this.present():!1===t&&!0===e&&this.dismiss()}connectedCallback(){const{configureTriggerInteraction:t,el:e}=this;a(e),t()}disconnectedCallback(){const{destroyTriggerInteraction:t}=this;t&&t(),this.headerResizeObserver&&(this.headerResizeObserver.disconnect(),this.headerResizeObserver=void 0)}componentWillLoad(){var t,e;const{el:o}=this,r=null!==(e=null===(t=this.htmlAttributes)||void 0===t?void 0:t.id)&&void 0!==e?e:p(o);this.parentPopover=o.closest(`ion-popover:not(#${r})`),void 0===this.alignment&&(this.alignment="ios"===P(this)?"center":"start")}componentDidLoad(){const{parentPopover:t,isOpen:e}=this;!0===e&&u((()=>this.present())),t&&x(t,"ionPopoverWillDismiss",(()=>{this.dismiss(void 0,void 0,!1)})),this.configureTriggerInteraction()}async presentFromTrigger(t,e=!1){this.focusDescendantOnPresent=e,await this.present(t),this.focusDescendantOnPresent=!1}getDelegate(t=!1){if(this.workingDelegate&&!t)return{delegate:this.workingDelegate,inline:this.inline};const e=this.inline=null!==this.el.parentNode&&!this.hasController;return{inline:e,delegate:this.workingDelegate=e?this.delegate||this.coreDelegate:this.delegate}}async present(t){const e=await this.lockController.lock();if(this.presented)return void e();const{el:o}=this,{inline:r,delegate:i}=this.getDelegate(!0);this.ionMount.emit(),this.usersElement=await g(i,o,this.component,["popover-viewport"],this.componentProps,r),this.recalculateContentOnHeaderReady(),this.keyboardEvents||this.configureKeyboardInteraction(),this.configureDismissInteraction(),w(o)?await A(this.usersElement):this.keepContentsMounted||await I(),await c(this,"popoverEnter",B,F,{event:t||this.event,size:this.size,trigger:this.triggerEl,reference:this.reference,side:this.side,align:this.alignment}),this.focusDescendantOnPresent&&d(o),e()}recalculateContentOnHeaderReady(){var t;const e=null===(t=this.el.shadowRoot)||void 0===t?void 0:t.querySelector(".popover-content");if(!e)return;const o=this.usersElement||e,r=o.querySelector("ion-header"),i=o.querySelectorAll("ion-content");r&&0!==i.length&&(this.headerResizeObserver=new ResizeObserver((async()=>{var t;if(r.offsetHeight>0){null===(t=this.headerResizeObserver)||void 0===t||t.disconnect(),this.headerResizeObserver=void 0;for(const t of i)await t.recalculateDimensions()}})),this.headerResizeObserver.observe(r))}async dismiss(t,e,o=!0){const r=await this.lockController.lock(),{destroyKeyboardInteraction:i,destroyDismissInteraction:s}=this;o&&this.parentPopover&&this.parentPopover.dismiss(t,e,o);const n=await l(this,t,e,"popoverLeave",V,K,this.event);if(n){i&&(i(),this.destroyKeyboardInteraction=void 0),s&&(s(),this.destroyDismissInteraction=void 0);const{delegate:t}=this.getDelegate();await m(t,this.usersElement)}return r(),n}async getParentPopover(){return this.parentPopover}onDidDismiss(){return h(this.el,"ionPopoverDidDismiss")}onWillDismiss(){return h(this.el,"ionPopoverWillDismiss")}render(){const t=P(this),{onLifecycle:e,parentPopover:o,dismissOnSelect:s,side:n,arrow:a,htmlAttributes:p,focusTrap:c}=this,d=D("desktop"),l=a&&!o;return r(i,Object.assign({key:"42863f748c93f709d433931d969230137b37d42d","aria-modal":"true","no-router":!0,tabindex:"-1"},p,{style:{zIndex:`${2e4+this.overlayIndex}`},class:Object.assign(Object.assign({},T(this.cssClass)),{[t]:!0,"popover-translucent":this.translucent,"overlay-hidden":!0,"popover-desktop":d,[`popover-side-${n}`]:!0,[v]:!1===c,"popover-nested":!!o}),onIonPopoverDidPresent:e,onIonPopoverWillPresent:e,onIonPopoverWillDismiss:e,onIonPopoverDidDismiss:e,onIonBackdropTap:this.onBackdropTap}),!o&&r("ion-backdrop",{key:"22b6d82178b52158b76ab3fd9a7dd738fd6e4bbf",tappable:this.backdropDismiss,visible:this.showBackdrop,part:"backdrop"}),r("div",{key:"b76335c64e992a964ed3fb91d17a992c3474b4cd",class:"popover-wrapper ion-overlay-wrapper",onClick:s?()=>this.dismiss():void 0},l&&r("div",{key:"018c846c32e7ff7fa010528e6b37a17e5f03c84c",class:"popover-arrow",part:"arrow"}),r("div",{key:"350c468c80052da3a07768bceab98fe159c35a43",class:"popover-content",part:"content"},r("slot",{key:"686443c17ac9873d33905c1cdb67e6d6da675282"}))))}get el(){return this}static get watchers(){return{trigger:[{onTriggerChange:0}],triggerAction:[{onTriggerChange:0}],isOpen:[{onIsOpenChange:0}]}}static get style(){return{ios:':host{--background:var(--ion-background-color, #fff);--min-width:0;--min-height:0;--max-width:auto;--height:auto;--offset-x:0px;--offset-y:0px;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;color:var(--ion-text-color, #000);z-index:1001}:host(.popover-nested){pointer-events:none}:host(.popover-nested) .popover-wrapper{pointer-events:auto}:host(.overlay-hidden){display:none}.popover-wrapper{z-index:10}.popover-content{display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);overflow:auto;z-index:10}::slotted(.popover-viewport){--ion-safe-area-top:0px;--ion-safe-area-right:0px;--ion-safe-area-bottom:0px;--ion-safe-area-left:0px;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}:host(.popover-nested.popover-side-left){--offset-x:5px}:host(.popover-nested.popover-side-right){--offset-x:-5px}:host(.popover-nested.popover-side-start){--offset-x:5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-start),:host-context([dir=rtl]).popover-nested.popover-side-start{--offset-x:-5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-start:dir(rtl)){--offset-x:-5px}}:host(.popover-nested.popover-side-end){--offset-x:-5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-end),:host-context([dir=rtl]).popover-nested.popover-side-end{--offset-x:5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-end:dir(rtl)){--offset-x:5px}}:host{--width:200px;--max-height:90%;--box-shadow:none;--backdrop-opacity:var(--ion-backdrop-opacity, 0.08)}:host(.popover-desktop){--box-shadow:0px 4px 16px 0px rgba(0, 0, 0, 0.12)}.popover-content{border-radius:10px}:host(.popover-desktop) .popover-content{border:0.5px solid var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}.popover-arrow{display:block;position:absolute;width:20px;height:10px;overflow:hidden;z-index:11}.popover-arrow::after{top:3px;border-radius:3px;position:absolute;width:14px;height:14px;-webkit-transform:rotate(45deg);transform:rotate(45deg);background:var(--background);content:"";z-index:10}.popover-arrow::after{inset-inline-start:3px}:host(.popover-bottom) .popover-arrow{top:auto;bottom:-10px}:host(.popover-bottom) .popover-arrow::after{top:-6px}:host(.popover-side-left) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}:host(.popover-side-right) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}:host(.popover-side-top) .popover-arrow{-webkit-transform:rotate(180deg);transform:rotate(180deg)}:host(.popover-side-start) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}:host-context([dir=rtl]):host(.popover-side-start) .popover-arrow,:host-context([dir=rtl]).popover-side-start .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}@supports selector(:dir(rtl)){:host(.popover-side-start:dir(rtl)) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}}:host(.popover-side-end) .popover-arrow{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}:host-context([dir=rtl]):host(.popover-side-end) .popover-arrow,:host-context([dir=rtl]).popover-side-end .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}@supports selector(:dir(rtl)){:host(.popover-side-end:dir(rtl)) .popover-arrow{-webkit-transform:rotate(90deg);transform:rotate(90deg)}}.popover-arrow,.popover-content{opacity:0}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){:host(.popover-translucent) .popover-content,:host(.popover-translucent) .popover-arrow::after{background:rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}}',md:":host{--background:var(--ion-background-color, #fff);--min-width:0;--min-height:0;--max-width:auto;--height:auto;--offset-x:0px;--offset-y:0px;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:fixed;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;outline:none;color:var(--ion-text-color, #000);z-index:1001}:host(.popover-nested){pointer-events:none}:host(.popover-nested) .popover-wrapper{pointer-events:auto}:host(.overlay-hidden){display:none}.popover-wrapper{z-index:10}.popover-content{display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);background:var(--background);-webkit-box-shadow:var(--box-shadow);box-shadow:var(--box-shadow);overflow:auto;z-index:10}::slotted(.popover-viewport){--ion-safe-area-top:0px;--ion-safe-area-right:0px;--ion-safe-area-bottom:0px;--ion-safe-area-left:0px;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}:host(.popover-nested.popover-side-left){--offset-x:5px}:host(.popover-nested.popover-side-right){--offset-x:-5px}:host(.popover-nested.popover-side-start){--offset-x:5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-start),:host-context([dir=rtl]).popover-nested.popover-side-start{--offset-x:-5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-start:dir(rtl)){--offset-x:-5px}}:host(.popover-nested.popover-side-end){--offset-x:-5px}:host-context([dir=rtl]):host(.popover-nested.popover-side-end),:host-context([dir=rtl]).popover-nested.popover-side-end{--offset-x:5px}@supports selector(:dir(rtl)){:host(.popover-nested.popover-side-end:dir(rtl)){--offset-x:5px}}:host{--width:250px;--max-height:90%;--box-shadow:0 5px 5px -3px rgba(0, 0, 0, 0.2), 0 8px 10px 1px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12);--backdrop-opacity:var(--ion-backdrop-opacity, 0.32)}.popover-content{border-radius:4px;-webkit-transform-origin:left top;transform-origin:left top}:host-context([dir=rtl]) .popover-content{-webkit-transform-origin:right top;transform-origin:right top}[dir=rtl] .popover-content{-webkit-transform-origin:right top;transform-origin:right top}@supports selector(:dir(rtl)){.popover-content:dir(rtl){-webkit-transform-origin:right top;transform-origin:right top}}.popover-viewport{-webkit-transition-delay:100ms;transition-delay:100ms}.popover-wrapper{opacity:0}"}}},[289,"ion-popover",{hasController:[4,"has-controller"],delegate:[16],overlayIndex:[2,"overlay-index"],enterAnimation:[16],leaveAnimation:[16],component:[1],componentProps:[16],keyboardClose:[4,"keyboard-close"],cssClass:[1,"css-class"],backdropDismiss:[4,"backdrop-dismiss"],event:[8],showBackdrop:[4,"show-backdrop"],translucent:[4],animated:[4],htmlAttributes:[16],triggerAction:[1,"trigger-action"],trigger:[1],size:[1],dismissOnSelect:[4,"dismiss-on-select"],reference:[1],side:[1],alignment:[1025],arrow:[4],isOpen:[4,"is-open"],keyboardEvents:[4,"keyboard-events"],focusTrap:[4,"focus-trap"],keepContentsMounted:[4,"keep-contents-mounted"],presented:[32],presentFromTrigger:[64],present:[64],dismiss:[64],getParentPopover:[64],onDidDismiss:[64],onWillDismiss:[64]},void 0,{trigger:[{onTriggerChange:0}],triggerAction:[{onTriggerChange:0}],isOpen:[{onIsOpenChange:0}]}]),q={ionPopoverDidPresent:"ionViewDidEnter",ionPopoverWillPresent:"ionViewWillEnter",ionPopoverWillDismiss:"ionViewWillLeave",ionPopoverDidDismiss:"ionViewDidLeave"};function G(){"undefined"!=typeof customElements&&["ion-popover","ion-backdrop"].forEach((t=>{switch(t){case"ion-popover":customElements.get(s(t))||customElements.define(s(t),U);break;case"ion-backdrop":customElements.get(s(t))||O()}}))}export{U as P,G as d}