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