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