@ionic/react 8.8.12-dev.11781793379.156d3260 → 8.8.12-dev.11782342444.186b6e9c

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-swiper.css +1 -1
  10. package/css/ionic-swiper.css.map +1 -1
  11. package/css/ionic.bundle.css +1 -1
  12. package/css/ionic.bundle.css.map +1 -1
  13. package/css/normalize.css.map +1 -1
  14. package/css/padding.css.map +1 -1
  15. package/css/palettes/dark.always.css.map +1 -1
  16. package/css/palettes/dark.class.css.map +1 -1
  17. package/css/palettes/dark.system.css.map +1 -1
  18. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  19. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  20. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  21. package/css/palettes/high-contrast.always.css.map +1 -1
  22. package/css/palettes/high-contrast.class.css.map +1 -1
  23. package/css/palettes/high-contrast.system.css.map +1 -1
  24. package/css/structure.css.map +1 -1
  25. package/css/text-alignment.css.map +1 -1
  26. package/css/text-transformation.css.map +1 -1
  27. package/css/typography.css.map +1 -1
  28. package/css/utils.bundle.css +1 -1
  29. package/css/utils.bundle.css.map +1 -1
  30. package/dist/index.js +1007 -321
  31. package/dist/index.js.map +1 -1
  32. package/dist/types/components/IonActionSheet.d.ts +1 -1
  33. package/dist/types/components/IonAlert.d.ts +1 -1
  34. package/dist/types/components/IonIcon.d.ts +1 -1
  35. package/dist/types/components/IonLoading.d.ts +1 -1
  36. package/dist/types/components/IonModal.d.ts +1 -1
  37. package/dist/types/components/IonPage.d.ts +1 -1
  38. package/dist/types/components/IonPopover.d.ts +1 -1
  39. package/dist/types/components/IonRoute.d.ts +3 -2
  40. package/dist/types/components/IonRouterContext.d.ts +8 -0
  41. package/dist/types/components/IonRouterOutlet.d.ts +1 -0
  42. package/dist/types/components/IonToast.d.ts +1 -1
  43. package/dist/types/components/components.d.ts +326 -0
  44. package/dist/types/components/createInlineOverlayComponent.d.ts +1 -1
  45. package/dist/types/components/createRoutingComponent.d.ts +1 -1
  46. package/dist/types/components/index.d.ts +2 -5
  47. package/dist/types/components/navigation/IonNav.d.ts +2 -1
  48. package/dist/types/components/navigation/IonTabBar.d.ts +1 -1
  49. package/dist/types/components/navigation/IonTabs.d.ts +1 -2
  50. package/dist/types/components/react-component-lib/createComponent.d.ts +1 -1
  51. package/dist/types/components/react-component-lib/utils/index.d.ts +1 -1
  52. package/dist/types/components/routing-proxies.d.ts +7 -7
  53. package/dist/types/components/utils/index.d.ts +2 -11
  54. package/dist/types/contexts/NavContext.d.ts +0 -2
  55. package/dist/types/lifecycle/IonLifeCycleHOC.d.ts +1 -3
  56. package/dist/types/routing/LocationHistory.d.ts +7 -0
  57. package/dist/types/routing/NavManager.d.ts +2 -4
  58. package/dist/types/routing/OutletPageManager.d.ts +2 -0
  59. package/dist/types/routing/PageManager.d.ts +8 -0
  60. package/dist/types/routing/RouteManagerContext.d.ts +6 -1
  61. package/dist/types/routing/ViewLifeCycleManager.d.ts +1 -0
  62. package/dist/types/routing/ViewStacks.d.ts +2 -2
  63. package/package.json +8 -8
  64. package/css/ionic/bundle.ionic.css +0 -1
  65. package/css/ionic/bundle.ionic.css.map +0 -1
  66. package/css/ionic/core.ionic.css +0 -1
  67. package/css/ionic/core.ionic.css.map +0 -1
  68. package/css/ionic/global.bundle.ionic.css +0 -1
  69. package/css/ionic/global.bundle.ionic.css.map +0 -1
  70. package/css/ionic/ionic-swiper.ionic.css +0 -1
  71. package/css/ionic/ionic-swiper.ionic.css.map +0 -1
  72. package/css/ionic/link.ionic.css +0 -1
  73. package/css/ionic/link.ionic.css.map +0 -1
  74. package/css/ionic/structure.ionic.css +0 -1
  75. package/css/ionic/structure.ionic.css.map +0 -1
  76. package/css/ionic/typography.ionic.css +0 -1
  77. package/css/ionic/typography.ionic.css.map +0 -1
  78. package/css/ionic/utils.bundle.ionic.css +0 -1
  79. package/css/ionic/utils.bundle.ionic.css.map +0 -1
  80. package/dist/types/components/IonPickerLegacy.d.ts +0 -2
  81. package/dist/types/components/IonRedirect.d.ts +0 -16
  82. package/dist/types/components/proxies.d.ts +0 -76
  83. package/dist/types/hooks/useIonPicker.d.ts +0 -27
package/dist/index.js CHANGED
@@ -1,83 +1,80 @@
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, pickerController, loadingController, initialize } from '@ionic/core/components';
3
+ import { isPlatform as isPlatform$1, getPlatforms as getPlatforms$1, componentOnReady, createAnimation, actionSheetController, alertController, toastController, modalController, popoverController, loadingController, initialize } from '@ionic/core/components';
4
4
  export { IonicSafeString, IonicSlides, createAnimation, createGesture, getIonPageElement, getTimeGivenProgression, iosTransitionAnimation, mdTransitionAnimation, openURL } from '@ionic/core/components';
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';
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';
81
78
  import { IonBreadcrumb as IonBreadcrumb$1 } from '@ionic/core/components/ion-breadcrumb.js';
82
79
  import { IonButton as IonButton$1 } from '@ionic/core/components/ion-button.js';
83
80
  import { IonCard as IonCard$1 } from '@ionic/core/components/ion-card.js';
@@ -85,20 +82,20 @@ import { IonFabButton as IonFabButton$1 } from '@ionic/core/components/ion-fab-b
85
82
  import { IonItemOption as IonItemOption$1 } from '@ionic/core/components/ion-item-option.js';
86
83
  import { IonItem as IonItem$1 } from '@ionic/core/components/ion-item.js';
87
84
  import { IonRouterLink as IonRouterLink$1 } from '@ionic/core/components/ion-router-link.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';
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';
102
99
 
103
100
  const IonLifeCycleContext = /*@__PURE__*/ React.createContext({
104
101
  onIonViewWillEnter: () => {
@@ -383,9 +380,7 @@ const useIonViewDidLeave = (callback, deps = []) => {
383
380
  };
384
381
 
385
382
  const NavContext = /*@__PURE__*/ React.createContext({
386
- getIonRedirect: () => undefined,
387
383
  getIonRoute: () => undefined,
388
- getPageManager: () => undefined,
389
384
  getStackManager: () => undefined,
390
385
  goBack: (route) => {
391
386
  if (typeof window !== 'undefined') {
@@ -417,6 +412,699 @@ const NavContext = /*@__PURE__*/ React.createContext({
417
412
  },
418
413
  });
419
414
 
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
+
420
1108
  const dashToPascalCase = (str) => str
421
1109
  .toLowerCase()
422
1110
  .split('-')
@@ -564,150 +1252,6 @@ const defineCustomElement = (tagName, customElement) => {
564
1252
  }
565
1253
  };
566
1254
 
567
- const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => {
568
- if (defineCustomElement !== undefined) {
569
- defineCustomElement();
570
- }
571
- const displayName = dashToPascalCase(tagName);
572
- const ReactComponent = class extends React.Component {
573
- constructor(props) {
574
- super(props);
575
- this.setComponentElRef = (element) => {
576
- this.componentEl = element;
577
- };
578
- }
579
- componentDidMount() {
580
- this.componentDidUpdate(this.props);
581
- }
582
- componentDidUpdate(prevProps) {
583
- attachProps(this.componentEl, this.props, prevProps);
584
- }
585
- render() {
586
- const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
587
- let propsToPass = Object.keys(cProps).reduce((acc, name) => {
588
- const value = cProps[name];
589
- if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
590
- const eventName = name.substring(2).toLowerCase();
591
- if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
592
- acc[name] = value;
593
- }
594
- }
595
- else {
596
- // we should only render strings, booleans, and numbers as attrs in html.
597
- // objects, functions, arrays etc get synced via properties on mount.
598
- const type = typeof value;
599
- if (type === 'string' || type === 'boolean' || type === 'number') {
600
- acc[camelToDashCase(name)] = value;
601
- }
602
- }
603
- return acc;
604
- }, {});
605
- if (manipulatePropsFunction) {
606
- propsToPass = manipulatePropsFunction(this.props, propsToPass);
607
- }
608
- const newProps = {
609
- ...propsToPass,
610
- ref: mergeRefs(forwardedRef, this.setComponentElRef),
611
- style,
612
- };
613
- /**
614
- * We use createElement here instead of
615
- * React.createElement to work around a
616
- * bug in Vite (https://github.com/vitejs/vite/issues/6104).
617
- * React.createElement causes all elements to be rendered
618
- * as <tagname> instead of the actual Web Component.
619
- */
620
- return createElement(tagName, newProps, children);
621
- }
622
- static get displayName() {
623
- return displayName;
624
- }
625
- };
626
- // If context was passed to createReactComponent then conditionally add it to the Component Class
627
- if (ReactComponentContext) {
628
- ReactComponent.contextType = ReactComponentContext;
629
- }
630
- return createForwardRef$1(ReactComponent, displayName);
631
- };
632
-
633
- /* eslint-disable */
634
- /* tslint:disable */
635
- /* auto-generated react proxies */
636
- const IonAccordion = /*@__PURE__*/ createReactComponent('ion-accordion', undefined, undefined, defineCustomElement$1);
637
- const IonAccordionGroup = /*@__PURE__*/ createReactComponent('ion-accordion-group', undefined, undefined, defineCustomElement$2);
638
- const IonAvatar = /*@__PURE__*/ createReactComponent('ion-avatar', undefined, undefined, defineCustomElement$3);
639
- const IonBackdrop = /*@__PURE__*/ createReactComponent('ion-backdrop', undefined, undefined, defineCustomElement$4);
640
- const IonBadge = /*@__PURE__*/ createReactComponent('ion-badge', undefined, undefined, defineCustomElement$5);
641
- const IonBreadcrumbs = /*@__PURE__*/ createReactComponent('ion-breadcrumbs', undefined, undefined, defineCustomElement$6);
642
- const IonButtons = /*@__PURE__*/ createReactComponent('ion-buttons', undefined, undefined, defineCustomElement$7);
643
- const IonCardContent = /*@__PURE__*/ createReactComponent('ion-card-content', undefined, undefined, defineCustomElement$8);
644
- const IonCardHeader = /*@__PURE__*/ createReactComponent('ion-card-header', undefined, undefined, defineCustomElement$9);
645
- const IonCardSubtitle = /*@__PURE__*/ createReactComponent('ion-card-subtitle', undefined, undefined, defineCustomElement$a);
646
- const IonCardTitle = /*@__PURE__*/ createReactComponent('ion-card-title', undefined, undefined, defineCustomElement$b);
647
- const IonCheckbox = /*@__PURE__*/ createReactComponent('ion-checkbox', undefined, undefined, defineCustomElement$c);
648
- const IonChip = /*@__PURE__*/ createReactComponent('ion-chip', undefined, undefined, defineCustomElement$d);
649
- const IonCol = /*@__PURE__*/ createReactComponent('ion-col', undefined, undefined, defineCustomElement$e);
650
- const IonContent = /*@__PURE__*/ createReactComponent('ion-content', undefined, undefined, defineCustomElement$f);
651
- const IonDatetime = /*@__PURE__*/ createReactComponent('ion-datetime', undefined, undefined, defineCustomElement$g);
652
- const IonDatetimeButton = /*@__PURE__*/ createReactComponent('ion-datetime-button', undefined, undefined, defineCustomElement$h);
653
- const IonDivider = /*@__PURE__*/ createReactComponent('ion-divider', undefined, undefined, defineCustomElement$i);
654
- const IonFab = /*@__PURE__*/ createReactComponent('ion-fab', undefined, undefined, defineCustomElement$j);
655
- const IonFabList = /*@__PURE__*/ createReactComponent('ion-fab-list', undefined, undefined, defineCustomElement$k);
656
- const IonFooter = /*@__PURE__*/ createReactComponent('ion-footer', undefined, undefined, defineCustomElement$l);
657
- const IonGallery = /*@__PURE__*/ createReactComponent('ion-gallery', undefined, undefined, defineCustomElement$m);
658
- const IonGalleryItem = /*@__PURE__*/ createReactComponent('ion-gallery-item', undefined, undefined, defineCustomElement$n);
659
- const IonGrid = /*@__PURE__*/ createReactComponent('ion-grid', undefined, undefined, defineCustomElement$o);
660
- const IonHeader = /*@__PURE__*/ createReactComponent('ion-header', undefined, undefined, defineCustomElement$p);
661
- const IonImg = /*@__PURE__*/ createReactComponent('ion-img', undefined, undefined, defineCustomElement$q);
662
- const IonInfiniteScroll = /*@__PURE__*/ createReactComponent('ion-infinite-scroll', undefined, undefined, defineCustomElement$r);
663
- const IonInfiniteScrollContent = /*@__PURE__*/ createReactComponent('ion-infinite-scroll-content', undefined, undefined, defineCustomElement$s);
664
- const IonInput = /*@__PURE__*/ createReactComponent('ion-input', undefined, undefined, defineCustomElement$t);
665
- const IonInputOtp = /*@__PURE__*/ createReactComponent('ion-input-otp', undefined, undefined, defineCustomElement$u);
666
- const IonInputPasswordToggle = /*@__PURE__*/ createReactComponent('ion-input-password-toggle', undefined, undefined, defineCustomElement$v);
667
- const IonItemDivider = /*@__PURE__*/ createReactComponent('ion-item-divider', undefined, undefined, defineCustomElement$w);
668
- const IonItemGroup = /*@__PURE__*/ createReactComponent('ion-item-group', undefined, undefined, defineCustomElement$x);
669
- const IonItemOptions = /*@__PURE__*/ createReactComponent('ion-item-options', undefined, undefined, defineCustomElement$y);
670
- const IonItemSliding = /*@__PURE__*/ createReactComponent('ion-item-sliding', undefined, undefined, defineCustomElement$z);
671
- const IonLabel = /*@__PURE__*/ createReactComponent('ion-label', undefined, undefined, defineCustomElement$A);
672
- const IonList = /*@__PURE__*/ createReactComponent('ion-list', undefined, undefined, defineCustomElement$B);
673
- const IonListHeader = /*@__PURE__*/ createReactComponent('ion-list-header', undefined, undefined, defineCustomElement$C);
674
- const IonMenu = /*@__PURE__*/ createReactComponent('ion-menu', undefined, undefined, defineCustomElement$D);
675
- const IonMenuButton = /*@__PURE__*/ createReactComponent('ion-menu-button', undefined, undefined, defineCustomElement$E);
676
- const IonMenuToggle = /*@__PURE__*/ createReactComponent('ion-menu-toggle', undefined, undefined, defineCustomElement$F);
677
- const IonNavLink = /*@__PURE__*/ createReactComponent('ion-nav-link', undefined, undefined, defineCustomElement$G);
678
- const IonNote = /*@__PURE__*/ createReactComponent('ion-note', undefined, undefined, defineCustomElement$H);
679
- const IonPicker = /*@__PURE__*/ createReactComponent('ion-picker', undefined, undefined, defineCustomElement$I);
680
- const IonPickerColumn = /*@__PURE__*/ createReactComponent('ion-picker-column', undefined, undefined, defineCustomElement$J);
681
- const IonPickerColumnOption = /*@__PURE__*/ createReactComponent('ion-picker-column-option', undefined, undefined, defineCustomElement$K);
682
- const IonProgressBar = /*@__PURE__*/ createReactComponent('ion-progress-bar', undefined, undefined, defineCustomElement$L);
683
- const IonRadio = /*@__PURE__*/ createReactComponent('ion-radio', undefined, undefined, defineCustomElement$M);
684
- const IonRadioGroup = /*@__PURE__*/ createReactComponent('ion-radio-group', undefined, undefined, defineCustomElement$N);
685
- const IonRange = /*@__PURE__*/ createReactComponent('ion-range', undefined, undefined, defineCustomElement$O);
686
- const IonRefresher = /*@__PURE__*/ createReactComponent('ion-refresher', undefined, undefined, defineCustomElement$P);
687
- const IonRefresherContent = /*@__PURE__*/ createReactComponent('ion-refresher-content', undefined, undefined, defineCustomElement$Q);
688
- const IonReorder = /*@__PURE__*/ createReactComponent('ion-reorder', undefined, undefined, defineCustomElement$R);
689
- const IonReorderGroup = /*@__PURE__*/ createReactComponent('ion-reorder-group', undefined, undefined, defineCustomElement$S);
690
- const IonRippleEffect = /*@__PURE__*/ createReactComponent('ion-ripple-effect', undefined, undefined, defineCustomElement$T);
691
- const IonRow = /*@__PURE__*/ createReactComponent('ion-row', undefined, undefined, defineCustomElement$U);
692
- const IonSearchbar = /*@__PURE__*/ createReactComponent('ion-searchbar', undefined, undefined, defineCustomElement$V);
693
- const IonSegment = /*@__PURE__*/ createReactComponent('ion-segment', undefined, undefined, defineCustomElement$W);
694
- const IonSegmentButton = /*@__PURE__*/ createReactComponent('ion-segment-button', undefined, undefined, defineCustomElement$X);
695
- const IonSegmentContent = /*@__PURE__*/ createReactComponent('ion-segment-content', undefined, undefined, defineCustomElement$Y);
696
- const IonSegmentView = /*@__PURE__*/ createReactComponent('ion-segment-view', undefined, undefined, defineCustomElement$Z);
697
- const IonSelect = /*@__PURE__*/ createReactComponent('ion-select', undefined, undefined, defineCustomElement$_);
698
- const IonSelectModal = /*@__PURE__*/ createReactComponent('ion-select-modal', undefined, undefined, defineCustomElement$$);
699
- const IonSelectOption = /*@__PURE__*/ createReactComponent('ion-select-option', undefined, undefined, defineCustomElement$10);
700
- const IonSkeletonText = /*@__PURE__*/ createReactComponent('ion-skeleton-text', undefined, undefined, defineCustomElement$11);
701
- const IonSpinner = /*@__PURE__*/ createReactComponent('ion-spinner', undefined, undefined, defineCustomElement$12);
702
- const IonSplitPane = /*@__PURE__*/ createReactComponent('ion-split-pane', undefined, undefined, defineCustomElement$13);
703
- const IonTab = /*@__PURE__*/ createReactComponent('ion-tab', undefined, undefined, defineCustomElement$14);
704
- const IonText = /*@__PURE__*/ createReactComponent('ion-text', undefined, undefined, defineCustomElement$15);
705
- const IonTextarea = /*@__PURE__*/ createReactComponent('ion-textarea', undefined, undefined, defineCustomElement$16);
706
- const IonThumbnail = /*@__PURE__*/ createReactComponent('ion-thumbnail', undefined, undefined, defineCustomElement$17);
707
- const IonTitle = /*@__PURE__*/ createReactComponent('ion-title', undefined, undefined, defineCustomElement$18);
708
- const IonToggle = /*@__PURE__*/ createReactComponent('ion-toggle', undefined, undefined, defineCustomElement$19);
709
- const IonToolbar = /*@__PURE__*/ createReactComponent('ion-toolbar', undefined, undefined, defineCustomElement$1a);
710
-
711
1255
  const createForwardRef = (ReactComponent, // TODO(FW-2959): type
712
1256
  displayName) => {
713
1257
  const forwardRef = (props, ref) => {
@@ -745,6 +1289,11 @@ const createRoutingComponent = (tagName, customElement) => {
745
1289
  this.handleClick = (e) => {
746
1290
  const { routerLink, routerDirection, routerOptions, routerAnimation } = this.props;
747
1291
  if (routerLink !== undefined) {
1292
+ // Allow modifier key clicks (ctrl/cmd/shift) to open the link in a new tab/window
1293
+ // without triggering SPA navigation on the current page.
1294
+ if (e.metaKey || e.ctrlKey || e.shiftKey) {
1295
+ return;
1296
+ }
748
1297
  e.preventDefault();
749
1298
  this.context.navigate(routerLink, routerDirection, undefined, routerAnimation, routerOptions);
750
1299
  }
@@ -1093,19 +1642,17 @@ const createInlineOverlayComponent = (tagName, defineCustomElement, hasDelegateH
1093
1642
  };
1094
1643
  const DELEGATE_HOST = 'ion-delegate-host';
1095
1644
 
1096
- const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$1b);
1645
+ const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$18);
1097
1646
 
1098
- const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$1c);
1647
+ const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$19);
1099
1648
 
1100
- const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1d);
1649
+ const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1a);
1101
1650
 
1102
- const IonPickerLegacy = /*@__PURE__*/ createInlineOverlayComponent('ion-picker-legacy', defineCustomElement$1e);
1651
+ const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1b);
1103
1652
 
1104
- const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1f);
1653
+ const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1c, true);
1105
1654
 
1106
- const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1g, true);
1107
-
1108
- const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1h);
1655
+ const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1d);
1109
1656
 
1110
1657
  const IonContext = React.createContext({
1111
1658
  addOverlay: () => {
@@ -1197,14 +1744,81 @@ const IonOverlayManager = ({ onAddOverlay, onRemoveOverlay }) => {
1197
1744
  }) }));
1198
1745
  };
1199
1746
 
1200
- const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1i);
1201
- const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1j);
1202
- const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1k);
1203
- const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1l);
1204
- const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1m);
1205
- const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1n);
1747
+ const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => {
1748
+ if (defineCustomElement !== undefined) {
1749
+ defineCustomElement();
1750
+ }
1751
+ const displayName = dashToPascalCase(tagName);
1752
+ const ReactComponent = class extends React.Component {
1753
+ constructor(props) {
1754
+ super(props);
1755
+ this.setComponentElRef = (element) => {
1756
+ this.componentEl = element;
1757
+ };
1758
+ }
1759
+ componentDidMount() {
1760
+ this.componentDidUpdate(this.props);
1761
+ }
1762
+ componentDidUpdate(prevProps) {
1763
+ attachProps(this.componentEl, this.props, prevProps);
1764
+ }
1765
+ render() {
1766
+ const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
1767
+ let propsToPass = Object.keys(cProps).reduce((acc, name) => {
1768
+ const value = cProps[name];
1769
+ if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
1770
+ const eventName = name.substring(2).toLowerCase();
1771
+ if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
1772
+ acc[name] = value;
1773
+ }
1774
+ }
1775
+ else {
1776
+ // we should only render strings, booleans, and numbers as attrs in html.
1777
+ // objects, functions, arrays etc get synced via properties on mount.
1778
+ const type = typeof value;
1779
+ if (type === 'string' || type === 'boolean' || type === 'number') {
1780
+ acc[camelToDashCase(name)] = value;
1781
+ }
1782
+ }
1783
+ return acc;
1784
+ }, {});
1785
+ if (manipulatePropsFunction) {
1786
+ propsToPass = manipulatePropsFunction(this.props, propsToPass);
1787
+ }
1788
+ const newProps = {
1789
+ ...propsToPass,
1790
+ ref: mergeRefs(forwardedRef, this.setComponentElRef),
1791
+ style,
1792
+ children
1793
+ };
1794
+ /**
1795
+ * We use createElement here instead of
1796
+ * React.createElement to work around a
1797
+ * bug in Vite (https://github.com/vitejs/vite/issues/6104).
1798
+ * React.createElement causes all elements to be rendered
1799
+ * as <tagname> instead of the actual Web Component.
1800
+ */
1801
+ return createElement(tagName, newProps, children);
1802
+ }
1803
+ static get displayName() {
1804
+ return displayName;
1805
+ }
1806
+ };
1807
+ // If context was passed to createReactComponent then conditionally add it to the Component Class
1808
+ if (ReactComponentContext) {
1809
+ ReactComponent.contextType = ReactComponentContext;
1810
+ }
1811
+ return createForwardRef$1(ReactComponent, displayName);
1812
+ };
1813
+
1814
+ const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1e);
1815
+ const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1f);
1816
+ const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1g);
1817
+ const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1h);
1818
+ const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1i);
1819
+ const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1j);
1206
1820
  // ionicons
1207
- const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1o);
1821
+ const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1k);
1208
1822
 
1209
1823
  class IonApp extends React.Component {
1210
1824
  constructor(props) {
@@ -1242,7 +1856,25 @@ class PageManager extends React.PureComponent {
1242
1856
  super(props);
1243
1857
  this.ionPageElementRef = React.createRef();
1244
1858
  // React refs must be stable (not created inline).
1245
- this.stableMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
1859
+ // Wrap merged refs to add ion-page-invisible synchronously when element is created
1860
+ const baseMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
1861
+ // Guard against React 19 strict mode double-mount re-adding ion-page-invisible.
1862
+ // The ref fires again on remount after StackManager may have already removed it.
1863
+ let hasAppliedInvisible = false;
1864
+ this.stableMergedRefs = (node) => {
1865
+ if (node &&
1866
+ !hasAppliedInvisible &&
1867
+ !node.classList.contains('ion-page-invisible') &&
1868
+ !node.classList.contains('ion-page-hidden')) {
1869
+ // Add ion-page-invisible synchronously before first paint (if in an outlet)
1870
+ // This prevents the flash that occurs when componentDidMount runs after paint
1871
+ if (this.context?.isInOutlet?.()) {
1872
+ node.classList.add('ion-page-invisible');
1873
+ hasAppliedInvisible = true;
1874
+ }
1875
+ }
1876
+ baseMergedRefs(node);
1877
+ };
1246
1878
  /**
1247
1879
  * This binds the scope of the following methods to the class scope.
1248
1880
  * The `.bind` method returns a new function, so we need to assign it
@@ -1254,11 +1886,38 @@ class PageManager extends React.PureComponent {
1254
1886
  this.ionViewWillLeaveHandler = this.ionViewWillLeaveHandler.bind(this);
1255
1887
  this.ionViewDidLeaveHandler = this.ionViewDidLeaveHandler.bind(this);
1256
1888
  }
1889
+ parseClasses(className) {
1890
+ if (!className)
1891
+ return new Set();
1892
+ return new Set(className.split(/\s+/).filter(Boolean));
1893
+ }
1894
+ /**
1895
+ * Updates classList by diffing old/new className props.
1896
+ * Preserves framework-added classes (can-go-back, ion-page-invisible, etc.).
1897
+ */
1898
+ updateUserClasses(oldClassName, newClassName) {
1899
+ if (!this.ionPageElementRef.current)
1900
+ return;
1901
+ const oldClasses = this.parseClasses(oldClassName);
1902
+ const newClasses = this.parseClasses(newClassName);
1903
+ oldClasses.forEach((cls) => {
1904
+ if (!newClasses.has(cls)) {
1905
+ this.ionPageElementRef.current.classList.remove(cls);
1906
+ }
1907
+ });
1908
+ newClasses.forEach((cls) => {
1909
+ if (!oldClasses.has(cls)) {
1910
+ this.ionPageElementRef.current.classList.add(cls);
1911
+ }
1912
+ });
1913
+ }
1257
1914
  componentDidMount() {
1258
1915
  if (this.ionPageElementRef.current) {
1259
- if (this.context.isInOutlet()) {
1260
- this.ionPageElementRef.current.classList.add('ion-page-invisible');
1261
- }
1916
+ // Add user classes via DOM manipulation to preserve framework-added classes.
1917
+ // We only set "ion-page" in JSX; user classes are added here.
1918
+ // Note: ion-page-invisible is added in the ref callback (stableMergedRefs) to prevent flash.
1919
+ // The ref callback runs synchronously when the element is created, before the browser paints.
1920
+ this.updateUserClasses(undefined, this.props.className);
1262
1921
  this.context.registerIonPage(this.ionPageElementRef.current, this.props.routeInfo);
1263
1922
  this.ionPageElementRef.current.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
1264
1923
  this.ionPageElementRef.current.addEventListener('ionViewDidEnter', this.ionViewDidEnterHandler);
@@ -1266,6 +1925,11 @@ class PageManager extends React.PureComponent {
1266
1925
  this.ionPageElementRef.current.addEventListener('ionViewDidLeave', this.ionViewDidLeaveHandler);
1267
1926
  }
1268
1927
  }
1928
+ componentDidUpdate(prevProps) {
1929
+ if (prevProps.className !== this.props.className) {
1930
+ this.updateUserClasses(prevProps.className, this.props.className);
1931
+ }
1932
+ }
1269
1933
  componentWillUnmount() {
1270
1934
  if (this.ionPageElementRef.current) {
1271
1935
  this.ionPageElementRef.current.removeEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
@@ -1295,9 +1959,11 @@ class PageManager extends React.PureComponent {
1295
1959
  render() {
1296
1960
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
1297
1961
  const { className, children, routeInfo, forwardedRef, ...props } = this.props;
1962
+ // Only set "ion-page" in JSX. User classes are managed via DOM in componentDidMount/componentDidUpdate
1963
+ // to preserve framework-added classes (can-go-back, ion-page-invisible, etc.) when className prop changes.
1298
1964
  return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
1299
1965
  this.ionLifeCycleContext = context;
1300
- return (jsx("div", { className: className ? `${className} ion-page` : `ion-page`, ref: this.stableMergedRefs, ...props, children: children }));
1966
+ return (jsx("div", { className: "ion-page", ref: this.stableMergedRefs, ...props, children: children }));
1301
1967
  } }));
1302
1968
  }
1303
1969
  static get contextType() {
@@ -1357,7 +2023,7 @@ const ReactDelegate = (addView, removeView) => {
1357
2023
  };
1358
2024
  };
1359
2025
 
1360
- const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1p);
2026
+ const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1l);
1361
2027
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
1362
2028
  const IonNavInternal = ({ children, forwardedRef, ...restOfProps }) => {
1363
2029
  const [views, setViews] = useState([]);
@@ -1405,8 +2071,30 @@ class OutletPageManager extends React.Component {
1405
2071
  */
1406
2072
  if (!this.outletIsReady) {
1407
2073
  componentOnReady(this.ionRouterOutlet, () => {
2074
+ /**
2075
+ * Guard against duplicate callbacks from React strict mode double-mount.
2076
+ * Both componentDidMount calls pass the outer !outletIsReady check before
2077
+ * either async callback fires. Without this inner guard, the second callback
2078
+ * re-adds ion-page-invisible after the first callback's transition removed it,
2079
+ * and registerIonPage returns early (same element), leaving the page invisible.
2080
+ */
2081
+ if (this.outletIsReady)
2082
+ return;
1408
2083
  this.outletIsReady = true;
1409
- this.context.registerIonPage(this.ionRouterOutlet, this.props.routeInfo);
2084
+ /**
2085
+ * Add ion-page + ion-page-invisible AFTER Stencil hydration but
2086
+ * BEFORE registerIonPage. Stencil hydration overwrites className,
2087
+ * so classes added in a React ref callback get wiped. Adding them
2088
+ * here -- after hydration -- ensures they persist until the parent
2089
+ * outlet's forward animation removes ion-page-invisible, preventing
2090
+ * a flash where the outlet is briefly visible at full opacity.
2091
+ */
2092
+ const el = this.ionRouterOutlet;
2093
+ if (!el.classList.contains('ion-page-invisible') && !el.classList.contains('ion-page-hidden')) {
2094
+ el.classList.add('ion-page');
2095
+ el.classList.add('ion-page-invisible');
2096
+ }
2097
+ this.context.registerIonPage(el, this.props.routeInfo);
1410
2098
  });
1411
2099
  }
1412
2100
  this.ionRouterOutlet.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
@@ -1436,10 +2124,10 @@ class OutletPageManager extends React.Component {
1436
2124
  this.ionLifeCycleContext.ionViewDidLeave();
1437
2125
  }
1438
2126
  render() {
1439
- const { StackManager, children, routeInfo, ...props } = this.props;
2127
+ const { StackManager, children, routeInfo, id, ...props } = this.props;
1440
2128
  return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
1441
2129
  this.ionLifeCycleContext = context;
1442
- return (jsx(StackManager, { routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
2130
+ return (jsx(StackManager, { id: id, routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { id: id, setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
1443
2131
  } }));
1444
2132
  }
1445
2133
  static get contextType() {
@@ -1450,11 +2138,13 @@ class OutletPageManager extends React.Component {
1450
2138
  class IonRouterOutletContainer extends React.Component {
1451
2139
  constructor(props) {
1452
2140
  super(props);
2141
+ this.outletId = props.id ?? `routerOutlet-${generateId('routerOutlet')}`;
1453
2142
  }
1454
2143
  render() {
1455
2144
  const StackManager = this.context.getStackManager();
1456
2145
  const { children, forwardedRef, ...props } = this.props;
1457
- 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 }));
2146
+ const outletId = props.id ?? this.outletId;
2147
+ 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 }));
1458
2148
  }
1459
2149
  static get contextType() {
1460
2150
  return NavContext;
@@ -1651,7 +2341,9 @@ const matchesTab = (pathname, href) => {
1651
2341
  if (href === undefined) {
1652
2342
  return false;
1653
2343
  }
1654
- const normalizedHref = href.endsWith('/') && href !== '/' ? href.slice(0, -1) : href;
2344
+ // Strip query string before comparing — href may contain search params (e.g., "/tabs/home?foo=bar")
2345
+ const hrefPathname = href.split('?')[0];
2346
+ const normalizedHref = hrefPathname.endsWith('/') && hrefPathname !== '/' ? hrefPathname.slice(0, -1) : hrefPathname;
1655
2347
  return pathname === normalizedHref || pathname.startsWith(normalizedHref + '/');
1656
2348
  };
1657
2349
  class IonTabBarUnwrapped extends React.PureComponent {
@@ -1743,7 +2435,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
1743
2435
  const prevHref = state.tabs[prevActiveTab].currentHref;
1744
2436
  const prevRouteOptions = state.tabs[prevActiveTab].currentRouteOptions;
1745
2437
  if (activeTab !== prevActiveTab ||
1746
- prevHref !== props.routeInfo?.pathname ||
2438
+ prevHref !== (props.routeInfo?.pathname || '') + (props.routeInfo?.search || '') ||
1747
2439
  prevRouteOptions !== props.routeInfo?.routeOptions) {
1748
2440
  tabs[activeTab] = {
1749
2441
  originalHref: tabs[activeTab].originalHref,
@@ -1810,7 +2502,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
1810
2502
  return (child) => {
1811
2503
  if (child != null && child.props && (child.type === IonTabButton || child.type.isTabButton)) {
1812
2504
  const href = child.props.tab === activeTab
1813
- ? this.props.routeInfo?.pathname
2505
+ ? (this.props.routeInfo?.pathname || '') + (this.props.routeInfo?.search || '')
1814
2506
  : this.state.tabs[child.props.tab].currentHref;
1815
2507
  const routeOptions = child.props.tab === activeTab
1816
2508
  ? this.props.routeInfo?.routeOptions
@@ -1935,20 +2627,6 @@ class IonRoute extends React.PureComponent {
1935
2627
  }
1936
2628
  }
1937
2629
 
1938
- class IonRedirect extends React.PureComponent {
1939
- render() {
1940
- const IonRedirectInner = this.context.getIonRedirect();
1941
- if (!this.context.hasIonicRouter() || !IonRedirect) {
1942
- console.error('You either do not have an Ionic Router package, or your router does not support using <IonRedirect>');
1943
- return null;
1944
- }
1945
- return jsx(IonRedirectInner, { ...this.props });
1946
- }
1947
- static get contextType() {
1948
- return NavContext;
1949
- }
1950
- }
1951
-
1952
2630
  const IonRouterContext = React.createContext({
1953
2631
  routeInfo: undefined, // TODO(FW-2959): type
1954
2632
  push: () => {
@@ -1957,6 +2635,9 @@ const IonRouterContext = React.createContext({
1957
2635
  back: () => {
1958
2636
  throw new Error('An Ionic Router is required for IonRouterContext');
1959
2637
  },
2638
+ navigateRoot: () => {
2639
+ throw new Error('An Ionic Router is required for IonRouterContext');
2640
+ },
1960
2641
  canGoBack: () => {
1961
2642
  throw new Error('An Ionic Router is required for IonRouterContext');
1962
2643
  },
@@ -1973,9 +2654,10 @@ function useIonRouter() {
1973
2654
  back: context.back,
1974
2655
  push: context.push,
1975
2656
  goBack: context.back,
2657
+ navigateRoot: context.navigateRoot,
1976
2658
  canGoBack: context.canGoBack,
1977
2659
  routeInfo: context.routeInfo,
1978
- }), [context.back, context.push, context.canGoBack, context.routeInfo]);
2660
+ }), [context.back, context.push, context.navigateRoot, context.canGoBack, context.routeInfo]);
1979
2661
  }
1980
2662
 
1981
2663
  class CreateAnimation extends React.PureComponent {
@@ -2129,7 +2811,7 @@ function useController(displayName, controller, defineCustomElement) {
2129
2811
  * @returns Returns the present and dismiss methods in an array
2130
2812
  */
2131
2813
  function useIonActionSheet() {
2132
- const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1f);
2814
+ const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1b);
2133
2815
  const present = useCallback((buttonsOrOptions, header) => {
2134
2816
  if (Array.isArray(buttonsOrOptions)) {
2135
2817
  return controller.present({
@@ -2149,7 +2831,7 @@ function useIonActionSheet() {
2149
2831
  * @returns Returns the present and dismiss methods in an array
2150
2832
  */
2151
2833
  function useIonAlert() {
2152
- const controller = useController('IonAlert', alertController, defineCustomElement$1b);
2834
+ const controller = useController('IonAlert', alertController, defineCustomElement$18);
2153
2835
  const present = useCallback((messageOrOptions, buttons) => {
2154
2836
  if (typeof messageOrOptions === 'string') {
2155
2837
  return controller.present({
@@ -2169,7 +2851,7 @@ function useIonAlert() {
2169
2851
  * @returns Returns the present and dismiss methods in an array
2170
2852
  */
2171
2853
  function useIonToast() {
2172
- const controller = useController('IonToast', toastController, defineCustomElement$1d);
2854
+ const controller = useController('IonToast', toastController, defineCustomElement$1a);
2173
2855
  const present = useCallback((messageOrOptions, duration) => {
2174
2856
  if (typeof messageOrOptions === 'string') {
2175
2857
  return controller.present({
@@ -2255,7 +2937,7 @@ function useOverlay(displayName, controller, defineCustomElement, component, com
2255
2937
  * @returns Returns the present and dismiss methods in an array
2256
2938
  */
2257
2939
  function useIonModal(component, componentProps) {
2258
- const controller = useOverlay('IonModal', modalController, defineCustomElement$1g, component, componentProps);
2940
+ const controller = useOverlay('IonModal', modalController, defineCustomElement$1c, component, componentProps);
2259
2941
  const present = useCallback((options = {}) => {
2260
2942
  controller.present(options);
2261
2943
  }, [controller.present]);
@@ -2270,40 +2952,19 @@ function useIonModal(component, componentProps) {
2270
2952
  * @returns Returns the present and dismiss methods in an array
2271
2953
  */
2272
2954
  function useIonPopover(component, componentProps) {
2273
- const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1h, component, componentProps);
2955
+ const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1d, component, componentProps);
2274
2956
  const present = useCallback((options = {}) => {
2275
2957
  controller.present(options);
2276
2958
  }, [controller.present]);
2277
2959
  return [present, controller.dismiss];
2278
2960
  }
2279
2961
 
2280
- /**
2281
- * A hook for presenting/dismissing an IonPicker component
2282
- * @returns Returns the present and dismiss methods in an array
2283
- * @deprecated Use the inline ion-picker component instead.
2284
- */
2285
- function useIonPicker() {
2286
- const controller = useController('IonPicker', pickerController, defineCustomElement$1e);
2287
- const present = useCallback((columnsOrOptions, buttons) => {
2288
- if (Array.isArray(columnsOrOptions)) {
2289
- return controller.present({
2290
- columns: columnsOrOptions,
2291
- buttons: buttons ?? [{ text: 'Ok' }],
2292
- });
2293
- }
2294
- else {
2295
- return controller.present(columnsOrOptions);
2296
- }
2297
- }, [controller.present]);
2298
- return [present, controller.dismiss];
2299
- }
2300
-
2301
2962
  /**
2302
2963
  * A hook for presenting/dismissing an IonLoading component
2303
2964
  * @returns Returns the present and dismiss methods in an array
2304
2965
  */
2305
2966
  function useIonLoading() {
2306
- const controller = useController('IonLoading', loadingController, defineCustomElement$1c);
2967
+ const controller = useController('IonLoading', loadingController, defineCustomElement$19);
2307
2968
  const present = useCallback((messageOrOptions = {}, duration, spinner) => {
2308
2969
  if (typeof messageOrOptions === 'string') {
2309
2970
  return controller.present({
@@ -2345,6 +3006,7 @@ const RouteManagerContext = /*@__PURE__*/ React.createContext({
2345
3006
  findLeavingViewItemByRouteInfo: () => undefined,
2346
3007
  findViewItemByRouteInfo: () => undefined,
2347
3008
  getChildrenToRender: () => undefined,
3009
+ getViewItemsForOutlet: () => [],
2348
3010
  goBack: () => undefined,
2349
3011
  unMountViewItem: () => undefined,
2350
3012
  });
@@ -2463,7 +3125,14 @@ class LocationHistory {
2463
3125
  _replace(routeInfo) {
2464
3126
  const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
2465
3127
  routeInfos && routeInfos.pop();
2466
- this.locationHistory.pop();
3128
+ // Get the current route that's being replaced
3129
+ const currentRoute = this.locationHistory[this.locationHistory.length - 1];
3130
+ // Only pop from global history if we're replacing in the same outlet context.
3131
+ // Don't pop if we're entering a nested outlet (current route has no tab, new route has a tab)
3132
+ const isEnteringNestedOutlet = currentRoute && !currentRoute.tab && !!routeInfo.tab;
3133
+ if (!isEnteringNestedOutlet) {
3134
+ this.locationHistory.pop();
3135
+ }
2467
3136
  this._add(routeInfo);
2468
3137
  }
2469
3138
  _clear() {
@@ -2495,6 +3164,20 @@ class LocationHistory {
2495
3164
  }
2496
3165
  return undefined;
2497
3166
  }
3167
+ /**
3168
+ * Returns the most recent RouteInfo in global history (excluding the current
3169
+ * entry) whose pathname matches the given value. Unlike findLastLocation,
3170
+ * this search is tab-agnostic. Used by the multi-step back detection.
3171
+ */
3172
+ findLastLocationByPathname(pathname) {
3173
+ for (let i = this.locationHistory.length - 2; i >= 0; i--) {
3174
+ const ri = this.locationHistory[i];
3175
+ if (ri && ri.pathname === pathname) {
3176
+ return ri;
3177
+ }
3178
+ }
3179
+ return undefined;
3180
+ }
2498
3181
  findLastLocation(routeInfo) {
2499
3182
  const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
2500
3183
  if (routeInfos) {
@@ -2526,6 +3209,17 @@ class LocationHistory {
2526
3209
  canGoBack() {
2527
3210
  return this.locationHistory.length > 1;
2528
3211
  }
3212
+ findTabForPathname(pathname) {
3213
+ for (const tab of Object.keys(this.tabHistory)) {
3214
+ const routeInfos = this.tabHistory[tab];
3215
+ for (let i = routeInfos.length - 1; i >= 0; i--) {
3216
+ if (routeInfos[i].pathname === pathname) {
3217
+ return tab;
3218
+ }
3219
+ }
3220
+ }
3221
+ return undefined;
3222
+ }
2529
3223
  }
2530
3224
 
2531
3225
  class NavManager extends React.PureComponent {
@@ -2538,6 +3232,9 @@ class NavManager extends React.PureComponent {
2538
3232
  back: (animationBuilder) => {
2539
3233
  this.goBack(undefined, animationBuilder);
2540
3234
  },
3235
+ navigateRoot: (pathname, animationBuilder) => {
3236
+ this.props.onNavigateRoot(pathname, animationBuilder);
3237
+ },
2541
3238
  canGoBack: () => this.props.locationHistory.canGoBack(),
2542
3239
  nativeBack: () => this.props.onNativeBack(),
2543
3240
  routeInfo: this.props.routeInfo,
@@ -2546,10 +3243,8 @@ class NavManager extends React.PureComponent {
2546
3243
  goBack: this.goBack.bind(this),
2547
3244
  hasIonicRouter: () => true,
2548
3245
  navigate: this.navigate.bind(this),
2549
- getIonRedirect: this.getIonRedirect.bind(this),
2550
3246
  getIonRoute: this.getIonRoute.bind(this),
2551
3247
  getStackManager: this.getStackManager.bind(this),
2552
- getPageManager: this.getPageManager.bind(this),
2553
3248
  routeInfo: this.props.routeInfo,
2554
3249
  setCurrentTab: this.props.onSetCurrentTab,
2555
3250
  changeTab: this.props.onChangeTab,
@@ -2582,12 +3277,6 @@ class NavManager extends React.PureComponent {
2582
3277
  navigate(path, direction = 'forward', action = 'push', animationBuilder, options, tab) {
2583
3278
  this.props.onNavigate(path, action, direction, animationBuilder, options, tab);
2584
3279
  }
2585
- getPageManager() {
2586
- return PageManager;
2587
- }
2588
- getIonRedirect() {
2589
- return this.props.ionRedirect;
2590
- }
2591
3280
  getIonRoute() {
2592
3281
  return this.props.ionRoute;
2593
3282
  }
@@ -2617,10 +3306,7 @@ class ViewStacks {
2617
3306
  }
2618
3307
  }
2619
3308
  clear(outletId) {
2620
- // Give some time for the leaving views to transition before removing
2621
- return setTimeout(() => {
2622
- delete this.viewStacks[outletId];
2623
- }, 500);
3309
+ delete this.viewStacks[outletId];
2624
3310
  }
2625
3311
  getViewItemsForOutlet(outletId) {
2626
3312
  return this.viewStacks[outletId] || [];
@@ -2649,5 +3335,5 @@ class ViewStacks {
2649
3335
  }
2650
3336
  }
2651
3337
 
2652
- 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 };
3338
+ 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 };
2653
3339
  //# sourceMappingURL=index.js.map