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