@ionic/react 8.8.12-dev.11781793379.156d3260 → 8.8.12-dev.11782342444.186b6e9c
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/css/core.css +1 -1
- package/css/core.css.map +1 -1
- package/css/display.css +1 -1
- package/css/display.css.map +1 -1
- package/css/flex-utils.css +1 -1
- package/css/flex-utils.css.map +1 -1
- package/css/float-elements.css.map +1 -1
- package/css/global.bundle.css.map +1 -1
- package/css/ionic-swiper.css +1 -1
- package/css/ionic-swiper.css.map +1 -1
- package/css/ionic.bundle.css +1 -1
- package/css/ionic.bundle.css.map +1 -1
- package/css/normalize.css.map +1 -1
- package/css/padding.css.map +1 -1
- package/css/palettes/dark.always.css.map +1 -1
- package/css/palettes/dark.class.css.map +1 -1
- package/css/palettes/dark.system.css.map +1 -1
- package/css/palettes/high-contrast-dark.always.css.map +1 -1
- package/css/palettes/high-contrast-dark.class.css.map +1 -1
- package/css/palettes/high-contrast-dark.system.css.map +1 -1
- package/css/palettes/high-contrast.always.css.map +1 -1
- package/css/palettes/high-contrast.class.css.map +1 -1
- package/css/palettes/high-contrast.system.css.map +1 -1
- package/css/structure.css.map +1 -1
- package/css/text-alignment.css.map +1 -1
- package/css/text-transformation.css.map +1 -1
- package/css/typography.css.map +1 -1
- package/css/utils.bundle.css +1 -1
- package/css/utils.bundle.css.map +1 -1
- package/dist/index.js +1007 -321
- 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 +1 -0
- package/dist/types/components/IonToast.d.ts +1 -1
- package/dist/types/components/components.d.ts +326 -0
- package/dist/types/components/createInlineOverlayComponent.d.ts +1 -1
- package/dist/types/components/createRoutingComponent.d.ts +1 -1
- package/dist/types/components/index.d.ts +2 -5
- package/dist/types/components/navigation/IonNav.d.ts +2 -1
- package/dist/types/components/navigation/IonTabBar.d.ts +1 -1
- package/dist/types/components/navigation/IonTabs.d.ts +1 -2
- package/dist/types/components/react-component-lib/createComponent.d.ts +1 -1
- package/dist/types/components/react-component-lib/utils/index.d.ts +1 -1
- package/dist/types/components/routing-proxies.d.ts +7 -7
- package/dist/types/components/utils/index.d.ts +2 -11
- package/dist/types/contexts/NavContext.d.ts +0 -2
- package/dist/types/lifecycle/IonLifeCycleHOC.d.ts +1 -3
- package/dist/types/routing/LocationHistory.d.ts +7 -0
- package/dist/types/routing/NavManager.d.ts +2 -4
- package/dist/types/routing/OutletPageManager.d.ts +2 -0
- package/dist/types/routing/PageManager.d.ts +8 -0
- package/dist/types/routing/RouteManagerContext.d.ts +6 -1
- package/dist/types/routing/ViewLifeCycleManager.d.ts +1 -0
- package/dist/types/routing/ViewStacks.d.ts +2 -2
- package/package.json +8 -8
- package/css/ionic/bundle.ionic.css +0 -1
- package/css/ionic/bundle.ionic.css.map +0 -1
- package/css/ionic/core.ionic.css +0 -1
- package/css/ionic/core.ionic.css.map +0 -1
- package/css/ionic/global.bundle.ionic.css +0 -1
- package/css/ionic/global.bundle.ionic.css.map +0 -1
- package/css/ionic/ionic-swiper.ionic.css +0 -1
- package/css/ionic/ionic-swiper.ionic.css.map +0 -1
- package/css/ionic/link.ionic.css +0 -1
- package/css/ionic/link.ionic.css.map +0 -1
- package/css/ionic/structure.ionic.css +0 -1
- package/css/ionic/structure.ionic.css.map +0 -1
- package/css/ionic/typography.ionic.css +0 -1
- package/css/ionic/typography.ionic.css.map +0 -1
- package/css/ionic/utils.bundle.ionic.css +0 -1
- package/css/ionic/utils.bundle.ionic.css.map +0 -1
- package/dist/types/components/IonPickerLegacy.d.ts +0 -2
- package/dist/types/components/IonRedirect.d.ts +0 -16
- package/dist/types/components/proxies.d.ts +0 -76
- package/dist/types/hooks/useIonPicker.d.ts +0 -27
package/dist/index.js
CHANGED
|
@@ -1,83 +1,80 @@
|
|
|
1
1
|
import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
|
|
2
2
|
import React, { useContext, useRef, useEffect, createElement, useState, useMemo, Fragment as Fragment$1, useCallback } from 'react';
|
|
3
|
-
import { isPlatform as isPlatform$1, getPlatforms as getPlatforms$1, componentOnReady, createAnimation, actionSheetController, alertController, toastController, modalController, popoverController,
|
|
3
|
+
import { isPlatform as isPlatform$1, getPlatforms as getPlatforms$1, componentOnReady, createAnimation, actionSheetController, alertController, toastController, modalController, popoverController, loadingController, initialize } from '@ionic/core/components';
|
|
4
4
|
export { IonicSafeString, IonicSlides, createAnimation, createGesture, getIonPageElement, getTimeGivenProgression, iosTransitionAnimation, mdTransitionAnimation, openURL } from '@ionic/core/components';
|
|
5
|
-
import
|
|
6
|
-
import { defineCustomElement as defineCustomElement$
|
|
7
|
-
import { defineCustomElement as defineCustomElement$
|
|
8
|
-
import { defineCustomElement as defineCustomElement$3 } from '@ionic/core/components/ion-avatar.js';
|
|
9
|
-
import { defineCustomElement as defineCustomElement$4 } from '@ionic/core/components/ion-backdrop.js';
|
|
10
|
-
import { defineCustomElement as defineCustomElement$5 } from '@ionic/core/components/ion-badge.js';
|
|
11
|
-
import { defineCustomElement as defineCustomElement$6 } from '@ionic/core/components/ion-breadcrumbs.js';
|
|
12
|
-
import { defineCustomElement as defineCustomElement$7 } from '@ionic/core/components/ion-buttons.js';
|
|
13
|
-
import { defineCustomElement as defineCustomElement$8 } from '@ionic/core/components/ion-card-content.js';
|
|
14
|
-
import { defineCustomElement as defineCustomElement$9 } from '@ionic/core/components/ion-card-header.js';
|
|
15
|
-
import { defineCustomElement as defineCustomElement$a } from '@ionic/core/components/ion-card-subtitle.js';
|
|
16
|
-
import { defineCustomElement as defineCustomElement$b } from '@ionic/core/components/ion-card-title.js';
|
|
17
|
-
import { defineCustomElement as defineCustomElement$c } from '@ionic/core/components/ion-checkbox.js';
|
|
18
|
-
import { defineCustomElement as defineCustomElement$d } from '@ionic/core/components/ion-chip.js';
|
|
19
|
-
import { defineCustomElement as defineCustomElement$e } from '@ionic/core/components/ion-col.js';
|
|
20
|
-
import { defineCustomElement as defineCustomElement$f } from '@ionic/core/components/ion-content.js';
|
|
21
|
-
import { defineCustomElement as defineCustomElement$
|
|
22
|
-
import { defineCustomElement as defineCustomElement$
|
|
23
|
-
import { defineCustomElement as defineCustomElement$
|
|
24
|
-
import { defineCustomElement as defineCustomElement$
|
|
25
|
-
import { defineCustomElement as defineCustomElement$k } from '@ionic/core/components/ion-
|
|
26
|
-
import { defineCustomElement as defineCustomElement$l } from '@ionic/core/components/ion-
|
|
27
|
-
import { defineCustomElement as defineCustomElement$m } from '@ionic/core/components/ion-
|
|
28
|
-
import { defineCustomElement as defineCustomElement$n } from '@ionic/core/components/ion-
|
|
29
|
-
import { defineCustomElement as defineCustomElement$
|
|
30
|
-
import { defineCustomElement as defineCustomElement$
|
|
31
|
-
import { defineCustomElement as defineCustomElement$
|
|
32
|
-
import { defineCustomElement as defineCustomElement$
|
|
33
|
-
import { defineCustomElement as defineCustomElement$
|
|
34
|
-
import { defineCustomElement as defineCustomElement$t } from '@ionic/core/components/ion-
|
|
35
|
-
import { defineCustomElement as defineCustomElement$u } from '@ionic/core/components/ion-
|
|
36
|
-
import { defineCustomElement as defineCustomElement$v } from '@ionic/core/components/ion-
|
|
37
|
-
import { defineCustomElement as defineCustomElement$w } from '@ionic/core/components/ion-item-
|
|
38
|
-
import { defineCustomElement as defineCustomElement$x } from '@ionic/core/components/ion-
|
|
39
|
-
import { defineCustomElement as defineCustomElement$
|
|
40
|
-
import { defineCustomElement as defineCustomElement$
|
|
41
|
-
import { defineCustomElement as defineCustomElement$
|
|
42
|
-
import { defineCustomElement as defineCustomElement$
|
|
43
|
-
import { defineCustomElement as defineCustomElement$
|
|
44
|
-
import { defineCustomElement as defineCustomElement$D } from '@ionic/core/components/ion-
|
|
45
|
-
import { defineCustomElement as defineCustomElement$
|
|
46
|
-
import { defineCustomElement as defineCustomElement$
|
|
47
|
-
import { defineCustomElement as defineCustomElement$
|
|
48
|
-
import { defineCustomElement as defineCustomElement$G } from '@ionic/core/components/ion-
|
|
49
|
-
import { defineCustomElement as defineCustomElement$
|
|
50
|
-
import { defineCustomElement as defineCustomElement$I } from '@ionic/core/components/ion-
|
|
51
|
-
import { defineCustomElement as defineCustomElement$
|
|
52
|
-
import { defineCustomElement as defineCustomElement$
|
|
53
|
-
import { defineCustomElement as defineCustomElement$L } from '@ionic/core/components/ion-
|
|
54
|
-
import { defineCustomElement as defineCustomElement$
|
|
55
|
-
import { defineCustomElement as defineCustomElement$
|
|
56
|
-
import { defineCustomElement as defineCustomElement$
|
|
57
|
-
import { defineCustomElement as defineCustomElement$
|
|
58
|
-
import { defineCustomElement as defineCustomElement$Q } from '@ionic/core/components/ion-
|
|
59
|
-
import { defineCustomElement as defineCustomElement$R } from '@ionic/core/components/ion-
|
|
60
|
-
import { defineCustomElement as defineCustomElement$S } from '@ionic/core/components/ion-
|
|
61
|
-
import { defineCustomElement as defineCustomElement$
|
|
62
|
-
import { defineCustomElement as defineCustomElement$
|
|
63
|
-
import { defineCustomElement as defineCustomElement$
|
|
64
|
-
import { defineCustomElement as defineCustomElement$
|
|
65
|
-
import { defineCustomElement as defineCustomElement$
|
|
66
|
-
import { defineCustomElement as defineCustomElement$
|
|
67
|
-
import { defineCustomElement as defineCustomElement$
|
|
68
|
-
import { defineCustomElement as defineCustomElement$_ } from '@ionic/core/components/ion-
|
|
69
|
-
import { defineCustomElement as defineCustomElement$$ } from '@ionic/core/components/ion-
|
|
70
|
-
import { defineCustomElement as defineCustomElement$10 } from '@ionic/core/components/ion-
|
|
71
|
-
import { defineCustomElement as defineCustomElement$11 } from '@ionic/core/components/ion-
|
|
72
|
-
import { defineCustomElement as defineCustomElement$12 } from '@ionic/core/components/ion-
|
|
73
|
-
import { defineCustomElement as defineCustomElement$13 } from '@ionic/core/components/ion-
|
|
74
|
-
import { defineCustomElement as defineCustomElement$14 } from '@ionic/core/components/ion-
|
|
75
|
-
import { defineCustomElement as defineCustomElement$15 } from '@ionic/core/components/ion-
|
|
76
|
-
import { defineCustomElement as defineCustomElement$16 } from '@ionic/core/components/ion-
|
|
77
|
-
import { defineCustomElement as defineCustomElement$17 } from '@ionic/core/components/ion-
|
|
78
|
-
import { defineCustomElement as defineCustomElement$18 } from '@ionic/core/components/ion-title.js';
|
|
79
|
-
import { defineCustomElement as defineCustomElement$19 } from '@ionic/core/components/ion-toggle.js';
|
|
80
|
-
import { defineCustomElement as defineCustomElement$1a } from '@ionic/core/components/ion-toolbar.js';
|
|
5
|
+
import { createComponent } from '@stencil/react-output-target/runtime';
|
|
6
|
+
import { IonAccordionGroup as IonAccordionGroup$1, defineCustomElement as defineCustomElement$2 } from '@ionic/core/components/ion-accordion-group.js';
|
|
7
|
+
import { IonAccordion as IonAccordion$1, defineCustomElement as defineCustomElement$1 } from '@ionic/core/components/ion-accordion.js';
|
|
8
|
+
import { IonAvatar as IonAvatar$1, defineCustomElement as defineCustomElement$3 } from '@ionic/core/components/ion-avatar.js';
|
|
9
|
+
import { IonBackdrop as IonBackdrop$1, defineCustomElement as defineCustomElement$4 } from '@ionic/core/components/ion-backdrop.js';
|
|
10
|
+
import { IonBadge as IonBadge$1, defineCustomElement as defineCustomElement$5 } from '@ionic/core/components/ion-badge.js';
|
|
11
|
+
import { IonBreadcrumbs as IonBreadcrumbs$1, defineCustomElement as defineCustomElement$6 } from '@ionic/core/components/ion-breadcrumbs.js';
|
|
12
|
+
import { IonButtons as IonButtons$1, defineCustomElement as defineCustomElement$7 } from '@ionic/core/components/ion-buttons.js';
|
|
13
|
+
import { IonCardContent as IonCardContent$1, defineCustomElement as defineCustomElement$8 } from '@ionic/core/components/ion-card-content.js';
|
|
14
|
+
import { IonCardHeader as IonCardHeader$1, defineCustomElement as defineCustomElement$9 } from '@ionic/core/components/ion-card-header.js';
|
|
15
|
+
import { IonCardSubtitle as IonCardSubtitle$1, defineCustomElement as defineCustomElement$a } from '@ionic/core/components/ion-card-subtitle.js';
|
|
16
|
+
import { IonCardTitle as IonCardTitle$1, defineCustomElement as defineCustomElement$b } from '@ionic/core/components/ion-card-title.js';
|
|
17
|
+
import { IonCheckbox as IonCheckbox$1, defineCustomElement as defineCustomElement$c } from '@ionic/core/components/ion-checkbox.js';
|
|
18
|
+
import { IonChip as IonChip$1, defineCustomElement as defineCustomElement$d } from '@ionic/core/components/ion-chip.js';
|
|
19
|
+
import { IonCol as IonCol$1, defineCustomElement as defineCustomElement$e } from '@ionic/core/components/ion-col.js';
|
|
20
|
+
import { IonContent as IonContent$1, defineCustomElement as defineCustomElement$f } from '@ionic/core/components/ion-content.js';
|
|
21
|
+
import { IonDatetimeButton as IonDatetimeButton$1, defineCustomElement as defineCustomElement$h } from '@ionic/core/components/ion-datetime-button.js';
|
|
22
|
+
import { IonDatetime as IonDatetime$1, defineCustomElement as defineCustomElement$g } from '@ionic/core/components/ion-datetime.js';
|
|
23
|
+
import { IonFabList as IonFabList$1, defineCustomElement as defineCustomElement$j } from '@ionic/core/components/ion-fab-list.js';
|
|
24
|
+
import { IonFab as IonFab$1, defineCustomElement as defineCustomElement$i } from '@ionic/core/components/ion-fab.js';
|
|
25
|
+
import { IonFooter as IonFooter$1, defineCustomElement as defineCustomElement$k } from '@ionic/core/components/ion-footer.js';
|
|
26
|
+
import { IonGrid as IonGrid$1, defineCustomElement as defineCustomElement$l } from '@ionic/core/components/ion-grid.js';
|
|
27
|
+
import { IonHeader as IonHeader$1, defineCustomElement as defineCustomElement$m } from '@ionic/core/components/ion-header.js';
|
|
28
|
+
import { IonImg as IonImg$1, defineCustomElement as defineCustomElement$n } from '@ionic/core/components/ion-img.js';
|
|
29
|
+
import { IonInfiniteScrollContent as IonInfiniteScrollContent$1, defineCustomElement as defineCustomElement$p } from '@ionic/core/components/ion-infinite-scroll-content.js';
|
|
30
|
+
import { IonInfiniteScroll as IonInfiniteScroll$1, defineCustomElement as defineCustomElement$o } from '@ionic/core/components/ion-infinite-scroll.js';
|
|
31
|
+
import { IonInputOtp as IonInputOtp$1, defineCustomElement as defineCustomElement$r } from '@ionic/core/components/ion-input-otp.js';
|
|
32
|
+
import { IonInputPasswordToggle as IonInputPasswordToggle$1, defineCustomElement as defineCustomElement$s } from '@ionic/core/components/ion-input-password-toggle.js';
|
|
33
|
+
import { IonInput as IonInput$1, defineCustomElement as defineCustomElement$q } from '@ionic/core/components/ion-input.js';
|
|
34
|
+
import { IonItemDivider as IonItemDivider$1, defineCustomElement as defineCustomElement$t } from '@ionic/core/components/ion-item-divider.js';
|
|
35
|
+
import { IonItemGroup as IonItemGroup$1, defineCustomElement as defineCustomElement$u } from '@ionic/core/components/ion-item-group.js';
|
|
36
|
+
import { IonItemOptions as IonItemOptions$1, defineCustomElement as defineCustomElement$v } from '@ionic/core/components/ion-item-options.js';
|
|
37
|
+
import { IonItemSliding as IonItemSliding$1, defineCustomElement as defineCustomElement$w } from '@ionic/core/components/ion-item-sliding.js';
|
|
38
|
+
import { IonLabel as IonLabel$1, defineCustomElement as defineCustomElement$x } from '@ionic/core/components/ion-label.js';
|
|
39
|
+
import { IonListHeader as IonListHeader$1, defineCustomElement as defineCustomElement$z } from '@ionic/core/components/ion-list-header.js';
|
|
40
|
+
import { IonList as IonList$1, defineCustomElement as defineCustomElement$y } from '@ionic/core/components/ion-list.js';
|
|
41
|
+
import { IonMenuButton as IonMenuButton$1, defineCustomElement as defineCustomElement$B } from '@ionic/core/components/ion-menu-button.js';
|
|
42
|
+
import { IonMenuToggle as IonMenuToggle$1, defineCustomElement as defineCustomElement$C } from '@ionic/core/components/ion-menu-toggle.js';
|
|
43
|
+
import { IonMenu as IonMenu$1, defineCustomElement as defineCustomElement$A } from '@ionic/core/components/ion-menu.js';
|
|
44
|
+
import { IonNavLink as IonNavLink$1, defineCustomElement as defineCustomElement$D } from '@ionic/core/components/ion-nav-link.js';
|
|
45
|
+
import { defineCustomElement as defineCustomElement$1l } from '@ionic/core/components/ion-nav.js';
|
|
46
|
+
import { IonNote as IonNote$1, defineCustomElement as defineCustomElement$E } from '@ionic/core/components/ion-note.js';
|
|
47
|
+
import { IonPickerColumnOption as IonPickerColumnOption$1, defineCustomElement as defineCustomElement$H } from '@ionic/core/components/ion-picker-column-option.js';
|
|
48
|
+
import { IonPickerColumn as IonPickerColumn$1, defineCustomElement as defineCustomElement$G } from '@ionic/core/components/ion-picker-column.js';
|
|
49
|
+
import { IonPicker as IonPicker$1, defineCustomElement as defineCustomElement$F } from '@ionic/core/components/ion-picker.js';
|
|
50
|
+
import { IonProgressBar as IonProgressBar$1, defineCustomElement as defineCustomElement$I } from '@ionic/core/components/ion-progress-bar.js';
|
|
51
|
+
import { IonRadioGroup as IonRadioGroup$1, defineCustomElement as defineCustomElement$K } from '@ionic/core/components/ion-radio-group.js';
|
|
52
|
+
import { IonRadio as IonRadio$1, defineCustomElement as defineCustomElement$J } from '@ionic/core/components/ion-radio.js';
|
|
53
|
+
import { IonRange as IonRange$1, defineCustomElement as defineCustomElement$L } from '@ionic/core/components/ion-range.js';
|
|
54
|
+
import { IonRefresherContent as IonRefresherContent$1, defineCustomElement as defineCustomElement$N } from '@ionic/core/components/ion-refresher-content.js';
|
|
55
|
+
import { IonRefresher as IonRefresher$1, defineCustomElement as defineCustomElement$M } from '@ionic/core/components/ion-refresher.js';
|
|
56
|
+
import { IonReorderGroup as IonReorderGroup$1, defineCustomElement as defineCustomElement$P } from '@ionic/core/components/ion-reorder-group.js';
|
|
57
|
+
import { IonReorder as IonReorder$1, defineCustomElement as defineCustomElement$O } from '@ionic/core/components/ion-reorder.js';
|
|
58
|
+
import { IonRippleEffect as IonRippleEffect$1, defineCustomElement as defineCustomElement$Q } from '@ionic/core/components/ion-ripple-effect.js';
|
|
59
|
+
import { IonRow as IonRow$1, defineCustomElement as defineCustomElement$R } from '@ionic/core/components/ion-row.js';
|
|
60
|
+
import { IonSearchbar as IonSearchbar$1, defineCustomElement as defineCustomElement$S } from '@ionic/core/components/ion-searchbar.js';
|
|
61
|
+
import { IonSegmentButton as IonSegmentButton$1, defineCustomElement as defineCustomElement$U } from '@ionic/core/components/ion-segment-button.js';
|
|
62
|
+
import { IonSegmentContent as IonSegmentContent$1, defineCustomElement as defineCustomElement$V } from '@ionic/core/components/ion-segment-content.js';
|
|
63
|
+
import { IonSegmentView as IonSegmentView$1, defineCustomElement as defineCustomElement$W } from '@ionic/core/components/ion-segment-view.js';
|
|
64
|
+
import { IonSegment as IonSegment$1, defineCustomElement as defineCustomElement$T } from '@ionic/core/components/ion-segment.js';
|
|
65
|
+
import { IonSelectModal as IonSelectModal$1, defineCustomElement as defineCustomElement$Y } from '@ionic/core/components/ion-select-modal.js';
|
|
66
|
+
import { IonSelectOption as IonSelectOption$1, defineCustomElement as defineCustomElement$Z } from '@ionic/core/components/ion-select-option.js';
|
|
67
|
+
import { IonSelect as IonSelect$1, defineCustomElement as defineCustomElement$X } from '@ionic/core/components/ion-select.js';
|
|
68
|
+
import { IonSkeletonText as IonSkeletonText$1, defineCustomElement as defineCustomElement$_ } from '@ionic/core/components/ion-skeleton-text.js';
|
|
69
|
+
import { IonSpinner as IonSpinner$1, defineCustomElement as defineCustomElement$$ } from '@ionic/core/components/ion-spinner.js';
|
|
70
|
+
import { IonSplitPane as IonSplitPane$1, defineCustomElement as defineCustomElement$10 } from '@ionic/core/components/ion-split-pane.js';
|
|
71
|
+
import { IonTab as IonTab$1, defineCustomElement as defineCustomElement$11 } from '@ionic/core/components/ion-tab.js';
|
|
72
|
+
import { IonText as IonText$1, defineCustomElement as defineCustomElement$12 } from '@ionic/core/components/ion-text.js';
|
|
73
|
+
import { IonTextarea as IonTextarea$1, defineCustomElement as defineCustomElement$13 } from '@ionic/core/components/ion-textarea.js';
|
|
74
|
+
import { IonThumbnail as IonThumbnail$1, defineCustomElement as defineCustomElement$14 } from '@ionic/core/components/ion-thumbnail.js';
|
|
75
|
+
import { IonTitle as IonTitle$1, defineCustomElement as defineCustomElement$15 } from '@ionic/core/components/ion-title.js';
|
|
76
|
+
import { IonToggle as IonToggle$1, defineCustomElement as defineCustomElement$16 } from '@ionic/core/components/ion-toggle.js';
|
|
77
|
+
import { IonToolbar as IonToolbar$1, defineCustomElement as defineCustomElement$17 } from '@ionic/core/components/ion-toolbar.js';
|
|
81
78
|
import { IonBreadcrumb as IonBreadcrumb$1 } from '@ionic/core/components/ion-breadcrumb.js';
|
|
82
79
|
import { IonButton as IonButton$1 } from '@ionic/core/components/ion-button.js';
|
|
83
80
|
import { IonCard as IonCard$1 } from '@ionic/core/components/ion-card.js';
|
|
@@ -85,20 +82,20 @@ import { IonFabButton as IonFabButton$1 } from '@ionic/core/components/ion-fab-b
|
|
|
85
82
|
import { IonItemOption as IonItemOption$1 } from '@ionic/core/components/ion-item-option.js';
|
|
86
83
|
import { IonItem as IonItem$1 } from '@ionic/core/components/ion-item.js';
|
|
87
84
|
import { IonRouterLink as IonRouterLink$1 } from '@ionic/core/components/ion-router-link.js';
|
|
88
|
-
import { defineCustomElement as defineCustomElement$
|
|
89
|
-
import {
|
|
90
|
-
import { defineCustomElement as defineCustomElement$
|
|
91
|
-
import { defineCustomElement as defineCustomElement$
|
|
92
|
-
import { defineCustomElement as defineCustomElement$
|
|
93
|
-
import { defineCustomElement as defineCustomElement$
|
|
94
|
-
import { defineCustomElement as defineCustomElement$
|
|
95
|
-
import { defineCustomElement as defineCustomElement$
|
|
96
|
-
import { defineCustomElement as defineCustomElement$
|
|
97
|
-
import { defineCustomElement as defineCustomElement$
|
|
98
|
-
import { defineCustomElement as defineCustomElement$
|
|
99
|
-
import { defineCustomElement as defineCustomElement$
|
|
100
|
-
import { defineCustomElement as defineCustomElement$
|
|
101
|
-
import { defineCustomElement as defineCustomElement$
|
|
85
|
+
import { defineCustomElement as defineCustomElement$18 } from '@ionic/core/components/ion-alert.js';
|
|
86
|
+
import ReactDOM, { createPortal } from 'react-dom';
|
|
87
|
+
import { defineCustomElement as defineCustomElement$19 } from '@ionic/core/components/ion-loading.js';
|
|
88
|
+
import { defineCustomElement as defineCustomElement$1a } from '@ionic/core/components/ion-toast.js';
|
|
89
|
+
import { defineCustomElement as defineCustomElement$1b } from '@ionic/core/components/ion-action-sheet.js';
|
|
90
|
+
import { defineCustomElement as defineCustomElement$1c } from '@ionic/core/components/ion-modal.js';
|
|
91
|
+
import { defineCustomElement as defineCustomElement$1d } from '@ionic/core/components/ion-popover.js';
|
|
92
|
+
import { defineCustomElement as defineCustomElement$1j } from '@ionic/core/components/ion-app.js';
|
|
93
|
+
import { defineCustomElement as defineCustomElement$1h } from '@ionic/core/components/ion-back-button.js';
|
|
94
|
+
import { defineCustomElement as defineCustomElement$1i } from '@ionic/core/components/ion-router-outlet.js';
|
|
95
|
+
import { defineCustomElement as defineCustomElement$1f } from '@ionic/core/components/ion-tab-bar.js';
|
|
96
|
+
import { defineCustomElement as defineCustomElement$1e } from '@ionic/core/components/ion-tab-button.js';
|
|
97
|
+
import { defineCustomElement as defineCustomElement$1g } from '@ionic/core/components/ion-tabs.js';
|
|
98
|
+
import { defineCustomElement as defineCustomElement$1k } from 'ionicons/components/ion-icon.js';
|
|
102
99
|
|
|
103
100
|
const IonLifeCycleContext = /*@__PURE__*/ React.createContext({
|
|
104
101
|
onIonViewWillEnter: () => {
|
|
@@ -383,9 +380,7 @@ const useIonViewDidLeave = (callback, deps = []) => {
|
|
|
383
380
|
};
|
|
384
381
|
|
|
385
382
|
const NavContext = /*@__PURE__*/ React.createContext({
|
|
386
|
-
getIonRedirect: () => undefined,
|
|
387
383
|
getIonRoute: () => undefined,
|
|
388
|
-
getPageManager: () => undefined,
|
|
389
384
|
getStackManager: () => undefined,
|
|
390
385
|
goBack: (route) => {
|
|
391
386
|
if (typeof window !== 'undefined') {
|
|
@@ -417,6 +412,699 @@ const NavContext = /*@__PURE__*/ React.createContext({
|
|
|
417
412
|
},
|
|
418
413
|
});
|
|
419
414
|
|
|
415
|
+
const IonAccordion =
|
|
416
|
+
/*@__PURE__*/ createComponent({
|
|
417
|
+
tagName: 'ion-accordion',
|
|
418
|
+
elementClass: IonAccordion$1,
|
|
419
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
420
|
+
react: React,
|
|
421
|
+
events: {},
|
|
422
|
+
defineCustomElement: defineCustomElement$1,
|
|
423
|
+
});
|
|
424
|
+
const IonAccordionGroup = /*@__PURE__*/ createComponent({
|
|
425
|
+
tagName: 'ion-accordion-group',
|
|
426
|
+
elementClass: IonAccordionGroup$1,
|
|
427
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
428
|
+
react: React,
|
|
429
|
+
events: { onIonChange: 'ionChange' },
|
|
430
|
+
defineCustomElement: defineCustomElement$2,
|
|
431
|
+
});
|
|
432
|
+
const IonAvatar =
|
|
433
|
+
/*@__PURE__*/ createComponent({
|
|
434
|
+
tagName: 'ion-avatar',
|
|
435
|
+
elementClass: IonAvatar$1,
|
|
436
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
437
|
+
react: React,
|
|
438
|
+
events: {},
|
|
439
|
+
defineCustomElement: defineCustomElement$3,
|
|
440
|
+
});
|
|
441
|
+
const IonBackdrop =
|
|
442
|
+
/*@__PURE__*/ createComponent({
|
|
443
|
+
tagName: 'ion-backdrop',
|
|
444
|
+
elementClass: IonBackdrop$1,
|
|
445
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
446
|
+
react: React,
|
|
447
|
+
events: { onIonBackdropTap: 'ionBackdropTap' },
|
|
448
|
+
defineCustomElement: defineCustomElement$4,
|
|
449
|
+
});
|
|
450
|
+
const IonBadge =
|
|
451
|
+
/*@__PURE__*/ createComponent({
|
|
452
|
+
tagName: 'ion-badge',
|
|
453
|
+
elementClass: IonBadge$1,
|
|
454
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
455
|
+
react: React,
|
|
456
|
+
events: {},
|
|
457
|
+
defineCustomElement: defineCustomElement$5,
|
|
458
|
+
});
|
|
459
|
+
const IonBreadcrumbs = /*@__PURE__*/ createComponent({
|
|
460
|
+
tagName: 'ion-breadcrumbs',
|
|
461
|
+
elementClass: IonBreadcrumbs$1,
|
|
462
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
463
|
+
react: React,
|
|
464
|
+
events: { onIonCollapsedClick: 'ionCollapsedClick' },
|
|
465
|
+
defineCustomElement: defineCustomElement$6,
|
|
466
|
+
});
|
|
467
|
+
const IonButtons =
|
|
468
|
+
/*@__PURE__*/ createComponent({
|
|
469
|
+
tagName: 'ion-buttons',
|
|
470
|
+
elementClass: IonButtons$1,
|
|
471
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
472
|
+
react: React,
|
|
473
|
+
events: {},
|
|
474
|
+
defineCustomElement: defineCustomElement$7,
|
|
475
|
+
});
|
|
476
|
+
const IonCardContent = /*@__PURE__*/ createComponent({
|
|
477
|
+
tagName: 'ion-card-content',
|
|
478
|
+
elementClass: IonCardContent$1,
|
|
479
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
480
|
+
react: React,
|
|
481
|
+
events: {},
|
|
482
|
+
defineCustomElement: defineCustomElement$8,
|
|
483
|
+
});
|
|
484
|
+
const IonCardHeader =
|
|
485
|
+
/*@__PURE__*/ createComponent({
|
|
486
|
+
tagName: 'ion-card-header',
|
|
487
|
+
elementClass: IonCardHeader$1,
|
|
488
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
489
|
+
react: React,
|
|
490
|
+
events: {},
|
|
491
|
+
defineCustomElement: defineCustomElement$9,
|
|
492
|
+
});
|
|
493
|
+
const IonCardSubtitle = /*@__PURE__*/ createComponent({
|
|
494
|
+
tagName: 'ion-card-subtitle',
|
|
495
|
+
elementClass: IonCardSubtitle$1,
|
|
496
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
497
|
+
react: React,
|
|
498
|
+
events: {},
|
|
499
|
+
defineCustomElement: defineCustomElement$a,
|
|
500
|
+
});
|
|
501
|
+
const IonCardTitle =
|
|
502
|
+
/*@__PURE__*/ createComponent({
|
|
503
|
+
tagName: 'ion-card-title',
|
|
504
|
+
elementClass: IonCardTitle$1,
|
|
505
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
506
|
+
react: React,
|
|
507
|
+
events: {},
|
|
508
|
+
defineCustomElement: defineCustomElement$b,
|
|
509
|
+
});
|
|
510
|
+
const IonCheckbox =
|
|
511
|
+
/*@__PURE__*/ createComponent({
|
|
512
|
+
tagName: 'ion-checkbox',
|
|
513
|
+
elementClass: IonCheckbox$1,
|
|
514
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
515
|
+
react: React,
|
|
516
|
+
events: {
|
|
517
|
+
onIonChange: 'ionChange',
|
|
518
|
+
onIonFocus: 'ionFocus',
|
|
519
|
+
onIonBlur: 'ionBlur',
|
|
520
|
+
},
|
|
521
|
+
defineCustomElement: defineCustomElement$c,
|
|
522
|
+
});
|
|
523
|
+
const IonChip =
|
|
524
|
+
/*@__PURE__*/ createComponent({
|
|
525
|
+
tagName: 'ion-chip',
|
|
526
|
+
elementClass: IonChip$1,
|
|
527
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
528
|
+
react: React,
|
|
529
|
+
events: {},
|
|
530
|
+
defineCustomElement: defineCustomElement$d,
|
|
531
|
+
});
|
|
532
|
+
const IonCol =
|
|
533
|
+
/*@__PURE__*/ createComponent({
|
|
534
|
+
tagName: 'ion-col',
|
|
535
|
+
elementClass: IonCol$1,
|
|
536
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
537
|
+
react: React,
|
|
538
|
+
events: {},
|
|
539
|
+
defineCustomElement: defineCustomElement$e,
|
|
540
|
+
});
|
|
541
|
+
const IonContent =
|
|
542
|
+
/*@__PURE__*/ createComponent({
|
|
543
|
+
tagName: 'ion-content',
|
|
544
|
+
elementClass: IonContent$1,
|
|
545
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
546
|
+
react: React,
|
|
547
|
+
events: {
|
|
548
|
+
onIonScrollStart: 'ionScrollStart',
|
|
549
|
+
onIonScroll: 'ionScroll',
|
|
550
|
+
onIonScrollEnd: 'ionScrollEnd',
|
|
551
|
+
},
|
|
552
|
+
defineCustomElement: defineCustomElement$f,
|
|
553
|
+
});
|
|
554
|
+
const IonDatetime =
|
|
555
|
+
/*@__PURE__*/ createComponent({
|
|
556
|
+
tagName: 'ion-datetime',
|
|
557
|
+
elementClass: IonDatetime$1,
|
|
558
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
559
|
+
react: React,
|
|
560
|
+
events: {
|
|
561
|
+
onIonCancel: 'ionCancel',
|
|
562
|
+
onIonChange: 'ionChange',
|
|
563
|
+
onIonFocus: 'ionFocus',
|
|
564
|
+
onIonBlur: 'ionBlur',
|
|
565
|
+
},
|
|
566
|
+
defineCustomElement: defineCustomElement$g,
|
|
567
|
+
});
|
|
568
|
+
const IonDatetimeButton = /*@__PURE__*/ createComponent({
|
|
569
|
+
tagName: 'ion-datetime-button',
|
|
570
|
+
elementClass: IonDatetimeButton$1,
|
|
571
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
572
|
+
react: React,
|
|
573
|
+
events: {},
|
|
574
|
+
defineCustomElement: defineCustomElement$h,
|
|
575
|
+
});
|
|
576
|
+
const IonFab =
|
|
577
|
+
/*@__PURE__*/ createComponent({
|
|
578
|
+
tagName: 'ion-fab',
|
|
579
|
+
elementClass: IonFab$1,
|
|
580
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
581
|
+
react: React,
|
|
582
|
+
events: {},
|
|
583
|
+
defineCustomElement: defineCustomElement$i,
|
|
584
|
+
});
|
|
585
|
+
const IonFabList =
|
|
586
|
+
/*@__PURE__*/ createComponent({
|
|
587
|
+
tagName: 'ion-fab-list',
|
|
588
|
+
elementClass: IonFabList$1,
|
|
589
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
590
|
+
react: React,
|
|
591
|
+
events: {},
|
|
592
|
+
defineCustomElement: defineCustomElement$j,
|
|
593
|
+
});
|
|
594
|
+
const IonFooter =
|
|
595
|
+
/*@__PURE__*/ createComponent({
|
|
596
|
+
tagName: 'ion-footer',
|
|
597
|
+
elementClass: IonFooter$1,
|
|
598
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
599
|
+
react: React,
|
|
600
|
+
events: {},
|
|
601
|
+
defineCustomElement: defineCustomElement$k,
|
|
602
|
+
});
|
|
603
|
+
const IonGrid =
|
|
604
|
+
/*@__PURE__*/ createComponent({
|
|
605
|
+
tagName: 'ion-grid',
|
|
606
|
+
elementClass: IonGrid$1,
|
|
607
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
608
|
+
react: React,
|
|
609
|
+
events: {},
|
|
610
|
+
defineCustomElement: defineCustomElement$l,
|
|
611
|
+
});
|
|
612
|
+
const IonHeader =
|
|
613
|
+
/*@__PURE__*/ createComponent({
|
|
614
|
+
tagName: 'ion-header',
|
|
615
|
+
elementClass: IonHeader$1,
|
|
616
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
617
|
+
react: React,
|
|
618
|
+
events: {},
|
|
619
|
+
defineCustomElement: defineCustomElement$m,
|
|
620
|
+
});
|
|
621
|
+
const IonImg =
|
|
622
|
+
/*@__PURE__*/ createComponent({
|
|
623
|
+
tagName: 'ion-img',
|
|
624
|
+
elementClass: IonImg$1,
|
|
625
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
626
|
+
react: React,
|
|
627
|
+
events: {
|
|
628
|
+
onIonImgWillLoad: 'ionImgWillLoad',
|
|
629
|
+
onIonImgDidLoad: 'ionImgDidLoad',
|
|
630
|
+
onIonError: 'ionError',
|
|
631
|
+
},
|
|
632
|
+
defineCustomElement: defineCustomElement$n,
|
|
633
|
+
});
|
|
634
|
+
const IonInfiniteScroll = /*@__PURE__*/ createComponent({
|
|
635
|
+
tagName: 'ion-infinite-scroll',
|
|
636
|
+
elementClass: IonInfiniteScroll$1,
|
|
637
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
638
|
+
react: React,
|
|
639
|
+
events: { onIonInfinite: 'ionInfinite' },
|
|
640
|
+
defineCustomElement: defineCustomElement$o,
|
|
641
|
+
});
|
|
642
|
+
const IonInfiniteScrollContent = /*@__PURE__*/ createComponent({
|
|
643
|
+
tagName: 'ion-infinite-scroll-content',
|
|
644
|
+
elementClass: IonInfiniteScrollContent$1,
|
|
645
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
646
|
+
react: React,
|
|
647
|
+
events: {},
|
|
648
|
+
defineCustomElement: defineCustomElement$p,
|
|
649
|
+
});
|
|
650
|
+
const IonInput =
|
|
651
|
+
/*@__PURE__*/ createComponent({
|
|
652
|
+
tagName: 'ion-input',
|
|
653
|
+
elementClass: IonInput$1,
|
|
654
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
655
|
+
react: React,
|
|
656
|
+
events: {
|
|
657
|
+
onIonInput: 'ionInput',
|
|
658
|
+
onIonChange: 'ionChange',
|
|
659
|
+
onIonBlur: 'ionBlur',
|
|
660
|
+
onIonFocus: 'ionFocus',
|
|
661
|
+
},
|
|
662
|
+
defineCustomElement: defineCustomElement$q,
|
|
663
|
+
});
|
|
664
|
+
const IonInputOtp =
|
|
665
|
+
/*@__PURE__*/ createComponent({
|
|
666
|
+
tagName: 'ion-input-otp',
|
|
667
|
+
elementClass: IonInputOtp$1,
|
|
668
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
669
|
+
react: React,
|
|
670
|
+
events: {
|
|
671
|
+
onIonInput: 'ionInput',
|
|
672
|
+
onIonChange: 'ionChange',
|
|
673
|
+
onIonComplete: 'ionComplete',
|
|
674
|
+
onIonBlur: 'ionBlur',
|
|
675
|
+
onIonFocus: 'ionFocus',
|
|
676
|
+
},
|
|
677
|
+
defineCustomElement: defineCustomElement$r,
|
|
678
|
+
});
|
|
679
|
+
const IonInputPasswordToggle = /*@__PURE__*/ createComponent({
|
|
680
|
+
tagName: 'ion-input-password-toggle',
|
|
681
|
+
elementClass: IonInputPasswordToggle$1,
|
|
682
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
683
|
+
react: React,
|
|
684
|
+
events: {},
|
|
685
|
+
defineCustomElement: defineCustomElement$s,
|
|
686
|
+
});
|
|
687
|
+
const IonItemDivider = /*@__PURE__*/ createComponent({
|
|
688
|
+
tagName: 'ion-item-divider',
|
|
689
|
+
elementClass: IonItemDivider$1,
|
|
690
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
691
|
+
react: React,
|
|
692
|
+
events: {},
|
|
693
|
+
defineCustomElement: defineCustomElement$t,
|
|
694
|
+
});
|
|
695
|
+
const IonItemGroup =
|
|
696
|
+
/*@__PURE__*/ createComponent({
|
|
697
|
+
tagName: 'ion-item-group',
|
|
698
|
+
elementClass: IonItemGroup$1,
|
|
699
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
700
|
+
react: React,
|
|
701
|
+
events: {},
|
|
702
|
+
defineCustomElement: defineCustomElement$u,
|
|
703
|
+
});
|
|
704
|
+
const IonItemOptions = /*@__PURE__*/ createComponent({
|
|
705
|
+
tagName: 'ion-item-options',
|
|
706
|
+
elementClass: IonItemOptions$1,
|
|
707
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
708
|
+
react: React,
|
|
709
|
+
events: { onIonSwipe: 'ionSwipe' },
|
|
710
|
+
defineCustomElement: defineCustomElement$v,
|
|
711
|
+
});
|
|
712
|
+
const IonItemSliding = /*@__PURE__*/ createComponent({
|
|
713
|
+
tagName: 'ion-item-sliding',
|
|
714
|
+
elementClass: IonItemSliding$1,
|
|
715
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
716
|
+
react: React,
|
|
717
|
+
events: { onIonDrag: 'ionDrag' },
|
|
718
|
+
defineCustomElement: defineCustomElement$w,
|
|
719
|
+
});
|
|
720
|
+
const IonLabel =
|
|
721
|
+
/*@__PURE__*/ createComponent({
|
|
722
|
+
tagName: 'ion-label',
|
|
723
|
+
elementClass: IonLabel$1,
|
|
724
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
725
|
+
react: React,
|
|
726
|
+
events: {},
|
|
727
|
+
defineCustomElement: defineCustomElement$x,
|
|
728
|
+
});
|
|
729
|
+
const IonList =
|
|
730
|
+
/*@__PURE__*/ createComponent({
|
|
731
|
+
tagName: 'ion-list',
|
|
732
|
+
elementClass: IonList$1,
|
|
733
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
734
|
+
react: React,
|
|
735
|
+
events: {},
|
|
736
|
+
defineCustomElement: defineCustomElement$y,
|
|
737
|
+
});
|
|
738
|
+
const IonListHeader =
|
|
739
|
+
/*@__PURE__*/ createComponent({
|
|
740
|
+
tagName: 'ion-list-header',
|
|
741
|
+
elementClass: IonListHeader$1,
|
|
742
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
743
|
+
react: React,
|
|
744
|
+
events: {},
|
|
745
|
+
defineCustomElement: defineCustomElement$z,
|
|
746
|
+
});
|
|
747
|
+
const IonMenu =
|
|
748
|
+
/*@__PURE__*/ createComponent({
|
|
749
|
+
tagName: 'ion-menu',
|
|
750
|
+
elementClass: IonMenu$1,
|
|
751
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
752
|
+
react: React,
|
|
753
|
+
events: {
|
|
754
|
+
onIonWillOpen: 'ionWillOpen',
|
|
755
|
+
onIonWillClose: 'ionWillClose',
|
|
756
|
+
onIonDidOpen: 'ionDidOpen',
|
|
757
|
+
onIonDidClose: 'ionDidClose',
|
|
758
|
+
},
|
|
759
|
+
defineCustomElement: defineCustomElement$A,
|
|
760
|
+
});
|
|
761
|
+
const IonMenuButton =
|
|
762
|
+
/*@__PURE__*/ createComponent({
|
|
763
|
+
tagName: 'ion-menu-button',
|
|
764
|
+
elementClass: IonMenuButton$1,
|
|
765
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
766
|
+
react: React,
|
|
767
|
+
events: {},
|
|
768
|
+
defineCustomElement: defineCustomElement$B,
|
|
769
|
+
});
|
|
770
|
+
const IonMenuToggle =
|
|
771
|
+
/*@__PURE__*/ createComponent({
|
|
772
|
+
tagName: 'ion-menu-toggle',
|
|
773
|
+
elementClass: IonMenuToggle$1,
|
|
774
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
775
|
+
react: React,
|
|
776
|
+
events: {},
|
|
777
|
+
defineCustomElement: defineCustomElement$C,
|
|
778
|
+
});
|
|
779
|
+
const IonNavLink =
|
|
780
|
+
/*@__PURE__*/ createComponent({
|
|
781
|
+
tagName: 'ion-nav-link',
|
|
782
|
+
elementClass: IonNavLink$1,
|
|
783
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
784
|
+
react: React,
|
|
785
|
+
events: {},
|
|
786
|
+
defineCustomElement: defineCustomElement$D,
|
|
787
|
+
});
|
|
788
|
+
const IonNote =
|
|
789
|
+
/*@__PURE__*/ createComponent({
|
|
790
|
+
tagName: 'ion-note',
|
|
791
|
+
elementClass: IonNote$1,
|
|
792
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
793
|
+
react: React,
|
|
794
|
+
events: {},
|
|
795
|
+
defineCustomElement: defineCustomElement$E,
|
|
796
|
+
});
|
|
797
|
+
const IonPicker =
|
|
798
|
+
/*@__PURE__*/ createComponent({
|
|
799
|
+
tagName: 'ion-picker',
|
|
800
|
+
elementClass: IonPicker$1,
|
|
801
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
802
|
+
react: React,
|
|
803
|
+
events: {},
|
|
804
|
+
defineCustomElement: defineCustomElement$F,
|
|
805
|
+
});
|
|
806
|
+
const IonPickerColumn = /*@__PURE__*/ createComponent({
|
|
807
|
+
tagName: 'ion-picker-column',
|
|
808
|
+
elementClass: IonPickerColumn$1,
|
|
809
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
810
|
+
react: React,
|
|
811
|
+
events: { onIonChange: 'ionChange' },
|
|
812
|
+
defineCustomElement: defineCustomElement$G,
|
|
813
|
+
});
|
|
814
|
+
const IonPickerColumnOption = /*@__PURE__*/ createComponent({
|
|
815
|
+
tagName: 'ion-picker-column-option',
|
|
816
|
+
elementClass: IonPickerColumnOption$1,
|
|
817
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
818
|
+
react: React,
|
|
819
|
+
events: {},
|
|
820
|
+
defineCustomElement: defineCustomElement$H,
|
|
821
|
+
});
|
|
822
|
+
const IonProgressBar = /*@__PURE__*/ createComponent({
|
|
823
|
+
tagName: 'ion-progress-bar',
|
|
824
|
+
elementClass: IonProgressBar$1,
|
|
825
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
826
|
+
react: React,
|
|
827
|
+
events: {},
|
|
828
|
+
defineCustomElement: defineCustomElement$I,
|
|
829
|
+
});
|
|
830
|
+
const IonRadio =
|
|
831
|
+
/*@__PURE__*/ createComponent({
|
|
832
|
+
tagName: 'ion-radio',
|
|
833
|
+
elementClass: IonRadio$1,
|
|
834
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
835
|
+
react: React,
|
|
836
|
+
events: {
|
|
837
|
+
onIonFocus: 'ionFocus',
|
|
838
|
+
onIonBlur: 'ionBlur',
|
|
839
|
+
},
|
|
840
|
+
defineCustomElement: defineCustomElement$J,
|
|
841
|
+
});
|
|
842
|
+
const IonRadioGroup =
|
|
843
|
+
/*@__PURE__*/ createComponent({
|
|
844
|
+
tagName: 'ion-radio-group',
|
|
845
|
+
elementClass: IonRadioGroup$1,
|
|
846
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
847
|
+
react: React,
|
|
848
|
+
events: { onIonChange: 'ionChange' },
|
|
849
|
+
defineCustomElement: defineCustomElement$K,
|
|
850
|
+
});
|
|
851
|
+
const IonRange =
|
|
852
|
+
/*@__PURE__*/ createComponent({
|
|
853
|
+
tagName: 'ion-range',
|
|
854
|
+
elementClass: IonRange$1,
|
|
855
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
856
|
+
react: React,
|
|
857
|
+
events: {
|
|
858
|
+
onIonChange: 'ionChange',
|
|
859
|
+
onIonInput: 'ionInput',
|
|
860
|
+
onIonFocus: 'ionFocus',
|
|
861
|
+
onIonBlur: 'ionBlur',
|
|
862
|
+
onIonKnobMoveStart: 'ionKnobMoveStart',
|
|
863
|
+
onIonKnobMoveEnd: 'ionKnobMoveEnd',
|
|
864
|
+
},
|
|
865
|
+
defineCustomElement: defineCustomElement$L,
|
|
866
|
+
});
|
|
867
|
+
const IonRefresher =
|
|
868
|
+
/*@__PURE__*/ createComponent({
|
|
869
|
+
tagName: 'ion-refresher',
|
|
870
|
+
elementClass: IonRefresher$1,
|
|
871
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
872
|
+
react: React,
|
|
873
|
+
events: {
|
|
874
|
+
onIonRefresh: 'ionRefresh',
|
|
875
|
+
onIonPull: 'ionPull',
|
|
876
|
+
onIonStart: 'ionStart',
|
|
877
|
+
onIonPullStart: 'ionPullStart',
|
|
878
|
+
onIonPullEnd: 'ionPullEnd',
|
|
879
|
+
},
|
|
880
|
+
defineCustomElement: defineCustomElement$M,
|
|
881
|
+
});
|
|
882
|
+
const IonRefresherContent = /*@__PURE__*/ createComponent({
|
|
883
|
+
tagName: 'ion-refresher-content',
|
|
884
|
+
elementClass: IonRefresherContent$1,
|
|
885
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
886
|
+
react: React,
|
|
887
|
+
events: {},
|
|
888
|
+
defineCustomElement: defineCustomElement$N,
|
|
889
|
+
});
|
|
890
|
+
const IonReorder =
|
|
891
|
+
/*@__PURE__*/ createComponent({
|
|
892
|
+
tagName: 'ion-reorder',
|
|
893
|
+
elementClass: IonReorder$1,
|
|
894
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
895
|
+
react: React,
|
|
896
|
+
events: {},
|
|
897
|
+
defineCustomElement: defineCustomElement$O,
|
|
898
|
+
});
|
|
899
|
+
const IonReorderGroup = /*@__PURE__*/ createComponent({
|
|
900
|
+
tagName: 'ion-reorder-group',
|
|
901
|
+
elementClass: IonReorderGroup$1,
|
|
902
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
903
|
+
react: React,
|
|
904
|
+
events: {
|
|
905
|
+
onIonItemReorder: 'ionItemReorder',
|
|
906
|
+
onIonReorderStart: 'ionReorderStart',
|
|
907
|
+
onIonReorderMove: 'ionReorderMove',
|
|
908
|
+
onIonReorderEnd: 'ionReorderEnd',
|
|
909
|
+
},
|
|
910
|
+
defineCustomElement: defineCustomElement$P,
|
|
911
|
+
});
|
|
912
|
+
const IonRippleEffect = /*@__PURE__*/ createComponent({
|
|
913
|
+
tagName: 'ion-ripple-effect',
|
|
914
|
+
elementClass: IonRippleEffect$1,
|
|
915
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
916
|
+
react: React,
|
|
917
|
+
events: {},
|
|
918
|
+
defineCustomElement: defineCustomElement$Q,
|
|
919
|
+
});
|
|
920
|
+
const IonRow =
|
|
921
|
+
/*@__PURE__*/ createComponent({
|
|
922
|
+
tagName: 'ion-row',
|
|
923
|
+
elementClass: IonRow$1,
|
|
924
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
925
|
+
react: React,
|
|
926
|
+
events: {},
|
|
927
|
+
defineCustomElement: defineCustomElement$R,
|
|
928
|
+
});
|
|
929
|
+
const IonSearchbar =
|
|
930
|
+
/*@__PURE__*/ createComponent({
|
|
931
|
+
tagName: 'ion-searchbar',
|
|
932
|
+
elementClass: IonSearchbar$1,
|
|
933
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
934
|
+
react: React,
|
|
935
|
+
events: {
|
|
936
|
+
onIonInput: 'ionInput',
|
|
937
|
+
onIonChange: 'ionChange',
|
|
938
|
+
onIonCancel: 'ionCancel',
|
|
939
|
+
onIonClear: 'ionClear',
|
|
940
|
+
onIonBlur: 'ionBlur',
|
|
941
|
+
onIonFocus: 'ionFocus',
|
|
942
|
+
},
|
|
943
|
+
defineCustomElement: defineCustomElement$S,
|
|
944
|
+
});
|
|
945
|
+
const IonSegment =
|
|
946
|
+
/*@__PURE__*/ createComponent({
|
|
947
|
+
tagName: 'ion-segment',
|
|
948
|
+
elementClass: IonSegment$1,
|
|
949
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
950
|
+
react: React,
|
|
951
|
+
events: { onIonChange: 'ionChange' },
|
|
952
|
+
defineCustomElement: defineCustomElement$T,
|
|
953
|
+
});
|
|
954
|
+
const IonSegmentButton = /*@__PURE__*/ createComponent({
|
|
955
|
+
tagName: 'ion-segment-button',
|
|
956
|
+
elementClass: IonSegmentButton$1,
|
|
957
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
958
|
+
react: React,
|
|
959
|
+
events: {},
|
|
960
|
+
defineCustomElement: defineCustomElement$U,
|
|
961
|
+
});
|
|
962
|
+
const IonSegmentContent = /*@__PURE__*/ createComponent({
|
|
963
|
+
tagName: 'ion-segment-content',
|
|
964
|
+
elementClass: IonSegmentContent$1,
|
|
965
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
966
|
+
react: React,
|
|
967
|
+
events: {},
|
|
968
|
+
defineCustomElement: defineCustomElement$V,
|
|
969
|
+
});
|
|
970
|
+
const IonSegmentView = /*@__PURE__*/ createComponent({
|
|
971
|
+
tagName: 'ion-segment-view',
|
|
972
|
+
elementClass: IonSegmentView$1,
|
|
973
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
974
|
+
react: React,
|
|
975
|
+
events: { onIonSegmentViewScroll: 'ionSegmentViewScroll' },
|
|
976
|
+
defineCustomElement: defineCustomElement$W,
|
|
977
|
+
});
|
|
978
|
+
const IonSelect =
|
|
979
|
+
/*@__PURE__*/ createComponent({
|
|
980
|
+
tagName: 'ion-select',
|
|
981
|
+
elementClass: IonSelect$1,
|
|
982
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
983
|
+
react: React,
|
|
984
|
+
events: {
|
|
985
|
+
onIonChange: 'ionChange',
|
|
986
|
+
onIonCancel: 'ionCancel',
|
|
987
|
+
onIonDismiss: 'ionDismiss',
|
|
988
|
+
onIonFocus: 'ionFocus',
|
|
989
|
+
onIonBlur: 'ionBlur',
|
|
990
|
+
},
|
|
991
|
+
defineCustomElement: defineCustomElement$X,
|
|
992
|
+
});
|
|
993
|
+
const IonSelectModal = /*@__PURE__*/ createComponent({
|
|
994
|
+
tagName: 'ion-select-modal',
|
|
995
|
+
elementClass: IonSelectModal$1,
|
|
996
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
997
|
+
react: React,
|
|
998
|
+
events: {},
|
|
999
|
+
defineCustomElement: defineCustomElement$Y,
|
|
1000
|
+
});
|
|
1001
|
+
const IonSelectOption = /*@__PURE__*/ createComponent({
|
|
1002
|
+
tagName: 'ion-select-option',
|
|
1003
|
+
elementClass: IonSelectOption$1,
|
|
1004
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1005
|
+
react: React,
|
|
1006
|
+
events: {},
|
|
1007
|
+
defineCustomElement: defineCustomElement$Z,
|
|
1008
|
+
});
|
|
1009
|
+
const IonSkeletonText = /*@__PURE__*/ createComponent({
|
|
1010
|
+
tagName: 'ion-skeleton-text',
|
|
1011
|
+
elementClass: IonSkeletonText$1,
|
|
1012
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1013
|
+
react: React,
|
|
1014
|
+
events: {},
|
|
1015
|
+
defineCustomElement: defineCustomElement$_,
|
|
1016
|
+
});
|
|
1017
|
+
const IonSpinner =
|
|
1018
|
+
/*@__PURE__*/ createComponent({
|
|
1019
|
+
tagName: 'ion-spinner',
|
|
1020
|
+
elementClass: IonSpinner$1,
|
|
1021
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1022
|
+
react: React,
|
|
1023
|
+
events: {},
|
|
1024
|
+
defineCustomElement: defineCustomElement$$,
|
|
1025
|
+
});
|
|
1026
|
+
const IonSplitPane =
|
|
1027
|
+
/*@__PURE__*/ createComponent({
|
|
1028
|
+
tagName: 'ion-split-pane',
|
|
1029
|
+
elementClass: IonSplitPane$1,
|
|
1030
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1031
|
+
react: React,
|
|
1032
|
+
events: { onIonSplitPaneVisible: 'ionSplitPaneVisible' },
|
|
1033
|
+
defineCustomElement: defineCustomElement$10,
|
|
1034
|
+
});
|
|
1035
|
+
const IonTab =
|
|
1036
|
+
/*@__PURE__*/ createComponent({
|
|
1037
|
+
tagName: 'ion-tab',
|
|
1038
|
+
elementClass: IonTab$1,
|
|
1039
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1040
|
+
react: React,
|
|
1041
|
+
events: {},
|
|
1042
|
+
defineCustomElement: defineCustomElement$11,
|
|
1043
|
+
});
|
|
1044
|
+
const IonText =
|
|
1045
|
+
/*@__PURE__*/ createComponent({
|
|
1046
|
+
tagName: 'ion-text',
|
|
1047
|
+
elementClass: IonText$1,
|
|
1048
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1049
|
+
react: React,
|
|
1050
|
+
events: {},
|
|
1051
|
+
defineCustomElement: defineCustomElement$12,
|
|
1052
|
+
});
|
|
1053
|
+
const IonTextarea =
|
|
1054
|
+
/*@__PURE__*/ createComponent({
|
|
1055
|
+
tagName: 'ion-textarea',
|
|
1056
|
+
elementClass: IonTextarea$1,
|
|
1057
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1058
|
+
react: React,
|
|
1059
|
+
events: {
|
|
1060
|
+
onIonChange: 'ionChange',
|
|
1061
|
+
onIonInput: 'ionInput',
|
|
1062
|
+
onIonBlur: 'ionBlur',
|
|
1063
|
+
onIonFocus: 'ionFocus',
|
|
1064
|
+
},
|
|
1065
|
+
defineCustomElement: defineCustomElement$13,
|
|
1066
|
+
});
|
|
1067
|
+
const IonThumbnail =
|
|
1068
|
+
/*@__PURE__*/ createComponent({
|
|
1069
|
+
tagName: 'ion-thumbnail',
|
|
1070
|
+
elementClass: IonThumbnail$1,
|
|
1071
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1072
|
+
react: React,
|
|
1073
|
+
events: {},
|
|
1074
|
+
defineCustomElement: defineCustomElement$14,
|
|
1075
|
+
});
|
|
1076
|
+
const IonTitle =
|
|
1077
|
+
/*@__PURE__*/ createComponent({
|
|
1078
|
+
tagName: 'ion-title',
|
|
1079
|
+
elementClass: IonTitle$1,
|
|
1080
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1081
|
+
react: React,
|
|
1082
|
+
events: {},
|
|
1083
|
+
defineCustomElement: defineCustomElement$15,
|
|
1084
|
+
});
|
|
1085
|
+
const IonToggle =
|
|
1086
|
+
/*@__PURE__*/ createComponent({
|
|
1087
|
+
tagName: 'ion-toggle',
|
|
1088
|
+
elementClass: IonToggle$1,
|
|
1089
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1090
|
+
react: React,
|
|
1091
|
+
events: {
|
|
1092
|
+
onIonChange: 'ionChange',
|
|
1093
|
+
onIonFocus: 'ionFocus',
|
|
1094
|
+
onIonBlur: 'ionBlur',
|
|
1095
|
+
},
|
|
1096
|
+
defineCustomElement: defineCustomElement$16,
|
|
1097
|
+
});
|
|
1098
|
+
const IonToolbar =
|
|
1099
|
+
/*@__PURE__*/ createComponent({
|
|
1100
|
+
tagName: 'ion-toolbar',
|
|
1101
|
+
elementClass: IonToolbar$1,
|
|
1102
|
+
// @ts-ignore - ignore potential React type mismatches between the Stencil Output Target and your project.
|
|
1103
|
+
react: React,
|
|
1104
|
+
events: {},
|
|
1105
|
+
defineCustomElement: defineCustomElement$17,
|
|
1106
|
+
});
|
|
1107
|
+
|
|
420
1108
|
const dashToPascalCase = (str) => str
|
|
421
1109
|
.toLowerCase()
|
|
422
1110
|
.split('-')
|
|
@@ -564,150 +1252,6 @@ const defineCustomElement = (tagName, customElement) => {
|
|
|
564
1252
|
}
|
|
565
1253
|
};
|
|
566
1254
|
|
|
567
|
-
const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => {
|
|
568
|
-
if (defineCustomElement !== undefined) {
|
|
569
|
-
defineCustomElement();
|
|
570
|
-
}
|
|
571
|
-
const displayName = dashToPascalCase(tagName);
|
|
572
|
-
const ReactComponent = class extends React.Component {
|
|
573
|
-
constructor(props) {
|
|
574
|
-
super(props);
|
|
575
|
-
this.setComponentElRef = (element) => {
|
|
576
|
-
this.componentEl = element;
|
|
577
|
-
};
|
|
578
|
-
}
|
|
579
|
-
componentDidMount() {
|
|
580
|
-
this.componentDidUpdate(this.props);
|
|
581
|
-
}
|
|
582
|
-
componentDidUpdate(prevProps) {
|
|
583
|
-
attachProps(this.componentEl, this.props, prevProps);
|
|
584
|
-
}
|
|
585
|
-
render() {
|
|
586
|
-
const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
|
|
587
|
-
let propsToPass = Object.keys(cProps).reduce((acc, name) => {
|
|
588
|
-
const value = cProps[name];
|
|
589
|
-
if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
|
|
590
|
-
const eventName = name.substring(2).toLowerCase();
|
|
591
|
-
if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
|
|
592
|
-
acc[name] = value;
|
|
593
|
-
}
|
|
594
|
-
}
|
|
595
|
-
else {
|
|
596
|
-
// we should only render strings, booleans, and numbers as attrs in html.
|
|
597
|
-
// objects, functions, arrays etc get synced via properties on mount.
|
|
598
|
-
const type = typeof value;
|
|
599
|
-
if (type === 'string' || type === 'boolean' || type === 'number') {
|
|
600
|
-
acc[camelToDashCase(name)] = value;
|
|
601
|
-
}
|
|
602
|
-
}
|
|
603
|
-
return acc;
|
|
604
|
-
}, {});
|
|
605
|
-
if (manipulatePropsFunction) {
|
|
606
|
-
propsToPass = manipulatePropsFunction(this.props, propsToPass);
|
|
607
|
-
}
|
|
608
|
-
const newProps = {
|
|
609
|
-
...propsToPass,
|
|
610
|
-
ref: mergeRefs(forwardedRef, this.setComponentElRef),
|
|
611
|
-
style,
|
|
612
|
-
};
|
|
613
|
-
/**
|
|
614
|
-
* We use createElement here instead of
|
|
615
|
-
* React.createElement to work around a
|
|
616
|
-
* bug in Vite (https://github.com/vitejs/vite/issues/6104).
|
|
617
|
-
* React.createElement causes all elements to be rendered
|
|
618
|
-
* as <tagname> instead of the actual Web Component.
|
|
619
|
-
*/
|
|
620
|
-
return createElement(tagName, newProps, children);
|
|
621
|
-
}
|
|
622
|
-
static get displayName() {
|
|
623
|
-
return displayName;
|
|
624
|
-
}
|
|
625
|
-
};
|
|
626
|
-
// If context was passed to createReactComponent then conditionally add it to the Component Class
|
|
627
|
-
if (ReactComponentContext) {
|
|
628
|
-
ReactComponent.contextType = ReactComponentContext;
|
|
629
|
-
}
|
|
630
|
-
return createForwardRef$1(ReactComponent, displayName);
|
|
631
|
-
};
|
|
632
|
-
|
|
633
|
-
/* eslint-disable */
|
|
634
|
-
/* tslint:disable */
|
|
635
|
-
/* auto-generated react proxies */
|
|
636
|
-
const IonAccordion = /*@__PURE__*/ createReactComponent('ion-accordion', undefined, undefined, defineCustomElement$1);
|
|
637
|
-
const IonAccordionGroup = /*@__PURE__*/ createReactComponent('ion-accordion-group', undefined, undefined, defineCustomElement$2);
|
|
638
|
-
const IonAvatar = /*@__PURE__*/ createReactComponent('ion-avatar', undefined, undefined, defineCustomElement$3);
|
|
639
|
-
const IonBackdrop = /*@__PURE__*/ createReactComponent('ion-backdrop', undefined, undefined, defineCustomElement$4);
|
|
640
|
-
const IonBadge = /*@__PURE__*/ createReactComponent('ion-badge', undefined, undefined, defineCustomElement$5);
|
|
641
|
-
const IonBreadcrumbs = /*@__PURE__*/ createReactComponent('ion-breadcrumbs', undefined, undefined, defineCustomElement$6);
|
|
642
|
-
const IonButtons = /*@__PURE__*/ createReactComponent('ion-buttons', undefined, undefined, defineCustomElement$7);
|
|
643
|
-
const IonCardContent = /*@__PURE__*/ createReactComponent('ion-card-content', undefined, undefined, defineCustomElement$8);
|
|
644
|
-
const IonCardHeader = /*@__PURE__*/ createReactComponent('ion-card-header', undefined, undefined, defineCustomElement$9);
|
|
645
|
-
const IonCardSubtitle = /*@__PURE__*/ createReactComponent('ion-card-subtitle', undefined, undefined, defineCustomElement$a);
|
|
646
|
-
const IonCardTitle = /*@__PURE__*/ createReactComponent('ion-card-title', undefined, undefined, defineCustomElement$b);
|
|
647
|
-
const IonCheckbox = /*@__PURE__*/ createReactComponent('ion-checkbox', undefined, undefined, defineCustomElement$c);
|
|
648
|
-
const IonChip = /*@__PURE__*/ createReactComponent('ion-chip', undefined, undefined, defineCustomElement$d);
|
|
649
|
-
const IonCol = /*@__PURE__*/ createReactComponent('ion-col', undefined, undefined, defineCustomElement$e);
|
|
650
|
-
const IonContent = /*@__PURE__*/ createReactComponent('ion-content', undefined, undefined, defineCustomElement$f);
|
|
651
|
-
const IonDatetime = /*@__PURE__*/ createReactComponent('ion-datetime', undefined, undefined, defineCustomElement$g);
|
|
652
|
-
const IonDatetimeButton = /*@__PURE__*/ createReactComponent('ion-datetime-button', undefined, undefined, defineCustomElement$h);
|
|
653
|
-
const IonDivider = /*@__PURE__*/ createReactComponent('ion-divider', undefined, undefined, defineCustomElement$i);
|
|
654
|
-
const IonFab = /*@__PURE__*/ createReactComponent('ion-fab', undefined, undefined, defineCustomElement$j);
|
|
655
|
-
const IonFabList = /*@__PURE__*/ createReactComponent('ion-fab-list', undefined, undefined, defineCustomElement$k);
|
|
656
|
-
const IonFooter = /*@__PURE__*/ createReactComponent('ion-footer', undefined, undefined, defineCustomElement$l);
|
|
657
|
-
const IonGallery = /*@__PURE__*/ createReactComponent('ion-gallery', undefined, undefined, defineCustomElement$m);
|
|
658
|
-
const IonGalleryItem = /*@__PURE__*/ createReactComponent('ion-gallery-item', undefined, undefined, defineCustomElement$n);
|
|
659
|
-
const IonGrid = /*@__PURE__*/ createReactComponent('ion-grid', undefined, undefined, defineCustomElement$o);
|
|
660
|
-
const IonHeader = /*@__PURE__*/ createReactComponent('ion-header', undefined, undefined, defineCustomElement$p);
|
|
661
|
-
const IonImg = /*@__PURE__*/ createReactComponent('ion-img', undefined, undefined, defineCustomElement$q);
|
|
662
|
-
const IonInfiniteScroll = /*@__PURE__*/ createReactComponent('ion-infinite-scroll', undefined, undefined, defineCustomElement$r);
|
|
663
|
-
const IonInfiniteScrollContent = /*@__PURE__*/ createReactComponent('ion-infinite-scroll-content', undefined, undefined, defineCustomElement$s);
|
|
664
|
-
const IonInput = /*@__PURE__*/ createReactComponent('ion-input', undefined, undefined, defineCustomElement$t);
|
|
665
|
-
const IonInputOtp = /*@__PURE__*/ createReactComponent('ion-input-otp', undefined, undefined, defineCustomElement$u);
|
|
666
|
-
const IonInputPasswordToggle = /*@__PURE__*/ createReactComponent('ion-input-password-toggle', undefined, undefined, defineCustomElement$v);
|
|
667
|
-
const IonItemDivider = /*@__PURE__*/ createReactComponent('ion-item-divider', undefined, undefined, defineCustomElement$w);
|
|
668
|
-
const IonItemGroup = /*@__PURE__*/ createReactComponent('ion-item-group', undefined, undefined, defineCustomElement$x);
|
|
669
|
-
const IonItemOptions = /*@__PURE__*/ createReactComponent('ion-item-options', undefined, undefined, defineCustomElement$y);
|
|
670
|
-
const IonItemSliding = /*@__PURE__*/ createReactComponent('ion-item-sliding', undefined, undefined, defineCustomElement$z);
|
|
671
|
-
const IonLabel = /*@__PURE__*/ createReactComponent('ion-label', undefined, undefined, defineCustomElement$A);
|
|
672
|
-
const IonList = /*@__PURE__*/ createReactComponent('ion-list', undefined, undefined, defineCustomElement$B);
|
|
673
|
-
const IonListHeader = /*@__PURE__*/ createReactComponent('ion-list-header', undefined, undefined, defineCustomElement$C);
|
|
674
|
-
const IonMenu = /*@__PURE__*/ createReactComponent('ion-menu', undefined, undefined, defineCustomElement$D);
|
|
675
|
-
const IonMenuButton = /*@__PURE__*/ createReactComponent('ion-menu-button', undefined, undefined, defineCustomElement$E);
|
|
676
|
-
const IonMenuToggle = /*@__PURE__*/ createReactComponent('ion-menu-toggle', undefined, undefined, defineCustomElement$F);
|
|
677
|
-
const IonNavLink = /*@__PURE__*/ createReactComponent('ion-nav-link', undefined, undefined, defineCustomElement$G);
|
|
678
|
-
const IonNote = /*@__PURE__*/ createReactComponent('ion-note', undefined, undefined, defineCustomElement$H);
|
|
679
|
-
const IonPicker = /*@__PURE__*/ createReactComponent('ion-picker', undefined, undefined, defineCustomElement$I);
|
|
680
|
-
const IonPickerColumn = /*@__PURE__*/ createReactComponent('ion-picker-column', undefined, undefined, defineCustomElement$J);
|
|
681
|
-
const IonPickerColumnOption = /*@__PURE__*/ createReactComponent('ion-picker-column-option', undefined, undefined, defineCustomElement$K);
|
|
682
|
-
const IonProgressBar = /*@__PURE__*/ createReactComponent('ion-progress-bar', undefined, undefined, defineCustomElement$L);
|
|
683
|
-
const IonRadio = /*@__PURE__*/ createReactComponent('ion-radio', undefined, undefined, defineCustomElement$M);
|
|
684
|
-
const IonRadioGroup = /*@__PURE__*/ createReactComponent('ion-radio-group', undefined, undefined, defineCustomElement$N);
|
|
685
|
-
const IonRange = /*@__PURE__*/ createReactComponent('ion-range', undefined, undefined, defineCustomElement$O);
|
|
686
|
-
const IonRefresher = /*@__PURE__*/ createReactComponent('ion-refresher', undefined, undefined, defineCustomElement$P);
|
|
687
|
-
const IonRefresherContent = /*@__PURE__*/ createReactComponent('ion-refresher-content', undefined, undefined, defineCustomElement$Q);
|
|
688
|
-
const IonReorder = /*@__PURE__*/ createReactComponent('ion-reorder', undefined, undefined, defineCustomElement$R);
|
|
689
|
-
const IonReorderGroup = /*@__PURE__*/ createReactComponent('ion-reorder-group', undefined, undefined, defineCustomElement$S);
|
|
690
|
-
const IonRippleEffect = /*@__PURE__*/ createReactComponent('ion-ripple-effect', undefined, undefined, defineCustomElement$T);
|
|
691
|
-
const IonRow = /*@__PURE__*/ createReactComponent('ion-row', undefined, undefined, defineCustomElement$U);
|
|
692
|
-
const IonSearchbar = /*@__PURE__*/ createReactComponent('ion-searchbar', undefined, undefined, defineCustomElement$V);
|
|
693
|
-
const IonSegment = /*@__PURE__*/ createReactComponent('ion-segment', undefined, undefined, defineCustomElement$W);
|
|
694
|
-
const IonSegmentButton = /*@__PURE__*/ createReactComponent('ion-segment-button', undefined, undefined, defineCustomElement$X);
|
|
695
|
-
const IonSegmentContent = /*@__PURE__*/ createReactComponent('ion-segment-content', undefined, undefined, defineCustomElement$Y);
|
|
696
|
-
const IonSegmentView = /*@__PURE__*/ createReactComponent('ion-segment-view', undefined, undefined, defineCustomElement$Z);
|
|
697
|
-
const IonSelect = /*@__PURE__*/ createReactComponent('ion-select', undefined, undefined, defineCustomElement$_);
|
|
698
|
-
const IonSelectModal = /*@__PURE__*/ createReactComponent('ion-select-modal', undefined, undefined, defineCustomElement$$);
|
|
699
|
-
const IonSelectOption = /*@__PURE__*/ createReactComponent('ion-select-option', undefined, undefined, defineCustomElement$10);
|
|
700
|
-
const IonSkeletonText = /*@__PURE__*/ createReactComponent('ion-skeleton-text', undefined, undefined, defineCustomElement$11);
|
|
701
|
-
const IonSpinner = /*@__PURE__*/ createReactComponent('ion-spinner', undefined, undefined, defineCustomElement$12);
|
|
702
|
-
const IonSplitPane = /*@__PURE__*/ createReactComponent('ion-split-pane', undefined, undefined, defineCustomElement$13);
|
|
703
|
-
const IonTab = /*@__PURE__*/ createReactComponent('ion-tab', undefined, undefined, defineCustomElement$14);
|
|
704
|
-
const IonText = /*@__PURE__*/ createReactComponent('ion-text', undefined, undefined, defineCustomElement$15);
|
|
705
|
-
const IonTextarea = /*@__PURE__*/ createReactComponent('ion-textarea', undefined, undefined, defineCustomElement$16);
|
|
706
|
-
const IonThumbnail = /*@__PURE__*/ createReactComponent('ion-thumbnail', undefined, undefined, defineCustomElement$17);
|
|
707
|
-
const IonTitle = /*@__PURE__*/ createReactComponent('ion-title', undefined, undefined, defineCustomElement$18);
|
|
708
|
-
const IonToggle = /*@__PURE__*/ createReactComponent('ion-toggle', undefined, undefined, defineCustomElement$19);
|
|
709
|
-
const IonToolbar = /*@__PURE__*/ createReactComponent('ion-toolbar', undefined, undefined, defineCustomElement$1a);
|
|
710
|
-
|
|
711
1255
|
const createForwardRef = (ReactComponent, // TODO(FW-2959): type
|
|
712
1256
|
displayName) => {
|
|
713
1257
|
const forwardRef = (props, ref) => {
|
|
@@ -745,6 +1289,11 @@ const createRoutingComponent = (tagName, customElement) => {
|
|
|
745
1289
|
this.handleClick = (e) => {
|
|
746
1290
|
const { routerLink, routerDirection, routerOptions, routerAnimation } = this.props;
|
|
747
1291
|
if (routerLink !== undefined) {
|
|
1292
|
+
// Allow modifier key clicks (ctrl/cmd/shift) to open the link in a new tab/window
|
|
1293
|
+
// without triggering SPA navigation on the current page.
|
|
1294
|
+
if (e.metaKey || e.ctrlKey || e.shiftKey) {
|
|
1295
|
+
return;
|
|
1296
|
+
}
|
|
748
1297
|
e.preventDefault();
|
|
749
1298
|
this.context.navigate(routerLink, routerDirection, undefined, routerAnimation, routerOptions);
|
|
750
1299
|
}
|
|
@@ -1093,19 +1642,17 @@ const createInlineOverlayComponent = (tagName, defineCustomElement, hasDelegateH
|
|
|
1093
1642
|
};
|
|
1094
1643
|
const DELEGATE_HOST = 'ion-delegate-host';
|
|
1095
1644
|
|
|
1096
|
-
const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$
|
|
1645
|
+
const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$18);
|
|
1097
1646
|
|
|
1098
|
-
const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$
|
|
1647
|
+
const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$19);
|
|
1099
1648
|
|
|
1100
|
-
const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$
|
|
1649
|
+
const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1a);
|
|
1101
1650
|
|
|
1102
|
-
const
|
|
1651
|
+
const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1b);
|
|
1103
1652
|
|
|
1104
|
-
const
|
|
1653
|
+
const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1c, true);
|
|
1105
1654
|
|
|
1106
|
-
const
|
|
1107
|
-
|
|
1108
|
-
const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1h);
|
|
1655
|
+
const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1d);
|
|
1109
1656
|
|
|
1110
1657
|
const IonContext = React.createContext({
|
|
1111
1658
|
addOverlay: () => {
|
|
@@ -1197,14 +1744,81 @@ const IonOverlayManager = ({ onAddOverlay, onRemoveOverlay }) => {
|
|
|
1197
1744
|
}) }));
|
|
1198
1745
|
};
|
|
1199
1746
|
|
|
1200
|
-
const
|
|
1201
|
-
|
|
1202
|
-
|
|
1203
|
-
|
|
1204
|
-
const
|
|
1205
|
-
const
|
|
1747
|
+
const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => {
|
|
1748
|
+
if (defineCustomElement !== undefined) {
|
|
1749
|
+
defineCustomElement();
|
|
1750
|
+
}
|
|
1751
|
+
const displayName = dashToPascalCase(tagName);
|
|
1752
|
+
const ReactComponent = class extends React.Component {
|
|
1753
|
+
constructor(props) {
|
|
1754
|
+
super(props);
|
|
1755
|
+
this.setComponentElRef = (element) => {
|
|
1756
|
+
this.componentEl = element;
|
|
1757
|
+
};
|
|
1758
|
+
}
|
|
1759
|
+
componentDidMount() {
|
|
1760
|
+
this.componentDidUpdate(this.props);
|
|
1761
|
+
}
|
|
1762
|
+
componentDidUpdate(prevProps) {
|
|
1763
|
+
attachProps(this.componentEl, this.props, prevProps);
|
|
1764
|
+
}
|
|
1765
|
+
render() {
|
|
1766
|
+
const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
|
|
1767
|
+
let propsToPass = Object.keys(cProps).reduce((acc, name) => {
|
|
1768
|
+
const value = cProps[name];
|
|
1769
|
+
if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
|
|
1770
|
+
const eventName = name.substring(2).toLowerCase();
|
|
1771
|
+
if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
|
|
1772
|
+
acc[name] = value;
|
|
1773
|
+
}
|
|
1774
|
+
}
|
|
1775
|
+
else {
|
|
1776
|
+
// we should only render strings, booleans, and numbers as attrs in html.
|
|
1777
|
+
// objects, functions, arrays etc get synced via properties on mount.
|
|
1778
|
+
const type = typeof value;
|
|
1779
|
+
if (type === 'string' || type === 'boolean' || type === 'number') {
|
|
1780
|
+
acc[camelToDashCase(name)] = value;
|
|
1781
|
+
}
|
|
1782
|
+
}
|
|
1783
|
+
return acc;
|
|
1784
|
+
}, {});
|
|
1785
|
+
if (manipulatePropsFunction) {
|
|
1786
|
+
propsToPass = manipulatePropsFunction(this.props, propsToPass);
|
|
1787
|
+
}
|
|
1788
|
+
const newProps = {
|
|
1789
|
+
...propsToPass,
|
|
1790
|
+
ref: mergeRefs(forwardedRef, this.setComponentElRef),
|
|
1791
|
+
style,
|
|
1792
|
+
children
|
|
1793
|
+
};
|
|
1794
|
+
/**
|
|
1795
|
+
* We use createElement here instead of
|
|
1796
|
+
* React.createElement to work around a
|
|
1797
|
+
* bug in Vite (https://github.com/vitejs/vite/issues/6104).
|
|
1798
|
+
* React.createElement causes all elements to be rendered
|
|
1799
|
+
* as <tagname> instead of the actual Web Component.
|
|
1800
|
+
*/
|
|
1801
|
+
return createElement(tagName, newProps, children);
|
|
1802
|
+
}
|
|
1803
|
+
static get displayName() {
|
|
1804
|
+
return displayName;
|
|
1805
|
+
}
|
|
1806
|
+
};
|
|
1807
|
+
// If context was passed to createReactComponent then conditionally add it to the Component Class
|
|
1808
|
+
if (ReactComponentContext) {
|
|
1809
|
+
ReactComponent.contextType = ReactComponentContext;
|
|
1810
|
+
}
|
|
1811
|
+
return createForwardRef$1(ReactComponent, displayName);
|
|
1812
|
+
};
|
|
1813
|
+
|
|
1814
|
+
const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1e);
|
|
1815
|
+
const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1f);
|
|
1816
|
+
const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1g);
|
|
1817
|
+
const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1h);
|
|
1818
|
+
const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1i);
|
|
1819
|
+
const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1j);
|
|
1206
1820
|
// ionicons
|
|
1207
|
-
const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$
|
|
1821
|
+
const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1k);
|
|
1208
1822
|
|
|
1209
1823
|
class IonApp extends React.Component {
|
|
1210
1824
|
constructor(props) {
|
|
@@ -1242,7 +1856,25 @@ class PageManager extends React.PureComponent {
|
|
|
1242
1856
|
super(props);
|
|
1243
1857
|
this.ionPageElementRef = React.createRef();
|
|
1244
1858
|
// React refs must be stable (not created inline).
|
|
1245
|
-
|
|
1859
|
+
// Wrap merged refs to add ion-page-invisible synchronously when element is created
|
|
1860
|
+
const baseMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
|
|
1861
|
+
// Guard against React 19 strict mode double-mount re-adding ion-page-invisible.
|
|
1862
|
+
// The ref fires again on remount after StackManager may have already removed it.
|
|
1863
|
+
let hasAppliedInvisible = false;
|
|
1864
|
+
this.stableMergedRefs = (node) => {
|
|
1865
|
+
if (node &&
|
|
1866
|
+
!hasAppliedInvisible &&
|
|
1867
|
+
!node.classList.contains('ion-page-invisible') &&
|
|
1868
|
+
!node.classList.contains('ion-page-hidden')) {
|
|
1869
|
+
// Add ion-page-invisible synchronously before first paint (if in an outlet)
|
|
1870
|
+
// This prevents the flash that occurs when componentDidMount runs after paint
|
|
1871
|
+
if (this.context?.isInOutlet?.()) {
|
|
1872
|
+
node.classList.add('ion-page-invisible');
|
|
1873
|
+
hasAppliedInvisible = true;
|
|
1874
|
+
}
|
|
1875
|
+
}
|
|
1876
|
+
baseMergedRefs(node);
|
|
1877
|
+
};
|
|
1246
1878
|
/**
|
|
1247
1879
|
* This binds the scope of the following methods to the class scope.
|
|
1248
1880
|
* The `.bind` method returns a new function, so we need to assign it
|
|
@@ -1254,11 +1886,38 @@ class PageManager extends React.PureComponent {
|
|
|
1254
1886
|
this.ionViewWillLeaveHandler = this.ionViewWillLeaveHandler.bind(this);
|
|
1255
1887
|
this.ionViewDidLeaveHandler = this.ionViewDidLeaveHandler.bind(this);
|
|
1256
1888
|
}
|
|
1889
|
+
parseClasses(className) {
|
|
1890
|
+
if (!className)
|
|
1891
|
+
return new Set();
|
|
1892
|
+
return new Set(className.split(/\s+/).filter(Boolean));
|
|
1893
|
+
}
|
|
1894
|
+
/**
|
|
1895
|
+
* Updates classList by diffing old/new className props.
|
|
1896
|
+
* Preserves framework-added classes (can-go-back, ion-page-invisible, etc.).
|
|
1897
|
+
*/
|
|
1898
|
+
updateUserClasses(oldClassName, newClassName) {
|
|
1899
|
+
if (!this.ionPageElementRef.current)
|
|
1900
|
+
return;
|
|
1901
|
+
const oldClasses = this.parseClasses(oldClassName);
|
|
1902
|
+
const newClasses = this.parseClasses(newClassName);
|
|
1903
|
+
oldClasses.forEach((cls) => {
|
|
1904
|
+
if (!newClasses.has(cls)) {
|
|
1905
|
+
this.ionPageElementRef.current.classList.remove(cls);
|
|
1906
|
+
}
|
|
1907
|
+
});
|
|
1908
|
+
newClasses.forEach((cls) => {
|
|
1909
|
+
if (!oldClasses.has(cls)) {
|
|
1910
|
+
this.ionPageElementRef.current.classList.add(cls);
|
|
1911
|
+
}
|
|
1912
|
+
});
|
|
1913
|
+
}
|
|
1257
1914
|
componentDidMount() {
|
|
1258
1915
|
if (this.ionPageElementRef.current) {
|
|
1259
|
-
|
|
1260
|
-
|
|
1261
|
-
|
|
1916
|
+
// Add user classes via DOM manipulation to preserve framework-added classes.
|
|
1917
|
+
// We only set "ion-page" in JSX; user classes are added here.
|
|
1918
|
+
// Note: ion-page-invisible is added in the ref callback (stableMergedRefs) to prevent flash.
|
|
1919
|
+
// The ref callback runs synchronously when the element is created, before the browser paints.
|
|
1920
|
+
this.updateUserClasses(undefined, this.props.className);
|
|
1262
1921
|
this.context.registerIonPage(this.ionPageElementRef.current, this.props.routeInfo);
|
|
1263
1922
|
this.ionPageElementRef.current.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
|
|
1264
1923
|
this.ionPageElementRef.current.addEventListener('ionViewDidEnter', this.ionViewDidEnterHandler);
|
|
@@ -1266,6 +1925,11 @@ class PageManager extends React.PureComponent {
|
|
|
1266
1925
|
this.ionPageElementRef.current.addEventListener('ionViewDidLeave', this.ionViewDidLeaveHandler);
|
|
1267
1926
|
}
|
|
1268
1927
|
}
|
|
1928
|
+
componentDidUpdate(prevProps) {
|
|
1929
|
+
if (prevProps.className !== this.props.className) {
|
|
1930
|
+
this.updateUserClasses(prevProps.className, this.props.className);
|
|
1931
|
+
}
|
|
1932
|
+
}
|
|
1269
1933
|
componentWillUnmount() {
|
|
1270
1934
|
if (this.ionPageElementRef.current) {
|
|
1271
1935
|
this.ionPageElementRef.current.removeEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
|
|
@@ -1295,9 +1959,11 @@ class PageManager extends React.PureComponent {
|
|
|
1295
1959
|
render() {
|
|
1296
1960
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
1297
1961
|
const { className, children, routeInfo, forwardedRef, ...props } = this.props;
|
|
1962
|
+
// Only set "ion-page" in JSX. User classes are managed via DOM in componentDidMount/componentDidUpdate
|
|
1963
|
+
// to preserve framework-added classes (can-go-back, ion-page-invisible, etc.) when className prop changes.
|
|
1298
1964
|
return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
|
|
1299
1965
|
this.ionLifeCycleContext = context;
|
|
1300
|
-
return (jsx("div", { className:
|
|
1966
|
+
return (jsx("div", { className: "ion-page", ref: this.stableMergedRefs, ...props, children: children }));
|
|
1301
1967
|
} }));
|
|
1302
1968
|
}
|
|
1303
1969
|
static get contextType() {
|
|
@@ -1357,7 +2023,7 @@ const ReactDelegate = (addView, removeView) => {
|
|
|
1357
2023
|
};
|
|
1358
2024
|
};
|
|
1359
2025
|
|
|
1360
|
-
const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$
|
|
2026
|
+
const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1l);
|
|
1361
2027
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
1362
2028
|
const IonNavInternal = ({ children, forwardedRef, ...restOfProps }) => {
|
|
1363
2029
|
const [views, setViews] = useState([]);
|
|
@@ -1405,8 +2071,30 @@ class OutletPageManager extends React.Component {
|
|
|
1405
2071
|
*/
|
|
1406
2072
|
if (!this.outletIsReady) {
|
|
1407
2073
|
componentOnReady(this.ionRouterOutlet, () => {
|
|
2074
|
+
/**
|
|
2075
|
+
* Guard against duplicate callbacks from React strict mode double-mount.
|
|
2076
|
+
* Both componentDidMount calls pass the outer !outletIsReady check before
|
|
2077
|
+
* either async callback fires. Without this inner guard, the second callback
|
|
2078
|
+
* re-adds ion-page-invisible after the first callback's transition removed it,
|
|
2079
|
+
* and registerIonPage returns early (same element), leaving the page invisible.
|
|
2080
|
+
*/
|
|
2081
|
+
if (this.outletIsReady)
|
|
2082
|
+
return;
|
|
1408
2083
|
this.outletIsReady = true;
|
|
1409
|
-
|
|
2084
|
+
/**
|
|
2085
|
+
* Add ion-page + ion-page-invisible AFTER Stencil hydration but
|
|
2086
|
+
* BEFORE registerIonPage. Stencil hydration overwrites className,
|
|
2087
|
+
* so classes added in a React ref callback get wiped. Adding them
|
|
2088
|
+
* here -- after hydration -- ensures they persist until the parent
|
|
2089
|
+
* outlet's forward animation removes ion-page-invisible, preventing
|
|
2090
|
+
* a flash where the outlet is briefly visible at full opacity.
|
|
2091
|
+
*/
|
|
2092
|
+
const el = this.ionRouterOutlet;
|
|
2093
|
+
if (!el.classList.contains('ion-page-invisible') && !el.classList.contains('ion-page-hidden')) {
|
|
2094
|
+
el.classList.add('ion-page');
|
|
2095
|
+
el.classList.add('ion-page-invisible');
|
|
2096
|
+
}
|
|
2097
|
+
this.context.registerIonPage(el, this.props.routeInfo);
|
|
1410
2098
|
});
|
|
1411
2099
|
}
|
|
1412
2100
|
this.ionRouterOutlet.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
|
|
@@ -1436,10 +2124,10 @@ class OutletPageManager extends React.Component {
|
|
|
1436
2124
|
this.ionLifeCycleContext.ionViewDidLeave();
|
|
1437
2125
|
}
|
|
1438
2126
|
render() {
|
|
1439
|
-
const { StackManager, children, routeInfo, ...props } = this.props;
|
|
2127
|
+
const { StackManager, children, routeInfo, id, ...props } = this.props;
|
|
1440
2128
|
return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
|
|
1441
2129
|
this.ionLifeCycleContext = context;
|
|
1442
|
-
return (jsx(StackManager, { routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
|
|
2130
|
+
return (jsx(StackManager, { id: id, routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { id: id, setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
|
|
1443
2131
|
} }));
|
|
1444
2132
|
}
|
|
1445
2133
|
static get contextType() {
|
|
@@ -1450,11 +2138,13 @@ class OutletPageManager extends React.Component {
|
|
|
1450
2138
|
class IonRouterOutletContainer extends React.Component {
|
|
1451
2139
|
constructor(props) {
|
|
1452
2140
|
super(props);
|
|
2141
|
+
this.outletId = props.id ?? `routerOutlet-${generateId('routerOutlet')}`;
|
|
1453
2142
|
}
|
|
1454
2143
|
render() {
|
|
1455
2144
|
const StackManager = this.context.getStackManager();
|
|
1456
2145
|
const { children, forwardedRef, ...props } = this.props;
|
|
1457
|
-
|
|
2146
|
+
const outletId = props.id ?? this.outletId;
|
|
2147
|
+
return this.context.hasIonicRouter() ? (props.ionPage ? (jsx(OutletPageManager, { StackManager: StackManager, routeInfo: this.context.routeInfo, ...props, children: children })) : (jsx(StackManager, { routeInfo: this.context.routeInfo, id: outletId, children: jsx(IonRouterOutletInner, { ...props, id: outletId, forwardedRef: forwardedRef, children: children }) }))) : (jsx(IonRouterOutletInner, { ref: forwardedRef, ...this.props, children: this.props.children }));
|
|
1458
2148
|
}
|
|
1459
2149
|
static get contextType() {
|
|
1460
2150
|
return NavContext;
|
|
@@ -1651,7 +2341,9 @@ const matchesTab = (pathname, href) => {
|
|
|
1651
2341
|
if (href === undefined) {
|
|
1652
2342
|
return false;
|
|
1653
2343
|
}
|
|
1654
|
-
|
|
2344
|
+
// Strip query string before comparing — href may contain search params (e.g., "/tabs/home?foo=bar")
|
|
2345
|
+
const hrefPathname = href.split('?')[0];
|
|
2346
|
+
const normalizedHref = hrefPathname.endsWith('/') && hrefPathname !== '/' ? hrefPathname.slice(0, -1) : hrefPathname;
|
|
1655
2347
|
return pathname === normalizedHref || pathname.startsWith(normalizedHref + '/');
|
|
1656
2348
|
};
|
|
1657
2349
|
class IonTabBarUnwrapped extends React.PureComponent {
|
|
@@ -1743,7 +2435,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
|
|
|
1743
2435
|
const prevHref = state.tabs[prevActiveTab].currentHref;
|
|
1744
2436
|
const prevRouteOptions = state.tabs[prevActiveTab].currentRouteOptions;
|
|
1745
2437
|
if (activeTab !== prevActiveTab ||
|
|
1746
|
-
prevHref !== props.routeInfo?.pathname ||
|
|
2438
|
+
prevHref !== (props.routeInfo?.pathname || '') + (props.routeInfo?.search || '') ||
|
|
1747
2439
|
prevRouteOptions !== props.routeInfo?.routeOptions) {
|
|
1748
2440
|
tabs[activeTab] = {
|
|
1749
2441
|
originalHref: tabs[activeTab].originalHref,
|
|
@@ -1810,7 +2502,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
|
|
|
1810
2502
|
return (child) => {
|
|
1811
2503
|
if (child != null && child.props && (child.type === IonTabButton || child.type.isTabButton)) {
|
|
1812
2504
|
const href = child.props.tab === activeTab
|
|
1813
|
-
? this.props.routeInfo?.pathname
|
|
2505
|
+
? (this.props.routeInfo?.pathname || '') + (this.props.routeInfo?.search || '')
|
|
1814
2506
|
: this.state.tabs[child.props.tab].currentHref;
|
|
1815
2507
|
const routeOptions = child.props.tab === activeTab
|
|
1816
2508
|
? this.props.routeInfo?.routeOptions
|
|
@@ -1935,20 +2627,6 @@ class IonRoute extends React.PureComponent {
|
|
|
1935
2627
|
}
|
|
1936
2628
|
}
|
|
1937
2629
|
|
|
1938
|
-
class IonRedirect extends React.PureComponent {
|
|
1939
|
-
render() {
|
|
1940
|
-
const IonRedirectInner = this.context.getIonRedirect();
|
|
1941
|
-
if (!this.context.hasIonicRouter() || !IonRedirect) {
|
|
1942
|
-
console.error('You either do not have an Ionic Router package, or your router does not support using <IonRedirect>');
|
|
1943
|
-
return null;
|
|
1944
|
-
}
|
|
1945
|
-
return jsx(IonRedirectInner, { ...this.props });
|
|
1946
|
-
}
|
|
1947
|
-
static get contextType() {
|
|
1948
|
-
return NavContext;
|
|
1949
|
-
}
|
|
1950
|
-
}
|
|
1951
|
-
|
|
1952
2630
|
const IonRouterContext = React.createContext({
|
|
1953
2631
|
routeInfo: undefined, // TODO(FW-2959): type
|
|
1954
2632
|
push: () => {
|
|
@@ -1957,6 +2635,9 @@ const IonRouterContext = React.createContext({
|
|
|
1957
2635
|
back: () => {
|
|
1958
2636
|
throw new Error('An Ionic Router is required for IonRouterContext');
|
|
1959
2637
|
},
|
|
2638
|
+
navigateRoot: () => {
|
|
2639
|
+
throw new Error('An Ionic Router is required for IonRouterContext');
|
|
2640
|
+
},
|
|
1960
2641
|
canGoBack: () => {
|
|
1961
2642
|
throw new Error('An Ionic Router is required for IonRouterContext');
|
|
1962
2643
|
},
|
|
@@ -1973,9 +2654,10 @@ function useIonRouter() {
|
|
|
1973
2654
|
back: context.back,
|
|
1974
2655
|
push: context.push,
|
|
1975
2656
|
goBack: context.back,
|
|
2657
|
+
navigateRoot: context.navigateRoot,
|
|
1976
2658
|
canGoBack: context.canGoBack,
|
|
1977
2659
|
routeInfo: context.routeInfo,
|
|
1978
|
-
}), [context.back, context.push, context.canGoBack, context.routeInfo]);
|
|
2660
|
+
}), [context.back, context.push, context.navigateRoot, context.canGoBack, context.routeInfo]);
|
|
1979
2661
|
}
|
|
1980
2662
|
|
|
1981
2663
|
class CreateAnimation extends React.PureComponent {
|
|
@@ -2129,7 +2811,7 @@ function useController(displayName, controller, defineCustomElement) {
|
|
|
2129
2811
|
* @returns Returns the present and dismiss methods in an array
|
|
2130
2812
|
*/
|
|
2131
2813
|
function useIonActionSheet() {
|
|
2132
|
-
const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$
|
|
2814
|
+
const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1b);
|
|
2133
2815
|
const present = useCallback((buttonsOrOptions, header) => {
|
|
2134
2816
|
if (Array.isArray(buttonsOrOptions)) {
|
|
2135
2817
|
return controller.present({
|
|
@@ -2149,7 +2831,7 @@ function useIonActionSheet() {
|
|
|
2149
2831
|
* @returns Returns the present and dismiss methods in an array
|
|
2150
2832
|
*/
|
|
2151
2833
|
function useIonAlert() {
|
|
2152
|
-
const controller = useController('IonAlert', alertController, defineCustomElement$
|
|
2834
|
+
const controller = useController('IonAlert', alertController, defineCustomElement$18);
|
|
2153
2835
|
const present = useCallback((messageOrOptions, buttons) => {
|
|
2154
2836
|
if (typeof messageOrOptions === 'string') {
|
|
2155
2837
|
return controller.present({
|
|
@@ -2169,7 +2851,7 @@ function useIonAlert() {
|
|
|
2169
2851
|
* @returns Returns the present and dismiss methods in an array
|
|
2170
2852
|
*/
|
|
2171
2853
|
function useIonToast() {
|
|
2172
|
-
const controller = useController('IonToast', toastController, defineCustomElement$
|
|
2854
|
+
const controller = useController('IonToast', toastController, defineCustomElement$1a);
|
|
2173
2855
|
const present = useCallback((messageOrOptions, duration) => {
|
|
2174
2856
|
if (typeof messageOrOptions === 'string') {
|
|
2175
2857
|
return controller.present({
|
|
@@ -2255,7 +2937,7 @@ function useOverlay(displayName, controller, defineCustomElement, component, com
|
|
|
2255
2937
|
* @returns Returns the present and dismiss methods in an array
|
|
2256
2938
|
*/
|
|
2257
2939
|
function useIonModal(component, componentProps) {
|
|
2258
|
-
const controller = useOverlay('IonModal', modalController, defineCustomElement$
|
|
2940
|
+
const controller = useOverlay('IonModal', modalController, defineCustomElement$1c, component, componentProps);
|
|
2259
2941
|
const present = useCallback((options = {}) => {
|
|
2260
2942
|
controller.present(options);
|
|
2261
2943
|
}, [controller.present]);
|
|
@@ -2270,40 +2952,19 @@ function useIonModal(component, componentProps) {
|
|
|
2270
2952
|
* @returns Returns the present and dismiss methods in an array
|
|
2271
2953
|
*/
|
|
2272
2954
|
function useIonPopover(component, componentProps) {
|
|
2273
|
-
const controller = useOverlay('IonPopover', popoverController, defineCustomElement$
|
|
2955
|
+
const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1d, component, componentProps);
|
|
2274
2956
|
const present = useCallback((options = {}) => {
|
|
2275
2957
|
controller.present(options);
|
|
2276
2958
|
}, [controller.present]);
|
|
2277
2959
|
return [present, controller.dismiss];
|
|
2278
2960
|
}
|
|
2279
2961
|
|
|
2280
|
-
/**
|
|
2281
|
-
* A hook for presenting/dismissing an IonPicker component
|
|
2282
|
-
* @returns Returns the present and dismiss methods in an array
|
|
2283
|
-
* @deprecated Use the inline ion-picker component instead.
|
|
2284
|
-
*/
|
|
2285
|
-
function useIonPicker() {
|
|
2286
|
-
const controller = useController('IonPicker', pickerController, defineCustomElement$1e);
|
|
2287
|
-
const present = useCallback((columnsOrOptions, buttons) => {
|
|
2288
|
-
if (Array.isArray(columnsOrOptions)) {
|
|
2289
|
-
return controller.present({
|
|
2290
|
-
columns: columnsOrOptions,
|
|
2291
|
-
buttons: buttons ?? [{ text: 'Ok' }],
|
|
2292
|
-
});
|
|
2293
|
-
}
|
|
2294
|
-
else {
|
|
2295
|
-
return controller.present(columnsOrOptions);
|
|
2296
|
-
}
|
|
2297
|
-
}, [controller.present]);
|
|
2298
|
-
return [present, controller.dismiss];
|
|
2299
|
-
}
|
|
2300
|
-
|
|
2301
2962
|
/**
|
|
2302
2963
|
* A hook for presenting/dismissing an IonLoading component
|
|
2303
2964
|
* @returns Returns the present and dismiss methods in an array
|
|
2304
2965
|
*/
|
|
2305
2966
|
function useIonLoading() {
|
|
2306
|
-
const controller = useController('IonLoading', loadingController, defineCustomElement$
|
|
2967
|
+
const controller = useController('IonLoading', loadingController, defineCustomElement$19);
|
|
2307
2968
|
const present = useCallback((messageOrOptions = {}, duration, spinner) => {
|
|
2308
2969
|
if (typeof messageOrOptions === 'string') {
|
|
2309
2970
|
return controller.present({
|
|
@@ -2345,6 +3006,7 @@ const RouteManagerContext = /*@__PURE__*/ React.createContext({
|
|
|
2345
3006
|
findLeavingViewItemByRouteInfo: () => undefined,
|
|
2346
3007
|
findViewItemByRouteInfo: () => undefined,
|
|
2347
3008
|
getChildrenToRender: () => undefined,
|
|
3009
|
+
getViewItemsForOutlet: () => [],
|
|
2348
3010
|
goBack: () => undefined,
|
|
2349
3011
|
unMountViewItem: () => undefined,
|
|
2350
3012
|
});
|
|
@@ -2463,7 +3125,14 @@ class LocationHistory {
|
|
|
2463
3125
|
_replace(routeInfo) {
|
|
2464
3126
|
const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
|
|
2465
3127
|
routeInfos && routeInfos.pop();
|
|
2466
|
-
|
|
3128
|
+
// Get the current route that's being replaced
|
|
3129
|
+
const currentRoute = this.locationHistory[this.locationHistory.length - 1];
|
|
3130
|
+
// Only pop from global history if we're replacing in the same outlet context.
|
|
3131
|
+
// Don't pop if we're entering a nested outlet (current route has no tab, new route has a tab)
|
|
3132
|
+
const isEnteringNestedOutlet = currentRoute && !currentRoute.tab && !!routeInfo.tab;
|
|
3133
|
+
if (!isEnteringNestedOutlet) {
|
|
3134
|
+
this.locationHistory.pop();
|
|
3135
|
+
}
|
|
2467
3136
|
this._add(routeInfo);
|
|
2468
3137
|
}
|
|
2469
3138
|
_clear() {
|
|
@@ -2495,6 +3164,20 @@ class LocationHistory {
|
|
|
2495
3164
|
}
|
|
2496
3165
|
return undefined;
|
|
2497
3166
|
}
|
|
3167
|
+
/**
|
|
3168
|
+
* Returns the most recent RouteInfo in global history (excluding the current
|
|
3169
|
+
* entry) whose pathname matches the given value. Unlike findLastLocation,
|
|
3170
|
+
* this search is tab-agnostic. Used by the multi-step back detection.
|
|
3171
|
+
*/
|
|
3172
|
+
findLastLocationByPathname(pathname) {
|
|
3173
|
+
for (let i = this.locationHistory.length - 2; i >= 0; i--) {
|
|
3174
|
+
const ri = this.locationHistory[i];
|
|
3175
|
+
if (ri && ri.pathname === pathname) {
|
|
3176
|
+
return ri;
|
|
3177
|
+
}
|
|
3178
|
+
}
|
|
3179
|
+
return undefined;
|
|
3180
|
+
}
|
|
2498
3181
|
findLastLocation(routeInfo) {
|
|
2499
3182
|
const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
|
|
2500
3183
|
if (routeInfos) {
|
|
@@ -2526,6 +3209,17 @@ class LocationHistory {
|
|
|
2526
3209
|
canGoBack() {
|
|
2527
3210
|
return this.locationHistory.length > 1;
|
|
2528
3211
|
}
|
|
3212
|
+
findTabForPathname(pathname) {
|
|
3213
|
+
for (const tab of Object.keys(this.tabHistory)) {
|
|
3214
|
+
const routeInfos = this.tabHistory[tab];
|
|
3215
|
+
for (let i = routeInfos.length - 1; i >= 0; i--) {
|
|
3216
|
+
if (routeInfos[i].pathname === pathname) {
|
|
3217
|
+
return tab;
|
|
3218
|
+
}
|
|
3219
|
+
}
|
|
3220
|
+
}
|
|
3221
|
+
return undefined;
|
|
3222
|
+
}
|
|
2529
3223
|
}
|
|
2530
3224
|
|
|
2531
3225
|
class NavManager extends React.PureComponent {
|
|
@@ -2538,6 +3232,9 @@ class NavManager extends React.PureComponent {
|
|
|
2538
3232
|
back: (animationBuilder) => {
|
|
2539
3233
|
this.goBack(undefined, animationBuilder);
|
|
2540
3234
|
},
|
|
3235
|
+
navigateRoot: (pathname, animationBuilder) => {
|
|
3236
|
+
this.props.onNavigateRoot(pathname, animationBuilder);
|
|
3237
|
+
},
|
|
2541
3238
|
canGoBack: () => this.props.locationHistory.canGoBack(),
|
|
2542
3239
|
nativeBack: () => this.props.onNativeBack(),
|
|
2543
3240
|
routeInfo: this.props.routeInfo,
|
|
@@ -2546,10 +3243,8 @@ class NavManager extends React.PureComponent {
|
|
|
2546
3243
|
goBack: this.goBack.bind(this),
|
|
2547
3244
|
hasIonicRouter: () => true,
|
|
2548
3245
|
navigate: this.navigate.bind(this),
|
|
2549
|
-
getIonRedirect: this.getIonRedirect.bind(this),
|
|
2550
3246
|
getIonRoute: this.getIonRoute.bind(this),
|
|
2551
3247
|
getStackManager: this.getStackManager.bind(this),
|
|
2552
|
-
getPageManager: this.getPageManager.bind(this),
|
|
2553
3248
|
routeInfo: this.props.routeInfo,
|
|
2554
3249
|
setCurrentTab: this.props.onSetCurrentTab,
|
|
2555
3250
|
changeTab: this.props.onChangeTab,
|
|
@@ -2582,12 +3277,6 @@ class NavManager extends React.PureComponent {
|
|
|
2582
3277
|
navigate(path, direction = 'forward', action = 'push', animationBuilder, options, tab) {
|
|
2583
3278
|
this.props.onNavigate(path, action, direction, animationBuilder, options, tab);
|
|
2584
3279
|
}
|
|
2585
|
-
getPageManager() {
|
|
2586
|
-
return PageManager;
|
|
2587
|
-
}
|
|
2588
|
-
getIonRedirect() {
|
|
2589
|
-
return this.props.ionRedirect;
|
|
2590
|
-
}
|
|
2591
3280
|
getIonRoute() {
|
|
2592
3281
|
return this.props.ionRoute;
|
|
2593
3282
|
}
|
|
@@ -2617,10 +3306,7 @@ class ViewStacks {
|
|
|
2617
3306
|
}
|
|
2618
3307
|
}
|
|
2619
3308
|
clear(outletId) {
|
|
2620
|
-
|
|
2621
|
-
return setTimeout(() => {
|
|
2622
|
-
delete this.viewStacks[outletId];
|
|
2623
|
-
}, 500);
|
|
3309
|
+
delete this.viewStacks[outletId];
|
|
2624
3310
|
}
|
|
2625
3311
|
getViewItemsForOutlet(outletId) {
|
|
2626
3312
|
return this.viewStacks[outletId] || [];
|
|
@@ -2649,5 +3335,5 @@ class ViewStacks {
|
|
|
2649
3335
|
}
|
|
2650
3336
|
}
|
|
2651
3337
|
|
|
2652
|
-
export { CreateAnimation, DefaultIonLifeCycleContext, IonAccordion, IonAccordionGroup, IonActionSheet, IonAlert, IonApp, IonAvatar, IonBackButton, IonBackdrop, IonBadge, IonBreadcrumb, IonBreadcrumbs, IonButton, IonButtons, IonCard, IonCardContent, IonCardHeader, IonCardSubtitle, IonCardTitle, IonCheckbox, IonChip, IonCol, IonContent, IonDatetime, IonDatetimeButton,
|
|
3338
|
+
export { CreateAnimation, DefaultIonLifeCycleContext, IonAccordion, IonAccordionGroup, IonActionSheet, IonAlert, IonApp, IonAvatar, IonBackButton, IonBackdrop, IonBadge, IonBreadcrumb, IonBreadcrumbs, IonButton, IonButtons, IonCard, IonCardContent, IonCardHeader, IonCardSubtitle, IonCardTitle, IonCheckbox, IonChip, IonCol, IonContent, IonDatetime, IonDatetimeButton, IonFab, IonFabButton, IonFabList, IonFooter, IonGrid, IonHeader, IonIcon, IonImg, IonInfiniteScroll, IonInfiniteScrollContent, IonInput, IonInputOtp, IonInputPasswordToggle, IonItem, IonItemDivider, IonItemGroup, IonItemOption, IonItemOptions, IonItemSliding, IonLabel, IonLifeCycleContext, IonList, IonListHeader, IonLoading, IonMenu, IonMenuButton, IonMenuToggle, IonModal, IonNav, IonNavLink, IonNote, IonPage, IonPicker, IonPickerColumn, IonPickerColumnOption, IonPopover, IonProgressBar, IonRadio, IonRadioGroup, IonRange, IonRefresher, IonRefresherContent, IonReorder, IonReorderGroup, IonRippleEffect, IonRoute, IonRouterContext, IonRouterLink, IonRouterOutlet, IonRow, IonSearchbar, IonSegment, IonSegmentButton, IonSegmentContent, IonSegmentView, IonSelect, IonSelectModal, IonSelectOption, IonSkeletonText, IonSpinner, IonSplitPane, IonTab, IonTabBar, IonTabButton, IonTabs, IonTabsContext, IonText, IonTextarea, IonThumbnail, IonTitle, IonToast, IonToggle, IonToolbar, LocationHistory, NavContext, NavManager, RouteManagerContext, StackContext, ViewLifeCycleManager, ViewStacks, generateId, getConfig, getPlatforms, isPlatform, setupIonicReact, useIonActionSheet, useIonAlert, useIonLoading, useIonModal, useIonPopover, useIonRouter, useIonToast, useIonViewDidEnter, useIonViewDidLeave, useIonViewWillEnter, useIonViewWillLeave, withIonLifeCycle };
|
|
2653
3339
|
//# sourceMappingURL=index.js.map
|