@ionic/react 8.8.9-dev.11780604658.184bb991 → 8.8.9-dev.11780683233.1c5e9d9b

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 (83) hide show
  1. package/css/core.css +1 -1
  2. package/css/core.css.map +1 -1
  3. package/css/display.css +1 -1
  4. package/css/display.css.map +1 -1
  5. package/css/flex-utils.css +1 -1
  6. package/css/flex-utils.css.map +1 -1
  7. package/css/float-elements.css.map +1 -1
  8. package/css/global.bundle.css.map +1 -1
  9. package/css/ionic/bundle.ionic.css +1 -0
  10. package/css/ionic/bundle.ionic.css.map +1 -0
  11. package/css/ionic/core.ionic.css +1 -0
  12. package/css/ionic/core.ionic.css.map +1 -0
  13. package/css/ionic/global.bundle.ionic.css +1 -0
  14. package/css/ionic/global.bundle.ionic.css.map +1 -0
  15. package/css/ionic/ionic-swiper.ionic.css +1 -0
  16. package/css/ionic/ionic-swiper.ionic.css.map +1 -0
  17. package/css/ionic/link.ionic.css +1 -0
  18. package/css/ionic/link.ionic.css.map +1 -0
  19. package/css/ionic/structure.ionic.css +1 -0
  20. package/css/ionic/structure.ionic.css.map +1 -0
  21. package/css/ionic/typography.ionic.css +1 -0
  22. package/css/ionic/typography.ionic.css.map +1 -0
  23. package/css/ionic/utils.bundle.ionic.css +1 -0
  24. package/css/ionic/utils.bundle.ionic.css.map +1 -0
  25. package/css/ionic-swiper.css +1 -1
  26. package/css/ionic-swiper.css.map +1 -1
  27. package/css/ionic.bundle.css +1 -1
  28. package/css/ionic.bundle.css.map +1 -1
  29. package/css/normalize.css.map +1 -1
  30. package/css/padding.css.map +1 -1
  31. package/css/palettes/dark.always.css.map +1 -1
  32. package/css/palettes/dark.class.css.map +1 -1
  33. package/css/palettes/dark.system.css.map +1 -1
  34. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  35. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  36. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  37. package/css/palettes/high-contrast.always.css.map +1 -1
  38. package/css/palettes/high-contrast.class.css.map +1 -1
  39. package/css/palettes/high-contrast.system.css.map +1 -1
  40. package/css/structure.css.map +1 -1
  41. package/css/text-alignment.css.map +1 -1
  42. package/css/text-transformation.css.map +1 -1
  43. package/css/typography.css.map +1 -1
  44. package/css/utils.bundle.css +1 -1
  45. package/css/utils.bundle.css.map +1 -1
  46. package/dist/index.js +321 -1007
  47. package/dist/index.js.map +1 -1
  48. package/dist/types/components/IonActionSheet.d.ts +1 -1
  49. package/dist/types/components/IonAlert.d.ts +1 -1
  50. package/dist/types/components/IonIcon.d.ts +1 -1
  51. package/dist/types/components/IonLoading.d.ts +1 -1
  52. package/dist/types/components/IonModal.d.ts +1 -1
  53. package/dist/types/components/IonPage.d.ts +1 -1
  54. package/dist/types/components/IonPickerLegacy.d.ts +2 -0
  55. package/dist/types/components/IonPopover.d.ts +1 -1
  56. package/dist/types/components/IonRedirect.d.ts +16 -0
  57. package/dist/types/components/IonRoute.d.ts +2 -3
  58. package/dist/types/components/IonRouterContext.d.ts +0 -8
  59. package/dist/types/components/IonRouterOutlet.d.ts +2 -3
  60. package/dist/types/components/IonToast.d.ts +1 -1
  61. package/dist/types/components/createInlineOverlayComponent.d.ts +1 -1
  62. package/dist/types/components/createRoutingComponent.d.ts +1 -1
  63. package/dist/types/components/index.d.ts +5 -2
  64. package/dist/types/components/navigation/IonNav.d.ts +1 -2
  65. package/dist/types/components/navigation/IonTabBar.d.ts +1 -1
  66. package/dist/types/components/navigation/IonTabs.d.ts +2 -1
  67. package/dist/types/components/proxies.d.ts +76 -0
  68. package/dist/types/components/react-component-lib/createComponent.d.ts +1 -1
  69. package/dist/types/components/react-component-lib/utils/index.d.ts +1 -1
  70. package/dist/types/components/routing-proxies.d.ts +7 -7
  71. package/dist/types/components/utils/index.d.ts +11 -2
  72. package/dist/types/contexts/NavContext.d.ts +2 -0
  73. package/dist/types/hooks/useIonPicker.d.ts +27 -0
  74. package/dist/types/lifecycle/IonLifeCycleHOC.d.ts +3 -1
  75. package/dist/types/routing/LocationHistory.d.ts +0 -7
  76. package/dist/types/routing/NavManager.d.ts +4 -2
  77. package/dist/types/routing/OutletPageManager.d.ts +0 -2
  78. package/dist/types/routing/PageManager.d.ts +0 -8
  79. package/dist/types/routing/RouteManagerContext.d.ts +1 -6
  80. package/dist/types/routing/ViewLifeCycleManager.d.ts +0 -1
  81. package/dist/types/routing/ViewStacks.d.ts +2 -2
  82. package/package.json +8 -8
  83. package/dist/types/components/components.d.ts +0 -326
package/dist/index.js CHANGED
@@ -1,80 +1,83 @@
1
1
  import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
2
2
  import React, { useContext, useRef, useEffect, createElement, useState, useMemo, Fragment as Fragment$1, useCallback } from 'react';
3
- import { isPlatform as isPlatform$1, getPlatforms as getPlatforms$1, componentOnReady, createAnimation, actionSheetController, alertController, toastController, modalController, popoverController, loadingController, initialize } from '@ionic/core/components';
3
+ import { isPlatform as isPlatform$1, getPlatforms as getPlatforms$1, componentOnReady, createAnimation, actionSheetController, alertController, toastController, modalController, popoverController, pickerController, loadingController, initialize } from '@ionic/core/components';
4
4
  export { IonicSafeString, IonicSlides, createAnimation, createGesture, getIonPageElement, getTimeGivenProgression, iosTransitionAnimation, mdTransitionAnimation, openURL } from '@ionic/core/components';
5
- import { createComponent } from '@stencil/react-output-target/runtime';
6
- import { IonAccordionGroup as IonAccordionGroup$1, defineCustomElement as defineCustomElement$2 } from '@ionic/core/components/ion-accordion-group.js';
7
- import { IonAccordion as IonAccordion$1, defineCustomElement as defineCustomElement$1 } from '@ionic/core/components/ion-accordion.js';
8
- import { IonAvatar as IonAvatar$1, defineCustomElement as defineCustomElement$3 } from '@ionic/core/components/ion-avatar.js';
9
- import { IonBackdrop as IonBackdrop$1, defineCustomElement as defineCustomElement$4 } from '@ionic/core/components/ion-backdrop.js';
10
- import { IonBadge as IonBadge$1, defineCustomElement as defineCustomElement$5 } from '@ionic/core/components/ion-badge.js';
11
- import { IonBreadcrumbs as IonBreadcrumbs$1, defineCustomElement as defineCustomElement$6 } from '@ionic/core/components/ion-breadcrumbs.js';
12
- import { IonButtons as IonButtons$1, defineCustomElement as defineCustomElement$7 } from '@ionic/core/components/ion-buttons.js';
13
- import { IonCardContent as IonCardContent$1, defineCustomElement as defineCustomElement$8 } from '@ionic/core/components/ion-card-content.js';
14
- import { IonCardHeader as IonCardHeader$1, defineCustomElement as defineCustomElement$9 } from '@ionic/core/components/ion-card-header.js';
15
- import { IonCardSubtitle as IonCardSubtitle$1, defineCustomElement as defineCustomElement$a } from '@ionic/core/components/ion-card-subtitle.js';
16
- import { IonCardTitle as IonCardTitle$1, defineCustomElement as defineCustomElement$b } from '@ionic/core/components/ion-card-title.js';
17
- import { IonCheckbox as IonCheckbox$1, defineCustomElement as defineCustomElement$c } from '@ionic/core/components/ion-checkbox.js';
18
- import { IonChip as IonChip$1, defineCustomElement as defineCustomElement$d } from '@ionic/core/components/ion-chip.js';
19
- import { IonCol as IonCol$1, defineCustomElement as defineCustomElement$e } from '@ionic/core/components/ion-col.js';
20
- import { IonContent as IonContent$1, defineCustomElement as defineCustomElement$f } from '@ionic/core/components/ion-content.js';
21
- import { IonDatetimeButton as IonDatetimeButton$1, defineCustomElement as defineCustomElement$h } from '@ionic/core/components/ion-datetime-button.js';
22
- import { IonDatetime as IonDatetime$1, defineCustomElement as defineCustomElement$g } from '@ionic/core/components/ion-datetime.js';
23
- import { IonFabList as IonFabList$1, defineCustomElement as defineCustomElement$j } from '@ionic/core/components/ion-fab-list.js';
24
- import { IonFab as IonFab$1, defineCustomElement as defineCustomElement$i } from '@ionic/core/components/ion-fab.js';
25
- import { IonFooter as IonFooter$1, defineCustomElement as defineCustomElement$k } from '@ionic/core/components/ion-footer.js';
26
- import { IonGrid as IonGrid$1, defineCustomElement as defineCustomElement$l } from '@ionic/core/components/ion-grid.js';
27
- import { IonHeader as IonHeader$1, defineCustomElement as defineCustomElement$m } from '@ionic/core/components/ion-header.js';
28
- import { IonImg as IonImg$1, defineCustomElement as defineCustomElement$n } from '@ionic/core/components/ion-img.js';
29
- import { IonInfiniteScrollContent as IonInfiniteScrollContent$1, defineCustomElement as defineCustomElement$p } from '@ionic/core/components/ion-infinite-scroll-content.js';
30
- import { IonInfiniteScroll as IonInfiniteScroll$1, defineCustomElement as defineCustomElement$o } from '@ionic/core/components/ion-infinite-scroll.js';
31
- import { IonInputOtp as IonInputOtp$1, defineCustomElement as defineCustomElement$r } from '@ionic/core/components/ion-input-otp.js';
32
- import { IonInputPasswordToggle as IonInputPasswordToggle$1, defineCustomElement as defineCustomElement$s } from '@ionic/core/components/ion-input-password-toggle.js';
33
- import { IonInput as IonInput$1, defineCustomElement as defineCustomElement$q } from '@ionic/core/components/ion-input.js';
34
- import { IonItemDivider as IonItemDivider$1, defineCustomElement as defineCustomElement$t } from '@ionic/core/components/ion-item-divider.js';
35
- import { IonItemGroup as IonItemGroup$1, defineCustomElement as defineCustomElement$u } from '@ionic/core/components/ion-item-group.js';
36
- import { IonItemOptions as IonItemOptions$1, defineCustomElement as defineCustomElement$v } from '@ionic/core/components/ion-item-options.js';
37
- import { IonItemSliding as IonItemSliding$1, defineCustomElement as defineCustomElement$w } from '@ionic/core/components/ion-item-sliding.js';
38
- import { IonLabel as IonLabel$1, defineCustomElement as defineCustomElement$x } from '@ionic/core/components/ion-label.js';
39
- import { IonListHeader as IonListHeader$1, defineCustomElement as defineCustomElement$z } from '@ionic/core/components/ion-list-header.js';
40
- import { IonList as IonList$1, defineCustomElement as defineCustomElement$y } from '@ionic/core/components/ion-list.js';
41
- import { IonMenuButton as IonMenuButton$1, defineCustomElement as defineCustomElement$B } from '@ionic/core/components/ion-menu-button.js';
42
- import { IonMenuToggle as IonMenuToggle$1, defineCustomElement as defineCustomElement$C } from '@ionic/core/components/ion-menu-toggle.js';
43
- import { IonMenu as IonMenu$1, defineCustomElement as defineCustomElement$A } from '@ionic/core/components/ion-menu.js';
44
- import { IonNavLink as IonNavLink$1, defineCustomElement as defineCustomElement$D } from '@ionic/core/components/ion-nav-link.js';
45
- import { defineCustomElement as defineCustomElement$1l } from '@ionic/core/components/ion-nav.js';
46
- import { IonNote as IonNote$1, defineCustomElement as defineCustomElement$E } from '@ionic/core/components/ion-note.js';
47
- import { IonPickerColumnOption as IonPickerColumnOption$1, defineCustomElement as defineCustomElement$H } from '@ionic/core/components/ion-picker-column-option.js';
48
- import { IonPickerColumn as IonPickerColumn$1, defineCustomElement as defineCustomElement$G } from '@ionic/core/components/ion-picker-column.js';
49
- import { IonPicker as IonPicker$1, defineCustomElement as defineCustomElement$F } from '@ionic/core/components/ion-picker.js';
50
- import { IonProgressBar as IonProgressBar$1, defineCustomElement as defineCustomElement$I } from '@ionic/core/components/ion-progress-bar.js';
51
- import { IonRadioGroup as IonRadioGroup$1, defineCustomElement as defineCustomElement$K } from '@ionic/core/components/ion-radio-group.js';
52
- import { IonRadio as IonRadio$1, defineCustomElement as defineCustomElement$J } from '@ionic/core/components/ion-radio.js';
53
- import { IonRange as IonRange$1, defineCustomElement as defineCustomElement$L } from '@ionic/core/components/ion-range.js';
54
- import { IonRefresherContent as IonRefresherContent$1, defineCustomElement as defineCustomElement$N } from '@ionic/core/components/ion-refresher-content.js';
55
- import { IonRefresher as IonRefresher$1, defineCustomElement as defineCustomElement$M } from '@ionic/core/components/ion-refresher.js';
56
- import { IonReorderGroup as IonReorderGroup$1, defineCustomElement as defineCustomElement$P } from '@ionic/core/components/ion-reorder-group.js';
57
- import { IonReorder as IonReorder$1, defineCustomElement as defineCustomElement$O } from '@ionic/core/components/ion-reorder.js';
58
- import { IonRippleEffect as IonRippleEffect$1, defineCustomElement as defineCustomElement$Q } from '@ionic/core/components/ion-ripple-effect.js';
59
- import { IonRow as IonRow$1, defineCustomElement as defineCustomElement$R } from '@ionic/core/components/ion-row.js';
60
- import { IonSearchbar as IonSearchbar$1, defineCustomElement as defineCustomElement$S } from '@ionic/core/components/ion-searchbar.js';
61
- import { IonSegmentButton as IonSegmentButton$1, defineCustomElement as defineCustomElement$U } from '@ionic/core/components/ion-segment-button.js';
62
- import { IonSegmentContent as IonSegmentContent$1, defineCustomElement as defineCustomElement$V } from '@ionic/core/components/ion-segment-content.js';
63
- import { IonSegmentView as IonSegmentView$1, defineCustomElement as defineCustomElement$W } from '@ionic/core/components/ion-segment-view.js';
64
- import { IonSegment as IonSegment$1, defineCustomElement as defineCustomElement$T } from '@ionic/core/components/ion-segment.js';
65
- import { IonSelectModal as IonSelectModal$1, defineCustomElement as defineCustomElement$Y } from '@ionic/core/components/ion-select-modal.js';
66
- import { IonSelectOption as IonSelectOption$1, defineCustomElement as defineCustomElement$Z } from '@ionic/core/components/ion-select-option.js';
67
- import { IonSelect as IonSelect$1, defineCustomElement as defineCustomElement$X } from '@ionic/core/components/ion-select.js';
68
- import { IonSkeletonText as IonSkeletonText$1, defineCustomElement as defineCustomElement$_ } from '@ionic/core/components/ion-skeleton-text.js';
69
- import { IonSpinner as IonSpinner$1, defineCustomElement as defineCustomElement$$ } from '@ionic/core/components/ion-spinner.js';
70
- import { IonSplitPane as IonSplitPane$1, defineCustomElement as defineCustomElement$10 } from '@ionic/core/components/ion-split-pane.js';
71
- import { IonTab as IonTab$1, defineCustomElement as defineCustomElement$11 } from '@ionic/core/components/ion-tab.js';
72
- import { IonText as IonText$1, defineCustomElement as defineCustomElement$12 } from '@ionic/core/components/ion-text.js';
73
- import { IonTextarea as IonTextarea$1, defineCustomElement as defineCustomElement$13 } from '@ionic/core/components/ion-textarea.js';
74
- import { IonThumbnail as IonThumbnail$1, defineCustomElement as defineCustomElement$14 } from '@ionic/core/components/ion-thumbnail.js';
75
- import { IonTitle as IonTitle$1, defineCustomElement as defineCustomElement$15 } from '@ionic/core/components/ion-title.js';
76
- import { IonToggle as IonToggle$1, defineCustomElement as defineCustomElement$16 } from '@ionic/core/components/ion-toggle.js';
77
- import { IonToolbar as IonToolbar$1, defineCustomElement as defineCustomElement$17 } from '@ionic/core/components/ion-toolbar.js';
5
+ import ReactDOM, { createPortal } from 'react-dom';
6
+ import { defineCustomElement as defineCustomElement$1 } from '@ionic/core/components/ion-accordion.js';
7
+ import { defineCustomElement as defineCustomElement$2 } from '@ionic/core/components/ion-accordion-group.js';
8
+ import { defineCustomElement as defineCustomElement$3 } from '@ionic/core/components/ion-avatar.js';
9
+ import { defineCustomElement as defineCustomElement$4 } from '@ionic/core/components/ion-backdrop.js';
10
+ import { defineCustomElement as defineCustomElement$5 } from '@ionic/core/components/ion-badge.js';
11
+ import { defineCustomElement as defineCustomElement$6 } from '@ionic/core/components/ion-breadcrumbs.js';
12
+ import { defineCustomElement as defineCustomElement$7 } from '@ionic/core/components/ion-buttons.js';
13
+ import { defineCustomElement as defineCustomElement$8 } from '@ionic/core/components/ion-card-content.js';
14
+ import { defineCustomElement as defineCustomElement$9 } from '@ionic/core/components/ion-card-header.js';
15
+ import { defineCustomElement as defineCustomElement$a } from '@ionic/core/components/ion-card-subtitle.js';
16
+ import { defineCustomElement as defineCustomElement$b } from '@ionic/core/components/ion-card-title.js';
17
+ import { defineCustomElement as defineCustomElement$c } from '@ionic/core/components/ion-checkbox.js';
18
+ import { defineCustomElement as defineCustomElement$d } from '@ionic/core/components/ion-chip.js';
19
+ import { defineCustomElement as defineCustomElement$e } from '@ionic/core/components/ion-col.js';
20
+ import { defineCustomElement as defineCustomElement$f } from '@ionic/core/components/ion-content.js';
21
+ import { defineCustomElement as defineCustomElement$g } from '@ionic/core/components/ion-datetime.js';
22
+ import { defineCustomElement as defineCustomElement$h } from '@ionic/core/components/ion-datetime-button.js';
23
+ import { defineCustomElement as defineCustomElement$i } from '@ionic/core/components/ion-divider.js';
24
+ import { defineCustomElement as defineCustomElement$j } from '@ionic/core/components/ion-fab.js';
25
+ import { defineCustomElement as defineCustomElement$k } from '@ionic/core/components/ion-fab-list.js';
26
+ import { defineCustomElement as defineCustomElement$l } from '@ionic/core/components/ion-footer.js';
27
+ import { defineCustomElement as defineCustomElement$m } from '@ionic/core/components/ion-gallery.js';
28
+ import { defineCustomElement as defineCustomElement$n } from '@ionic/core/components/ion-gallery-item.js';
29
+ import { defineCustomElement as defineCustomElement$o } from '@ionic/core/components/ion-grid.js';
30
+ import { defineCustomElement as defineCustomElement$p } from '@ionic/core/components/ion-header.js';
31
+ import { defineCustomElement as defineCustomElement$q } from '@ionic/core/components/ion-img.js';
32
+ import { defineCustomElement as defineCustomElement$r } from '@ionic/core/components/ion-infinite-scroll.js';
33
+ import { defineCustomElement as defineCustomElement$s } from '@ionic/core/components/ion-infinite-scroll-content.js';
34
+ import { defineCustomElement as defineCustomElement$t } from '@ionic/core/components/ion-input.js';
35
+ import { defineCustomElement as defineCustomElement$u } from '@ionic/core/components/ion-input-otp.js';
36
+ import { defineCustomElement as defineCustomElement$v } from '@ionic/core/components/ion-input-password-toggle.js';
37
+ import { defineCustomElement as defineCustomElement$w } from '@ionic/core/components/ion-item-divider.js';
38
+ import { defineCustomElement as defineCustomElement$x } from '@ionic/core/components/ion-item-group.js';
39
+ import { defineCustomElement as defineCustomElement$y } from '@ionic/core/components/ion-item-options.js';
40
+ import { defineCustomElement as defineCustomElement$z } from '@ionic/core/components/ion-item-sliding.js';
41
+ import { defineCustomElement as defineCustomElement$A } from '@ionic/core/components/ion-label.js';
42
+ import { defineCustomElement as defineCustomElement$B } from '@ionic/core/components/ion-list.js';
43
+ import { defineCustomElement as defineCustomElement$C } from '@ionic/core/components/ion-list-header.js';
44
+ import { defineCustomElement as defineCustomElement$D } from '@ionic/core/components/ion-menu.js';
45
+ import { defineCustomElement as defineCustomElement$E } from '@ionic/core/components/ion-menu-button.js';
46
+ import { defineCustomElement as defineCustomElement$F } from '@ionic/core/components/ion-menu-toggle.js';
47
+ import { defineCustomElement as defineCustomElement$1p } from '@ionic/core/components/ion-nav.js';
48
+ import { defineCustomElement as defineCustomElement$G } from '@ionic/core/components/ion-nav-link.js';
49
+ import { defineCustomElement as defineCustomElement$H } from '@ionic/core/components/ion-note.js';
50
+ import { defineCustomElement as defineCustomElement$I } from '@ionic/core/components/ion-picker.js';
51
+ import { defineCustomElement as defineCustomElement$J } from '@ionic/core/components/ion-picker-column.js';
52
+ import { defineCustomElement as defineCustomElement$K } from '@ionic/core/components/ion-picker-column-option.js';
53
+ import { defineCustomElement as defineCustomElement$L } from '@ionic/core/components/ion-progress-bar.js';
54
+ import { defineCustomElement as defineCustomElement$M } from '@ionic/core/components/ion-radio.js';
55
+ import { defineCustomElement as defineCustomElement$N } from '@ionic/core/components/ion-radio-group.js';
56
+ import { defineCustomElement as defineCustomElement$O } from '@ionic/core/components/ion-range.js';
57
+ import { defineCustomElement as defineCustomElement$P } from '@ionic/core/components/ion-refresher.js';
58
+ import { defineCustomElement as defineCustomElement$Q } from '@ionic/core/components/ion-refresher-content.js';
59
+ import { defineCustomElement as defineCustomElement$R } from '@ionic/core/components/ion-reorder.js';
60
+ import { defineCustomElement as defineCustomElement$S } from '@ionic/core/components/ion-reorder-group.js';
61
+ import { defineCustomElement as defineCustomElement$T } from '@ionic/core/components/ion-ripple-effect.js';
62
+ import { defineCustomElement as defineCustomElement$U } from '@ionic/core/components/ion-row.js';
63
+ import { defineCustomElement as defineCustomElement$V } from '@ionic/core/components/ion-searchbar.js';
64
+ import { defineCustomElement as defineCustomElement$W } from '@ionic/core/components/ion-segment.js';
65
+ import { defineCustomElement as defineCustomElement$X } from '@ionic/core/components/ion-segment-button.js';
66
+ import { defineCustomElement as defineCustomElement$Y } from '@ionic/core/components/ion-segment-content.js';
67
+ import { defineCustomElement as defineCustomElement$Z } from '@ionic/core/components/ion-segment-view.js';
68
+ import { defineCustomElement as defineCustomElement$_ } from '@ionic/core/components/ion-select.js';
69
+ import { defineCustomElement as defineCustomElement$$ } from '@ionic/core/components/ion-select-modal.js';
70
+ import { defineCustomElement as defineCustomElement$10 } from '@ionic/core/components/ion-select-option.js';
71
+ import { defineCustomElement as defineCustomElement$11 } from '@ionic/core/components/ion-skeleton-text.js';
72
+ import { defineCustomElement as defineCustomElement$12 } from '@ionic/core/components/ion-spinner.js';
73
+ import { defineCustomElement as defineCustomElement$13 } from '@ionic/core/components/ion-split-pane.js';
74
+ import { defineCustomElement as defineCustomElement$14 } from '@ionic/core/components/ion-tab.js';
75
+ import { defineCustomElement as defineCustomElement$15 } from '@ionic/core/components/ion-text.js';
76
+ import { defineCustomElement as defineCustomElement$16 } from '@ionic/core/components/ion-textarea.js';
77
+ import { defineCustomElement as defineCustomElement$17 } from '@ionic/core/components/ion-thumbnail.js';
78
+ import { defineCustomElement as defineCustomElement$18 } from '@ionic/core/components/ion-title.js';
79
+ import { defineCustomElement as defineCustomElement$19 } from '@ionic/core/components/ion-toggle.js';
80
+ import { defineCustomElement as defineCustomElement$1a } from '@ionic/core/components/ion-toolbar.js';
78
81
  import { IonBreadcrumb as IonBreadcrumb$1 } from '@ionic/core/components/ion-breadcrumb.js';
79
82
  import { IonButton as IonButton$1 } from '@ionic/core/components/ion-button.js';
80
83
  import { IonCard as IonCard$1 } from '@ionic/core/components/ion-card.js';
@@ -82,20 +85,20 @@ import { IonFabButton as IonFabButton$1 } from '@ionic/core/components/ion-fab-b
82
85
  import { IonItemOption as IonItemOption$1 } from '@ionic/core/components/ion-item-option.js';
83
86
  import { IonItem as IonItem$1 } from '@ionic/core/components/ion-item.js';
84
87
  import { IonRouterLink as IonRouterLink$1 } from '@ionic/core/components/ion-router-link.js';
85
- import { defineCustomElement as defineCustomElement$18 } from '@ionic/core/components/ion-alert.js';
86
- import ReactDOM, { createPortal } from 'react-dom';
87
- import { defineCustomElement as defineCustomElement$19 } from '@ionic/core/components/ion-loading.js';
88
- import { defineCustomElement as defineCustomElement$1a } from '@ionic/core/components/ion-toast.js';
89
- import { defineCustomElement as defineCustomElement$1b } from '@ionic/core/components/ion-action-sheet.js';
90
- import { defineCustomElement as defineCustomElement$1c } from '@ionic/core/components/ion-modal.js';
91
- import { defineCustomElement as defineCustomElement$1d } from '@ionic/core/components/ion-popover.js';
92
- import { defineCustomElement as defineCustomElement$1j } from '@ionic/core/components/ion-app.js';
93
- import { defineCustomElement as defineCustomElement$1h } from '@ionic/core/components/ion-back-button.js';
94
- import { defineCustomElement as defineCustomElement$1i } from '@ionic/core/components/ion-router-outlet.js';
95
- import { defineCustomElement as defineCustomElement$1f } from '@ionic/core/components/ion-tab-bar.js';
96
- import { defineCustomElement as defineCustomElement$1e } from '@ionic/core/components/ion-tab-button.js';
97
- import { defineCustomElement as defineCustomElement$1g } from '@ionic/core/components/ion-tabs.js';
98
- import { defineCustomElement as defineCustomElement$1k } from 'ionicons/components/ion-icon.js';
88
+ import { defineCustomElement as defineCustomElement$1b } from '@ionic/core/components/ion-alert.js';
89
+ import { defineCustomElement as defineCustomElement$1c } from '@ionic/core/components/ion-loading.js';
90
+ import { defineCustomElement as defineCustomElement$1d } from '@ionic/core/components/ion-toast.js';
91
+ import { defineCustomElement as defineCustomElement$1e } from '@ionic/core/components/ion-picker-legacy.js';
92
+ import { defineCustomElement as defineCustomElement$1f } from '@ionic/core/components/ion-action-sheet.js';
93
+ import { defineCustomElement as defineCustomElement$1g } from '@ionic/core/components/ion-modal.js';
94
+ import { defineCustomElement as defineCustomElement$1h } from '@ionic/core/components/ion-popover.js';
95
+ import { defineCustomElement as defineCustomElement$1n } from '@ionic/core/components/ion-app.js';
96
+ import { defineCustomElement as defineCustomElement$1l } from '@ionic/core/components/ion-back-button.js';
97
+ import { defineCustomElement as defineCustomElement$1m } from '@ionic/core/components/ion-router-outlet.js';
98
+ import { defineCustomElement as defineCustomElement$1j } from '@ionic/core/components/ion-tab-bar.js';
99
+ import { defineCustomElement as defineCustomElement$1i } from '@ionic/core/components/ion-tab-button.js';
100
+ import { defineCustomElement as defineCustomElement$1k } from '@ionic/core/components/ion-tabs.js';
101
+ import { defineCustomElement as defineCustomElement$1o } from 'ionicons/components/ion-icon.js';
99
102
 
100
103
  const IonLifeCycleContext = /*@__PURE__*/ React.createContext({
101
104
  onIonViewWillEnter: () => {
@@ -380,7 +383,9 @@ const useIonViewDidLeave = (callback, deps = []) => {
380
383
  };
381
384
 
382
385
  const NavContext = /*@__PURE__*/ React.createContext({
386
+ getIonRedirect: () => undefined,
383
387
  getIonRoute: () => undefined,
388
+ getPageManager: () => undefined,
384
389
  getStackManager: () => undefined,
385
390
  goBack: (route) => {
386
391
  if (typeof window !== 'undefined') {
@@ -412,699 +417,6 @@ const NavContext = /*@__PURE__*/ React.createContext({
412
417
  },
413
418
  });
414
419
 
415
- const IonAccordion =
416
- /*@__PURE__*/ createComponent({
417
- tagName: 'ion-accordion',
418
- elementClass: IonAccordion$1,
419
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
420
- react: React,
421
- events: {},
422
- defineCustomElement: defineCustomElement$1,
423
- });
424
- const IonAccordionGroup = /*@__PURE__*/ createComponent({
425
- tagName: 'ion-accordion-group',
426
- elementClass: IonAccordionGroup$1,
427
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
428
- react: React,
429
- events: { onIonChange: 'ionChange' },
430
- defineCustomElement: defineCustomElement$2,
431
- });
432
- const IonAvatar =
433
- /*@__PURE__*/ createComponent({
434
- tagName: 'ion-avatar',
435
- elementClass: IonAvatar$1,
436
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
437
- react: React,
438
- events: {},
439
- defineCustomElement: defineCustomElement$3,
440
- });
441
- const IonBackdrop =
442
- /*@__PURE__*/ createComponent({
443
- tagName: 'ion-backdrop',
444
- elementClass: IonBackdrop$1,
445
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
446
- react: React,
447
- events: { onIonBackdropTap: 'ionBackdropTap' },
448
- defineCustomElement: defineCustomElement$4,
449
- });
450
- const IonBadge =
451
- /*@__PURE__*/ createComponent({
452
- tagName: 'ion-badge',
453
- elementClass: IonBadge$1,
454
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
455
- react: React,
456
- events: {},
457
- defineCustomElement: defineCustomElement$5,
458
- });
459
- const IonBreadcrumbs = /*@__PURE__*/ createComponent({
460
- tagName: 'ion-breadcrumbs',
461
- elementClass: IonBreadcrumbs$1,
462
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
463
- react: React,
464
- events: { onIonCollapsedClick: 'ionCollapsedClick' },
465
- defineCustomElement: defineCustomElement$6,
466
- });
467
- const IonButtons =
468
- /*@__PURE__*/ createComponent({
469
- tagName: 'ion-buttons',
470
- elementClass: IonButtons$1,
471
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
472
- react: React,
473
- events: {},
474
- defineCustomElement: defineCustomElement$7,
475
- });
476
- const IonCardContent = /*@__PURE__*/ createComponent({
477
- tagName: 'ion-card-content',
478
- elementClass: IonCardContent$1,
479
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
480
- react: React,
481
- events: {},
482
- defineCustomElement: defineCustomElement$8,
483
- });
484
- const IonCardHeader =
485
- /*@__PURE__*/ createComponent({
486
- tagName: 'ion-card-header',
487
- elementClass: IonCardHeader$1,
488
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
489
- react: React,
490
- events: {},
491
- defineCustomElement: defineCustomElement$9,
492
- });
493
- const IonCardSubtitle = /*@__PURE__*/ createComponent({
494
- tagName: 'ion-card-subtitle',
495
- elementClass: IonCardSubtitle$1,
496
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
497
- react: React,
498
- events: {},
499
- defineCustomElement: defineCustomElement$a,
500
- });
501
- const IonCardTitle =
502
- /*@__PURE__*/ createComponent({
503
- tagName: 'ion-card-title',
504
- elementClass: IonCardTitle$1,
505
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
506
- react: React,
507
- events: {},
508
- defineCustomElement: defineCustomElement$b,
509
- });
510
- const IonCheckbox =
511
- /*@__PURE__*/ createComponent({
512
- tagName: 'ion-checkbox',
513
- elementClass: IonCheckbox$1,
514
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
515
- react: React,
516
- events: {
517
- onIonChange: 'ionChange',
518
- onIonFocus: 'ionFocus',
519
- onIonBlur: 'ionBlur',
520
- },
521
- defineCustomElement: defineCustomElement$c,
522
- });
523
- const IonChip =
524
- /*@__PURE__*/ createComponent({
525
- tagName: 'ion-chip',
526
- elementClass: IonChip$1,
527
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
528
- react: React,
529
- events: {},
530
- defineCustomElement: defineCustomElement$d,
531
- });
532
- const IonCol =
533
- /*@__PURE__*/ createComponent({
534
- tagName: 'ion-col',
535
- elementClass: IonCol$1,
536
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
537
- react: React,
538
- events: {},
539
- defineCustomElement: defineCustomElement$e,
540
- });
541
- const IonContent =
542
- /*@__PURE__*/ createComponent({
543
- tagName: 'ion-content',
544
- elementClass: IonContent$1,
545
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
546
- react: React,
547
- events: {
548
- onIonScrollStart: 'ionScrollStart',
549
- onIonScroll: 'ionScroll',
550
- onIonScrollEnd: 'ionScrollEnd',
551
- },
552
- defineCustomElement: defineCustomElement$f,
553
- });
554
- const IonDatetime =
555
- /*@__PURE__*/ createComponent({
556
- tagName: 'ion-datetime',
557
- elementClass: IonDatetime$1,
558
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
559
- react: React,
560
- events: {
561
- onIonCancel: 'ionCancel',
562
- onIonChange: 'ionChange',
563
- onIonFocus: 'ionFocus',
564
- onIonBlur: 'ionBlur',
565
- },
566
- defineCustomElement: defineCustomElement$g,
567
- });
568
- const IonDatetimeButton = /*@__PURE__*/ createComponent({
569
- tagName: 'ion-datetime-button',
570
- elementClass: IonDatetimeButton$1,
571
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
572
- react: React,
573
- events: {},
574
- defineCustomElement: defineCustomElement$h,
575
- });
576
- const IonFab =
577
- /*@__PURE__*/ createComponent({
578
- tagName: 'ion-fab',
579
- elementClass: IonFab$1,
580
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
581
- react: React,
582
- events: {},
583
- defineCustomElement: defineCustomElement$i,
584
- });
585
- const IonFabList =
586
- /*@__PURE__*/ createComponent({
587
- tagName: 'ion-fab-list',
588
- elementClass: IonFabList$1,
589
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
590
- react: React,
591
- events: {},
592
- defineCustomElement: defineCustomElement$j,
593
- });
594
- const IonFooter =
595
- /*@__PURE__*/ createComponent({
596
- tagName: 'ion-footer',
597
- elementClass: IonFooter$1,
598
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
599
- react: React,
600
- events: {},
601
- defineCustomElement: defineCustomElement$k,
602
- });
603
- const IonGrid =
604
- /*@__PURE__*/ createComponent({
605
- tagName: 'ion-grid',
606
- elementClass: IonGrid$1,
607
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
608
- react: React,
609
- events: {},
610
- defineCustomElement: defineCustomElement$l,
611
- });
612
- const IonHeader =
613
- /*@__PURE__*/ createComponent({
614
- tagName: 'ion-header',
615
- elementClass: IonHeader$1,
616
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
617
- react: React,
618
- events: {},
619
- defineCustomElement: defineCustomElement$m,
620
- });
621
- const IonImg =
622
- /*@__PURE__*/ createComponent({
623
- tagName: 'ion-img',
624
- elementClass: IonImg$1,
625
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
626
- react: React,
627
- events: {
628
- onIonImgWillLoad: 'ionImgWillLoad',
629
- onIonImgDidLoad: 'ionImgDidLoad',
630
- onIonError: 'ionError',
631
- },
632
- defineCustomElement: defineCustomElement$n,
633
- });
634
- const IonInfiniteScroll = /*@__PURE__*/ createComponent({
635
- tagName: 'ion-infinite-scroll',
636
- elementClass: IonInfiniteScroll$1,
637
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
638
- react: React,
639
- events: { onIonInfinite: 'ionInfinite' },
640
- defineCustomElement: defineCustomElement$o,
641
- });
642
- const IonInfiniteScrollContent = /*@__PURE__*/ createComponent({
643
- tagName: 'ion-infinite-scroll-content',
644
- elementClass: IonInfiniteScrollContent$1,
645
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
646
- react: React,
647
- events: {},
648
- defineCustomElement: defineCustomElement$p,
649
- });
650
- const IonInput =
651
- /*@__PURE__*/ createComponent({
652
- tagName: 'ion-input',
653
- elementClass: IonInput$1,
654
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
655
- react: React,
656
- events: {
657
- onIonInput: 'ionInput',
658
- onIonChange: 'ionChange',
659
- onIonBlur: 'ionBlur',
660
- onIonFocus: 'ionFocus',
661
- },
662
- defineCustomElement: defineCustomElement$q,
663
- });
664
- const IonInputOtp =
665
- /*@__PURE__*/ createComponent({
666
- tagName: 'ion-input-otp',
667
- elementClass: IonInputOtp$1,
668
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
669
- react: React,
670
- events: {
671
- onIonInput: 'ionInput',
672
- onIonChange: 'ionChange',
673
- onIonComplete: 'ionComplete',
674
- onIonBlur: 'ionBlur',
675
- onIonFocus: 'ionFocus',
676
- },
677
- defineCustomElement: defineCustomElement$r,
678
- });
679
- const IonInputPasswordToggle = /*@__PURE__*/ createComponent({
680
- tagName: 'ion-input-password-toggle',
681
- elementClass: IonInputPasswordToggle$1,
682
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
683
- react: React,
684
- events: {},
685
- defineCustomElement: defineCustomElement$s,
686
- });
687
- const IonItemDivider = /*@__PURE__*/ createComponent({
688
- tagName: 'ion-item-divider',
689
- elementClass: IonItemDivider$1,
690
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
691
- react: React,
692
- events: {},
693
- defineCustomElement: defineCustomElement$t,
694
- });
695
- const IonItemGroup =
696
- /*@__PURE__*/ createComponent({
697
- tagName: 'ion-item-group',
698
- elementClass: IonItemGroup$1,
699
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
700
- react: React,
701
- events: {},
702
- defineCustomElement: defineCustomElement$u,
703
- });
704
- const IonItemOptions = /*@__PURE__*/ createComponent({
705
- tagName: 'ion-item-options',
706
- elementClass: IonItemOptions$1,
707
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
708
- react: React,
709
- events: { onIonSwipe: 'ionSwipe' },
710
- defineCustomElement: defineCustomElement$v,
711
- });
712
- const IonItemSliding = /*@__PURE__*/ createComponent({
713
- tagName: 'ion-item-sliding',
714
- elementClass: IonItemSliding$1,
715
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
716
- react: React,
717
- events: { onIonDrag: 'ionDrag' },
718
- defineCustomElement: defineCustomElement$w,
719
- });
720
- const IonLabel =
721
- /*@__PURE__*/ createComponent({
722
- tagName: 'ion-label',
723
- elementClass: IonLabel$1,
724
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
725
- react: React,
726
- events: {},
727
- defineCustomElement: defineCustomElement$x,
728
- });
729
- const IonList =
730
- /*@__PURE__*/ createComponent({
731
- tagName: 'ion-list',
732
- elementClass: IonList$1,
733
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
734
- react: React,
735
- events: {},
736
- defineCustomElement: defineCustomElement$y,
737
- });
738
- const IonListHeader =
739
- /*@__PURE__*/ createComponent({
740
- tagName: 'ion-list-header',
741
- elementClass: IonListHeader$1,
742
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
743
- react: React,
744
- events: {},
745
- defineCustomElement: defineCustomElement$z,
746
- });
747
- const IonMenu =
748
- /*@__PURE__*/ createComponent({
749
- tagName: 'ion-menu',
750
- elementClass: IonMenu$1,
751
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
752
- react: React,
753
- events: {
754
- onIonWillOpen: 'ionWillOpen',
755
- onIonWillClose: 'ionWillClose',
756
- onIonDidOpen: 'ionDidOpen',
757
- onIonDidClose: 'ionDidClose',
758
- },
759
- defineCustomElement: defineCustomElement$A,
760
- });
761
- const IonMenuButton =
762
- /*@__PURE__*/ createComponent({
763
- tagName: 'ion-menu-button',
764
- elementClass: IonMenuButton$1,
765
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
766
- react: React,
767
- events: {},
768
- defineCustomElement: defineCustomElement$B,
769
- });
770
- const IonMenuToggle =
771
- /*@__PURE__*/ createComponent({
772
- tagName: 'ion-menu-toggle',
773
- elementClass: IonMenuToggle$1,
774
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
775
- react: React,
776
- events: {},
777
- defineCustomElement: defineCustomElement$C,
778
- });
779
- const IonNavLink =
780
- /*@__PURE__*/ createComponent({
781
- tagName: 'ion-nav-link',
782
- elementClass: IonNavLink$1,
783
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
784
- react: React,
785
- events: {},
786
- defineCustomElement: defineCustomElement$D,
787
- });
788
- const IonNote =
789
- /*@__PURE__*/ createComponent({
790
- tagName: 'ion-note',
791
- elementClass: IonNote$1,
792
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
793
- react: React,
794
- events: {},
795
- defineCustomElement: defineCustomElement$E,
796
- });
797
- const IonPicker =
798
- /*@__PURE__*/ createComponent({
799
- tagName: 'ion-picker',
800
- elementClass: IonPicker$1,
801
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
802
- react: React,
803
- events: {},
804
- defineCustomElement: defineCustomElement$F,
805
- });
806
- const IonPickerColumn = /*@__PURE__*/ createComponent({
807
- tagName: 'ion-picker-column',
808
- elementClass: IonPickerColumn$1,
809
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
810
- react: React,
811
- events: { onIonChange: 'ionChange' },
812
- defineCustomElement: defineCustomElement$G,
813
- });
814
- const IonPickerColumnOption = /*@__PURE__*/ createComponent({
815
- tagName: 'ion-picker-column-option',
816
- elementClass: IonPickerColumnOption$1,
817
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
818
- react: React,
819
- events: {},
820
- defineCustomElement: defineCustomElement$H,
821
- });
822
- const IonProgressBar = /*@__PURE__*/ createComponent({
823
- tagName: 'ion-progress-bar',
824
- elementClass: IonProgressBar$1,
825
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
826
- react: React,
827
- events: {},
828
- defineCustomElement: defineCustomElement$I,
829
- });
830
- const IonRadio =
831
- /*@__PURE__*/ createComponent({
832
- tagName: 'ion-radio',
833
- elementClass: IonRadio$1,
834
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
835
- react: React,
836
- events: {
837
- onIonFocus: 'ionFocus',
838
- onIonBlur: 'ionBlur',
839
- },
840
- defineCustomElement: defineCustomElement$J,
841
- });
842
- const IonRadioGroup =
843
- /*@__PURE__*/ createComponent({
844
- tagName: 'ion-radio-group',
845
- elementClass: IonRadioGroup$1,
846
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
847
- react: React,
848
- events: { onIonChange: 'ionChange' },
849
- defineCustomElement: defineCustomElement$K,
850
- });
851
- const IonRange =
852
- /*@__PURE__*/ createComponent({
853
- tagName: 'ion-range',
854
- elementClass: IonRange$1,
855
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
856
- react: React,
857
- events: {
858
- onIonChange: 'ionChange',
859
- onIonInput: 'ionInput',
860
- onIonFocus: 'ionFocus',
861
- onIonBlur: 'ionBlur',
862
- onIonKnobMoveStart: 'ionKnobMoveStart',
863
- onIonKnobMoveEnd: 'ionKnobMoveEnd',
864
- },
865
- defineCustomElement: defineCustomElement$L,
866
- });
867
- const IonRefresher =
868
- /*@__PURE__*/ createComponent({
869
- tagName: 'ion-refresher',
870
- elementClass: IonRefresher$1,
871
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
872
- react: React,
873
- events: {
874
- onIonRefresh: 'ionRefresh',
875
- onIonPull: 'ionPull',
876
- onIonStart: 'ionStart',
877
- onIonPullStart: 'ionPullStart',
878
- onIonPullEnd: 'ionPullEnd',
879
- },
880
- defineCustomElement: defineCustomElement$M,
881
- });
882
- const IonRefresherContent = /*@__PURE__*/ createComponent({
883
- tagName: 'ion-refresher-content',
884
- elementClass: IonRefresherContent$1,
885
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
886
- react: React,
887
- events: {},
888
- defineCustomElement: defineCustomElement$N,
889
- });
890
- const IonReorder =
891
- /*@__PURE__*/ createComponent({
892
- tagName: 'ion-reorder',
893
- elementClass: IonReorder$1,
894
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
895
- react: React,
896
- events: {},
897
- defineCustomElement: defineCustomElement$O,
898
- });
899
- const IonReorderGroup = /*@__PURE__*/ createComponent({
900
- tagName: 'ion-reorder-group',
901
- elementClass: IonReorderGroup$1,
902
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
903
- react: React,
904
- events: {
905
- onIonItemReorder: 'ionItemReorder',
906
- onIonReorderStart: 'ionReorderStart',
907
- onIonReorderMove: 'ionReorderMove',
908
- onIonReorderEnd: 'ionReorderEnd',
909
- },
910
- defineCustomElement: defineCustomElement$P,
911
- });
912
- const IonRippleEffect = /*@__PURE__*/ createComponent({
913
- tagName: 'ion-ripple-effect',
914
- elementClass: IonRippleEffect$1,
915
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
916
- react: React,
917
- events: {},
918
- defineCustomElement: defineCustomElement$Q,
919
- });
920
- const IonRow =
921
- /*@__PURE__*/ createComponent({
922
- tagName: 'ion-row',
923
- elementClass: IonRow$1,
924
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
925
- react: React,
926
- events: {},
927
- defineCustomElement: defineCustomElement$R,
928
- });
929
- const IonSearchbar =
930
- /*@__PURE__*/ createComponent({
931
- tagName: 'ion-searchbar',
932
- elementClass: IonSearchbar$1,
933
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
934
- react: React,
935
- events: {
936
- onIonInput: 'ionInput',
937
- onIonChange: 'ionChange',
938
- onIonCancel: 'ionCancel',
939
- onIonClear: 'ionClear',
940
- onIonBlur: 'ionBlur',
941
- onIonFocus: 'ionFocus',
942
- },
943
- defineCustomElement: defineCustomElement$S,
944
- });
945
- const IonSegment =
946
- /*@__PURE__*/ createComponent({
947
- tagName: 'ion-segment',
948
- elementClass: IonSegment$1,
949
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
950
- react: React,
951
- events: { onIonChange: 'ionChange' },
952
- defineCustomElement: defineCustomElement$T,
953
- });
954
- const IonSegmentButton = /*@__PURE__*/ createComponent({
955
- tagName: 'ion-segment-button',
956
- elementClass: IonSegmentButton$1,
957
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
958
- react: React,
959
- events: {},
960
- defineCustomElement: defineCustomElement$U,
961
- });
962
- const IonSegmentContent = /*@__PURE__*/ createComponent({
963
- tagName: 'ion-segment-content',
964
- elementClass: IonSegmentContent$1,
965
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
966
- react: React,
967
- events: {},
968
- defineCustomElement: defineCustomElement$V,
969
- });
970
- const IonSegmentView = /*@__PURE__*/ createComponent({
971
- tagName: 'ion-segment-view',
972
- elementClass: IonSegmentView$1,
973
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
974
- react: React,
975
- events: { onIonSegmentViewScroll: 'ionSegmentViewScroll' },
976
- defineCustomElement: defineCustomElement$W,
977
- });
978
- const IonSelect =
979
- /*@__PURE__*/ createComponent({
980
- tagName: 'ion-select',
981
- elementClass: IonSelect$1,
982
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
983
- react: React,
984
- events: {
985
- onIonChange: 'ionChange',
986
- onIonCancel: 'ionCancel',
987
- onIonDismiss: 'ionDismiss',
988
- onIonFocus: 'ionFocus',
989
- onIonBlur: 'ionBlur',
990
- },
991
- defineCustomElement: defineCustomElement$X,
992
- });
993
- const IonSelectModal = /*@__PURE__*/ createComponent({
994
- tagName: 'ion-select-modal',
995
- elementClass: IonSelectModal$1,
996
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
997
- react: React,
998
- events: {},
999
- defineCustomElement: defineCustomElement$Y,
1000
- });
1001
- const IonSelectOption = /*@__PURE__*/ createComponent({
1002
- tagName: 'ion-select-option',
1003
- elementClass: IonSelectOption$1,
1004
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1005
- react: React,
1006
- events: {},
1007
- defineCustomElement: defineCustomElement$Z,
1008
- });
1009
- const IonSkeletonText = /*@__PURE__*/ createComponent({
1010
- tagName: 'ion-skeleton-text',
1011
- elementClass: IonSkeletonText$1,
1012
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1013
- react: React,
1014
- events: {},
1015
- defineCustomElement: defineCustomElement$_,
1016
- });
1017
- const IonSpinner =
1018
- /*@__PURE__*/ createComponent({
1019
- tagName: 'ion-spinner',
1020
- elementClass: IonSpinner$1,
1021
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1022
- react: React,
1023
- events: {},
1024
- defineCustomElement: defineCustomElement$$,
1025
- });
1026
- const IonSplitPane =
1027
- /*@__PURE__*/ createComponent({
1028
- tagName: 'ion-split-pane',
1029
- elementClass: IonSplitPane$1,
1030
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1031
- react: React,
1032
- events: { onIonSplitPaneVisible: 'ionSplitPaneVisible' },
1033
- defineCustomElement: defineCustomElement$10,
1034
- });
1035
- const IonTab =
1036
- /*@__PURE__*/ createComponent({
1037
- tagName: 'ion-tab',
1038
- elementClass: IonTab$1,
1039
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1040
- react: React,
1041
- events: {},
1042
- defineCustomElement: defineCustomElement$11,
1043
- });
1044
- const IonText =
1045
- /*@__PURE__*/ createComponent({
1046
- tagName: 'ion-text',
1047
- elementClass: IonText$1,
1048
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1049
- react: React,
1050
- events: {},
1051
- defineCustomElement: defineCustomElement$12,
1052
- });
1053
- const IonTextarea =
1054
- /*@__PURE__*/ createComponent({
1055
- tagName: 'ion-textarea',
1056
- elementClass: IonTextarea$1,
1057
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1058
- react: React,
1059
- events: {
1060
- onIonChange: 'ionChange',
1061
- onIonInput: 'ionInput',
1062
- onIonBlur: 'ionBlur',
1063
- onIonFocus: 'ionFocus',
1064
- },
1065
- defineCustomElement: defineCustomElement$13,
1066
- });
1067
- const IonThumbnail =
1068
- /*@__PURE__*/ createComponent({
1069
- tagName: 'ion-thumbnail',
1070
- elementClass: IonThumbnail$1,
1071
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1072
- react: React,
1073
- events: {},
1074
- defineCustomElement: defineCustomElement$14,
1075
- });
1076
- const IonTitle =
1077
- /*@__PURE__*/ createComponent({
1078
- tagName: 'ion-title',
1079
- elementClass: IonTitle$1,
1080
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1081
- react: React,
1082
- events: {},
1083
- defineCustomElement: defineCustomElement$15,
1084
- });
1085
- const IonToggle =
1086
- /*@__PURE__*/ createComponent({
1087
- tagName: 'ion-toggle',
1088
- elementClass: IonToggle$1,
1089
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1090
- react: React,
1091
- events: {
1092
- onIonChange: 'ionChange',
1093
- onIonFocus: 'ionFocus',
1094
- onIonBlur: 'ionBlur',
1095
- },
1096
- defineCustomElement: defineCustomElement$16,
1097
- });
1098
- const IonToolbar =
1099
- /*@__PURE__*/ createComponent({
1100
- tagName: 'ion-toolbar',
1101
- elementClass: IonToolbar$1,
1102
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1103
- react: React,
1104
- events: {},
1105
- defineCustomElement: defineCustomElement$17,
1106
- });
1107
-
1108
420
  const dashToPascalCase = (str) => str
1109
421
  .toLowerCase()
1110
422
  .split('-')
@@ -1248,6 +560,150 @@ const defineCustomElement = (tagName, customElement) => {
1248
560
  }
1249
561
  };
1250
562
 
563
+ const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => {
564
+ if (defineCustomElement !== undefined) {
565
+ defineCustomElement();
566
+ }
567
+ const displayName = dashToPascalCase(tagName);
568
+ const ReactComponent = class extends React.Component {
569
+ constructor(props) {
570
+ super(props);
571
+ this.setComponentElRef = (element) => {
572
+ this.componentEl = element;
573
+ };
574
+ }
575
+ componentDidMount() {
576
+ this.componentDidUpdate(this.props);
577
+ }
578
+ componentDidUpdate(prevProps) {
579
+ attachProps(this.componentEl, this.props, prevProps);
580
+ }
581
+ render() {
582
+ const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
583
+ let propsToPass = Object.keys(cProps).reduce((acc, name) => {
584
+ const value = cProps[name];
585
+ if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
586
+ const eventName = name.substring(2).toLowerCase();
587
+ if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
588
+ acc[name] = value;
589
+ }
590
+ }
591
+ else {
592
+ // we should only render strings, booleans, and numbers as attrs in html.
593
+ // objects, functions, arrays etc get synced via properties on mount.
594
+ const type = typeof value;
595
+ if (type === 'string' || type === 'boolean' || type === 'number') {
596
+ acc[camelToDashCase(name)] = value;
597
+ }
598
+ }
599
+ return acc;
600
+ }, {});
601
+ if (manipulatePropsFunction) {
602
+ propsToPass = manipulatePropsFunction(this.props, propsToPass);
603
+ }
604
+ const newProps = {
605
+ ...propsToPass,
606
+ ref: mergeRefs(forwardedRef, this.setComponentElRef),
607
+ style,
608
+ };
609
+ /**
610
+ * We use createElement here instead of
611
+ * React.createElement to work around a
612
+ * bug in Vite (https://github.com/vitejs/vite/issues/6104).
613
+ * React.createElement causes all elements to be rendered
614
+ * as <tagname> instead of the actual Web Component.
615
+ */
616
+ return createElement(tagName, newProps, children);
617
+ }
618
+ static get displayName() {
619
+ return displayName;
620
+ }
621
+ };
622
+ // If context was passed to createReactComponent then conditionally add it to the Component Class
623
+ if (ReactComponentContext) {
624
+ ReactComponent.contextType = ReactComponentContext;
625
+ }
626
+ return createForwardRef$1(ReactComponent, displayName);
627
+ };
628
+
629
+ /* eslint-disable */
630
+ /* tslint:disable */
631
+ /* auto-generated react proxies */
632
+ const IonAccordion = /*@__PURE__*/ createReactComponent('ion-accordion', undefined, undefined, defineCustomElement$1);
633
+ const IonAccordionGroup = /*@__PURE__*/ createReactComponent('ion-accordion-group', undefined, undefined, defineCustomElement$2);
634
+ const IonAvatar = /*@__PURE__*/ createReactComponent('ion-avatar', undefined, undefined, defineCustomElement$3);
635
+ const IonBackdrop = /*@__PURE__*/ createReactComponent('ion-backdrop', undefined, undefined, defineCustomElement$4);
636
+ const IonBadge = /*@__PURE__*/ createReactComponent('ion-badge', undefined, undefined, defineCustomElement$5);
637
+ const IonBreadcrumbs = /*@__PURE__*/ createReactComponent('ion-breadcrumbs', undefined, undefined, defineCustomElement$6);
638
+ const IonButtons = /*@__PURE__*/ createReactComponent('ion-buttons', undefined, undefined, defineCustomElement$7);
639
+ const IonCardContent = /*@__PURE__*/ createReactComponent('ion-card-content', undefined, undefined, defineCustomElement$8);
640
+ const IonCardHeader = /*@__PURE__*/ createReactComponent('ion-card-header', undefined, undefined, defineCustomElement$9);
641
+ const IonCardSubtitle = /*@__PURE__*/ createReactComponent('ion-card-subtitle', undefined, undefined, defineCustomElement$a);
642
+ const IonCardTitle = /*@__PURE__*/ createReactComponent('ion-card-title', undefined, undefined, defineCustomElement$b);
643
+ const IonCheckbox = /*@__PURE__*/ createReactComponent('ion-checkbox', undefined, undefined, defineCustomElement$c);
644
+ const IonChip = /*@__PURE__*/ createReactComponent('ion-chip', undefined, undefined, defineCustomElement$d);
645
+ const IonCol = /*@__PURE__*/ createReactComponent('ion-col', undefined, undefined, defineCustomElement$e);
646
+ const IonContent = /*@__PURE__*/ createReactComponent('ion-content', undefined, undefined, defineCustomElement$f);
647
+ const IonDatetime = /*@__PURE__*/ createReactComponent('ion-datetime', undefined, undefined, defineCustomElement$g);
648
+ const IonDatetimeButton = /*@__PURE__*/ createReactComponent('ion-datetime-button', undefined, undefined, defineCustomElement$h);
649
+ const IonDivider = /*@__PURE__*/ createReactComponent('ion-divider', undefined, undefined, defineCustomElement$i);
650
+ const IonFab = /*@__PURE__*/ createReactComponent('ion-fab', undefined, undefined, defineCustomElement$j);
651
+ const IonFabList = /*@__PURE__*/ createReactComponent('ion-fab-list', undefined, undefined, defineCustomElement$k);
652
+ const IonFooter = /*@__PURE__*/ createReactComponent('ion-footer', undefined, undefined, defineCustomElement$l);
653
+ const IonGallery = /*@__PURE__*/ createReactComponent('ion-gallery', undefined, undefined, defineCustomElement$m);
654
+ const IonGalleryItem = /*@__PURE__*/ createReactComponent('ion-gallery-item', undefined, undefined, defineCustomElement$n);
655
+ const IonGrid = /*@__PURE__*/ createReactComponent('ion-grid', undefined, undefined, defineCustomElement$o);
656
+ const IonHeader = /*@__PURE__*/ createReactComponent('ion-header', undefined, undefined, defineCustomElement$p);
657
+ const IonImg = /*@__PURE__*/ createReactComponent('ion-img', undefined, undefined, defineCustomElement$q);
658
+ const IonInfiniteScroll = /*@__PURE__*/ createReactComponent('ion-infinite-scroll', undefined, undefined, defineCustomElement$r);
659
+ const IonInfiniteScrollContent = /*@__PURE__*/ createReactComponent('ion-infinite-scroll-content', undefined, undefined, defineCustomElement$s);
660
+ const IonInput = /*@__PURE__*/ createReactComponent('ion-input', undefined, undefined, defineCustomElement$t);
661
+ const IonInputOtp = /*@__PURE__*/ createReactComponent('ion-input-otp', undefined, undefined, defineCustomElement$u);
662
+ const IonInputPasswordToggle = /*@__PURE__*/ createReactComponent('ion-input-password-toggle', undefined, undefined, defineCustomElement$v);
663
+ const IonItemDivider = /*@__PURE__*/ createReactComponent('ion-item-divider', undefined, undefined, defineCustomElement$w);
664
+ const IonItemGroup = /*@__PURE__*/ createReactComponent('ion-item-group', undefined, undefined, defineCustomElement$x);
665
+ const IonItemOptions = /*@__PURE__*/ createReactComponent('ion-item-options', undefined, undefined, defineCustomElement$y);
666
+ const IonItemSliding = /*@__PURE__*/ createReactComponent('ion-item-sliding', undefined, undefined, defineCustomElement$z);
667
+ const IonLabel = /*@__PURE__*/ createReactComponent('ion-label', undefined, undefined, defineCustomElement$A);
668
+ const IonList = /*@__PURE__*/ createReactComponent('ion-list', undefined, undefined, defineCustomElement$B);
669
+ const IonListHeader = /*@__PURE__*/ createReactComponent('ion-list-header', undefined, undefined, defineCustomElement$C);
670
+ const IonMenu = /*@__PURE__*/ createReactComponent('ion-menu', undefined, undefined, defineCustomElement$D);
671
+ const IonMenuButton = /*@__PURE__*/ createReactComponent('ion-menu-button', undefined, undefined, defineCustomElement$E);
672
+ const IonMenuToggle = /*@__PURE__*/ createReactComponent('ion-menu-toggle', undefined, undefined, defineCustomElement$F);
673
+ const IonNavLink = /*@__PURE__*/ createReactComponent('ion-nav-link', undefined, undefined, defineCustomElement$G);
674
+ const IonNote = /*@__PURE__*/ createReactComponent('ion-note', undefined, undefined, defineCustomElement$H);
675
+ const IonPicker = /*@__PURE__*/ createReactComponent('ion-picker', undefined, undefined, defineCustomElement$I);
676
+ const IonPickerColumn = /*@__PURE__*/ createReactComponent('ion-picker-column', undefined, undefined, defineCustomElement$J);
677
+ const IonPickerColumnOption = /*@__PURE__*/ createReactComponent('ion-picker-column-option', undefined, undefined, defineCustomElement$K);
678
+ const IonProgressBar = /*@__PURE__*/ createReactComponent('ion-progress-bar', undefined, undefined, defineCustomElement$L);
679
+ const IonRadio = /*@__PURE__*/ createReactComponent('ion-radio', undefined, undefined, defineCustomElement$M);
680
+ const IonRadioGroup = /*@__PURE__*/ createReactComponent('ion-radio-group', undefined, undefined, defineCustomElement$N);
681
+ const IonRange = /*@__PURE__*/ createReactComponent('ion-range', undefined, undefined, defineCustomElement$O);
682
+ const IonRefresher = /*@__PURE__*/ createReactComponent('ion-refresher', undefined, undefined, defineCustomElement$P);
683
+ const IonRefresherContent = /*@__PURE__*/ createReactComponent('ion-refresher-content', undefined, undefined, defineCustomElement$Q);
684
+ const IonReorder = /*@__PURE__*/ createReactComponent('ion-reorder', undefined, undefined, defineCustomElement$R);
685
+ const IonReorderGroup = /*@__PURE__*/ createReactComponent('ion-reorder-group', undefined, undefined, defineCustomElement$S);
686
+ const IonRippleEffect = /*@__PURE__*/ createReactComponent('ion-ripple-effect', undefined, undefined, defineCustomElement$T);
687
+ const IonRow = /*@__PURE__*/ createReactComponent('ion-row', undefined, undefined, defineCustomElement$U);
688
+ const IonSearchbar = /*@__PURE__*/ createReactComponent('ion-searchbar', undefined, undefined, defineCustomElement$V);
689
+ const IonSegment = /*@__PURE__*/ createReactComponent('ion-segment', undefined, undefined, defineCustomElement$W);
690
+ const IonSegmentButton = /*@__PURE__*/ createReactComponent('ion-segment-button', undefined, undefined, defineCustomElement$X);
691
+ const IonSegmentContent = /*@__PURE__*/ createReactComponent('ion-segment-content', undefined, undefined, defineCustomElement$Y);
692
+ const IonSegmentView = /*@__PURE__*/ createReactComponent('ion-segment-view', undefined, undefined, defineCustomElement$Z);
693
+ const IonSelect = /*@__PURE__*/ createReactComponent('ion-select', undefined, undefined, defineCustomElement$_);
694
+ const IonSelectModal = /*@__PURE__*/ createReactComponent('ion-select-modal', undefined, undefined, defineCustomElement$$);
695
+ const IonSelectOption = /*@__PURE__*/ createReactComponent('ion-select-option', undefined, undefined, defineCustomElement$10);
696
+ const IonSkeletonText = /*@__PURE__*/ createReactComponent('ion-skeleton-text', undefined, undefined, defineCustomElement$11);
697
+ const IonSpinner = /*@__PURE__*/ createReactComponent('ion-spinner', undefined, undefined, defineCustomElement$12);
698
+ const IonSplitPane = /*@__PURE__*/ createReactComponent('ion-split-pane', undefined, undefined, defineCustomElement$13);
699
+ const IonTab = /*@__PURE__*/ createReactComponent('ion-tab', undefined, undefined, defineCustomElement$14);
700
+ const IonText = /*@__PURE__*/ createReactComponent('ion-text', undefined, undefined, defineCustomElement$15);
701
+ const IonTextarea = /*@__PURE__*/ createReactComponent('ion-textarea', undefined, undefined, defineCustomElement$16);
702
+ const IonThumbnail = /*@__PURE__*/ createReactComponent('ion-thumbnail', undefined, undefined, defineCustomElement$17);
703
+ const IonTitle = /*@__PURE__*/ createReactComponent('ion-title', undefined, undefined, defineCustomElement$18);
704
+ const IonToggle = /*@__PURE__*/ createReactComponent('ion-toggle', undefined, undefined, defineCustomElement$19);
705
+ const IonToolbar = /*@__PURE__*/ createReactComponent('ion-toolbar', undefined, undefined, defineCustomElement$1a);
706
+
1251
707
  const createForwardRef = (ReactComponent, // TODO(FW-2959): type
1252
708
  displayName) => {
1253
709
  const forwardRef = (props, ref) => {
@@ -1281,11 +737,6 @@ const createRoutingComponent = (tagName, customElement) => {
1281
737
  this.handleClick = (e) => {
1282
738
  const { routerLink, routerDirection, routerOptions, routerAnimation } = this.props;
1283
739
  if (routerLink !== undefined) {
1284
- // Allow modifier key clicks (ctrl/cmd/shift) to open the link in a new tab/window
1285
- // without triggering SPA navigation on the current page.
1286
- if (e.metaKey || e.ctrlKey || e.shiftKey) {
1287
- return;
1288
- }
1289
740
  e.preventDefault();
1290
741
  this.context.navigate(routerLink, routerDirection, undefined, routerAnimation, routerOptions);
1291
742
  }
@@ -1612,17 +1063,19 @@ const createInlineOverlayComponent = (tagName, defineCustomElement, hasDelegateH
1612
1063
  };
1613
1064
  const DELEGATE_HOST = 'ion-delegate-host';
1614
1065
 
1615
- const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$18);
1066
+ const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$1b);
1616
1067
 
1617
- const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$19);
1068
+ const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$1c);
1618
1069
 
1619
- const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1a);
1070
+ const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1d);
1620
1071
 
1621
- const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1b);
1072
+ const IonPickerLegacy = /*@__PURE__*/ createInlineOverlayComponent('ion-picker-legacy', defineCustomElement$1e);
1622
1073
 
1623
- const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1c, true);
1074
+ const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1f);
1624
1075
 
1625
- const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1d);
1076
+ const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1g, true);
1077
+
1078
+ const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1h);
1626
1079
 
1627
1080
  const IonContext = React.createContext({
1628
1081
  addOverlay: () => {
@@ -1714,81 +1167,14 @@ const IonOverlayManager = ({ onAddOverlay, onRemoveOverlay }) => {
1714
1167
  }) }));
1715
1168
  };
1716
1169
 
1717
- const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => {
1718
- if (defineCustomElement !== undefined) {
1719
- defineCustomElement();
1720
- }
1721
- const displayName = dashToPascalCase(tagName);
1722
- const ReactComponent = class extends React.Component {
1723
- constructor(props) {
1724
- super(props);
1725
- this.setComponentElRef = (element) => {
1726
- this.componentEl = element;
1727
- };
1728
- }
1729
- componentDidMount() {
1730
- this.componentDidUpdate(this.props);
1731
- }
1732
- componentDidUpdate(prevProps) {
1733
- attachProps(this.componentEl, this.props, prevProps);
1734
- }
1735
- render() {
1736
- const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
1737
- let propsToPass = Object.keys(cProps).reduce((acc, name) => {
1738
- const value = cProps[name];
1739
- if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
1740
- const eventName = name.substring(2).toLowerCase();
1741
- if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
1742
- acc[name] = value;
1743
- }
1744
- }
1745
- else {
1746
- // we should only render strings, booleans, and numbers as attrs in html.
1747
- // objects, functions, arrays etc get synced via properties on mount.
1748
- const type = typeof value;
1749
- if (type === 'string' || type === 'boolean' || type === 'number') {
1750
- acc[camelToDashCase(name)] = value;
1751
- }
1752
- }
1753
- return acc;
1754
- }, {});
1755
- if (manipulatePropsFunction) {
1756
- propsToPass = manipulatePropsFunction(this.props, propsToPass);
1757
- }
1758
- const newProps = {
1759
- ...propsToPass,
1760
- ref: mergeRefs(forwardedRef, this.setComponentElRef),
1761
- style,
1762
- children
1763
- };
1764
- /**
1765
- * We use createElement here instead of
1766
- * React.createElement to work around a
1767
- * bug in Vite (https://github.com/vitejs/vite/issues/6104).
1768
- * React.createElement causes all elements to be rendered
1769
- * as <tagname> instead of the actual Web Component.
1770
- */
1771
- return createElement(tagName, newProps, children);
1772
- }
1773
- static get displayName() {
1774
- return displayName;
1775
- }
1776
- };
1777
- // If context was passed to createReactComponent then conditionally add it to the Component Class
1778
- if (ReactComponentContext) {
1779
- ReactComponent.contextType = ReactComponentContext;
1780
- }
1781
- return createForwardRef$1(ReactComponent, displayName);
1782
- };
1783
-
1784
- const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1e);
1785
- const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1f);
1786
- const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1g);
1787
- const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1h);
1788
- const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1i);
1789
- const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1j);
1170
+ const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1i);
1171
+ const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1j);
1172
+ const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1k);
1173
+ const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1l);
1174
+ const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1m);
1175
+ const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1n);
1790
1176
  // ionicons
1791
- const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1k);
1177
+ const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1o);
1792
1178
 
1793
1179
  class IonApp extends React.Component {
1794
1180
  constructor(props) {
@@ -1826,25 +1212,7 @@ class PageManager extends React.PureComponent {
1826
1212
  super(props);
1827
1213
  this.ionPageElementRef = React.createRef();
1828
1214
  // React refs must be stable (not created inline).
1829
- // Wrap merged refs to add ion-page-invisible synchronously when element is created
1830
- const baseMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
1831
- // Guard against React 19 strict mode double-mount re-adding ion-page-invisible.
1832
- // The ref fires again on remount after StackManager may have already removed it.
1833
- let hasAppliedInvisible = false;
1834
- this.stableMergedRefs = (node) => {
1835
- if (node &&
1836
- !hasAppliedInvisible &&
1837
- !node.classList.contains('ion-page-invisible') &&
1838
- !node.classList.contains('ion-page-hidden')) {
1839
- // Add ion-page-invisible synchronously before first paint (if in an outlet)
1840
- // This prevents the flash that occurs when componentDidMount runs after paint
1841
- if (this.context?.isInOutlet?.()) {
1842
- node.classList.add('ion-page-invisible');
1843
- hasAppliedInvisible = true;
1844
- }
1845
- }
1846
- baseMergedRefs(node);
1847
- };
1215
+ this.stableMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
1848
1216
  /**
1849
1217
  * This binds the scope of the following methods to the class scope.
1850
1218
  * The `.bind` method returns a new function, so we need to assign it
@@ -1856,38 +1224,11 @@ class PageManager extends React.PureComponent {
1856
1224
  this.ionViewWillLeaveHandler = this.ionViewWillLeaveHandler.bind(this);
1857
1225
  this.ionViewDidLeaveHandler = this.ionViewDidLeaveHandler.bind(this);
1858
1226
  }
1859
- parseClasses(className) {
1860
- if (!className)
1861
- return new Set();
1862
- return new Set(className.split(/\s+/).filter(Boolean));
1863
- }
1864
- /**
1865
- * Updates classList by diffing old/new className props.
1866
- * Preserves framework-added classes (can-go-back, ion-page-invisible, etc.).
1867
- */
1868
- updateUserClasses(oldClassName, newClassName) {
1869
- if (!this.ionPageElementRef.current)
1870
- return;
1871
- const oldClasses = this.parseClasses(oldClassName);
1872
- const newClasses = this.parseClasses(newClassName);
1873
- oldClasses.forEach((cls) => {
1874
- if (!newClasses.has(cls)) {
1875
- this.ionPageElementRef.current.classList.remove(cls);
1876
- }
1877
- });
1878
- newClasses.forEach((cls) => {
1879
- if (!oldClasses.has(cls)) {
1880
- this.ionPageElementRef.current.classList.add(cls);
1881
- }
1882
- });
1883
- }
1884
1227
  componentDidMount() {
1885
1228
  if (this.ionPageElementRef.current) {
1886
- // Add user classes via DOM manipulation to preserve framework-added classes.
1887
- // We only set "ion-page" in JSX; user classes are added here.
1888
- // Note: ion-page-invisible is added in the ref callback (stableMergedRefs) to prevent flash.
1889
- // The ref callback runs synchronously when the element is created, before the browser paints.
1890
- this.updateUserClasses(undefined, this.props.className);
1229
+ if (this.context.isInOutlet()) {
1230
+ this.ionPageElementRef.current.classList.add('ion-page-invisible');
1231
+ }
1891
1232
  this.context.registerIonPage(this.ionPageElementRef.current, this.props.routeInfo);
1892
1233
  this.ionPageElementRef.current.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
1893
1234
  this.ionPageElementRef.current.addEventListener('ionViewDidEnter', this.ionViewDidEnterHandler);
@@ -1895,11 +1236,6 @@ class PageManager extends React.PureComponent {
1895
1236
  this.ionPageElementRef.current.addEventListener('ionViewDidLeave', this.ionViewDidLeaveHandler);
1896
1237
  }
1897
1238
  }
1898
- componentDidUpdate(prevProps) {
1899
- if (prevProps.className !== this.props.className) {
1900
- this.updateUserClasses(prevProps.className, this.props.className);
1901
- }
1902
- }
1903
1239
  componentWillUnmount() {
1904
1240
  if (this.ionPageElementRef.current) {
1905
1241
  this.ionPageElementRef.current.removeEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
@@ -1929,11 +1265,9 @@ class PageManager extends React.PureComponent {
1929
1265
  render() {
1930
1266
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
1931
1267
  const { className, children, routeInfo, forwardedRef, ...props } = this.props;
1932
- // Only set "ion-page" in JSX. User classes are managed via DOM in componentDidMount/componentDidUpdate
1933
- // to preserve framework-added classes (can-go-back, ion-page-invisible, etc.) when className prop changes.
1934
1268
  return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
1935
1269
  this.ionLifeCycleContext = context;
1936
- return (jsx("div", { className: "ion-page", ref: this.stableMergedRefs, ...props, children: children }));
1270
+ return (jsx("div", { className: className ? `${className} ion-page` : `ion-page`, ref: this.stableMergedRefs, ...props, children: children }));
1937
1271
  } }));
1938
1272
  }
1939
1273
  static get contextType() {
@@ -1993,7 +1327,7 @@ const ReactDelegate = (addView, removeView) => {
1993
1327
  };
1994
1328
  };
1995
1329
 
1996
- const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1l);
1330
+ const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1p);
1997
1331
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
1998
1332
  const IonNavInternal = ({ children, forwardedRef, ...restOfProps }) => {
1999
1333
  const [views, setViews] = useState([]);
@@ -2041,30 +1375,8 @@ class OutletPageManager extends React.Component {
2041
1375
  */
2042
1376
  if (!this.outletIsReady) {
2043
1377
  componentOnReady(this.ionRouterOutlet, () => {
2044
- /**
2045
- * Guard against duplicate callbacks from React strict mode double-mount.
2046
- * Both componentDidMount calls pass the outer !outletIsReady check before
2047
- * either async callback fires. Without this inner guard, the second callback
2048
- * re-adds ion-page-invisible after the first callback's transition removed it,
2049
- * and registerIonPage returns early (same element), leaving the page invisible.
2050
- */
2051
- if (this.outletIsReady)
2052
- return;
2053
1378
  this.outletIsReady = true;
2054
- /**
2055
- * Add ion-page + ion-page-invisible AFTER Stencil hydration but
2056
- * BEFORE registerIonPage. Stencil hydration overwrites className,
2057
- * so classes added in a React ref callback get wiped. Adding them
2058
- * here -- after hydration -- ensures they persist until the parent
2059
- * outlet's forward animation removes ion-page-invisible, preventing
2060
- * a flash where the outlet is briefly visible at full opacity.
2061
- */
2062
- const el = this.ionRouterOutlet;
2063
- if (!el.classList.contains('ion-page-invisible') && !el.classList.contains('ion-page-hidden')) {
2064
- el.classList.add('ion-page');
2065
- el.classList.add('ion-page-invisible');
2066
- }
2067
- this.context.registerIonPage(el, this.props.routeInfo);
1379
+ this.context.registerIonPage(this.ionRouterOutlet, this.props.routeInfo);
2068
1380
  });
2069
1381
  }
2070
1382
  this.ionRouterOutlet.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
@@ -2094,10 +1406,10 @@ class OutletPageManager extends React.Component {
2094
1406
  this.ionLifeCycleContext.ionViewDidLeave();
2095
1407
  }
2096
1408
  render() {
2097
- const { StackManager, children, routeInfo, id, ...props } = this.props;
1409
+ const { StackManager, children, routeInfo, ...props } = this.props;
2098
1410
  return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
2099
1411
  this.ionLifeCycleContext = context;
2100
- return (jsx(StackManager, { id: id, routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { id: id, setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
1412
+ return (jsx(StackManager, { routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
2101
1413
  } }));
2102
1414
  }
2103
1415
  static get contextType() {
@@ -2108,13 +1420,11 @@ class OutletPageManager extends React.Component {
2108
1420
  class IonRouterOutletContainer extends React.Component {
2109
1421
  constructor(props) {
2110
1422
  super(props);
2111
- this.outletId = props.id ?? `routerOutlet-${generateId('routerOutlet')}`;
2112
1423
  }
2113
1424
  render() {
2114
1425
  const StackManager = this.context.getStackManager();
2115
1426
  const { children, forwardedRef, ...props } = this.props;
2116
- const outletId = props.id ?? this.outletId;
2117
- return this.context.hasIonicRouter() ? (props.ionPage ? (jsx(OutletPageManager, { StackManager: StackManager, routeInfo: this.context.routeInfo, ...props, children: children })) : (jsx(StackManager, { routeInfo: this.context.routeInfo, id: outletId, children: jsx(IonRouterOutletInner, { ...props, id: outletId, forwardedRef: forwardedRef, children: children }) }))) : (jsx(IonRouterOutletInner, { ref: forwardedRef, ...this.props, children: this.props.children }));
1427
+ return this.context.hasIonicRouter() ? (props.ionPage ? (jsx(OutletPageManager, { StackManager: StackManager, routeInfo: this.context.routeInfo, ...props, children: children })) : (jsx(StackManager, { routeInfo: this.context.routeInfo, children: jsx(IonRouterOutletInner, { ...props, forwardedRef: forwardedRef, children: children }) }))) : (jsx(IonRouterOutletInner, { ref: forwardedRef, ...this.props, children: this.props.children }));
2118
1428
  }
2119
1429
  static get contextType() {
2120
1430
  return NavContext;
@@ -2311,9 +1621,7 @@ const matchesTab = (pathname, href) => {
2311
1621
  if (href === undefined) {
2312
1622
  return false;
2313
1623
  }
2314
- // Strip query string before comparing — href may contain search params (e.g., "/tabs/home?foo=bar")
2315
- const hrefPathname = href.split('?')[0];
2316
- const normalizedHref = hrefPathname.endsWith('/') && hrefPathname !== '/' ? hrefPathname.slice(0, -1) : hrefPathname;
1624
+ const normalizedHref = href.endsWith('/') && href !== '/' ? href.slice(0, -1) : href;
2317
1625
  return pathname === normalizedHref || pathname.startsWith(normalizedHref + '/');
2318
1626
  };
2319
1627
  class IonTabBarUnwrapped extends React.PureComponent {
@@ -2405,7 +1713,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
2405
1713
  const prevHref = state.tabs[prevActiveTab].currentHref;
2406
1714
  const prevRouteOptions = state.tabs[prevActiveTab].currentRouteOptions;
2407
1715
  if (activeTab !== prevActiveTab ||
2408
- prevHref !== (props.routeInfo?.pathname || '') + (props.routeInfo?.search || '') ||
1716
+ prevHref !== props.routeInfo?.pathname ||
2409
1717
  prevRouteOptions !== props.routeInfo?.routeOptions) {
2410
1718
  tabs[activeTab] = {
2411
1719
  originalHref: tabs[activeTab].originalHref,
@@ -2472,7 +1780,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
2472
1780
  return (child) => {
2473
1781
  if (child != null && child.props && (child.type === IonTabButton || child.type.isTabButton)) {
2474
1782
  const href = child.props.tab === activeTab
2475
- ? (this.props.routeInfo?.pathname || '') + (this.props.routeInfo?.search || '')
1783
+ ? this.props.routeInfo?.pathname
2476
1784
  : this.state.tabs[child.props.tab].currentHref;
2477
1785
  const routeOptions = child.props.tab === activeTab
2478
1786
  ? this.props.routeInfo?.routeOptions
@@ -2597,6 +1905,20 @@ class IonRoute extends React.PureComponent {
2597
1905
  }
2598
1906
  }
2599
1907
 
1908
+ class IonRedirect extends React.PureComponent {
1909
+ render() {
1910
+ const IonRedirectInner = this.context.getIonRedirect();
1911
+ if (!this.context.hasIonicRouter() || !IonRedirect) {
1912
+ console.error('You either do not have an Ionic Router package, or your router does not support using <IonRedirect>');
1913
+ return null;
1914
+ }
1915
+ return jsx(IonRedirectInner, { ...this.props });
1916
+ }
1917
+ static get contextType() {
1918
+ return NavContext;
1919
+ }
1920
+ }
1921
+
2600
1922
  const IonRouterContext = React.createContext({
2601
1923
  routeInfo: undefined, // TODO(FW-2959): type
2602
1924
  push: () => {
@@ -2605,9 +1927,6 @@ const IonRouterContext = React.createContext({
2605
1927
  back: () => {
2606
1928
  throw new Error('An Ionic Router is required for IonRouterContext');
2607
1929
  },
2608
- navigateRoot: () => {
2609
- throw new Error('An Ionic Router is required for IonRouterContext');
2610
- },
2611
1930
  canGoBack: () => {
2612
1931
  throw new Error('An Ionic Router is required for IonRouterContext');
2613
1932
  },
@@ -2624,10 +1943,9 @@ function useIonRouter() {
2624
1943
  back: context.back,
2625
1944
  push: context.push,
2626
1945
  goBack: context.back,
2627
- navigateRoot: context.navigateRoot,
2628
1946
  canGoBack: context.canGoBack,
2629
1947
  routeInfo: context.routeInfo,
2630
- }), [context.back, context.push, context.navigateRoot, context.canGoBack, context.routeInfo]);
1948
+ }), [context.back, context.push, context.canGoBack, context.routeInfo]);
2631
1949
  }
2632
1950
 
2633
1951
  class CreateAnimation extends React.PureComponent {
@@ -2781,7 +2099,7 @@ function useController(displayName, controller, defineCustomElement) {
2781
2099
  * @returns Returns the present and dismiss methods in an array
2782
2100
  */
2783
2101
  function useIonActionSheet() {
2784
- const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1b);
2102
+ const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1f);
2785
2103
  const present = useCallback((buttonsOrOptions, header) => {
2786
2104
  if (Array.isArray(buttonsOrOptions)) {
2787
2105
  return controller.present({
@@ -2801,7 +2119,7 @@ function useIonActionSheet() {
2801
2119
  * @returns Returns the present and dismiss methods in an array
2802
2120
  */
2803
2121
  function useIonAlert() {
2804
- const controller = useController('IonAlert', alertController, defineCustomElement$18);
2122
+ const controller = useController('IonAlert', alertController, defineCustomElement$1b);
2805
2123
  const present = useCallback((messageOrOptions, buttons) => {
2806
2124
  if (typeof messageOrOptions === 'string') {
2807
2125
  return controller.present({
@@ -2821,7 +2139,7 @@ function useIonAlert() {
2821
2139
  * @returns Returns the present and dismiss methods in an array
2822
2140
  */
2823
2141
  function useIonToast() {
2824
- const controller = useController('IonToast', toastController, defineCustomElement$1a);
2142
+ const controller = useController('IonToast', toastController, defineCustomElement$1d);
2825
2143
  const present = useCallback((messageOrOptions, duration) => {
2826
2144
  if (typeof messageOrOptions === 'string') {
2827
2145
  return controller.present({
@@ -2907,7 +2225,7 @@ function useOverlay(displayName, controller, defineCustomElement, component, com
2907
2225
  * @returns Returns the present and dismiss methods in an array
2908
2226
  */
2909
2227
  function useIonModal(component, componentProps) {
2910
- const controller = useOverlay('IonModal', modalController, defineCustomElement$1c, component, componentProps);
2228
+ const controller = useOverlay('IonModal', modalController, defineCustomElement$1g, component, componentProps);
2911
2229
  const present = useCallback((options = {}) => {
2912
2230
  controller.present(options);
2913
2231
  }, [controller.present]);
@@ -2922,19 +2240,40 @@ function useIonModal(component, componentProps) {
2922
2240
  * @returns Returns the present and dismiss methods in an array
2923
2241
  */
2924
2242
  function useIonPopover(component, componentProps) {
2925
- const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1d, component, componentProps);
2243
+ const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1h, component, componentProps);
2926
2244
  const present = useCallback((options = {}) => {
2927
2245
  controller.present(options);
2928
2246
  }, [controller.present]);
2929
2247
  return [present, controller.dismiss];
2930
2248
  }
2931
2249
 
2250
+ /**
2251
+ * A hook for presenting/dismissing an IonPicker component
2252
+ * @returns Returns the present and dismiss methods in an array
2253
+ * @deprecated Use the inline ion-picker component instead.
2254
+ */
2255
+ function useIonPicker() {
2256
+ const controller = useController('IonPicker', pickerController, defineCustomElement$1e);
2257
+ const present = useCallback((columnsOrOptions, buttons) => {
2258
+ if (Array.isArray(columnsOrOptions)) {
2259
+ return controller.present({
2260
+ columns: columnsOrOptions,
2261
+ buttons: buttons ?? [{ text: 'Ok' }],
2262
+ });
2263
+ }
2264
+ else {
2265
+ return controller.present(columnsOrOptions);
2266
+ }
2267
+ }, [controller.present]);
2268
+ return [present, controller.dismiss];
2269
+ }
2270
+
2932
2271
  /**
2933
2272
  * A hook for presenting/dismissing an IonLoading component
2934
2273
  * @returns Returns the present and dismiss methods in an array
2935
2274
  */
2936
2275
  function useIonLoading() {
2937
- const controller = useController('IonLoading', loadingController, defineCustomElement$19);
2276
+ const controller = useController('IonLoading', loadingController, defineCustomElement$1c);
2938
2277
  const present = useCallback((messageOrOptions = {}, duration, spinner) => {
2939
2278
  if (typeof messageOrOptions === 'string') {
2940
2279
  return controller.present({
@@ -2976,7 +2315,6 @@ const RouteManagerContext = /*@__PURE__*/ React.createContext({
2976
2315
  findLeavingViewItemByRouteInfo: () => undefined,
2977
2316
  findViewItemByRouteInfo: () => undefined,
2978
2317
  getChildrenToRender: () => undefined,
2979
- getViewItemsForOutlet: () => [],
2980
2318
  goBack: () => undefined,
2981
2319
  unMountViewItem: () => undefined,
2982
2320
  });
@@ -3095,14 +2433,7 @@ class LocationHistory {
3095
2433
  _replace(routeInfo) {
3096
2434
  const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
3097
2435
  routeInfos && routeInfos.pop();
3098
- // Get the current route that's being replaced
3099
- const currentRoute = this.locationHistory[this.locationHistory.length - 1];
3100
- // Only pop from global history if we're replacing in the same outlet context.
3101
- // Don't pop if we're entering a nested outlet (current route has no tab, new route has a tab)
3102
- const isEnteringNestedOutlet = currentRoute && !currentRoute.tab && !!routeInfo.tab;
3103
- if (!isEnteringNestedOutlet) {
3104
- this.locationHistory.pop();
3105
- }
2436
+ this.locationHistory.pop();
3106
2437
  this._add(routeInfo);
3107
2438
  }
3108
2439
  _clear() {
@@ -3134,20 +2465,6 @@ class LocationHistory {
3134
2465
  }
3135
2466
  return undefined;
3136
2467
  }
3137
- /**
3138
- * Returns the most recent RouteInfo in global history (excluding the current
3139
- * entry) whose pathname matches the given value. Unlike findLastLocation,
3140
- * this search is tab-agnostic. Used by the multi-step back detection.
3141
- */
3142
- findLastLocationByPathname(pathname) {
3143
- for (let i = this.locationHistory.length - 2; i >= 0; i--) {
3144
- const ri = this.locationHistory[i];
3145
- if (ri && ri.pathname === pathname) {
3146
- return ri;
3147
- }
3148
- }
3149
- return undefined;
3150
- }
3151
2468
  findLastLocation(routeInfo) {
3152
2469
  const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
3153
2470
  if (routeInfos) {
@@ -3179,17 +2496,6 @@ class LocationHistory {
3179
2496
  canGoBack() {
3180
2497
  return this.locationHistory.length > 1;
3181
2498
  }
3182
- findTabForPathname(pathname) {
3183
- for (const tab of Object.keys(this.tabHistory)) {
3184
- const routeInfos = this.tabHistory[tab];
3185
- for (let i = routeInfos.length - 1; i >= 0; i--) {
3186
- if (routeInfos[i].pathname === pathname) {
3187
- return tab;
3188
- }
3189
- }
3190
- }
3191
- return undefined;
3192
- }
3193
2499
  }
3194
2500
 
3195
2501
  class NavManager extends React.PureComponent {
@@ -3202,9 +2508,6 @@ class NavManager extends React.PureComponent {
3202
2508
  back: (animationBuilder) => {
3203
2509
  this.goBack(undefined, animationBuilder);
3204
2510
  },
3205
- navigateRoot: (pathname, animationBuilder) => {
3206
- this.props.onNavigateRoot(pathname, animationBuilder);
3207
- },
3208
2511
  canGoBack: () => this.props.locationHistory.canGoBack(),
3209
2512
  nativeBack: () => this.props.onNativeBack(),
3210
2513
  routeInfo: this.props.routeInfo,
@@ -3213,8 +2516,10 @@ class NavManager extends React.PureComponent {
3213
2516
  goBack: this.goBack.bind(this),
3214
2517
  hasIonicRouter: () => true,
3215
2518
  navigate: this.navigate.bind(this),
2519
+ getIonRedirect: this.getIonRedirect.bind(this),
3216
2520
  getIonRoute: this.getIonRoute.bind(this),
3217
2521
  getStackManager: this.getStackManager.bind(this),
2522
+ getPageManager: this.getPageManager.bind(this),
3218
2523
  routeInfo: this.props.routeInfo,
3219
2524
  setCurrentTab: this.props.onSetCurrentTab,
3220
2525
  changeTab: this.props.onChangeTab,
@@ -3247,6 +2552,12 @@ class NavManager extends React.PureComponent {
3247
2552
  navigate(path, direction = 'forward', action = 'push', animationBuilder, options, tab) {
3248
2553
  this.props.onNavigate(path, action, direction, animationBuilder, options, tab);
3249
2554
  }
2555
+ getPageManager() {
2556
+ return PageManager;
2557
+ }
2558
+ getIonRedirect() {
2559
+ return this.props.ionRedirect;
2560
+ }
3250
2561
  getIonRoute() {
3251
2562
  return this.props.ionRoute;
3252
2563
  }
@@ -3276,7 +2587,10 @@ class ViewStacks {
3276
2587
  }
3277
2588
  }
3278
2589
  clear(outletId) {
3279
- delete this.viewStacks[outletId];
2590
+ // Give some time for the leaving views to transition before removing
2591
+ return setTimeout(() => {
2592
+ delete this.viewStacks[outletId];
2593
+ }, 500);
3280
2594
  }
3281
2595
  getViewItemsForOutlet(outletId) {
3282
2596
  return this.viewStacks[outletId] || [];
@@ -3305,5 +2619,5 @@ class ViewStacks {
3305
2619
  }
3306
2620
  }
3307
2621
 
3308
- export { CreateAnimation, DefaultIonLifeCycleContext, IonAccordion, IonAccordionGroup, IonActionSheet, IonAlert, IonApp, IonAvatar, IonBackButton, IonBackdrop, IonBadge, IonBreadcrumb, IonBreadcrumbs, IonButton, IonButtons, IonCard, IonCardContent, IonCardHeader, IonCardSubtitle, IonCardTitle, IonCheckbox, IonChip, IonCol, IonContent, IonDatetime, IonDatetimeButton, IonFab, IonFabButton, IonFabList, IonFooter, IonGrid, IonHeader, IonIcon, IonImg, IonInfiniteScroll, IonInfiniteScrollContent, IonInput, IonInputOtp, IonInputPasswordToggle, IonItem, IonItemDivider, IonItemGroup, IonItemOption, IonItemOptions, IonItemSliding, IonLabel, IonLifeCycleContext, IonList, IonListHeader, IonLoading, IonMenu, IonMenuButton, IonMenuToggle, IonModal, IonNav, IonNavLink, IonNote, IonPage, IonPicker, IonPickerColumn, IonPickerColumnOption, IonPopover, IonProgressBar, IonRadio, IonRadioGroup, IonRange, IonRefresher, IonRefresherContent, IonReorder, IonReorderGroup, IonRippleEffect, IonRoute, IonRouterContext, IonRouterLink, IonRouterOutlet, IonRow, IonSearchbar, IonSegment, IonSegmentButton, IonSegmentContent, IonSegmentView, IonSelect, IonSelectModal, IonSelectOption, IonSkeletonText, IonSpinner, IonSplitPane, IonTab, IonTabBar, IonTabButton, IonTabs, IonTabsContext, IonText, IonTextarea, IonThumbnail, IonTitle, IonToast, IonToggle, IonToolbar, LocationHistory, NavContext, NavManager, RouteManagerContext, StackContext, ViewLifeCycleManager, ViewStacks, generateId, getConfig, getPlatforms, isPlatform, setupIonicReact, useIonActionSheet, useIonAlert, useIonLoading, useIonModal, useIonPopover, useIonRouter, useIonToast, useIonViewDidEnter, useIonViewDidLeave, useIonViewWillEnter, useIonViewWillLeave, withIonLifeCycle };
2622
+ export { CreateAnimation, DefaultIonLifeCycleContext, IonAccordion, IonAccordionGroup, IonActionSheet, IonAlert, IonApp, IonAvatar, IonBackButton, IonBackdrop, IonBadge, IonBreadcrumb, IonBreadcrumbs, IonButton, IonButtons, IonCard, IonCardContent, IonCardHeader, IonCardSubtitle, IonCardTitle, IonCheckbox, IonChip, IonCol, IonContent, IonDatetime, IonDatetimeButton, IonDivider, IonFab, IonFabButton, IonFabList, IonFooter, IonGallery, IonGalleryItem, IonGrid, IonHeader, IonIcon, IonImg, IonInfiniteScroll, IonInfiniteScrollContent, IonInput, IonInputOtp, IonInputPasswordToggle, IonItem, IonItemDivider, IonItemGroup, IonItemOption, IonItemOptions, IonItemSliding, IonLabel, IonLifeCycleContext, IonList, IonListHeader, IonLoading, IonMenu, IonMenuButton, IonMenuToggle, IonModal, IonNav, IonNavLink, IonNote, IonPage, IonPicker, IonPickerColumn, IonPickerColumnOption, IonPickerLegacy, IonPopover, IonProgressBar, IonRadio, IonRadioGroup, IonRange, IonRedirect, IonRefresher, IonRefresherContent, IonReorder, IonReorderGroup, IonRippleEffect, IonRoute, IonRouterContext, IonRouterLink, IonRouterOutlet, IonRow, IonSearchbar, IonSegment, IonSegmentButton, IonSegmentContent, IonSegmentView, IonSelect, IonSelectModal, IonSelectOption, IonSkeletonText, IonSpinner, IonSplitPane, IonTab, IonTabBar, IonTabButton, IonTabs, IonTabsContext, IonText, IonTextarea, IonThumbnail, IonTitle, IonToast, IonToggle, IonToolbar, LocationHistory, NavContext, NavManager, RouteManagerContext, StackContext, ViewLifeCycleManager, ViewStacks, generateId, getConfig, getPlatforms, isPlatform, setupIonicReact, useIonActionSheet, useIonAlert, useIonLoading, useIonModal, useIonPicker, useIonPopover, useIonRouter, useIonToast, useIonViewDidEnter, useIonViewDidLeave, useIonViewWillEnter, useIonViewWillLeave, withIonLifeCycle };
3309
2623
  //# sourceMappingURL=index.js.map