@ionic/react 8.8.6-dev.11777569278.1613db2e → 8.8.6-dev.11777572994.1147595d

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 -319
  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 +3 -2
  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 -75
  83. package/dist/types/hooks/useIonPicker.d.ts +0 -27
package/dist/index.js CHANGED
@@ -1,82 +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-grid.js';
29
- import { defineCustomElement as defineCustomElement$o } from '@ionic/core/components/ion-header.js';
30
- import { defineCustomElement as defineCustomElement$p } from '@ionic/core/components/ion-img.js';
31
- import { defineCustomElement as defineCustomElement$q } from '@ionic/core/components/ion-infinite-scroll.js';
32
- import { defineCustomElement as defineCustomElement$r } from '@ionic/core/components/ion-infinite-scroll-content.js';
33
- import { defineCustomElement as defineCustomElement$s } from '@ionic/core/components/ion-input.js';
34
- import { defineCustomElement as defineCustomElement$t } from '@ionic/core/components/ion-input-otp.js';
35
- import { defineCustomElement as defineCustomElement$u } from '@ionic/core/components/ion-input-password-toggle.js';
36
- import { defineCustomElement as defineCustomElement$v } from '@ionic/core/components/ion-item-divider.js';
37
- import { defineCustomElement as defineCustomElement$w } from '@ionic/core/components/ion-item-group.js';
38
- import { defineCustomElement as defineCustomElement$x } from '@ionic/core/components/ion-item-options.js';
39
- import { defineCustomElement as defineCustomElement$y } from '@ionic/core/components/ion-item-sliding.js';
40
- import { defineCustomElement as defineCustomElement$z } from '@ionic/core/components/ion-label.js';
41
- import { defineCustomElement as defineCustomElement$A } from '@ionic/core/components/ion-list.js';
42
- import { defineCustomElement as defineCustomElement$B } from '@ionic/core/components/ion-list-header.js';
43
- import { defineCustomElement as defineCustomElement$C } from '@ionic/core/components/ion-menu.js';
44
- import { defineCustomElement as defineCustomElement$D } from '@ionic/core/components/ion-menu-button.js';
45
- import { defineCustomElement as defineCustomElement$E } from '@ionic/core/components/ion-menu-toggle.js';
46
- import { defineCustomElement as defineCustomElement$1o } from '@ionic/core/components/ion-nav.js';
47
- import { defineCustomElement as defineCustomElement$F } from '@ionic/core/components/ion-nav-link.js';
48
- import { defineCustomElement as defineCustomElement$G } from '@ionic/core/components/ion-note.js';
49
- import { defineCustomElement as defineCustomElement$H } from '@ionic/core/components/ion-picker.js';
50
- import { defineCustomElement as defineCustomElement$I } from '@ionic/core/components/ion-picker-column.js';
51
- import { defineCustomElement as defineCustomElement$J } from '@ionic/core/components/ion-picker-column-option.js';
52
- import { defineCustomElement as defineCustomElement$K } from '@ionic/core/components/ion-progress-bar.js';
53
- import { defineCustomElement as defineCustomElement$L } from '@ionic/core/components/ion-radio.js';
54
- import { defineCustomElement as defineCustomElement$M } from '@ionic/core/components/ion-radio-group.js';
55
- import { defineCustomElement as defineCustomElement$N } from '@ionic/core/components/ion-range.js';
56
- import { defineCustomElement as defineCustomElement$O } from '@ionic/core/components/ion-refresher.js';
57
- import { defineCustomElement as defineCustomElement$P } from '@ionic/core/components/ion-refresher-content.js';
58
- import { defineCustomElement as defineCustomElement$Q } from '@ionic/core/components/ion-reorder.js';
59
- import { defineCustomElement as defineCustomElement$R } from '@ionic/core/components/ion-reorder-group.js';
60
- import { defineCustomElement as defineCustomElement$S } from '@ionic/core/components/ion-ripple-effect.js';
61
- import { defineCustomElement as defineCustomElement$T } from '@ionic/core/components/ion-row.js';
62
- import { defineCustomElement as defineCustomElement$U } from '@ionic/core/components/ion-searchbar.js';
63
- import { defineCustomElement as defineCustomElement$V } from '@ionic/core/components/ion-segment.js';
64
- import { defineCustomElement as defineCustomElement$W } from '@ionic/core/components/ion-segment-button.js';
65
- import { defineCustomElement as defineCustomElement$X } from '@ionic/core/components/ion-segment-content.js';
66
- import { defineCustomElement as defineCustomElement$Y } from '@ionic/core/components/ion-segment-view.js';
67
- import { defineCustomElement as defineCustomElement$Z } from '@ionic/core/components/ion-select.js';
68
- import { defineCustomElement as defineCustomElement$_ } from '@ionic/core/components/ion-select-modal.js';
69
- import { defineCustomElement as defineCustomElement$$ } from '@ionic/core/components/ion-select-option.js';
70
- import { defineCustomElement as defineCustomElement$10 } from '@ionic/core/components/ion-skeleton-text.js';
71
- import { defineCustomElement as defineCustomElement$11 } from '@ionic/core/components/ion-spinner.js';
72
- import { defineCustomElement as defineCustomElement$12 } from '@ionic/core/components/ion-split-pane.js';
73
- import { defineCustomElement as defineCustomElement$13 } from '@ionic/core/components/ion-tab.js';
74
- import { defineCustomElement as defineCustomElement$14 } from '@ionic/core/components/ion-text.js';
75
- import { defineCustomElement as defineCustomElement$15 } from '@ionic/core/components/ion-textarea.js';
76
- import { defineCustomElement as defineCustomElement$16 } from '@ionic/core/components/ion-thumbnail.js';
77
- import { defineCustomElement as defineCustomElement$17 } from '@ionic/core/components/ion-title.js';
78
- import { defineCustomElement as defineCustomElement$18 } from '@ionic/core/components/ion-toggle.js';
79
- import { defineCustomElement as defineCustomElement$19 } 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';
80
78
  import { IonBreadcrumb as IonBreadcrumb$1 } from '@ionic/core/components/ion-breadcrumb.js';
81
79
  import { IonButton as IonButton$1 } from '@ionic/core/components/ion-button.js';
82
80
  import { IonCard as IonCard$1 } from '@ionic/core/components/ion-card.js';
@@ -84,20 +82,20 @@ import { IonFabButton as IonFabButton$1 } from '@ionic/core/components/ion-fab-b
84
82
  import { IonItemOption as IonItemOption$1 } from '@ionic/core/components/ion-item-option.js';
85
83
  import { IonItem as IonItem$1 } from '@ionic/core/components/ion-item.js';
86
84
  import { IonRouterLink as IonRouterLink$1 } from '@ionic/core/components/ion-router-link.js';
87
- import { defineCustomElement as defineCustomElement$1a } from '@ionic/core/components/ion-alert.js';
88
- import { defineCustomElement as defineCustomElement$1b } from '@ionic/core/components/ion-loading.js';
89
- import { defineCustomElement as defineCustomElement$1c } from '@ionic/core/components/ion-toast.js';
90
- import { defineCustomElement as defineCustomElement$1d } from '@ionic/core/components/ion-picker-legacy.js';
91
- import { defineCustomElement as defineCustomElement$1e } from '@ionic/core/components/ion-action-sheet.js';
92
- import { defineCustomElement as defineCustomElement$1f } from '@ionic/core/components/ion-modal.js';
93
- import { defineCustomElement as defineCustomElement$1g } from '@ionic/core/components/ion-popover.js';
94
- import { defineCustomElement as defineCustomElement$1m } from '@ionic/core/components/ion-app.js';
95
- import { defineCustomElement as defineCustomElement$1k } from '@ionic/core/components/ion-back-button.js';
96
- import { defineCustomElement as defineCustomElement$1l } from '@ionic/core/components/ion-router-outlet.js';
97
- import { defineCustomElement as defineCustomElement$1i } from '@ionic/core/components/ion-tab-bar.js';
98
- import { defineCustomElement as defineCustomElement$1h } from '@ionic/core/components/ion-tab-button.js';
99
- import { defineCustomElement as defineCustomElement$1j } from '@ionic/core/components/ion-tabs.js';
100
- import { defineCustomElement as defineCustomElement$1n } from 'ionicons/components/ion-icon.js';
85
+ import { defineCustomElement as defineCustomElement$18 } from '@ionic/core/components/ion-alert.js';
86
+ import { defineCustomElement as defineCustomElement$19 } from '@ionic/core/components/ion-loading.js';
87
+ import { defineCustomElement as defineCustomElement$1a } from '@ionic/core/components/ion-toast.js';
88
+ import { defineCustomElement as defineCustomElement$1b } from '@ionic/core/components/ion-action-sheet.js';
89
+ import { defineCustomElement as defineCustomElement$1c } from '@ionic/core/components/ion-modal.js';
90
+ import { defineCustomElement as defineCustomElement$1d } from '@ionic/core/components/ion-popover.js';
91
+ import ReactDOM, { createPortal } from 'react-dom';
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';
101
99
 
102
100
  const IonLifeCycleContext = /*@__PURE__*/ React.createContext({
103
101
  onIonViewWillEnter: () => {
@@ -382,9 +380,7 @@ const useIonViewDidLeave = (callback, deps = []) => {
382
380
  };
383
381
 
384
382
  const NavContext = /*@__PURE__*/ React.createContext({
385
- getIonRedirect: () => undefined,
386
383
  getIonRoute: () => undefined,
387
- getPageManager: () => undefined,
388
384
  getStackManager: () => undefined,
389
385
  goBack: (route) => {
390
386
  if (typeof window !== 'undefined') {
@@ -416,6 +412,699 @@ const NavContext = /*@__PURE__*/ React.createContext({
416
412
  },
417
413
  });
418
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
+
419
1108
  const dashToPascalCase = (str) => str
420
1109
  .toLowerCase()
421
1110
  .split('-')
@@ -559,149 +1248,6 @@ const defineCustomElement = (tagName, customElement) => {
559
1248
  }
560
1249
  };
561
1250
 
562
- const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => {
563
- if (defineCustomElement !== undefined) {
564
- defineCustomElement();
565
- }
566
- const displayName = dashToPascalCase(tagName);
567
- const ReactComponent = class extends React.Component {
568
- constructor(props) {
569
- super(props);
570
- this.setComponentElRef = (element) => {
571
- this.componentEl = element;
572
- };
573
- }
574
- componentDidMount() {
575
- this.componentDidUpdate(this.props);
576
- }
577
- componentDidUpdate(prevProps) {
578
- attachProps(this.componentEl, this.props, prevProps);
579
- }
580
- render() {
581
- const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
582
- let propsToPass = Object.keys(cProps).reduce((acc, name) => {
583
- const value = cProps[name];
584
- if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
585
- const eventName = name.substring(2).toLowerCase();
586
- if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
587
- acc[name] = value;
588
- }
589
- }
590
- else {
591
- // we should only render strings, booleans, and numbers as attrs in html.
592
- // objects, functions, arrays etc get synced via properties on mount.
593
- const type = typeof value;
594
- if (type === 'string' || type === 'boolean' || type === 'number') {
595
- acc[camelToDashCase(name)] = value;
596
- }
597
- }
598
- return acc;
599
- }, {});
600
- if (manipulatePropsFunction) {
601
- propsToPass = manipulatePropsFunction(this.props, propsToPass);
602
- }
603
- const newProps = {
604
- ...propsToPass,
605
- ref: mergeRefs(forwardedRef, this.setComponentElRef),
606
- style,
607
- };
608
- /**
609
- * We use createElement here instead of
610
- * React.createElement to work around a
611
- * bug in Vite (https://github.com/vitejs/vite/issues/6104).
612
- * React.createElement causes all elements to be rendered
613
- * as <tagname> instead of the actual Web Component.
614
- */
615
- return createElement(tagName, newProps, children);
616
- }
617
- static get displayName() {
618
- return displayName;
619
- }
620
- };
621
- // If context was passed to createReactComponent then conditionally add it to the Component Class
622
- if (ReactComponentContext) {
623
- ReactComponent.contextType = ReactComponentContext;
624
- }
625
- return createForwardRef$1(ReactComponent, displayName);
626
- };
627
-
628
- /* eslint-disable */
629
- /* tslint:disable */
630
- /* auto-generated react proxies */
631
- const IonAccordion = /*@__PURE__*/ createReactComponent('ion-accordion', undefined, undefined, defineCustomElement$1);
632
- const IonAccordionGroup = /*@__PURE__*/ createReactComponent('ion-accordion-group', undefined, undefined, defineCustomElement$2);
633
- const IonAvatar = /*@__PURE__*/ createReactComponent('ion-avatar', undefined, undefined, defineCustomElement$3);
634
- const IonBackdrop = /*@__PURE__*/ createReactComponent('ion-backdrop', undefined, undefined, defineCustomElement$4);
635
- const IonBadge = /*@__PURE__*/ createReactComponent('ion-badge', undefined, undefined, defineCustomElement$5);
636
- const IonBreadcrumbs = /*@__PURE__*/ createReactComponent('ion-breadcrumbs', undefined, undefined, defineCustomElement$6);
637
- const IonButtons = /*@__PURE__*/ createReactComponent('ion-buttons', undefined, undefined, defineCustomElement$7);
638
- const IonCardContent = /*@__PURE__*/ createReactComponent('ion-card-content', undefined, undefined, defineCustomElement$8);
639
- const IonCardHeader = /*@__PURE__*/ createReactComponent('ion-card-header', undefined, undefined, defineCustomElement$9);
640
- const IonCardSubtitle = /*@__PURE__*/ createReactComponent('ion-card-subtitle', undefined, undefined, defineCustomElement$a);
641
- const IonCardTitle = /*@__PURE__*/ createReactComponent('ion-card-title', undefined, undefined, defineCustomElement$b);
642
- const IonCheckbox = /*@__PURE__*/ createReactComponent('ion-checkbox', undefined, undefined, defineCustomElement$c);
643
- const IonChip = /*@__PURE__*/ createReactComponent('ion-chip', undefined, undefined, defineCustomElement$d);
644
- const IonCol = /*@__PURE__*/ createReactComponent('ion-col', undefined, undefined, defineCustomElement$e);
645
- const IonContent = /*@__PURE__*/ createReactComponent('ion-content', undefined, undefined, defineCustomElement$f);
646
- const IonDatetime = /*@__PURE__*/ createReactComponent('ion-datetime', undefined, undefined, defineCustomElement$g);
647
- const IonDatetimeButton = /*@__PURE__*/ createReactComponent('ion-datetime-button', undefined, undefined, defineCustomElement$h);
648
- const IonDivider = /*@__PURE__*/ createReactComponent('ion-divider', undefined, undefined, defineCustomElement$i);
649
- const IonFab = /*@__PURE__*/ createReactComponent('ion-fab', undefined, undefined, defineCustomElement$j);
650
- const IonFabList = /*@__PURE__*/ createReactComponent('ion-fab-list', undefined, undefined, defineCustomElement$k);
651
- const IonFooter = /*@__PURE__*/ createReactComponent('ion-footer', undefined, undefined, defineCustomElement$l);
652
- const IonGallery = /*@__PURE__*/ createReactComponent('ion-gallery', undefined, undefined, defineCustomElement$m);
653
- const IonGrid = /*@__PURE__*/ createReactComponent('ion-grid', undefined, undefined, defineCustomElement$n);
654
- const IonHeader = /*@__PURE__*/ createReactComponent('ion-header', undefined, undefined, defineCustomElement$o);
655
- const IonImg = /*@__PURE__*/ createReactComponent('ion-img', undefined, undefined, defineCustomElement$p);
656
- const IonInfiniteScroll = /*@__PURE__*/ createReactComponent('ion-infinite-scroll', undefined, undefined, defineCustomElement$q);
657
- const IonInfiniteScrollContent = /*@__PURE__*/ createReactComponent('ion-infinite-scroll-content', undefined, undefined, defineCustomElement$r);
658
- const IonInput = /*@__PURE__*/ createReactComponent('ion-input', undefined, undefined, defineCustomElement$s);
659
- const IonInputOtp = /*@__PURE__*/ createReactComponent('ion-input-otp', undefined, undefined, defineCustomElement$t);
660
- const IonInputPasswordToggle = /*@__PURE__*/ createReactComponent('ion-input-password-toggle', undefined, undefined, defineCustomElement$u);
661
- const IonItemDivider = /*@__PURE__*/ createReactComponent('ion-item-divider', undefined, undefined, defineCustomElement$v);
662
- const IonItemGroup = /*@__PURE__*/ createReactComponent('ion-item-group', undefined, undefined, defineCustomElement$w);
663
- const IonItemOptions = /*@__PURE__*/ createReactComponent('ion-item-options', undefined, undefined, defineCustomElement$x);
664
- const IonItemSliding = /*@__PURE__*/ createReactComponent('ion-item-sliding', undefined, undefined, defineCustomElement$y);
665
- const IonLabel = /*@__PURE__*/ createReactComponent('ion-label', undefined, undefined, defineCustomElement$z);
666
- const IonList = /*@__PURE__*/ createReactComponent('ion-list', undefined, undefined, defineCustomElement$A);
667
- const IonListHeader = /*@__PURE__*/ createReactComponent('ion-list-header', undefined, undefined, defineCustomElement$B);
668
- const IonMenu = /*@__PURE__*/ createReactComponent('ion-menu', undefined, undefined, defineCustomElement$C);
669
- const IonMenuButton = /*@__PURE__*/ createReactComponent('ion-menu-button', undefined, undefined, defineCustomElement$D);
670
- const IonMenuToggle = /*@__PURE__*/ createReactComponent('ion-menu-toggle', undefined, undefined, defineCustomElement$E);
671
- const IonNavLink = /*@__PURE__*/ createReactComponent('ion-nav-link', undefined, undefined, defineCustomElement$F);
672
- const IonNote = /*@__PURE__*/ createReactComponent('ion-note', undefined, undefined, defineCustomElement$G);
673
- const IonPicker = /*@__PURE__*/ createReactComponent('ion-picker', undefined, undefined, defineCustomElement$H);
674
- const IonPickerColumn = /*@__PURE__*/ createReactComponent('ion-picker-column', undefined, undefined, defineCustomElement$I);
675
- const IonPickerColumnOption = /*@__PURE__*/ createReactComponent('ion-picker-column-option', undefined, undefined, defineCustomElement$J);
676
- const IonProgressBar = /*@__PURE__*/ createReactComponent('ion-progress-bar', undefined, undefined, defineCustomElement$K);
677
- const IonRadio = /*@__PURE__*/ createReactComponent('ion-radio', undefined, undefined, defineCustomElement$L);
678
- const IonRadioGroup = /*@__PURE__*/ createReactComponent('ion-radio-group', undefined, undefined, defineCustomElement$M);
679
- const IonRange = /*@__PURE__*/ createReactComponent('ion-range', undefined, undefined, defineCustomElement$N);
680
- const IonRefresher = /*@__PURE__*/ createReactComponent('ion-refresher', undefined, undefined, defineCustomElement$O);
681
- const IonRefresherContent = /*@__PURE__*/ createReactComponent('ion-refresher-content', undefined, undefined, defineCustomElement$P);
682
- const IonReorder = /*@__PURE__*/ createReactComponent('ion-reorder', undefined, undefined, defineCustomElement$Q);
683
- const IonReorderGroup = /*@__PURE__*/ createReactComponent('ion-reorder-group', undefined, undefined, defineCustomElement$R);
684
- const IonRippleEffect = /*@__PURE__*/ createReactComponent('ion-ripple-effect', undefined, undefined, defineCustomElement$S);
685
- const IonRow = /*@__PURE__*/ createReactComponent('ion-row', undefined, undefined, defineCustomElement$T);
686
- const IonSearchbar = /*@__PURE__*/ createReactComponent('ion-searchbar', undefined, undefined, defineCustomElement$U);
687
- const IonSegment = /*@__PURE__*/ createReactComponent('ion-segment', undefined, undefined, defineCustomElement$V);
688
- const IonSegmentButton = /*@__PURE__*/ createReactComponent('ion-segment-button', undefined, undefined, defineCustomElement$W);
689
- const IonSegmentContent = /*@__PURE__*/ createReactComponent('ion-segment-content', undefined, undefined, defineCustomElement$X);
690
- const IonSegmentView = /*@__PURE__*/ createReactComponent('ion-segment-view', undefined, undefined, defineCustomElement$Y);
691
- const IonSelect = /*@__PURE__*/ createReactComponent('ion-select', undefined, undefined, defineCustomElement$Z);
692
- const IonSelectModal = /*@__PURE__*/ createReactComponent('ion-select-modal', undefined, undefined, defineCustomElement$_);
693
- const IonSelectOption = /*@__PURE__*/ createReactComponent('ion-select-option', undefined, undefined, defineCustomElement$$);
694
- const IonSkeletonText = /*@__PURE__*/ createReactComponent('ion-skeleton-text', undefined, undefined, defineCustomElement$10);
695
- const IonSpinner = /*@__PURE__*/ createReactComponent('ion-spinner', undefined, undefined, defineCustomElement$11);
696
- const IonSplitPane = /*@__PURE__*/ createReactComponent('ion-split-pane', undefined, undefined, defineCustomElement$12);
697
- const IonTab = /*@__PURE__*/ createReactComponent('ion-tab', undefined, undefined, defineCustomElement$13);
698
- const IonText = /*@__PURE__*/ createReactComponent('ion-text', undefined, undefined, defineCustomElement$14);
699
- const IonTextarea = /*@__PURE__*/ createReactComponent('ion-textarea', undefined, undefined, defineCustomElement$15);
700
- const IonThumbnail = /*@__PURE__*/ createReactComponent('ion-thumbnail', undefined, undefined, defineCustomElement$16);
701
- const IonTitle = /*@__PURE__*/ createReactComponent('ion-title', undefined, undefined, defineCustomElement$17);
702
- const IonToggle = /*@__PURE__*/ createReactComponent('ion-toggle', undefined, undefined, defineCustomElement$18);
703
- const IonToolbar = /*@__PURE__*/ createReactComponent('ion-toolbar', undefined, undefined, defineCustomElement$19);
704
-
705
1251
  const createForwardRef = (ReactComponent, // TODO(FW-2959): type
706
1252
  displayName) => {
707
1253
  const forwardRef = (props, ref) => {
@@ -735,6 +1281,11 @@ const createRoutingComponent = (tagName, customElement) => {
735
1281
  this.handleClick = (e) => {
736
1282
  const { routerLink, routerDirection, routerOptions, routerAnimation } = this.props;
737
1283
  if (routerLink !== undefined) {
1284
+ // Allow modifier key clicks (ctrl/cmd/shift) to open the link in a new tab/window
1285
+ // without triggering SPA navigation on the current page.
1286
+ if (e.metaKey || e.ctrlKey || e.shiftKey) {
1287
+ return;
1288
+ }
738
1289
  e.preventDefault();
739
1290
  this.context.navigate(routerLink, routerDirection, undefined, routerAnimation, routerOptions);
740
1291
  }
@@ -992,19 +1543,17 @@ const createInlineOverlayComponent = (tagName, defineCustomElement, hasDelegateH
992
1543
  };
993
1544
  const DELEGATE_HOST = 'ion-delegate-host';
994
1545
 
995
- const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$1a);
996
-
997
- const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$1b);
1546
+ const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$18);
998
1547
 
999
- const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1c);
1548
+ const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$19);
1000
1549
 
1001
- const IonPickerLegacy = /*@__PURE__*/ createInlineOverlayComponent('ion-picker-legacy', defineCustomElement$1d);
1550
+ const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1a);
1002
1551
 
1003
- const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1e);
1552
+ const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1b);
1004
1553
 
1005
- const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1f, true);
1554
+ const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1c, true);
1006
1555
 
1007
- const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1g);
1556
+ const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1d);
1008
1557
 
1009
1558
  const IonContext = React.createContext({
1010
1559
  addOverlay: () => {
@@ -1096,14 +1645,81 @@ const IonOverlayManager = ({ onAddOverlay, onRemoveOverlay }) => {
1096
1645
  }) }));
1097
1646
  };
1098
1647
 
1099
- const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1h);
1100
- const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1i);
1101
- const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1j);
1102
- const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1k);
1103
- const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1l);
1104
- const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1m);
1648
+ const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => {
1649
+ if (defineCustomElement !== undefined) {
1650
+ defineCustomElement();
1651
+ }
1652
+ const displayName = dashToPascalCase(tagName);
1653
+ const ReactComponent = class extends React.Component {
1654
+ constructor(props) {
1655
+ super(props);
1656
+ this.setComponentElRef = (element) => {
1657
+ this.componentEl = element;
1658
+ };
1659
+ }
1660
+ componentDidMount() {
1661
+ this.componentDidUpdate(this.props);
1662
+ }
1663
+ componentDidUpdate(prevProps) {
1664
+ attachProps(this.componentEl, this.props, prevProps);
1665
+ }
1666
+ render() {
1667
+ const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
1668
+ let propsToPass = Object.keys(cProps).reduce((acc, name) => {
1669
+ const value = cProps[name];
1670
+ if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
1671
+ const eventName = name.substring(2).toLowerCase();
1672
+ if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
1673
+ acc[name] = value;
1674
+ }
1675
+ }
1676
+ else {
1677
+ // we should only render strings, booleans, and numbers as attrs in html.
1678
+ // objects, functions, arrays etc get synced via properties on mount.
1679
+ const type = typeof value;
1680
+ if (type === 'string' || type === 'boolean' || type === 'number') {
1681
+ acc[camelToDashCase(name)] = value;
1682
+ }
1683
+ }
1684
+ return acc;
1685
+ }, {});
1686
+ if (manipulatePropsFunction) {
1687
+ propsToPass = manipulatePropsFunction(this.props, propsToPass);
1688
+ }
1689
+ const newProps = {
1690
+ ...propsToPass,
1691
+ ref: mergeRefs(forwardedRef, this.setComponentElRef),
1692
+ style,
1693
+ children
1694
+ };
1695
+ /**
1696
+ * We use createElement here instead of
1697
+ * React.createElement to work around a
1698
+ * bug in Vite (https://github.com/vitejs/vite/issues/6104).
1699
+ * React.createElement causes all elements to be rendered
1700
+ * as <tagname> instead of the actual Web Component.
1701
+ */
1702
+ return createElement(tagName, newProps, children);
1703
+ }
1704
+ static get displayName() {
1705
+ return displayName;
1706
+ }
1707
+ };
1708
+ // If context was passed to createReactComponent then conditionally add it to the Component Class
1709
+ if (ReactComponentContext) {
1710
+ ReactComponent.contextType = ReactComponentContext;
1711
+ }
1712
+ return createForwardRef$1(ReactComponent, displayName);
1713
+ };
1714
+
1715
+ const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1e);
1716
+ const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1f);
1717
+ const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1g);
1718
+ const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1h);
1719
+ const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1i);
1720
+ const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1j);
1105
1721
  // ionicons
1106
- const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1n);
1722
+ const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1k);
1107
1723
 
1108
1724
  class IonApp extends React.Component {
1109
1725
  constructor(props) {
@@ -1141,7 +1757,25 @@ class PageManager extends React.PureComponent {
1141
1757
  super(props);
1142
1758
  this.ionPageElementRef = React.createRef();
1143
1759
  // React refs must be stable (not created inline).
1144
- this.stableMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
1760
+ // Wrap merged refs to add ion-page-invisible synchronously when element is created
1761
+ const baseMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
1762
+ // Guard against React 19 strict mode double-mount re-adding ion-page-invisible.
1763
+ // The ref fires again on remount after StackManager may have already removed it.
1764
+ let hasAppliedInvisible = false;
1765
+ this.stableMergedRefs = (node) => {
1766
+ if (node &&
1767
+ !hasAppliedInvisible &&
1768
+ !node.classList.contains('ion-page-invisible') &&
1769
+ !node.classList.contains('ion-page-hidden')) {
1770
+ // Add ion-page-invisible synchronously before first paint (if in an outlet)
1771
+ // This prevents the flash that occurs when componentDidMount runs after paint
1772
+ if (this.context?.isInOutlet?.()) {
1773
+ node.classList.add('ion-page-invisible');
1774
+ hasAppliedInvisible = true;
1775
+ }
1776
+ }
1777
+ baseMergedRefs(node);
1778
+ };
1145
1779
  /**
1146
1780
  * This binds the scope of the following methods to the class scope.
1147
1781
  * The `.bind` method returns a new function, so we need to assign it
@@ -1153,11 +1787,38 @@ class PageManager extends React.PureComponent {
1153
1787
  this.ionViewWillLeaveHandler = this.ionViewWillLeaveHandler.bind(this);
1154
1788
  this.ionViewDidLeaveHandler = this.ionViewDidLeaveHandler.bind(this);
1155
1789
  }
1790
+ parseClasses(className) {
1791
+ if (!className)
1792
+ return new Set();
1793
+ return new Set(className.split(/\s+/).filter(Boolean));
1794
+ }
1795
+ /**
1796
+ * Updates classList by diffing old/new className props.
1797
+ * Preserves framework-added classes (can-go-back, ion-page-invisible, etc.).
1798
+ */
1799
+ updateUserClasses(oldClassName, newClassName) {
1800
+ if (!this.ionPageElementRef.current)
1801
+ return;
1802
+ const oldClasses = this.parseClasses(oldClassName);
1803
+ const newClasses = this.parseClasses(newClassName);
1804
+ oldClasses.forEach((cls) => {
1805
+ if (!newClasses.has(cls)) {
1806
+ this.ionPageElementRef.current.classList.remove(cls);
1807
+ }
1808
+ });
1809
+ newClasses.forEach((cls) => {
1810
+ if (!oldClasses.has(cls)) {
1811
+ this.ionPageElementRef.current.classList.add(cls);
1812
+ }
1813
+ });
1814
+ }
1156
1815
  componentDidMount() {
1157
1816
  if (this.ionPageElementRef.current) {
1158
- if (this.context.isInOutlet()) {
1159
- this.ionPageElementRef.current.classList.add('ion-page-invisible');
1160
- }
1817
+ // Add user classes via DOM manipulation to preserve framework-added classes.
1818
+ // We only set "ion-page" in JSX; user classes are added here.
1819
+ // Note: ion-page-invisible is added in the ref callback (stableMergedRefs) to prevent flash.
1820
+ // The ref callback runs synchronously when the element is created, before the browser paints.
1821
+ this.updateUserClasses(undefined, this.props.className);
1161
1822
  this.context.registerIonPage(this.ionPageElementRef.current, this.props.routeInfo);
1162
1823
  this.ionPageElementRef.current.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
1163
1824
  this.ionPageElementRef.current.addEventListener('ionViewDidEnter', this.ionViewDidEnterHandler);
@@ -1165,6 +1826,11 @@ class PageManager extends React.PureComponent {
1165
1826
  this.ionPageElementRef.current.addEventListener('ionViewDidLeave', this.ionViewDidLeaveHandler);
1166
1827
  }
1167
1828
  }
1829
+ componentDidUpdate(prevProps) {
1830
+ if (prevProps.className !== this.props.className) {
1831
+ this.updateUserClasses(prevProps.className, this.props.className);
1832
+ }
1833
+ }
1168
1834
  componentWillUnmount() {
1169
1835
  if (this.ionPageElementRef.current) {
1170
1836
  this.ionPageElementRef.current.removeEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
@@ -1194,9 +1860,11 @@ class PageManager extends React.PureComponent {
1194
1860
  render() {
1195
1861
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
1196
1862
  const { className, children, routeInfo, forwardedRef, ...props } = this.props;
1863
+ // Only set "ion-page" in JSX. User classes are managed via DOM in componentDidMount/componentDidUpdate
1864
+ // to preserve framework-added classes (can-go-back, ion-page-invisible, etc.) when className prop changes.
1197
1865
  return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
1198
1866
  this.ionLifeCycleContext = context;
1199
- return (jsx("div", { className: className ? `${className} ion-page` : `ion-page`, ref: this.stableMergedRefs, ...props, children: children }));
1867
+ return (jsx("div", { className: "ion-page", ref: this.stableMergedRefs, ...props, children: children }));
1200
1868
  } }));
1201
1869
  }
1202
1870
  static get contextType() {
@@ -1256,7 +1924,7 @@ const ReactDelegate = (addView, removeView) => {
1256
1924
  };
1257
1925
  };
1258
1926
 
1259
- const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1o);
1927
+ const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1l);
1260
1928
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
1261
1929
  const IonNavInternal = ({ children, forwardedRef, ...restOfProps }) => {
1262
1930
  const [views, setViews] = useState([]);
@@ -1304,8 +1972,30 @@ class OutletPageManager extends React.Component {
1304
1972
  */
1305
1973
  if (!this.outletIsReady) {
1306
1974
  componentOnReady(this.ionRouterOutlet, () => {
1975
+ /**
1976
+ * Guard against duplicate callbacks from React strict mode double-mount.
1977
+ * Both componentDidMount calls pass the outer !outletIsReady check before
1978
+ * either async callback fires. Without this inner guard, the second callback
1979
+ * re-adds ion-page-invisible after the first callback's transition removed it,
1980
+ * and registerIonPage returns early (same element), leaving the page invisible.
1981
+ */
1982
+ if (this.outletIsReady)
1983
+ return;
1307
1984
  this.outletIsReady = true;
1308
- this.context.registerIonPage(this.ionRouterOutlet, this.props.routeInfo);
1985
+ /**
1986
+ * Add ion-page + ion-page-invisible AFTER Stencil hydration but
1987
+ * BEFORE registerIonPage. Stencil hydration overwrites className,
1988
+ * so classes added in a React ref callback get wiped. Adding them
1989
+ * here -- after hydration -- ensures they persist until the parent
1990
+ * outlet's forward animation removes ion-page-invisible, preventing
1991
+ * a flash where the outlet is briefly visible at full opacity.
1992
+ */
1993
+ const el = this.ionRouterOutlet;
1994
+ if (!el.classList.contains('ion-page-invisible') && !el.classList.contains('ion-page-hidden')) {
1995
+ el.classList.add('ion-page');
1996
+ el.classList.add('ion-page-invisible');
1997
+ }
1998
+ this.context.registerIonPage(el, this.props.routeInfo);
1309
1999
  });
1310
2000
  }
1311
2001
  this.ionRouterOutlet.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
@@ -1335,10 +2025,10 @@ class OutletPageManager extends React.Component {
1335
2025
  this.ionLifeCycleContext.ionViewDidLeave();
1336
2026
  }
1337
2027
  render() {
1338
- const { StackManager, children, routeInfo, ...props } = this.props;
2028
+ const { StackManager, children, routeInfo, id, ...props } = this.props;
1339
2029
  return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
1340
2030
  this.ionLifeCycleContext = context;
1341
- return (jsx(StackManager, { routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
2031
+ return (jsx(StackManager, { id: id, routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { id: id, setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
1342
2032
  } }));
1343
2033
  }
1344
2034
  static get contextType() {
@@ -1349,11 +2039,13 @@ class OutletPageManager extends React.Component {
1349
2039
  class IonRouterOutletContainer extends React.Component {
1350
2040
  constructor(props) {
1351
2041
  super(props);
2042
+ this.outletId = props.id ?? `routerOutlet-${generateId('routerOutlet')}`;
1352
2043
  }
1353
2044
  render() {
1354
2045
  const StackManager = this.context.getStackManager();
1355
2046
  const { children, forwardedRef, ...props } = this.props;
1356
- 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 }));
2047
+ const outletId = props.id ?? this.outletId;
2048
+ 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 }));
1357
2049
  }
1358
2050
  static get contextType() {
1359
2051
  return NavContext;
@@ -1550,7 +2242,9 @@ const matchesTab = (pathname, href) => {
1550
2242
  if (href === undefined) {
1551
2243
  return false;
1552
2244
  }
1553
- const normalizedHref = href.endsWith('/') && href !== '/' ? href.slice(0, -1) : href;
2245
+ // Strip query string before comparing — href may contain search params (e.g., "/tabs/home?foo=bar")
2246
+ const hrefPathname = href.split('?')[0];
2247
+ const normalizedHref = hrefPathname.endsWith('/') && hrefPathname !== '/' ? hrefPathname.slice(0, -1) : hrefPathname;
1554
2248
  return pathname === normalizedHref || pathname.startsWith(normalizedHref + '/');
1555
2249
  };
1556
2250
  class IonTabBarUnwrapped extends React.PureComponent {
@@ -1642,7 +2336,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
1642
2336
  const prevHref = state.tabs[prevActiveTab].currentHref;
1643
2337
  const prevRouteOptions = state.tabs[prevActiveTab].currentRouteOptions;
1644
2338
  if (activeTab !== prevActiveTab ||
1645
- prevHref !== props.routeInfo?.pathname ||
2339
+ prevHref !== (props.routeInfo?.pathname || '') + (props.routeInfo?.search || '') ||
1646
2340
  prevRouteOptions !== props.routeInfo?.routeOptions) {
1647
2341
  tabs[activeTab] = {
1648
2342
  originalHref: tabs[activeTab].originalHref,
@@ -1709,7 +2403,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
1709
2403
  return (child) => {
1710
2404
  if (child != null && child.props && (child.type === IonTabButton || child.type.isTabButton)) {
1711
2405
  const href = child.props.tab === activeTab
1712
- ? this.props.routeInfo?.pathname
2406
+ ? (this.props.routeInfo?.pathname || '') + (this.props.routeInfo?.search || '')
1713
2407
  : this.state.tabs[child.props.tab].currentHref;
1714
2408
  const routeOptions = child.props.tab === activeTab
1715
2409
  ? this.props.routeInfo?.routeOptions
@@ -1834,20 +2528,6 @@ class IonRoute extends React.PureComponent {
1834
2528
  }
1835
2529
  }
1836
2530
 
1837
- class IonRedirect extends React.PureComponent {
1838
- render() {
1839
- const IonRedirectInner = this.context.getIonRedirect();
1840
- if (!this.context.hasIonicRouter() || !IonRedirect) {
1841
- console.error('You either do not have an Ionic Router package, or your router does not support using <IonRedirect>');
1842
- return null;
1843
- }
1844
- return jsx(IonRedirectInner, { ...this.props });
1845
- }
1846
- static get contextType() {
1847
- return NavContext;
1848
- }
1849
- }
1850
-
1851
2531
  const IonRouterContext = React.createContext({
1852
2532
  routeInfo: undefined, // TODO(FW-2959): type
1853
2533
  push: () => {
@@ -1856,6 +2536,9 @@ const IonRouterContext = React.createContext({
1856
2536
  back: () => {
1857
2537
  throw new Error('An Ionic Router is required for IonRouterContext');
1858
2538
  },
2539
+ navigateRoot: () => {
2540
+ throw new Error('An Ionic Router is required for IonRouterContext');
2541
+ },
1859
2542
  canGoBack: () => {
1860
2543
  throw new Error('An Ionic Router is required for IonRouterContext');
1861
2544
  },
@@ -1872,9 +2555,10 @@ function useIonRouter() {
1872
2555
  back: context.back,
1873
2556
  push: context.push,
1874
2557
  goBack: context.back,
2558
+ navigateRoot: context.navigateRoot,
1875
2559
  canGoBack: context.canGoBack,
1876
2560
  routeInfo: context.routeInfo,
1877
- }), [context.back, context.push, context.canGoBack, context.routeInfo]);
2561
+ }), [context.back, context.push, context.navigateRoot, context.canGoBack, context.routeInfo]);
1878
2562
  }
1879
2563
 
1880
2564
  class CreateAnimation extends React.PureComponent {
@@ -2028,7 +2712,7 @@ function useController(displayName, controller, defineCustomElement) {
2028
2712
  * @returns Returns the present and dismiss methods in an array
2029
2713
  */
2030
2714
  function useIonActionSheet() {
2031
- const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1e);
2715
+ const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1b);
2032
2716
  const present = useCallback((buttonsOrOptions, header) => {
2033
2717
  if (Array.isArray(buttonsOrOptions)) {
2034
2718
  return controller.present({
@@ -2048,7 +2732,7 @@ function useIonActionSheet() {
2048
2732
  * @returns Returns the present and dismiss methods in an array
2049
2733
  */
2050
2734
  function useIonAlert() {
2051
- const controller = useController('IonAlert', alertController, defineCustomElement$1a);
2735
+ const controller = useController('IonAlert', alertController, defineCustomElement$18);
2052
2736
  const present = useCallback((messageOrOptions, buttons) => {
2053
2737
  if (typeof messageOrOptions === 'string') {
2054
2738
  return controller.present({
@@ -2068,7 +2752,7 @@ function useIonAlert() {
2068
2752
  * @returns Returns the present and dismiss methods in an array
2069
2753
  */
2070
2754
  function useIonToast() {
2071
- const controller = useController('IonToast', toastController, defineCustomElement$1c);
2755
+ const controller = useController('IonToast', toastController, defineCustomElement$1a);
2072
2756
  const present = useCallback((messageOrOptions, duration) => {
2073
2757
  if (typeof messageOrOptions === 'string') {
2074
2758
  return controller.present({
@@ -2154,7 +2838,7 @@ function useOverlay(displayName, controller, defineCustomElement, component, com
2154
2838
  * @returns Returns the present and dismiss methods in an array
2155
2839
  */
2156
2840
  function useIonModal(component, componentProps) {
2157
- const controller = useOverlay('IonModal', modalController, defineCustomElement$1f, component, componentProps);
2841
+ const controller = useOverlay('IonModal', modalController, defineCustomElement$1c, component, componentProps);
2158
2842
  const present = useCallback((options = {}) => {
2159
2843
  controller.present(options);
2160
2844
  }, [controller.present]);
@@ -2169,40 +2853,19 @@ function useIonModal(component, componentProps) {
2169
2853
  * @returns Returns the present and dismiss methods in an array
2170
2854
  */
2171
2855
  function useIonPopover(component, componentProps) {
2172
- const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1g, component, componentProps);
2856
+ const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1d, component, componentProps);
2173
2857
  const present = useCallback((options = {}) => {
2174
2858
  controller.present(options);
2175
2859
  }, [controller.present]);
2176
2860
  return [present, controller.dismiss];
2177
2861
  }
2178
2862
 
2179
- /**
2180
- * A hook for presenting/dismissing an IonPicker component
2181
- * @returns Returns the present and dismiss methods in an array
2182
- * @deprecated Use the inline ion-picker component instead.
2183
- */
2184
- function useIonPicker() {
2185
- const controller = useController('IonPicker', pickerController, defineCustomElement$1d);
2186
- const present = useCallback((columnsOrOptions, buttons) => {
2187
- if (Array.isArray(columnsOrOptions)) {
2188
- return controller.present({
2189
- columns: columnsOrOptions,
2190
- buttons: buttons ?? [{ text: 'Ok' }],
2191
- });
2192
- }
2193
- else {
2194
- return controller.present(columnsOrOptions);
2195
- }
2196
- }, [controller.present]);
2197
- return [present, controller.dismiss];
2198
- }
2199
-
2200
2863
  /**
2201
2864
  * A hook for presenting/dismissing an IonLoading component
2202
2865
  * @returns Returns the present and dismiss methods in an array
2203
2866
  */
2204
2867
  function useIonLoading() {
2205
- const controller = useController('IonLoading', loadingController, defineCustomElement$1b);
2868
+ const controller = useController('IonLoading', loadingController, defineCustomElement$19);
2206
2869
  const present = useCallback((messageOrOptions = {}, duration, spinner) => {
2207
2870
  if (typeof messageOrOptions === 'string') {
2208
2871
  return controller.present({
@@ -2244,6 +2907,7 @@ const RouteManagerContext = /*@__PURE__*/ React.createContext({
2244
2907
  findLeavingViewItemByRouteInfo: () => undefined,
2245
2908
  findViewItemByRouteInfo: () => undefined,
2246
2909
  getChildrenToRender: () => undefined,
2910
+ getViewItemsForOutlet: () => [],
2247
2911
  goBack: () => undefined,
2248
2912
  unMountViewItem: () => undefined,
2249
2913
  });
@@ -2362,7 +3026,14 @@ class LocationHistory {
2362
3026
  _replace(routeInfo) {
2363
3027
  const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
2364
3028
  routeInfos && routeInfos.pop();
2365
- this.locationHistory.pop();
3029
+ // Get the current route that's being replaced
3030
+ const currentRoute = this.locationHistory[this.locationHistory.length - 1];
3031
+ // Only pop from global history if we're replacing in the same outlet context.
3032
+ // Don't pop if we're entering a nested outlet (current route has no tab, new route has a tab)
3033
+ const isEnteringNestedOutlet = currentRoute && !currentRoute.tab && !!routeInfo.tab;
3034
+ if (!isEnteringNestedOutlet) {
3035
+ this.locationHistory.pop();
3036
+ }
2366
3037
  this._add(routeInfo);
2367
3038
  }
2368
3039
  _clear() {
@@ -2394,6 +3065,20 @@ class LocationHistory {
2394
3065
  }
2395
3066
  return undefined;
2396
3067
  }
3068
+ /**
3069
+ * Returns the most recent RouteInfo in global history (excluding the current
3070
+ * entry) whose pathname matches the given value. Unlike findLastLocation,
3071
+ * this search is tab-agnostic. Used by the multi-step back detection.
3072
+ */
3073
+ findLastLocationByPathname(pathname) {
3074
+ for (let i = this.locationHistory.length - 2; i >= 0; i--) {
3075
+ const ri = this.locationHistory[i];
3076
+ if (ri && ri.pathname === pathname) {
3077
+ return ri;
3078
+ }
3079
+ }
3080
+ return undefined;
3081
+ }
2397
3082
  findLastLocation(routeInfo) {
2398
3083
  const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
2399
3084
  if (routeInfos) {
@@ -2425,6 +3110,17 @@ class LocationHistory {
2425
3110
  canGoBack() {
2426
3111
  return this.locationHistory.length > 1;
2427
3112
  }
3113
+ findTabForPathname(pathname) {
3114
+ for (const tab of Object.keys(this.tabHistory)) {
3115
+ const routeInfos = this.tabHistory[tab];
3116
+ for (let i = routeInfos.length - 1; i >= 0; i--) {
3117
+ if (routeInfos[i].pathname === pathname) {
3118
+ return tab;
3119
+ }
3120
+ }
3121
+ }
3122
+ return undefined;
3123
+ }
2428
3124
  }
2429
3125
 
2430
3126
  class NavManager extends React.PureComponent {
@@ -2437,6 +3133,9 @@ class NavManager extends React.PureComponent {
2437
3133
  back: (animationBuilder) => {
2438
3134
  this.goBack(undefined, animationBuilder);
2439
3135
  },
3136
+ navigateRoot: (pathname, animationBuilder) => {
3137
+ this.props.onNavigateRoot(pathname, animationBuilder);
3138
+ },
2440
3139
  canGoBack: () => this.props.locationHistory.canGoBack(),
2441
3140
  nativeBack: () => this.props.onNativeBack(),
2442
3141
  routeInfo: this.props.routeInfo,
@@ -2445,10 +3144,8 @@ class NavManager extends React.PureComponent {
2445
3144
  goBack: this.goBack.bind(this),
2446
3145
  hasIonicRouter: () => true,
2447
3146
  navigate: this.navigate.bind(this),
2448
- getIonRedirect: this.getIonRedirect.bind(this),
2449
3147
  getIonRoute: this.getIonRoute.bind(this),
2450
3148
  getStackManager: this.getStackManager.bind(this),
2451
- getPageManager: this.getPageManager.bind(this),
2452
3149
  routeInfo: this.props.routeInfo,
2453
3150
  setCurrentTab: this.props.onSetCurrentTab,
2454
3151
  changeTab: this.props.onChangeTab,
@@ -2481,12 +3178,6 @@ class NavManager extends React.PureComponent {
2481
3178
  navigate(path, direction = 'forward', action = 'push', animationBuilder, options, tab) {
2482
3179
  this.props.onNavigate(path, action, direction, animationBuilder, options, tab);
2483
3180
  }
2484
- getPageManager() {
2485
- return PageManager;
2486
- }
2487
- getIonRedirect() {
2488
- return this.props.ionRedirect;
2489
- }
2490
3181
  getIonRoute() {
2491
3182
  return this.props.ionRoute;
2492
3183
  }
@@ -2516,10 +3207,7 @@ class ViewStacks {
2516
3207
  }
2517
3208
  }
2518
3209
  clear(outletId) {
2519
- // Give some time for the leaving views to transition before removing
2520
- return setTimeout(() => {
2521
- delete this.viewStacks[outletId];
2522
- }, 500);
3210
+ delete this.viewStacks[outletId];
2523
3211
  }
2524
3212
  getViewItemsForOutlet(outletId) {
2525
3213
  return this.viewStacks[outletId] || [];
@@ -2548,5 +3236,5 @@ class ViewStacks {
2548
3236
  }
2549
3237
  }
2550
3238
 
2551
- 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, 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 };
3239
+ 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 };
2552
3240
  //# sourceMappingURL=index.js.map