@ionic/react 8.8.6-dev.11777572994.1147595d → 8.8.6-dev.11777668103.132817bd
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 { defineCustomElement as defineCustomElement$
|
|
87
|
-
import { defineCustomElement as defineCustomElement$
|
|
88
|
-
import { defineCustomElement as defineCustomElement$
|
|
89
|
-
import { defineCustomElement as defineCustomElement$
|
|
90
|
-
import { defineCustomElement as defineCustomElement$
|
|
91
|
-
import
|
|
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
|
}
|
|
@@ -1543,17 +992,19 @@ const createInlineOverlayComponent = (tagName, defineCustomElement, hasDelegateH
|
|
|
1543
992
|
};
|
|
1544
993
|
const DELEGATE_HOST = 'ion-delegate-host';
|
|
1545
994
|
|
|
1546
|
-
const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$
|
|
995
|
+
const IonAlert = /*@__PURE__*/ createInlineOverlayComponent('ion-alert', defineCustomElement$1a);
|
|
996
|
+
|
|
997
|
+
const IonLoading = /*@__PURE__*/ createInlineOverlayComponent('ion-loading', defineCustomElement$1b);
|
|
1547
998
|
|
|
1548
|
-
const
|
|
999
|
+
const IonToast = /*@__PURE__*/ createInlineOverlayComponent('ion-toast', defineCustomElement$1c);
|
|
1549
1000
|
|
|
1550
|
-
const
|
|
1001
|
+
const IonPickerLegacy = /*@__PURE__*/ createInlineOverlayComponent('ion-picker-legacy', defineCustomElement$1d);
|
|
1551
1002
|
|
|
1552
|
-
const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$
|
|
1003
|
+
const IonActionSheet = /*@__PURE__*/ createInlineOverlayComponent('ion-action-sheet', defineCustomElement$1e);
|
|
1553
1004
|
|
|
1554
|
-
const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$
|
|
1005
|
+
const IonModal = /*@__PURE__*/ createInlineOverlayComponent('ion-modal', defineCustomElement$1f, true);
|
|
1555
1006
|
|
|
1556
|
-
const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$
|
|
1007
|
+
const IonPopover = /*@__PURE__*/ createInlineOverlayComponent('ion-popover', defineCustomElement$1g);
|
|
1557
1008
|
|
|
1558
1009
|
const IonContext = React.createContext({
|
|
1559
1010
|
addOverlay: () => {
|
|
@@ -1645,81 +1096,14 @@ const IonOverlayManager = ({ onAddOverlay, onRemoveOverlay }) => {
|
|
|
1645
1096
|
}) }));
|
|
1646
1097
|
};
|
|
1647
1098
|
|
|
1648
|
-
const
|
|
1649
|
-
|
|
1650
|
-
|
|
1651
|
-
|
|
1652
|
-
|
|
1653
|
-
|
|
1654
|
-
constructor(props) {
|
|
1655
|
-
super(props);
|
|
1656
|
-
this.setComponentElRef = (element) => {
|
|
1657
|
-
this.componentEl = element;
|
|
1658
|
-
};
|
|
1659
|
-
}
|
|
1660
|
-
componentDidMount() {
|
|
1661
|
-
this.componentDidUpdate(this.props);
|
|
1662
|
-
}
|
|
1663
|
-
componentDidUpdate(prevProps) {
|
|
1664
|
-
attachProps(this.componentEl, this.props, prevProps);
|
|
1665
|
-
}
|
|
1666
|
-
render() {
|
|
1667
|
-
const { children, forwardedRef, style, className, ref, ...cProps } = this.props;
|
|
1668
|
-
let propsToPass = Object.keys(cProps).reduce((acc, name) => {
|
|
1669
|
-
const value = cProps[name];
|
|
1670
|
-
if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) {
|
|
1671
|
-
const eventName = name.substring(2).toLowerCase();
|
|
1672
|
-
if (typeof document !== 'undefined' && isCoveredByReact(eventName)) {
|
|
1673
|
-
acc[name] = value;
|
|
1674
|
-
}
|
|
1675
|
-
}
|
|
1676
|
-
else {
|
|
1677
|
-
// we should only render strings, booleans, and numbers as attrs in html.
|
|
1678
|
-
// objects, functions, arrays etc get synced via properties on mount.
|
|
1679
|
-
const type = typeof value;
|
|
1680
|
-
if (type === 'string' || type === 'boolean' || type === 'number') {
|
|
1681
|
-
acc[camelToDashCase(name)] = value;
|
|
1682
|
-
}
|
|
1683
|
-
}
|
|
1684
|
-
return acc;
|
|
1685
|
-
}, {});
|
|
1686
|
-
if (manipulatePropsFunction) {
|
|
1687
|
-
propsToPass = manipulatePropsFunction(this.props, propsToPass);
|
|
1688
|
-
}
|
|
1689
|
-
const newProps = {
|
|
1690
|
-
...propsToPass,
|
|
1691
|
-
ref: mergeRefs(forwardedRef, this.setComponentElRef),
|
|
1692
|
-
style,
|
|
1693
|
-
children
|
|
1694
|
-
};
|
|
1695
|
-
/**
|
|
1696
|
-
* We use createElement here instead of
|
|
1697
|
-
* React.createElement to work around a
|
|
1698
|
-
* bug in Vite (https://github.com/vitejs/vite/issues/6104).
|
|
1699
|
-
* React.createElement causes all elements to be rendered
|
|
1700
|
-
* as <tagname> instead of the actual Web Component.
|
|
1701
|
-
*/
|
|
1702
|
-
return createElement(tagName, newProps, children);
|
|
1703
|
-
}
|
|
1704
|
-
static get displayName() {
|
|
1705
|
-
return displayName;
|
|
1706
|
-
}
|
|
1707
|
-
};
|
|
1708
|
-
// If context was passed to createReactComponent then conditionally add it to the Component Class
|
|
1709
|
-
if (ReactComponentContext) {
|
|
1710
|
-
ReactComponent.contextType = ReactComponentContext;
|
|
1711
|
-
}
|
|
1712
|
-
return createForwardRef$1(ReactComponent, displayName);
|
|
1713
|
-
};
|
|
1714
|
-
|
|
1715
|
-
const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1e);
|
|
1716
|
-
const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1f);
|
|
1717
|
-
const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1g);
|
|
1718
|
-
const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1h);
|
|
1719
|
-
const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1i);
|
|
1720
|
-
const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1j);
|
|
1099
|
+
const IonTabButtonInner = /*@__PURE__*/ createReactComponent('ion-tab-button', undefined, undefined, defineCustomElement$1h);
|
|
1100
|
+
const IonTabBarInner = /*@__PURE__*/ createReactComponent('ion-tab-bar', undefined, undefined, defineCustomElement$1i);
|
|
1101
|
+
const IonTabsInner = /*@__PURE__*/ createReactComponent('ion-tabs', undefined, undefined, defineCustomElement$1j);
|
|
1102
|
+
const IonBackButtonInner = /*@__PURE__*/ createReactComponent('ion-back-button', undefined, undefined, defineCustomElement$1k);
|
|
1103
|
+
const IonRouterOutletInner = /*@__PURE__*/ createReactComponent('ion-router-outlet', undefined, undefined, defineCustomElement$1l);
|
|
1104
|
+
const IonAppInner = /*@__PURE__*/ createReactComponent('ion-app', undefined, undefined, defineCustomElement$1m);
|
|
1721
1105
|
// ionicons
|
|
1722
|
-
const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$
|
|
1106
|
+
const IonIconInner = /*@__PURE__*/ createReactComponent('ion-icon', undefined, undefined, defineCustomElement$1n);
|
|
1723
1107
|
|
|
1724
1108
|
class IonApp extends React.Component {
|
|
1725
1109
|
constructor(props) {
|
|
@@ -1757,25 +1141,7 @@ class PageManager extends React.PureComponent {
|
|
|
1757
1141
|
super(props);
|
|
1758
1142
|
this.ionPageElementRef = React.createRef();
|
|
1759
1143
|
// React refs must be stable (not created inline).
|
|
1760
|
-
|
|
1761
|
-
const baseMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
|
|
1762
|
-
// Guard against React 19 strict mode double-mount re-adding ion-page-invisible.
|
|
1763
|
-
// The ref fires again on remount after StackManager may have already removed it.
|
|
1764
|
-
let hasAppliedInvisible = false;
|
|
1765
|
-
this.stableMergedRefs = (node) => {
|
|
1766
|
-
if (node &&
|
|
1767
|
-
!hasAppliedInvisible &&
|
|
1768
|
-
!node.classList.contains('ion-page-invisible') &&
|
|
1769
|
-
!node.classList.contains('ion-page-hidden')) {
|
|
1770
|
-
// Add ion-page-invisible synchronously before first paint (if in an outlet)
|
|
1771
|
-
// This prevents the flash that occurs when componentDidMount runs after paint
|
|
1772
|
-
if (this.context?.isInOutlet?.()) {
|
|
1773
|
-
node.classList.add('ion-page-invisible');
|
|
1774
|
-
hasAppliedInvisible = true;
|
|
1775
|
-
}
|
|
1776
|
-
}
|
|
1777
|
-
baseMergedRefs(node);
|
|
1778
|
-
};
|
|
1144
|
+
this.stableMergedRefs = mergeRefs(this.ionPageElementRef, this.props.forwardedRef);
|
|
1779
1145
|
/**
|
|
1780
1146
|
* This binds the scope of the following methods to the class scope.
|
|
1781
1147
|
* The `.bind` method returns a new function, so we need to assign it
|
|
@@ -1787,38 +1153,11 @@ class PageManager extends React.PureComponent {
|
|
|
1787
1153
|
this.ionViewWillLeaveHandler = this.ionViewWillLeaveHandler.bind(this);
|
|
1788
1154
|
this.ionViewDidLeaveHandler = this.ionViewDidLeaveHandler.bind(this);
|
|
1789
1155
|
}
|
|
1790
|
-
parseClasses(className) {
|
|
1791
|
-
if (!className)
|
|
1792
|
-
return new Set();
|
|
1793
|
-
return new Set(className.split(/\s+/).filter(Boolean));
|
|
1794
|
-
}
|
|
1795
|
-
/**
|
|
1796
|
-
* Updates classList by diffing old/new className props.
|
|
1797
|
-
* Preserves framework-added classes (can-go-back, ion-page-invisible, etc.).
|
|
1798
|
-
*/
|
|
1799
|
-
updateUserClasses(oldClassName, newClassName) {
|
|
1800
|
-
if (!this.ionPageElementRef.current)
|
|
1801
|
-
return;
|
|
1802
|
-
const oldClasses = this.parseClasses(oldClassName);
|
|
1803
|
-
const newClasses = this.parseClasses(newClassName);
|
|
1804
|
-
oldClasses.forEach((cls) => {
|
|
1805
|
-
if (!newClasses.has(cls)) {
|
|
1806
|
-
this.ionPageElementRef.current.classList.remove(cls);
|
|
1807
|
-
}
|
|
1808
|
-
});
|
|
1809
|
-
newClasses.forEach((cls) => {
|
|
1810
|
-
if (!oldClasses.has(cls)) {
|
|
1811
|
-
this.ionPageElementRef.current.classList.add(cls);
|
|
1812
|
-
}
|
|
1813
|
-
});
|
|
1814
|
-
}
|
|
1815
1156
|
componentDidMount() {
|
|
1816
1157
|
if (this.ionPageElementRef.current) {
|
|
1817
|
-
|
|
1818
|
-
|
|
1819
|
-
|
|
1820
|
-
// The ref callback runs synchronously when the element is created, before the browser paints.
|
|
1821
|
-
this.updateUserClasses(undefined, this.props.className);
|
|
1158
|
+
if (this.context.isInOutlet()) {
|
|
1159
|
+
this.ionPageElementRef.current.classList.add('ion-page-invisible');
|
|
1160
|
+
}
|
|
1822
1161
|
this.context.registerIonPage(this.ionPageElementRef.current, this.props.routeInfo);
|
|
1823
1162
|
this.ionPageElementRef.current.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
|
|
1824
1163
|
this.ionPageElementRef.current.addEventListener('ionViewDidEnter', this.ionViewDidEnterHandler);
|
|
@@ -1826,11 +1165,6 @@ class PageManager extends React.PureComponent {
|
|
|
1826
1165
|
this.ionPageElementRef.current.addEventListener('ionViewDidLeave', this.ionViewDidLeaveHandler);
|
|
1827
1166
|
}
|
|
1828
1167
|
}
|
|
1829
|
-
componentDidUpdate(prevProps) {
|
|
1830
|
-
if (prevProps.className !== this.props.className) {
|
|
1831
|
-
this.updateUserClasses(prevProps.className, this.props.className);
|
|
1832
|
-
}
|
|
1833
|
-
}
|
|
1834
1168
|
componentWillUnmount() {
|
|
1835
1169
|
if (this.ionPageElementRef.current) {
|
|
1836
1170
|
this.ionPageElementRef.current.removeEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
|
|
@@ -1860,11 +1194,9 @@ class PageManager extends React.PureComponent {
|
|
|
1860
1194
|
render() {
|
|
1861
1195
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
1862
1196
|
const { className, children, routeInfo, forwardedRef, ...props } = this.props;
|
|
1863
|
-
// Only set "ion-page" in JSX. User classes are managed via DOM in componentDidMount/componentDidUpdate
|
|
1864
|
-
// to preserve framework-added classes (can-go-back, ion-page-invisible, etc.) when className prop changes.
|
|
1865
1197
|
return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
|
|
1866
1198
|
this.ionLifeCycleContext = context;
|
|
1867
|
-
return (jsx("div", { className:
|
|
1199
|
+
return (jsx("div", { className: className ? `${className} ion-page` : `ion-page`, ref: this.stableMergedRefs, ...props, children: children }));
|
|
1868
1200
|
} }));
|
|
1869
1201
|
}
|
|
1870
1202
|
static get contextType() {
|
|
@@ -1924,7 +1256,7 @@ const ReactDelegate = (addView, removeView) => {
|
|
|
1924
1256
|
};
|
|
1925
1257
|
};
|
|
1926
1258
|
|
|
1927
|
-
const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$
|
|
1259
|
+
const IonNavInner = createReactComponent('ion-nav', undefined, undefined, defineCustomElement$1o);
|
|
1928
1260
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
1929
1261
|
const IonNavInternal = ({ children, forwardedRef, ...restOfProps }) => {
|
|
1930
1262
|
const [views, setViews] = useState([]);
|
|
@@ -1972,30 +1304,8 @@ class OutletPageManager extends React.Component {
|
|
|
1972
1304
|
*/
|
|
1973
1305
|
if (!this.outletIsReady) {
|
|
1974
1306
|
componentOnReady(this.ionRouterOutlet, () => {
|
|
1975
|
-
/**
|
|
1976
|
-
* Guard against duplicate callbacks from React strict mode double-mount.
|
|
1977
|
-
* Both componentDidMount calls pass the outer !outletIsReady check before
|
|
1978
|
-
* either async callback fires. Without this inner guard, the second callback
|
|
1979
|
-
* re-adds ion-page-invisible after the first callback's transition removed it,
|
|
1980
|
-
* and registerIonPage returns early (same element), leaving the page invisible.
|
|
1981
|
-
*/
|
|
1982
|
-
if (this.outletIsReady)
|
|
1983
|
-
return;
|
|
1984
1307
|
this.outletIsReady = true;
|
|
1985
|
-
|
|
1986
|
-
* Add ion-page + ion-page-invisible AFTER Stencil hydration but
|
|
1987
|
-
* BEFORE registerIonPage. Stencil hydration overwrites className,
|
|
1988
|
-
* so classes added in a React ref callback get wiped. Adding them
|
|
1989
|
-
* here -- after hydration -- ensures they persist until the parent
|
|
1990
|
-
* outlet's forward animation removes ion-page-invisible, preventing
|
|
1991
|
-
* a flash where the outlet is briefly visible at full opacity.
|
|
1992
|
-
*/
|
|
1993
|
-
const el = this.ionRouterOutlet;
|
|
1994
|
-
if (!el.classList.contains('ion-page-invisible') && !el.classList.contains('ion-page-hidden')) {
|
|
1995
|
-
el.classList.add('ion-page');
|
|
1996
|
-
el.classList.add('ion-page-invisible');
|
|
1997
|
-
}
|
|
1998
|
-
this.context.registerIonPage(el, this.props.routeInfo);
|
|
1308
|
+
this.context.registerIonPage(this.ionRouterOutlet, this.props.routeInfo);
|
|
1999
1309
|
});
|
|
2000
1310
|
}
|
|
2001
1311
|
this.ionRouterOutlet.addEventListener('ionViewWillEnter', this.ionViewWillEnterHandler);
|
|
@@ -2025,10 +1335,10 @@ class OutletPageManager extends React.Component {
|
|
|
2025
1335
|
this.ionLifeCycleContext.ionViewDidLeave();
|
|
2026
1336
|
}
|
|
2027
1337
|
render() {
|
|
2028
|
-
const { StackManager, children, routeInfo,
|
|
1338
|
+
const { StackManager, children, routeInfo, ...props } = this.props;
|
|
2029
1339
|
return (jsx(IonLifeCycleContext.Consumer, { children: (context) => {
|
|
2030
1340
|
this.ionLifeCycleContext = context;
|
|
2031
|
-
return (jsx(StackManager, {
|
|
1341
|
+
return (jsx(StackManager, { routeInfo: routeInfo, children: jsx(IonRouterOutletInner, { setRef: (val) => (this.ionRouterOutlet = val), ...props, children: children }) }));
|
|
2032
1342
|
} }));
|
|
2033
1343
|
}
|
|
2034
1344
|
static get contextType() {
|
|
@@ -2039,13 +1349,11 @@ class OutletPageManager extends React.Component {
|
|
|
2039
1349
|
class IonRouterOutletContainer extends React.Component {
|
|
2040
1350
|
constructor(props) {
|
|
2041
1351
|
super(props);
|
|
2042
|
-
this.outletId = props.id ?? `routerOutlet-${generateId('routerOutlet')}`;
|
|
2043
1352
|
}
|
|
2044
1353
|
render() {
|
|
2045
1354
|
const StackManager = this.context.getStackManager();
|
|
2046
1355
|
const { children, forwardedRef, ...props } = this.props;
|
|
2047
|
-
|
|
2048
|
-
return this.context.hasIonicRouter() ? (props.ionPage ? (jsx(OutletPageManager, { StackManager: StackManager, routeInfo: this.context.routeInfo, ...props, children: children })) : (jsx(StackManager, { routeInfo: this.context.routeInfo, id: outletId, children: jsx(IonRouterOutletInner, { ...props, id: outletId, forwardedRef: forwardedRef, children: children }) }))) : (jsx(IonRouterOutletInner, { ref: forwardedRef, ...this.props, children: this.props.children }));
|
|
1356
|
+
return this.context.hasIonicRouter() ? (props.ionPage ? (jsx(OutletPageManager, { StackManager: StackManager, routeInfo: this.context.routeInfo, ...props, children: children })) : (jsx(StackManager, { routeInfo: this.context.routeInfo, children: jsx(IonRouterOutletInner, { ...props, forwardedRef: forwardedRef, children: children }) }))) : (jsx(IonRouterOutletInner, { ref: forwardedRef, ...this.props, children: this.props.children }));
|
|
2049
1357
|
}
|
|
2050
1358
|
static get contextType() {
|
|
2051
1359
|
return NavContext;
|
|
@@ -2242,9 +1550,7 @@ const matchesTab = (pathname, href) => {
|
|
|
2242
1550
|
if (href === undefined) {
|
|
2243
1551
|
return false;
|
|
2244
1552
|
}
|
|
2245
|
-
|
|
2246
|
-
const hrefPathname = href.split('?')[0];
|
|
2247
|
-
const normalizedHref = hrefPathname.endsWith('/') && hrefPathname !== '/' ? hrefPathname.slice(0, -1) : hrefPathname;
|
|
1553
|
+
const normalizedHref = href.endsWith('/') && href !== '/' ? href.slice(0, -1) : href;
|
|
2248
1554
|
return pathname === normalizedHref || pathname.startsWith(normalizedHref + '/');
|
|
2249
1555
|
};
|
|
2250
1556
|
class IonTabBarUnwrapped extends React.PureComponent {
|
|
@@ -2336,7 +1642,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
|
|
|
2336
1642
|
const prevHref = state.tabs[prevActiveTab].currentHref;
|
|
2337
1643
|
const prevRouteOptions = state.tabs[prevActiveTab].currentRouteOptions;
|
|
2338
1644
|
if (activeTab !== prevActiveTab ||
|
|
2339
|
-
prevHref !==
|
|
1645
|
+
prevHref !== props.routeInfo?.pathname ||
|
|
2340
1646
|
prevRouteOptions !== props.routeInfo?.routeOptions) {
|
|
2341
1647
|
tabs[activeTab] = {
|
|
2342
1648
|
originalHref: tabs[activeTab].originalHref,
|
|
@@ -2403,7 +1709,7 @@ class IonTabBarUnwrapped extends React.PureComponent {
|
|
|
2403
1709
|
return (child) => {
|
|
2404
1710
|
if (child != null && child.props && (child.type === IonTabButton || child.type.isTabButton)) {
|
|
2405
1711
|
const href = child.props.tab === activeTab
|
|
2406
|
-
?
|
|
1712
|
+
? this.props.routeInfo?.pathname
|
|
2407
1713
|
: this.state.tabs[child.props.tab].currentHref;
|
|
2408
1714
|
const routeOptions = child.props.tab === activeTab
|
|
2409
1715
|
? this.props.routeInfo?.routeOptions
|
|
@@ -2528,6 +1834,20 @@ class IonRoute extends React.PureComponent {
|
|
|
2528
1834
|
}
|
|
2529
1835
|
}
|
|
2530
1836
|
|
|
1837
|
+
class IonRedirect extends React.PureComponent {
|
|
1838
|
+
render() {
|
|
1839
|
+
const IonRedirectInner = this.context.getIonRedirect();
|
|
1840
|
+
if (!this.context.hasIonicRouter() || !IonRedirect) {
|
|
1841
|
+
console.error('You either do not have an Ionic Router package, or your router does not support using <IonRedirect>');
|
|
1842
|
+
return null;
|
|
1843
|
+
}
|
|
1844
|
+
return jsx(IonRedirectInner, { ...this.props });
|
|
1845
|
+
}
|
|
1846
|
+
static get contextType() {
|
|
1847
|
+
return NavContext;
|
|
1848
|
+
}
|
|
1849
|
+
}
|
|
1850
|
+
|
|
2531
1851
|
const IonRouterContext = React.createContext({
|
|
2532
1852
|
routeInfo: undefined, // TODO(FW-2959): type
|
|
2533
1853
|
push: () => {
|
|
@@ -2536,9 +1856,6 @@ const IonRouterContext = React.createContext({
|
|
|
2536
1856
|
back: () => {
|
|
2537
1857
|
throw new Error('An Ionic Router is required for IonRouterContext');
|
|
2538
1858
|
},
|
|
2539
|
-
navigateRoot: () => {
|
|
2540
|
-
throw new Error('An Ionic Router is required for IonRouterContext');
|
|
2541
|
-
},
|
|
2542
1859
|
canGoBack: () => {
|
|
2543
1860
|
throw new Error('An Ionic Router is required for IonRouterContext');
|
|
2544
1861
|
},
|
|
@@ -2555,10 +1872,9 @@ function useIonRouter() {
|
|
|
2555
1872
|
back: context.back,
|
|
2556
1873
|
push: context.push,
|
|
2557
1874
|
goBack: context.back,
|
|
2558
|
-
navigateRoot: context.navigateRoot,
|
|
2559
1875
|
canGoBack: context.canGoBack,
|
|
2560
1876
|
routeInfo: context.routeInfo,
|
|
2561
|
-
}), [context.back, context.push, context.
|
|
1877
|
+
}), [context.back, context.push, context.canGoBack, context.routeInfo]);
|
|
2562
1878
|
}
|
|
2563
1879
|
|
|
2564
1880
|
class CreateAnimation extends React.PureComponent {
|
|
@@ -2712,7 +2028,7 @@ function useController(displayName, controller, defineCustomElement) {
|
|
|
2712
2028
|
* @returns Returns the present and dismiss methods in an array
|
|
2713
2029
|
*/
|
|
2714
2030
|
function useIonActionSheet() {
|
|
2715
|
-
const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$
|
|
2031
|
+
const controller = useController('IonActionSheet', actionSheetController, defineCustomElement$1e);
|
|
2716
2032
|
const present = useCallback((buttonsOrOptions, header) => {
|
|
2717
2033
|
if (Array.isArray(buttonsOrOptions)) {
|
|
2718
2034
|
return controller.present({
|
|
@@ -2732,7 +2048,7 @@ function useIonActionSheet() {
|
|
|
2732
2048
|
* @returns Returns the present and dismiss methods in an array
|
|
2733
2049
|
*/
|
|
2734
2050
|
function useIonAlert() {
|
|
2735
|
-
const controller = useController('IonAlert', alertController, defineCustomElement$
|
|
2051
|
+
const controller = useController('IonAlert', alertController, defineCustomElement$1a);
|
|
2736
2052
|
const present = useCallback((messageOrOptions, buttons) => {
|
|
2737
2053
|
if (typeof messageOrOptions === 'string') {
|
|
2738
2054
|
return controller.present({
|
|
@@ -2752,7 +2068,7 @@ function useIonAlert() {
|
|
|
2752
2068
|
* @returns Returns the present and dismiss methods in an array
|
|
2753
2069
|
*/
|
|
2754
2070
|
function useIonToast() {
|
|
2755
|
-
const controller = useController('IonToast', toastController, defineCustomElement$
|
|
2071
|
+
const controller = useController('IonToast', toastController, defineCustomElement$1c);
|
|
2756
2072
|
const present = useCallback((messageOrOptions, duration) => {
|
|
2757
2073
|
if (typeof messageOrOptions === 'string') {
|
|
2758
2074
|
return controller.present({
|
|
@@ -2838,7 +2154,7 @@ function useOverlay(displayName, controller, defineCustomElement, component, com
|
|
|
2838
2154
|
* @returns Returns the present and dismiss methods in an array
|
|
2839
2155
|
*/
|
|
2840
2156
|
function useIonModal(component, componentProps) {
|
|
2841
|
-
const controller = useOverlay('IonModal', modalController, defineCustomElement$
|
|
2157
|
+
const controller = useOverlay('IonModal', modalController, defineCustomElement$1f, component, componentProps);
|
|
2842
2158
|
const present = useCallback((options = {}) => {
|
|
2843
2159
|
controller.present(options);
|
|
2844
2160
|
}, [controller.present]);
|
|
@@ -2853,19 +2169,40 @@ function useIonModal(component, componentProps) {
|
|
|
2853
2169
|
* @returns Returns the present and dismiss methods in an array
|
|
2854
2170
|
*/
|
|
2855
2171
|
function useIonPopover(component, componentProps) {
|
|
2856
|
-
const controller = useOverlay('IonPopover', popoverController, defineCustomElement$
|
|
2172
|
+
const controller = useOverlay('IonPopover', popoverController, defineCustomElement$1g, component, componentProps);
|
|
2857
2173
|
const present = useCallback((options = {}) => {
|
|
2858
2174
|
controller.present(options);
|
|
2859
2175
|
}, [controller.present]);
|
|
2860
2176
|
return [present, controller.dismiss];
|
|
2861
2177
|
}
|
|
2862
2178
|
|
|
2179
|
+
/**
|
|
2180
|
+
* A hook for presenting/dismissing an IonPicker component
|
|
2181
|
+
* @returns Returns the present and dismiss methods in an array
|
|
2182
|
+
* @deprecated Use the inline ion-picker component instead.
|
|
2183
|
+
*/
|
|
2184
|
+
function useIonPicker() {
|
|
2185
|
+
const controller = useController('IonPicker', pickerController, defineCustomElement$1d);
|
|
2186
|
+
const present = useCallback((columnsOrOptions, buttons) => {
|
|
2187
|
+
if (Array.isArray(columnsOrOptions)) {
|
|
2188
|
+
return controller.present({
|
|
2189
|
+
columns: columnsOrOptions,
|
|
2190
|
+
buttons: buttons ?? [{ text: 'Ok' }],
|
|
2191
|
+
});
|
|
2192
|
+
}
|
|
2193
|
+
else {
|
|
2194
|
+
return controller.present(columnsOrOptions);
|
|
2195
|
+
}
|
|
2196
|
+
}, [controller.present]);
|
|
2197
|
+
return [present, controller.dismiss];
|
|
2198
|
+
}
|
|
2199
|
+
|
|
2863
2200
|
/**
|
|
2864
2201
|
* A hook for presenting/dismissing an IonLoading component
|
|
2865
2202
|
* @returns Returns the present and dismiss methods in an array
|
|
2866
2203
|
*/
|
|
2867
2204
|
function useIonLoading() {
|
|
2868
|
-
const controller = useController('IonLoading', loadingController, defineCustomElement$
|
|
2205
|
+
const controller = useController('IonLoading', loadingController, defineCustomElement$1b);
|
|
2869
2206
|
const present = useCallback((messageOrOptions = {}, duration, spinner) => {
|
|
2870
2207
|
if (typeof messageOrOptions === 'string') {
|
|
2871
2208
|
return controller.present({
|
|
@@ -2907,7 +2244,6 @@ const RouteManagerContext = /*@__PURE__*/ React.createContext({
|
|
|
2907
2244
|
findLeavingViewItemByRouteInfo: () => undefined,
|
|
2908
2245
|
findViewItemByRouteInfo: () => undefined,
|
|
2909
2246
|
getChildrenToRender: () => undefined,
|
|
2910
|
-
getViewItemsForOutlet: () => [],
|
|
2911
2247
|
goBack: () => undefined,
|
|
2912
2248
|
unMountViewItem: () => undefined,
|
|
2913
2249
|
});
|
|
@@ -3026,14 +2362,7 @@ class LocationHistory {
|
|
|
3026
2362
|
_replace(routeInfo) {
|
|
3027
2363
|
const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
|
|
3028
2364
|
routeInfos && routeInfos.pop();
|
|
3029
|
-
|
|
3030
|
-
const currentRoute = this.locationHistory[this.locationHistory.length - 1];
|
|
3031
|
-
// Only pop from global history if we're replacing in the same outlet context.
|
|
3032
|
-
// Don't pop if we're entering a nested outlet (current route has no tab, new route has a tab)
|
|
3033
|
-
const isEnteringNestedOutlet = currentRoute && !currentRoute.tab && !!routeInfo.tab;
|
|
3034
|
-
if (!isEnteringNestedOutlet) {
|
|
3035
|
-
this.locationHistory.pop();
|
|
3036
|
-
}
|
|
2365
|
+
this.locationHistory.pop();
|
|
3037
2366
|
this._add(routeInfo);
|
|
3038
2367
|
}
|
|
3039
2368
|
_clear() {
|
|
@@ -3065,20 +2394,6 @@ class LocationHistory {
|
|
|
3065
2394
|
}
|
|
3066
2395
|
return undefined;
|
|
3067
2396
|
}
|
|
3068
|
-
/**
|
|
3069
|
-
* Returns the most recent RouteInfo in global history (excluding the current
|
|
3070
|
-
* entry) whose pathname matches the given value. Unlike findLastLocation,
|
|
3071
|
-
* this search is tab-agnostic. Used by the multi-step back detection.
|
|
3072
|
-
*/
|
|
3073
|
-
findLastLocationByPathname(pathname) {
|
|
3074
|
-
for (let i = this.locationHistory.length - 2; i >= 0; i--) {
|
|
3075
|
-
const ri = this.locationHistory[i];
|
|
3076
|
-
if (ri && ri.pathname === pathname) {
|
|
3077
|
-
return ri;
|
|
3078
|
-
}
|
|
3079
|
-
}
|
|
3080
|
-
return undefined;
|
|
3081
|
-
}
|
|
3082
2397
|
findLastLocation(routeInfo) {
|
|
3083
2398
|
const routeInfos = this._getRouteInfosByKey(routeInfo.tab);
|
|
3084
2399
|
if (routeInfos) {
|
|
@@ -3110,17 +2425,6 @@ class LocationHistory {
|
|
|
3110
2425
|
canGoBack() {
|
|
3111
2426
|
return this.locationHistory.length > 1;
|
|
3112
2427
|
}
|
|
3113
|
-
findTabForPathname(pathname) {
|
|
3114
|
-
for (const tab of Object.keys(this.tabHistory)) {
|
|
3115
|
-
const routeInfos = this.tabHistory[tab];
|
|
3116
|
-
for (let i = routeInfos.length - 1; i >= 0; i--) {
|
|
3117
|
-
if (routeInfos[i].pathname === pathname) {
|
|
3118
|
-
return tab;
|
|
3119
|
-
}
|
|
3120
|
-
}
|
|
3121
|
-
}
|
|
3122
|
-
return undefined;
|
|
3123
|
-
}
|
|
3124
2428
|
}
|
|
3125
2429
|
|
|
3126
2430
|
class NavManager extends React.PureComponent {
|
|
@@ -3133,9 +2437,6 @@ class NavManager extends React.PureComponent {
|
|
|
3133
2437
|
back: (animationBuilder) => {
|
|
3134
2438
|
this.goBack(undefined, animationBuilder);
|
|
3135
2439
|
},
|
|
3136
|
-
navigateRoot: (pathname, animationBuilder) => {
|
|
3137
|
-
this.props.onNavigateRoot(pathname, animationBuilder);
|
|
3138
|
-
},
|
|
3139
2440
|
canGoBack: () => this.props.locationHistory.canGoBack(),
|
|
3140
2441
|
nativeBack: () => this.props.onNativeBack(),
|
|
3141
2442
|
routeInfo: this.props.routeInfo,
|
|
@@ -3144,8 +2445,10 @@ class NavManager extends React.PureComponent {
|
|
|
3144
2445
|
goBack: this.goBack.bind(this),
|
|
3145
2446
|
hasIonicRouter: () => true,
|
|
3146
2447
|
navigate: this.navigate.bind(this),
|
|
2448
|
+
getIonRedirect: this.getIonRedirect.bind(this),
|
|
3147
2449
|
getIonRoute: this.getIonRoute.bind(this),
|
|
3148
2450
|
getStackManager: this.getStackManager.bind(this),
|
|
2451
|
+
getPageManager: this.getPageManager.bind(this),
|
|
3149
2452
|
routeInfo: this.props.routeInfo,
|
|
3150
2453
|
setCurrentTab: this.props.onSetCurrentTab,
|
|
3151
2454
|
changeTab: this.props.onChangeTab,
|
|
@@ -3178,6 +2481,12 @@ class NavManager extends React.PureComponent {
|
|
|
3178
2481
|
navigate(path, direction = 'forward', action = 'push', animationBuilder, options, tab) {
|
|
3179
2482
|
this.props.onNavigate(path, action, direction, animationBuilder, options, tab);
|
|
3180
2483
|
}
|
|
2484
|
+
getPageManager() {
|
|
2485
|
+
return PageManager;
|
|
2486
|
+
}
|
|
2487
|
+
getIonRedirect() {
|
|
2488
|
+
return this.props.ionRedirect;
|
|
2489
|
+
}
|
|
3181
2490
|
getIonRoute() {
|
|
3182
2491
|
return this.props.ionRoute;
|
|
3183
2492
|
}
|
|
@@ -3207,7 +2516,10 @@ class ViewStacks {
|
|
|
3207
2516
|
}
|
|
3208
2517
|
}
|
|
3209
2518
|
clear(outletId) {
|
|
3210
|
-
|
|
2519
|
+
// Give some time for the leaving views to transition before removing
|
|
2520
|
+
return setTimeout(() => {
|
|
2521
|
+
delete this.viewStacks[outletId];
|
|
2522
|
+
}, 500);
|
|
3211
2523
|
}
|
|
3212
2524
|
getViewItemsForOutlet(outletId) {
|
|
3213
2525
|
return this.viewStacks[outletId] || [];
|
|
@@ -3236,5 +2548,5 @@ class ViewStacks {
|
|
|
3236
2548
|
}
|
|
3237
2549
|
}
|
|
3238
2550
|
|
|
3239
|
-
export { CreateAnimation, DefaultIonLifeCycleContext, IonAccordion, IonAccordionGroup, IonActionSheet, IonAlert, IonApp, IonAvatar, IonBackButton, IonBackdrop, IonBadge, IonBreadcrumb, IonBreadcrumbs, IonButton, IonButtons, IonCard, IonCardContent, IonCardHeader, IonCardSubtitle, IonCardTitle, IonCheckbox, IonChip, IonCol, IonContent, IonDatetime, IonDatetimeButton, IonFab, IonFabButton, IonFabList, IonFooter, IonGrid, IonHeader, IonIcon, IonImg, IonInfiniteScroll, IonInfiniteScrollContent, IonInput, IonInputOtp, IonInputPasswordToggle, IonItem, IonItemDivider, IonItemGroup, IonItemOption, IonItemOptions, IonItemSliding, IonLabel, IonLifeCycleContext, IonList, IonListHeader, IonLoading, IonMenu, IonMenuButton, IonMenuToggle, IonModal, IonNav, IonNavLink, IonNote, IonPage, IonPicker, IonPickerColumn, IonPickerColumnOption, IonPopover, IonProgressBar, IonRadio, IonRadioGroup, IonRange, IonRefresher, IonRefresherContent, IonReorder, IonReorderGroup, IonRippleEffect, IonRoute, IonRouterContext, IonRouterLink, IonRouterOutlet, IonRow, IonSearchbar, IonSegment, IonSegmentButton, IonSegmentContent, IonSegmentView, IonSelect, IonSelectModal, IonSelectOption, IonSkeletonText, IonSpinner, IonSplitPane, IonTab, IonTabBar, IonTabButton, IonTabs, IonTabsContext, IonText, IonTextarea, IonThumbnail, IonTitle, IonToast, IonToggle, IonToolbar, LocationHistory, NavContext, NavManager, RouteManagerContext, StackContext, ViewLifeCycleManager, ViewStacks, generateId, getConfig, getPlatforms, isPlatform, setupIonicReact, useIonActionSheet, useIonAlert, useIonLoading, useIonModal, useIonPopover, useIonRouter, useIonToast, useIonViewDidEnter, useIonViewDidLeave, useIonViewWillEnter, useIonViewWillLeave, withIonLifeCycle };
|
|
2551
|
+
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 };
|
|
3240
2552
|
//# sourceMappingURL=index.js.map
|