@ionic/react 8.8.6-dev.11778015413.1dc85fcb → 8.8.6-dev.11778097327.1321e918

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (83) hide show
  1. package/css/core.css +1 -1
  2. package/css/core.css.map +1 -1
  3. package/css/display.css +1 -1
  4. package/css/display.css.map +1 -1
  5. package/css/flex-utils.css +1 -1
  6. package/css/flex-utils.css.map +1 -1
  7. package/css/float-elements.css.map +1 -1
  8. package/css/global.bundle.css.map +1 -1
  9. package/css/ionic/bundle.ionic.css +1 -0
  10. package/css/ionic/bundle.ionic.css.map +1 -0
  11. package/css/ionic/core.ionic.css +1 -0
  12. package/css/ionic/core.ionic.css.map +1 -0
  13. package/css/ionic/global.bundle.ionic.css +1 -0
  14. package/css/ionic/global.bundle.ionic.css.map +1 -0
  15. package/css/ionic/ionic-swiper.ionic.css +1 -0
  16. package/css/ionic/ionic-swiper.ionic.css.map +1 -0
  17. package/css/ionic/link.ionic.css +1 -0
  18. package/css/ionic/link.ionic.css.map +1 -0
  19. package/css/ionic/structure.ionic.css +1 -0
  20. package/css/ionic/structure.ionic.css.map +1 -0
  21. package/css/ionic/typography.ionic.css +1 -0
  22. package/css/ionic/typography.ionic.css.map +1 -0
  23. package/css/ionic/utils.bundle.ionic.css +1 -0
  24. package/css/ionic/utils.bundle.ionic.css.map +1 -0
  25. package/css/ionic-swiper.css +1 -1
  26. package/css/ionic-swiper.css.map +1 -1
  27. package/css/ionic.bundle.css +1 -1
  28. package/css/ionic.bundle.css.map +1 -1
  29. package/css/normalize.css.map +1 -1
  30. package/css/padding.css.map +1 -1
  31. package/css/palettes/dark.always.css.map +1 -1
  32. package/css/palettes/dark.class.css.map +1 -1
  33. package/css/palettes/dark.system.css.map +1 -1
  34. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  35. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  36. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  37. package/css/palettes/high-contrast.always.css.map +1 -1
  38. package/css/palettes/high-contrast.class.css.map +1 -1
  39. package/css/palettes/high-contrast.system.css.map +1 -1
  40. package/css/structure.css.map +1 -1
  41. package/css/text-alignment.css.map +1 -1
  42. package/css/text-transformation.css.map +1 -1
  43. package/css/typography.css.map +1 -1
  44. package/css/utils.bundle.css +1 -1
  45. package/css/utils.bundle.css.map +1 -1
  46. package/dist/index.js +317 -1007
  47. package/dist/index.js.map +1 -1
  48. package/dist/types/components/IonActionSheet.d.ts +1 -1
  49. package/dist/types/components/IonAlert.d.ts +1 -1
  50. package/dist/types/components/IonIcon.d.ts +1 -1
  51. package/dist/types/components/IonLoading.d.ts +1 -1
  52. package/dist/types/components/IonModal.d.ts +1 -1
  53. package/dist/types/components/IonPage.d.ts +1 -1
  54. package/dist/types/components/IonPickerLegacy.d.ts +2 -0
  55. package/dist/types/components/IonPopover.d.ts +1 -1
  56. package/dist/types/components/IonRedirect.d.ts +16 -0
  57. package/dist/types/components/IonRoute.d.ts +2 -3
  58. package/dist/types/components/IonRouterContext.d.ts +0 -8
  59. package/dist/types/components/IonRouterOutlet.d.ts +2 -3
  60. package/dist/types/components/IonToast.d.ts +1 -1
  61. package/dist/types/components/createInlineOverlayComponent.d.ts +1 -1
  62. package/dist/types/components/createRoutingComponent.d.ts +1 -1
  63. package/dist/types/components/index.d.ts +5 -2
  64. package/dist/types/components/navigation/IonNav.d.ts +1 -2
  65. package/dist/types/components/navigation/IonTabBar.d.ts +1 -1
  66. package/dist/types/components/navigation/IonTabs.d.ts +2 -1
  67. package/dist/types/components/proxies.d.ts +74 -0
  68. package/dist/types/components/react-component-lib/createComponent.d.ts +1 -1
  69. package/dist/types/components/react-component-lib/utils/index.d.ts +1 -1
  70. package/dist/types/components/routing-proxies.d.ts +7 -7
  71. package/dist/types/components/utils/index.d.ts +11 -2
  72. package/dist/types/contexts/NavContext.d.ts +2 -0
  73. package/dist/types/hooks/useIonPicker.d.ts +27 -0
  74. package/dist/types/lifecycle/IonLifeCycleHOC.d.ts +3 -1
  75. package/dist/types/routing/LocationHistory.d.ts +0 -7
  76. package/dist/types/routing/NavManager.d.ts +4 -2
  77. package/dist/types/routing/OutletPageManager.d.ts +0 -2
  78. package/dist/types/routing/PageManager.d.ts +0 -8
  79. package/dist/types/routing/RouteManagerContext.d.ts +1 -6
  80. package/dist/types/routing/ViewLifeCycleManager.d.ts +0 -1
  81. package/dist/types/routing/ViewStacks.d.ts +2 -2
  82. package/package.json +8 -8
  83. package/dist/types/components/components.d.ts +0 -326
package/dist/index.js CHANGED
@@ -1,80 +1,81 @@
1
1
  import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
2
2
  import React, { useContext, useRef, useEffect, createElement, useState, useMemo, Fragment as Fragment$1, useCallback } from 'react';
3
- import { isPlatform as isPlatform$1, getPlatforms as getPlatforms$1, componentOnReady, createAnimation, actionSheetController, alertController, toastController, modalController, popoverController, loadingController, initialize } from '@ionic/core/components';
3
+ import { isPlatform as isPlatform$1, getPlatforms as getPlatforms$1, componentOnReady, createAnimation, actionSheetController, alertController, toastController, modalController, popoverController, pickerController, loadingController, initialize } from '@ionic/core/components';
4
4
  export { IonicSafeString, IonicSlides, createAnimation, createGesture, getIonPageElement, getTimeGivenProgression, iosTransitionAnimation, mdTransitionAnimation, openURL } from '@ionic/core/components';
5
- import { createComponent } from '@stencil/react-output-target/runtime';
6
- import { IonAccordionGroup as IonAccordionGroup$1, defineCustomElement as defineCustomElement$2 } from '@ionic/core/components/ion-accordion-group.js';
7
- import { IonAccordion as IonAccordion$1, defineCustomElement as defineCustomElement$1 } from '@ionic/core/components/ion-accordion.js';
8
- import { IonAvatar as IonAvatar$1, defineCustomElement as defineCustomElement$3 } from '@ionic/core/components/ion-avatar.js';
9
- import { IonBackdrop as IonBackdrop$1, defineCustomElement as defineCustomElement$4 } from '@ionic/core/components/ion-backdrop.js';
10
- import { IonBadge as IonBadge$1, defineCustomElement as defineCustomElement$5 } from '@ionic/core/components/ion-badge.js';
11
- import { IonBreadcrumbs as IonBreadcrumbs$1, defineCustomElement as defineCustomElement$6 } from '@ionic/core/components/ion-breadcrumbs.js';
12
- import { IonButtons as IonButtons$1, defineCustomElement as defineCustomElement$7 } from '@ionic/core/components/ion-buttons.js';
13
- import { IonCardContent as IonCardContent$1, defineCustomElement as defineCustomElement$8 } from '@ionic/core/components/ion-card-content.js';
14
- import { IonCardHeader as IonCardHeader$1, defineCustomElement as defineCustomElement$9 } from '@ionic/core/components/ion-card-header.js';
15
- import { IonCardSubtitle as IonCardSubtitle$1, defineCustomElement as defineCustomElement$a } from '@ionic/core/components/ion-card-subtitle.js';
16
- import { IonCardTitle as IonCardTitle$1, defineCustomElement as defineCustomElement$b } from '@ionic/core/components/ion-card-title.js';
17
- import { IonCheckbox as IonCheckbox$1, defineCustomElement as defineCustomElement$c } from '@ionic/core/components/ion-checkbox.js';
18
- import { IonChip as IonChip$1, defineCustomElement as defineCustomElement$d } from '@ionic/core/components/ion-chip.js';
19
- import { IonCol as IonCol$1, defineCustomElement as defineCustomElement$e } from '@ionic/core/components/ion-col.js';
20
- import { IonContent as IonContent$1, defineCustomElement as defineCustomElement$f } from '@ionic/core/components/ion-content.js';
21
- import { IonDatetimeButton as IonDatetimeButton$1, defineCustomElement as defineCustomElement$h } from '@ionic/core/components/ion-datetime-button.js';
22
- import { IonDatetime as IonDatetime$1, defineCustomElement as defineCustomElement$g } from '@ionic/core/components/ion-datetime.js';
23
- import { IonFabList as IonFabList$1, defineCustomElement as defineCustomElement$j } from '@ionic/core/components/ion-fab-list.js';
24
- import { IonFab as IonFab$1, defineCustomElement as defineCustomElement$i } from '@ionic/core/components/ion-fab.js';
25
- import { IonFooter as IonFooter$1, defineCustomElement as defineCustomElement$k } from '@ionic/core/components/ion-footer.js';
26
- import { IonGrid as IonGrid$1, defineCustomElement as defineCustomElement$l } from '@ionic/core/components/ion-grid.js';
27
- import { IonHeader as IonHeader$1, defineCustomElement as defineCustomElement$m } from '@ionic/core/components/ion-header.js';
28
- import { IonImg as IonImg$1, defineCustomElement as defineCustomElement$n } from '@ionic/core/components/ion-img.js';
29
- import { IonInfiniteScrollContent as IonInfiniteScrollContent$1, defineCustomElement as defineCustomElement$p } from '@ionic/core/components/ion-infinite-scroll-content.js';
30
- import { IonInfiniteScroll as IonInfiniteScroll$1, defineCustomElement as defineCustomElement$o } from '@ionic/core/components/ion-infinite-scroll.js';
31
- import { IonInputOtp as IonInputOtp$1, defineCustomElement as defineCustomElement$r } from '@ionic/core/components/ion-input-otp.js';
32
- import { IonInputPasswordToggle as IonInputPasswordToggle$1, defineCustomElement as defineCustomElement$s } from '@ionic/core/components/ion-input-password-toggle.js';
33
- import { IonInput as IonInput$1, defineCustomElement as defineCustomElement$q } from '@ionic/core/components/ion-input.js';
34
- import { IonItemDivider as IonItemDivider$1, defineCustomElement as defineCustomElement$t } from '@ionic/core/components/ion-item-divider.js';
35
- import { IonItemGroup as IonItemGroup$1, defineCustomElement as defineCustomElement$u } from '@ionic/core/components/ion-item-group.js';
36
- import { IonItemOptions as IonItemOptions$1, defineCustomElement as defineCustomElement$v } from '@ionic/core/components/ion-item-options.js';
37
- import { IonItemSliding as IonItemSliding$1, defineCustomElement as defineCustomElement$w } from '@ionic/core/components/ion-item-sliding.js';
38
- import { IonLabel as IonLabel$1, defineCustomElement as defineCustomElement$x } from '@ionic/core/components/ion-label.js';
39
- import { IonListHeader as IonListHeader$1, defineCustomElement as defineCustomElement$z } from '@ionic/core/components/ion-list-header.js';
40
- import { IonList as IonList$1, defineCustomElement as defineCustomElement$y } from '@ionic/core/components/ion-list.js';
41
- import { IonMenuButton as IonMenuButton$1, defineCustomElement as defineCustomElement$B } from '@ionic/core/components/ion-menu-button.js';
42
- import { IonMenuToggle as IonMenuToggle$1, defineCustomElement as defineCustomElement$C } from '@ionic/core/components/ion-menu-toggle.js';
43
- import { IonMenu as IonMenu$1, defineCustomElement as defineCustomElement$A } from '@ionic/core/components/ion-menu.js';
44
- import { IonNavLink as IonNavLink$1, defineCustomElement as defineCustomElement$D } from '@ionic/core/components/ion-nav-link.js';
45
- import { defineCustomElement as defineCustomElement$1l } from '@ionic/core/components/ion-nav.js';
46
- import { IonNote as IonNote$1, defineCustomElement as defineCustomElement$E } from '@ionic/core/components/ion-note.js';
47
- import { IonPickerColumnOption as IonPickerColumnOption$1, defineCustomElement as defineCustomElement$H } from '@ionic/core/components/ion-picker-column-option.js';
48
- import { IonPickerColumn as IonPickerColumn$1, defineCustomElement as defineCustomElement$G } from '@ionic/core/components/ion-picker-column.js';
49
- import { IonPicker as IonPicker$1, defineCustomElement as defineCustomElement$F } from '@ionic/core/components/ion-picker.js';
50
- import { IonProgressBar as IonProgressBar$1, defineCustomElement as defineCustomElement$I } from '@ionic/core/components/ion-progress-bar.js';
51
- import { IonRadioGroup as IonRadioGroup$1, defineCustomElement as defineCustomElement$K } from '@ionic/core/components/ion-radio-group.js';
52
- import { IonRadio as IonRadio$1, defineCustomElement as defineCustomElement$J } from '@ionic/core/components/ion-radio.js';
53
- import { IonRange as IonRange$1, defineCustomElement as defineCustomElement$L } from '@ionic/core/components/ion-range.js';
54
- import { IonRefresherContent as IonRefresherContent$1, defineCustomElement as defineCustomElement$N } from '@ionic/core/components/ion-refresher-content.js';
55
- import { IonRefresher as IonRefresher$1, defineCustomElement as defineCustomElement$M } from '@ionic/core/components/ion-refresher.js';
56
- import { IonReorderGroup as IonReorderGroup$1, defineCustomElement as defineCustomElement$P } from '@ionic/core/components/ion-reorder-group.js';
57
- import { IonReorder as IonReorder$1, defineCustomElement as defineCustomElement$O } from '@ionic/core/components/ion-reorder.js';
58
- import { IonRippleEffect as IonRippleEffect$1, defineCustomElement as defineCustomElement$Q } from '@ionic/core/components/ion-ripple-effect.js';
59
- import { IonRow as IonRow$1, defineCustomElement as defineCustomElement$R } from '@ionic/core/components/ion-row.js';
60
- import { IonSearchbar as IonSearchbar$1, defineCustomElement as defineCustomElement$S } from '@ionic/core/components/ion-searchbar.js';
61
- import { IonSegmentButton as IonSegmentButton$1, defineCustomElement as defineCustomElement$U } from '@ionic/core/components/ion-segment-button.js';
62
- import { IonSegmentContent as IonSegmentContent$1, defineCustomElement as defineCustomElement$V } from '@ionic/core/components/ion-segment-content.js';
63
- import { IonSegmentView as IonSegmentView$1, defineCustomElement as defineCustomElement$W } from '@ionic/core/components/ion-segment-view.js';
64
- import { IonSegment as IonSegment$1, defineCustomElement as defineCustomElement$T } from '@ionic/core/components/ion-segment.js';
65
- import { IonSelectModal as IonSelectModal$1, defineCustomElement as defineCustomElement$Y } from '@ionic/core/components/ion-select-modal.js';
66
- import { IonSelectOption as IonSelectOption$1, defineCustomElement as defineCustomElement$Z } from '@ionic/core/components/ion-select-option.js';
67
- import { IonSelect as IonSelect$1, defineCustomElement as defineCustomElement$X } from '@ionic/core/components/ion-select.js';
68
- import { IonSkeletonText as IonSkeletonText$1, defineCustomElement as defineCustomElement$_ } from '@ionic/core/components/ion-skeleton-text.js';
69
- import { IonSpinner as IonSpinner$1, defineCustomElement as defineCustomElement$$ } from '@ionic/core/components/ion-spinner.js';
70
- import { IonSplitPane as IonSplitPane$1, defineCustomElement as defineCustomElement$10 } from '@ionic/core/components/ion-split-pane.js';
71
- import { IonTab as IonTab$1, defineCustomElement as defineCustomElement$11 } from '@ionic/core/components/ion-tab.js';
72
- import { IonText as IonText$1, defineCustomElement as defineCustomElement$12 } from '@ionic/core/components/ion-text.js';
73
- import { IonTextarea as IonTextarea$1, defineCustomElement as defineCustomElement$13 } from '@ionic/core/components/ion-textarea.js';
74
- import { IonThumbnail as IonThumbnail$1, defineCustomElement as defineCustomElement$14 } from '@ionic/core/components/ion-thumbnail.js';
75
- import { IonTitle as IonTitle$1, defineCustomElement as defineCustomElement$15 } from '@ionic/core/components/ion-title.js';
76
- import { IonToggle as IonToggle$1, defineCustomElement as defineCustomElement$16 } from '@ionic/core/components/ion-toggle.js';
77
- import { IonToolbar as IonToolbar$1, defineCustomElement as defineCustomElement$17 } from '@ionic/core/components/ion-toolbar.js';
5
+ import ReactDOM, { createPortal } from 'react-dom';
6
+ import { defineCustomElement as defineCustomElement$1 } from '@ionic/core/components/ion-accordion.js';
7
+ import { defineCustomElement as defineCustomElement$2 } from '@ionic/core/components/ion-accordion-group.js';
8
+ import { defineCustomElement as defineCustomElement$3 } from '@ionic/core/components/ion-avatar.js';
9
+ import { defineCustomElement as defineCustomElement$4 } from '@ionic/core/components/ion-backdrop.js';
10
+ import { defineCustomElement as defineCustomElement$5 } from '@ionic/core/components/ion-badge.js';
11
+ import { defineCustomElement as defineCustomElement$6 } from '@ionic/core/components/ion-breadcrumbs.js';
12
+ import { defineCustomElement as defineCustomElement$7 } from '@ionic/core/components/ion-buttons.js';
13
+ import { defineCustomElement as defineCustomElement$8 } from '@ionic/core/components/ion-card-content.js';
14
+ import { defineCustomElement as defineCustomElement$9 } from '@ionic/core/components/ion-card-header.js';
15
+ import { defineCustomElement as defineCustomElement$a } from '@ionic/core/components/ion-card-subtitle.js';
16
+ import { defineCustomElement as defineCustomElement$b } from '@ionic/core/components/ion-card-title.js';
17
+ import { defineCustomElement as defineCustomElement$c } from '@ionic/core/components/ion-checkbox.js';
18
+ import { defineCustomElement as defineCustomElement$d } from '@ionic/core/components/ion-chip.js';
19
+ import { defineCustomElement as defineCustomElement$e } from '@ionic/core/components/ion-col.js';
20
+ import { defineCustomElement as defineCustomElement$f } from '@ionic/core/components/ion-content.js';
21
+ import { defineCustomElement as defineCustomElement$g } from '@ionic/core/components/ion-datetime.js';
22
+ import { defineCustomElement as defineCustomElement$h } from '@ionic/core/components/ion-datetime-button.js';
23
+ import { defineCustomElement as defineCustomElement$i } from '@ionic/core/components/ion-divider.js';
24
+ import { defineCustomElement as defineCustomElement$j } from '@ionic/core/components/ion-fab.js';
25
+ import { defineCustomElement as defineCustomElement$k } from '@ionic/core/components/ion-fab-list.js';
26
+ import { defineCustomElement as defineCustomElement$l } from '@ionic/core/components/ion-footer.js';
27
+ import { defineCustomElement as defineCustomElement$m } from '@ionic/core/components/ion-grid.js';
28
+ import { defineCustomElement as defineCustomElement$n } from '@ionic/core/components/ion-header.js';
29
+ import { defineCustomElement as defineCustomElement$o } from '@ionic/core/components/ion-img.js';
30
+ import { defineCustomElement as defineCustomElement$p } from '@ionic/core/components/ion-infinite-scroll.js';
31
+ import { defineCustomElement as defineCustomElement$q } from '@ionic/core/components/ion-infinite-scroll-content.js';
32
+ import { defineCustomElement as defineCustomElement$r } from '@ionic/core/components/ion-input.js';
33
+ import { defineCustomElement as defineCustomElement$s } from '@ionic/core/components/ion-input-otp.js';
34
+ import { defineCustomElement as defineCustomElement$t } from '@ionic/core/components/ion-input-password-toggle.js';
35
+ import { defineCustomElement as defineCustomElement$u } from '@ionic/core/components/ion-item-divider.js';
36
+ import { defineCustomElement as defineCustomElement$v } from '@ionic/core/components/ion-item-group.js';
37
+ import { defineCustomElement as defineCustomElement$w } from '@ionic/core/components/ion-item-options.js';
38
+ import { defineCustomElement as defineCustomElement$x } from '@ionic/core/components/ion-item-sliding.js';
39
+ import { defineCustomElement as defineCustomElement$y } from '@ionic/core/components/ion-label.js';
40
+ import { defineCustomElement as defineCustomElement$z } from '@ionic/core/components/ion-list.js';
41
+ import { defineCustomElement as defineCustomElement$A } from '@ionic/core/components/ion-list-header.js';
42
+ import { defineCustomElement as defineCustomElement$B } from '@ionic/core/components/ion-menu.js';
43
+ import { defineCustomElement as defineCustomElement$C } from '@ionic/core/components/ion-menu-button.js';
44
+ import { defineCustomElement as defineCustomElement$D } from '@ionic/core/components/ion-menu-toggle.js';
45
+ import { defineCustomElement as defineCustomElement$1n } from '@ionic/core/components/ion-nav.js';
46
+ import { defineCustomElement as defineCustomElement$E } from '@ionic/core/components/ion-nav-link.js';
47
+ import { defineCustomElement as defineCustomElement$F } from '@ionic/core/components/ion-note.js';
48
+ import { defineCustomElement as defineCustomElement$G } from '@ionic/core/components/ion-picker.js';
49
+ import { defineCustomElement as defineCustomElement$H } from '@ionic/core/components/ion-picker-column.js';
50
+ import { defineCustomElement as defineCustomElement$I } from '@ionic/core/components/ion-picker-column-option.js';
51
+ import { defineCustomElement as defineCustomElement$J } from '@ionic/core/components/ion-progress-bar.js';
52
+ import { defineCustomElement as defineCustomElement$K } from '@ionic/core/components/ion-radio.js';
53
+ import { defineCustomElement as defineCustomElement$L } from '@ionic/core/components/ion-radio-group.js';
54
+ import { defineCustomElement as defineCustomElement$M } from '@ionic/core/components/ion-range.js';
55
+ import { defineCustomElement as defineCustomElement$N } from '@ionic/core/components/ion-refresher.js';
56
+ import { defineCustomElement as defineCustomElement$O } from '@ionic/core/components/ion-refresher-content.js';
57
+ import { defineCustomElement as defineCustomElement$P } from '@ionic/core/components/ion-reorder.js';
58
+ import { defineCustomElement as defineCustomElement$Q } from '@ionic/core/components/ion-reorder-group.js';
59
+ import { defineCustomElement as defineCustomElement$R } from '@ionic/core/components/ion-ripple-effect.js';
60
+ import { defineCustomElement as defineCustomElement$S } from '@ionic/core/components/ion-row.js';
61
+ import { defineCustomElement as defineCustomElement$T } from '@ionic/core/components/ion-searchbar.js';
62
+ import { defineCustomElement as defineCustomElement$U } from '@ionic/core/components/ion-segment.js';
63
+ import { defineCustomElement as defineCustomElement$V } from '@ionic/core/components/ion-segment-button.js';
64
+ import { defineCustomElement as defineCustomElement$W } from '@ionic/core/components/ion-segment-content.js';
65
+ import { defineCustomElement as defineCustomElement$X } from '@ionic/core/components/ion-segment-view.js';
66
+ import { defineCustomElement as defineCustomElement$Y } from '@ionic/core/components/ion-select.js';
67
+ import { defineCustomElement as defineCustomElement$Z } from '@ionic/core/components/ion-select-modal.js';
68
+ import { defineCustomElement as defineCustomElement$_ } from '@ionic/core/components/ion-select-option.js';
69
+ import { defineCustomElement as defineCustomElement$$ } from '@ionic/core/components/ion-skeleton-text.js';
70
+ import { defineCustomElement as defineCustomElement$10 } from '@ionic/core/components/ion-spinner.js';
71
+ import { defineCustomElement as defineCustomElement$11 } from '@ionic/core/components/ion-split-pane.js';
72
+ import { defineCustomElement as defineCustomElement$12 } from '@ionic/core/components/ion-tab.js';
73
+ import { defineCustomElement as defineCustomElement$13 } from '@ionic/core/components/ion-text.js';
74
+ import { defineCustomElement as defineCustomElement$14 } from '@ionic/core/components/ion-textarea.js';
75
+ import { defineCustomElement as defineCustomElement$15 } from '@ionic/core/components/ion-thumbnail.js';
76
+ import { defineCustomElement as defineCustomElement$16 } from '@ionic/core/components/ion-title.js';
77
+ import { defineCustomElement as defineCustomElement$17 } from '@ionic/core/components/ion-toggle.js';
78
+ import { defineCustomElement as defineCustomElement$18 } from '@ionic/core/components/ion-toolbar.js';
78
79
  import { IonBreadcrumb as IonBreadcrumb$1 } from '@ionic/core/components/ion-breadcrumb.js';
79
80
  import { IonButton as IonButton$1 } from '@ionic/core/components/ion-button.js';
80
81
  import { IonCard as IonCard$1 } from '@ionic/core/components/ion-card.js';
@@ -82,20 +83,20 @@ import { IonFabButton as IonFabButton$1 } from '@ionic/core/components/ion-fab-b
82
83
  import { IonItemOption as IonItemOption$1 } from '@ionic/core/components/ion-item-option.js';
83
84
  import { IonItem as IonItem$1 } from '@ionic/core/components/ion-item.js';
84
85
  import { IonRouterLink as IonRouterLink$1 } from '@ionic/core/components/ion-router-link.js';
85
- import { defineCustomElement as defineCustomElement$18 } from '@ionic/core/components/ion-alert.js';
86
- import { 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';
86
+ import { defineCustomElement as defineCustomElement$19 } from '@ionic/core/components/ion-alert.js';
87
+ import { defineCustomElement as defineCustomElement$1a } from '@ionic/core/components/ion-loading.js';
88
+ import { defineCustomElement as defineCustomElement$1b } from '@ionic/core/components/ion-toast.js';
89
+ import { defineCustomElement as defineCustomElement$1c } from '@ionic/core/components/ion-picker-legacy.js';
90
+ import { defineCustomElement as defineCustomElement$1d } from '@ionic/core/components/ion-action-sheet.js';
91
+ import { defineCustomElement as defineCustomElement$1e } from '@ionic/core/components/ion-modal.js';
92
+ import { defineCustomElement as defineCustomElement$1f } from '@ionic/core/components/ion-popover.js';
93
+ import { defineCustomElement as defineCustomElement$1l } from '@ionic/core/components/ion-app.js';
94
+ import { defineCustomElement as defineCustomElement$1j } from '@ionic/core/components/ion-back-button.js';
95
+ import { defineCustomElement as defineCustomElement$1k } from '@ionic/core/components/ion-router-outlet.js';
96
+ import { defineCustomElement as defineCustomElement$1h } from '@ionic/core/components/ion-tab-bar.js';
97
+ import { defineCustomElement as defineCustomElement$1g } from '@ionic/core/components/ion-tab-button.js';
98
+ import { defineCustomElement as defineCustomElement$1i } from '@ionic/core/components/ion-tabs.js';
99
+ import { defineCustomElement as defineCustomElement$1m } from 'ionicons/components/ion-icon.js';
99
100
 
100
101
  const IonLifeCycleContext = /*@__PURE__*/ React.createContext({
101
102
  onIonViewWillEnter: () => {
@@ -380,7 +381,9 @@ const useIonViewDidLeave = (callback, deps = []) => {
380
381
  };
381
382
 
382
383
  const NavContext = /*@__PURE__*/ React.createContext({
384
+ getIonRedirect: () => undefined,
383
385
  getIonRoute: () => undefined,
386
+ getPageManager: () => undefined,
384
387
  getStackManager: () => undefined,
385
388
  goBack: (route) => {
386
389
  if (typeof window !== 'undefined') {
@@ -412,699 +415,6 @@ const NavContext = /*@__PURE__*/ React.createContext({
412
415
  },
413
416
  });
414
417
 
415
- const IonAccordion =
416
- /*@__PURE__*/ createComponent({
417
- tagName: 'ion-accordion',
418
- elementClass: IonAccordion$1,
419
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
420
- react: React,
421
- events: {},
422
- defineCustomElement: defineCustomElement$1,
423
- });
424
- const IonAccordionGroup = /*@__PURE__*/ createComponent({
425
- tagName: 'ion-accordion-group',
426
- elementClass: IonAccordionGroup$1,
427
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
428
- react: React,
429
- events: { onIonChange: 'ionChange' },
430
- defineCustomElement: defineCustomElement$2,
431
- });
432
- const IonAvatar =
433
- /*@__PURE__*/ createComponent({
434
- tagName: 'ion-avatar',
435
- elementClass: IonAvatar$1,
436
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
437
- react: React,
438
- events: {},
439
- defineCustomElement: defineCustomElement$3,
440
- });
441
- const IonBackdrop =
442
- /*@__PURE__*/ createComponent({
443
- tagName: 'ion-backdrop',
444
- elementClass: IonBackdrop$1,
445
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
446
- react: React,
447
- events: { onIonBackdropTap: 'ionBackdropTap' },
448
- defineCustomElement: defineCustomElement$4,
449
- });
450
- const IonBadge =
451
- /*@__PURE__*/ createComponent({
452
- tagName: 'ion-badge',
453
- elementClass: IonBadge$1,
454
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
455
- react: React,
456
- events: {},
457
- defineCustomElement: defineCustomElement$5,
458
- });
459
- const IonBreadcrumbs = /*@__PURE__*/ createComponent({
460
- tagName: 'ion-breadcrumbs',
461
- elementClass: IonBreadcrumbs$1,
462
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
463
- react: React,
464
- events: { onIonCollapsedClick: 'ionCollapsedClick' },
465
- defineCustomElement: defineCustomElement$6,
466
- });
467
- const IonButtons =
468
- /*@__PURE__*/ createComponent({
469
- tagName: 'ion-buttons',
470
- elementClass: IonButtons$1,
471
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
472
- react: React,
473
- events: {},
474
- defineCustomElement: defineCustomElement$7,
475
- });
476
- const IonCardContent = /*@__PURE__*/ createComponent({
477
- tagName: 'ion-card-content',
478
- elementClass: IonCardContent$1,
479
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
480
- react: React,
481
- events: {},
482
- defineCustomElement: defineCustomElement$8,
483
- });
484
- const IonCardHeader =
485
- /*@__PURE__*/ createComponent({
486
- tagName: 'ion-card-header',
487
- elementClass: IonCardHeader$1,
488
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
489
- react: React,
490
- events: {},
491
- defineCustomElement: defineCustomElement$9,
492
- });
493
- const IonCardSubtitle = /*@__PURE__*/ createComponent({
494
- tagName: 'ion-card-subtitle',
495
- elementClass: IonCardSubtitle$1,
496
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
497
- react: React,
498
- events: {},
499
- defineCustomElement: defineCustomElement$a,
500
- });
501
- const IonCardTitle =
502
- /*@__PURE__*/ createComponent({
503
- tagName: 'ion-card-title',
504
- elementClass: IonCardTitle$1,
505
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
506
- react: React,
507
- events: {},
508
- defineCustomElement: defineCustomElement$b,
509
- });
510
- const IonCheckbox =
511
- /*@__PURE__*/ createComponent({
512
- tagName: 'ion-checkbox',
513
- elementClass: IonCheckbox$1,
514
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
515
- react: React,
516
- events: {
517
- onIonChange: 'ionChange',
518
- onIonFocus: 'ionFocus',
519
- onIonBlur: 'ionBlur',
520
- },
521
- defineCustomElement: defineCustomElement$c,
522
- });
523
- const IonChip =
524
- /*@__PURE__*/ createComponent({
525
- tagName: 'ion-chip',
526
- elementClass: IonChip$1,
527
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
528
- react: React,
529
- events: {},
530
- defineCustomElement: defineCustomElement$d,
531
- });
532
- const IonCol =
533
- /*@__PURE__*/ createComponent({
534
- tagName: 'ion-col',
535
- elementClass: IonCol$1,
536
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
537
- react: React,
538
- events: {},
539
- defineCustomElement: defineCustomElement$e,
540
- });
541
- const IonContent =
542
- /*@__PURE__*/ createComponent({
543
- tagName: 'ion-content',
544
- elementClass: IonContent$1,
545
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
546
- react: React,
547
- events: {
548
- onIonScrollStart: 'ionScrollStart',
549
- onIonScroll: 'ionScroll',
550
- onIonScrollEnd: 'ionScrollEnd',
551
- },
552
- defineCustomElement: defineCustomElement$f,
553
- });
554
- const IonDatetime =
555
- /*@__PURE__*/ createComponent({
556
- tagName: 'ion-datetime',
557
- elementClass: IonDatetime$1,
558
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
559
- react: React,
560
- events: {
561
- onIonCancel: 'ionCancel',
562
- onIonChange: 'ionChange',
563
- onIonFocus: 'ionFocus',
564
- onIonBlur: 'ionBlur',
565
- },
566
- defineCustomElement: defineCustomElement$g,
567
- });
568
- const IonDatetimeButton = /*@__PURE__*/ createComponent({
569
- tagName: 'ion-datetime-button',
570
- elementClass: IonDatetimeButton$1,
571
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
572
- react: React,
573
- events: {},
574
- defineCustomElement: defineCustomElement$h,
575
- });
576
- const IonFab =
577
- /*@__PURE__*/ createComponent({
578
- tagName: 'ion-fab',
579
- elementClass: IonFab$1,
580
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
581
- react: React,
582
- events: {},
583
- defineCustomElement: defineCustomElement$i,
584
- });
585
- const IonFabList =
586
- /*@__PURE__*/ createComponent({
587
- tagName: 'ion-fab-list',
588
- elementClass: IonFabList$1,
589
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
590
- react: React,
591
- events: {},
592
- defineCustomElement: defineCustomElement$j,
593
- });
594
- const IonFooter =
595
- /*@__PURE__*/ createComponent({
596
- tagName: 'ion-footer',
597
- elementClass: IonFooter$1,
598
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
599
- react: React,
600
- events: {},
601
- defineCustomElement: defineCustomElement$k,
602
- });
603
- const IonGrid =
604
- /*@__PURE__*/ createComponent({
605
- tagName: 'ion-grid',
606
- elementClass: IonGrid$1,
607
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
608
- react: React,
609
- events: {},
610
- defineCustomElement: defineCustomElement$l,
611
- });
612
- const IonHeader =
613
- /*@__PURE__*/ createComponent({
614
- tagName: 'ion-header',
615
- elementClass: IonHeader$1,
616
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
617
- react: React,
618
- events: {},
619
- defineCustomElement: defineCustomElement$m,
620
- });
621
- const IonImg =
622
- /*@__PURE__*/ createComponent({
623
- tagName: 'ion-img',
624
- elementClass: IonImg$1,
625
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
626
- react: React,
627
- events: {
628
- onIonImgWillLoad: 'ionImgWillLoad',
629
- onIonImgDidLoad: 'ionImgDidLoad',
630
- onIonError: 'ionError',
631
- },
632
- defineCustomElement: defineCustomElement$n,
633
- });
634
- const IonInfiniteScroll = /*@__PURE__*/ createComponent({
635
- tagName: 'ion-infinite-scroll',
636
- elementClass: IonInfiniteScroll$1,
637
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
638
- react: React,
639
- events: { onIonInfinite: 'ionInfinite' },
640
- defineCustomElement: defineCustomElement$o,
641
- });
642
- const IonInfiniteScrollContent = /*@__PURE__*/ createComponent({
643
- tagName: 'ion-infinite-scroll-content',
644
- elementClass: IonInfiniteScrollContent$1,
645
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
646
- react: React,
647
- events: {},
648
- defineCustomElement: defineCustomElement$p,
649
- });
650
- const IonInput =
651
- /*@__PURE__*/ createComponent({
652
- tagName: 'ion-input',
653
- elementClass: IonInput$1,
654
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
655
- react: React,
656
- events: {
657
- onIonInput: 'ionInput',
658
- onIonChange: 'ionChange',
659
- onIonBlur: 'ionBlur',
660
- onIonFocus: 'ionFocus',
661
- },
662
- defineCustomElement: defineCustomElement$q,
663
- });
664
- const IonInputOtp =
665
- /*@__PURE__*/ createComponent({
666
- tagName: 'ion-input-otp',
667
- elementClass: IonInputOtp$1,
668
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
669
- react: React,
670
- events: {
671
- onIonInput: 'ionInput',
672
- onIonChange: 'ionChange',
673
- onIonComplete: 'ionComplete',
674
- onIonBlur: 'ionBlur',
675
- onIonFocus: 'ionFocus',
676
- },
677
- defineCustomElement: defineCustomElement$r,
678
- });
679
- const IonInputPasswordToggle = /*@__PURE__*/ createComponent({
680
- tagName: 'ion-input-password-toggle',
681
- elementClass: IonInputPasswordToggle$1,
682
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
683
- react: React,
684
- events: {},
685
- defineCustomElement: defineCustomElement$s,
686
- });
687
- const IonItemDivider = /*@__PURE__*/ createComponent({
688
- tagName: 'ion-item-divider',
689
- elementClass: IonItemDivider$1,
690
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
691
- react: React,
692
- events: {},
693
- defineCustomElement: defineCustomElement$t,
694
- });
695
- const IonItemGroup =
696
- /*@__PURE__*/ createComponent({
697
- tagName: 'ion-item-group',
698
- elementClass: IonItemGroup$1,
699
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
700
- react: React,
701
- events: {},
702
- defineCustomElement: defineCustomElement$u,
703
- });
704
- const IonItemOptions = /*@__PURE__*/ createComponent({
705
- tagName: 'ion-item-options',
706
- elementClass: IonItemOptions$1,
707
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
708
- react: React,
709
- events: { onIonSwipe: 'ionSwipe' },
710
- defineCustomElement: defineCustomElement$v,
711
- });
712
- const IonItemSliding = /*@__PURE__*/ createComponent({
713
- tagName: 'ion-item-sliding',
714
- elementClass: IonItemSliding$1,
715
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
716
- react: React,
717
- events: { onIonDrag: 'ionDrag' },
718
- defineCustomElement: defineCustomElement$w,
719
- });
720
- const IonLabel =
721
- /*@__PURE__*/ createComponent({
722
- tagName: 'ion-label',
723
- elementClass: IonLabel$1,
724
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
725
- react: React,
726
- events: {},
727
- defineCustomElement: defineCustomElement$x,
728
- });
729
- const IonList =
730
- /*@__PURE__*/ createComponent({
731
- tagName: 'ion-list',
732
- elementClass: IonList$1,
733
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
734
- react: React,
735
- events: {},
736
- defineCustomElement: defineCustomElement$y,
737
- });
738
- const IonListHeader =
739
- /*@__PURE__*/ createComponent({
740
- tagName: 'ion-list-header',
741
- elementClass: IonListHeader$1,
742
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
743
- react: React,
744
- events: {},
745
- defineCustomElement: defineCustomElement$z,
746
- });
747
- const IonMenu =
748
- /*@__PURE__*/ createComponent({
749
- tagName: 'ion-menu',
750
- elementClass: IonMenu$1,
751
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
752
- react: React,
753
- events: {
754
- onIonWillOpen: 'ionWillOpen',
755
- onIonWillClose: 'ionWillClose',
756
- onIonDidOpen: 'ionDidOpen',
757
- onIonDidClose: 'ionDidClose',
758
- },
759
- defineCustomElement: defineCustomElement$A,
760
- });
761
- const IonMenuButton =
762
- /*@__PURE__*/ createComponent({
763
- tagName: 'ion-menu-button',
764
- elementClass: IonMenuButton$1,
765
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
766
- react: React,
767
- events: {},
768
- defineCustomElement: defineCustomElement$B,
769
- });
770
- const IonMenuToggle =
771
- /*@__PURE__*/ createComponent({
772
- tagName: 'ion-menu-toggle',
773
- elementClass: IonMenuToggle$1,
774
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
775
- react: React,
776
- events: {},
777
- defineCustomElement: defineCustomElement$C,
778
- });
779
- const IonNavLink =
780
- /*@__PURE__*/ createComponent({
781
- tagName: 'ion-nav-link',
782
- elementClass: IonNavLink$1,
783
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
784
- react: React,
785
- events: {},
786
- defineCustomElement: defineCustomElement$D,
787
- });
788
- const IonNote =
789
- /*@__PURE__*/ createComponent({
790
- tagName: 'ion-note',
791
- elementClass: IonNote$1,
792
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
793
- react: React,
794
- events: {},
795
- defineCustomElement: defineCustomElement$E,
796
- });
797
- const IonPicker =
798
- /*@__PURE__*/ createComponent({
799
- tagName: 'ion-picker',
800
- elementClass: IonPicker$1,
801
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
802
- react: React,
803
- events: {},
804
- defineCustomElement: defineCustomElement$F,
805
- });
806
- const IonPickerColumn = /*@__PURE__*/ createComponent({
807
- tagName: 'ion-picker-column',
808
- elementClass: IonPickerColumn$1,
809
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
810
- react: React,
811
- events: { onIonChange: 'ionChange' },
812
- defineCustomElement: defineCustomElement$G,
813
- });
814
- const IonPickerColumnOption = /*@__PURE__*/ createComponent({
815
- tagName: 'ion-picker-column-option',
816
- elementClass: IonPickerColumnOption$1,
817
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
818
- react: React,
819
- events: {},
820
- defineCustomElement: defineCustomElement$H,
821
- });
822
- const IonProgressBar = /*@__PURE__*/ createComponent({
823
- tagName: 'ion-progress-bar',
824
- elementClass: IonProgressBar$1,
825
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
826
- react: React,
827
- events: {},
828
- defineCustomElement: defineCustomElement$I,
829
- });
830
- const IonRadio =
831
- /*@__PURE__*/ createComponent({
832
- tagName: 'ion-radio',
833
- elementClass: IonRadio$1,
834
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
835
- react: React,
836
- events: {
837
- onIonFocus: 'ionFocus',
838
- onIonBlur: 'ionBlur',
839
- },
840
- defineCustomElement: defineCustomElement$J,
841
- });
842
- const IonRadioGroup =
843
- /*@__PURE__*/ createComponent({
844
- tagName: 'ion-radio-group',
845
- elementClass: IonRadioGroup$1,
846
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
847
- react: React,
848
- events: { onIonChange: 'ionChange' },
849
- defineCustomElement: defineCustomElement$K,
850
- });
851
- const IonRange =
852
- /*@__PURE__*/ createComponent({
853
- tagName: 'ion-range',
854
- elementClass: IonRange$1,
855
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
856
- react: React,
857
- events: {
858
- onIonChange: 'ionChange',
859
- onIonInput: 'ionInput',
860
- onIonFocus: 'ionFocus',
861
- onIonBlur: 'ionBlur',
862
- onIonKnobMoveStart: 'ionKnobMoveStart',
863
- onIonKnobMoveEnd: 'ionKnobMoveEnd',
864
- },
865
- defineCustomElement: defineCustomElement$L,
866
- });
867
- const IonRefresher =
868
- /*@__PURE__*/ createComponent({
869
- tagName: 'ion-refresher',
870
- elementClass: IonRefresher$1,
871
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
872
- react: React,
873
- events: {
874
- onIonRefresh: 'ionRefresh',
875
- onIonPull: 'ionPull',
876
- onIonStart: 'ionStart',
877
- onIonPullStart: 'ionPullStart',
878
- onIonPullEnd: 'ionPullEnd',
879
- },
880
- defineCustomElement: defineCustomElement$M,
881
- });
882
- const IonRefresherContent = /*@__PURE__*/ createComponent({
883
- tagName: 'ion-refresher-content',
884
- elementClass: IonRefresherContent$1,
885
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
886
- react: React,
887
- events: {},
888
- defineCustomElement: defineCustomElement$N,
889
- });
890
- const IonReorder =
891
- /*@__PURE__*/ createComponent({
892
- tagName: 'ion-reorder',
893
- elementClass: IonReorder$1,
894
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
895
- react: React,
896
- events: {},
897
- defineCustomElement: defineCustomElement$O,
898
- });
899
- const IonReorderGroup = /*@__PURE__*/ createComponent({
900
- tagName: 'ion-reorder-group',
901
- elementClass: IonReorderGroup$1,
902
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
903
- react: React,
904
- events: {
905
- onIonItemReorder: 'ionItemReorder',
906
- onIonReorderStart: 'ionReorderStart',
907
- onIonReorderMove: 'ionReorderMove',
908
- onIonReorderEnd: 'ionReorderEnd',
909
- },
910
- defineCustomElement: defineCustomElement$P,
911
- });
912
- const IonRippleEffect = /*@__PURE__*/ createComponent({
913
- tagName: 'ion-ripple-effect',
914
- elementClass: IonRippleEffect$1,
915
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
916
- react: React,
917
- events: {},
918
- defineCustomElement: defineCustomElement$Q,
919
- });
920
- const IonRow =
921
- /*@__PURE__*/ createComponent({
922
- tagName: 'ion-row',
923
- elementClass: IonRow$1,
924
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
925
- react: React,
926
- events: {},
927
- defineCustomElement: defineCustomElement$R,
928
- });
929
- const IonSearchbar =
930
- /*@__PURE__*/ createComponent({
931
- tagName: 'ion-searchbar',
932
- elementClass: IonSearchbar$1,
933
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
934
- react: React,
935
- events: {
936
- onIonInput: 'ionInput',
937
- onIonChange: 'ionChange',
938
- onIonCancel: 'ionCancel',
939
- onIonClear: 'ionClear',
940
- onIonBlur: 'ionBlur',
941
- onIonFocus: 'ionFocus',
942
- },
943
- defineCustomElement: defineCustomElement$S,
944
- });
945
- const IonSegment =
946
- /*@__PURE__*/ createComponent({
947
- tagName: 'ion-segment',
948
- elementClass: IonSegment$1,
949
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
950
- react: React,
951
- events: { onIonChange: 'ionChange' },
952
- defineCustomElement: defineCustomElement$T,
953
- });
954
- const IonSegmentButton = /*@__PURE__*/ createComponent({
955
- tagName: 'ion-segment-button',
956
- elementClass: IonSegmentButton$1,
957
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
958
- react: React,
959
- events: {},
960
- defineCustomElement: defineCustomElement$U,
961
- });
962
- const IonSegmentContent = /*@__PURE__*/ createComponent({
963
- tagName: 'ion-segment-content',
964
- elementClass: IonSegmentContent$1,
965
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
966
- react: React,
967
- events: {},
968
- defineCustomElement: defineCustomElement$V,
969
- });
970
- const IonSegmentView = /*@__PURE__*/ createComponent({
971
- tagName: 'ion-segment-view',
972
- elementClass: IonSegmentView$1,
973
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
974
- react: React,
975
- events: { onIonSegmentViewScroll: 'ionSegmentViewScroll' },
976
- defineCustomElement: defineCustomElement$W,
977
- });
978
- const IonSelect =
979
- /*@__PURE__*/ createComponent({
980
- tagName: 'ion-select',
981
- elementClass: IonSelect$1,
982
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
983
- react: React,
984
- events: {
985
- onIonChange: 'ionChange',
986
- onIonCancel: 'ionCancel',
987
- onIonDismiss: 'ionDismiss',
988
- onIonFocus: 'ionFocus',
989
- onIonBlur: 'ionBlur',
990
- },
991
- defineCustomElement: defineCustomElement$X,
992
- });
993
- const IonSelectModal = /*@__PURE__*/ createComponent({
994
- tagName: 'ion-select-modal',
995
- elementClass: IonSelectModal$1,
996
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
997
- react: React,
998
- events: {},
999
- defineCustomElement: defineCustomElement$Y,
1000
- });
1001
- const IonSelectOption = /*@__PURE__*/ createComponent({
1002
- tagName: 'ion-select-option',
1003
- elementClass: IonSelectOption$1,
1004
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1005
- react: React,
1006
- events: {},
1007
- defineCustomElement: defineCustomElement$Z,
1008
- });
1009
- const IonSkeletonText = /*@__PURE__*/ createComponent({
1010
- tagName: 'ion-skeleton-text',
1011
- elementClass: IonSkeletonText$1,
1012
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1013
- react: React,
1014
- events: {},
1015
- defineCustomElement: defineCustomElement$_,
1016
- });
1017
- const IonSpinner =
1018
- /*@__PURE__*/ createComponent({
1019
- tagName: 'ion-spinner',
1020
- elementClass: IonSpinner$1,
1021
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1022
- react: React,
1023
- events: {},
1024
- defineCustomElement: defineCustomElement$$,
1025
- });
1026
- const IonSplitPane =
1027
- /*@__PURE__*/ createComponent({
1028
- tagName: 'ion-split-pane',
1029
- elementClass: IonSplitPane$1,
1030
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1031
- react: React,
1032
- events: { onIonSplitPaneVisible: 'ionSplitPaneVisible' },
1033
- defineCustomElement: defineCustomElement$10,
1034
- });
1035
- const IonTab =
1036
- /*@__PURE__*/ createComponent({
1037
- tagName: 'ion-tab',
1038
- elementClass: IonTab$1,
1039
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1040
- react: React,
1041
- events: {},
1042
- defineCustomElement: defineCustomElement$11,
1043
- });
1044
- const IonText =
1045
- /*@__PURE__*/ createComponent({
1046
- tagName: 'ion-text',
1047
- elementClass: IonText$1,
1048
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1049
- react: React,
1050
- events: {},
1051
- defineCustomElement: defineCustomElement$12,
1052
- });
1053
- const IonTextarea =
1054
- /*@__PURE__*/ createComponent({
1055
- tagName: 'ion-textarea',
1056
- elementClass: IonTextarea$1,
1057
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1058
- react: React,
1059
- events: {
1060
- onIonChange: 'ionChange',
1061
- onIonInput: 'ionInput',
1062
- onIonBlur: 'ionBlur',
1063
- onIonFocus: 'ionFocus',
1064
- },
1065
- defineCustomElement: defineCustomElement$13,
1066
- });
1067
- const IonThumbnail =
1068
- /*@__PURE__*/ createComponent({
1069
- tagName: 'ion-thumbnail',
1070
- elementClass: IonThumbnail$1,
1071
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1072
- react: React,
1073
- events: {},
1074
- defineCustomElement: defineCustomElement$14,
1075
- });
1076
- const IonTitle =
1077
- /*@__PURE__*/ createComponent({
1078
- tagName: 'ion-title',
1079
- elementClass: IonTitle$1,
1080
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1081
- react: React,
1082
- events: {},
1083
- defineCustomElement: defineCustomElement$15,
1084
- });
1085
- const IonToggle =
1086
- /*@__PURE__*/ createComponent({
1087
- tagName: 'ion-toggle',
1088
- elementClass: IonToggle$1,
1089
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1090
- react: React,
1091
- events: {
1092
- onIonChange: 'ionChange',
1093
- onIonFocus: 'ionFocus',
1094
- onIonBlur: 'ionBlur',
1095
- },
1096
- defineCustomElement: defineCustomElement$16,
1097
- });
1098
- const IonToolbar =
1099
- /*@__PURE__*/ createComponent({
1100
- tagName: 'ion-toolbar',
1101
- elementClass: IonToolbar$1,
1102
- // @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
1103
- react: React,
1104
- events: {},
1105
- defineCustomElement: defineCustomElement$17,
1106
- });
1107
-
1108
418
  const dashToPascalCase = (str) => str
1109
419
  .toLowerCase()
1110
420
  .split('-')
@@ -1248,6 +558,148 @@ const defineCustomElement = (tagName, customElement) => {
1248
558
  }
1249
559
  };
1250
560
 
561
+ const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => {
562
+ if (defineCustomElement !== undefined) {
563
+ defineCustomElement();
564
+ }
565
+ const displayName = dashToPascalCase(tagName);
566
+ const ReactComponent = class extends React.Component {
567
+ constructor(props) {
568
+ super(props);
569
+ this.setComponentElRef = (element) => {
570
+ this.componentEl = element;
571
+ };
572
+ }
573
+ componentDidMount() {
574
+ this.componentDidUpdate(this.props);
575
+ }
576
+ componentDidUpdate(prevProps) {
577
+ attachProps(this.componentEl, this.props, prevProps);
578
+ }
579
+ render() {
580
+ const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
581
+ let propsToPass = Object.keys(cProps).reduce((acc, name) => {
582
+ const value = cProps[name];
583
+ if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
584
+ const eventName = name.substring(2).toLowerCase();
585
+ if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
586
+ acc[name] = value;
587
+ }
588
+ }
589
+ else {
590
+ // we should only render strings, booleans, and numbers as attrs in html.
591
+ // objects, functions, arrays etc get synced via properties on mount.
592
+ const type = typeof value;
593
+ if (type === 'string' || type === 'boolean' || type === 'number') {
594
+ acc[camelToDashCase(name)] = value;
595
+ }
596
+ }
597
+ return acc;
598
+ }, {});
599
+ if (manipulatePropsFunction) {
600
+ propsToPass = manipulatePropsFunction(this.props, propsToPass);
601
+ }
602
+ const newProps = {
603
+ ...propsToPass,
604
+ ref: mergeRefs(forwardedRef, this.setComponentElRef),
605
+ style,
606
+ };
607
+ /**
608
+ * We use createElement here instead of
609
+ * React.createElement to work around a
610
+ * bug in Vite (https://github.com/vitejs/vite/issues/6104).
611
+ * React.createElement causes all elements to be rendered
612
+ * as <tagname> instead of the actual Web Component.
613
+ */
614
+ return createElement(tagName, newProps, children);
615
+ }
616
+ static get displayName() {
617
+ return displayName;
618
+ }
619
+ };
620
+ // If context was passed to createReactComponent then conditionally add it to the Component Class
621
+ if (ReactComponentContext) {
622
+ ReactComponent.contextType = ReactComponentContext;
623
+ }
624
+ return createForwardRef$1(ReactComponent, displayName);
625
+ };
626
+
627
+ /* eslint-disable */
628
+ /* tslint:disable */
629
+ /* auto-generated react proxies */
630
+ const IonAccordion = /*@__PURE__*/ createReactComponent('ion-accordion', undefined, undefined, defineCustomElement$1);
631
+ const IonAccordionGroup = /*@__PURE__*/ createReactComponent('ion-accordion-group', undefined, undefined, defineCustomElement$2);
632
+ const IonAvatar = /*@__PURE__*/ createReactComponent('ion-avatar', undefined, undefined, defineCustomElement$3);
633
+ const IonBackdrop = /*@__PURE__*/ createReactComponent('ion-backdrop', undefined, undefined, defineCustomElement$4);
634
+ const IonBadge = /*@__PURE__*/ createReactComponent('ion-badge', undefined, undefined, defineCustomElement$5);
635
+ const IonBreadcrumbs = /*@__PURE__*/ createReactComponent('ion-breadcrumbs', undefined, undefined, defineCustomElement$6);
636
+ const IonButtons = /*@__PURE__*/ createReactComponent('ion-buttons', undefined, undefined, defineCustomElement$7);
637
+ const IonCardContent = /*@__PURE__*/ createReactComponent('ion-card-content', undefined, undefined, defineCustomElement$8);
638
+ const IonCardHeader = /*@__PURE__*/ createReactComponent('ion-card-header', undefined, undefined, defineCustomElement$9);
639
+ const IonCardSubtitle = /*@__PURE__*/ createReactComponent('ion-card-subtitle', undefined, undefined, defineCustomElement$a);
640
+ const IonCardTitle = /*@__PURE__*/ createReactComponent('ion-card-title', undefined, undefined, defineCustomElement$b);
641
+ const IonCheckbox = /*@__PURE__*/ createReactComponent('ion-checkbox', undefined, undefined, defineCustomElement$c);
642
+ const IonChip = /*@__PURE__*/ createReactComponent('ion-chip', undefined, undefined, defineCustomElement$d);
643
+ const IonCol = /*@__PURE__*/ createReactComponent('ion-col', undefined, undefined, defineCustomElement$e);
644
+ const IonContent = /*@__PURE__*/ createReactComponent('ion-content', undefined, undefined, defineCustomElement$f);
645
+ const IonDatetime = /*@__PURE__*/ createReactComponent('ion-datetime', undefined, undefined, defineCustomElement$g);
646
+ const IonDatetimeButton = /*@__PURE__*/ createReactComponent('ion-datetime-button', undefined, undefined, defineCustomElement$h);
647
+ const IonDivider = /*@__PURE__*/ createReactComponent('ion-divider', undefined, undefined, defineCustomElement$i);
648
+ const IonFab = /*@__PURE__*/ createReactComponent('ion-fab', undefined, undefined, defineCustomElement$j);
649
+ const IonFabList = /*@__PURE__*/ createReactComponent('ion-fab-list', undefined, undefined, defineCustomElement$k);
650
+ const IonFooter = /*@__PURE__*/ createReactComponent('ion-footer', undefined, undefined, defineCustomElement$l);
651
+ const IonGrid = /*@__PURE__*/ createReactComponent('ion-grid', undefined, undefined, defineCustomElement$m);
652
+ const IonHeader = /*@__PURE__*/ createReactComponent('ion-header', undefined, undefined, defineCustomElement$n);
653
+ const IonImg = /*@__PURE__*/ createReactComponent('ion-img', undefined, undefined, defineCustomElement$o);
654
+ const IonInfiniteScroll = /*@__PURE__*/ createReactComponent('ion-infinite-scroll', undefined, undefined, defineCustomElement$p);
655
+ const IonInfiniteScrollContent = /*@__PURE__*/ createReactComponent('ion-infinite-scroll-content', undefined, undefined, defineCustomElement$q);
656
+ const IonInput = /*@__PURE__*/ createReactComponent('ion-input', undefined, undefined, defineCustomElement$r);
657
+ const IonInputOtp = /*@__PURE__*/ createReactComponent('ion-input-otp', undefined, undefined, defineCustomElement$s);
658
+ const IonInputPasswordToggle = /*@__PURE__*/ createReactComponent('ion-input-password-toggle', undefined, undefined, defineCustomElement$t);
659
+ const IonItemDivider = /*@__PURE__*/ createReactComponent('ion-item-divider', undefined, undefined, defineCustomElement$u);
660
+ const IonItemGroup = /*@__PURE__*/ createReactComponent('ion-item-group', undefined, undefined, defineCustomElement$v);
661
+ const IonItemOptions = /*@__PURE__*/ createReactComponent('ion-item-options', undefined, undefined, defineCustomElement$w);
662
+ const IonItemSliding = /*@__PURE__*/ createReactComponent('ion-item-sliding', undefined, undefined, defineCustomElement$x);
663
+ const IonLabel = /*@__PURE__*/ createReactComponent('ion-label', undefined, undefined, defineCustomElement$y);
664
+ const IonList = /*@__PURE__*/ createReactComponent('ion-list', undefined, undefined, defineCustomElement$z);
665
+ const IonListHeader = /*@__PURE__*/ createReactComponent('ion-list-header', undefined, undefined, defineCustomElement$A);
666
+ const IonMenu = /*@__PURE__*/ createReactComponent('ion-menu', undefined, undefined, defineCustomElement$B);
667
+ const IonMenuButton = /*@__PURE__*/ createReactComponent('ion-menu-button', undefined, undefined, defineCustomElement$C);
668
+ const IonMenuToggle = /*@__PURE__*/ createReactComponent('ion-menu-toggle', undefined, undefined, defineCustomElement$D);
669
+ const IonNavLink = /*@__PURE__*/ createReactComponent('ion-nav-link', undefined, undefined, defineCustomElement$E);
670
+ const IonNote = /*@__PURE__*/ createReactComponent('ion-note', undefined, undefined, defineCustomElement$F);
671
+ const IonPicker = /*@__PURE__*/ createReactComponent('ion-picker', undefined, undefined, defineCustomElement$G);
672
+ const IonPickerColumn = /*@__PURE__*/ createReactComponent('ion-picker-column', undefined, undefined, defineCustomElement$H);
673
+ const IonPickerColumnOption = /*@__PURE__*/ createReactComponent('ion-picker-column-option', undefined, undefined, defineCustomElement$I);
674
+ const IonProgressBar = /*@__PURE__*/ createReactComponent('ion-progress-bar', undefined, undefined, defineCustomElement$J);
675
+ const IonRadio = /*@__PURE__*/ createReactComponent('ion-radio', undefined, undefined, defineCustomElement$K);
676
+ const IonRadioGroup = /*@__PURE__*/ createReactComponent('ion-radio-group', undefined, undefined, defineCustomElement$L);
677
+ const IonRange = /*@__PURE__*/ createReactComponent('ion-range', undefined, undefined, defineCustomElement$M);
678
+ const IonRefresher = /*@__PURE__*/ createReactComponent('ion-refresher', undefined, undefined, defineCustomElement$N);
679
+ const IonRefresherContent = /*@__PURE__*/ createReactComponent('ion-refresher-content', undefined, undefined, defineCustomElement$O);
680
+ const IonReorder = /*@__PURE__*/ createReactComponent('ion-reorder', undefined, undefined, defineCustomElement$P);
681
+ const IonReorderGroup = /*@__PURE__*/ createReactComponent('ion-reorder-group', undefined, undefined, defineCustomElement$Q);
682
+ const IonRippleEffect = /*@__PURE__*/ createReactComponent('ion-ripple-effect', undefined, undefined, defineCustomElement$R);
683
+ const IonRow = /*@__PURE__*/ createReactComponent('ion-row', undefined, undefined, defineCustomElement$S);
684
+ const IonSearchbar = /*@__PURE__*/ createReactComponent('ion-searchbar', undefined, undefined, defineCustomElement$T);
685
+ const IonSegment = /*@__PURE__*/ createReactComponent('ion-segment', undefined, undefined, defineCustomElement$U);
686
+ const IonSegmentButton = /*@__PURE__*/ createReactComponent('ion-segment-button', undefined, undefined, defineCustomElement$V);
687
+ const IonSegmentContent = /*@__PURE__*/ createReactComponent('ion-segment-content', undefined, undefined, defineCustomElement$W);
688
+ const IonSegmentView = /*@__PURE__*/ createReactComponent('ion-segment-view', undefined, undefined, defineCustomElement$X);
689
+ const IonSelect = /*@__PURE__*/ createReactComponent('ion-select', undefined, undefined, defineCustomElement$Y);
690
+ const IonSelectModal = /*@__PURE__*/ createReactComponent('ion-select-modal', undefined, undefined, defineCustomElement$Z);
691
+ const IonSelectOption = /*@__PURE__*/ createReactComponent('ion-select-option', undefined, undefined, defineCustomElement$_);
692
+ const IonSkeletonText = /*@__PURE__*/ createReactComponent('ion-skeleton-text', undefined, undefined, defineCustomElement$$);
693
+ const IonSpinner = /*@__PURE__*/ createReactComponent('ion-spinner', undefined, undefined, defineCustomElement$10);
694
+ const IonSplitPane = /*@__PURE__*/ createReactComponent('ion-split-pane', undefined, undefined, defineCustomElement$11);
695
+ const IonTab = /*@__PURE__*/ createReactComponent('ion-tab', undefined, undefined, defineCustomElement$12);
696
+ const IonText = /*@__PURE__*/ createReactComponent('ion-text', undefined, undefined, defineCustomElement$13);
697
+ const IonTextarea = /*@__PURE__*/ createReactComponent('ion-textarea', undefined, undefined, defineCustomElement$14);
698
+ const IonThumbnail = /*@__PURE__*/ createReactComponent('ion-thumbnail', undefined, undefined, defineCustomElement$15);
699
+ const IonTitle = /*@__PURE__*/ createReactComponent('ion-title', undefined, undefined, defineCustomElement$16);
700
+ const IonToggle = /*@__PURE__*/ createReactComponent('ion-toggle', undefined, undefined, defineCustomElement$17);
701
+ const IonToolbar = /*@__PURE__*/ createReactComponent('ion-toolbar', undefined, undefined, defineCustomElement$18);
702
+
1251
703
  const createForwardRef = (ReactComponent, // TODO(FW-2959): type
1252
704
  displayName) => {
1253
705
  const forwardRef = (props, ref) => {
@@ -1281,11 +733,6 @@ const createRoutingComponent = (tagName, customElement) => {
1281
733
  this.handleClick = (e) => {
1282
734
  const { routerLink, routerDirection, routerOptions, routerAnimation } = this.props;
1283
735
  if (routerLink !== undefined) {
1284
- // Allow modifier key clicks (ctrl/cmd/shift) to open the link in a new tab/window
1285
- // without triggering SPA navigation on the current page.
1286
- if (e.metaKey || e.ctrlKey || e.shiftKey) {
1287
- return;
1288
- }
1289
736
  e.preventDefault();
1290
737
  this.context.navigate(routerLink, routerDirection, undefined, routerAnimation, routerOptions);
1291
738
  }
@@ -1543,17 +990,19 @@ const createInlineOverlayComponent = (tagName, defineCustomElement, hasDelegateH
1543
990
  };
1544
991
  const DELEGATE_HOST = 'ion-delegate-host';
1545
992
 
1546
- const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$18);
993
+ const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$19);
994
+
995
+ const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$1a);
1547
996
 
1548
- const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$19);
997
+ const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1b);
1549
998
 
1550
- const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1a);
999
+ const IonPickerLegacy = /*@__PURE__*/ createInlineOverlayComponent('ion-picker-legacy', defineCustomElement$1c);
1551
1000
 
1552
- const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1b);
1001
+ const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1d);
1553
1002
 
1554
- const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1c, true);
1003
+ const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1e, true);
1555
1004
 
1556
- const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1d);
1005
+ const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1f);
1557
1006
 
1558
1007
  const IonContext = React.createContext({
1559
1008
  addOverlay: () => {
@@ -1645,81 +1094,14 @@ const IonOverlayManager = ({ onAddOverlay, onRemoveOverlay }) => {
1645
1094
  }) }));
1646
1095
  };
1647
1096
 
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);
1097
+ const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1g);
1098
+ const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1h);
1099
+ const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1i);
1100
+ const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1j);
1101
+ const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1k);
1102
+ const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1l);
1721
1103
  // ionicons
1722
- const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1k);
1104
+ const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1m);
1723
1105
 
1724
1106
  class IonApp extends React.Component {
1725
1107
  constructor(props) {
@@ -1757,25 +1139,7 @@ class PageManager extends React.PureComponent {
1757
1139
  super(props);
1758
1140
  this.ionPageElementRef = React.createRef();
1759
1141
  // React refs must be stable (not created inline).
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
- };
1142
+ this.stableMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
1779
1143
  /**
1780
1144
  * This binds the scope of the following methods to the class scope.
1781
1145
  * The `.bind` method returns a new function, so we need to assign it
@@ -1787,38 +1151,11 @@ class PageManager extends React.PureComponent {
1787
1151
  this.ionViewWillLeaveHandler = this.ionViewWillLeaveHandler.bind(this);
1788
1152
  this.ionViewDidLeaveHandler = this.ionViewDidLeaveHandler.bind(this);
1789
1153
  }
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
- }
1815
1154
  componentDidMount() {
1816
1155
  if (this.ionPageElementRef.current) {
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);
1156
+ if (this.context.isInOutlet()) {
1157
+ this.ionPageElementRef.current.classList.add('ion-page-invisible');
1158
+ }
1822
1159
  this.context.registerIonPage(this.ionPageElementRef.current, this.props.routeInfo);
1823
1160
  this.ionPageElementRef.current.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
1824
1161
  this.ionPageElementRef.current.addEventListener('ionViewDidEnter', this.ionViewDidEnterHandler);
@@ -1826,11 +1163,6 @@ class PageManager extends React.PureComponent {
1826
1163
  this.ionPageElementRef.current.addEventListener('ionViewDidLeave', this.ionViewDidLeaveHandler);
1827
1164
  }
1828
1165
  }
1829
- componentDidUpdate(prevProps) {
1830
- if (prevProps.className !== this.props.className) {
1831
- this.updateUserClasses(prevProps.className, this.props.className);
1832
- }
1833
- }
1834
1166
  componentWillUnmount() {
1835
1167
  if (this.ionPageElementRef.current) {
1836
1168
  this.ionPageElementRef.current.removeEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
@@ -1860,11 +1192,9 @@ class PageManager extends React.PureComponent {
1860
1192
  render() {
1861
1193
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
1862
1194
  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.
1865
1195
  return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
1866
1196
  this.ionLifeCycleContext = context;
1867
- return (jsx("div", { className: "ion-page", ref: this.stableMergedRefs, ...props, children: children }));
1197
+ return (jsx("div", { className: className ? `${className} ion-page` : `ion-page`, ref: this.stableMergedRefs, ...props, children: children }));
1868
1198
  } }));
1869
1199
  }
1870
1200
  static get contextType() {
@@ -1924,7 +1254,7 @@ const ReactDelegate = (addView, removeView) => {
1924
1254
  };
1925
1255
  };
1926
1256
 
1927
- const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1l);
1257
+ const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1n);
1928
1258
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
1929
1259
  const IonNavInternal = ({ children, forwardedRef, ...restOfProps }) => {
1930
1260
  const [views, setViews] = useState([]);
@@ -1972,30 +1302,8 @@ class OutletPageManager extends React.Component {
1972
1302
  */
1973
1303
  if (!this.outletIsReady) {
1974
1304
  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;
1984
1305
  this.outletIsReady = true;
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);
1306
+ this.context.registerIonPage(this.ionRouterOutlet, this.props.routeInfo);
1999
1307
  });
2000
1308
  }
2001
1309
  this.ionRouterOutlet.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
@@ -2025,10 +1333,10 @@ class OutletPageManager extends React.Component {
2025
1333
  this.ionLifeCycleContext.ionViewDidLeave();
2026
1334
  }
2027
1335
  render() {
2028
- const { StackManager, children, routeInfo, id, ...props } = this.props;
1336
+ const { StackManager, children, routeInfo, ...props } = this.props;
2029
1337
  return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
2030
1338
  this.ionLifeCycleContext = context;
2031
- return (jsx(StackManager, { id: id, routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { id: id, setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
1339
+ return (jsx(StackManager, { routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
2032
1340
  } }));
2033
1341
  }
2034
1342
  static get contextType() {
@@ -2039,13 +1347,11 @@ class OutletPageManager extends React.Component {
2039
1347
  class IonRouterOutletContainer extends React.Component {
2040
1348
  constructor(props) {
2041
1349
  super(props);
2042
- this.outletId = props.id ?? `routerOutlet-${generateId('routerOutlet')}`;
2043
1350
  }
2044
1351
  render() {
2045
1352
  const StackManager = this.context.getStackManager();
2046
1353
  const { children, forwardedRef, ...props } = this.props;
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 }));
1354
+ 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 }));
2049
1355
  }
2050
1356
  static get contextType() {
2051
1357
  return NavContext;
@@ -2242,9 +1548,7 @@ const matchesTab = (pathname, href) => {
2242
1548
  if (href === undefined) {
2243
1549
  return false;
2244
1550
  }
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;
1551
+ const normalizedHref = href.endsWith('/') && href !== '/' ? href.slice(0, -1) : href;
2248
1552
  return pathname === normalizedHref || pathname.startsWith(normalizedHref + '/');
2249
1553
  };
2250
1554
  class IonTabBarUnwrapped extends React.PureComponent {
@@ -2336,7 +1640,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
2336
1640
  const prevHref = state.tabs[prevActiveTab].currentHref;
2337
1641
  const prevRouteOptions = state.tabs[prevActiveTab].currentRouteOptions;
2338
1642
  if (activeTab !== prevActiveTab ||
2339
- prevHref !== (props.routeInfo?.pathname || '') + (props.routeInfo?.search || '') ||
1643
+ prevHref !== props.routeInfo?.pathname ||
2340
1644
  prevRouteOptions !== props.routeInfo?.routeOptions) {
2341
1645
  tabs[activeTab] = {
2342
1646
  originalHref: tabs[activeTab].originalHref,
@@ -2403,7 +1707,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
2403
1707
  return (child) => {
2404
1708
  if (child != null && child.props && (child.type === IonTabButton || child.type.isTabButton)) {
2405
1709
  const href = child.props.tab === activeTab
2406
- ? (this.props.routeInfo?.pathname || '') + (this.props.routeInfo?.search || '')
1710
+ ? this.props.routeInfo?.pathname
2407
1711
  : this.state.tabs[child.props.tab].currentHref;
2408
1712
  const routeOptions = child.props.tab === activeTab
2409
1713
  ? this.props.routeInfo?.routeOptions
@@ -2528,6 +1832,20 @@ class IonRoute extends React.PureComponent {
2528
1832
  }
2529
1833
  }
2530
1834
 
1835
+ class IonRedirect extends React.PureComponent {
1836
+ render() {
1837
+ const IonRedirectInner = this.context.getIonRedirect();
1838
+ if (!this.context.hasIonicRouter() || !IonRedirect) {
1839
+ console.error('You either do not have an Ionic Router package, or your router does not support using <IonRedirect>');
1840
+ return null;
1841
+ }
1842
+ return jsx(IonRedirectInner, { ...this.props });
1843
+ }
1844
+ static get contextType() {
1845
+ return NavContext;
1846
+ }
1847
+ }
1848
+
2531
1849
  const IonRouterContext = React.createContext({
2532
1850
  routeInfo: undefined, // TODO(FW-2959): type
2533
1851
  push: () => {
@@ -2536,9 +1854,6 @@ const IonRouterContext = React.createContext({
2536
1854
  back: () => {
2537
1855
  throw new Error('An Ionic Router is required for IonRouterContext');
2538
1856
  },
2539
- navigateRoot: () => {
2540
- throw new Error('An Ionic Router is required for IonRouterContext');
2541
- },
2542
1857
  canGoBack: () => {
2543
1858
  throw new Error('An Ionic Router is required for IonRouterContext');
2544
1859
  },
@@ -2555,10 +1870,9 @@ function useIonRouter() {
2555
1870
  back: context.back,
2556
1871
  push: context.push,
2557
1872
  goBack: context.back,
2558
- navigateRoot: context.navigateRoot,
2559
1873
  canGoBack: context.canGoBack,
2560
1874
  routeInfo: context.routeInfo,
2561
- }), [context.back, context.push, context.navigateRoot, context.canGoBack, context.routeInfo]);
1875
+ }), [context.back, context.push, context.canGoBack, context.routeInfo]);
2562
1876
  }
2563
1877
 
2564
1878
  class CreateAnimation extends React.PureComponent {
@@ -2712,7 +2026,7 @@ function useController(displayName, controller, defineCustomElement) {
2712
2026
  * @returns Returns the present and dismiss methods in an array
2713
2027
  */
2714
2028
  function useIonActionSheet() {
2715
- const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1b);
2029
+ const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1d);
2716
2030
  const present = useCallback((buttonsOrOptions, header) => {
2717
2031
  if (Array.isArray(buttonsOrOptions)) {
2718
2032
  return controller.present({
@@ -2732,7 +2046,7 @@ function useIonActionSheet() {
2732
2046
  * @returns Returns the present and dismiss methods in an array
2733
2047
  */
2734
2048
  function useIonAlert() {
2735
- const controller = useController('IonAlert', alertController, defineCustomElement$18);
2049
+ const controller = useController('IonAlert', alertController, defineCustomElement$19);
2736
2050
  const present = useCallback((messageOrOptions, buttons) => {
2737
2051
  if (typeof messageOrOptions === 'string') {
2738
2052
  return controller.present({
@@ -2752,7 +2066,7 @@ function useIonAlert() {
2752
2066
  * @returns Returns the present and dismiss methods in an array
2753
2067
  */
2754
2068
  function useIonToast() {
2755
- const controller = useController('IonToast', toastController, defineCustomElement$1a);
2069
+ const controller = useController('IonToast', toastController, defineCustomElement$1b);
2756
2070
  const present = useCallback((messageOrOptions, duration) => {
2757
2071
  if (typeof messageOrOptions === 'string') {
2758
2072
  return controller.present({
@@ -2838,7 +2152,7 @@ function useOverlay(displayName, controller, defineCustomElement, component, com
2838
2152
  * @returns Returns the present and dismiss methods in an array
2839
2153
  */
2840
2154
  function useIonModal(component, componentProps) {
2841
- const controller = useOverlay('IonModal', modalController, defineCustomElement$1c, component, componentProps);
2155
+ const controller = useOverlay('IonModal', modalController, defineCustomElement$1e, component, componentProps);
2842
2156
  const present = useCallback((options = {}) => {
2843
2157
  controller.present(options);
2844
2158
  }, [controller.present]);
@@ -2853,19 +2167,40 @@ function useIonModal(component, componentProps) {
2853
2167
  * @returns Returns the present and dismiss methods in an array
2854
2168
  */
2855
2169
  function useIonPopover(component, componentProps) {
2856
- const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1d, component, componentProps);
2170
+ const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1f, component, componentProps);
2857
2171
  const present = useCallback((options = {}) => {
2858
2172
  controller.present(options);
2859
2173
  }, [controller.present]);
2860
2174
  return [present, controller.dismiss];
2861
2175
  }
2862
2176
 
2177
+ /**
2178
+ * A hook for presenting/dismissing an IonPicker component
2179
+ * @returns Returns the present and dismiss methods in an array
2180
+ * @deprecated Use the inline ion-picker component instead.
2181
+ */
2182
+ function useIonPicker() {
2183
+ const controller = useController('IonPicker', pickerController, defineCustomElement$1c);
2184
+ const present = useCallback((columnsOrOptions, buttons) => {
2185
+ if (Array.isArray(columnsOrOptions)) {
2186
+ return controller.present({
2187
+ columns: columnsOrOptions,
2188
+ buttons: buttons ?? [{ text: 'Ok' }],
2189
+ });
2190
+ }
2191
+ else {
2192
+ return controller.present(columnsOrOptions);
2193
+ }
2194
+ }, [controller.present]);
2195
+ return [present, controller.dismiss];
2196
+ }
2197
+
2863
2198
  /**
2864
2199
  * A hook for presenting/dismissing an IonLoading component
2865
2200
  * @returns Returns the present and dismiss methods in an array
2866
2201
  */
2867
2202
  function useIonLoading() {
2868
- const controller = useController('IonLoading', loadingController, defineCustomElement$19);
2203
+ const controller = useController('IonLoading', loadingController, defineCustomElement$1a);
2869
2204
  const present = useCallback((messageOrOptions = {}, duration, spinner) => {
2870
2205
  if (typeof messageOrOptions === 'string') {
2871
2206
  return controller.present({
@@ -2907,7 +2242,6 @@ const RouteManagerContext = /*@__PURE__*/ React.createContext({
2907
2242
  findLeavingViewItemByRouteInfo: () => undefined,
2908
2243
  findViewItemByRouteInfo: () => undefined,
2909
2244
  getChildrenToRender: () => undefined,
2910
- getViewItemsForOutlet: () => [],
2911
2245
  goBack: () => undefined,
2912
2246
  unMountViewItem: () => undefined,
2913
2247
  });
@@ -3026,14 +2360,7 @@ class LocationHistory {
3026
2360
  _replace(routeInfo) {
3027
2361
  const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
3028
2362
  routeInfos && routeInfos.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
- }
2363
+ this.locationHistory.pop();
3037
2364
  this._add(routeInfo);
3038
2365
  }
3039
2366
  _clear() {
@@ -3065,20 +2392,6 @@ class LocationHistory {
3065
2392
  }
3066
2393
  return undefined;
3067
2394
  }
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
- }
3082
2395
  findLastLocation(routeInfo) {
3083
2396
  const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
3084
2397
  if (routeInfos) {
@@ -3110,17 +2423,6 @@ class LocationHistory {
3110
2423
  canGoBack() {
3111
2424
  return this.locationHistory.length > 1;
3112
2425
  }
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
- }
3124
2426
  }
3125
2427
 
3126
2428
  class NavManager extends React.PureComponent {
@@ -3133,9 +2435,6 @@ class NavManager extends React.PureComponent {
3133
2435
  back: (animationBuilder) => {
3134
2436
  this.goBack(undefined, animationBuilder);
3135
2437
  },
3136
- navigateRoot: (pathname, animationBuilder) => {
3137
- this.props.onNavigateRoot(pathname, animationBuilder);
3138
- },
3139
2438
  canGoBack: () => this.props.locationHistory.canGoBack(),
3140
2439
  nativeBack: () => this.props.onNativeBack(),
3141
2440
  routeInfo: this.props.routeInfo,
@@ -3144,8 +2443,10 @@ class NavManager extends React.PureComponent {
3144
2443
  goBack: this.goBack.bind(this),
3145
2444
  hasIonicRouter: () => true,
3146
2445
  navigate: this.navigate.bind(this),
2446
+ getIonRedirect: this.getIonRedirect.bind(this),
3147
2447
  getIonRoute: this.getIonRoute.bind(this),
3148
2448
  getStackManager: this.getStackManager.bind(this),
2449
+ getPageManager: this.getPageManager.bind(this),
3149
2450
  routeInfo: this.props.routeInfo,
3150
2451
  setCurrentTab: this.props.onSetCurrentTab,
3151
2452
  changeTab: this.props.onChangeTab,
@@ -3178,6 +2479,12 @@ class NavManager extends React.PureComponent {
3178
2479
  navigate(path, direction = 'forward', action = 'push', animationBuilder, options, tab) {
3179
2480
  this.props.onNavigate(path, action, direction, animationBuilder, options, tab);
3180
2481
  }
2482
+ getPageManager() {
2483
+ return PageManager;
2484
+ }
2485
+ getIonRedirect() {
2486
+ return this.props.ionRedirect;
2487
+ }
3181
2488
  getIonRoute() {
3182
2489
  return this.props.ionRoute;
3183
2490
  }
@@ -3207,7 +2514,10 @@ class ViewStacks {
3207
2514
  }
3208
2515
  }
3209
2516
  clear(outletId) {
3210
- delete this.viewStacks[outletId];
2517
+ // Give some time for the leaving views to transition before removing
2518
+ return setTimeout(() => {
2519
+ delete this.viewStacks[outletId];
2520
+ }, 500);
3211
2521
  }
3212
2522
  getViewItemsForOutlet(outletId) {
3213
2523
  return this.viewStacks[outletId] || [];
@@ -3236,5 +2546,5 @@ class ViewStacks {
3236
2546
  }
3237
2547
  }
3238
2548
 
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 };
2549
+ 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, 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 };
3240
2550
  //# sourceMappingURL=index.js.map