@pod-os/elements 0.0.1
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/LICENSE +21 -0
- package/dist/cjs/animation-bd89cfc5.js +957 -0
- package/dist/cjs/app-globals-01ad6c72.js +9 -0
- package/dist/cjs/button-active-e6ddc8af.js +66 -0
- package/dist/cjs/cubic-bezier-24e309bf.js +91 -0
- package/dist/cjs/elements.cjs.js +22 -0
- package/dist/cjs/focus-visible-1583bc8e.js +45 -0
- package/dist/cjs/framework-delegate-0a2d58a6.js +37 -0
- package/dist/cjs/gesture-controller-e824cfb3.js +193 -0
- package/dist/cjs/haptic-415dac5b.js +112 -0
- package/dist/cjs/hardware-back-button-ca468aae.js +73 -0
- package/dist/cjs/helpers-ff618d5e.js +265 -0
- package/dist/cjs/index-427d03fb.js +135 -0
- package/dist/cjs/index-5571e89c.js +450 -0
- package/dist/cjs/index-5663f42c.js +308 -0
- package/dist/cjs/index-6bf2cd3d.js +1834 -0
- package/dist/cjs/index-b29012b2.js +222 -0
- package/dist/cjs/index.cjs.js +2 -0
- package/dist/cjs/input-shims-23510d35.js +400 -0
- package/dist/cjs/ion-action-sheet.cjs.entry.js +265 -0
- package/dist/cjs/ion-alert.cjs.entry.js +456 -0
- package/dist/cjs/ion-app_32.cjs.entry.js +2393 -0
- package/dist/cjs/ion-avatar.cjs.entry.js +25 -0
- package/dist/cjs/ion-back-button.cjs.entry.js +89 -0
- package/dist/cjs/ion-backdrop.cjs.entry.js +67 -0
- package/dist/cjs/ion-badge.cjs.entry.js +29 -0
- package/dist/cjs/ion-buttons.cjs.entry.js +42 -0
- package/dist/cjs/ion-checkbox.cjs.entry.js +117 -0
- package/dist/cjs/ion-chip.cjs.entry.js +40 -0
- package/dist/cjs/ion-datetime.cjs.entry.js +993 -0
- package/dist/cjs/ion-fab-button.cjs.entry.js +91 -0
- package/dist/cjs/ion-fab-list.cjs.entry.js +45 -0
- package/dist/cjs/ion-fab.cjs.entry.js +74 -0
- package/dist/cjs/ion-img.cjs.entry.js +77 -0
- package/dist/cjs/ion-infinite-scroll-content.cjs.entry.js +37 -0
- package/dist/cjs/ion-infinite-scroll.cjs.entry.js +206 -0
- package/dist/cjs/ion-input.cjs.entry.js +266 -0
- package/dist/cjs/ion-item-option.cjs.entry.js +60 -0
- package/dist/cjs/ion-item-options.cjs.entry.js +47 -0
- package/dist/cjs/ion-item-sliding.cjs.entry.js +403 -0
- package/dist/cjs/ion-list-header_3.cjs.entry.js +259 -0
- package/dist/cjs/ion-loading.cjs.entry.js +215 -0
- package/dist/cjs/ion-menu-button.cjs.entry.js +75 -0
- package/dist/cjs/ion-menu-toggle.cjs.entry.js +47 -0
- package/dist/cjs/ion-menu.cjs.entry.js +456 -0
- package/dist/cjs/ion-modal.cjs.entry.js +485 -0
- package/dist/cjs/ion-nav-link.cjs.entry.js +44 -0
- package/dist/cjs/ion-nav.cjs.entry.js +859 -0
- package/dist/cjs/ion-note.cjs.entry.js +29 -0
- package/dist/cjs/ion-picker-column.cjs.entry.js +333 -0
- package/dist/cjs/ion-picker.cjs.entry.js +217 -0
- package/dist/cjs/ion-popover.cjs.entry.js +365 -0
- package/dist/cjs/ion-range.cjs.entry.js +438 -0
- package/dist/cjs/ion-refresher-content.cjs.entry.js +40 -0
- package/dist/cjs/ion-refresher.cjs.entry.js +801 -0
- package/dist/cjs/ion-reorder-group.cjs.entry.js +280 -0
- package/dist/cjs/ion-reorder.cjs.entry.js +37 -0
- package/dist/cjs/ion-route-redirect.cjs.entry.js +24 -0
- package/dist/cjs/ion-route.cjs.entry.js +49 -0
- package/dist/cjs/ion-router-link.cjs.entry.js +38 -0
- package/dist/cjs/ion-router-outlet.cjs.entry.js +196 -0
- package/dist/cjs/ion-router.cjs.entry.js +694 -0
- package/dist/cjs/ion-searchbar.cjs.entry.js +370 -0
- package/dist/cjs/ion-segment-button.cjs.entry.js +109 -0
- package/dist/cjs/ion-segment.cjs.entry.js +340 -0
- package/dist/cjs/ion-select-option.cjs.entry.js +27 -0
- package/dist/cjs/ion-select-popover.cjs.entry.js +35 -0
- package/dist/cjs/ion-select.cjs.entry.js +444 -0
- package/dist/cjs/ion-skeleton-text.cjs.entry.js +33 -0
- package/dist/cjs/ion-slide.cjs.entry.js +25 -0
- package/dist/cjs/ion-slides.cjs.entry.js +410 -0
- package/dist/cjs/ion-spinner.cjs.entry.js +64 -0
- package/dist/cjs/ion-split-pane.cjs.entry.js +150 -0
- package/dist/cjs/ion-tab-bar.cjs.entry.js +75 -0
- package/dist/cjs/ion-tab-button.cjs.entry.js +103 -0
- package/dist/cjs/ion-tab.cjs.entry.js +59 -0
- package/dist/cjs/ion-tabs.cjs.entry.js +155 -0
- package/dist/cjs/ion-text.cjs.entry.js +24 -0
- package/dist/cjs/ion-textarea.cjs.entry.js +246 -0
- package/dist/cjs/ion-thumbnail.cjs.entry.js +20 -0
- package/dist/cjs/ion-toast.cjs.entry.js +283 -0
- package/dist/cjs/ion-toggle.cjs.entry.js +160 -0
- package/dist/cjs/ion-virtual-scroll.cjs.entry.js +548 -0
- package/dist/cjs/ionic-global-167e590d.js +211 -0
- package/dist/cjs/ios.transition-2250af96.js +459 -0
- package/dist/cjs/keyboard-1dcbde6c.js +137 -0
- package/dist/cjs/loader.cjs.js +24 -0
- package/dist/cjs/md.transition-e801e09e.js +61 -0
- package/dist/cjs/menu-toggle-util-48d3b587.js +11 -0
- package/dist/cjs/overlays-0c3389b6.js +399 -0
- package/dist/cjs/spinner-configs-559523fd.js +112 -0
- package/dist/cjs/status-tap-da644888.js +37 -0
- package/dist/cjs/swipe-back-a15422cc.js +52 -0
- package/dist/cjs/swiper.bundle-8c897c07.js +6420 -0
- package/dist/cjs/tap-click-9c4dcea3.js +169 -0
- package/dist/cjs/theme-98ccfc24.js +44 -0
- package/dist/collection/collection-manifest.json +120 -0
- package/dist/collection/components/pos-app/pos-app.js +32 -0
- package/dist/collection/components/pos-demo-app/pos-demo-app.js +47 -0
- package/dist/collection/components/pos-description/pos-description.component.js +35 -0
- package/dist/collection/components/pos-label/pos-label.js +35 -0
- package/dist/collection/components/pos-literals/pos-literals.js +42 -0
- package/dist/collection/components/pos-login/pos-login.js +46 -0
- package/dist/collection/components/pos-relations/pos-relations.js +40 -0
- package/dist/collection/components/pos-resource/pos-resource.js +148 -0
- package/dist/collection/components/pos-rich-link/pos-rich-link.js +55 -0
- package/dist/collection/global.js +1 -0
- package/dist/collection/index.js +1 -0
- package/dist/collection/pod-os.js +4 -0
- package/dist/collection/store/getIdpUrl.js +1 -0
- package/dist/collection/store/session.js +8 -0
- package/dist/collection/test/mockPodOS.js +14 -0
- package/dist/collection/window.js +2 -0
- package/dist/custom-elements/focus-visible.js +43 -0
- package/dist/custom-elements/index.d.ts +93 -0
- package/dist/custom-elements/index.js +18772 -0
- package/dist/custom-elements/input-shims.js +398 -0
- package/dist/custom-elements/ios.transition.js +453 -0
- package/dist/custom-elements/keyboard.js +125 -0
- package/dist/custom-elements/md.transition.js +56 -0
- package/dist/custom-elements/status-tap.js +35 -0
- package/dist/custom-elements/swipe-back.js +48 -0
- package/dist/custom-elements/swiper.bundle.js +6418 -0
- package/dist/custom-elements/tap-click.js +167 -0
- package/dist/elements/elements.css +1 -0
- package/dist/elements/elements.esm.js +1 -0
- package/dist/elements/index.esm.js +0 -0
- package/dist/elements/p-051e7d1c.entry.js +1 -0
- package/dist/elements/p-073c4b46.entry.js +1 -0
- package/dist/elements/p-0773b39d.entry.js +1 -0
- package/dist/elements/p-0bbdf7ee.entry.js +1 -0
- package/dist/elements/p-0ce985f2.entry.js +1 -0
- package/dist/elements/p-10a1d53e.entry.js +1 -0
- package/dist/elements/p-111520a0.js +1 -0
- package/dist/elements/p-1672bb59.js +1 -0
- package/dist/elements/p-20488e32.entry.js +1 -0
- package/dist/elements/p-21a76883.js +1 -0
- package/dist/elements/p-22c3fe84.js +1 -0
- package/dist/elements/p-252ee244.entry.js +1 -0
- package/dist/elements/p-258f83d6.entry.js +1 -0
- package/dist/elements/p-2ae62ee2.entry.js +1 -0
- package/dist/elements/p-2bb4eed0.entry.js +1 -0
- package/dist/elements/p-2e4e8117.js +1 -0
- package/dist/elements/p-35ae10a1.entry.js +1 -0
- package/dist/elements/p-3783db21.entry.js +1 -0
- package/dist/elements/p-37fb0153.entry.js +1 -0
- package/dist/elements/p-39e69ceb.entry.js +1 -0
- package/dist/elements/p-3bf3b9ee.entry.js +1 -0
- package/dist/elements/p-3d052ec7.entry.js +1 -0
- package/dist/elements/p-3d2c1009.entry.js +1 -0
- package/dist/elements/p-3eb3ceda.js +1 -0
- package/dist/elements/p-417a8dd6.js +1 -0
- package/dist/elements/p-4261cf00.entry.js +1 -0
- package/dist/elements/p-44da9fdb.entry.js +1 -0
- package/dist/elements/p-4e81f5a3.js +1 -0
- package/dist/elements/p-4ea63d49.entry.js +1 -0
- package/dist/elements/p-4f428fec.js +1 -0
- package/dist/elements/p-514a156e.entry.js +1 -0
- package/dist/elements/p-52b26eb1.entry.js +1 -0
- package/dist/elements/p-559e271a.entry.js +1 -0
- package/dist/elements/p-58fde612.entry.js +1 -0
- package/dist/elements/p-5dcf40ab.entry.js +1 -0
- package/dist/elements/p-5e6fdd4f.entry.js +1 -0
- package/dist/elements/p-627c2a27.entry.js +1 -0
- package/dist/elements/p-6428a29b.entry.js +1 -0
- package/dist/elements/p-64fbf059.entry.js +1 -0
- package/dist/elements/p-670281d8.entry.js +1 -0
- package/dist/elements/p-677eed6e.entry.js +1 -0
- package/dist/elements/p-69104d78.entry.js +1 -0
- package/dist/elements/p-6c8effa6.entry.js +1 -0
- package/dist/elements/p-6d0e7670.entry.js +1 -0
- package/dist/elements/p-6f125c33.entry.js +1 -0
- package/dist/elements/p-73a89fc4.entry.js +1 -0
- package/dist/elements/p-762052a8.entry.js +1 -0
- package/dist/elements/p-7735ce2a.js +1 -0
- package/dist/elements/p-7748825d.entry.js +1 -0
- package/dist/elements/p-7840618d.js +1 -0
- package/dist/elements/p-7dbfc316.js +1 -0
- package/dist/elements/p-7e4727c5.entry.js +1 -0
- package/dist/elements/p-825cd4a4.js +1 -0
- package/dist/elements/p-894597a1.entry.js +1 -0
- package/dist/elements/p-89d2245e.entry.js +1 -0
- package/dist/elements/p-8e7bb098.js +1 -0
- package/dist/elements/p-8f72be08.js +1 -0
- package/dist/elements/p-8f9f5815.entry.js +1 -0
- package/dist/elements/p-8fc9298a.js +1 -0
- package/dist/elements/p-94ccf933.js +1 -0
- package/dist/elements/p-974e28d1.entry.js +1 -0
- package/dist/elements/p-996d272b.entry.js +1 -0
- package/dist/elements/p-9ab5469e.entry.js +1 -0
- package/dist/elements/p-a856c740.entry.js +1 -0
- package/dist/elements/p-aae3bbd8.js +1 -0
- package/dist/elements/p-adaf489e.entry.js +1 -0
- package/dist/elements/p-aef0bba0.js +1 -0
- package/dist/elements/p-b41e0ead.entry.js +1 -0
- package/dist/elements/p-b5c94073.entry.js +1 -0
- package/dist/elements/p-b85f2273.entry.js +1 -0
- package/dist/elements/p-bc8ab428.entry.js +1 -0
- package/dist/elements/p-c2396e45.js +1 -0
- package/dist/elements/p-c358ebf9.entry.js +1 -0
- package/dist/elements/p-c46ee782.entry.js +1 -0
- package/dist/elements/p-c563b4de.js +1 -0
- package/dist/elements/p-c6685d24.entry.js +1 -0
- package/dist/elements/p-c9c31823.entry.js +1 -0
- package/dist/elements/p-cb3dd05c.entry.js +1 -0
- package/dist/elements/p-cd151f5b.js +1 -0
- package/dist/elements/p-cd981ec5.js +1 -0
- package/dist/elements/p-cf929f00.entry.js +1 -0
- package/dist/elements/p-d3820644.entry.js +1 -0
- package/dist/elements/p-d7bc38e3.entry.js +1 -0
- package/dist/elements/p-d9cf0163.js +1 -0
- package/dist/elements/p-db2e69b4.js +1 -0
- package/dist/elements/p-deec7dde.entry.js +1 -0
- package/dist/elements/p-e110bbef.entry.js +1 -0
- package/dist/elements/p-e4cd9daa.entry.js +1 -0
- package/dist/elements/p-f2660943.js +1 -0
- package/dist/elements/p-f5849699.js +1 -0
- package/dist/elements/p-f8e7eda0.js +1 -0
- package/dist/elements/p-fba364fd.entry.js +1 -0
- package/dist/elements/svg/accessibility-outline.svg +1 -0
- package/dist/elements/svg/accessibility-sharp.svg +1 -0
- package/dist/elements/svg/accessibility.svg +1 -0
- package/dist/elements/svg/add-circle-outline.svg +1 -0
- package/dist/elements/svg/add-circle-sharp.svg +1 -0
- package/dist/elements/svg/add-circle.svg +1 -0
- package/dist/elements/svg/add-outline.svg +1 -0
- package/dist/elements/svg/add-sharp.svg +1 -0
- package/dist/elements/svg/add.svg +1 -0
- package/dist/elements/svg/airplane-outline.svg +1 -0
- package/dist/elements/svg/airplane-sharp.svg +1 -0
- package/dist/elements/svg/airplane.svg +1 -0
- package/dist/elements/svg/alarm-outline.svg +1 -0
- package/dist/elements/svg/alarm-sharp.svg +1 -0
- package/dist/elements/svg/alarm.svg +1 -0
- package/dist/elements/svg/albums-outline.svg +1 -0
- package/dist/elements/svg/albums-sharp.svg +1 -0
- package/dist/elements/svg/albums.svg +1 -0
- package/dist/elements/svg/alert-circle-outline.svg +1 -0
- package/dist/elements/svg/alert-circle-sharp.svg +1 -0
- package/dist/elements/svg/alert-circle.svg +1 -0
- package/dist/elements/svg/alert-outline.svg +1 -0
- package/dist/elements/svg/alert-sharp.svg +1 -0
- package/dist/elements/svg/alert.svg +1 -0
- package/dist/elements/svg/american-football-outline.svg +1 -0
- package/dist/elements/svg/american-football-sharp.svg +1 -0
- package/dist/elements/svg/american-football.svg +1 -0
- package/dist/elements/svg/analytics-outline.svg +1 -0
- package/dist/elements/svg/analytics-sharp.svg +1 -0
- package/dist/elements/svg/analytics.svg +1 -0
- package/dist/elements/svg/aperture-outline.svg +1 -0
- package/dist/elements/svg/aperture-sharp.svg +1 -0
- package/dist/elements/svg/aperture.svg +1 -0
- package/dist/elements/svg/apps-outline.svg +1 -0
- package/dist/elements/svg/apps-sharp.svg +1 -0
- package/dist/elements/svg/apps.svg +1 -0
- package/dist/elements/svg/archive-outline.svg +1 -0
- package/dist/elements/svg/archive-sharp.svg +1 -0
- package/dist/elements/svg/archive.svg +1 -0
- package/dist/elements/svg/arrow-back-circle-outline.svg +1 -0
- package/dist/elements/svg/arrow-back-circle-sharp.svg +1 -0
- package/dist/elements/svg/arrow-back-circle.svg +1 -0
- package/dist/elements/svg/arrow-back-outline.svg +1 -0
- package/dist/elements/svg/arrow-back-sharp.svg +1 -0
- package/dist/elements/svg/arrow-back.svg +1 -0
- package/dist/elements/svg/arrow-down-circle-outline.svg +1 -0
- package/dist/elements/svg/arrow-down-circle-sharp.svg +1 -0
- package/dist/elements/svg/arrow-down-circle.svg +1 -0
- package/dist/elements/svg/arrow-down-outline.svg +1 -0
- package/dist/elements/svg/arrow-down-sharp.svg +1 -0
- package/dist/elements/svg/arrow-down.svg +1 -0
- package/dist/elements/svg/arrow-forward-circle-outline.svg +1 -0
- package/dist/elements/svg/arrow-forward-circle-sharp.svg +1 -0
- package/dist/elements/svg/arrow-forward-circle.svg +1 -0
- package/dist/elements/svg/arrow-forward-outline.svg +1 -0
- package/dist/elements/svg/arrow-forward-sharp.svg +1 -0
- package/dist/elements/svg/arrow-forward.svg +1 -0
- package/dist/elements/svg/arrow-redo-circle-outline.svg +1 -0
- package/dist/elements/svg/arrow-redo-circle-sharp.svg +1 -0
- package/dist/elements/svg/arrow-redo-circle.svg +1 -0
- package/dist/elements/svg/arrow-redo-outline.svg +1 -0
- package/dist/elements/svg/arrow-redo-sharp.svg +1 -0
- package/dist/elements/svg/arrow-redo.svg +1 -0
- package/dist/elements/svg/arrow-undo-circle-outline.svg +1 -0
- package/dist/elements/svg/arrow-undo-circle-sharp.svg +1 -0
- package/dist/elements/svg/arrow-undo-circle.svg +1 -0
- package/dist/elements/svg/arrow-undo-outline.svg +1 -0
- package/dist/elements/svg/arrow-undo-sharp.svg +1 -0
- package/dist/elements/svg/arrow-undo.svg +1 -0
- package/dist/elements/svg/arrow-up-circle-outline.svg +1 -0
- package/dist/elements/svg/arrow-up-circle-sharp.svg +1 -0
- package/dist/elements/svg/arrow-up-circle.svg +1 -0
- package/dist/elements/svg/arrow-up-outline.svg +1 -0
- package/dist/elements/svg/arrow-up-sharp.svg +1 -0
- package/dist/elements/svg/arrow-up.svg +1 -0
- package/dist/elements/svg/at-circle-outline.svg +1 -0
- package/dist/elements/svg/at-circle-sharp.svg +1 -0
- package/dist/elements/svg/at-circle.svg +1 -0
- package/dist/elements/svg/at-outline.svg +1 -0
- package/dist/elements/svg/at-sharp.svg +1 -0
- package/dist/elements/svg/at.svg +1 -0
- package/dist/elements/svg/attach-outline.svg +1 -0
- package/dist/elements/svg/attach-sharp.svg +1 -0
- package/dist/elements/svg/attach.svg +1 -0
- package/dist/elements/svg/backspace-outline.svg +1 -0
- package/dist/elements/svg/backspace-sharp.svg +1 -0
- package/dist/elements/svg/backspace.svg +1 -0
- package/dist/elements/svg/bag-add-outline.svg +1 -0
- package/dist/elements/svg/bag-add-sharp.svg +1 -0
- package/dist/elements/svg/bag-add.svg +1 -0
- package/dist/elements/svg/bag-check-outline.svg +1 -0
- package/dist/elements/svg/bag-check-sharp.svg +1 -0
- package/dist/elements/svg/bag-check.svg +1 -0
- package/dist/elements/svg/bag-handle-outline.svg +1 -0
- package/dist/elements/svg/bag-handle-sharp.svg +1 -0
- package/dist/elements/svg/bag-handle.svg +1 -0
- package/dist/elements/svg/bag-outline.svg +1 -0
- package/dist/elements/svg/bag-remove-outline.svg +1 -0
- package/dist/elements/svg/bag-remove-sharp.svg +1 -0
- package/dist/elements/svg/bag-remove.svg +1 -0
- package/dist/elements/svg/bag-sharp.svg +1 -0
- package/dist/elements/svg/bag.svg +1 -0
- package/dist/elements/svg/balloon-outline.svg +1 -0
- package/dist/elements/svg/balloon-sharp.svg +1 -0
- package/dist/elements/svg/balloon.svg +1 -0
- package/dist/elements/svg/ban-outline.svg +1 -0
- package/dist/elements/svg/ban-sharp.svg +1 -0
- package/dist/elements/svg/ban.svg +1 -0
- package/dist/elements/svg/bandage-outline.svg +1 -0
- package/dist/elements/svg/bandage-sharp.svg +1 -0
- package/dist/elements/svg/bandage.svg +1 -0
- package/dist/elements/svg/bar-chart-outline.svg +1 -0
- package/dist/elements/svg/bar-chart-sharp.svg +1 -0
- package/dist/elements/svg/bar-chart.svg +1 -0
- package/dist/elements/svg/barbell-outline.svg +1 -0
- package/dist/elements/svg/barbell-sharp.svg +1 -0
- package/dist/elements/svg/barbell.svg +1 -0
- package/dist/elements/svg/barcode-outline.svg +1 -0
- package/dist/elements/svg/barcode-sharp.svg +1 -0
- package/dist/elements/svg/barcode.svg +1 -0
- package/dist/elements/svg/baseball-outline.svg +1 -0
- package/dist/elements/svg/baseball-sharp.svg +1 -0
- package/dist/elements/svg/baseball.svg +1 -0
- package/dist/elements/svg/basket-outline.svg +1 -0
- package/dist/elements/svg/basket-sharp.svg +1 -0
- package/dist/elements/svg/basket.svg +1 -0
- package/dist/elements/svg/basketball-outline.svg +1 -0
- package/dist/elements/svg/basketball-sharp.svg +1 -0
- package/dist/elements/svg/basketball.svg +1 -0
- package/dist/elements/svg/battery-charging-outline.svg +1 -0
- package/dist/elements/svg/battery-charging-sharp.svg +1 -0
- package/dist/elements/svg/battery-charging.svg +1 -0
- package/dist/elements/svg/battery-dead-outline.svg +1 -0
- package/dist/elements/svg/battery-dead-sharp.svg +1 -0
- package/dist/elements/svg/battery-dead.svg +1 -0
- package/dist/elements/svg/battery-full-outline.svg +1 -0
- package/dist/elements/svg/battery-full-sharp.svg +1 -0
- package/dist/elements/svg/battery-full.svg +1 -0
- package/dist/elements/svg/battery-half-outline.svg +1 -0
- package/dist/elements/svg/battery-half-sharp.svg +1 -0
- package/dist/elements/svg/battery-half.svg +1 -0
- package/dist/elements/svg/beaker-outline.svg +1 -0
- package/dist/elements/svg/beaker-sharp.svg +1 -0
- package/dist/elements/svg/beaker.svg +1 -0
- package/dist/elements/svg/bed-outline.svg +1 -0
- package/dist/elements/svg/bed-sharp.svg +1 -0
- package/dist/elements/svg/bed.svg +1 -0
- package/dist/elements/svg/beer-outline.svg +1 -0
- package/dist/elements/svg/beer-sharp.svg +1 -0
- package/dist/elements/svg/beer.svg +1 -0
- package/dist/elements/svg/bicycle-outline.svg +1 -0
- package/dist/elements/svg/bicycle-sharp.svg +1 -0
- package/dist/elements/svg/bicycle.svg +1 -0
- package/dist/elements/svg/bluetooth-outline.svg +1 -0
- package/dist/elements/svg/bluetooth-sharp.svg +1 -0
- package/dist/elements/svg/bluetooth.svg +1 -0
- package/dist/elements/svg/boat-outline.svg +1 -0
- package/dist/elements/svg/boat-sharp.svg +1 -0
- package/dist/elements/svg/boat.svg +1 -0
- package/dist/elements/svg/body-outline.svg +1 -0
- package/dist/elements/svg/body-sharp.svg +1 -0
- package/dist/elements/svg/body.svg +1 -0
- package/dist/elements/svg/bonfire-outline.svg +1 -0
- package/dist/elements/svg/bonfire-sharp.svg +1 -0
- package/dist/elements/svg/bonfire.svg +1 -0
- package/dist/elements/svg/book-outline.svg +1 -0
- package/dist/elements/svg/book-sharp.svg +1 -0
- package/dist/elements/svg/book.svg +1 -0
- package/dist/elements/svg/bookmark-outline.svg +1 -0
- package/dist/elements/svg/bookmark-sharp.svg +1 -0
- package/dist/elements/svg/bookmark.svg +1 -0
- package/dist/elements/svg/bookmarks-outline.svg +1 -0
- package/dist/elements/svg/bookmarks-sharp.svg +1 -0
- package/dist/elements/svg/bookmarks.svg +1 -0
- package/dist/elements/svg/bowling-ball-outline.svg +1 -0
- package/dist/elements/svg/bowling-ball-sharp.svg +1 -0
- package/dist/elements/svg/bowling-ball.svg +1 -0
- package/dist/elements/svg/briefcase-outline.svg +1 -0
- package/dist/elements/svg/briefcase-sharp.svg +1 -0
- package/dist/elements/svg/briefcase.svg +1 -0
- package/dist/elements/svg/browsers-outline.svg +1 -0
- package/dist/elements/svg/browsers-sharp.svg +1 -0
- package/dist/elements/svg/browsers.svg +1 -0
- package/dist/elements/svg/brush-outline.svg +1 -0
- package/dist/elements/svg/brush-sharp.svg +1 -0
- package/dist/elements/svg/brush.svg +1 -0
- package/dist/elements/svg/bug-outline.svg +1 -0
- package/dist/elements/svg/bug-sharp.svg +1 -0
- package/dist/elements/svg/bug.svg +1 -0
- package/dist/elements/svg/build-outline.svg +1 -0
- package/dist/elements/svg/build-sharp.svg +1 -0
- package/dist/elements/svg/build.svg +1 -0
- package/dist/elements/svg/bulb-outline.svg +1 -0
- package/dist/elements/svg/bulb-sharp.svg +1 -0
- package/dist/elements/svg/bulb.svg +1 -0
- package/dist/elements/svg/bus-outline.svg +1 -0
- package/dist/elements/svg/bus-sharp.svg +1 -0
- package/dist/elements/svg/bus.svg +1 -0
- package/dist/elements/svg/business-outline.svg +1 -0
- package/dist/elements/svg/business-sharp.svg +1 -0
- package/dist/elements/svg/business.svg +1 -0
- package/dist/elements/svg/cafe-outline.svg +1 -0
- package/dist/elements/svg/cafe-sharp.svg +1 -0
- package/dist/elements/svg/cafe.svg +1 -0
- package/dist/elements/svg/calculator-outline.svg +1 -0
- package/dist/elements/svg/calculator-sharp.svg +1 -0
- package/dist/elements/svg/calculator.svg +1 -0
- package/dist/elements/svg/calendar-clear-outline.svg +1 -0
- package/dist/elements/svg/calendar-clear-sharp.svg +1 -0
- package/dist/elements/svg/calendar-clear.svg +1 -0
- package/dist/elements/svg/calendar-number-outline.svg +1 -0
- package/dist/elements/svg/calendar-number-sharp.svg +1 -0
- package/dist/elements/svg/calendar-number.svg +1 -0
- package/dist/elements/svg/calendar-outline.svg +1 -0
- package/dist/elements/svg/calendar-sharp.svg +1 -0
- package/dist/elements/svg/calendar.svg +1 -0
- package/dist/elements/svg/call-outline.svg +1 -0
- package/dist/elements/svg/call-sharp.svg +1 -0
- package/dist/elements/svg/call.svg +1 -0
- package/dist/elements/svg/camera-outline.svg +1 -0
- package/dist/elements/svg/camera-reverse-outline.svg +1 -0
- package/dist/elements/svg/camera-reverse-sharp.svg +1 -0
- package/dist/elements/svg/camera-reverse.svg +1 -0
- package/dist/elements/svg/camera-sharp.svg +1 -0
- package/dist/elements/svg/camera.svg +1 -0
- package/dist/elements/svg/car-outline.svg +1 -0
- package/dist/elements/svg/car-sharp.svg +1 -0
- package/dist/elements/svg/car-sport-outline.svg +1 -0
- package/dist/elements/svg/car-sport-sharp.svg +1 -0
- package/dist/elements/svg/car-sport.svg +1 -0
- package/dist/elements/svg/car.svg +1 -0
- package/dist/elements/svg/card-outline.svg +1 -0
- package/dist/elements/svg/card-sharp.svg +1 -0
- package/dist/elements/svg/card.svg +1 -0
- package/dist/elements/svg/caret-back-circle-outline.svg +1 -0
- package/dist/elements/svg/caret-back-circle-sharp.svg +1 -0
- package/dist/elements/svg/caret-back-circle.svg +1 -0
- package/dist/elements/svg/caret-back-outline.svg +1 -0
- package/dist/elements/svg/caret-back-sharp.svg +1 -0
- package/dist/elements/svg/caret-back.svg +1 -0
- package/dist/elements/svg/caret-down-circle-outline.svg +1 -0
- package/dist/elements/svg/caret-down-circle-sharp.svg +1 -0
- package/dist/elements/svg/caret-down-circle.svg +1 -0
- package/dist/elements/svg/caret-down-outline.svg +1 -0
- package/dist/elements/svg/caret-down-sharp.svg +1 -0
- package/dist/elements/svg/caret-down.svg +1 -0
- package/dist/elements/svg/caret-forward-circle-outline.svg +1 -0
- package/dist/elements/svg/caret-forward-circle-sharp.svg +1 -0
- package/dist/elements/svg/caret-forward-circle.svg +1 -0
- package/dist/elements/svg/caret-forward-outline.svg +1 -0
- package/dist/elements/svg/caret-forward-sharp.svg +1 -0
- package/dist/elements/svg/caret-forward.svg +1 -0
- package/dist/elements/svg/caret-up-circle-outline.svg +1 -0
- package/dist/elements/svg/caret-up-circle-sharp.svg +1 -0
- package/dist/elements/svg/caret-up-circle.svg +1 -0
- package/dist/elements/svg/caret-up-outline.svg +1 -0
- package/dist/elements/svg/caret-up-sharp.svg +1 -0
- package/dist/elements/svg/caret-up.svg +1 -0
- package/dist/elements/svg/cart-outline.svg +1 -0
- package/dist/elements/svg/cart-sharp.svg +1 -0
- package/dist/elements/svg/cart.svg +1 -0
- package/dist/elements/svg/cash-outline.svg +1 -0
- package/dist/elements/svg/cash-sharp.svg +1 -0
- package/dist/elements/svg/cash.svg +1 -0
- package/dist/elements/svg/cellular-outline.svg +1 -0
- package/dist/elements/svg/cellular-sharp.svg +1 -0
- package/dist/elements/svg/cellular.svg +1 -0
- package/dist/elements/svg/chatbox-ellipses-outline.svg +1 -0
- package/dist/elements/svg/chatbox-ellipses-sharp.svg +1 -0
- package/dist/elements/svg/chatbox-ellipses.svg +1 -0
- package/dist/elements/svg/chatbox-outline.svg +1 -0
- package/dist/elements/svg/chatbox-sharp.svg +1 -0
- package/dist/elements/svg/chatbox.svg +1 -0
- package/dist/elements/svg/chatbubble-ellipses-outline.svg +1 -0
- package/dist/elements/svg/chatbubble-ellipses-sharp.svg +1 -0
- package/dist/elements/svg/chatbubble-ellipses.svg +1 -0
- package/dist/elements/svg/chatbubble-outline.svg +1 -0
- package/dist/elements/svg/chatbubble-sharp.svg +1 -0
- package/dist/elements/svg/chatbubble.svg +1 -0
- package/dist/elements/svg/chatbubbles-outline.svg +1 -0
- package/dist/elements/svg/chatbubbles-sharp.svg +1 -0
- package/dist/elements/svg/chatbubbles.svg +1 -0
- package/dist/elements/svg/checkbox-outline.svg +1 -0
- package/dist/elements/svg/checkbox-sharp.svg +1 -0
- package/dist/elements/svg/checkbox.svg +1 -0
- package/dist/elements/svg/checkmark-circle-outline.svg +1 -0
- package/dist/elements/svg/checkmark-circle-sharp.svg +1 -0
- package/dist/elements/svg/checkmark-circle.svg +1 -0
- package/dist/elements/svg/checkmark-done-circle-outline.svg +1 -0
- package/dist/elements/svg/checkmark-done-circle-sharp.svg +1 -0
- package/dist/elements/svg/checkmark-done-circle.svg +1 -0
- package/dist/elements/svg/checkmark-done-outline.svg +1 -0
- package/dist/elements/svg/checkmark-done-sharp.svg +1 -0
- package/dist/elements/svg/checkmark-done.svg +1 -0
- package/dist/elements/svg/checkmark-outline.svg +1 -0
- package/dist/elements/svg/checkmark-sharp.svg +1 -0
- package/dist/elements/svg/checkmark.svg +1 -0
- package/dist/elements/svg/chevron-back-circle-outline.svg +1 -0
- package/dist/elements/svg/chevron-back-circle-sharp.svg +1 -0
- package/dist/elements/svg/chevron-back-circle.svg +1 -0
- package/dist/elements/svg/chevron-back-outline.svg +1 -0
- package/dist/elements/svg/chevron-back-sharp.svg +1 -0
- package/dist/elements/svg/chevron-back.svg +1 -0
- package/dist/elements/svg/chevron-down-circle-outline.svg +1 -0
- package/dist/elements/svg/chevron-down-circle-sharp.svg +1 -0
- package/dist/elements/svg/chevron-down-circle.svg +1 -0
- package/dist/elements/svg/chevron-down-outline.svg +1 -0
- package/dist/elements/svg/chevron-down-sharp.svg +1 -0
- package/dist/elements/svg/chevron-down.svg +1 -0
- package/dist/elements/svg/chevron-forward-circle-outline.svg +1 -0
- package/dist/elements/svg/chevron-forward-circle-sharp.svg +1 -0
- package/dist/elements/svg/chevron-forward-circle.svg +1 -0
- package/dist/elements/svg/chevron-forward-outline.svg +1 -0
- package/dist/elements/svg/chevron-forward-sharp.svg +1 -0
- package/dist/elements/svg/chevron-forward.svg +1 -0
- package/dist/elements/svg/chevron-up-circle-outline.svg +1 -0
- package/dist/elements/svg/chevron-up-circle-sharp.svg +1 -0
- package/dist/elements/svg/chevron-up-circle.svg +1 -0
- package/dist/elements/svg/chevron-up-outline.svg +1 -0
- package/dist/elements/svg/chevron-up-sharp.svg +1 -0
- package/dist/elements/svg/chevron-up.svg +1 -0
- package/dist/elements/svg/clipboard-outline.svg +1 -0
- package/dist/elements/svg/clipboard-sharp.svg +1 -0
- package/dist/elements/svg/clipboard.svg +1 -0
- package/dist/elements/svg/close-circle-outline.svg +1 -0
- package/dist/elements/svg/close-circle-sharp.svg +1 -0
- package/dist/elements/svg/close-circle.svg +1 -0
- package/dist/elements/svg/close-outline.svg +1 -0
- package/dist/elements/svg/close-sharp.svg +1 -0
- package/dist/elements/svg/close.svg +1 -0
- package/dist/elements/svg/cloud-circle-outline.svg +1 -0
- package/dist/elements/svg/cloud-circle-sharp.svg +1 -0
- package/dist/elements/svg/cloud-circle.svg +1 -0
- package/dist/elements/svg/cloud-done-outline.svg +1 -0
- package/dist/elements/svg/cloud-done-sharp.svg +1 -0
- package/dist/elements/svg/cloud-done.svg +1 -0
- package/dist/elements/svg/cloud-download-outline.svg +1 -0
- package/dist/elements/svg/cloud-download-sharp.svg +1 -0
- package/dist/elements/svg/cloud-download.svg +1 -0
- package/dist/elements/svg/cloud-offline-outline.svg +1 -0
- package/dist/elements/svg/cloud-offline-sharp.svg +1 -0
- package/dist/elements/svg/cloud-offline.svg +1 -0
- package/dist/elements/svg/cloud-outline.svg +1 -0
- package/dist/elements/svg/cloud-sharp.svg +1 -0
- package/dist/elements/svg/cloud-upload-outline.svg +1 -0
- package/dist/elements/svg/cloud-upload-sharp.svg +1 -0
- package/dist/elements/svg/cloud-upload.svg +1 -0
- package/dist/elements/svg/cloud.svg +1 -0
- package/dist/elements/svg/cloudy-night-outline.svg +1 -0
- package/dist/elements/svg/cloudy-night-sharp.svg +1 -0
- package/dist/elements/svg/cloudy-night.svg +1 -0
- package/dist/elements/svg/cloudy-outline.svg +1 -0
- package/dist/elements/svg/cloudy-sharp.svg +1 -0
- package/dist/elements/svg/cloudy.svg +1 -0
- package/dist/elements/svg/code-download-outline.svg +1 -0
- package/dist/elements/svg/code-download-sharp.svg +1 -0
- package/dist/elements/svg/code-download.svg +1 -0
- package/dist/elements/svg/code-outline.svg +1 -0
- package/dist/elements/svg/code-sharp.svg +1 -0
- package/dist/elements/svg/code-slash-outline.svg +1 -0
- package/dist/elements/svg/code-slash-sharp.svg +1 -0
- package/dist/elements/svg/code-slash.svg +1 -0
- package/dist/elements/svg/code-working-outline.svg +1 -0
- package/dist/elements/svg/code-working-sharp.svg +1 -0
- package/dist/elements/svg/code-working.svg +1 -0
- package/dist/elements/svg/code.svg +1 -0
- package/dist/elements/svg/cog-outline.svg +1 -0
- package/dist/elements/svg/cog-sharp.svg +1 -0
- package/dist/elements/svg/cog.svg +1 -0
- package/dist/elements/svg/color-fill-outline.svg +1 -0
- package/dist/elements/svg/color-fill-sharp.svg +1 -0
- package/dist/elements/svg/color-fill.svg +1 -0
- package/dist/elements/svg/color-filter-outline.svg +1 -0
- package/dist/elements/svg/color-filter-sharp.svg +1 -0
- package/dist/elements/svg/color-filter.svg +1 -0
- package/dist/elements/svg/color-palette-outline.svg +1 -0
- package/dist/elements/svg/color-palette-sharp.svg +1 -0
- package/dist/elements/svg/color-palette.svg +1 -0
- package/dist/elements/svg/color-wand-outline.svg +1 -0
- package/dist/elements/svg/color-wand-sharp.svg +1 -0
- package/dist/elements/svg/color-wand.svg +1 -0
- package/dist/elements/svg/compass-outline.svg +1 -0
- package/dist/elements/svg/compass-sharp.svg +1 -0
- package/dist/elements/svg/compass.svg +1 -0
- package/dist/elements/svg/construct-outline.svg +1 -0
- package/dist/elements/svg/construct-sharp.svg +1 -0
- package/dist/elements/svg/construct.svg +1 -0
- package/dist/elements/svg/contract-outline.svg +1 -0
- package/dist/elements/svg/contract-sharp.svg +1 -0
- package/dist/elements/svg/contract.svg +1 -0
- package/dist/elements/svg/contrast-outline.svg +1 -0
- package/dist/elements/svg/contrast-sharp.svg +1 -0
- package/dist/elements/svg/contrast.svg +1 -0
- package/dist/elements/svg/copy-outline.svg +1 -0
- package/dist/elements/svg/copy-sharp.svg +1 -0
- package/dist/elements/svg/copy.svg +1 -0
- package/dist/elements/svg/create-outline.svg +1 -0
- package/dist/elements/svg/create-sharp.svg +1 -0
- package/dist/elements/svg/create.svg +1 -0
- package/dist/elements/svg/crop-outline.svg +1 -0
- package/dist/elements/svg/crop-sharp.svg +1 -0
- package/dist/elements/svg/crop.svg +1 -0
- package/dist/elements/svg/cube-outline.svg +1 -0
- package/dist/elements/svg/cube-sharp.svg +1 -0
- package/dist/elements/svg/cube.svg +1 -0
- package/dist/elements/svg/cut-outline.svg +1 -0
- package/dist/elements/svg/cut-sharp.svg +1 -0
- package/dist/elements/svg/cut.svg +1 -0
- package/dist/elements/svg/desktop-outline.svg +1 -0
- package/dist/elements/svg/desktop-sharp.svg +1 -0
- package/dist/elements/svg/desktop.svg +1 -0
- package/dist/elements/svg/diamond-outline.svg +1 -0
- package/dist/elements/svg/diamond-sharp.svg +1 -0
- package/dist/elements/svg/diamond.svg +1 -0
- package/dist/elements/svg/dice-outline.svg +1 -0
- package/dist/elements/svg/dice-sharp.svg +1 -0
- package/dist/elements/svg/dice.svg +1 -0
- package/dist/elements/svg/disc-outline.svg +1 -0
- package/dist/elements/svg/disc-sharp.svg +1 -0
- package/dist/elements/svg/disc.svg +1 -0
- package/dist/elements/svg/document-attach-outline.svg +1 -0
- package/dist/elements/svg/document-attach-sharp.svg +1 -0
- package/dist/elements/svg/document-attach.svg +1 -0
- package/dist/elements/svg/document-lock-outline.svg +1 -0
- package/dist/elements/svg/document-lock-sharp.svg +1 -0
- package/dist/elements/svg/document-lock.svg +1 -0
- package/dist/elements/svg/document-outline.svg +1 -0
- package/dist/elements/svg/document-sharp.svg +1 -0
- package/dist/elements/svg/document-text-outline.svg +1 -0
- package/dist/elements/svg/document-text-sharp.svg +1 -0
- package/dist/elements/svg/document-text.svg +1 -0
- package/dist/elements/svg/document.svg +1 -0
- package/dist/elements/svg/documents-outline.svg +1 -0
- package/dist/elements/svg/documents-sharp.svg +1 -0
- package/dist/elements/svg/documents.svg +1 -0
- package/dist/elements/svg/download-outline.svg +1 -0
- package/dist/elements/svg/download-sharp.svg +1 -0
- package/dist/elements/svg/download.svg +1 -0
- package/dist/elements/svg/duplicate-outline.svg +1 -0
- package/dist/elements/svg/duplicate-sharp.svg +1 -0
- package/dist/elements/svg/duplicate.svg +1 -0
- package/dist/elements/svg/ear-outline.svg +1 -0
- package/dist/elements/svg/ear-sharp.svg +1 -0
- package/dist/elements/svg/ear.svg +1 -0
- package/dist/elements/svg/earth-outline.svg +1 -0
- package/dist/elements/svg/earth-sharp.svg +1 -0
- package/dist/elements/svg/earth.svg +1 -0
- package/dist/elements/svg/easel-outline.svg +1 -0
- package/dist/elements/svg/easel-sharp.svg +1 -0
- package/dist/elements/svg/easel.svg +1 -0
- package/dist/elements/svg/egg-outline.svg +1 -0
- package/dist/elements/svg/egg-sharp.svg +1 -0
- package/dist/elements/svg/egg.svg +1 -0
- package/dist/elements/svg/ellipse-outline.svg +1 -0
- package/dist/elements/svg/ellipse-sharp.svg +1 -0
- package/dist/elements/svg/ellipse.svg +1 -0
- package/dist/elements/svg/ellipsis-horizontal-circle-outline.svg +1 -0
- package/dist/elements/svg/ellipsis-horizontal-circle-sharp.svg +1 -0
- package/dist/elements/svg/ellipsis-horizontal-circle.svg +1 -0
- package/dist/elements/svg/ellipsis-horizontal-outline.svg +1 -0
- package/dist/elements/svg/ellipsis-horizontal-sharp.svg +1 -0
- package/dist/elements/svg/ellipsis-horizontal.svg +1 -0
- package/dist/elements/svg/ellipsis-vertical-circle-outline.svg +1 -0
- package/dist/elements/svg/ellipsis-vertical-circle-sharp.svg +1 -0
- package/dist/elements/svg/ellipsis-vertical-circle.svg +1 -0
- package/dist/elements/svg/ellipsis-vertical-outline.svg +1 -0
- package/dist/elements/svg/ellipsis-vertical-sharp.svg +1 -0
- package/dist/elements/svg/ellipsis-vertical.svg +1 -0
- package/dist/elements/svg/enter-outline.svg +1 -0
- package/dist/elements/svg/enter-sharp.svg +1 -0
- package/dist/elements/svg/enter.svg +1 -0
- package/dist/elements/svg/exit-outline.svg +1 -0
- package/dist/elements/svg/exit-sharp.svg +1 -0
- package/dist/elements/svg/exit.svg +1 -0
- package/dist/elements/svg/expand-outline.svg +1 -0
- package/dist/elements/svg/expand-sharp.svg +1 -0
- package/dist/elements/svg/expand.svg +1 -0
- package/dist/elements/svg/extension-puzzle-outline.svg +1 -0
- package/dist/elements/svg/extension-puzzle-sharp.svg +1 -0
- package/dist/elements/svg/extension-puzzle.svg +1 -0
- package/dist/elements/svg/eye-off-outline.svg +1 -0
- package/dist/elements/svg/eye-off-sharp.svg +1 -0
- package/dist/elements/svg/eye-off.svg +1 -0
- package/dist/elements/svg/eye-outline.svg +1 -0
- package/dist/elements/svg/eye-sharp.svg +1 -0
- package/dist/elements/svg/eye.svg +1 -0
- package/dist/elements/svg/eyedrop-outline.svg +1 -0
- package/dist/elements/svg/eyedrop-sharp.svg +1 -0
- package/dist/elements/svg/eyedrop.svg +1 -0
- package/dist/elements/svg/fast-food-outline.svg +1 -0
- package/dist/elements/svg/fast-food-sharp.svg +1 -0
- package/dist/elements/svg/fast-food.svg +1 -0
- package/dist/elements/svg/female-outline.svg +1 -0
- package/dist/elements/svg/female-sharp.svg +1 -0
- package/dist/elements/svg/female.svg +1 -0
- package/dist/elements/svg/file-tray-full-outline.svg +1 -0
- package/dist/elements/svg/file-tray-full-sharp.svg +1 -0
- package/dist/elements/svg/file-tray-full.svg +1 -0
- package/dist/elements/svg/file-tray-outline.svg +1 -0
- package/dist/elements/svg/file-tray-sharp.svg +1 -0
- package/dist/elements/svg/file-tray-stacked-outline.svg +1 -0
- package/dist/elements/svg/file-tray-stacked-sharp.svg +1 -0
- package/dist/elements/svg/file-tray-stacked.svg +1 -0
- package/dist/elements/svg/file-tray.svg +1 -0
- package/dist/elements/svg/film-outline.svg +1 -0
- package/dist/elements/svg/film-sharp.svg +1 -0
- package/dist/elements/svg/film.svg +1 -0
- package/dist/elements/svg/filter-circle-outline.svg +1 -0
- package/dist/elements/svg/filter-circle-sharp.svg +1 -0
- package/dist/elements/svg/filter-circle.svg +1 -0
- package/dist/elements/svg/filter-outline.svg +1 -0
- package/dist/elements/svg/filter-sharp.svg +1 -0
- package/dist/elements/svg/filter.svg +1 -0
- package/dist/elements/svg/finger-print-outline.svg +1 -0
- package/dist/elements/svg/finger-print-sharp.svg +1 -0
- package/dist/elements/svg/finger-print.svg +1 -0
- package/dist/elements/svg/fish-outline.svg +1 -0
- package/dist/elements/svg/fish-sharp.svg +1 -0
- package/dist/elements/svg/fish.svg +1 -0
- package/dist/elements/svg/fitness-outline.svg +1 -0
- package/dist/elements/svg/fitness-sharp.svg +1 -0
- package/dist/elements/svg/fitness.svg +1 -0
- package/dist/elements/svg/flag-outline.svg +1 -0
- package/dist/elements/svg/flag-sharp.svg +1 -0
- package/dist/elements/svg/flag.svg +1 -0
- package/dist/elements/svg/flame-outline.svg +1 -0
- package/dist/elements/svg/flame-sharp.svg +1 -0
- package/dist/elements/svg/flame.svg +1 -0
- package/dist/elements/svg/flash-off-outline.svg +1 -0
- package/dist/elements/svg/flash-off-sharp.svg +1 -0
- package/dist/elements/svg/flash-off.svg +1 -0
- package/dist/elements/svg/flash-outline.svg +1 -0
- package/dist/elements/svg/flash-sharp.svg +1 -0
- package/dist/elements/svg/flash.svg +1 -0
- package/dist/elements/svg/flashlight-outline.svg +1 -0
- package/dist/elements/svg/flashlight-sharp.svg +1 -0
- package/dist/elements/svg/flashlight.svg +1 -0
- package/dist/elements/svg/flask-outline.svg +1 -0
- package/dist/elements/svg/flask-sharp.svg +1 -0
- package/dist/elements/svg/flask.svg +1 -0
- package/dist/elements/svg/flower-outline.svg +1 -0
- package/dist/elements/svg/flower-sharp.svg +1 -0
- package/dist/elements/svg/flower.svg +1 -0
- package/dist/elements/svg/folder-open-outline.svg +1 -0
- package/dist/elements/svg/folder-open-sharp.svg +1 -0
- package/dist/elements/svg/folder-open.svg +1 -0
- package/dist/elements/svg/folder-outline.svg +1 -0
- package/dist/elements/svg/folder-sharp.svg +1 -0
- package/dist/elements/svg/folder.svg +1 -0
- package/dist/elements/svg/football-outline.svg +1 -0
- package/dist/elements/svg/football-sharp.svg +1 -0
- package/dist/elements/svg/football.svg +1 -0
- package/dist/elements/svg/footsteps-outline.svg +1 -0
- package/dist/elements/svg/footsteps-sharp.svg +1 -0
- package/dist/elements/svg/footsteps.svg +1 -0
- package/dist/elements/svg/funnel-outline.svg +1 -0
- package/dist/elements/svg/funnel-sharp.svg +1 -0
- package/dist/elements/svg/funnel.svg +1 -0
- package/dist/elements/svg/game-controller-outline.svg +1 -0
- package/dist/elements/svg/game-controller-sharp.svg +1 -0
- package/dist/elements/svg/game-controller.svg +1 -0
- package/dist/elements/svg/gift-outline.svg +1 -0
- package/dist/elements/svg/gift-sharp.svg +1 -0
- package/dist/elements/svg/gift.svg +1 -0
- package/dist/elements/svg/git-branch-outline.svg +1 -0
- package/dist/elements/svg/git-branch-sharp.svg +1 -0
- package/dist/elements/svg/git-branch.svg +1 -0
- package/dist/elements/svg/git-commit-outline.svg +1 -0
- package/dist/elements/svg/git-commit-sharp.svg +1 -0
- package/dist/elements/svg/git-commit.svg +1 -0
- package/dist/elements/svg/git-compare-outline.svg +1 -0
- package/dist/elements/svg/git-compare-sharp.svg +1 -0
- package/dist/elements/svg/git-compare.svg +1 -0
- package/dist/elements/svg/git-merge-outline.svg +1 -0
- package/dist/elements/svg/git-merge-sharp.svg +1 -0
- package/dist/elements/svg/git-merge.svg +1 -0
- package/dist/elements/svg/git-network-outline.svg +1 -0
- package/dist/elements/svg/git-network-sharp.svg +1 -0
- package/dist/elements/svg/git-network.svg +1 -0
- package/dist/elements/svg/git-pull-request-outline.svg +1 -0
- package/dist/elements/svg/git-pull-request-sharp.svg +1 -0
- package/dist/elements/svg/git-pull-request.svg +1 -0
- package/dist/elements/svg/glasses-outline.svg +1 -0
- package/dist/elements/svg/glasses-sharp.svg +1 -0
- package/dist/elements/svg/glasses.svg +1 -0
- package/dist/elements/svg/globe-outline.svg +1 -0
- package/dist/elements/svg/globe-sharp.svg +1 -0
- package/dist/elements/svg/globe.svg +1 -0
- package/dist/elements/svg/golf-outline.svg +1 -0
- package/dist/elements/svg/golf-sharp.svg +1 -0
- package/dist/elements/svg/golf.svg +1 -0
- package/dist/elements/svg/grid-outline.svg +1 -0
- package/dist/elements/svg/grid-sharp.svg +1 -0
- package/dist/elements/svg/grid.svg +1 -0
- package/dist/elements/svg/hammer-outline.svg +1 -0
- package/dist/elements/svg/hammer-sharp.svg +1 -0
- package/dist/elements/svg/hammer.svg +1 -0
- package/dist/elements/svg/hand-left-outline.svg +1 -0
- package/dist/elements/svg/hand-left-sharp.svg +1 -0
- package/dist/elements/svg/hand-left.svg +1 -0
- package/dist/elements/svg/hand-right-outline.svg +1 -0
- package/dist/elements/svg/hand-right-sharp.svg +1 -0
- package/dist/elements/svg/hand-right.svg +1 -0
- package/dist/elements/svg/happy-outline.svg +1 -0
- package/dist/elements/svg/happy-sharp.svg +1 -0
- package/dist/elements/svg/happy.svg +1 -0
- package/dist/elements/svg/hardware-chip-outline.svg +1 -0
- package/dist/elements/svg/hardware-chip-sharp.svg +1 -0
- package/dist/elements/svg/hardware-chip.svg +1 -0
- package/dist/elements/svg/headset-outline.svg +1 -0
- package/dist/elements/svg/headset-sharp.svg +1 -0
- package/dist/elements/svg/headset.svg +1 -0
- package/dist/elements/svg/heart-circle-outline.svg +1 -0
- package/dist/elements/svg/heart-circle-sharp.svg +1 -0
- package/dist/elements/svg/heart-circle.svg +1 -0
- package/dist/elements/svg/heart-dislike-circle-outline.svg +1 -0
- package/dist/elements/svg/heart-dislike-circle-sharp.svg +1 -0
- package/dist/elements/svg/heart-dislike-circle.svg +1 -0
- package/dist/elements/svg/heart-dislike-outline.svg +1 -0
- package/dist/elements/svg/heart-dislike-sharp.svg +1 -0
- package/dist/elements/svg/heart-dislike.svg +1 -0
- package/dist/elements/svg/heart-half-outline.svg +1 -0
- package/dist/elements/svg/heart-half-sharp.svg +1 -0
- package/dist/elements/svg/heart-half.svg +1 -0
- package/dist/elements/svg/heart-outline.svg +1 -0
- package/dist/elements/svg/heart-sharp.svg +1 -0
- package/dist/elements/svg/heart.svg +1 -0
- package/dist/elements/svg/help-buoy-outline.svg +1 -0
- package/dist/elements/svg/help-buoy-sharp.svg +1 -0
- package/dist/elements/svg/help-buoy.svg +1 -0
- package/dist/elements/svg/help-circle-outline.svg +1 -0
- package/dist/elements/svg/help-circle-sharp.svg +1 -0
- package/dist/elements/svg/help-circle.svg +1 -0
- package/dist/elements/svg/help-outline.svg +1 -0
- package/dist/elements/svg/help-sharp.svg +1 -0
- package/dist/elements/svg/help.svg +1 -0
- package/dist/elements/svg/home-outline.svg +1 -0
- package/dist/elements/svg/home-sharp.svg +1 -0
- package/dist/elements/svg/home.svg +1 -0
- package/dist/elements/svg/hourglass-outline.svg +1 -0
- package/dist/elements/svg/hourglass-sharp.svg +1 -0
- package/dist/elements/svg/hourglass.svg +1 -0
- package/dist/elements/svg/ice-cream-outline.svg +1 -0
- package/dist/elements/svg/ice-cream-sharp.svg +1 -0
- package/dist/elements/svg/ice-cream.svg +1 -0
- package/dist/elements/svg/id-card-outline.svg +1 -0
- package/dist/elements/svg/id-card-sharp.svg +1 -0
- package/dist/elements/svg/id-card.svg +1 -0
- package/dist/elements/svg/image-outline.svg +1 -0
- package/dist/elements/svg/image-sharp.svg +1 -0
- package/dist/elements/svg/image.svg +1 -0
- package/dist/elements/svg/images-outline.svg +1 -0
- package/dist/elements/svg/images-sharp.svg +1 -0
- package/dist/elements/svg/images.svg +1 -0
- package/dist/elements/svg/infinite-outline.svg +1 -0
- package/dist/elements/svg/infinite-sharp.svg +1 -0
- package/dist/elements/svg/infinite.svg +1 -0
- package/dist/elements/svg/information-circle-outline.svg +1 -0
- package/dist/elements/svg/information-circle-sharp.svg +1 -0
- package/dist/elements/svg/information-circle.svg +1 -0
- package/dist/elements/svg/information-outline.svg +1 -0
- package/dist/elements/svg/information-sharp.svg +1 -0
- package/dist/elements/svg/information.svg +1 -0
- package/dist/elements/svg/invert-mode-outline.svg +1 -0
- package/dist/elements/svg/invert-mode-sharp.svg +1 -0
- package/dist/elements/svg/invert-mode.svg +1 -0
- package/dist/elements/svg/journal-outline.svg +1 -0
- package/dist/elements/svg/journal-sharp.svg +1 -0
- package/dist/elements/svg/journal.svg +1 -0
- package/dist/elements/svg/key-outline.svg +1 -0
- package/dist/elements/svg/key-sharp.svg +1 -0
- package/dist/elements/svg/key.svg +1 -0
- package/dist/elements/svg/keypad-outline.svg +1 -0
- package/dist/elements/svg/keypad-sharp.svg +1 -0
- package/dist/elements/svg/keypad.svg +1 -0
- package/dist/elements/svg/language-outline.svg +1 -0
- package/dist/elements/svg/language-sharp.svg +1 -0
- package/dist/elements/svg/language.svg +1 -0
- package/dist/elements/svg/laptop-outline.svg +1 -0
- package/dist/elements/svg/laptop-sharp.svg +1 -0
- package/dist/elements/svg/laptop.svg +1 -0
- package/dist/elements/svg/layers-outline.svg +1 -0
- package/dist/elements/svg/layers-sharp.svg +1 -0
- package/dist/elements/svg/layers.svg +1 -0
- package/dist/elements/svg/leaf-outline.svg +1 -0
- package/dist/elements/svg/leaf-sharp.svg +1 -0
- package/dist/elements/svg/leaf.svg +1 -0
- package/dist/elements/svg/library-outline.svg +1 -0
- package/dist/elements/svg/library-sharp.svg +1 -0
- package/dist/elements/svg/library.svg +1 -0
- package/dist/elements/svg/link-outline.svg +1 -0
- package/dist/elements/svg/link-sharp.svg +1 -0
- package/dist/elements/svg/link.svg +1 -0
- package/dist/elements/svg/list-circle-outline.svg +1 -0
- package/dist/elements/svg/list-circle-sharp.svg +1 -0
- package/dist/elements/svg/list-circle.svg +1 -0
- package/dist/elements/svg/list-outline.svg +1 -0
- package/dist/elements/svg/list-sharp.svg +1 -0
- package/dist/elements/svg/list.svg +1 -0
- package/dist/elements/svg/locate-outline.svg +1 -0
- package/dist/elements/svg/locate-sharp.svg +1 -0
- package/dist/elements/svg/locate.svg +1 -0
- package/dist/elements/svg/location-outline.svg +1 -0
- package/dist/elements/svg/location-sharp.svg +1 -0
- package/dist/elements/svg/location.svg +1 -0
- package/dist/elements/svg/lock-closed-outline.svg +1 -0
- package/dist/elements/svg/lock-closed-sharp.svg +1 -0
- package/dist/elements/svg/lock-closed.svg +1 -0
- package/dist/elements/svg/lock-open-outline.svg +1 -0
- package/dist/elements/svg/lock-open-sharp.svg +1 -0
- package/dist/elements/svg/lock-open.svg +1 -0
- package/dist/elements/svg/log-in-outline.svg +1 -0
- package/dist/elements/svg/log-in-sharp.svg +1 -0
- package/dist/elements/svg/log-in.svg +1 -0
- package/dist/elements/svg/log-out-outline.svg +1 -0
- package/dist/elements/svg/log-out-sharp.svg +1 -0
- package/dist/elements/svg/log-out.svg +1 -0
- package/dist/elements/svg/logo-alipay.svg +1 -0
- package/dist/elements/svg/logo-amazon.svg +1 -0
- package/dist/elements/svg/logo-amplify.svg +1 -0
- package/dist/elements/svg/logo-android.svg +1 -0
- package/dist/elements/svg/logo-angular.svg +1 -0
- package/dist/elements/svg/logo-apple-appstore.svg +1 -0
- package/dist/elements/svg/logo-apple-ar.svg +1 -0
- package/dist/elements/svg/logo-apple.svg +1 -0
- package/dist/elements/svg/logo-behance.svg +1 -0
- package/dist/elements/svg/logo-bitbucket.svg +1 -0
- package/dist/elements/svg/logo-bitcoin.svg +1 -0
- package/dist/elements/svg/logo-buffer.svg +1 -0
- package/dist/elements/svg/logo-capacitor.svg +1 -0
- package/dist/elements/svg/logo-chrome.svg +1 -0
- package/dist/elements/svg/logo-closed-captioning.svg +1 -0
- package/dist/elements/svg/logo-codepen.svg +1 -0
- package/dist/elements/svg/logo-css3.svg +1 -0
- package/dist/elements/svg/logo-designernews.svg +1 -0
- package/dist/elements/svg/logo-deviantart.svg +1 -0
- package/dist/elements/svg/logo-discord.svg +1 -0
- package/dist/elements/svg/logo-docker.svg +1 -0
- package/dist/elements/svg/logo-dribbble.svg +1 -0
- package/dist/elements/svg/logo-dropbox.svg +1 -0
- package/dist/elements/svg/logo-edge.svg +1 -0
- package/dist/elements/svg/logo-electron.svg +1 -0
- package/dist/elements/svg/logo-euro.svg +1 -0
- package/dist/elements/svg/logo-facebook.svg +1 -0
- package/dist/elements/svg/logo-figma.svg +1 -0
- package/dist/elements/svg/logo-firebase.svg +1 -0
- package/dist/elements/svg/logo-firefox.svg +1 -0
- package/dist/elements/svg/logo-flickr.svg +1 -0
- package/dist/elements/svg/logo-foursquare.svg +1 -0
- package/dist/elements/svg/logo-github.svg +1 -0
- package/dist/elements/svg/logo-gitlab.svg +1 -0
- package/dist/elements/svg/logo-google-playstore.svg +1 -0
- package/dist/elements/svg/logo-google.svg +1 -0
- package/dist/elements/svg/logo-hackernews.svg +1 -0
- package/dist/elements/svg/logo-html5.svg +1 -0
- package/dist/elements/svg/logo-instagram.svg +1 -0
- package/dist/elements/svg/logo-ionic.svg +1 -0
- package/dist/elements/svg/logo-ionitron.svg +1 -0
- package/dist/elements/svg/logo-javascript.svg +1 -0
- package/dist/elements/svg/logo-laravel.svg +1 -0
- package/dist/elements/svg/logo-linkedin.svg +1 -0
- package/dist/elements/svg/logo-markdown.svg +1 -0
- package/dist/elements/svg/logo-mastodon.svg +1 -0
- package/dist/elements/svg/logo-medium.svg +1 -0
- package/dist/elements/svg/logo-microsoft.svg +1 -0
- package/dist/elements/svg/logo-no-smoking.svg +1 -0
- package/dist/elements/svg/logo-nodejs.svg +1 -0
- package/dist/elements/svg/logo-npm.svg +1 -0
- package/dist/elements/svg/logo-octocat.svg +1 -0
- package/dist/elements/svg/logo-paypal.svg +1 -0
- package/dist/elements/svg/logo-pinterest.svg +1 -0
- package/dist/elements/svg/logo-playstation.svg +1 -0
- package/dist/elements/svg/logo-pwa.svg +1 -0
- package/dist/elements/svg/logo-python.svg +1 -0
- package/dist/elements/svg/logo-react.svg +1 -0
- package/dist/elements/svg/logo-reddit.svg +1 -0
- package/dist/elements/svg/logo-rss.svg +1 -0
- package/dist/elements/svg/logo-sass.svg +1 -0
- package/dist/elements/svg/logo-skype.svg +1 -0
- package/dist/elements/svg/logo-slack.svg +1 -0
- package/dist/elements/svg/logo-snapchat.svg +1 -0
- package/dist/elements/svg/logo-soundcloud.svg +1 -0
- package/dist/elements/svg/logo-stackoverflow.svg +1 -0
- package/dist/elements/svg/logo-steam.svg +1 -0
- package/dist/elements/svg/logo-stencil.svg +1 -0
- package/dist/elements/svg/logo-tableau.svg +1 -0
- package/dist/elements/svg/logo-tiktok.svg +1 -0
- package/dist/elements/svg/logo-tumblr.svg +1 -0
- package/dist/elements/svg/logo-tux.svg +1 -0
- package/dist/elements/svg/logo-twitch.svg +1 -0
- package/dist/elements/svg/logo-twitter.svg +1 -0
- package/dist/elements/svg/logo-usd.svg +1 -0
- package/dist/elements/svg/logo-venmo.svg +1 -0
- package/dist/elements/svg/logo-vercel.svg +1 -0
- package/dist/elements/svg/logo-vimeo.svg +1 -0
- package/dist/elements/svg/logo-vk.svg +1 -0
- package/dist/elements/svg/logo-vue.svg +1 -0
- package/dist/elements/svg/logo-web-component.svg +1 -0
- package/dist/elements/svg/logo-wechat.svg +1 -0
- package/dist/elements/svg/logo-whatsapp.svg +1 -0
- package/dist/elements/svg/logo-windows.svg +1 -0
- package/dist/elements/svg/logo-wordpress.svg +1 -0
- package/dist/elements/svg/logo-xbox.svg +1 -0
- package/dist/elements/svg/logo-xing.svg +1 -0
- package/dist/elements/svg/logo-yahoo.svg +1 -0
- package/dist/elements/svg/logo-yen.svg +1 -0
- package/dist/elements/svg/logo-youtube.svg +1 -0
- package/dist/elements/svg/magnet-outline.svg +1 -0
- package/dist/elements/svg/magnet-sharp.svg +1 -0
- package/dist/elements/svg/magnet.svg +1 -0
- package/dist/elements/svg/mail-open-outline.svg +1 -0
- package/dist/elements/svg/mail-open-sharp.svg +1 -0
- package/dist/elements/svg/mail-open.svg +1 -0
- package/dist/elements/svg/mail-outline.svg +1 -0
- package/dist/elements/svg/mail-sharp.svg +1 -0
- package/dist/elements/svg/mail-unread-outline.svg +1 -0
- package/dist/elements/svg/mail-unread-sharp.svg +1 -0
- package/dist/elements/svg/mail-unread.svg +1 -0
- package/dist/elements/svg/mail.svg +1 -0
- package/dist/elements/svg/male-female-outline.svg +1 -0
- package/dist/elements/svg/male-female-sharp.svg +1 -0
- package/dist/elements/svg/male-female.svg +1 -0
- package/dist/elements/svg/male-outline.svg +1 -0
- package/dist/elements/svg/male-sharp.svg +1 -0
- package/dist/elements/svg/male.svg +1 -0
- package/dist/elements/svg/man-outline.svg +1 -0
- package/dist/elements/svg/man-sharp.svg +1 -0
- package/dist/elements/svg/man.svg +1 -0
- package/dist/elements/svg/map-outline.svg +1 -0
- package/dist/elements/svg/map-sharp.svg +1 -0
- package/dist/elements/svg/map.svg +1 -0
- package/dist/elements/svg/medal-outline.svg +1 -0
- package/dist/elements/svg/medal-sharp.svg +1 -0
- package/dist/elements/svg/medal.svg +1 -0
- package/dist/elements/svg/medical-outline.svg +1 -0
- package/dist/elements/svg/medical-sharp.svg +1 -0
- package/dist/elements/svg/medical.svg +1 -0
- package/dist/elements/svg/medkit-outline.svg +1 -0
- package/dist/elements/svg/medkit-sharp.svg +1 -0
- package/dist/elements/svg/medkit.svg +1 -0
- package/dist/elements/svg/megaphone-outline.svg +1 -0
- package/dist/elements/svg/megaphone-sharp.svg +1 -0
- package/dist/elements/svg/megaphone.svg +1 -0
- package/dist/elements/svg/menu-outline.svg +1 -0
- package/dist/elements/svg/menu-sharp.svg +1 -0
- package/dist/elements/svg/menu.svg +1 -0
- package/dist/elements/svg/mic-circle-outline.svg +1 -0
- package/dist/elements/svg/mic-circle-sharp.svg +1 -0
- package/dist/elements/svg/mic-circle.svg +1 -0
- package/dist/elements/svg/mic-off-circle-outline.svg +1 -0
- package/dist/elements/svg/mic-off-circle-sharp.svg +1 -0
- package/dist/elements/svg/mic-off-circle.svg +1 -0
- package/dist/elements/svg/mic-off-outline.svg +1 -0
- package/dist/elements/svg/mic-off-sharp.svg +1 -0
- package/dist/elements/svg/mic-off.svg +1 -0
- package/dist/elements/svg/mic-outline.svg +1 -0
- package/dist/elements/svg/mic-sharp.svg +1 -0
- package/dist/elements/svg/mic.svg +1 -0
- package/dist/elements/svg/moon-outline.svg +1 -0
- package/dist/elements/svg/moon-sharp.svg +1 -0
- package/dist/elements/svg/moon.svg +1 -0
- package/dist/elements/svg/move-outline.svg +1 -0
- package/dist/elements/svg/move-sharp.svg +1 -0
- package/dist/elements/svg/move.svg +1 -0
- package/dist/elements/svg/musical-note-outline.svg +1 -0
- package/dist/elements/svg/musical-note-sharp.svg +1 -0
- package/dist/elements/svg/musical-note.svg +1 -0
- package/dist/elements/svg/musical-notes-outline.svg +1 -0
- package/dist/elements/svg/musical-notes-sharp.svg +1 -0
- package/dist/elements/svg/musical-notes.svg +1 -0
- package/dist/elements/svg/navigate-circle-outline.svg +1 -0
- package/dist/elements/svg/navigate-circle-sharp.svg +1 -0
- package/dist/elements/svg/navigate-circle.svg +1 -0
- package/dist/elements/svg/navigate-outline.svg +1 -0
- package/dist/elements/svg/navigate-sharp.svg +1 -0
- package/dist/elements/svg/navigate.svg +1 -0
- package/dist/elements/svg/newspaper-outline.svg +1 -0
- package/dist/elements/svg/newspaper-sharp.svg +1 -0
- package/dist/elements/svg/newspaper.svg +1 -0
- package/dist/elements/svg/notifications-circle-outline.svg +1 -0
- package/dist/elements/svg/notifications-circle-sharp.svg +1 -0
- package/dist/elements/svg/notifications-circle.svg +1 -0
- package/dist/elements/svg/notifications-off-circle-outline.svg +1 -0
- package/dist/elements/svg/notifications-off-circle-sharp.svg +1 -0
- package/dist/elements/svg/notifications-off-circle.svg +1 -0
- package/dist/elements/svg/notifications-off-outline.svg +1 -0
- package/dist/elements/svg/notifications-off-sharp.svg +1 -0
- package/dist/elements/svg/notifications-off.svg +1 -0
- package/dist/elements/svg/notifications-outline.svg +1 -0
- package/dist/elements/svg/notifications-sharp.svg +1 -0
- package/dist/elements/svg/notifications.svg +1 -0
- package/dist/elements/svg/nuclear-outline.svg +1 -0
- package/dist/elements/svg/nuclear-sharp.svg +1 -0
- package/dist/elements/svg/nuclear.svg +1 -0
- package/dist/elements/svg/nutrition-outline.svg +1 -0
- package/dist/elements/svg/nutrition-sharp.svg +1 -0
- package/dist/elements/svg/nutrition.svg +1 -0
- package/dist/elements/svg/open-outline.svg +1 -0
- package/dist/elements/svg/open-sharp.svg +1 -0
- package/dist/elements/svg/open.svg +1 -0
- package/dist/elements/svg/options-outline.svg +1 -0
- package/dist/elements/svg/options-sharp.svg +1 -0
- package/dist/elements/svg/options.svg +1 -0
- package/dist/elements/svg/paper-plane-outline.svg +1 -0
- package/dist/elements/svg/paper-plane-sharp.svg +1 -0
- package/dist/elements/svg/paper-plane.svg +1 -0
- package/dist/elements/svg/partly-sunny-outline.svg +1 -0
- package/dist/elements/svg/partly-sunny-sharp.svg +1 -0
- package/dist/elements/svg/partly-sunny.svg +1 -0
- package/dist/elements/svg/pause-circle-outline.svg +1 -0
- package/dist/elements/svg/pause-circle-sharp.svg +1 -0
- package/dist/elements/svg/pause-circle.svg +1 -0
- package/dist/elements/svg/pause-outline.svg +1 -0
- package/dist/elements/svg/pause-sharp.svg +1 -0
- package/dist/elements/svg/pause.svg +1 -0
- package/dist/elements/svg/paw-outline.svg +1 -0
- package/dist/elements/svg/paw-sharp.svg +1 -0
- package/dist/elements/svg/paw.svg +1 -0
- package/dist/elements/svg/pencil-outline.svg +1 -0
- package/dist/elements/svg/pencil-sharp.svg +1 -0
- package/dist/elements/svg/pencil.svg +1 -0
- package/dist/elements/svg/people-circle-outline.svg +1 -0
- package/dist/elements/svg/people-circle-sharp.svg +1 -0
- package/dist/elements/svg/people-circle.svg +1 -0
- package/dist/elements/svg/people-outline.svg +1 -0
- package/dist/elements/svg/people-sharp.svg +1 -0
- package/dist/elements/svg/people.svg +1 -0
- package/dist/elements/svg/person-add-outline.svg +1 -0
- package/dist/elements/svg/person-add-sharp.svg +1 -0
- package/dist/elements/svg/person-add.svg +1 -0
- package/dist/elements/svg/person-circle-outline.svg +1 -0
- package/dist/elements/svg/person-circle-sharp.svg +1 -0
- package/dist/elements/svg/person-circle.svg +1 -0
- package/dist/elements/svg/person-outline.svg +1 -0
- package/dist/elements/svg/person-remove-outline.svg +1 -0
- package/dist/elements/svg/person-remove-sharp.svg +1 -0
- package/dist/elements/svg/person-remove.svg +1 -0
- package/dist/elements/svg/person-sharp.svg +1 -0
- package/dist/elements/svg/person.svg +1 -0
- package/dist/elements/svg/phone-landscape-outline.svg +1 -0
- package/dist/elements/svg/phone-landscape-sharp.svg +1 -0
- package/dist/elements/svg/phone-landscape.svg +1 -0
- package/dist/elements/svg/phone-portrait-outline.svg +1 -0
- package/dist/elements/svg/phone-portrait-sharp.svg +1 -0
- package/dist/elements/svg/phone-portrait.svg +1 -0
- package/dist/elements/svg/pie-chart-outline.svg +1 -0
- package/dist/elements/svg/pie-chart-sharp.svg +1 -0
- package/dist/elements/svg/pie-chart.svg +1 -0
- package/dist/elements/svg/pin-outline.svg +1 -0
- package/dist/elements/svg/pin-sharp.svg +1 -0
- package/dist/elements/svg/pin.svg +1 -0
- package/dist/elements/svg/pint-outline.svg +1 -0
- package/dist/elements/svg/pint-sharp.svg +1 -0
- package/dist/elements/svg/pint.svg +1 -0
- package/dist/elements/svg/pizza-outline.svg +1 -0
- package/dist/elements/svg/pizza-sharp.svg +1 -0
- package/dist/elements/svg/pizza.svg +1 -0
- package/dist/elements/svg/planet-outline.svg +1 -0
- package/dist/elements/svg/planet-sharp.svg +1 -0
- package/dist/elements/svg/planet.svg +1 -0
- package/dist/elements/svg/play-back-circle-outline.svg +1 -0
- package/dist/elements/svg/play-back-circle-sharp.svg +1 -0
- package/dist/elements/svg/play-back-circle.svg +1 -0
- package/dist/elements/svg/play-back-outline.svg +1 -0
- package/dist/elements/svg/play-back-sharp.svg +1 -0
- package/dist/elements/svg/play-back.svg +1 -0
- package/dist/elements/svg/play-circle-outline.svg +1 -0
- package/dist/elements/svg/play-circle-sharp.svg +1 -0
- package/dist/elements/svg/play-circle.svg +1 -0
- package/dist/elements/svg/play-forward-circle-outline.svg +1 -0
- package/dist/elements/svg/play-forward-circle-sharp.svg +1 -0
- package/dist/elements/svg/play-forward-circle.svg +1 -0
- package/dist/elements/svg/play-forward-outline.svg +1 -0
- package/dist/elements/svg/play-forward-sharp.svg +1 -0
- package/dist/elements/svg/play-forward.svg +1 -0
- package/dist/elements/svg/play-outline.svg +1 -0
- package/dist/elements/svg/play-sharp.svg +1 -0
- package/dist/elements/svg/play-skip-back-circle-outline.svg +1 -0
- package/dist/elements/svg/play-skip-back-circle-sharp.svg +1 -0
- package/dist/elements/svg/play-skip-back-circle.svg +1 -0
- package/dist/elements/svg/play-skip-back-outline.svg +1 -0
- package/dist/elements/svg/play-skip-back-sharp.svg +1 -0
- package/dist/elements/svg/play-skip-back.svg +1 -0
- package/dist/elements/svg/play-skip-forward-circle-outline.svg +1 -0
- package/dist/elements/svg/play-skip-forward-circle-sharp.svg +1 -0
- package/dist/elements/svg/play-skip-forward-circle.svg +1 -0
- package/dist/elements/svg/play-skip-forward-outline.svg +1 -0
- package/dist/elements/svg/play-skip-forward-sharp.svg +1 -0
- package/dist/elements/svg/play-skip-forward.svg +1 -0
- package/dist/elements/svg/play.svg +1 -0
- package/dist/elements/svg/podium-outline.svg +1 -0
- package/dist/elements/svg/podium-sharp.svg +1 -0
- package/dist/elements/svg/podium.svg +1 -0
- package/dist/elements/svg/power-outline.svg +1 -0
- package/dist/elements/svg/power-sharp.svg +1 -0
- package/dist/elements/svg/power.svg +1 -0
- package/dist/elements/svg/pricetag-outline.svg +1 -0
- package/dist/elements/svg/pricetag-sharp.svg +1 -0
- package/dist/elements/svg/pricetag.svg +1 -0
- package/dist/elements/svg/pricetags-outline.svg +1 -0
- package/dist/elements/svg/pricetags-sharp.svg +1 -0
- package/dist/elements/svg/pricetags.svg +1 -0
- package/dist/elements/svg/print-outline.svg +1 -0
- package/dist/elements/svg/print-sharp.svg +1 -0
- package/dist/elements/svg/print.svg +1 -0
- package/dist/elements/svg/prism-outline.svg +1 -0
- package/dist/elements/svg/prism-sharp.svg +1 -0
- package/dist/elements/svg/prism.svg +1 -0
- package/dist/elements/svg/pulse-outline.svg +1 -0
- package/dist/elements/svg/pulse-sharp.svg +1 -0
- package/dist/elements/svg/pulse.svg +1 -0
- package/dist/elements/svg/push-outline.svg +1 -0
- package/dist/elements/svg/push-sharp.svg +1 -0
- package/dist/elements/svg/push.svg +1 -0
- package/dist/elements/svg/qr-code-outline.svg +1 -0
- package/dist/elements/svg/qr-code-sharp.svg +1 -0
- package/dist/elements/svg/qr-code.svg +1 -0
- package/dist/elements/svg/radio-button-off-outline.svg +1 -0
- package/dist/elements/svg/radio-button-off-sharp.svg +1 -0
- package/dist/elements/svg/radio-button-off.svg +1 -0
- package/dist/elements/svg/radio-button-on-outline.svg +1 -0
- package/dist/elements/svg/radio-button-on-sharp.svg +1 -0
- package/dist/elements/svg/radio-button-on.svg +1 -0
- package/dist/elements/svg/radio-outline.svg +1 -0
- package/dist/elements/svg/radio-sharp.svg +1 -0
- package/dist/elements/svg/radio.svg +1 -0
- package/dist/elements/svg/rainy-outline.svg +1 -0
- package/dist/elements/svg/rainy-sharp.svg +1 -0
- package/dist/elements/svg/rainy.svg +1 -0
- package/dist/elements/svg/reader-outline.svg +1 -0
- package/dist/elements/svg/reader-sharp.svg +1 -0
- package/dist/elements/svg/reader.svg +1 -0
- package/dist/elements/svg/receipt-outline.svg +1 -0
- package/dist/elements/svg/receipt-sharp.svg +1 -0
- package/dist/elements/svg/receipt.svg +1 -0
- package/dist/elements/svg/recording-outline.svg +1 -0
- package/dist/elements/svg/recording-sharp.svg +1 -0
- package/dist/elements/svg/recording.svg +1 -0
- package/dist/elements/svg/refresh-circle-outline.svg +1 -0
- package/dist/elements/svg/refresh-circle-sharp.svg +1 -0
- package/dist/elements/svg/refresh-circle.svg +1 -0
- package/dist/elements/svg/refresh-outline.svg +1 -0
- package/dist/elements/svg/refresh-sharp.svg +1 -0
- package/dist/elements/svg/refresh.svg +1 -0
- package/dist/elements/svg/reload-circle-outline.svg +1 -0
- package/dist/elements/svg/reload-circle-sharp.svg +1 -0
- package/dist/elements/svg/reload-circle.svg +1 -0
- package/dist/elements/svg/reload-outline.svg +1 -0
- package/dist/elements/svg/reload-sharp.svg +1 -0
- package/dist/elements/svg/reload.svg +1 -0
- package/dist/elements/svg/remove-circle-outline.svg +1 -0
- package/dist/elements/svg/remove-circle-sharp.svg +1 -0
- package/dist/elements/svg/remove-circle.svg +1 -0
- package/dist/elements/svg/remove-outline.svg +1 -0
- package/dist/elements/svg/remove-sharp.svg +1 -0
- package/dist/elements/svg/remove.svg +1 -0
- package/dist/elements/svg/reorder-four-outline.svg +1 -0
- package/dist/elements/svg/reorder-four-sharp.svg +1 -0
- package/dist/elements/svg/reorder-four.svg +1 -0
- package/dist/elements/svg/reorder-three-outline.svg +1 -0
- package/dist/elements/svg/reorder-three-sharp.svg +1 -0
- package/dist/elements/svg/reorder-three.svg +1 -0
- package/dist/elements/svg/reorder-two-outline.svg +1 -0
- package/dist/elements/svg/reorder-two-sharp.svg +1 -0
- package/dist/elements/svg/reorder-two.svg +1 -0
- package/dist/elements/svg/repeat-outline.svg +1 -0
- package/dist/elements/svg/repeat-sharp.svg +1 -0
- package/dist/elements/svg/repeat.svg +1 -0
- package/dist/elements/svg/resize-outline.svg +1 -0
- package/dist/elements/svg/resize-sharp.svg +1 -0
- package/dist/elements/svg/resize.svg +1 -0
- package/dist/elements/svg/restaurant-outline.svg +1 -0
- package/dist/elements/svg/restaurant-sharp.svg +1 -0
- package/dist/elements/svg/restaurant.svg +1 -0
- package/dist/elements/svg/return-down-back-outline.svg +1 -0
- package/dist/elements/svg/return-down-back-sharp.svg +1 -0
- package/dist/elements/svg/return-down-back.svg +1 -0
- package/dist/elements/svg/return-down-forward-outline.svg +1 -0
- package/dist/elements/svg/return-down-forward-sharp.svg +1 -0
- package/dist/elements/svg/return-down-forward.svg +1 -0
- package/dist/elements/svg/return-up-back-outline.svg +1 -0
- package/dist/elements/svg/return-up-back-sharp.svg +1 -0
- package/dist/elements/svg/return-up-back.svg +1 -0
- package/dist/elements/svg/return-up-forward-outline.svg +1 -0
- package/dist/elements/svg/return-up-forward-sharp.svg +1 -0
- package/dist/elements/svg/return-up-forward.svg +1 -0
- package/dist/elements/svg/ribbon-outline.svg +1 -0
- package/dist/elements/svg/ribbon-sharp.svg +1 -0
- package/dist/elements/svg/ribbon.svg +1 -0
- package/dist/elements/svg/rocket-outline.svg +1 -0
- package/dist/elements/svg/rocket-sharp.svg +1 -0
- package/dist/elements/svg/rocket.svg +1 -0
- package/dist/elements/svg/rose-outline.svg +1 -0
- package/dist/elements/svg/rose-sharp.svg +1 -0
- package/dist/elements/svg/rose.svg +1 -0
- package/dist/elements/svg/sad-outline.svg +1 -0
- package/dist/elements/svg/sad-sharp.svg +1 -0
- package/dist/elements/svg/sad.svg +1 -0
- package/dist/elements/svg/save-outline.svg +1 -0
- package/dist/elements/svg/save-sharp.svg +1 -0
- package/dist/elements/svg/save.svg +1 -0
- package/dist/elements/svg/scale-outline.svg +1 -0
- package/dist/elements/svg/scale-sharp.svg +1 -0
- package/dist/elements/svg/scale.svg +1 -0
- package/dist/elements/svg/scan-circle-outline.svg +1 -0
- package/dist/elements/svg/scan-circle-sharp.svg +1 -0
- package/dist/elements/svg/scan-circle.svg +1 -0
- package/dist/elements/svg/scan-outline.svg +1 -0
- package/dist/elements/svg/scan-sharp.svg +1 -0
- package/dist/elements/svg/scan.svg +1 -0
- package/dist/elements/svg/school-outline.svg +1 -0
- package/dist/elements/svg/school-sharp.svg +1 -0
- package/dist/elements/svg/school.svg +1 -0
- package/dist/elements/svg/search-circle-outline.svg +1 -0
- package/dist/elements/svg/search-circle-sharp.svg +1 -0
- package/dist/elements/svg/search-circle.svg +1 -0
- package/dist/elements/svg/search-outline.svg +1 -0
- package/dist/elements/svg/search-sharp.svg +1 -0
- package/dist/elements/svg/search.svg +1 -0
- package/dist/elements/svg/send-outline.svg +1 -0
- package/dist/elements/svg/send-sharp.svg +1 -0
- package/dist/elements/svg/send.svg +1 -0
- package/dist/elements/svg/server-outline.svg +1 -0
- package/dist/elements/svg/server-sharp.svg +1 -0
- package/dist/elements/svg/server.svg +1 -0
- package/dist/elements/svg/settings-outline.svg +1 -0
- package/dist/elements/svg/settings-sharp.svg +1 -0
- package/dist/elements/svg/settings.svg +1 -0
- package/dist/elements/svg/shapes-outline.svg +1 -0
- package/dist/elements/svg/shapes-sharp.svg +1 -0
- package/dist/elements/svg/shapes.svg +1 -0
- package/dist/elements/svg/share-outline.svg +1 -0
- package/dist/elements/svg/share-sharp.svg +1 -0
- package/dist/elements/svg/share-social-outline.svg +1 -0
- package/dist/elements/svg/share-social-sharp.svg +1 -0
- package/dist/elements/svg/share-social.svg +1 -0
- package/dist/elements/svg/share.svg +1 -0
- package/dist/elements/svg/shield-checkmark-outline.svg +1 -0
- package/dist/elements/svg/shield-checkmark-sharp.svg +1 -0
- package/dist/elements/svg/shield-checkmark.svg +1 -0
- package/dist/elements/svg/shield-half-outline.svg +1 -0
- package/dist/elements/svg/shield-half-sharp.svg +1 -0
- package/dist/elements/svg/shield-half.svg +1 -0
- package/dist/elements/svg/shield-outline.svg +1 -0
- package/dist/elements/svg/shield-sharp.svg +1 -0
- package/dist/elements/svg/shield.svg +1 -0
- package/dist/elements/svg/shirt-outline.svg +1 -0
- package/dist/elements/svg/shirt-sharp.svg +1 -0
- package/dist/elements/svg/shirt.svg +1 -0
- package/dist/elements/svg/shuffle-outline.svg +1 -0
- package/dist/elements/svg/shuffle-sharp.svg +1 -0
- package/dist/elements/svg/shuffle.svg +1 -0
- package/dist/elements/svg/skull-outline.svg +1 -0
- package/dist/elements/svg/skull-sharp.svg +1 -0
- package/dist/elements/svg/skull.svg +1 -0
- package/dist/elements/svg/snow-outline.svg +1 -0
- package/dist/elements/svg/snow-sharp.svg +1 -0
- package/dist/elements/svg/snow.svg +1 -0
- package/dist/elements/svg/sparkles-outline.svg +1 -0
- package/dist/elements/svg/sparkles-sharp.svg +1 -0
- package/dist/elements/svg/sparkles.svg +1 -0
- package/dist/elements/svg/speedometer-outline.svg +1 -0
- package/dist/elements/svg/speedometer-sharp.svg +1 -0
- package/dist/elements/svg/speedometer.svg +1 -0
- package/dist/elements/svg/square-outline.svg +1 -0
- package/dist/elements/svg/square-sharp.svg +1 -0
- package/dist/elements/svg/square.svg +1 -0
- package/dist/elements/svg/star-half-outline.svg +1 -0
- package/dist/elements/svg/star-half-sharp.svg +1 -0
- package/dist/elements/svg/star-half.svg +1 -0
- package/dist/elements/svg/star-outline.svg +1 -0
- package/dist/elements/svg/star-sharp.svg +1 -0
- package/dist/elements/svg/star.svg +1 -0
- package/dist/elements/svg/stats-chart-outline.svg +1 -0
- package/dist/elements/svg/stats-chart-sharp.svg +1 -0
- package/dist/elements/svg/stats-chart.svg +1 -0
- package/dist/elements/svg/stop-circle-outline.svg +1 -0
- package/dist/elements/svg/stop-circle-sharp.svg +1 -0
- package/dist/elements/svg/stop-circle.svg +1 -0
- package/dist/elements/svg/stop-outline.svg +1 -0
- package/dist/elements/svg/stop-sharp.svg +1 -0
- package/dist/elements/svg/stop.svg +1 -0
- package/dist/elements/svg/stopwatch-outline.svg +1 -0
- package/dist/elements/svg/stopwatch-sharp.svg +1 -0
- package/dist/elements/svg/stopwatch.svg +1 -0
- package/dist/elements/svg/storefront-outline.svg +1 -0
- package/dist/elements/svg/storefront-sharp.svg +1 -0
- package/dist/elements/svg/storefront.svg +1 -0
- package/dist/elements/svg/subway-outline.svg +1 -0
- package/dist/elements/svg/subway-sharp.svg +1 -0
- package/dist/elements/svg/subway.svg +1 -0
- package/dist/elements/svg/sunny-outline.svg +1 -0
- package/dist/elements/svg/sunny-sharp.svg +1 -0
- package/dist/elements/svg/sunny.svg +1 -0
- package/dist/elements/svg/swap-horizontal-outline.svg +1 -0
- package/dist/elements/svg/swap-horizontal-sharp.svg +1 -0
- package/dist/elements/svg/swap-horizontal.svg +1 -0
- package/dist/elements/svg/swap-vertical-outline.svg +1 -0
- package/dist/elements/svg/swap-vertical-sharp.svg +1 -0
- package/dist/elements/svg/swap-vertical.svg +1 -0
- package/dist/elements/svg/sync-circle-outline.svg +1 -0
- package/dist/elements/svg/sync-circle-sharp.svg +1 -0
- package/dist/elements/svg/sync-circle.svg +1 -0
- package/dist/elements/svg/sync-outline.svg +1 -0
- package/dist/elements/svg/sync-sharp.svg +1 -0
- package/dist/elements/svg/sync.svg +1 -0
- package/dist/elements/svg/tablet-landscape-outline.svg +1 -0
- package/dist/elements/svg/tablet-landscape-sharp.svg +1 -0
- package/dist/elements/svg/tablet-landscape.svg +1 -0
- package/dist/elements/svg/tablet-portrait-outline.svg +1 -0
- package/dist/elements/svg/tablet-portrait-sharp.svg +1 -0
- package/dist/elements/svg/tablet-portrait.svg +1 -0
- package/dist/elements/svg/telescope-outline.svg +1 -0
- package/dist/elements/svg/telescope-sharp.svg +1 -0
- package/dist/elements/svg/telescope.svg +1 -0
- package/dist/elements/svg/tennisball-outline.svg +1 -0
- package/dist/elements/svg/tennisball-sharp.svg +1 -0
- package/dist/elements/svg/tennisball.svg +1 -0
- package/dist/elements/svg/terminal-outline.svg +1 -0
- package/dist/elements/svg/terminal-sharp.svg +1 -0
- package/dist/elements/svg/terminal.svg +1 -0
- package/dist/elements/svg/text-outline.svg +1 -0
- package/dist/elements/svg/text-sharp.svg +1 -0
- package/dist/elements/svg/text.svg +1 -0
- package/dist/elements/svg/thermometer-outline.svg +1 -0
- package/dist/elements/svg/thermometer-sharp.svg +1 -0
- package/dist/elements/svg/thermometer.svg +1 -0
- package/dist/elements/svg/thumbs-down-outline.svg +1 -0
- package/dist/elements/svg/thumbs-down-sharp.svg +1 -0
- package/dist/elements/svg/thumbs-down.svg +1 -0
- package/dist/elements/svg/thumbs-up-outline.svg +1 -0
- package/dist/elements/svg/thumbs-up-sharp.svg +1 -0
- package/dist/elements/svg/thumbs-up.svg +1 -0
- package/dist/elements/svg/thunderstorm-outline.svg +1 -0
- package/dist/elements/svg/thunderstorm-sharp.svg +1 -0
- package/dist/elements/svg/thunderstorm.svg +1 -0
- package/dist/elements/svg/ticket-outline.svg +1 -0
- package/dist/elements/svg/ticket-sharp.svg +1 -0
- package/dist/elements/svg/ticket.svg +1 -0
- package/dist/elements/svg/time-outline.svg +1 -0
- package/dist/elements/svg/time-sharp.svg +1 -0
- package/dist/elements/svg/time.svg +1 -0
- package/dist/elements/svg/timer-outline.svg +1 -0
- package/dist/elements/svg/timer-sharp.svg +1 -0
- package/dist/elements/svg/timer.svg +1 -0
- package/dist/elements/svg/today-outline.svg +1 -0
- package/dist/elements/svg/today-sharp.svg +1 -0
- package/dist/elements/svg/today.svg +1 -0
- package/dist/elements/svg/toggle-outline.svg +1 -0
- package/dist/elements/svg/toggle-sharp.svg +1 -0
- package/dist/elements/svg/toggle.svg +1 -0
- package/dist/elements/svg/trail-sign-outline.svg +1 -0
- package/dist/elements/svg/trail-sign-sharp.svg +1 -0
- package/dist/elements/svg/trail-sign.svg +1 -0
- package/dist/elements/svg/train-outline.svg +1 -0
- package/dist/elements/svg/train-sharp.svg +1 -0
- package/dist/elements/svg/train.svg +1 -0
- package/dist/elements/svg/transgender-outline.svg +1 -0
- package/dist/elements/svg/transgender-sharp.svg +1 -0
- package/dist/elements/svg/transgender.svg +1 -0
- package/dist/elements/svg/trash-bin-outline.svg +1 -0
- package/dist/elements/svg/trash-bin-sharp.svg +1 -0
- package/dist/elements/svg/trash-bin.svg +1 -0
- package/dist/elements/svg/trash-outline.svg +1 -0
- package/dist/elements/svg/trash-sharp.svg +1 -0
- package/dist/elements/svg/trash.svg +1 -0
- package/dist/elements/svg/trending-down-outline.svg +1 -0
- package/dist/elements/svg/trending-down-sharp.svg +1 -0
- package/dist/elements/svg/trending-down.svg +1 -0
- package/dist/elements/svg/trending-up-outline.svg +1 -0
- package/dist/elements/svg/trending-up-sharp.svg +1 -0
- package/dist/elements/svg/trending-up.svg +1 -0
- package/dist/elements/svg/triangle-outline.svg +1 -0
- package/dist/elements/svg/triangle-sharp.svg +1 -0
- package/dist/elements/svg/triangle.svg +1 -0
- package/dist/elements/svg/trophy-outline.svg +1 -0
- package/dist/elements/svg/trophy-sharp.svg +1 -0
- package/dist/elements/svg/trophy.svg +1 -0
- package/dist/elements/svg/tv-outline.svg +1 -0
- package/dist/elements/svg/tv-sharp.svg +1 -0
- package/dist/elements/svg/tv.svg +1 -0
- package/dist/elements/svg/umbrella-outline.svg +1 -0
- package/dist/elements/svg/umbrella-sharp.svg +1 -0
- package/dist/elements/svg/umbrella.svg +1 -0
- package/dist/elements/svg/unlink-outline.svg +1 -0
- package/dist/elements/svg/unlink-sharp.svg +1 -0
- package/dist/elements/svg/unlink.svg +1 -0
- package/dist/elements/svg/videocam-off-outline.svg +1 -0
- package/dist/elements/svg/videocam-off-sharp.svg +1 -0
- package/dist/elements/svg/videocam-off.svg +1 -0
- package/dist/elements/svg/videocam-outline.svg +1 -0
- package/dist/elements/svg/videocam-sharp.svg +1 -0
- package/dist/elements/svg/videocam.svg +1 -0
- package/dist/elements/svg/volume-high-outline.svg +1 -0
- package/dist/elements/svg/volume-high-sharp.svg +1 -0
- package/dist/elements/svg/volume-high.svg +1 -0
- package/dist/elements/svg/volume-low-outline.svg +1 -0
- package/dist/elements/svg/volume-low-sharp.svg +1 -0
- package/dist/elements/svg/volume-low.svg +1 -0
- package/dist/elements/svg/volume-medium-outline.svg +1 -0
- package/dist/elements/svg/volume-medium-sharp.svg +1 -0
- package/dist/elements/svg/volume-medium.svg +1 -0
- package/dist/elements/svg/volume-mute-outline.svg +1 -0
- package/dist/elements/svg/volume-mute-sharp.svg +1 -0
- package/dist/elements/svg/volume-mute.svg +1 -0
- package/dist/elements/svg/volume-off-outline.svg +1 -0
- package/dist/elements/svg/volume-off-sharp.svg +1 -0
- package/dist/elements/svg/volume-off.svg +1 -0
- package/dist/elements/svg/walk-outline.svg +1 -0
- package/dist/elements/svg/walk-sharp.svg +1 -0
- package/dist/elements/svg/walk.svg +1 -0
- package/dist/elements/svg/wallet-outline.svg +1 -0
- package/dist/elements/svg/wallet-sharp.svg +1 -0
- package/dist/elements/svg/wallet.svg +1 -0
- package/dist/elements/svg/warning-outline.svg +1 -0
- package/dist/elements/svg/warning-sharp.svg +1 -0
- package/dist/elements/svg/warning.svg +1 -0
- package/dist/elements/svg/watch-outline.svg +1 -0
- package/dist/elements/svg/watch-sharp.svg +1 -0
- package/dist/elements/svg/watch.svg +1 -0
- package/dist/elements/svg/water-outline.svg +1 -0
- package/dist/elements/svg/water-sharp.svg +1 -0
- package/dist/elements/svg/water.svg +1 -0
- package/dist/elements/svg/wifi-outline.svg +1 -0
- package/dist/elements/svg/wifi-sharp.svg +1 -0
- package/dist/elements/svg/wifi.svg +1 -0
- package/dist/elements/svg/wine-outline.svg +1 -0
- package/dist/elements/svg/wine-sharp.svg +1 -0
- package/dist/elements/svg/wine.svg +1 -0
- package/dist/elements/svg/woman-outline.svg +1 -0
- package/dist/elements/svg/woman-sharp.svg +1 -0
- package/dist/elements/svg/woman.svg +1 -0
- package/dist/elements/swiper/swiper-interface.d.ts +1 -0
- package/dist/elements/swiper/swiper.bundle.js +6418 -0
- package/dist/elements/swiper/swiper.js +4 -0
- package/dist/esm/animation-23699cc5.js +955 -0
- package/dist/esm/app-globals-b3330c28.js +7 -0
- package/dist/esm/button-active-8918719c.js +64 -0
- package/dist/esm/cubic-bezier-ed243a9b.js +89 -0
- package/dist/esm/elements.js +20 -0
- package/dist/esm/focus-visible-abf04ce3.js +43 -0
- package/dist/esm/framework-delegate-0a271c52.js +34 -0
- package/dist/esm/gesture-controller-604336b7.js +191 -0
- package/dist/esm/haptic-67928174.js +106 -0
- package/dist/esm/hardware-back-button-508e48cf.js +68 -0
- package/dist/esm/helpers-dffac6f7.js +247 -0
- package/dist/esm/index-51ec9e66.js +448 -0
- package/dist/esm/index-82f710ea.js +1798 -0
- package/dist/esm/index-cc97b114.js +133 -0
- package/dist/esm/index-db7c08b4.js +213 -0
- package/dist/esm/index-f910ce2c.js +306 -0
- package/dist/esm/index.js +1 -0
- package/dist/esm/input-shims-9c0b3bc9.js +398 -0
- package/dist/esm/ion-action-sheet.entry.js +261 -0
- package/dist/esm/ion-alert.entry.js +452 -0
- package/dist/esm/ion-app_32.entry.js +2358 -0
- package/dist/esm/ion-avatar.entry.js +21 -0
- package/dist/esm/ion-back-button.entry.js +85 -0
- package/dist/esm/ion-backdrop.entry.js +63 -0
- package/dist/esm/ion-badge.entry.js +25 -0
- package/dist/esm/ion-buttons.entry.js +38 -0
- package/dist/esm/ion-checkbox.entry.js +113 -0
- package/dist/esm/ion-chip.entry.js +36 -0
- package/dist/esm/ion-datetime.entry.js +989 -0
- package/dist/esm/ion-fab-button.entry.js +87 -0
- package/dist/esm/ion-fab-list.entry.js +41 -0
- package/dist/esm/ion-fab.entry.js +70 -0
- package/dist/esm/ion-img.entry.js +73 -0
- package/dist/esm/ion-infinite-scroll-content.entry.js +33 -0
- package/dist/esm/ion-infinite-scroll.entry.js +202 -0
- package/dist/esm/ion-input.entry.js +262 -0
- package/dist/esm/ion-item-option.entry.js +56 -0
- package/dist/esm/ion-item-options.entry.js +43 -0
- package/dist/esm/ion-item-sliding.entry.js +399 -0
- package/dist/esm/ion-list-header_3.entry.js +253 -0
- package/dist/esm/ion-loading.entry.js +211 -0
- package/dist/esm/ion-menu-button.entry.js +71 -0
- package/dist/esm/ion-menu-toggle.entry.js +43 -0
- package/dist/esm/ion-menu.entry.js +452 -0
- package/dist/esm/ion-modal.entry.js +481 -0
- package/dist/esm/ion-nav-link.entry.js +40 -0
- package/dist/esm/ion-nav.entry.js +855 -0
- package/dist/esm/ion-note.entry.js +25 -0
- package/dist/esm/ion-picker-column.entry.js +329 -0
- package/dist/esm/ion-picker.entry.js +213 -0
- package/dist/esm/ion-popover.entry.js +361 -0
- package/dist/esm/ion-range.entry.js +434 -0
- package/dist/esm/ion-refresher-content.entry.js +36 -0
- package/dist/esm/ion-refresher.entry.js +797 -0
- package/dist/esm/ion-reorder-group.entry.js +276 -0
- package/dist/esm/ion-reorder.entry.js +33 -0
- package/dist/esm/ion-route-redirect.entry.js +20 -0
- package/dist/esm/ion-route.entry.js +45 -0
- package/dist/esm/ion-router-link.entry.js +34 -0
- package/dist/esm/ion-router-outlet.entry.js +192 -0
- package/dist/esm/ion-router.entry.js +690 -0
- package/dist/esm/ion-searchbar.entry.js +366 -0
- package/dist/esm/ion-segment-button.entry.js +105 -0
- package/dist/esm/ion-segment.entry.js +336 -0
- package/dist/esm/ion-select-option.entry.js +23 -0
- package/dist/esm/ion-select-popover.entry.js +31 -0
- package/dist/esm/ion-select.entry.js +440 -0
- package/dist/esm/ion-skeleton-text.entry.js +29 -0
- package/dist/esm/ion-slide.entry.js +21 -0
- package/dist/esm/ion-slides.entry.js +406 -0
- package/dist/esm/ion-spinner.entry.js +60 -0
- package/dist/esm/ion-split-pane.entry.js +146 -0
- package/dist/esm/ion-tab-bar.entry.js +71 -0
- package/dist/esm/ion-tab-button.entry.js +99 -0
- package/dist/esm/ion-tab.entry.js +55 -0
- package/dist/esm/ion-tabs.entry.js +151 -0
- package/dist/esm/ion-text.entry.js +20 -0
- package/dist/esm/ion-textarea.entry.js +242 -0
- package/dist/esm/ion-thumbnail.entry.js +16 -0
- package/dist/esm/ion-toast.entry.js +279 -0
- package/dist/esm/ion-toggle.entry.js +156 -0
- package/dist/esm/ion-virtual-scroll.entry.js +544 -0
- package/dist/esm/ionic-global-fadc16f8.js +206 -0
- package/dist/esm/ios.transition-dd5b9636.js +456 -0
- package/dist/esm/keyboard-06906eac.js +125 -0
- package/dist/esm/loader.js +20 -0
- package/dist/esm/md.transition-6a0a5df0.js +59 -0
- package/dist/esm/menu-toggle-util-0e5e4140.js +9 -0
- package/dist/esm/overlays-6a09f1ef.js +386 -0
- package/dist/esm/polyfills/core-js.js +11 -0
- package/dist/esm/polyfills/css-shim.js +1 -0
- package/dist/esm/polyfills/dom.js +79 -0
- package/dist/esm/polyfills/es5-html-element.js +1 -0
- package/dist/esm/polyfills/index.js +34 -0
- package/dist/esm/polyfills/system.js +6 -0
- package/dist/esm/spinner-configs-9536fae2.js +110 -0
- package/dist/esm/status-tap-54b1c888.js +35 -0
- package/dist/esm/swipe-back-5459ab3a.js +50 -0
- package/dist/esm/swiper.bundle-b6a959de.js +6418 -0
- package/dist/esm/tap-click-e0215d5a.js +167 -0
- package/dist/esm/theme-12606872.js +39 -0
- package/dist/index.cjs.js +1 -0
- package/dist/index.js +1 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/action-sheet/action-sheet.ios.css +371 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/action-sheet/action-sheet.md.css +287 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/alert/alert.ios.css +494 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/alert/alert.md.css +502 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/app/app.css +17 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/avatar/avatar.ios.css +22 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/avatar/avatar.md.css +22 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/back-button/back-button.ios.css +281 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/back-button/back-button.md.css +309 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/backdrop/backdrop.ios.css +26 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/backdrop/backdrop.md.css +26 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/badge/badge.ios.css +58 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/badge/badge.md.css +62 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/button/button.ios.css +439 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/button/button.md.css +428 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/buttons/buttons.ios.css +128 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/buttons/buttons.md.css +151 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card/card.ios.css +101 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card/card.md.css +95 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card-content/card-content.ios.css +61 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card-content/card-content.md.css +63 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card-header/card-header.ios.css +37 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card-header/card-header.md.css +35 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card-subtitle/card-subtitle.ios.css +28 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card-subtitle/card-subtitle.md.css +26 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card-title/card-title.ios.css +27 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/card-title/card-title.md.css +27 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/checkbox/checkbox.ios.css +169 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/checkbox/checkbox.md.css +172 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/chip/chip.ios.css +200 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/chip/chip.md.css +200 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/col/col.css +108 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/content/content.css +184 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/datetime/datetime.ios.css +106 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/datetime/datetime.md.css +106 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/fab/fab.css +61 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/fab-button/fab-button.ios.css +338 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/fab-button/fab-button.md.css +307 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/fab-list/fab-list.css +116 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/footer/footer.ios.css +33 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/footer/footer.md.css +37 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/grid/grid.css +151 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/header/header.ios.css +92 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/header/header.md.css +40 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/img/img.css +12 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/infinite-scroll/infinite-scroll.css +8 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +54 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +54 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/input/input.ios.css +185 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/input/input.md.css +185 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item/item.ios.css +580 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item/item.md.css +654 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item-divider/item-divider.ios.css +204 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item-divider/item-divider.md.css +297 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item-group/item-group.ios.css +3 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item-group/item-group.md.css +3 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item-option/item-option.ios.css +186 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item-option/item-option.md.css +180 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item-options/item-options.ios.css +88 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item-options/item-options.md.css +85 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/item-sliding/item-sliding.css +42 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/label/label.ios.css +156 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/label/label.md.css +172 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/list/list.ios.css +91 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/list/list.md.css +114 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/list-header/list-header.ios.css +118 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/list-header/list-header.md.css +94 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/loading/loading.ios.css +114 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/loading/loading.md.css +105 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/menu/menu.ios.css +131 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/menu/menu.md.css +127 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/menu-button/menu-button.ios.css +175 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/menu-button/menu-button.md.css +178 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/menu-toggle/menu-toggle.css +3 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/modal/modal.ios.css +159 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/modal/modal.md.css +105 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/nav/nav.css +10 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/note/note.ios.css +16 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/note/note.md.css +17 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/picker/picker.ios.css +217 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/picker/picker.md.css +204 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/picker-column/picker-column.ios.css +122 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/picker-column/picker-column.md.css +123 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/popover/popover.ios.css +118 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/popover/popover.md.css +83 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/progress-bar/progress-bar.ios.css +206 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/progress-bar/progress-bar.md.css +206 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/radio/radio.ios.css +177 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/radio/radio.md.css +178 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/range/range.ios.css +275 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/range/range.md.css +320 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/refresher/refresher.ios.css +177 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/refresher/refresher.md.css +210 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/reorder/reorder.ios.css +15 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/reorder/reorder.md.css +15 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/reorder-group/reorder-group.css +33 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/ripple-effect/ripple-effect.css +58 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/router-link/router-link.css +29 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/router-outlet/route-outlet.css +10 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/row/row.css +4 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/searchbar/searchbar.ios.css +348 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/searchbar/searchbar.md.css +279 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/segment/segment.ios.css +65 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/segment/segment.md.css +36 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/segment-button/segment-button.ios.css +446 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/segment-button/segment-button.md.css +424 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/select/select.ios.css +145 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/select/select.md.css +149 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/select-option/select-option.css +3 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/select-popover/select-popover.css +14 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/skeleton-text/skeleton-text.css +53 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/slide/slide.css +31 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/slides/slides.ios.css +764 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/slides/slides.md.css +764 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/spinner/spinner.css +154 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/split-pane/split-pane.ios.css +108 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/split-pane/split-pane.md.css +108 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/tab/tab.css +4 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/tab-bar/tab-bar.ios.css +97 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/tab-bar/tab-bar.md.css +82 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/tab-button/tab-button.ios.css +308 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/tab-button/tab-button.md.css +331 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/tabs/tabs.css +19 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/text/text.css +3 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/textarea/textarea.ios.css +158 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/textarea/textarea.md.css +162 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/thumbnail/thumbnail.css +21 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/title/title.ios.css +122 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/title/title.md.css +55 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/toast/toast.ios.css +250 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/toast/toast.md.css +283 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/toggle/toggle.ios.css +237 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/toggle/toggle.md.css +234 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/toolbar/toolbar.ios.css +174 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/toolbar/toolbar.md.css +167 -0
- package/dist/node_modules/@ionic/core/dist/collection/components/virtual-scroll/virtual-scroll.css +21 -0
- package/dist/node_modules/ionicons/dist/collection/components/icon/icon.css +101 -0
- package/dist/types/components/pos-app/pos-app.d.ts +10 -0
- package/dist/types/components/pos-demo-app/pos-demo-app.d.ts +5 -0
- package/dist/types/components/pos-description/pos-description.component.d.ts +8 -0
- package/dist/types/components/pos-label/pos-label.d.ts +8 -0
- package/dist/types/components/pos-literals/pos-literals.d.ts +8 -0
- package/dist/types/components/pos-login/pos-login.d.ts +10 -0
- package/dist/types/components/pos-relations/pos-relations.d.ts +8 -0
- package/dist/types/components/pos-resource/pos-resource.d.ts +22 -0
- package/dist/types/components/pos-rich-link/pos-rich-link.d.ts +6 -0
- package/dist/types/components.d.ts +155 -0
- package/dist/types/global.d.ts +1 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/pod-os.d.ts +1 -0
- package/dist/types/stencil-public-runtime.d.ts +1563 -0
- package/dist/types/store/getIdpUrl.d.ts +1 -0
- package/dist/types/store/session.d.ts +6 -0
- package/dist/types/test/mockPodOS.d.ts +9 -0
- package/dist/types/window.d.ts +1 -0
- package/loader/cdn.js +3 -0
- package/loader/index.cjs.js +3 -0
- package/loader/index.d.ts +13 -0
- package/loader/index.es2017.js +3 -0
- package/loader/index.js +4 -0
- package/loader/package.json +10 -0
- package/package.json +40 -0
- package/readme.md +75 -0
|
@@ -0,0 +1,2393 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
const index = require('./index-6bf2cd3d.js');
|
|
6
|
+
const ionicGlobal = require('./ionic-global-167e590d.js');
|
|
7
|
+
const helpers = require('./helpers-ff618d5e.js');
|
|
8
|
+
const theme = require('./theme-98ccfc24.js');
|
|
9
|
+
|
|
10
|
+
const appCss = "html.plt-mobile ion-app{user-select:none}html.plt-mobile ion-app [contenteditable]{user-select:text}ion-app.force-statusbar-padding{--ion-safe-area-top:20px}";
|
|
11
|
+
|
|
12
|
+
const App = class {
|
|
13
|
+
constructor(hostRef) {
|
|
14
|
+
index.registerInstance(this, hostRef);
|
|
15
|
+
}
|
|
16
|
+
componentDidLoad() {
|
|
17
|
+
{
|
|
18
|
+
rIC(async () => {
|
|
19
|
+
const isHybrid = ionicGlobal.isPlatform(window, 'hybrid');
|
|
20
|
+
if (!ionicGlobal.config.getBoolean('_testing')) {
|
|
21
|
+
Promise.resolve().then(function () { return require('./tap-click-9c4dcea3.js'); }).then(module => module.startTapClick(ionicGlobal.config));
|
|
22
|
+
}
|
|
23
|
+
if (ionicGlobal.config.getBoolean('statusTap', isHybrid)) {
|
|
24
|
+
Promise.resolve().then(function () { return require('./status-tap-da644888.js'); }).then(module => module.startStatusTap());
|
|
25
|
+
}
|
|
26
|
+
if (ionicGlobal.config.getBoolean('inputShims', needInputShims())) {
|
|
27
|
+
Promise.resolve().then(function () { return require('./input-shims-23510d35.js'); }).then(module => module.startInputShims(ionicGlobal.config));
|
|
28
|
+
}
|
|
29
|
+
const hardwareBackButtonModule = await Promise.resolve().then(function () { return require('./hardware-back-button-ca468aae.js'); });
|
|
30
|
+
if (ionicGlobal.config.getBoolean('hardwareBackButton', isHybrid)) {
|
|
31
|
+
hardwareBackButtonModule.startHardwareBackButton();
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
hardwareBackButtonModule.blockHardwareBackButton();
|
|
35
|
+
}
|
|
36
|
+
if (typeof window !== 'undefined') {
|
|
37
|
+
Promise.resolve().then(function () { return require('./keyboard-1dcbde6c.js'); }).then(module => module.startKeyboardAssist(window));
|
|
38
|
+
}
|
|
39
|
+
Promise.resolve().then(function () { return require('./focus-visible-1583bc8e.js'); }).then(module => module.startFocusVisible());
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
render() {
|
|
44
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
45
|
+
return (index.h(index.Host, { class: {
|
|
46
|
+
[mode]: true,
|
|
47
|
+
'ion-page': true,
|
|
48
|
+
'force-statusbar-padding': ionicGlobal.config.getBoolean('_forceStatusbarPadding'),
|
|
49
|
+
} }));
|
|
50
|
+
}
|
|
51
|
+
get el() { return index.getElement(this); }
|
|
52
|
+
};
|
|
53
|
+
const needInputShims = () => {
|
|
54
|
+
return ionicGlobal.isPlatform(window, 'ios') && ionicGlobal.isPlatform(window, 'mobile');
|
|
55
|
+
};
|
|
56
|
+
const rIC = (callback) => {
|
|
57
|
+
if ('requestIdleCallback' in window) {
|
|
58
|
+
window.requestIdleCallback(callback);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
setTimeout(callback, 32);
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
App.style = appCss;
|
|
65
|
+
|
|
66
|
+
const buttonIosCss = ":host{--overflow:hidden;--ripple-color:currentColor;--border-width:initial;--border-color:initial;--border-style:initial;--color-activated:var(--color);--color-focused:var(--color);--color-hover:var(--color);--box-shadow:none;display:inline-block;width:auto;color:var(--color);font-family:var(--ion-font-family, inherit);text-align:center;text-decoration:none;text-overflow:ellipsis;white-space:nowrap;user-select:none;vertical-align:top;vertical-align:-webkit-baseline-middle;font-kerning:none}:host(.button-disabled){cursor:default;opacity:0.5;pointer-events:none}:host(.button-solid){--background:var(--ion-color-primary, #3880ff);--color:var(--ion-color-primary-contrast, #fff)}:host(.button-outline){--border-color:var(--ion-color-primary, #3880ff);--background:transparent;--color:var(--ion-color-primary, #3880ff)}:host(.button-clear){--border-width:0;--background:transparent;--color:var(--ion-color-primary, #3880ff)}:host(.button-block){display:block}:host(.button-block) .button-native{margin-left:0;margin-right:0;display:block;width:100%;clear:both;contain:content}:host(.button-block) .button-native::after{clear:both}:host(.button-full){display:block}:host(.button-full) .button-native{margin-left:0;margin-right:0;display:block;width:100%;contain:content}:host(.button-full:not(.button-round)) .button-native{border-radius:0;border-right-width:0;border-left-width:0}.button-native{border-radius:var(--border-radius);-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;display:block;position:relative;width:100%;height:100%;transition:var(--transition);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);outline:none;background:var(--background);line-height:1;box-shadow:var(--box-shadow);contain:layout style;cursor:pointer;opacity:var(--opacity);overflow:var(--overflow);z-index:0;box-sizing:border-box;appearance:none}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.button-native{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}.button-native::-moz-focus-inner{border:0}.button-inner{display:flex;position:relative;flex-flow:row nowrap;flex-shrink:0;align-items:center;justify-content:center;width:100%;height:100%;z-index:1}::slotted(ion-icon){font-size:1.4em;pointer-events:none}::slotted(ion-icon[slot=start]){margin-left:-0.3em;margin-right:0.3em;margin-top:0;margin-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:-0.3em;margin-inline-start:-0.3em;-webkit-margin-end:0.3em;margin-inline-end:0.3em}}::slotted(ion-icon[slot=end]){margin-left:0.3em;margin-right:-0.2em;margin-top:0;margin-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:0.3em;margin-inline-start:0.3em;-webkit-margin-end:-0.2em;margin-inline-end:-0.2em}}::slotted(ion-icon[slot=icon-only]){font-size:1.8em}ion-ripple-effect{color:var(--ripple-color)}.button-native::after{left:0;right:0;top:0;bottom:0;position:absolute;content:\"\";opacity:0}:host(.ion-activated){color:var(--color-activated)}:host(.ion-activated) .button-native::after{background:var(--background-activated);opacity:var(--background-activated-opacity)}:host(.ion-focused){color:var(--color-focused)}:host(.ion-focused) .button-native::after{background:var(--background-focused);opacity:var(--background-focused-opacity)}@media (any-hover: hover){:host(:hover){color:var(--color-hover)}:host(:hover) .button-native::after{background:var(--background-hover);opacity:var(--background-hover-opacity)}}:host(.button-solid.ion-color) .button-native{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.button-outline.ion-color) .button-native{border-color:var(--ion-color-base);background:transparent;color:var(--ion-color-base)}:host(.button-clear.ion-color) .button-native{background:transparent;color:var(--ion-color-base)}:host(.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{color:var(--ion-toolbar-color, var(--color))}:host(.button-outline.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{border-color:var(--ion-toolbar-color, var(--color, var(--border-color)))}:host(.button-solid.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{background:var(--ion-toolbar-color, var(--background));color:var(--ion-toolbar-background, var(--color))}:host{--border-radius:10px;--padding-top:0;--padding-bottom:0;--padding-start:1em;--padding-end:1em;--transition:background-color, opacity 100ms linear;margin-left:2px;margin-right:2px;margin-top:4px;margin-bottom:4px;height:2.8em;font-size:16px;font-weight:500;letter-spacing:-0.03em}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{margin-left:unset;margin-right:unset;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px}}:host(.button-solid){--background-activated:var(--ion-color-primary-shade, #3171e0);--background-focused:var(--ion-color-primary-shade, #3171e0);--background-hover:var(--ion-color-primary-tint, #4c8dff);--background-activated-opacity:1;--background-focused-opacity:1;--background-hover-opacity:1}:host(.button-outline){--border-radius:10px;--border-width:1px;--border-style:solid;--background-activated:var(--ion-color-primary, #3880ff);--background-focused:var(--ion-color-primary, #3880ff);--background-hover:transparent;--background-focused-opacity:.1;--color-activated:var(--ion-color-primary-contrast, #fff)}:host(.button-clear){--background-activated:transparent;--background-focused:var(--ion-color-primary, #3880ff);--background-hover:transparent;--background-focused-opacity:.1;font-size:17px;font-weight:normal;letter-spacing:0}:host(.button-large){--border-radius:12px;--padding-top:0;--padding-start:1em;--padding-end:1em;--padding-bottom:0;height:2.8em;font-size:20px}:host(.button-small){--border-radius:6px;--padding-top:0;--padding-start:0.9em;--padding-end:0.9em;--padding-bottom:0;height:2.1em;font-size:13px}:host(.button-round){--border-radius:64px;--padding-top:0;--padding-start:26px;--padding-end:26px;--padding-bottom:0}:host(.button-strong){font-weight:600}:host(.button-clear.ion-activated){opacity:0.4}:host(.button-outline.ion-activated.ion-color) .button-native{color:var(--ion-color-contrast)}:host(.button-outline.ion-activated.ion-color) .button-native::after{background:var(--ion-color-base)}:host(.button-solid.ion-color.ion-activated) .button-native::after{background:var(--ion-color-shade)}:host(.button-outline.ion-focused.ion-color) .button-native,:host(.button-clear.ion-focused.ion-color) .button-native{color:var(--ion-color-base)}:host(.button-outline.ion-focused.ion-color) .button-native::after,:host(.button-clear.ion-focused.ion-color) .button-native::after{background:var(--ion-color-base)}:host(.button-solid.ion-color.ion-focused) .button-native::after{background:var(--ion-color-shade)}@media (any-hover: hover){:host(.button-clear:hover),:host(.button-outline:hover){opacity:0.6}:host(.button-clear.ion-color:hover) .button-native,:host(.button-outline.ion-color:hover) .button-native{color:var(--ion-color-base)}:host(.button-clear.ion-color:hover) .button-native::after,:host(.button-outline.ion-color:hover) .button-native::after{background:transparent}:host(.button-solid.ion-color:hover) .button-native::after{background:var(--ion-color-tint)}:host(:hover.button-solid.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native::after{background:#fff;opacity:0.1}}";
|
|
67
|
+
|
|
68
|
+
const buttonMdCss = ":host{--overflow:hidden;--ripple-color:currentColor;--border-width:initial;--border-color:initial;--border-style:initial;--color-activated:var(--color);--color-focused:var(--color);--color-hover:var(--color);--box-shadow:none;display:inline-block;width:auto;color:var(--color);font-family:var(--ion-font-family, inherit);text-align:center;text-decoration:none;text-overflow:ellipsis;white-space:nowrap;user-select:none;vertical-align:top;vertical-align:-webkit-baseline-middle;font-kerning:none}:host(.button-disabled){cursor:default;opacity:0.5;pointer-events:none}:host(.button-solid){--background:var(--ion-color-primary, #3880ff);--color:var(--ion-color-primary-contrast, #fff)}:host(.button-outline){--border-color:var(--ion-color-primary, #3880ff);--background:transparent;--color:var(--ion-color-primary, #3880ff)}:host(.button-clear){--border-width:0;--background:transparent;--color:var(--ion-color-primary, #3880ff)}:host(.button-block){display:block}:host(.button-block) .button-native{margin-left:0;margin-right:0;display:block;width:100%;clear:both;contain:content}:host(.button-block) .button-native::after{clear:both}:host(.button-full){display:block}:host(.button-full) .button-native{margin-left:0;margin-right:0;display:block;width:100%;contain:content}:host(.button-full:not(.button-round)) .button-native{border-radius:0;border-right-width:0;border-left-width:0}.button-native{border-radius:var(--border-radius);-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;display:block;position:relative;width:100%;height:100%;transition:var(--transition);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);outline:none;background:var(--background);line-height:1;box-shadow:var(--box-shadow);contain:layout style;cursor:pointer;opacity:var(--opacity);overflow:var(--overflow);z-index:0;box-sizing:border-box;appearance:none}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.button-native{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}.button-native::-moz-focus-inner{border:0}.button-inner{display:flex;position:relative;flex-flow:row nowrap;flex-shrink:0;align-items:center;justify-content:center;width:100%;height:100%;z-index:1}::slotted(ion-icon){font-size:1.4em;pointer-events:none}::slotted(ion-icon[slot=start]){margin-left:-0.3em;margin-right:0.3em;margin-top:0;margin-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:-0.3em;margin-inline-start:-0.3em;-webkit-margin-end:0.3em;margin-inline-end:0.3em}}::slotted(ion-icon[slot=end]){margin-left:0.3em;margin-right:-0.2em;margin-top:0;margin-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:0.3em;margin-inline-start:0.3em;-webkit-margin-end:-0.2em;margin-inline-end:-0.2em}}::slotted(ion-icon[slot=icon-only]){font-size:1.8em}ion-ripple-effect{color:var(--ripple-color)}.button-native::after{left:0;right:0;top:0;bottom:0;position:absolute;content:\"\";opacity:0}:host(.ion-activated){color:var(--color-activated)}:host(.ion-activated) .button-native::after{background:var(--background-activated);opacity:var(--background-activated-opacity)}:host(.ion-focused){color:var(--color-focused)}:host(.ion-focused) .button-native::after{background:var(--background-focused);opacity:var(--background-focused-opacity)}@media (any-hover: hover){:host(:hover){color:var(--color-hover)}:host(:hover) .button-native::after{background:var(--background-hover);opacity:var(--background-hover-opacity)}}:host(.button-solid.ion-color) .button-native{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.button-outline.ion-color) .button-native{border-color:var(--ion-color-base);background:transparent;color:var(--ion-color-base)}:host(.button-clear.ion-color) .button-native{background:transparent;color:var(--ion-color-base)}:host(.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{color:var(--ion-toolbar-color, var(--color))}:host(.button-outline.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{border-color:var(--ion-toolbar-color, var(--color, var(--border-color)))}:host(.button-solid.in-toolbar:not(.ion-color):not(.in-toolbar-color)) .button-native{background:var(--ion-toolbar-color, var(--background));color:var(--ion-toolbar-background, var(--color))}:host{--border-radius:4px;--padding-top:0;--padding-bottom:0;--padding-start:1.1em;--padding-end:1.1em;--transition:box-shadow 280ms cubic-bezier(.4, 0, .2, 1),\n background-color 15ms linear,\n color 15ms linear;margin-left:2px;margin-right:2px;margin-top:4px;margin-bottom:4px;height:36px;font-size:14px;font-weight:500;letter-spacing:0.06em;text-transform:uppercase}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{margin-left:unset;margin-right:unset;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px}}:host(.button-solid){--background-activated:transparent;--background-hover:var(--ion-color-primary-contrast, #fff);--background-focused:var(--ion-color-primary-contrast, #fff);--background-activated-opacity:0;--background-focused-opacity:.24;--background-hover-opacity:.08;--box-shadow:0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12)}:host(.button-solid.ion-activated){--box-shadow:0 5px 5px -3px rgba(0, 0, 0, 0.2), 0 8px 10px 1px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12)}:host(.button-outline){--border-width:2px;--border-style:solid;--box-shadow:none;--background-activated:transparent;--background-focused:var(--ion-color-primary, #3880ff);--background-hover:var(--ion-color-primary, #3880ff);--background-activated-opacity:0;--background-focused-opacity:.12;--background-hover-opacity:.04}:host(.button-outline.ion-activated.ion-color) .button-native{background:transparent}:host(.button-clear){--background-activated:transparent;--background-focused:var(--ion-color-primary, #3880ff);--background-hover:var(--ion-color-primary, #3880ff);--background-activated-opacity:0;--background-focused-opacity:.12;--background-hover-opacity:.04}:host(.button-round){--border-radius:64px;--padding-top:0;--padding-start:26px;--padding-end:26px;--padding-bottom:0}:host(.button-large){--padding-top:0;--padding-start:1em;--padding-end:1em;--padding-bottom:0;height:2.8em;font-size:20px}:host(.button-small){--padding-top:0;--padding-start:0.9em;--padding-end:0.9em;--padding-bottom:0;height:2.1em;font-size:13px}:host(.button-strong){font-weight:bold}::slotted(ion-icon[slot=icon-only]){padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host(.button-solid.ion-color.ion-focused) .button-native::after{background:var(--ion-color-contrast)}:host(.button-clear.ion-color.ion-focused) .button-native::after,:host(.button-outline.ion-color.ion-focused) .button-native::after{background:var(--ion-color-base)}@media (any-hover: hover){:host(.button-solid.ion-color:hover) .button-native::after{background:var(--ion-color-contrast)}:host(.button-clear.ion-color:hover) .button-native::after,:host(.button-outline.ion-color:hover) .button-native::after{background:var(--ion-color-base)}}";
|
|
69
|
+
|
|
70
|
+
const Button = class {
|
|
71
|
+
constructor(hostRef) {
|
|
72
|
+
index.registerInstance(this, hostRef);
|
|
73
|
+
this.ionFocus = index.createEvent(this, "ionFocus", 7);
|
|
74
|
+
this.ionBlur = index.createEvent(this, "ionBlur", 7);
|
|
75
|
+
this.inItem = false;
|
|
76
|
+
this.inListHeader = false;
|
|
77
|
+
this.inToolbar = false;
|
|
78
|
+
this.inheritedAttributes = {};
|
|
79
|
+
/**
|
|
80
|
+
* The type of button.
|
|
81
|
+
*/
|
|
82
|
+
this.buttonType = 'button';
|
|
83
|
+
/**
|
|
84
|
+
* If `true`, the user cannot interact with the button.
|
|
85
|
+
*/
|
|
86
|
+
this.disabled = false;
|
|
87
|
+
/**
|
|
88
|
+
* When using a router, it specifies the transition direction when navigating to
|
|
89
|
+
* another page using `href`.
|
|
90
|
+
*/
|
|
91
|
+
this.routerDirection = 'forward';
|
|
92
|
+
/**
|
|
93
|
+
* If `true`, activates a button with a heavier font weight.
|
|
94
|
+
*/
|
|
95
|
+
this.strong = false;
|
|
96
|
+
/**
|
|
97
|
+
* The type of the button.
|
|
98
|
+
*/
|
|
99
|
+
this.type = 'button';
|
|
100
|
+
this.handleClick = (ev) => {
|
|
101
|
+
if (this.type === 'button') {
|
|
102
|
+
theme.openURL(this.href, ev, this.routerDirection, this.routerAnimation);
|
|
103
|
+
}
|
|
104
|
+
else if (helpers.hasShadowDom(this.el)) {
|
|
105
|
+
// this button wants to specifically submit a form
|
|
106
|
+
// climb up the dom to see if we're in a <form>
|
|
107
|
+
// and if so, then use JS to submit it
|
|
108
|
+
const form = this.el.closest('form');
|
|
109
|
+
if (form) {
|
|
110
|
+
ev.preventDefault();
|
|
111
|
+
const fakeButton = document.createElement('button');
|
|
112
|
+
fakeButton.type = this.type;
|
|
113
|
+
fakeButton.style.display = 'none';
|
|
114
|
+
form.appendChild(fakeButton);
|
|
115
|
+
fakeButton.click();
|
|
116
|
+
fakeButton.remove();
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
this.onFocus = () => {
|
|
121
|
+
this.ionFocus.emit();
|
|
122
|
+
};
|
|
123
|
+
this.onBlur = () => {
|
|
124
|
+
this.ionBlur.emit();
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
componentWillLoad() {
|
|
128
|
+
this.inToolbar = !!this.el.closest('ion-buttons');
|
|
129
|
+
this.inListHeader = !!this.el.closest('ion-list-header');
|
|
130
|
+
this.inItem = !!this.el.closest('ion-item') || !!this.el.closest('ion-item-divider');
|
|
131
|
+
this.inheritedAttributes = helpers.inheritAttributes(this.el, ['aria-label']);
|
|
132
|
+
}
|
|
133
|
+
get hasIconOnly() {
|
|
134
|
+
return !!this.el.querySelector('[slot="icon-only"]');
|
|
135
|
+
}
|
|
136
|
+
get rippleType() {
|
|
137
|
+
const hasClearFill = this.fill === undefined || this.fill === 'clear';
|
|
138
|
+
// If the button is in a toolbar, has a clear fill (which is the default)
|
|
139
|
+
// and only has an icon we use the unbounded "circular" ripple effect
|
|
140
|
+
if (hasClearFill && this.hasIconOnly && this.inToolbar) {
|
|
141
|
+
return 'unbounded';
|
|
142
|
+
}
|
|
143
|
+
return 'bounded';
|
|
144
|
+
}
|
|
145
|
+
render() {
|
|
146
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
147
|
+
const { buttonType, type, disabled, rel, target, size, href, color, expand, hasIconOnly, shape, strong, inheritedAttributes } = this;
|
|
148
|
+
const finalSize = size === undefined && this.inItem ? 'small' : size;
|
|
149
|
+
const TagType = href === undefined ? 'button' : 'a';
|
|
150
|
+
const attrs = (TagType === 'button')
|
|
151
|
+
? { type }
|
|
152
|
+
: {
|
|
153
|
+
download: this.download,
|
|
154
|
+
href,
|
|
155
|
+
rel,
|
|
156
|
+
target
|
|
157
|
+
};
|
|
158
|
+
let fill = this.fill;
|
|
159
|
+
if (fill === undefined) {
|
|
160
|
+
fill = this.inToolbar || this.inListHeader ? 'clear' : 'solid';
|
|
161
|
+
}
|
|
162
|
+
return (index.h(index.Host, { onClick: this.handleClick, "aria-disabled": disabled ? 'true' : null, class: theme.createColorClasses(color, {
|
|
163
|
+
[mode]: true,
|
|
164
|
+
[buttonType]: true,
|
|
165
|
+
[`${buttonType}-${expand}`]: expand !== undefined,
|
|
166
|
+
[`${buttonType}-${finalSize}`]: finalSize !== undefined,
|
|
167
|
+
[`${buttonType}-${shape}`]: shape !== undefined,
|
|
168
|
+
[`${buttonType}-${fill}`]: true,
|
|
169
|
+
[`${buttonType}-strong`]: strong,
|
|
170
|
+
'in-toolbar': theme.hostContext('ion-toolbar', this.el),
|
|
171
|
+
'in-toolbar-color': theme.hostContext('ion-toolbar[color]', this.el),
|
|
172
|
+
'button-has-icon-only': hasIconOnly,
|
|
173
|
+
'button-disabled': disabled,
|
|
174
|
+
'ion-activatable': true,
|
|
175
|
+
'ion-focusable': true,
|
|
176
|
+
}) }, index.h(TagType, Object.assign({}, attrs, { class: "button-native", part: "native", disabled: disabled, onFocus: this.onFocus, onBlur: this.onBlur }, inheritedAttributes), index.h("span", { class: "button-inner" }, index.h("slot", { name: "icon-only" }), index.h("slot", { name: "start" }), index.h("slot", null), index.h("slot", { name: "end" })), mode === 'md' && index.h("ion-ripple-effect", { type: this.rippleType }))));
|
|
177
|
+
}
|
|
178
|
+
get el() { return index.getElement(this); }
|
|
179
|
+
};
|
|
180
|
+
Button.style = {
|
|
181
|
+
ios: buttonIosCss,
|
|
182
|
+
md: buttonMdCss
|
|
183
|
+
};
|
|
184
|
+
|
|
185
|
+
const cardIosCss = ":host{--ion-safe-area-left:0px;--ion-safe-area-right:0px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;background:var(--background);color:var(--color);font-family:var(--ion-font-family, inherit);overflow:hidden}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.card-disabled){cursor:default;opacity:0.3;pointer-events:none}.card-native{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;display:block;width:100%;min-height:var(--min-height);transition:var(--transition);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);outline:none;background:inherit}.card-native::-moz-focus-inner{border:0}button,a{cursor:pointer;user-select:none;-webkit-user-drag:none}ion-ripple-effect{color:var(--ripple-color)}:host{--background:var(--ion-card-background, var(--ion-item-background, var(--ion-background-color, #fff)));--color:var(--ion-card-color, var(--ion-item-color, var(--ion-color-step-600, #666666)));margin-left:16px;margin-right:16px;margin-top:24px;margin-bottom:24px;border-radius:8px;transform:translateZ(0);transition:transform 500ms cubic-bezier(0.12, 0.72, 0.29, 1);font-size:14px;box-shadow:0 4px 16px rgba(0, 0, 0, 0.12)}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{margin-left:unset;margin-right:unset;-webkit-margin-start:16px;margin-inline-start:16px;-webkit-margin-end:16px;margin-inline-end:16px}}:host(.ion-activated){transform:scale3d(0.97, 0.97, 1)}";
|
|
186
|
+
|
|
187
|
+
const cardMdCss = ":host{--ion-safe-area-left:0px;--ion-safe-area-right:0px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;background:var(--background);color:var(--color);font-family:var(--ion-font-family, inherit);overflow:hidden}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.card-disabled){cursor:default;opacity:0.3;pointer-events:none}.card-native{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;display:block;width:100%;min-height:var(--min-height);transition:var(--transition);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);outline:none;background:inherit}.card-native::-moz-focus-inner{border:0}button,a{cursor:pointer;user-select:none;-webkit-user-drag:none}ion-ripple-effect{color:var(--ripple-color)}:host{--background:var(--ion-card-background, var(--ion-item-background, var(--ion-background-color, #fff)));--color:var(--ion-card-color, var(--ion-item-color, var(--ion-color-step-550, #737373)));margin-left:10px;margin-right:10px;margin-top:10px;margin-bottom:10px;border-radius:4px;font-size:14px;box-shadow:0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12)}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{margin-left:unset;margin-right:unset;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px}}";
|
|
188
|
+
|
|
189
|
+
const Card = class {
|
|
190
|
+
constructor(hostRef) {
|
|
191
|
+
index.registerInstance(this, hostRef);
|
|
192
|
+
/**
|
|
193
|
+
* If `true`, a button tag will be rendered and the card will be tappable.
|
|
194
|
+
*/
|
|
195
|
+
this.button = false;
|
|
196
|
+
/**
|
|
197
|
+
* The type of the button. Only used when an `onclick` or `button` property is present.
|
|
198
|
+
*/
|
|
199
|
+
this.type = 'button';
|
|
200
|
+
/**
|
|
201
|
+
* If `true`, the user cannot interact with the card.
|
|
202
|
+
*/
|
|
203
|
+
this.disabled = false;
|
|
204
|
+
/**
|
|
205
|
+
* When using a router, it specifies the transition direction when navigating to
|
|
206
|
+
* another page using `href`.
|
|
207
|
+
*/
|
|
208
|
+
this.routerDirection = 'forward';
|
|
209
|
+
}
|
|
210
|
+
isClickable() {
|
|
211
|
+
return (this.href !== undefined || this.button);
|
|
212
|
+
}
|
|
213
|
+
renderCard(mode) {
|
|
214
|
+
const clickable = this.isClickable();
|
|
215
|
+
if (!clickable) {
|
|
216
|
+
return [
|
|
217
|
+
index.h("slot", null)
|
|
218
|
+
];
|
|
219
|
+
}
|
|
220
|
+
const { href, routerAnimation, routerDirection } = this;
|
|
221
|
+
const TagType = clickable ? (href === undefined ? 'button' : 'a') : 'div';
|
|
222
|
+
const attrs = (TagType === 'button')
|
|
223
|
+
? { type: this.type }
|
|
224
|
+
: {
|
|
225
|
+
download: this.download,
|
|
226
|
+
href: this.href,
|
|
227
|
+
rel: this.rel,
|
|
228
|
+
target: this.target
|
|
229
|
+
};
|
|
230
|
+
return (index.h(TagType, Object.assign({}, attrs, { class: "card-native", part: "native", disabled: this.disabled, onClick: (ev) => theme.openURL(href, ev, routerDirection, routerAnimation) }), index.h("slot", null), clickable && mode === 'md' && index.h("ion-ripple-effect", null)));
|
|
231
|
+
}
|
|
232
|
+
render() {
|
|
233
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
234
|
+
return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
|
|
235
|
+
[mode]: true,
|
|
236
|
+
'card-disabled': this.disabled,
|
|
237
|
+
'ion-activatable': this.isClickable()
|
|
238
|
+
}) }, this.renderCard(mode)));
|
|
239
|
+
}
|
|
240
|
+
};
|
|
241
|
+
Card.style = {
|
|
242
|
+
ios: cardIosCss,
|
|
243
|
+
md: cardMdCss
|
|
244
|
+
};
|
|
245
|
+
|
|
246
|
+
const cardContentIosCss = "ion-card-content{display:block;position:relative}.card-content-ios{padding-left:20px;padding-right:20px;padding-top:20px;padding-bottom:20px;font-size:16px;line-height:1.4}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.card-content-ios{padding-left:unset;padding-right:unset;-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px}}.card-content-ios h1{margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:24px;font-weight:normal}.card-content-ios h2{margin-left:0;margin-right:0;margin-top:2px;margin-bottom:2px;font-size:16px;font-weight:normal}.card-content-ios h3,.card-content-ios h4,.card-content-ios h5,.card-content-ios h6{margin-left:0;margin-right:0;margin-top:2px;margin-bottom:2px;font-size:14px;font-weight:normal}.card-content-ios p{margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:14px}ion-card-header+.card-content-ios{padding-top:0}";
|
|
247
|
+
|
|
248
|
+
const cardContentMdCss = "ion-card-content{display:block;position:relative}.card-content-md{padding-left:16px;padding-right:16px;padding-top:13px;padding-bottom:13px;font-size:14px;line-height:1.5}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.card-content-md{padding-left:unset;padding-right:unset;-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px}}.card-content-md h1{margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:24px;font-weight:normal}.card-content-md h2{margin-left:0;margin-right:0;margin-top:2px;margin-bottom:2px;font-size:16px;font-weight:normal}.card-content-md h3,.card-content-md h4,.card-content-md h5,.card-content-md h6{margin-left:0;margin-right:0;margin-top:2px;margin-bottom:2px;font-size:14px;font-weight:normal}.card-content-md p{margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:14px;font-weight:normal;line-height:1.5}ion-card-header+.card-content-md{padding-top:0}";
|
|
249
|
+
|
|
250
|
+
const CardContent = class {
|
|
251
|
+
constructor(hostRef) {
|
|
252
|
+
index.registerInstance(this, hostRef);
|
|
253
|
+
}
|
|
254
|
+
render() {
|
|
255
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
256
|
+
return (index.h(index.Host, { class: {
|
|
257
|
+
[mode]: true,
|
|
258
|
+
// Used internally for styling
|
|
259
|
+
[`card-content-${mode}`]: true
|
|
260
|
+
} }));
|
|
261
|
+
}
|
|
262
|
+
};
|
|
263
|
+
CardContent.style = {
|
|
264
|
+
ios: cardContentIosCss,
|
|
265
|
+
md: cardContentMdCss
|
|
266
|
+
};
|
|
267
|
+
|
|
268
|
+
const cardHeaderIosCss = ":host{--background:transparent;--color:inherit;display:block;position:relative;background:var(--background);color:var(--color)}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}:host{padding-left:20px;padding-right:20px;padding-top:20px;padding-bottom:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px}}@supports (backdrop-filter: blur(0)){:host(.card-header-translucent){background-color:rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.9);backdrop-filter:saturate(180%) blur(30px)}}";
|
|
269
|
+
|
|
270
|
+
const cardHeaderMdCss = ":host{--background:transparent;--color:inherit;display:block;position:relative;background:var(--background);color:var(--color)}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}:host{padding-left:16px;padding-right:16px;padding-top:16px;padding-bottom:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px}}::slotted(ion-card-title:not(:first-child)),::slotted(ion-card-subtitle:not(:first-child)){margin-top:8px}";
|
|
271
|
+
|
|
272
|
+
const CardHeader = class {
|
|
273
|
+
constructor(hostRef) {
|
|
274
|
+
index.registerInstance(this, hostRef);
|
|
275
|
+
/**
|
|
276
|
+
* If `true`, the card header will be translucent.
|
|
277
|
+
* Only applies when the mode is `"ios"` and the device supports
|
|
278
|
+
* [`backdrop-filter`](https://developer.mozilla.org/en-US/docs/Web/CSS/backdrop-filter#Browser_compatibility).
|
|
279
|
+
*/
|
|
280
|
+
this.translucent = false;
|
|
281
|
+
}
|
|
282
|
+
render() {
|
|
283
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
284
|
+
return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
|
|
285
|
+
'card-header-translucent': this.translucent,
|
|
286
|
+
'ion-inherit-color': true,
|
|
287
|
+
[mode]: true
|
|
288
|
+
}) }, index.h("slot", null)));
|
|
289
|
+
}
|
|
290
|
+
};
|
|
291
|
+
CardHeader.style = {
|
|
292
|
+
ios: cardHeaderIosCss,
|
|
293
|
+
md: cardHeaderMdCss
|
|
294
|
+
};
|
|
295
|
+
|
|
296
|
+
const cardSubtitleIosCss = ":host{display:block;position:relative;color:var(--color)}:host(.ion-color){color:var(--ion-color-base)}:host{--color:var(--ion-color-step-600, #666666);margin-left:0;margin-right:0;margin-top:0;margin-bottom:4px;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;font-size:12px;font-weight:700;letter-spacing:0.4px;text-transform:uppercase}";
|
|
297
|
+
|
|
298
|
+
const cardSubtitleMdCss = ":host{display:block;position:relative;color:var(--color)}:host(.ion-color){color:var(--ion-color-base)}:host{--color:var(--ion-color-step-550, #737373);margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;font-size:14px;font-weight:500}";
|
|
299
|
+
|
|
300
|
+
const CardSubtitle = class {
|
|
301
|
+
constructor(hostRef) {
|
|
302
|
+
index.registerInstance(this, hostRef);
|
|
303
|
+
}
|
|
304
|
+
render() {
|
|
305
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
306
|
+
return (index.h(index.Host, { role: "heading", "aria-level": "3", class: theme.createColorClasses(this.color, {
|
|
307
|
+
'ion-inherit-color': true,
|
|
308
|
+
[mode]: true
|
|
309
|
+
}) }, index.h("slot", null)));
|
|
310
|
+
}
|
|
311
|
+
};
|
|
312
|
+
CardSubtitle.style = {
|
|
313
|
+
ios: cardSubtitleIosCss,
|
|
314
|
+
md: cardSubtitleMdCss
|
|
315
|
+
};
|
|
316
|
+
|
|
317
|
+
const cardTitleIosCss = ":host{display:block;position:relative;color:var(--color)}:host(.ion-color){color:var(--ion-color-base)}:host{--color:var(--ion-text-color, #000);margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;font-size:28px;font-weight:700;line-height:1.2}";
|
|
318
|
+
|
|
319
|
+
const cardTitleMdCss = ":host{display:block;position:relative;color:var(--color)}:host(.ion-color){color:var(--ion-color-base)}:host{--color:var(--ion-color-step-850, #262626);margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;font-size:20px;font-weight:500;line-height:1.2}";
|
|
320
|
+
|
|
321
|
+
const CardTitle = class {
|
|
322
|
+
constructor(hostRef) {
|
|
323
|
+
index.registerInstance(this, hostRef);
|
|
324
|
+
}
|
|
325
|
+
render() {
|
|
326
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
327
|
+
return (index.h(index.Host, { role: "heading", "aria-level": "2", class: theme.createColorClasses(this.color, {
|
|
328
|
+
'ion-inherit-color': true,
|
|
329
|
+
[mode]: true
|
|
330
|
+
}) }, index.h("slot", null)));
|
|
331
|
+
}
|
|
332
|
+
};
|
|
333
|
+
CardTitle.style = {
|
|
334
|
+
ios: cardTitleIosCss,
|
|
335
|
+
md: cardTitleMdCss
|
|
336
|
+
};
|
|
337
|
+
|
|
338
|
+
const SIZE_TO_MEDIA = {
|
|
339
|
+
'xs': '(min-width: 0px)',
|
|
340
|
+
'sm': '(min-width: 576px)',
|
|
341
|
+
'md': '(min-width: 768px)',
|
|
342
|
+
'lg': '(min-width: 992px)',
|
|
343
|
+
'xl': '(min-width: 1200px)',
|
|
344
|
+
};
|
|
345
|
+
// Check if the window matches the media query
|
|
346
|
+
// at the breakpoint passed
|
|
347
|
+
// e.g. matchBreakpoint('sm') => true if screen width exceeds 576px
|
|
348
|
+
const matchBreakpoint = (breakpoint) => {
|
|
349
|
+
if (breakpoint === undefined || breakpoint === '') {
|
|
350
|
+
return true;
|
|
351
|
+
}
|
|
352
|
+
if (window.matchMedia) {
|
|
353
|
+
const mediaQuery = SIZE_TO_MEDIA[breakpoint];
|
|
354
|
+
return window.matchMedia(mediaQuery).matches;
|
|
355
|
+
}
|
|
356
|
+
return false;
|
|
357
|
+
};
|
|
358
|
+
|
|
359
|
+
const colCss = ":host{padding-left:var(--ion-grid-column-padding-xs, var(--ion-grid-column-padding, 5px));padding-right:var(--ion-grid-column-padding-xs, var(--ion-grid-column-padding, 5px));padding-top:var(--ion-grid-column-padding-xs, var(--ion-grid-column-padding, 5px));padding-bottom:var(--ion-grid-column-padding-xs, var(--ion-grid-column-padding, 5px));margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;box-sizing:border-box;position:relative;flex-basis:0;flex-grow:1;width:100%;max-width:100%;min-height:1px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-column-padding-xs, var(--ion-grid-column-padding, 5px));padding-inline-start:var(--ion-grid-column-padding-xs, var(--ion-grid-column-padding, 5px));-webkit-padding-end:var(--ion-grid-column-padding-xs, var(--ion-grid-column-padding, 5px));padding-inline-end:var(--ion-grid-column-padding-xs, var(--ion-grid-column-padding, 5px))}}@media (min-width: 576px){:host{padding-left:var(--ion-grid-column-padding-sm, var(--ion-grid-column-padding, 5px));padding-right:var(--ion-grid-column-padding-sm, var(--ion-grid-column-padding, 5px));padding-top:var(--ion-grid-column-padding-sm, var(--ion-grid-column-padding, 5px));padding-bottom:var(--ion-grid-column-padding-sm, var(--ion-grid-column-padding, 5px))}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-column-padding-sm, var(--ion-grid-column-padding, 5px));padding-inline-start:var(--ion-grid-column-padding-sm, var(--ion-grid-column-padding, 5px));-webkit-padding-end:var(--ion-grid-column-padding-sm, var(--ion-grid-column-padding, 5px));padding-inline-end:var(--ion-grid-column-padding-sm, var(--ion-grid-column-padding, 5px))}}}@media (min-width: 768px){:host{padding-left:var(--ion-grid-column-padding-md, var(--ion-grid-column-padding, 5px));padding-right:var(--ion-grid-column-padding-md, var(--ion-grid-column-padding, 5px));padding-top:var(--ion-grid-column-padding-md, var(--ion-grid-column-padding, 5px));padding-bottom:var(--ion-grid-column-padding-md, var(--ion-grid-column-padding, 5px))}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-column-padding-md, var(--ion-grid-column-padding, 5px));padding-inline-start:var(--ion-grid-column-padding-md, var(--ion-grid-column-padding, 5px));-webkit-padding-end:var(--ion-grid-column-padding-md, var(--ion-grid-column-padding, 5px));padding-inline-end:var(--ion-grid-column-padding-md, var(--ion-grid-column-padding, 5px))}}}@media (min-width: 992px){:host{padding-left:var(--ion-grid-column-padding-lg, var(--ion-grid-column-padding, 5px));padding-right:var(--ion-grid-column-padding-lg, var(--ion-grid-column-padding, 5px));padding-top:var(--ion-grid-column-padding-lg, var(--ion-grid-column-padding, 5px));padding-bottom:var(--ion-grid-column-padding-lg, var(--ion-grid-column-padding, 5px))}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-column-padding-lg, var(--ion-grid-column-padding, 5px));padding-inline-start:var(--ion-grid-column-padding-lg, var(--ion-grid-column-padding, 5px));-webkit-padding-end:var(--ion-grid-column-padding-lg, var(--ion-grid-column-padding, 5px));padding-inline-end:var(--ion-grid-column-padding-lg, var(--ion-grid-column-padding, 5px))}}}@media (min-width: 1200px){:host{padding-left:var(--ion-grid-column-padding-xl, var(--ion-grid-column-padding, 5px));padding-right:var(--ion-grid-column-padding-xl, var(--ion-grid-column-padding, 5px));padding-top:var(--ion-grid-column-padding-xl, var(--ion-grid-column-padding, 5px));padding-bottom:var(--ion-grid-column-padding-xl, var(--ion-grid-column-padding, 5px))}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-column-padding-xl, var(--ion-grid-column-padding, 5px));padding-inline-start:var(--ion-grid-column-padding-xl, var(--ion-grid-column-padding, 5px));-webkit-padding-end:var(--ion-grid-column-padding-xl, var(--ion-grid-column-padding, 5px));padding-inline-end:var(--ion-grid-column-padding-xl, var(--ion-grid-column-padding, 5px))}}}";
|
|
360
|
+
|
|
361
|
+
const win = window;
|
|
362
|
+
const SUPPORTS_VARS = !!(win.CSS && win.CSS.supports && win.CSS.supports('--a: 0'));
|
|
363
|
+
const BREAKPOINTS = ['', 'xs', 'sm', 'md', 'lg', 'xl'];
|
|
364
|
+
const Col = class {
|
|
365
|
+
constructor(hostRef) {
|
|
366
|
+
index.registerInstance(this, hostRef);
|
|
367
|
+
}
|
|
368
|
+
onResize() {
|
|
369
|
+
index.forceUpdate(this);
|
|
370
|
+
}
|
|
371
|
+
// Loop through all of the breakpoints to see if the media query
|
|
372
|
+
// matches and grab the column value from the relevant prop if so
|
|
373
|
+
getColumns(property) {
|
|
374
|
+
let matched;
|
|
375
|
+
for (const breakpoint of BREAKPOINTS) {
|
|
376
|
+
const matches = matchBreakpoint(breakpoint);
|
|
377
|
+
// Grab the value of the property, if it exists and our
|
|
378
|
+
// media query matches we return the value
|
|
379
|
+
const columns = this[property + breakpoint.charAt(0).toUpperCase() + breakpoint.slice(1)];
|
|
380
|
+
if (matches && columns !== undefined) {
|
|
381
|
+
matched = columns;
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
// Return the last matched columns since the breakpoints
|
|
385
|
+
// increase in size and we want to return the largest match
|
|
386
|
+
return matched;
|
|
387
|
+
}
|
|
388
|
+
calculateSize() {
|
|
389
|
+
const columns = this.getColumns('size');
|
|
390
|
+
// If size wasn't set for any breakpoint
|
|
391
|
+
// or if the user set the size without a value
|
|
392
|
+
// it means we need to stick with the default and return
|
|
393
|
+
// e.g. <ion-col size-md>
|
|
394
|
+
if (!columns || columns === '') {
|
|
395
|
+
return;
|
|
396
|
+
}
|
|
397
|
+
// If the size is set to auto then don't calculate a size
|
|
398
|
+
const colSize = (columns === 'auto')
|
|
399
|
+
? 'auto'
|
|
400
|
+
// If CSS supports variables we should use the grid columns var
|
|
401
|
+
: SUPPORTS_VARS ? `calc(calc(${columns} / var(--ion-grid-columns, 12)) * 100%)`
|
|
402
|
+
// Convert the columns to a percentage by dividing by the total number
|
|
403
|
+
// of columns (12) and then multiplying by 100
|
|
404
|
+
: ((columns / 12) * 100) + '%';
|
|
405
|
+
return {
|
|
406
|
+
'flex': `0 0 ${colSize}`,
|
|
407
|
+
'width': `${colSize}`,
|
|
408
|
+
'max-width': `${colSize}`
|
|
409
|
+
};
|
|
410
|
+
}
|
|
411
|
+
// Called by push, pull, and offset since they use the same calculations
|
|
412
|
+
calculatePosition(property, modifier) {
|
|
413
|
+
const columns = this.getColumns(property);
|
|
414
|
+
if (!columns) {
|
|
415
|
+
return;
|
|
416
|
+
}
|
|
417
|
+
// If the number of columns passed are greater than 0 and less than
|
|
418
|
+
// 12 we can position the column, else default to auto
|
|
419
|
+
const amount = SUPPORTS_VARS
|
|
420
|
+
// If CSS supports variables we should use the grid columns var
|
|
421
|
+
? `calc(calc(${columns} / var(--ion-grid-columns, 12)) * 100%)`
|
|
422
|
+
// Convert the columns to a percentage by dividing by the total number
|
|
423
|
+
// of columns (12) and then multiplying by 100
|
|
424
|
+
: (columns > 0 && columns < 12) ? (columns / 12 * 100) + '%' : 'auto';
|
|
425
|
+
return {
|
|
426
|
+
[modifier]: amount
|
|
427
|
+
};
|
|
428
|
+
}
|
|
429
|
+
calculateOffset(isRTL) {
|
|
430
|
+
return this.calculatePosition('offset', isRTL ? 'margin-right' : 'margin-left');
|
|
431
|
+
}
|
|
432
|
+
calculatePull(isRTL) {
|
|
433
|
+
return this.calculatePosition('pull', isRTL ? 'left' : 'right');
|
|
434
|
+
}
|
|
435
|
+
calculatePush(isRTL) {
|
|
436
|
+
return this.calculatePosition('push', isRTL ? 'right' : 'left');
|
|
437
|
+
}
|
|
438
|
+
render() {
|
|
439
|
+
const isRTL = document.dir === 'rtl';
|
|
440
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
441
|
+
return (index.h(index.Host, { class: {
|
|
442
|
+
[mode]: true
|
|
443
|
+
}, style: Object.assign(Object.assign(Object.assign(Object.assign({}, this.calculateOffset(isRTL)), this.calculatePull(isRTL)), this.calculatePush(isRTL)), this.calculateSize()) }, index.h("slot", null)));
|
|
444
|
+
}
|
|
445
|
+
};
|
|
446
|
+
Col.style = colCss;
|
|
447
|
+
|
|
448
|
+
const contentCss = ":host{--background:var(--ion-background-color, #fff);--color:var(--ion-text-color, #000);--padding-top:0px;--padding-bottom:0px;--padding-start:0px;--padding-end:0px;--keyboard-offset:0px;--offset-top:0px;--offset-bottom:0px;--overflow:auto;display:block;position:relative;flex:1;width:100%;height:100%;margin:0 !important;padding:0 !important;font-family:var(--ion-font-family, inherit);contain:size style}:host(.ion-color) .inner-scroll{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.outer-content){--background:var(--ion-color-step-50, #f2f2f2)}#background-content{left:0px;right:0px;top:calc(var(--offset-top) * -1);bottom:calc(var(--offset-bottom) * -1);position:absolute;background:var(--background)}.inner-scroll{left:0px;right:0px;top:calc(var(--offset-top) * -1);bottom:calc(var(--offset-bottom) * -1);padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:calc(var(--padding-top) + var(--offset-top));padding-bottom:calc(var(--padding-bottom) + var(--keyboard-offset) + var(--offset-bottom));position:absolute;color:var(--color);box-sizing:border-box;overflow:hidden}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.inner-scroll{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}.scroll-y,.scroll-x{-webkit-overflow-scrolling:touch;z-index:0;will-change:scroll-position}.scroll-y{touch-action:pan-y;overflow-y:var(--overflow);overscroll-behavior-y:contain}.scroll-x{touch-action:pan-x;overflow-x:var(--overflow);overscroll-behavior-x:contain}.scroll-x.scroll-y{touch-action:auto}.overscroll::before,.overscroll::after{position:absolute;width:1px;height:1px;content:\"\"}.overscroll::before{bottom:-1px}.overscroll::after{top:-1px}:host(.content-sizing){contain:none}:host(.content-sizing) .inner-scroll{position:relative}.transition-effect{display:none;position:absolute;left:-100%;width:100%;height:100vh;opacity:0;pointer-events:none}.transition-cover{position:absolute;right:0;width:100%;height:100%;background:black;opacity:0.1}.transition-shadow{display:block;position:absolute;right:0;width:10px;height:100%;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAgCAYAAAAIXrg4AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyhpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKE1hY2ludG9zaCkiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MTE3MDgzRkQ5QTkyMTFFOUEwNzQ5MkJFREE1NUY2MjQiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MTE3MDgzRkU5QTkyMTFFOUEwNzQ5MkJFREE1NUY2MjQiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDoxMTcwODNGQjlBOTIxMUU5QTA3NDkyQkVEQTU1RjYyNCIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDoxMTcwODNGQzlBOTIxMUU5QTA3NDkyQkVEQTU1RjYyNCIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PmePEuQAAABNSURBVHjaYvz//z8DIxAwMDAwATGMhmFmPDQuOSZks0AMmoJBaQHjkPfB0Lfg/2gQjVow+HPy/yHvg9GiYjQfjMbBqAWjFgy/4hogwADYqwdzxy5BuwAAAABJRU5ErkJggg==);background-repeat:repeat-y;background-size:10px 16px}::slotted([slot=fixed]){position:absolute}";
|
|
449
|
+
|
|
450
|
+
const Content = class {
|
|
451
|
+
constructor(hostRef) {
|
|
452
|
+
index.registerInstance(this, hostRef);
|
|
453
|
+
this.ionScrollStart = index.createEvent(this, "ionScrollStart", 7);
|
|
454
|
+
this.ionScroll = index.createEvent(this, "ionScroll", 7);
|
|
455
|
+
this.ionScrollEnd = index.createEvent(this, "ionScrollEnd", 7);
|
|
456
|
+
this.isScrolling = false;
|
|
457
|
+
this.lastScroll = 0;
|
|
458
|
+
this.queued = false;
|
|
459
|
+
this.cTop = -1;
|
|
460
|
+
this.cBottom = -1;
|
|
461
|
+
this.isMainContent = true;
|
|
462
|
+
// Detail is used in a hot loop in the scroll event, by allocating it here
|
|
463
|
+
// V8 will be able to inline any read/write to it since it's a monomorphic class.
|
|
464
|
+
// https://mrale.ph/blog/2015/01/11/whats-up-with-monomorphism.html
|
|
465
|
+
this.detail = {
|
|
466
|
+
scrollTop: 0,
|
|
467
|
+
scrollLeft: 0,
|
|
468
|
+
type: 'scroll',
|
|
469
|
+
event: undefined,
|
|
470
|
+
startX: 0,
|
|
471
|
+
startY: 0,
|
|
472
|
+
startTime: 0,
|
|
473
|
+
currentX: 0,
|
|
474
|
+
currentY: 0,
|
|
475
|
+
velocityX: 0,
|
|
476
|
+
velocityY: 0,
|
|
477
|
+
deltaX: 0,
|
|
478
|
+
deltaY: 0,
|
|
479
|
+
currentTime: 0,
|
|
480
|
+
data: undefined,
|
|
481
|
+
isScrolling: true,
|
|
482
|
+
};
|
|
483
|
+
/**
|
|
484
|
+
* If `true`, the content will scroll behind the headers
|
|
485
|
+
* and footers. This effect can easily be seen by setting the toolbar
|
|
486
|
+
* to transparent.
|
|
487
|
+
*/
|
|
488
|
+
this.fullscreen = false;
|
|
489
|
+
/**
|
|
490
|
+
* If you want to enable the content scrolling in the X axis, set this property to `true`.
|
|
491
|
+
*/
|
|
492
|
+
this.scrollX = false;
|
|
493
|
+
/**
|
|
494
|
+
* If you want to disable the content scrolling in the Y axis, set this property to `false`.
|
|
495
|
+
*/
|
|
496
|
+
this.scrollY = true;
|
|
497
|
+
/**
|
|
498
|
+
* Because of performance reasons, ionScroll events are disabled by default, in order to enable them
|
|
499
|
+
* and start listening from (ionScroll), set this property to `true`.
|
|
500
|
+
*/
|
|
501
|
+
this.scrollEvents = false;
|
|
502
|
+
}
|
|
503
|
+
connectedCallback() {
|
|
504
|
+
this.isMainContent = this.el.closest('ion-menu, ion-popover, ion-modal') === null;
|
|
505
|
+
}
|
|
506
|
+
disconnectedCallback() {
|
|
507
|
+
this.onScrollEnd();
|
|
508
|
+
}
|
|
509
|
+
onAppLoad() {
|
|
510
|
+
this.resize();
|
|
511
|
+
}
|
|
512
|
+
onClick(ev) {
|
|
513
|
+
if (this.isScrolling) {
|
|
514
|
+
ev.preventDefault();
|
|
515
|
+
ev.stopPropagation();
|
|
516
|
+
}
|
|
517
|
+
}
|
|
518
|
+
shouldForceOverscroll() {
|
|
519
|
+
const { forceOverscroll } = this;
|
|
520
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
521
|
+
return forceOverscroll === undefined
|
|
522
|
+
? mode === 'ios' && ionicGlobal.isPlatform('ios')
|
|
523
|
+
: forceOverscroll;
|
|
524
|
+
}
|
|
525
|
+
resize() {
|
|
526
|
+
if (this.fullscreen) {
|
|
527
|
+
index.readTask(() => this.readDimensions());
|
|
528
|
+
}
|
|
529
|
+
else if (this.cTop !== 0 || this.cBottom !== 0) {
|
|
530
|
+
this.cTop = this.cBottom = 0;
|
|
531
|
+
index.forceUpdate(this);
|
|
532
|
+
}
|
|
533
|
+
}
|
|
534
|
+
readDimensions() {
|
|
535
|
+
const page = getPageElement(this.el);
|
|
536
|
+
const top = Math.max(this.el.offsetTop, 0);
|
|
537
|
+
const bottom = Math.max(page.offsetHeight - top - this.el.offsetHeight, 0);
|
|
538
|
+
const dirty = top !== this.cTop || bottom !== this.cBottom;
|
|
539
|
+
if (dirty) {
|
|
540
|
+
this.cTop = top;
|
|
541
|
+
this.cBottom = bottom;
|
|
542
|
+
index.forceUpdate(this);
|
|
543
|
+
}
|
|
544
|
+
}
|
|
545
|
+
onScroll(ev) {
|
|
546
|
+
const timeStamp = Date.now();
|
|
547
|
+
const shouldStart = !this.isScrolling;
|
|
548
|
+
this.lastScroll = timeStamp;
|
|
549
|
+
if (shouldStart) {
|
|
550
|
+
this.onScrollStart();
|
|
551
|
+
}
|
|
552
|
+
if (!this.queued && this.scrollEvents) {
|
|
553
|
+
this.queued = true;
|
|
554
|
+
index.readTask(ts => {
|
|
555
|
+
this.queued = false;
|
|
556
|
+
this.detail.event = ev;
|
|
557
|
+
updateScrollDetail(this.detail, this.scrollEl, ts, shouldStart);
|
|
558
|
+
this.ionScroll.emit(this.detail);
|
|
559
|
+
});
|
|
560
|
+
}
|
|
561
|
+
}
|
|
562
|
+
/**
|
|
563
|
+
* Get the element where the actual scrolling takes place.
|
|
564
|
+
* This element can be used to subscribe to `scroll` events or manually modify
|
|
565
|
+
* `scrollTop`. However, it's recommended to use the API provided by `ion-content`:
|
|
566
|
+
*
|
|
567
|
+
* i.e. Using `ionScroll`, `ionScrollStart`, `ionScrollEnd` for scrolling events
|
|
568
|
+
* and `scrollToPoint()` to scroll the content into a certain point.
|
|
569
|
+
*/
|
|
570
|
+
getScrollElement() {
|
|
571
|
+
return Promise.resolve(this.scrollEl);
|
|
572
|
+
}
|
|
573
|
+
/**
|
|
574
|
+
* Scroll to the top of the component.
|
|
575
|
+
*
|
|
576
|
+
* @param duration The amount of time to take scrolling to the top. Defaults to `0`.
|
|
577
|
+
*/
|
|
578
|
+
scrollToTop(duration = 0) {
|
|
579
|
+
return this.scrollToPoint(undefined, 0, duration);
|
|
580
|
+
}
|
|
581
|
+
/**
|
|
582
|
+
* Scroll to the bottom of the component.
|
|
583
|
+
*
|
|
584
|
+
* @param duration The amount of time to take scrolling to the bottom. Defaults to `0`.
|
|
585
|
+
*/
|
|
586
|
+
scrollToBottom(duration = 0) {
|
|
587
|
+
const y = this.scrollEl.scrollHeight - this.scrollEl.clientHeight;
|
|
588
|
+
return this.scrollToPoint(undefined, y, duration);
|
|
589
|
+
}
|
|
590
|
+
/**
|
|
591
|
+
* Scroll by a specified X/Y distance in the component.
|
|
592
|
+
*
|
|
593
|
+
* @param x The amount to scroll by on the horizontal axis.
|
|
594
|
+
* @param y The amount to scroll by on the vertical axis.
|
|
595
|
+
* @param duration The amount of time to take scrolling by that amount.
|
|
596
|
+
*/
|
|
597
|
+
scrollByPoint(x, y, duration) {
|
|
598
|
+
return this.scrollToPoint(x + this.scrollEl.scrollLeft, y + this.scrollEl.scrollTop, duration);
|
|
599
|
+
}
|
|
600
|
+
/**
|
|
601
|
+
* Scroll to a specified X/Y location in the component.
|
|
602
|
+
*
|
|
603
|
+
* @param x The point to scroll to on the horizontal axis.
|
|
604
|
+
* @param y The point to scroll to on the vertical axis.
|
|
605
|
+
* @param duration The amount of time to take scrolling to that point. Defaults to `0`.
|
|
606
|
+
*/
|
|
607
|
+
async scrollToPoint(x, y, duration = 0) {
|
|
608
|
+
const el = this.scrollEl;
|
|
609
|
+
if (duration < 32) {
|
|
610
|
+
if (y != null) {
|
|
611
|
+
el.scrollTop = y;
|
|
612
|
+
}
|
|
613
|
+
if (x != null) {
|
|
614
|
+
el.scrollLeft = x;
|
|
615
|
+
}
|
|
616
|
+
return;
|
|
617
|
+
}
|
|
618
|
+
let resolve;
|
|
619
|
+
let startTime = 0;
|
|
620
|
+
const promise = new Promise(r => resolve = r);
|
|
621
|
+
const fromY = el.scrollTop;
|
|
622
|
+
const fromX = el.scrollLeft;
|
|
623
|
+
const deltaY = y != null ? y - fromY : 0;
|
|
624
|
+
const deltaX = x != null ? x - fromX : 0;
|
|
625
|
+
// scroll loop
|
|
626
|
+
const step = (timeStamp) => {
|
|
627
|
+
const linearTime = Math.min(1, ((timeStamp - startTime) / duration)) - 1;
|
|
628
|
+
const easedT = Math.pow(linearTime, 3) + 1;
|
|
629
|
+
if (deltaY !== 0) {
|
|
630
|
+
el.scrollTop = Math.floor((easedT * deltaY) + fromY);
|
|
631
|
+
}
|
|
632
|
+
if (deltaX !== 0) {
|
|
633
|
+
el.scrollLeft = Math.floor((easedT * deltaX) + fromX);
|
|
634
|
+
}
|
|
635
|
+
if (easedT < 1) {
|
|
636
|
+
// do not use DomController here
|
|
637
|
+
// must use nativeRaf in order to fire in the next frame
|
|
638
|
+
// TODO: remove as any
|
|
639
|
+
requestAnimationFrame(step);
|
|
640
|
+
}
|
|
641
|
+
else {
|
|
642
|
+
resolve();
|
|
643
|
+
}
|
|
644
|
+
};
|
|
645
|
+
// chill out for a frame first
|
|
646
|
+
requestAnimationFrame(ts => {
|
|
647
|
+
startTime = ts;
|
|
648
|
+
step(ts);
|
|
649
|
+
});
|
|
650
|
+
return promise;
|
|
651
|
+
}
|
|
652
|
+
onScrollStart() {
|
|
653
|
+
this.isScrolling = true;
|
|
654
|
+
this.ionScrollStart.emit({
|
|
655
|
+
isScrolling: true
|
|
656
|
+
});
|
|
657
|
+
if (this.watchDog) {
|
|
658
|
+
clearInterval(this.watchDog);
|
|
659
|
+
}
|
|
660
|
+
// watchdog
|
|
661
|
+
this.watchDog = setInterval(() => {
|
|
662
|
+
if (this.lastScroll < Date.now() - 120) {
|
|
663
|
+
this.onScrollEnd();
|
|
664
|
+
}
|
|
665
|
+
}, 100);
|
|
666
|
+
}
|
|
667
|
+
onScrollEnd() {
|
|
668
|
+
clearInterval(this.watchDog);
|
|
669
|
+
this.watchDog = null;
|
|
670
|
+
if (this.isScrolling) {
|
|
671
|
+
this.isScrolling = false;
|
|
672
|
+
this.ionScrollEnd.emit({
|
|
673
|
+
isScrolling: false
|
|
674
|
+
});
|
|
675
|
+
}
|
|
676
|
+
}
|
|
677
|
+
render() {
|
|
678
|
+
const { isMainContent, scrollX, scrollY } = this;
|
|
679
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
680
|
+
const forceOverscroll = this.shouldForceOverscroll();
|
|
681
|
+
const TagType = isMainContent ? 'main' : 'div';
|
|
682
|
+
const transitionShadow = (mode === 'ios' && ionicGlobal.config.getBoolean('experimentalTransitionShadow', true));
|
|
683
|
+
this.resize();
|
|
684
|
+
return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
|
|
685
|
+
[mode]: true,
|
|
686
|
+
'content-sizing': theme.hostContext('ion-popover', this.el),
|
|
687
|
+
'overscroll': forceOverscroll,
|
|
688
|
+
}), style: {
|
|
689
|
+
'--offset-top': `${this.cTop}px`,
|
|
690
|
+
'--offset-bottom': `${this.cBottom}px`,
|
|
691
|
+
} }, index.h("div", { id: "background-content", part: "background" }), index.h(TagType, { class: {
|
|
692
|
+
'inner-scroll': true,
|
|
693
|
+
'scroll-x': scrollX,
|
|
694
|
+
'scroll-y': scrollY,
|
|
695
|
+
'overscroll': (scrollX || scrollY) && forceOverscroll
|
|
696
|
+
}, ref: (el) => this.scrollEl = el, onScroll: (this.scrollEvents) ? (ev) => this.onScroll(ev) : undefined, part: "scroll" }, index.h("slot", null)), transitionShadow ? (index.h("div", { class: "transition-effect" }, index.h("div", { class: "transition-cover" }), index.h("div", { class: "transition-shadow" }))) : null, index.h("slot", { name: "fixed" })));
|
|
697
|
+
}
|
|
698
|
+
get el() { return index.getElement(this); }
|
|
699
|
+
};
|
|
700
|
+
const getParentElement = (el) => {
|
|
701
|
+
if (el.parentElement) {
|
|
702
|
+
// normal element with a parent element
|
|
703
|
+
return el.parentElement;
|
|
704
|
+
}
|
|
705
|
+
if (el.parentNode && el.parentNode.host) {
|
|
706
|
+
// shadow dom's document fragment
|
|
707
|
+
return el.parentNode.host;
|
|
708
|
+
}
|
|
709
|
+
return null;
|
|
710
|
+
};
|
|
711
|
+
const getPageElement = (el) => {
|
|
712
|
+
const tabs = el.closest('ion-tabs');
|
|
713
|
+
if (tabs) {
|
|
714
|
+
return tabs;
|
|
715
|
+
}
|
|
716
|
+
const page = el.closest('ion-app,ion-page,.ion-page,page-inner');
|
|
717
|
+
if (page) {
|
|
718
|
+
return page;
|
|
719
|
+
}
|
|
720
|
+
return getParentElement(el);
|
|
721
|
+
};
|
|
722
|
+
// ******** DOM READ ****************
|
|
723
|
+
const updateScrollDetail = (detail, el, timestamp, shouldStart) => {
|
|
724
|
+
const prevX = detail.currentX;
|
|
725
|
+
const prevY = detail.currentY;
|
|
726
|
+
const prevT = detail.currentTime;
|
|
727
|
+
const currentX = el.scrollLeft;
|
|
728
|
+
const currentY = el.scrollTop;
|
|
729
|
+
const timeDelta = timestamp - prevT;
|
|
730
|
+
if (shouldStart) {
|
|
731
|
+
// remember the start positions
|
|
732
|
+
detail.startTime = timestamp;
|
|
733
|
+
detail.startX = currentX;
|
|
734
|
+
detail.startY = currentY;
|
|
735
|
+
detail.velocityX = detail.velocityY = 0;
|
|
736
|
+
}
|
|
737
|
+
detail.currentTime = timestamp;
|
|
738
|
+
detail.currentX = detail.scrollLeft = currentX;
|
|
739
|
+
detail.currentY = detail.scrollTop = currentY;
|
|
740
|
+
detail.deltaX = currentX - detail.startX;
|
|
741
|
+
detail.deltaY = currentY - detail.startY;
|
|
742
|
+
if (timeDelta > 0 && timeDelta < 100) {
|
|
743
|
+
const velocityX = (currentX - prevX) / timeDelta;
|
|
744
|
+
const velocityY = (currentY - prevY) / timeDelta;
|
|
745
|
+
detail.velocityX = velocityX * 0.7 + detail.velocityX * 0.3;
|
|
746
|
+
detail.velocityY = velocityY * 0.7 + detail.velocityY * 0.3;
|
|
747
|
+
}
|
|
748
|
+
};
|
|
749
|
+
Content.style = contentCss;
|
|
750
|
+
|
|
751
|
+
const footerIosCss = "ion-footer{display:block;position:relative;order:1;width:100%;z-index:10}ion-footer ion-toolbar:last-of-type{padding-bottom:var(--ion-safe-area-bottom, 0)}.footer-ios ion-toolbar:first-of-type{--border-width:0.55px 0 0}@supports (backdrop-filter: blur(0)){.footer-background{left:0;right:0;top:0;bottom:0;position:absolute;backdrop-filter:saturate(180%) blur(20px)}.footer-translucent-ios ion-toolbar{--opacity:.8}}.footer-ios.ion-no-border ion-toolbar:first-of-type{--border-width:0}";
|
|
752
|
+
|
|
753
|
+
const footerMdCss = "ion-footer{display:block;position:relative;order:1;width:100%;z-index:10}ion-footer ion-toolbar:last-of-type{padding-bottom:var(--ion-safe-area-bottom, 0)}.footer-md::before{left:0;top:-2px;bottom:auto;background-position:left 0 top 0;position:absolute;width:100%;height:2px;background-image:url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAHBAMAAADzDtBxAAAAD1BMVEUAAAAAAAAAAAAAAAAAAABPDueNAAAABXRSTlMUCS0gBIh/TXEAAAAaSURBVAjXYxCEAgY4UIICBmMogMsgFLtAAQCNSwXZKOdPxgAAAABJRU5ErkJggg==\");background-repeat:repeat-x;content:\"\"}[dir=rtl] .footer-md::before,:host-context([dir=rtl]) .footer-md::before{left:unset;right:unset;right:0}[dir=rtl] .footer-md::before,:host-context([dir=rtl]) .footer-md::before{background-position:right 0 top 0}.footer-md.ion-no-border::before{display:none}";
|
|
754
|
+
|
|
755
|
+
const Footer = class {
|
|
756
|
+
constructor(hostRef) {
|
|
757
|
+
index.registerInstance(this, hostRef);
|
|
758
|
+
/**
|
|
759
|
+
* If `true`, the footer will be translucent.
|
|
760
|
+
* Only applies when the mode is `"ios"` and the device supports
|
|
761
|
+
* [`backdrop-filter`](https://developer.mozilla.org/en-US/docs/Web/CSS/backdrop-filter#Browser_compatibility).
|
|
762
|
+
*
|
|
763
|
+
* Note: In order to scroll content behind the footer, the `fullscreen`
|
|
764
|
+
* attribute needs to be set on the content.
|
|
765
|
+
*/
|
|
766
|
+
this.translucent = false;
|
|
767
|
+
}
|
|
768
|
+
render() {
|
|
769
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
770
|
+
const translucent = this.translucent;
|
|
771
|
+
return (index.h(index.Host, { role: "contentinfo", class: {
|
|
772
|
+
[mode]: true,
|
|
773
|
+
// Used internally for styling
|
|
774
|
+
[`footer-${mode}`]: true,
|
|
775
|
+
[`footer-translucent`]: translucent,
|
|
776
|
+
[`footer-translucent-${mode}`]: translucent,
|
|
777
|
+
} }, mode === 'ios' && translucent &&
|
|
778
|
+
index.h("div", { class: "footer-background" }), index.h("slot", null)));
|
|
779
|
+
}
|
|
780
|
+
};
|
|
781
|
+
Footer.style = {
|
|
782
|
+
ios: footerIosCss,
|
|
783
|
+
md: footerMdCss
|
|
784
|
+
};
|
|
785
|
+
|
|
786
|
+
const gridCss = ":host{padding-left:var(--ion-grid-padding-xs, var(--ion-grid-padding, 5px));padding-right:var(--ion-grid-padding-xs, var(--ion-grid-padding, 5px));padding-top:var(--ion-grid-padding-xs, var(--ion-grid-padding, 5px));padding-bottom:var(--ion-grid-padding-xs, var(--ion-grid-padding, 5px));margin-left:auto;margin-right:auto;display:block;flex:1}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-padding-xs, var(--ion-grid-padding, 5px));padding-inline-start:var(--ion-grid-padding-xs, var(--ion-grid-padding, 5px));-webkit-padding-end:var(--ion-grid-padding-xs, var(--ion-grid-padding, 5px));padding-inline-end:var(--ion-grid-padding-xs, var(--ion-grid-padding, 5px))}}@media (min-width: 576px){:host{padding-left:var(--ion-grid-padding-sm, var(--ion-grid-padding, 5px));padding-right:var(--ion-grid-padding-sm, var(--ion-grid-padding, 5px));padding-top:var(--ion-grid-padding-sm, var(--ion-grid-padding, 5px));padding-bottom:var(--ion-grid-padding-sm, var(--ion-grid-padding, 5px))}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-padding-sm, var(--ion-grid-padding, 5px));padding-inline-start:var(--ion-grid-padding-sm, var(--ion-grid-padding, 5px));-webkit-padding-end:var(--ion-grid-padding-sm, var(--ion-grid-padding, 5px));padding-inline-end:var(--ion-grid-padding-sm, var(--ion-grid-padding, 5px))}}}@media (min-width: 768px){:host{padding-left:var(--ion-grid-padding-md, var(--ion-grid-padding, 5px));padding-right:var(--ion-grid-padding-md, var(--ion-grid-padding, 5px));padding-top:var(--ion-grid-padding-md, var(--ion-grid-padding, 5px));padding-bottom:var(--ion-grid-padding-md, var(--ion-grid-padding, 5px))}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-padding-md, var(--ion-grid-padding, 5px));padding-inline-start:var(--ion-grid-padding-md, var(--ion-grid-padding, 5px));-webkit-padding-end:var(--ion-grid-padding-md, var(--ion-grid-padding, 5px));padding-inline-end:var(--ion-grid-padding-md, var(--ion-grid-padding, 5px))}}}@media (min-width: 992px){:host{padding-left:var(--ion-grid-padding-lg, var(--ion-grid-padding, 5px));padding-right:var(--ion-grid-padding-lg, var(--ion-grid-padding, 5px));padding-top:var(--ion-grid-padding-lg, var(--ion-grid-padding, 5px));padding-bottom:var(--ion-grid-padding-lg, var(--ion-grid-padding, 5px))}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-padding-lg, var(--ion-grid-padding, 5px));padding-inline-start:var(--ion-grid-padding-lg, var(--ion-grid-padding, 5px));-webkit-padding-end:var(--ion-grid-padding-lg, var(--ion-grid-padding, 5px));padding-inline-end:var(--ion-grid-padding-lg, var(--ion-grid-padding, 5px))}}}@media (min-width: 1200px){:host{padding-left:var(--ion-grid-padding-xl, var(--ion-grid-padding, 5px));padding-right:var(--ion-grid-padding-xl, var(--ion-grid-padding, 5px));padding-top:var(--ion-grid-padding-xl, var(--ion-grid-padding, 5px));padding-bottom:var(--ion-grid-padding-xl, var(--ion-grid-padding, 5px))}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-grid-padding-xl, var(--ion-grid-padding, 5px));padding-inline-start:var(--ion-grid-padding-xl, var(--ion-grid-padding, 5px));-webkit-padding-end:var(--ion-grid-padding-xl, var(--ion-grid-padding, 5px));padding-inline-end:var(--ion-grid-padding-xl, var(--ion-grid-padding, 5px))}}}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{margin-left:unset;margin-right:unset;-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto}}:host(.grid-fixed){width:var(--ion-grid-width-xs, var(--ion-grid-width, 100%));max-width:100%}@media (min-width: 576px){:host(.grid-fixed){width:var(--ion-grid-width-sm, var(--ion-grid-width, 540px))}}@media (min-width: 768px){:host(.grid-fixed){width:var(--ion-grid-width-md, var(--ion-grid-width, 720px))}}@media (min-width: 992px){:host(.grid-fixed){width:var(--ion-grid-width-lg, var(--ion-grid-width, 960px))}}@media (min-width: 1200px){:host(.grid-fixed){width:var(--ion-grid-width-xl, var(--ion-grid-width, 1140px))}}:host(.ion-no-padding){--ion-grid-column-padding:0;--ion-grid-column-padding-xs:0;--ion-grid-column-padding-sm:0;--ion-grid-column-padding-md:0;--ion-grid-column-padding-lg:0;--ion-grid-column-padding-xl:0}";
|
|
787
|
+
|
|
788
|
+
const Grid = class {
|
|
789
|
+
constructor(hostRef) {
|
|
790
|
+
index.registerInstance(this, hostRef);
|
|
791
|
+
/**
|
|
792
|
+
* If `true`, the grid will have a fixed width based on the screen size.
|
|
793
|
+
*/
|
|
794
|
+
this.fixed = false;
|
|
795
|
+
}
|
|
796
|
+
render() {
|
|
797
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
798
|
+
return (index.h(index.Host, { class: {
|
|
799
|
+
[mode]: true,
|
|
800
|
+
'grid-fixed': this.fixed
|
|
801
|
+
} }, index.h("slot", null)));
|
|
802
|
+
}
|
|
803
|
+
};
|
|
804
|
+
Grid.style = gridCss;
|
|
805
|
+
|
|
806
|
+
const TRANSITION = 'all 0.2s ease-in-out';
|
|
807
|
+
const cloneElement = (tagName) => {
|
|
808
|
+
const getCachedEl = document.querySelector(`${tagName}.ion-cloned-element`);
|
|
809
|
+
if (getCachedEl !== null) {
|
|
810
|
+
return getCachedEl;
|
|
811
|
+
}
|
|
812
|
+
const clonedEl = document.createElement(tagName);
|
|
813
|
+
clonedEl.classList.add('ion-cloned-element');
|
|
814
|
+
clonedEl.style.setProperty('display', 'none');
|
|
815
|
+
document.body.appendChild(clonedEl);
|
|
816
|
+
return clonedEl;
|
|
817
|
+
};
|
|
818
|
+
const createHeaderIndex = (headerEl) => {
|
|
819
|
+
if (!headerEl) {
|
|
820
|
+
return;
|
|
821
|
+
}
|
|
822
|
+
const toolbars = headerEl.querySelectorAll('ion-toolbar');
|
|
823
|
+
return {
|
|
824
|
+
el: headerEl,
|
|
825
|
+
toolbars: Array.from(toolbars).map((toolbar) => {
|
|
826
|
+
const ionTitleEl = toolbar.querySelector('ion-title');
|
|
827
|
+
return {
|
|
828
|
+
el: toolbar,
|
|
829
|
+
background: toolbar.shadowRoot.querySelector('.toolbar-background'),
|
|
830
|
+
ionTitleEl,
|
|
831
|
+
innerTitleEl: (ionTitleEl) ? ionTitleEl.shadowRoot.querySelector('.toolbar-title') : null,
|
|
832
|
+
ionButtonsEl: Array.from(toolbar.querySelectorAll('ion-buttons')) || []
|
|
833
|
+
};
|
|
834
|
+
}) || []
|
|
835
|
+
};
|
|
836
|
+
};
|
|
837
|
+
const handleContentScroll = (scrollEl, scrollHeaderIndex, contentEl) => {
|
|
838
|
+
index.readTask(() => {
|
|
839
|
+
const scrollTop = scrollEl.scrollTop;
|
|
840
|
+
const scale = helpers.clamp(1, 1 + (-scrollTop / 500), 1.1);
|
|
841
|
+
// Native refresher should not cause titles to scale
|
|
842
|
+
const nativeRefresher = contentEl.querySelector('ion-refresher.refresher-native');
|
|
843
|
+
if (nativeRefresher === null) {
|
|
844
|
+
index.writeTask(() => {
|
|
845
|
+
scaleLargeTitles(scrollHeaderIndex.toolbars, scale);
|
|
846
|
+
});
|
|
847
|
+
}
|
|
848
|
+
});
|
|
849
|
+
};
|
|
850
|
+
const setToolbarBackgroundOpacity = (toolbar, opacity) => {
|
|
851
|
+
if (opacity === undefined) {
|
|
852
|
+
toolbar.background.style.removeProperty('--opacity');
|
|
853
|
+
}
|
|
854
|
+
else {
|
|
855
|
+
toolbar.background.style.setProperty('--opacity', opacity.toString());
|
|
856
|
+
}
|
|
857
|
+
};
|
|
858
|
+
const handleToolbarBorderIntersection = (ev, mainHeaderIndex, scrollTop) => {
|
|
859
|
+
if (!ev[0].isIntersecting) {
|
|
860
|
+
return;
|
|
861
|
+
}
|
|
862
|
+
/**
|
|
863
|
+
* There is a bug in Safari where overflow scrolling on a non-body element
|
|
864
|
+
* does not always reset the scrollTop position to 0 when letting go. It will
|
|
865
|
+
* set to 1 once the rubber band effect has ended. This causes the background to
|
|
866
|
+
* appear slightly on certain app setups.
|
|
867
|
+
*
|
|
868
|
+
* Additionally, we check if user is rubber banding (scrolling is negative)
|
|
869
|
+
* as this can mean they are using pull to refresh. Once the refresher starts,
|
|
870
|
+
* the content is transformed which can cause the intersection observer to erroneously
|
|
871
|
+
* fire here as well.
|
|
872
|
+
*/
|
|
873
|
+
const scale = (ev[0].intersectionRatio > 0.9 || scrollTop <= 0) ? 0 : ((1 - ev[0].intersectionRatio) * 100) / 75;
|
|
874
|
+
mainHeaderIndex.toolbars.forEach(toolbar => {
|
|
875
|
+
setToolbarBackgroundOpacity(toolbar, (scale === 1) ? undefined : scale);
|
|
876
|
+
});
|
|
877
|
+
};
|
|
878
|
+
/**
|
|
879
|
+
* If toolbars are intersecting, hide the scrollable toolbar content
|
|
880
|
+
* and show the primary toolbar content. If the toolbars are not intersecting,
|
|
881
|
+
* hide the primary toolbar content and show the scrollable toolbar content
|
|
882
|
+
*/
|
|
883
|
+
const handleToolbarIntersection = (ev, mainHeaderIndex, scrollHeaderIndex, scrollEl) => {
|
|
884
|
+
index.writeTask(() => {
|
|
885
|
+
const scrollTop = scrollEl.scrollTop;
|
|
886
|
+
handleToolbarBorderIntersection(ev, mainHeaderIndex, scrollTop);
|
|
887
|
+
const event = ev[0];
|
|
888
|
+
const intersection = event.intersectionRect;
|
|
889
|
+
const intersectionArea = intersection.width * intersection.height;
|
|
890
|
+
const rootArea = event.rootBounds.width * event.rootBounds.height;
|
|
891
|
+
const isPageHidden = intersectionArea === 0 && rootArea === 0;
|
|
892
|
+
const leftDiff = Math.abs(intersection.left - event.boundingClientRect.left);
|
|
893
|
+
const rightDiff = Math.abs(intersection.right - event.boundingClientRect.right);
|
|
894
|
+
const isPageTransitioning = intersectionArea > 0 && (leftDiff >= 5 || rightDiff >= 5);
|
|
895
|
+
if (isPageHidden || isPageTransitioning) {
|
|
896
|
+
return;
|
|
897
|
+
}
|
|
898
|
+
if (event.isIntersecting) {
|
|
899
|
+
setHeaderActive(mainHeaderIndex, false);
|
|
900
|
+
setHeaderActive(scrollHeaderIndex);
|
|
901
|
+
}
|
|
902
|
+
else {
|
|
903
|
+
/**
|
|
904
|
+
* There is a bug with IntersectionObserver on Safari
|
|
905
|
+
* where `event.isIntersecting === false` when cancelling
|
|
906
|
+
* a swipe to go back gesture. Checking the intersection
|
|
907
|
+
* x, y, width, and height provides a workaround. This bug
|
|
908
|
+
* does not happen when using Safari + Web Animations,
|
|
909
|
+
* only Safari + CSS Animations.
|
|
910
|
+
*/
|
|
911
|
+
const hasValidIntersection = (intersection.x === 0 && intersection.y === 0) || (intersection.width !== 0 && intersection.height !== 0);
|
|
912
|
+
if (hasValidIntersection && scrollTop > 0) {
|
|
913
|
+
setHeaderActive(mainHeaderIndex);
|
|
914
|
+
setHeaderActive(scrollHeaderIndex, false);
|
|
915
|
+
setToolbarBackgroundOpacity(mainHeaderIndex.toolbars[0]);
|
|
916
|
+
}
|
|
917
|
+
}
|
|
918
|
+
});
|
|
919
|
+
};
|
|
920
|
+
const setHeaderActive = (headerIndex, active = true) => {
|
|
921
|
+
if (active) {
|
|
922
|
+
headerIndex.el.classList.remove('header-collapse-condense-inactive');
|
|
923
|
+
}
|
|
924
|
+
else {
|
|
925
|
+
headerIndex.el.classList.add('header-collapse-condense-inactive');
|
|
926
|
+
}
|
|
927
|
+
};
|
|
928
|
+
const scaleLargeTitles = (toolbars = [], scale = 1, transition = false) => {
|
|
929
|
+
toolbars.forEach(toolbar => {
|
|
930
|
+
const ionTitle = toolbar.ionTitleEl;
|
|
931
|
+
const titleDiv = toolbar.innerTitleEl;
|
|
932
|
+
if (!ionTitle || ionTitle.size !== 'large') {
|
|
933
|
+
return;
|
|
934
|
+
}
|
|
935
|
+
titleDiv.style.transition = (transition) ? TRANSITION : '';
|
|
936
|
+
titleDiv.style.transform = `scale3d(${scale}, ${scale}, 1)`;
|
|
937
|
+
});
|
|
938
|
+
};
|
|
939
|
+
|
|
940
|
+
const headerIosCss = "ion-header{display:block;position:relative;order:-1;width:100%;z-index:10}ion-header ion-toolbar:first-of-type{padding-top:var(--ion-safe-area-top, 0)}.header-ios ion-toolbar:last-of-type{--border-width:0 0 0.55px}@supports (backdrop-filter: blur(0)){.header-background{left:0;right:0;top:0;bottom:0;position:absolute;backdrop-filter:saturate(180%) blur(20px)}.header-translucent-ios ion-toolbar{--opacity:.8}.header-collapse-condense-inactive .header-background{backdrop-filter:blur(20px)}}.header-ios.ion-no-border ion-toolbar:last-of-type{--border-width:0}.header-collapse-condense{z-index:9}.header-collapse-condense ion-toolbar{position:sticky;top:0}.header-collapse-condense ion-toolbar:first-of-type{padding-top:7px;z-index:1}.header-collapse-condense ion-toolbar{--background:var(--ion-background-color, #fff);z-index:0}.header-collapse-condense ion-toolbar ion-searchbar{height:48px;padding-top:0px;padding-bottom:13px}.header-collapse-main ion-toolbar.in-toolbar ion-title,.header-collapse-main ion-toolbar.in-toolbar ion-buttons{transition:all 0.2s ease-in-out}.header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-title,.header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-buttons.buttons-collapse{opacity:0;pointer-events:none}.header-collapse-condense-inactive.header-collapse-condense ion-toolbar.in-toolbar ion-title,.header-collapse-condense-inactive.header-collapse-condense ion-toolbar.in-toolbar ion-buttons.buttons-collapse{visibility:hidden}";
|
|
941
|
+
|
|
942
|
+
const headerMdCss = "ion-header{display:block;position:relative;order:-1;width:100%;z-index:10}ion-header ion-toolbar:first-of-type{padding-top:var(--ion-safe-area-top, 0)}.header-md::after{left:0;bottom:-5px;background-position:left 0 top -2px;position:absolute;width:100%;height:5px;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAHBAMAAADzDtBxAAAAD1BMVEUAAAAAAAAAAAAAAAAAAABPDueNAAAABXRSTlMUCS0gBIh/TXEAAAAaSURBVAjXYxCEAgY4UIICBmMogMsgFLtAAQCNSwXZKOdPxgAAAABJRU5ErkJggg==);background-repeat:repeat-x;content:\"\"}[dir=rtl] .header-md::after,:host-context([dir=rtl]) .header-md::after{left:unset;right:unset;right:0}[dir=rtl] .header-md::after,:host-context([dir=rtl]) .header-md::after{background-position:right 0 top -2px}.header-collapse-condense{display:none}.header-md.ion-no-border::after{display:none}";
|
|
943
|
+
|
|
944
|
+
const Header = class {
|
|
945
|
+
constructor(hostRef) {
|
|
946
|
+
index.registerInstance(this, hostRef);
|
|
947
|
+
this.collapsibleHeaderInitialized = false;
|
|
948
|
+
this.inheritedAttributes = {};
|
|
949
|
+
/**
|
|
950
|
+
* If `true`, the header will be translucent.
|
|
951
|
+
* Only applies when the mode is `"ios"` and the device supports
|
|
952
|
+
* [`backdrop-filter`](https://developer.mozilla.org/en-US/docs/Web/CSS/backdrop-filter#Browser_compatibility).
|
|
953
|
+
*
|
|
954
|
+
* Note: In order to scroll content behind the header, the `fullscreen`
|
|
955
|
+
* attribute needs to be set on the content.
|
|
956
|
+
*/
|
|
957
|
+
this.translucent = false;
|
|
958
|
+
}
|
|
959
|
+
componentWillLoad() {
|
|
960
|
+
this.inheritedAttributes = helpers.inheritAttributes(this.el, ['role']);
|
|
961
|
+
}
|
|
962
|
+
async componentDidLoad() {
|
|
963
|
+
await this.checkCollapsibleHeader();
|
|
964
|
+
}
|
|
965
|
+
async componentDidUpdate() {
|
|
966
|
+
await this.checkCollapsibleHeader();
|
|
967
|
+
}
|
|
968
|
+
disconnectedCallback() {
|
|
969
|
+
this.destroyCollapsibleHeader();
|
|
970
|
+
}
|
|
971
|
+
async checkCollapsibleHeader() {
|
|
972
|
+
// Determine if the header can collapse
|
|
973
|
+
const hasCollapse = this.collapse === 'condense';
|
|
974
|
+
const canCollapse = (hasCollapse && ionicGlobal.getIonMode(this) === 'ios') ? hasCollapse : false;
|
|
975
|
+
if (!canCollapse && this.collapsibleHeaderInitialized) {
|
|
976
|
+
this.destroyCollapsibleHeader();
|
|
977
|
+
}
|
|
978
|
+
else if (canCollapse && !this.collapsibleHeaderInitialized) {
|
|
979
|
+
const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
|
|
980
|
+
const contentEl = (pageEl) ? pageEl.querySelector('ion-content') : null;
|
|
981
|
+
// Cloned elements are always needed in iOS transition
|
|
982
|
+
index.writeTask(() => {
|
|
983
|
+
const title = cloneElement('ion-title');
|
|
984
|
+
title.size = 'large';
|
|
985
|
+
cloneElement('ion-back-button');
|
|
986
|
+
});
|
|
987
|
+
await this.setupCollapsibleHeader(contentEl, pageEl);
|
|
988
|
+
}
|
|
989
|
+
}
|
|
990
|
+
destroyCollapsibleHeader() {
|
|
991
|
+
if (this.intersectionObserver) {
|
|
992
|
+
this.intersectionObserver.disconnect();
|
|
993
|
+
this.intersectionObserver = undefined;
|
|
994
|
+
}
|
|
995
|
+
if (this.scrollEl && this.contentScrollCallback) {
|
|
996
|
+
this.scrollEl.removeEventListener('scroll', this.contentScrollCallback);
|
|
997
|
+
this.contentScrollCallback = undefined;
|
|
998
|
+
}
|
|
999
|
+
if (this.collapsibleMainHeader) {
|
|
1000
|
+
this.collapsibleMainHeader.classList.remove('header-collapse-main');
|
|
1001
|
+
this.collapsibleMainHeader = undefined;
|
|
1002
|
+
}
|
|
1003
|
+
}
|
|
1004
|
+
async setupCollapsibleHeader(contentEl, pageEl) {
|
|
1005
|
+
if (!contentEl || !pageEl) {
|
|
1006
|
+
console.error('ion-header requires a content to collapse, make sure there is an ion-content.');
|
|
1007
|
+
return;
|
|
1008
|
+
}
|
|
1009
|
+
if (typeof IntersectionObserver === 'undefined') {
|
|
1010
|
+
return;
|
|
1011
|
+
}
|
|
1012
|
+
this.scrollEl = await contentEl.getScrollElement();
|
|
1013
|
+
const headers = pageEl.querySelectorAll('ion-header');
|
|
1014
|
+
this.collapsibleMainHeader = Array.from(headers).find((header) => header.collapse !== 'condense');
|
|
1015
|
+
if (!this.collapsibleMainHeader) {
|
|
1016
|
+
return;
|
|
1017
|
+
}
|
|
1018
|
+
const mainHeaderIndex = createHeaderIndex(this.collapsibleMainHeader);
|
|
1019
|
+
const scrollHeaderIndex = createHeaderIndex(this.el);
|
|
1020
|
+
if (!mainHeaderIndex || !scrollHeaderIndex) {
|
|
1021
|
+
return;
|
|
1022
|
+
}
|
|
1023
|
+
setHeaderActive(mainHeaderIndex, false);
|
|
1024
|
+
mainHeaderIndex.toolbars.forEach(toolbar => {
|
|
1025
|
+
setToolbarBackgroundOpacity(toolbar, 0);
|
|
1026
|
+
});
|
|
1027
|
+
/**
|
|
1028
|
+
* Handle interaction between toolbar collapse and
|
|
1029
|
+
* showing/hiding content in the primary ion-header
|
|
1030
|
+
* as well as progressively showing/hiding the main header
|
|
1031
|
+
* border as the top-most toolbar collapses or expands.
|
|
1032
|
+
*/
|
|
1033
|
+
const toolbarIntersection = (ev) => { handleToolbarIntersection(ev, mainHeaderIndex, scrollHeaderIndex, this.scrollEl); };
|
|
1034
|
+
this.intersectionObserver = new IntersectionObserver(toolbarIntersection, { root: contentEl, threshold: [0.25, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1] });
|
|
1035
|
+
this.intersectionObserver.observe(scrollHeaderIndex.toolbars[scrollHeaderIndex.toolbars.length - 1].el);
|
|
1036
|
+
/**
|
|
1037
|
+
* Handle scaling of large iOS titles and
|
|
1038
|
+
* showing/hiding border on last toolbar
|
|
1039
|
+
* in primary header
|
|
1040
|
+
*/
|
|
1041
|
+
this.contentScrollCallback = () => { handleContentScroll(this.scrollEl, scrollHeaderIndex, contentEl); };
|
|
1042
|
+
this.scrollEl.addEventListener('scroll', this.contentScrollCallback);
|
|
1043
|
+
index.writeTask(() => {
|
|
1044
|
+
if (this.collapsibleMainHeader !== undefined) {
|
|
1045
|
+
this.collapsibleMainHeader.classList.add('header-collapse-main');
|
|
1046
|
+
}
|
|
1047
|
+
});
|
|
1048
|
+
this.collapsibleHeaderInitialized = true;
|
|
1049
|
+
}
|
|
1050
|
+
render() {
|
|
1051
|
+
const { translucent, inheritedAttributes } = this;
|
|
1052
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1053
|
+
const collapse = this.collapse || 'none';
|
|
1054
|
+
return (index.h(index.Host, Object.assign({ role: "banner", class: {
|
|
1055
|
+
[mode]: true,
|
|
1056
|
+
// Used internally for styling
|
|
1057
|
+
[`header-${mode}`]: true,
|
|
1058
|
+
[`header-translucent`]: this.translucent,
|
|
1059
|
+
[`header-collapse-${collapse}`]: true,
|
|
1060
|
+
[`header-translucent-${mode}`]: this.translucent,
|
|
1061
|
+
} }, inheritedAttributes), mode === 'ios' && translucent &&
|
|
1062
|
+
index.h("div", { class: "header-background" }), index.h("slot", null)));
|
|
1063
|
+
}
|
|
1064
|
+
get el() { return index.getElement(this); }
|
|
1065
|
+
};
|
|
1066
|
+
Header.style = {
|
|
1067
|
+
ios: headerIosCss,
|
|
1068
|
+
md: headerMdCss
|
|
1069
|
+
};
|
|
1070
|
+
|
|
1071
|
+
let CACHED_MAP;
|
|
1072
|
+
const getIconMap = () => {
|
|
1073
|
+
if (typeof window === 'undefined') {
|
|
1074
|
+
return new Map();
|
|
1075
|
+
}
|
|
1076
|
+
else {
|
|
1077
|
+
if (!CACHED_MAP) {
|
|
1078
|
+
const win = window;
|
|
1079
|
+
win.Ionicons = win.Ionicons || {};
|
|
1080
|
+
CACHED_MAP = win.Ionicons.map = win.Ionicons.map || new Map();
|
|
1081
|
+
}
|
|
1082
|
+
return CACHED_MAP;
|
|
1083
|
+
}
|
|
1084
|
+
};
|
|
1085
|
+
const getUrl = (i) => {
|
|
1086
|
+
let url = getSrc(i.src);
|
|
1087
|
+
if (url) {
|
|
1088
|
+
return url;
|
|
1089
|
+
}
|
|
1090
|
+
url = getName(i.name, i.icon, i.mode, i.ios, i.md);
|
|
1091
|
+
if (url) {
|
|
1092
|
+
return getNamedUrl(url);
|
|
1093
|
+
}
|
|
1094
|
+
if (i.icon) {
|
|
1095
|
+
url = getSrc(i.icon);
|
|
1096
|
+
if (url) {
|
|
1097
|
+
return url;
|
|
1098
|
+
}
|
|
1099
|
+
url = getSrc(i.icon[i.mode]);
|
|
1100
|
+
if (url) {
|
|
1101
|
+
return url;
|
|
1102
|
+
}
|
|
1103
|
+
}
|
|
1104
|
+
return null;
|
|
1105
|
+
};
|
|
1106
|
+
const getNamedUrl = (iconName) => {
|
|
1107
|
+
const url = getIconMap().get(iconName);
|
|
1108
|
+
if (url) {
|
|
1109
|
+
return url;
|
|
1110
|
+
}
|
|
1111
|
+
return index.getAssetPath(`svg/${iconName}.svg`);
|
|
1112
|
+
};
|
|
1113
|
+
const getName = (iconName, icon, mode, ios, md) => {
|
|
1114
|
+
// default to "md" if somehow the mode wasn't set
|
|
1115
|
+
mode = (mode && toLower(mode)) === 'ios' ? 'ios' : 'md';
|
|
1116
|
+
// if an icon was passed in using the ios or md attributes
|
|
1117
|
+
// set the iconName to whatever was passed in
|
|
1118
|
+
if (ios && mode === 'ios') {
|
|
1119
|
+
iconName = toLower(ios);
|
|
1120
|
+
}
|
|
1121
|
+
else if (md && mode === 'md') {
|
|
1122
|
+
iconName = toLower(md);
|
|
1123
|
+
}
|
|
1124
|
+
else {
|
|
1125
|
+
if (!iconName && icon && !isSrc(icon)) {
|
|
1126
|
+
iconName = icon;
|
|
1127
|
+
}
|
|
1128
|
+
if (isStr(iconName)) {
|
|
1129
|
+
iconName = toLower(iconName);
|
|
1130
|
+
}
|
|
1131
|
+
}
|
|
1132
|
+
if (!isStr(iconName) || iconName.trim() === '') {
|
|
1133
|
+
return null;
|
|
1134
|
+
}
|
|
1135
|
+
// only allow alpha characters and dash
|
|
1136
|
+
const invalidChars = iconName.replace(/[a-z]|-|\d/gi, '');
|
|
1137
|
+
if (invalidChars !== '') {
|
|
1138
|
+
return null;
|
|
1139
|
+
}
|
|
1140
|
+
return iconName;
|
|
1141
|
+
};
|
|
1142
|
+
const getSrc = (src) => {
|
|
1143
|
+
if (isStr(src)) {
|
|
1144
|
+
src = src.trim();
|
|
1145
|
+
if (isSrc(src)) {
|
|
1146
|
+
return src;
|
|
1147
|
+
}
|
|
1148
|
+
}
|
|
1149
|
+
return null;
|
|
1150
|
+
};
|
|
1151
|
+
const isSrc = (str) => str.length > 0 && /(\/|\.)/.test(str);
|
|
1152
|
+
const isStr = (val) => typeof val === 'string';
|
|
1153
|
+
const toLower = (val) => val.toLowerCase();
|
|
1154
|
+
|
|
1155
|
+
const validateContent = (svgContent) => {
|
|
1156
|
+
const div = document.createElement('div');
|
|
1157
|
+
div.innerHTML = svgContent;
|
|
1158
|
+
// setup this way to ensure it works on our buddy IE
|
|
1159
|
+
for (let i = div.childNodes.length - 1; i >= 0; i--) {
|
|
1160
|
+
if (div.childNodes[i].nodeName.toLowerCase() !== 'svg') {
|
|
1161
|
+
div.removeChild(div.childNodes[i]);
|
|
1162
|
+
}
|
|
1163
|
+
}
|
|
1164
|
+
// must only have 1 root element
|
|
1165
|
+
const svgElm = div.firstElementChild;
|
|
1166
|
+
if (svgElm && svgElm.nodeName.toLowerCase() === 'svg') {
|
|
1167
|
+
const svgClass = svgElm.getAttribute('class') || '';
|
|
1168
|
+
svgElm.setAttribute('class', (svgClass + ' s-ion-icon').trim());
|
|
1169
|
+
// root element must be an svg
|
|
1170
|
+
// lets double check we've got valid elements
|
|
1171
|
+
// do not allow scripts
|
|
1172
|
+
if (isValid(svgElm)) {
|
|
1173
|
+
return div.innerHTML;
|
|
1174
|
+
}
|
|
1175
|
+
}
|
|
1176
|
+
return '';
|
|
1177
|
+
};
|
|
1178
|
+
const isValid = (elm) => {
|
|
1179
|
+
if (elm.nodeType === 1) {
|
|
1180
|
+
if (elm.nodeName.toLowerCase() === 'script') {
|
|
1181
|
+
return false;
|
|
1182
|
+
}
|
|
1183
|
+
for (let i = 0; i < elm.attributes.length; i++) {
|
|
1184
|
+
const val = elm.attributes[i].value;
|
|
1185
|
+
if (isStr(val) && val.toLowerCase().indexOf('on') === 0) {
|
|
1186
|
+
return false;
|
|
1187
|
+
}
|
|
1188
|
+
}
|
|
1189
|
+
for (let i = 0; i < elm.childNodes.length; i++) {
|
|
1190
|
+
if (!isValid(elm.childNodes[i])) {
|
|
1191
|
+
return false;
|
|
1192
|
+
}
|
|
1193
|
+
}
|
|
1194
|
+
}
|
|
1195
|
+
return true;
|
|
1196
|
+
};
|
|
1197
|
+
|
|
1198
|
+
const ioniconContent = new Map();
|
|
1199
|
+
const requests = new Map();
|
|
1200
|
+
const getSvgContent = (url, sanitize) => {
|
|
1201
|
+
// see if we already have a request for this url
|
|
1202
|
+
let req = requests.get(url);
|
|
1203
|
+
if (!req) {
|
|
1204
|
+
if (typeof fetch !== 'undefined' && typeof document !== 'undefined') {
|
|
1205
|
+
// we don't already have a request
|
|
1206
|
+
req = fetch(url).then((rsp) => {
|
|
1207
|
+
if (rsp.ok) {
|
|
1208
|
+
return rsp.text().then((svgContent) => {
|
|
1209
|
+
if (svgContent && sanitize !== false) {
|
|
1210
|
+
svgContent = validateContent(svgContent);
|
|
1211
|
+
}
|
|
1212
|
+
ioniconContent.set(url, svgContent || '');
|
|
1213
|
+
});
|
|
1214
|
+
}
|
|
1215
|
+
ioniconContent.set(url, '');
|
|
1216
|
+
});
|
|
1217
|
+
// cache for the same requests
|
|
1218
|
+
requests.set(url, req);
|
|
1219
|
+
}
|
|
1220
|
+
else {
|
|
1221
|
+
// set to empty for ssr scenarios and resolve promise
|
|
1222
|
+
ioniconContent.set(url, '');
|
|
1223
|
+
return Promise.resolve();
|
|
1224
|
+
}
|
|
1225
|
+
}
|
|
1226
|
+
return req;
|
|
1227
|
+
};
|
|
1228
|
+
|
|
1229
|
+
const iconCss = ":host{display:inline-block;width:1em;height:1em;contain:strict;fill:currentColor;box-sizing:content-box !important}:host .ionicon{stroke:currentColor}.ionicon-fill-none{fill:none}.ionicon-stroke-width{stroke-width:32px;stroke-width:var(--ionicon-stroke-width, 32px)}.icon-inner,.ionicon,svg{display:block;height:100%;width:100%}:host(.flip-rtl) .icon-inner{transform:scaleX(-1)}:host(.icon-small){font-size:18px !important}:host(.icon-large){font-size:32px !important}:host(.ion-color){color:var(--ion-color-base) !important}:host(.ion-color-primary){--ion-color-base:var(--ion-color-primary, #3880ff)}:host(.ion-color-secondary){--ion-color-base:var(--ion-color-secondary, #0cd1e8)}:host(.ion-color-tertiary){--ion-color-base:var(--ion-color-tertiary, #f4a942)}:host(.ion-color-success){--ion-color-base:var(--ion-color-success, #10dc60)}:host(.ion-color-warning){--ion-color-base:var(--ion-color-warning, #ffce00)}:host(.ion-color-danger){--ion-color-base:var(--ion-color-danger, #f14141)}:host(.ion-color-light){--ion-color-base:var(--ion-color-light, #f4f5f8)}:host(.ion-color-medium){--ion-color-base:var(--ion-color-medium, #989aa2)}:host(.ion-color-dark){--ion-color-base:var(--ion-color-dark, #222428)}";
|
|
1230
|
+
|
|
1231
|
+
const Icon = class {
|
|
1232
|
+
constructor(hostRef) {
|
|
1233
|
+
index.registerInstance(this, hostRef);
|
|
1234
|
+
this.iconName = null;
|
|
1235
|
+
this.isVisible = false;
|
|
1236
|
+
/**
|
|
1237
|
+
* The mode determines which platform styles to use.
|
|
1238
|
+
*/
|
|
1239
|
+
this.mode = getIonMode();
|
|
1240
|
+
/**
|
|
1241
|
+
* If enabled, ion-icon will be loaded lazily when it's visible in the viewport.
|
|
1242
|
+
* Default, `false`.
|
|
1243
|
+
*/
|
|
1244
|
+
this.lazy = false;
|
|
1245
|
+
/**
|
|
1246
|
+
* When set to `false`, SVG content that is HTTP fetched will not be checked
|
|
1247
|
+
* if the response SVG content has any `<script>` elements, or any attributes
|
|
1248
|
+
* that start with `on`, such as `onclick`.
|
|
1249
|
+
* @default true
|
|
1250
|
+
*/
|
|
1251
|
+
this.sanitize = true;
|
|
1252
|
+
}
|
|
1253
|
+
connectedCallback() {
|
|
1254
|
+
// purposely do not return the promise here because loading
|
|
1255
|
+
// the svg file should not hold up loading the app
|
|
1256
|
+
// only load the svg if it's visible
|
|
1257
|
+
this.waitUntilVisible(this.el, '50px', () => {
|
|
1258
|
+
this.isVisible = true;
|
|
1259
|
+
this.loadIcon();
|
|
1260
|
+
});
|
|
1261
|
+
}
|
|
1262
|
+
disconnectedCallback() {
|
|
1263
|
+
if (this.io) {
|
|
1264
|
+
this.io.disconnect();
|
|
1265
|
+
this.io = undefined;
|
|
1266
|
+
}
|
|
1267
|
+
}
|
|
1268
|
+
waitUntilVisible(el, rootMargin, cb) {
|
|
1269
|
+
if (this.lazy && typeof window !== 'undefined' && window.IntersectionObserver) {
|
|
1270
|
+
const io = (this.io = new window.IntersectionObserver((data) => {
|
|
1271
|
+
if (data[0].isIntersecting) {
|
|
1272
|
+
io.disconnect();
|
|
1273
|
+
this.io = undefined;
|
|
1274
|
+
cb();
|
|
1275
|
+
}
|
|
1276
|
+
}, { rootMargin }));
|
|
1277
|
+
io.observe(el);
|
|
1278
|
+
}
|
|
1279
|
+
else {
|
|
1280
|
+
// browser doesn't support IntersectionObserver
|
|
1281
|
+
// so just fallback to always show it
|
|
1282
|
+
cb();
|
|
1283
|
+
}
|
|
1284
|
+
}
|
|
1285
|
+
loadIcon() {
|
|
1286
|
+
if (this.isVisible) {
|
|
1287
|
+
const url = getUrl(this);
|
|
1288
|
+
if (url) {
|
|
1289
|
+
if (ioniconContent.has(url)) {
|
|
1290
|
+
// sync if it's already loaded
|
|
1291
|
+
this.svgContent = ioniconContent.get(url);
|
|
1292
|
+
}
|
|
1293
|
+
else {
|
|
1294
|
+
// async if it hasn't been loaded
|
|
1295
|
+
getSvgContent(url, this.sanitize).then(() => (this.svgContent = ioniconContent.get(url)));
|
|
1296
|
+
}
|
|
1297
|
+
}
|
|
1298
|
+
}
|
|
1299
|
+
const label = this.iconName = getName(this.name, this.icon, this.mode, this.ios, this.md);
|
|
1300
|
+
if (!this.ariaLabel && this.ariaHidden !== 'true') {
|
|
1301
|
+
// user did not provide a label
|
|
1302
|
+
// come up with the label based on the icon name
|
|
1303
|
+
if (label) {
|
|
1304
|
+
this.ariaLabel = label.replace(/\-/g, ' ');
|
|
1305
|
+
}
|
|
1306
|
+
}
|
|
1307
|
+
}
|
|
1308
|
+
render() {
|
|
1309
|
+
const { iconName } = this;
|
|
1310
|
+
const mode = this.mode || 'md';
|
|
1311
|
+
const flipRtl = this.flipRtl ||
|
|
1312
|
+
(iconName &&
|
|
1313
|
+
(iconName.indexOf('arrow') > -1 || iconName.indexOf('chevron') > -1) &&
|
|
1314
|
+
this.flipRtl !== false);
|
|
1315
|
+
return (index.h(index.Host, { role: "img", class: Object.assign(Object.assign({ [mode]: true }, createColorClasses(this.color)), { [`icon-${this.size}`]: !!this.size, 'flip-rtl': !!flipRtl && this.el.ownerDocument.dir === 'rtl' }) }, this.svgContent ? (index.h("div", { class: "icon-inner", innerHTML: this.svgContent })) : (index.h("div", { class: "icon-inner" }))));
|
|
1316
|
+
}
|
|
1317
|
+
static get assetsDirs() { return ["svg"]; }
|
|
1318
|
+
get el() { return index.getElement(this); }
|
|
1319
|
+
static get watchers() { return {
|
|
1320
|
+
"name": ["loadIcon"],
|
|
1321
|
+
"src": ["loadIcon"],
|
|
1322
|
+
"icon": ["loadIcon"]
|
|
1323
|
+
}; }
|
|
1324
|
+
};
|
|
1325
|
+
const getIonMode = () => (typeof document !== 'undefined' && document.documentElement.getAttribute('mode')) || 'md';
|
|
1326
|
+
const createColorClasses = (color) => {
|
|
1327
|
+
return color
|
|
1328
|
+
? {
|
|
1329
|
+
'ion-color': true,
|
|
1330
|
+
[`ion-color-${color}`]: true,
|
|
1331
|
+
}
|
|
1332
|
+
: null;
|
|
1333
|
+
};
|
|
1334
|
+
Icon.style = iconCss;
|
|
1335
|
+
|
|
1336
|
+
const itemIosCss = ":host{--border-radius:0px;--border-width:0px;--border-style:solid;--padding-top:0px;--padding-bottom:0px;--padding-end:0px;--padding-start:0px;--inner-border-width:0px;--inner-padding-top:0px;--inner-padding-bottom:0px;--inner-padding-start:0px;--inner-padding-end:0px;--inner-box-shadow:none;--show-full-highlight:0;--show-inset-highlight:0;--detail-icon-color:initial;--detail-icon-font-size:20px;--detail-icon-opacity:0.25;--color-activated:var(--color);--color-focused:var(--color);--color-hover:var(--color);--ripple-color:currentColor;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;align-items:center;justify-content:space-between;outline:none;color:var(--color);font-family:var(--ion-font-family, inherit);text-align:initial;text-decoration:none;overflow:hidden;box-sizing:border-box}:host(.ion-color) .item-native{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.ion-color) .item-native,:host(.ion-color) .item-inner{border-color:var(--ion-color-shade)}:host(.ion-activated) .item-native{color:var(--color-activated)}:host(.ion-activated) .item-native::after{background:var(--background-activated);opacity:var(--background-activated-opacity)}:host(.ion-color.ion-activated) .item-native{color:var(--ion-color-contrast)}:host(.ion-focused) .item-native{color:var(--color-focused)}:host(.ion-focused) .item-native::after{background:var(--background-focused);opacity:var(--background-focused-opacity)}:host(.ion-color.ion-focused) .item-native{color:var(--ion-color-contrast)}:host(.ion-color.ion-focused) .item-native::after{background:var(--ion-color-contrast)}@media (any-hover: hover){:host(.ion-activatable:hover) .item-native{color:var(--color-hover)}:host(.ion-activatable:hover) .item-native::after{background:var(--background-hover);opacity:var(--background-hover-opacity)}:host(.ion-color.ion-activatable:hover) .item-native{color:var(--ion-color-contrast)}:host(.ion-color.ion-activatable:hover) .item-native::after{background:var(--ion-color-contrast)}}:host(.item-interactive-disabled:not(.item-multiple-inputs)){cursor:default;pointer-events:none}:host(.item-disabled){cursor:default;opacity:0.3;pointer-events:none}.item-native{border-radius:var(--border-radius);margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;display:flex;position:relative;align-items:inherit;justify-content:inherit;width:100%;min-height:var(--min-height);transition:var(--transition);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);outline:none;background:var(--background);overflow:inherit;box-sizing:border-box;z-index:1}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.item-native{padding-left:unset;padding-right:unset;-webkit-padding-start:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));padding-inline-start:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}.item-native::-moz-focus-inner{border:0}.item-native::after{left:0;right:0;top:0;bottom:0;position:absolute;content:\"\";opacity:0;transition:var(--transition);z-index:-1}button,a{cursor:pointer;user-select:none;-webkit-user-drag:none}.item-inner{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:var(--inner-padding-start);padding-right:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end));padding-top:var(--inner-padding-top);padding-bottom:var(--inner-padding-bottom);display:flex;position:relative;flex:1;flex-direction:inherit;align-items:inherit;align-self:stretch;min-height:inherit;border-width:var(--inner-border-width);border-style:var(--border-style);border-color:var(--border-color);box-shadow:var(--inner-box-shadow);overflow:inherit;box-sizing:border-box}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.item-inner{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--inner-padding-start);padding-inline-start:var(--inner-padding-start);-webkit-padding-end:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end));padding-inline-end:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end))}}.item-detail-icon{color:var(--detail-icon-color);font-size:var(--detail-icon-font-size);opacity:var(--detail-icon-opacity)}::slotted(ion-icon){font-size:1.6em}::slotted(ion-button){--margin-top:0;--margin-bottom:0;--margin-start:0;--margin-end:0;z-index:1}::slotted(ion-label:not([slot=end])){flex:1}:host(.item-input){align-items:center}.input-wrapper{display:flex;flex:1;flex-direction:inherit;align-items:inherit;align-self:stretch;text-overflow:ellipsis;overflow:inherit;box-sizing:border-box}:host(.item-label-stacked),:host(.item-label-floating){align-items:start}:host(.item-label-stacked) .input-wrapper,:host(.item-label-floating) .input-wrapper{flex:1;flex-direction:column}.item-highlight,.item-inner-highlight{left:0;right:0;bottom:0;position:absolute;background:var(--highlight-background);z-index:1}.item-highlight{height:var(--full-highlight-height)}.item-inner-highlight{height:var(--inset-highlight-height)}:host(.item-interactive.item-has-focus),:host(.item-interactive.ion-touched.ion-invalid){--full-highlight-height:calc(var(--highlight-height) * var(--show-full-highlight));--inset-highlight-height:calc(var(--highlight-height) * var(--show-inset-highlight))}:host(.item-interactive.item-has-focus){--highlight-background:var(--highlight-color-focused)}:host(.item-interactive.ion-valid){--highlight-background:var(--highlight-color-valid)}:host(.item-interactive.ion-invalid){--highlight-background:var(--highlight-color-invalid)}:host(:not(.item-label)) ::slotted(ion-select){--padding-start:0;max-width:none}:host(.item-label-stacked) ::slotted(ion-select),:host(.item-label-floating) ::slotted(ion-select){--padding-top:8px;--padding-bottom:8px;--padding-start:0;align-self:stretch;width:100%;max-width:100%}:host(:not(.item-label)) ::slotted(ion-datetime){--padding-start:0}:host(.item-label-stacked) ::slotted(ion-datetime),:host(.item-label-floating) ::slotted(ion-datetime){--padding-start:0;width:100%}:host(.item-multiple-inputs) ::slotted(ion-checkbox),:host(.item-multiple-inputs) ::slotted(ion-datetime),:host(.item-multiple-inputs) ::slotted(ion-radio),:host(.item-multiple-inputs) ::slotted(ion-select){position:relative}:host(.item-textarea){align-items:stretch}::slotted(ion-reorder[slot]){margin-top:0;margin-bottom:0}ion-ripple-effect{color:var(--ripple-color)}:host{--min-height:44px;--transition:background-color 200ms linear, opacity 200ms linear;--padding-start:20px;--inner-padding-end:10px;--inner-border-width:0px 0px 0.55px 0px;--background:var(--ion-item-background, var(--ion-background-color, #fff));--background-activated:#000;--background-focused:#000;--background-hover:currentColor;--background-activated-opacity:.12;--background-focused-opacity:.15;--background-hover-opacity:.04;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, #c8c7cc)));--color:var(--ion-item-color, var(--ion-text-color, #000));--highlight-height:0;--highlight-color-focused:var(--ion-color-primary, #3880ff);--highlight-color-valid:var(--ion-color-success, #2dd36f);--highlight-color-invalid:var(--ion-color-danger, #eb445a);font-size:17px}:host(.ion-activated){--transition:none}:host(.ion-color.ion-focused) .item-native::after{background:#000;opacity:0.15}:host(.ion-color.ion-activated) .item-native::after{background:#000;opacity:0.12}:host(.item-interactive){--show-full-highlight:0;--show-inset-highlight:1}:host(.item-lines-full){--border-width:0px 0px 0.55px 0px;--show-full-highlight:1;--show-inset-highlight:0}:host(.item-lines-inset){--inner-border-width:0px 0px 0.55px 0px;--show-full-highlight:0;--show-inset-highlight:1}:host(.item-lines-inset),:host(.item-lines-none){--border-width:0px;--show-full-highlight:0}:host(.item-lines-full),:host(.item-lines-none){--inner-border-width:0px;--show-inset-highlight:0}::slotted([slot=start]){margin-left:0;margin-right:20px;margin-top:2px;margin-bottom:2px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:20px;margin-inline-end:20px}}::slotted([slot=end]){margin-left:10px;margin-right:10px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px}}::slotted(ion-icon[slot=start]),::slotted(ion-icon[slot=end]){margin-top:7px;margin-bottom:7px}::slotted(ion-toggle[slot=start]),::slotted(ion-toggle[slot=end]){margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host(.item-label-stacked) ::slotted([slot=end]),:host(.item-label-floating) ::slotted([slot=end]){margin-top:7px;margin-bottom:7px}::slotted(.button-small){--padding-top:0px;--padding-bottom:0px;--padding-start:.5em;--padding-end:.5em;height:24px;font-size:13px}::slotted(ion-avatar){width:36px;height:36px}::slotted(ion-thumbnail){width:56px;height:56px}::slotted(ion-avatar[slot=end]),::slotted(ion-thumbnail[slot=end]){margin-left:10px;margin-right:10px;margin-top:10px;margin-bottom:10px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-avatar[slot=end]),::slotted(ion-thumbnail[slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px}}:host(.item-radio) ::slotted(ion-label),:host(.item-toggle) ::slotted(ion-label){margin-left:0px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host(.item-radio) ::slotted(ion-label),:host(.item-toggle) ::slotted(ion-label){margin-left:unset;-webkit-margin-start:0px;margin-inline-start:0px}}::slotted(ion-label){margin-left:0;margin-right:8px;margin-top:10px;margin-bottom:10px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-label){margin-left:unset;margin-right:unset;-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:8px;margin-inline-end:8px}}:host(.item-label-floating),:host(.item-label-stacked){--min-height:68px}:host(.item-label-stacked) ::slotted(ion-select),:host(.item-label-floating) ::slotted(ion-select){--padding-top:8px;--padding-bottom:8px;--padding-start:0px}:host(.item-label-fixed) ::slotted(ion-select),:host(.item-label-fixed) ::slotted(ion-datetime){--padding-start:0}";
|
|
1337
|
+
|
|
1338
|
+
const itemMdCss = ":host{--border-radius:0px;--border-width:0px;--border-style:solid;--padding-top:0px;--padding-bottom:0px;--padding-end:0px;--padding-start:0px;--inner-border-width:0px;--inner-padding-top:0px;--inner-padding-bottom:0px;--inner-padding-start:0px;--inner-padding-end:0px;--inner-box-shadow:none;--show-full-highlight:0;--show-inset-highlight:0;--detail-icon-color:initial;--detail-icon-font-size:20px;--detail-icon-opacity:0.25;--color-activated:var(--color);--color-focused:var(--color);--color-hover:var(--color);--ripple-color:currentColor;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;align-items:center;justify-content:space-between;outline:none;color:var(--color);font-family:var(--ion-font-family, inherit);text-align:initial;text-decoration:none;overflow:hidden;box-sizing:border-box}:host(.ion-color) .item-native{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.ion-color) .item-native,:host(.ion-color) .item-inner{border-color:var(--ion-color-shade)}:host(.ion-activated) .item-native{color:var(--color-activated)}:host(.ion-activated) .item-native::after{background:var(--background-activated);opacity:var(--background-activated-opacity)}:host(.ion-color.ion-activated) .item-native{color:var(--ion-color-contrast)}:host(.ion-focused) .item-native{color:var(--color-focused)}:host(.ion-focused) .item-native::after{background:var(--background-focused);opacity:var(--background-focused-opacity)}:host(.ion-color.ion-focused) .item-native{color:var(--ion-color-contrast)}:host(.ion-color.ion-focused) .item-native::after{background:var(--ion-color-contrast)}@media (any-hover: hover){:host(.ion-activatable:hover) .item-native{color:var(--color-hover)}:host(.ion-activatable:hover) .item-native::after{background:var(--background-hover);opacity:var(--background-hover-opacity)}:host(.ion-color.ion-activatable:hover) .item-native{color:var(--ion-color-contrast)}:host(.ion-color.ion-activatable:hover) .item-native::after{background:var(--ion-color-contrast)}}:host(.item-interactive-disabled:not(.item-multiple-inputs)){cursor:default;pointer-events:none}:host(.item-disabled){cursor:default;opacity:0.3;pointer-events:none}.item-native{border-radius:var(--border-radius);margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;display:flex;position:relative;align-items:inherit;justify-content:inherit;width:100%;min-height:var(--min-height);transition:var(--transition);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);outline:none;background:var(--background);overflow:inherit;box-sizing:border-box;z-index:1}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.item-native{padding-left:unset;padding-right:unset;-webkit-padding-start:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));padding-inline-start:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}.item-native::-moz-focus-inner{border:0}.item-native::after{left:0;right:0;top:0;bottom:0;position:absolute;content:\"\";opacity:0;transition:var(--transition);z-index:-1}button,a{cursor:pointer;user-select:none;-webkit-user-drag:none}.item-inner{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:var(--inner-padding-start);padding-right:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end));padding-top:var(--inner-padding-top);padding-bottom:var(--inner-padding-bottom);display:flex;position:relative;flex:1;flex-direction:inherit;align-items:inherit;align-self:stretch;min-height:inherit;border-width:var(--inner-border-width);border-style:var(--border-style);border-color:var(--border-color);box-shadow:var(--inner-box-shadow);overflow:inherit;box-sizing:border-box}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.item-inner{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--inner-padding-start);padding-inline-start:var(--inner-padding-start);-webkit-padding-end:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end));padding-inline-end:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end))}}.item-detail-icon{color:var(--detail-icon-color);font-size:var(--detail-icon-font-size);opacity:var(--detail-icon-opacity)}::slotted(ion-icon){font-size:1.6em}::slotted(ion-button){--margin-top:0;--margin-bottom:0;--margin-start:0;--margin-end:0;z-index:1}::slotted(ion-label:not([slot=end])){flex:1}:host(.item-input){align-items:center}.input-wrapper{display:flex;flex:1;flex-direction:inherit;align-items:inherit;align-self:stretch;text-overflow:ellipsis;overflow:inherit;box-sizing:border-box}:host(.item-label-stacked),:host(.item-label-floating){align-items:start}:host(.item-label-stacked) .input-wrapper,:host(.item-label-floating) .input-wrapper{flex:1;flex-direction:column}.item-highlight,.item-inner-highlight{left:0;right:0;bottom:0;position:absolute;background:var(--highlight-background);z-index:1}.item-highlight{height:var(--full-highlight-height)}.item-inner-highlight{height:var(--inset-highlight-height)}:host(.item-interactive.item-has-focus),:host(.item-interactive.ion-touched.ion-invalid){--full-highlight-height:calc(var(--highlight-height) * var(--show-full-highlight));--inset-highlight-height:calc(var(--highlight-height) * var(--show-inset-highlight))}:host(.item-interactive.item-has-focus){--highlight-background:var(--highlight-color-focused)}:host(.item-interactive.ion-valid){--highlight-background:var(--highlight-color-valid)}:host(.item-interactive.ion-invalid){--highlight-background:var(--highlight-color-invalid)}:host(:not(.item-label)) ::slotted(ion-select){--padding-start:0;max-width:none}:host(.item-label-stacked) ::slotted(ion-select),:host(.item-label-floating) ::slotted(ion-select){--padding-top:8px;--padding-bottom:8px;--padding-start:0;align-self:stretch;width:100%;max-width:100%}:host(:not(.item-label)) ::slotted(ion-datetime){--padding-start:0}:host(.item-label-stacked) ::slotted(ion-datetime),:host(.item-label-floating) ::slotted(ion-datetime){--padding-start:0;width:100%}:host(.item-multiple-inputs) ::slotted(ion-checkbox),:host(.item-multiple-inputs) ::slotted(ion-datetime),:host(.item-multiple-inputs) ::slotted(ion-radio),:host(.item-multiple-inputs) ::slotted(ion-select){position:relative}:host(.item-textarea){align-items:stretch}::slotted(ion-reorder[slot]){margin-top:0;margin-bottom:0}ion-ripple-effect{color:var(--ripple-color)}:host{--min-height:48px;--background:var(--ion-item-background, var(--ion-background-color, #fff));--background-activated:transparent;--background-focused:currentColor;--background-hover:currentColor;--background-activated-opacity:0;--background-focused-opacity:.12;--background-hover-opacity:.04;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));--color:var(--ion-item-color, var(--ion-text-color, #000));--transition:opacity 15ms linear, background-color 15ms linear;--padding-start:16px;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));--inner-padding-end:16px;--inner-border-width:0 0 1px 0;--highlight-height:2px;--highlight-color-focused:var(--ion-color-primary, #3880ff);--highlight-color-valid:var(--ion-color-success, #2dd36f);--highlight-color-invalid:var(--ion-color-danger, #eb445a);font-size:16px;font-weight:normal;text-transform:none}:host(.ion-color.ion-activated) .item-native::after{background:transparent}:host(.item-interactive){--border-width:0 0 1px 0;--inner-border-width:0;--show-full-highlight:1;--show-inset-highlight:0}:host(.item-lines-full){--border-width:0 0 1px 0;--show-full-highlight:1;--show-inset-highlight:0}:host(.item-lines-inset){--inner-border-width:0 0 1px 0;--show-full-highlight:0;--show-inset-highlight:1}:host(.item-lines-inset),:host(.item-lines-none){--border-width:0;--show-full-highlight:0}:host(.item-lines-full),:host(.item-lines-none){--inner-border-width:0;--show-inset-highlight:0}:host(.item-multi-line) ::slotted([slot=start]),:host(.item-multi-line) ::slotted([slot=end]){margin-top:16px;margin-bottom:16px;align-self:flex-start}::slotted([slot=start]){margin-right:32px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=start]){margin-right:unset;-webkit-margin-end:32px;margin-inline-end:32px}}::slotted([slot=end]){margin-left:32px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=end]){margin-left:unset;-webkit-margin-start:32px;margin-inline-start:32px}}::slotted(ion-icon){color:rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.54);font-size:24px}:host(.ion-color) ::slotted(ion-icon){color:var(--ion-color-contrast)}::slotted(ion-icon[slot]){margin-top:12px;margin-bottom:12px}::slotted(ion-icon[slot=start]){margin-right:32px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=start]){margin-right:unset;-webkit-margin-end:32px;margin-inline-end:32px}}::slotted(ion-icon[slot=end]){margin-left:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=end]){margin-left:unset;-webkit-margin-start:16px;margin-inline-start:16px}}::slotted(ion-toggle[slot=start]),::slotted(ion-toggle[slot=end]){margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}::slotted(ion-note){margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;align-self:flex-start;font-size:11px}::slotted(ion-note[slot]){padding-left:0;padding-right:0;padding-top:18px;padding-bottom:10px}::slotted(ion-note[slot=start]){padding-right:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-note[slot=start]){padding-right:unset;-webkit-padding-end:16px;padding-inline-end:16px}}::slotted(ion-note[slot=end]){padding-left:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-note[slot=end]){padding-left:unset;-webkit-padding-start:16px;padding-inline-start:16px}}::slotted(ion-avatar){width:40px;height:40px}::slotted(ion-thumbnail){width:56px;height:56px}::slotted(ion-avatar),::slotted(ion-thumbnail){margin-top:8px;margin-bottom:8px}::slotted(ion-avatar[slot=start]),::slotted(ion-thumbnail[slot=start]){margin-right:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-avatar[slot=start]),::slotted(ion-thumbnail[slot=start]){margin-right:unset;-webkit-margin-end:16px;margin-inline-end:16px}}::slotted(ion-avatar[slot=end]),::slotted(ion-thumbnail[slot=end]){margin-left:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-avatar[slot=end]),::slotted(ion-thumbnail[slot=end]){margin-left:unset;-webkit-margin-start:16px;margin-inline-start:16px}}::slotted(ion-label){margin-left:0;margin-right:0;margin-top:11px;margin-bottom:10px}:host(.item-label-stacked) ::slotted([slot=end]),:host(.item-label-floating) ::slotted([slot=end]){margin-top:7px;margin-bottom:7px}:host(.item-label-fixed) ::slotted(ion-select),:host(.item-label-fixed) ::slotted(ion-datetime){--padding-start:8px}:host(.item-toggle) ::slotted(ion-label),:host(.item-radio) ::slotted(ion-label){margin-left:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host(.item-toggle) ::slotted(ion-label),:host(.item-radio) ::slotted(ion-label){margin-left:unset;-webkit-margin-start:0;margin-inline-start:0}}::slotted(.button-small){--padding-top:0;--padding-bottom:0;--padding-start:.6em;--padding-end:.6em;height:25px;font-size:12px}:host(.item-label-floating),:host(.item-label-stacked){--min-height:55px}:host(.item-label-stacked) ::slotted(ion-select),:host(.item-label-floating) ::slotted(ion-select){--padding-top:8px;--padding-bottom:8px;--padding-start:0}:host(.item-has-focus:not(.ion-color)) ::slotted(.label-stacked),:host(.item-has-focus:not(.ion-color)) ::slotted(.label-floating){color:var(--ion-color-primary, #3880ff)}:host(.ion-color){--highlight-color-focused:var(--ion-color-contrast)}:host(.item-label-color){--highlight-color-focused:var(--ion-color-base)}";
|
|
1339
|
+
|
|
1340
|
+
const Item = class {
|
|
1341
|
+
constructor(hostRef) {
|
|
1342
|
+
index.registerInstance(this, hostRef);
|
|
1343
|
+
this.labelColorStyles = {};
|
|
1344
|
+
this.itemStyles = new Map();
|
|
1345
|
+
this.multipleInputs = false;
|
|
1346
|
+
/**
|
|
1347
|
+
* If `true`, a button tag will be rendered and the item will be tappable.
|
|
1348
|
+
*/
|
|
1349
|
+
this.button = false;
|
|
1350
|
+
/**
|
|
1351
|
+
* The icon to use when `detail` is set to `true`.
|
|
1352
|
+
*/
|
|
1353
|
+
this.detailIcon = 'chevron-forward';
|
|
1354
|
+
/**
|
|
1355
|
+
* If `true`, the user cannot interact with the item.
|
|
1356
|
+
*/
|
|
1357
|
+
this.disabled = false;
|
|
1358
|
+
/**
|
|
1359
|
+
* When using a router, it specifies the transition direction when navigating to
|
|
1360
|
+
* another page using `href`.
|
|
1361
|
+
*/
|
|
1362
|
+
this.routerDirection = 'forward';
|
|
1363
|
+
/**
|
|
1364
|
+
* The type of the button. Only used when an `onclick` or `button` property is present.
|
|
1365
|
+
*/
|
|
1366
|
+
this.type = 'button';
|
|
1367
|
+
}
|
|
1368
|
+
labelColorChanged(ev) {
|
|
1369
|
+
const { color } = this;
|
|
1370
|
+
// There will be a conflict with item color if
|
|
1371
|
+
// we apply the label color to item, so we ignore
|
|
1372
|
+
// the label color if the user sets a color on item
|
|
1373
|
+
if (color === undefined) {
|
|
1374
|
+
this.labelColorStyles = ev.detail;
|
|
1375
|
+
}
|
|
1376
|
+
}
|
|
1377
|
+
itemStyle(ev) {
|
|
1378
|
+
ev.stopPropagation();
|
|
1379
|
+
const tagName = ev.target.tagName;
|
|
1380
|
+
const updatedStyles = ev.detail;
|
|
1381
|
+
const newStyles = {};
|
|
1382
|
+
const childStyles = this.itemStyles.get(tagName) || {};
|
|
1383
|
+
let hasStyleChange = false;
|
|
1384
|
+
Object.keys(updatedStyles).forEach(key => {
|
|
1385
|
+
if (updatedStyles[key]) {
|
|
1386
|
+
const itemKey = `item-${key}`;
|
|
1387
|
+
if (!childStyles[itemKey]) {
|
|
1388
|
+
hasStyleChange = true;
|
|
1389
|
+
}
|
|
1390
|
+
newStyles[itemKey] = true;
|
|
1391
|
+
}
|
|
1392
|
+
});
|
|
1393
|
+
if (!hasStyleChange && Object.keys(newStyles).length !== Object.keys(childStyles).length) {
|
|
1394
|
+
hasStyleChange = true;
|
|
1395
|
+
}
|
|
1396
|
+
if (hasStyleChange) {
|
|
1397
|
+
this.itemStyles.set(tagName, newStyles);
|
|
1398
|
+
index.forceUpdate(this);
|
|
1399
|
+
}
|
|
1400
|
+
}
|
|
1401
|
+
componentDidUpdate() {
|
|
1402
|
+
// Do not use @Listen here to avoid making all items
|
|
1403
|
+
// appear as clickable to screen readers
|
|
1404
|
+
// https://github.com/ionic-team/ionic-framework/issues/22011
|
|
1405
|
+
const input = this.getFirstInput();
|
|
1406
|
+
if (input && !this.clickListener) {
|
|
1407
|
+
this.clickListener = (ev) => this.delegateFocus(ev, input);
|
|
1408
|
+
this.el.addEventListener('click', this.clickListener);
|
|
1409
|
+
}
|
|
1410
|
+
}
|
|
1411
|
+
disconnectedCallback() {
|
|
1412
|
+
const input = this.getFirstInput();
|
|
1413
|
+
if (input && this.clickListener) {
|
|
1414
|
+
this.el.removeEventListener('click', this.clickListener);
|
|
1415
|
+
this.clickListener = undefined;
|
|
1416
|
+
}
|
|
1417
|
+
}
|
|
1418
|
+
componentDidLoad() {
|
|
1419
|
+
helpers.raf(() => this.setMultipleInputs());
|
|
1420
|
+
}
|
|
1421
|
+
// If the item contains multiple clickable elements and/or inputs, then the item
|
|
1422
|
+
// should not have a clickable input cover over the entire item to prevent
|
|
1423
|
+
// interfering with their individual click events
|
|
1424
|
+
setMultipleInputs() {
|
|
1425
|
+
// The following elements have a clickable cover that is relative to the entire item
|
|
1426
|
+
const covers = this.el.querySelectorAll('ion-checkbox, ion-datetime, ion-select, ion-radio');
|
|
1427
|
+
// The following elements can accept focus alongside the previous elements
|
|
1428
|
+
// therefore if these elements are also a child of item, we don't want the
|
|
1429
|
+
// input cover on top of those interfering with their clicks
|
|
1430
|
+
const inputs = this.el.querySelectorAll('ion-input, ion-range, ion-searchbar, ion-segment, ion-textarea, ion-toggle');
|
|
1431
|
+
// The following elements should also stay clickable when an input with cover is present
|
|
1432
|
+
const clickables = this.el.querySelectorAll('ion-anchor, ion-button, a, button');
|
|
1433
|
+
// Check for multiple inputs to change the position of the input cover to relative
|
|
1434
|
+
// for all of the covered inputs above
|
|
1435
|
+
this.multipleInputs = covers.length + inputs.length > 1
|
|
1436
|
+
|| covers.length + clickables.length > 1
|
|
1437
|
+
|| covers.length > 0 && this.isClickable();
|
|
1438
|
+
}
|
|
1439
|
+
// If the item contains an input including a checkbox, datetime, select, or radio
|
|
1440
|
+
// then the item will have a clickable input cover that covers the item
|
|
1441
|
+
// that should get the hover, focused and activated states UNLESS it has multiple
|
|
1442
|
+
// inputs, then those need to individually get each click
|
|
1443
|
+
hasCover() {
|
|
1444
|
+
const inputs = this.el.querySelectorAll('ion-checkbox, ion-datetime, ion-select, ion-radio');
|
|
1445
|
+
return inputs.length === 1 && !this.multipleInputs;
|
|
1446
|
+
}
|
|
1447
|
+
// If the item has an href or button property it will render a native
|
|
1448
|
+
// anchor or button that is clickable
|
|
1449
|
+
isClickable() {
|
|
1450
|
+
return (this.href !== undefined || this.button);
|
|
1451
|
+
}
|
|
1452
|
+
canActivate() {
|
|
1453
|
+
return (this.isClickable() || this.hasCover());
|
|
1454
|
+
}
|
|
1455
|
+
getFirstInput() {
|
|
1456
|
+
const inputs = this.el.querySelectorAll('ion-input, ion-textarea');
|
|
1457
|
+
return inputs[0];
|
|
1458
|
+
}
|
|
1459
|
+
// This is needed for WebKit due to a delegatesFocus bug where
|
|
1460
|
+
// clicking on the left padding of an item is not focusing the input
|
|
1461
|
+
// but is opening the keyboard. It will no longer be needed with
|
|
1462
|
+
// iOS 14.
|
|
1463
|
+
delegateFocus(ev, input) {
|
|
1464
|
+
const clickedItem = ev.target.tagName === 'ION-ITEM';
|
|
1465
|
+
let firstActive = false;
|
|
1466
|
+
// If the first input is the same as the active element we need
|
|
1467
|
+
// to focus the first input again, but if the active element
|
|
1468
|
+
// is another input inside of the item we shouldn't switch focus
|
|
1469
|
+
if (document.activeElement) {
|
|
1470
|
+
firstActive = input.querySelector('input, textarea') === document.activeElement;
|
|
1471
|
+
}
|
|
1472
|
+
// Only focus the first input if we clicked on an ion-item
|
|
1473
|
+
// and the first input exists
|
|
1474
|
+
if (clickedItem && firstActive) {
|
|
1475
|
+
input.fireFocusEvents = false;
|
|
1476
|
+
input.setBlur();
|
|
1477
|
+
input.setFocus();
|
|
1478
|
+
helpers.raf(() => {
|
|
1479
|
+
input.fireFocusEvents = true;
|
|
1480
|
+
});
|
|
1481
|
+
}
|
|
1482
|
+
}
|
|
1483
|
+
render() {
|
|
1484
|
+
const { detail, detailIcon, download, labelColorStyles, lines, disabled, href, rel, target, routerAnimation, routerDirection } = this;
|
|
1485
|
+
const childStyles = {};
|
|
1486
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1487
|
+
const clickable = this.isClickable();
|
|
1488
|
+
const canActivate = this.canActivate();
|
|
1489
|
+
const TagType = clickable ? (href === undefined ? 'button' : 'a') : 'div';
|
|
1490
|
+
const attrs = (TagType === 'button')
|
|
1491
|
+
? { type: this.type }
|
|
1492
|
+
: {
|
|
1493
|
+
download,
|
|
1494
|
+
href,
|
|
1495
|
+
rel,
|
|
1496
|
+
target
|
|
1497
|
+
};
|
|
1498
|
+
// Only set onClick if the item is clickable to prevent screen
|
|
1499
|
+
// readers from reading all items as clickable
|
|
1500
|
+
const clickFn = clickable ? {
|
|
1501
|
+
onClick: (ev) => { theme.openURL(href, ev, routerDirection, routerAnimation); }
|
|
1502
|
+
} : {};
|
|
1503
|
+
const showDetail = detail !== undefined ? detail : mode === 'ios' && clickable;
|
|
1504
|
+
this.itemStyles.forEach(value => {
|
|
1505
|
+
Object.assign(childStyles, value);
|
|
1506
|
+
});
|
|
1507
|
+
const ariaDisabled = (disabled || childStyles['item-interactive-disabled']) ? 'true' : null;
|
|
1508
|
+
return (index.h(index.Host, { "aria-disabled": ariaDisabled, class: Object.assign(Object.assign(Object.assign({}, childStyles), labelColorStyles), theme.createColorClasses(this.color, {
|
|
1509
|
+
'item': true,
|
|
1510
|
+
[mode]: true,
|
|
1511
|
+
[`item-lines-${lines}`]: lines !== undefined,
|
|
1512
|
+
'item-disabled': disabled,
|
|
1513
|
+
'in-list': theme.hostContext('ion-list', this.el),
|
|
1514
|
+
'item-multiple-inputs': this.multipleInputs,
|
|
1515
|
+
'ion-activatable': canActivate,
|
|
1516
|
+
'ion-focusable': true,
|
|
1517
|
+
})) }, index.h(TagType, Object.assign({}, attrs, { class: "item-native", part: "native", disabled: disabled }, clickFn), index.h("slot", { name: "start" }), index.h("div", { class: "item-inner" }, index.h("div", { class: "input-wrapper" }, index.h("slot", null)), index.h("slot", { name: "end" }), showDetail && index.h("ion-icon", { icon: detailIcon, lazy: false, class: "item-detail-icon", part: "detail-icon", "aria-hidden": "true" }), index.h("div", { class: "item-inner-highlight" })), canActivate && mode === 'md' && index.h("ion-ripple-effect", null)), index.h("div", { class: "item-highlight" })));
|
|
1518
|
+
}
|
|
1519
|
+
static get delegatesFocus() { return true; }
|
|
1520
|
+
get el() { return index.getElement(this); }
|
|
1521
|
+
};
|
|
1522
|
+
Item.style = {
|
|
1523
|
+
ios: itemIosCss,
|
|
1524
|
+
md: itemMdCss
|
|
1525
|
+
};
|
|
1526
|
+
|
|
1527
|
+
const itemDividerIosCss = ":host{--padding-top:0px;--padding-end:0px;--padding-bottom:0px;--padding-start:0px;--inner-padding-top:0px;--inner-padding-end:0px;--inner-padding-bottom:0px;--inner-padding-start:0px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--background);color:var(--color);font-family:var(--ion-font-family, inherit);overflow:hidden;z-index:100;box-sizing:border-box}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));padding-inline-start:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.item-divider-sticky){position:sticky;top:0}.item-divider-inner{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:var(--inner-padding-start);padding-right:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end));padding-top:var(--inner-padding-top);padding-bottom:var(--inner-padding-bottom);display:flex;flex:1;flex-direction:inherit;align-items:inherit;align-self:stretch;min-height:inherit;border:0;overflow:hidden}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.item-divider-inner{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--inner-padding-start);padding-inline-start:var(--inner-padding-start);-webkit-padding-end:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end));padding-inline-end:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end))}}.item-divider-wrapper{display:flex;flex:1;flex-direction:inherit;align-items:inherit;align-self:stretch;text-overflow:ellipsis;overflow:hidden}:host{--background:var(--ion-color-step-100, #e6e6e6);--color:var(--ion-color-step-850, #262626);--padding-start:20px;--inner-padding-end:10px;border-radius:0;position:relative;min-height:28px;font-size:17px;font-weight:600}:host([slot=start]){margin-left:0;margin-right:20px;margin-top:2px;margin-bottom:2px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host([slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:20px;margin-inline-end:20px}}:host([slot=end]){margin-left:10px;margin-right:10px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host([slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px}}::slotted(ion-icon[slot=start]),::slotted(ion-icon[slot=end]){margin-top:7px;margin-bottom:7px}::slotted(h1){margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:24px;font-weight:normal}::slotted(h2){margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:17px;font-weight:normal}::slotted(h3),::slotted(h4),::slotted(h5),::slotted(h6){margin-left:0;margin-right:0;margin-top:0;margin-bottom:3px;font-size:14px;font-weight:normal;line-height:normal}::slotted(p){margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;color:rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.4);font-size:14px;line-height:normal;text-overflow:inherit;overflow:inherit}::slotted(h2:last-child) ::slotted(h3:last-child),::slotted(h4:last-child),::slotted(h5:last-child),::slotted(h6:last-child),::slotted(p:last-child){margin-bottom:0}";
|
|
1528
|
+
|
|
1529
|
+
const itemDividerMdCss = ":host{--padding-top:0px;--padding-end:0px;--padding-bottom:0px;--padding-start:0px;--inner-padding-top:0px;--inner-padding-end:0px;--inner-padding-bottom:0px;--inner-padding-start:0px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--background);color:var(--color);font-family:var(--ion-font-family, inherit);overflow:hidden;z-index:100;box-sizing:border-box}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));padding-inline-start:calc(var(--padding-start) + var(--ion-safe-area-left, 0px));-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.item-divider-sticky){position:sticky;top:0}.item-divider-inner{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:var(--inner-padding-start);padding-right:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end));padding-top:var(--inner-padding-top);padding-bottom:var(--inner-padding-bottom);display:flex;flex:1;flex-direction:inherit;align-items:inherit;align-self:stretch;min-height:inherit;border:0;overflow:hidden}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.item-divider-inner{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--inner-padding-start);padding-inline-start:var(--inner-padding-start);-webkit-padding-end:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end));padding-inline-end:calc(var(--ion-safe-area-right, 0px) + var(--inner-padding-end))}}.item-divider-wrapper{display:flex;flex:1;flex-direction:inherit;align-items:inherit;align-self:stretch;text-overflow:ellipsis;overflow:hidden}:host{--background:var(--ion-background-color, #fff);--color:var(--ion-color-step-400, #999999);--padding-start:16px;--inner-padding-end:0;min-height:30px;border-bottom:1px solid var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));font-size:14px}::slotted([slot=start]){margin-right:32px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=start]){margin-right:unset;-webkit-margin-end:32px;margin-inline-end:32px}}::slotted([slot=end]){margin-left:32px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=end]){margin-left:unset;-webkit-margin-start:32px;margin-inline-start:32px}}::slotted(ion-label){margin-left:0;margin-right:0;margin-top:13px;margin-bottom:10px}::slotted(ion-icon){color:rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.54);font-size:24px}:host(.ion-color) ::slotted(ion-icon){color:var(--ion-color-contrast)}::slotted(ion-icon[slot]){margin-top:12px;margin-bottom:12px}::slotted(ion-icon[slot=start]){margin-right:32px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=start]){margin-right:unset;-webkit-margin-end:32px;margin-inline-end:32px}}::slotted(ion-icon[slot=end]){margin-left:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-icon[slot=end]){margin-left:unset;-webkit-margin-start:16px;margin-inline-start:16px}}::slotted(ion-note){margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;align-self:flex-start;font-size:11px}::slotted(ion-note[slot]){padding-left:0;padding-right:0;padding-top:18px;padding-bottom:10px}::slotted(ion-note[slot=start]){padding-right:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-note[slot=start]){padding-right:unset;-webkit-padding-end:16px;padding-inline-end:16px}}::slotted(ion-note[slot=end]){padding-left:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-note[slot=end]){padding-left:unset;-webkit-padding-start:16px;padding-inline-start:16px}}::slotted(ion-avatar){width:40px;height:40px}::slotted(ion-thumbnail){width:56px;height:56px}::slotted(ion-avatar),::slotted(ion-thumbnail){margin-top:8px;margin-bottom:8px}::slotted(ion-avatar[slot=start]),::slotted(ion-thumbnail[slot=start]){margin-right:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-avatar[slot=start]),::slotted(ion-thumbnail[slot=start]){margin-right:unset;-webkit-margin-end:16px;margin-inline-end:16px}}::slotted(ion-avatar[slot=end]),::slotted(ion-thumbnail[slot=end]){margin-left:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(ion-avatar[slot=end]),::slotted(ion-thumbnail[slot=end]){margin-left:unset;-webkit-margin-start:16px;margin-inline-start:16px}}::slotted(h1){margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:24px;font-weight:normal}::slotted(h2){margin-left:0;margin-right:0;margin-top:2px;margin-bottom:2px;font-size:16px;font-weight:normal}::slotted(h3,h4,h5,h6){margin-left:0;margin-right:0;margin-top:2px;margin-bottom:2px;font-size:14px;font-weight:normal;line-height:normal}::slotted(p){margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;color:var(--ion-color-step-600, #666666);font-size:14px;line-height:normal;text-overflow:inherit;overflow:inherit}";
|
|
1530
|
+
|
|
1531
|
+
const ItemDivider = class {
|
|
1532
|
+
constructor(hostRef) {
|
|
1533
|
+
index.registerInstance(this, hostRef);
|
|
1534
|
+
/**
|
|
1535
|
+
* When it's set to `true`, the item-divider will stay visible when it reaches the top
|
|
1536
|
+
* of the viewport until the next `ion-item-divider` replaces it.
|
|
1537
|
+
*
|
|
1538
|
+
* This feature relies in `position:sticky`:
|
|
1539
|
+
* https://caniuse.com/#feat=css-sticky
|
|
1540
|
+
*/
|
|
1541
|
+
this.sticky = false;
|
|
1542
|
+
}
|
|
1543
|
+
render() {
|
|
1544
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1545
|
+
return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
|
|
1546
|
+
[mode]: true,
|
|
1547
|
+
'item-divider-sticky': this.sticky,
|
|
1548
|
+
'item': true,
|
|
1549
|
+
}) }, index.h("slot", { name: "start" }), index.h("div", { class: "item-divider-inner" }, index.h("div", { class: "item-divider-wrapper" }, index.h("slot", null)), index.h("slot", { name: "end" }))));
|
|
1550
|
+
}
|
|
1551
|
+
get el() { return index.getElement(this); }
|
|
1552
|
+
};
|
|
1553
|
+
ItemDivider.style = {
|
|
1554
|
+
ios: itemDividerIosCss,
|
|
1555
|
+
md: itemDividerMdCss
|
|
1556
|
+
};
|
|
1557
|
+
|
|
1558
|
+
const itemGroupIosCss = "ion-item-group{display:block}";
|
|
1559
|
+
|
|
1560
|
+
const itemGroupMdCss = "ion-item-group{display:block}";
|
|
1561
|
+
|
|
1562
|
+
const ItemGroup = class {
|
|
1563
|
+
constructor(hostRef) {
|
|
1564
|
+
index.registerInstance(this, hostRef);
|
|
1565
|
+
}
|
|
1566
|
+
render() {
|
|
1567
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1568
|
+
return (index.h(index.Host, { role: "group", class: {
|
|
1569
|
+
[mode]: true,
|
|
1570
|
+
// Used internally for styling
|
|
1571
|
+
[`item-group-${mode}`]: true,
|
|
1572
|
+
'item': true
|
|
1573
|
+
} }));
|
|
1574
|
+
}
|
|
1575
|
+
};
|
|
1576
|
+
ItemGroup.style = {
|
|
1577
|
+
ios: itemGroupIosCss,
|
|
1578
|
+
md: itemGroupMdCss
|
|
1579
|
+
};
|
|
1580
|
+
|
|
1581
|
+
const labelIosCss = ".item.sc-ion-label-ios-h,.item .sc-ion-label-ios-h{--color:initial;display:block;color:var(--color);font-family:var(--ion-font-family, inherit);font-size:inherit;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;box-sizing:border-box}.ion-color.sc-ion-label-ios-h{color:var(--ion-color-base)}.ion-text-wrap.sc-ion-label-ios-h,[text-wrap].sc-ion-label-ios-h{white-space:normal}.item-interactive-disabled.sc-ion-label-ios-h:not(.item-multiple-inputs),.item-interactive-disabled:not(.item-multiple-inputs) .sc-ion-label-ios-h{cursor:default;opacity:0.3;pointer-events:none}.item-input.sc-ion-label-ios-h,.item-input .sc-ion-label-ios-h{flex:initial;max-width:200px;pointer-events:none}.item-textarea.sc-ion-label-ios-h,.item-textarea .sc-ion-label-ios-h{align-self:baseline}.label-fixed.sc-ion-label-ios-h{flex:0 0 100px;width:100px;min-width:100px;max-width:200px}.label-stacked.sc-ion-label-ios-h,.label-floating.sc-ion-label-ios-h{margin-bottom:0;align-self:stretch;width:auto;max-width:100%}.label-no-animate.label-floating.sc-ion-label-ios-h{transition:none}.sc-ion-label-ios-s h1,.sc-ion-label-ios-s h2,.sc-ion-label-ios-s h3,.sc-ion-label-ios-s h4,.sc-ion-label-ios-s h5,.sc-ion-label-ios-s h6{text-overflow:inherit;overflow:inherit}.ion-text-wrap.sc-ion-label-ios-h,[text-wrap].sc-ion-label-ios-h{font-size:14px;line-height:1.5}.label-stacked.sc-ion-label-ios-h{margin-bottom:4px;font-size:14px}.label-floating.sc-ion-label-ios-h{margin-bottom:0;transform:translate3d(0, 29px, 0);transform-origin:left top;transition:transform 150ms ease-in-out}[dir=rtl].sc-ion-label-ios-h -no-combinator.label-floating.sc-ion-label-ios-h,[dir=rtl] .sc-ion-label-ios-h -no-combinator.label-floating.sc-ion-label-ios-h,[dir=rtl].label-floating.sc-ion-label-ios-h,[dir=rtl] .label-floating.sc-ion-label-ios-h{transform-origin:right top}.item-textarea.label-floating.sc-ion-label-ios-h,.item-textarea .label-floating.sc-ion-label-ios-h{transform:translate3d(0, 28px, 0)}.item-has-focus.label-floating.sc-ion-label-ios-h,.item-has-focus .label-floating.sc-ion-label-ios-h,.item-has-placeholder.sc-ion-label-ios-h:not(.item-input).label-floating,.item-has-placeholder:not(.item-input) .label-floating.sc-ion-label-ios-h,.item-has-value.label-floating.sc-ion-label-ios-h,.item-has-value .label-floating.sc-ion-label-ios-h{transform:translate3d(0, 0, 0) scale(0.82)}.sc-ion-label-ios-s h1{margin-left:0;margin-right:0;margin-top:3px;margin-bottom:2px;font-size:22px;font-weight:normal}.sc-ion-label-ios-s h2{margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:17px;font-weight:normal}.sc-ion-label-ios-s h3,.sc-ion-label-ios-s h4,.sc-ion-label-ios-s h5,.sc-ion-label-ios-s h6{margin-left:0;margin-right:0;margin-top:0;margin-bottom:3px;font-size:14px;font-weight:normal;line-height:normal}.sc-ion-label-ios-s p{margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:14px;line-height:normal;text-overflow:inherit;overflow:inherit}.sc-ion-label-ios-s>p{color:rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.4)}.sc-ion-label-ios-h.in-item-color.sc-ion-label-ios-s>p{color:inherit}.sc-ion-label-ios-s h2:last-child,.sc-ion-label-ios-s h3:last-child,.sc-ion-label-ios-s h4:last-child,.sc-ion-label-ios-s h5:last-child,.sc-ion-label-ios-s h6:last-child,.sc-ion-label-ios-s p:last-child{margin-bottom:0}";
|
|
1582
|
+
|
|
1583
|
+
const labelMdCss = ".item.sc-ion-label-md-h,.item .sc-ion-label-md-h{--color:initial;display:block;color:var(--color);font-family:var(--ion-font-family, inherit);font-size:inherit;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;box-sizing:border-box}.ion-color.sc-ion-label-md-h{color:var(--ion-color-base)}.ion-text-wrap.sc-ion-label-md-h,[text-wrap].sc-ion-label-md-h{white-space:normal}.item-interactive-disabled.sc-ion-label-md-h:not(.item-multiple-inputs),.item-interactive-disabled:not(.item-multiple-inputs) .sc-ion-label-md-h{cursor:default;opacity:0.3;pointer-events:none}.item-input.sc-ion-label-md-h,.item-input .sc-ion-label-md-h{flex:initial;max-width:200px;pointer-events:none}.item-textarea.sc-ion-label-md-h,.item-textarea .sc-ion-label-md-h{align-self:baseline}.label-fixed.sc-ion-label-md-h{flex:0 0 100px;width:100px;min-width:100px;max-width:200px}.label-stacked.sc-ion-label-md-h,.label-floating.sc-ion-label-md-h{margin-bottom:0;align-self:stretch;width:auto;max-width:100%}.label-no-animate.label-floating.sc-ion-label-md-h{transition:none}.sc-ion-label-md-s h1,.sc-ion-label-md-s h2,.sc-ion-label-md-s h3,.sc-ion-label-md-s h4,.sc-ion-label-md-s h5,.sc-ion-label-md-s h6{text-overflow:inherit;overflow:inherit}.ion-text-wrap.sc-ion-label-md-h,[text-wrap].sc-ion-label-md-h{line-height:1.5}.label-stacked.sc-ion-label-md-h{transform-origin:left top;transform:translateY(50%) scale(0.75);transition:color 150ms cubic-bezier(0.4, 0, 0.2, 1)}[dir=rtl].sc-ion-label-md-h -no-combinator.label-stacked.sc-ion-label-md-h,[dir=rtl] .sc-ion-label-md-h -no-combinator.label-stacked.sc-ion-label-md-h,[dir=rtl].label-stacked.sc-ion-label-md-h,[dir=rtl] .label-stacked.sc-ion-label-md-h{transform-origin:right top}.label-floating.sc-ion-label-md-h{transform:translateY(96%);transform-origin:left top;transition:color 150ms cubic-bezier(0.4, 0, 0.2, 1), transform 150ms cubic-bezier(0.4, 0, 0.2, 1)}[dir=rtl].sc-ion-label-md-h -no-combinator.label-floating.sc-ion-label-md-h,[dir=rtl] .sc-ion-label-md-h -no-combinator.label-floating.sc-ion-label-md-h,[dir=rtl].label-floating.sc-ion-label-md-h,[dir=rtl] .label-floating.sc-ion-label-md-h{transform-origin:right top}.item-textarea.label-floating.sc-ion-label-md-h,.item-textarea .label-floating.sc-ion-label-md-h{transform:translateY(185%)}.label-stacked.sc-ion-label-md-h,.label-floating.sc-ion-label-md-h{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.item-has-focus.label-floating.sc-ion-label-md-h,.item-has-focus .label-floating.sc-ion-label-md-h,.item-has-placeholder.sc-ion-label-md-h:not(.item-input).label-floating,.item-has-placeholder:not(.item-input) .label-floating.sc-ion-label-md-h,.item-has-value.label-floating.sc-ion-label-md-h,.item-has-value .label-floating.sc-ion-label-md-h{transform:translateY(50%) scale(0.75)}.item-has-focus.label-stacked.sc-ion-label-md-h:not(.ion-color),.item-has-focus .label-stacked.sc-ion-label-md-h:not(.ion-color),.item-has-focus.label-floating.sc-ion-label-md-h:not(.ion-color),.item-has-focus .label-floating.sc-ion-label-md-h:not(.ion-color){color:var(--ion-color-primary, #3880ff)}.item-has-focus.ion-color.label-stacked.sc-ion-label-md-h:not(.ion-color),.item-has-focus.ion-color .label-stacked.sc-ion-label-md-h:not(.ion-color),.item-has-focus.ion-color.label-floating.sc-ion-label-md-h:not(.ion-color),.item-has-focus.ion-color .label-floating.sc-ion-label-md-h:not(.ion-color){color:var(--ion-color-contrast)}.sc-ion-label-md-s h1{margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:24px;font-weight:normal}.sc-ion-label-md-s h2{margin-left:0;margin-right:0;margin-top:2px;margin-bottom:2px;font-size:16px;font-weight:normal}.sc-ion-label-md-s h3,.sc-ion-label-md-s h4,.sc-ion-label-md-s h5,.sc-ion-label-md-s h6{margin-left:0;margin-right:0;margin-top:2px;margin-bottom:2px;font-size:14px;font-weight:normal;line-height:normal}.sc-ion-label-md-s p{margin-left:0;margin-right:0;margin-top:0;margin-bottom:2px;font-size:14px;line-height:20px;text-overflow:inherit;overflow:inherit}.sc-ion-label-md-s>p{color:var(--ion-color-step-600, #666666)}.sc-ion-label-md-h.in-item-color.sc-ion-label-md-s>p{color:inherit}";
|
|
1584
|
+
|
|
1585
|
+
const Label = class {
|
|
1586
|
+
constructor(hostRef) {
|
|
1587
|
+
index.registerInstance(this, hostRef);
|
|
1588
|
+
this.ionColor = index.createEvent(this, "ionColor", 7);
|
|
1589
|
+
this.ionStyle = index.createEvent(this, "ionStyle", 7);
|
|
1590
|
+
this.inRange = false;
|
|
1591
|
+
this.noAnimate = false;
|
|
1592
|
+
}
|
|
1593
|
+
componentWillLoad() {
|
|
1594
|
+
this.inRange = !!this.el.closest('ion-range');
|
|
1595
|
+
this.noAnimate = (this.position === 'floating');
|
|
1596
|
+
this.emitStyle();
|
|
1597
|
+
this.emitColor();
|
|
1598
|
+
}
|
|
1599
|
+
componentDidLoad() {
|
|
1600
|
+
if (this.noAnimate) {
|
|
1601
|
+
setTimeout(() => {
|
|
1602
|
+
this.noAnimate = false;
|
|
1603
|
+
}, 1000);
|
|
1604
|
+
}
|
|
1605
|
+
}
|
|
1606
|
+
colorChanged() {
|
|
1607
|
+
this.emitColor();
|
|
1608
|
+
}
|
|
1609
|
+
positionChanged() {
|
|
1610
|
+
this.emitStyle();
|
|
1611
|
+
}
|
|
1612
|
+
emitColor() {
|
|
1613
|
+
const { color } = this;
|
|
1614
|
+
this.ionColor.emit({
|
|
1615
|
+
'item-label-color': color !== undefined,
|
|
1616
|
+
[`ion-color-${color}`]: color !== undefined
|
|
1617
|
+
});
|
|
1618
|
+
}
|
|
1619
|
+
emitStyle() {
|
|
1620
|
+
const { inRange, position } = this;
|
|
1621
|
+
// If the label is inside of a range we don't want
|
|
1622
|
+
// to override the classes added by the label that
|
|
1623
|
+
// is a direct child of the item
|
|
1624
|
+
if (!inRange) {
|
|
1625
|
+
this.ionStyle.emit({
|
|
1626
|
+
'label': true,
|
|
1627
|
+
[`label-${position}`]: position !== undefined
|
|
1628
|
+
});
|
|
1629
|
+
}
|
|
1630
|
+
}
|
|
1631
|
+
render() {
|
|
1632
|
+
const position = this.position;
|
|
1633
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1634
|
+
return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
|
|
1635
|
+
[mode]: true,
|
|
1636
|
+
'in-item-color': theme.hostContext('ion-item.ion-color', this.el),
|
|
1637
|
+
[`label-${position}`]: position !== undefined,
|
|
1638
|
+
[`label-no-animate`]: (this.noAnimate)
|
|
1639
|
+
}) }));
|
|
1640
|
+
}
|
|
1641
|
+
get el() { return index.getElement(this); }
|
|
1642
|
+
static get watchers() { return {
|
|
1643
|
+
"color": ["colorChanged"],
|
|
1644
|
+
"position": ["positionChanged"]
|
|
1645
|
+
}; }
|
|
1646
|
+
};
|
|
1647
|
+
Label.style = {
|
|
1648
|
+
ios: labelIosCss,
|
|
1649
|
+
md: labelMdCss
|
|
1650
|
+
};
|
|
1651
|
+
|
|
1652
|
+
const listIosCss = "ion-list{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;display:block;contain:content;list-style-type:none}ion-list.list-inset{transform:translateZ(0);overflow:hidden}.list-ios{background:var(--ion-item-background, var(--ion-background-color, #fff))}.list-ios.list-inset{margin-left:16px;margin-right:16px;margin-top:16px;margin-bottom:16px;border-radius:4px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.list-ios.list-inset{margin-left:unset;margin-right:unset;-webkit-margin-start:16px;margin-inline-start:16px;-webkit-margin-end:16px;margin-inline-end:16px}}.list-ios.list-inset ion-item{--border-width:0 0 1px 0;--inner-border-width:0}.list-ios.list-inset ion-item:last-child{--border-width:0;--inner-border-width:0}.list-ios.list-inset+ion-list.list-inset{margin-top:0}.list-ios-lines-none .item{--border-width:0;--inner-border-width:0}.list-ios-lines-full .item,.list-ios .item-lines-full{--border-width:0 0 0.55px 0}.list-ios-lines-full .item{--inner-border-width:0}.list-ios-lines-inset .item,.list-ios .item-lines-inset{--inner-border-width:0 0 0.55px 0}.list-ios .item-lines-inset{--border-width:0}.list-ios .item-lines-full{--inner-border-width:0}.list-ios .item-lines-none{--border-width:0;--inner-border-width:0}ion-card .list-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}";
|
|
1653
|
+
|
|
1654
|
+
const listMdCss = "ion-list{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;display:block;contain:content;list-style-type:none}ion-list.list-inset{transform:translateZ(0);overflow:hidden}.list-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:8px;padding-bottom:8px;background:var(--ion-item-background, var(--ion-background-color, #fff))}.list-md>.input:last-child::after{left:0}[dir=rtl] .list-md>.input:last-child::after,:host-context([dir=rtl]) .list-md>.input:last-child::after{left:unset;right:unset;right:0}.list-md.list-inset{margin-left:16px;margin-right:16px;margin-top:16px;margin-bottom:16px;border-radius:2px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.list-md.list-inset{margin-left:unset;margin-right:unset;-webkit-margin-start:16px;margin-inline-start:16px;-webkit-margin-end:16px;margin-inline-end:16px}}.list-md.list-inset ion-item:first-child{--border-radius:2px 2px 0 0;--border-width:0 0 1px 0}.list-md.list-inset ion-item:last-child{--border-radius:0 0 2px, 2px;--border-width:0}.list-md.list-inset .item-interactive{--padding-start:0;--padding-end:0}.list-md.list-inset+ion-list.list-inset{margin-top:0}.list-md-lines-none .item{--border-width:0;--inner-border-width:0}.list-md-lines-full .item,.list-md .item-lines-full{--border-width:0 0 1px 0}.list-md-lines-full .item{--inner-border-width:0}.list-md-lines-inset .item,.list-md .item-lines-inset{--inner-border-width:0 0 1px 0}.list-md .item-lines-inset{--border-width:0}.list-md .item-lines-full{--inner-border-width:0}.list-md .item-lines-none{--border-width:0;--inner-border-width:0}ion-card .list-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}";
|
|
1655
|
+
|
|
1656
|
+
const List = class {
|
|
1657
|
+
constructor(hostRef) {
|
|
1658
|
+
index.registerInstance(this, hostRef);
|
|
1659
|
+
/**
|
|
1660
|
+
* If `true`, the list will have margin around it and rounded corners.
|
|
1661
|
+
*/
|
|
1662
|
+
this.inset = false;
|
|
1663
|
+
}
|
|
1664
|
+
/**
|
|
1665
|
+
* If `ion-item-sliding` are used inside the list, this method closes
|
|
1666
|
+
* any open sliding item.
|
|
1667
|
+
*
|
|
1668
|
+
* Returns `true` if an actual `ion-item-sliding` is closed.
|
|
1669
|
+
*/
|
|
1670
|
+
async closeSlidingItems() {
|
|
1671
|
+
const item = this.el.querySelector('ion-item-sliding');
|
|
1672
|
+
if (item && item.closeOpened) {
|
|
1673
|
+
return item.closeOpened();
|
|
1674
|
+
}
|
|
1675
|
+
return false;
|
|
1676
|
+
}
|
|
1677
|
+
render() {
|
|
1678
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1679
|
+
const { lines, inset } = this;
|
|
1680
|
+
return (index.h(index.Host, { class: {
|
|
1681
|
+
[mode]: true,
|
|
1682
|
+
// Used internally for styling
|
|
1683
|
+
[`list-${mode}`]: true,
|
|
1684
|
+
'list-inset': inset,
|
|
1685
|
+
[`list-lines-${lines}`]: lines !== undefined,
|
|
1686
|
+
[`list-${mode}-lines-${lines}`]: lines !== undefined
|
|
1687
|
+
} }));
|
|
1688
|
+
}
|
|
1689
|
+
get el() { return index.getElement(this); }
|
|
1690
|
+
};
|
|
1691
|
+
List.style = {
|
|
1692
|
+
ios: listIosCss,
|
|
1693
|
+
md: listMdCss
|
|
1694
|
+
};
|
|
1695
|
+
|
|
1696
|
+
const progressBarIosCss = ":host{--background:rgba(var(--ion-color-primary-rgb, 56, 128, 255), 0.3);--progress-background:var(--ion-color-primary, #3880ff);--buffer-background:var(--background);display:block;position:relative;width:100%;contain:strict;direction:ltr;overflow:hidden}.progress,.progress-indeterminate,.indeterminate-bar-primary,.indeterminate-bar-secondary,.progress-buffer-bar{left:0;right:0;top:0;bottom:0;position:absolute;width:100%;height:100%}.buffer-circles-container,.buffer-circles{left:0;right:0;top:0;bottom:0;position:absolute}.buffer-circles{right:-10px;left:-10px;}.progress,.progress-buffer-bar,.buffer-circles-container{transform-origin:left top;transition:transform 150ms linear}.progress,.progress-indeterminate{background:var(--progress-background);z-index:2}.progress-buffer-bar{background:var(--buffer-background);z-index:1}.buffer-circles-container{overflow:hidden}.indeterminate-bar-primary{top:0;right:0;bottom:0;left:-145.166611%;animation:primary-indeterminate-translate 2s infinite linear}.indeterminate-bar-primary .progress-indeterminate{animation:primary-indeterminate-scale 2s infinite linear;animation-play-state:inherit}.indeterminate-bar-secondary{top:0;right:0;bottom:0;left:-54.888891%;animation:secondary-indeterminate-translate 2s infinite linear}.indeterminate-bar-secondary .progress-indeterminate{animation:secondary-indeterminate-scale 2s infinite linear;animation-play-state:inherit}.buffer-circles{background-image:radial-gradient(ellipse at center, var(--buffer-background) 0%, var(--buffer-background) 30%, transparent 30%);background-repeat:repeat-x;background-position:5px center;background-size:10px 10px;z-index:0;animation:buffering 450ms infinite linear}:host(.progress-bar-reversed){transform:scaleX(-1)}:host(.progress-paused) .indeterminate-bar-secondary,:host(.progress-paused) .indeterminate-bar-primary,:host(.progress-paused) .buffer-circles{animation-play-state:paused}:host(.ion-color) .progress-buffer-bar{background:rgba(var(--ion-color-base-rgb), 0.3)}:host(.ion-color) .buffer-circles{background-image:radial-gradient(ellipse at center, rgba(var(--ion-color-base-rgb), 0.3) 0%, rgba(var(--ion-color-base-rgb), 0.3) 30%, transparent 30%)}:host(.ion-color) .progress,:host(.ion-color) .progress-indeterminate{background:var(--ion-color-base)}@keyframes primary-indeterminate-translate{0%{transform:translateX(0)}20%{animation-timing-function:cubic-bezier(0.5, 0, 0.701732, 0.495819);transform:translateX(0)}59.15%{animation-timing-function:cubic-bezier(0.302435, 0.381352, 0.55, 0.956352);transform:translateX(83.67142%)}100%{transform:translateX(200.611057%)}}@keyframes primary-indeterminate-scale{0%{transform:scaleX(0.08)}36.65%{animation-timing-function:cubic-bezier(0.334731, 0.12482, 0.785844, 1);transform:scaleX(0.08)}69.15%{animation-timing-function:cubic-bezier(0.06, 0.11, 0.6, 1);transform:scaleX(0.661479)}100%{transform:scaleX(0.08)}}@keyframes secondary-indeterminate-translate{0%{animation-timing-function:cubic-bezier(0.15, 0, 0.515058, 0.409685);transform:translateX(0)}25%{animation-timing-function:cubic-bezier(0.31033, 0.284058, 0.8, 0.733712);transform:translateX(37.651913%)}48.35%{animation-timing-function:cubic-bezier(0.4, 0.627035, 0.6, 0.902026);transform:translateX(84.386165%)}100%{transform:translateX(160.277782%)}}@keyframes secondary-indeterminate-scale{0%{animation-timing-function:cubic-bezier(0.205028, 0.057051, 0.57661, 0.453971);transform:scaleX(0.08)}19.15%{animation-timing-function:cubic-bezier(0.152313, 0.196432, 0.648374, 1.004315);transform:scaleX(0.457104)}44.15%{animation-timing-function:cubic-bezier(0.257759, -0.003163, 0.211762, 1.38179);transform:scaleX(0.72796)}100%{transform:scaleX(0.08)}}@keyframes buffering{to{transform:translateX(-10px)}}:host{height:3px}";
|
|
1697
|
+
|
|
1698
|
+
const progressBarMdCss = ":host{--background:rgba(var(--ion-color-primary-rgb, 56, 128, 255), 0.3);--progress-background:var(--ion-color-primary, #3880ff);--buffer-background:var(--background);display:block;position:relative;width:100%;contain:strict;direction:ltr;overflow:hidden}.progress,.progress-indeterminate,.indeterminate-bar-primary,.indeterminate-bar-secondary,.progress-buffer-bar{left:0;right:0;top:0;bottom:0;position:absolute;width:100%;height:100%}.buffer-circles-container,.buffer-circles{left:0;right:0;top:0;bottom:0;position:absolute}.buffer-circles{right:-10px;left:-10px;}.progress,.progress-buffer-bar,.buffer-circles-container{transform-origin:left top;transition:transform 150ms linear}.progress,.progress-indeterminate{background:var(--progress-background);z-index:2}.progress-buffer-bar{background:var(--buffer-background);z-index:1}.buffer-circles-container{overflow:hidden}.indeterminate-bar-primary{top:0;right:0;bottom:0;left:-145.166611%;animation:primary-indeterminate-translate 2s infinite linear}.indeterminate-bar-primary .progress-indeterminate{animation:primary-indeterminate-scale 2s infinite linear;animation-play-state:inherit}.indeterminate-bar-secondary{top:0;right:0;bottom:0;left:-54.888891%;animation:secondary-indeterminate-translate 2s infinite linear}.indeterminate-bar-secondary .progress-indeterminate{animation:secondary-indeterminate-scale 2s infinite linear;animation-play-state:inherit}.buffer-circles{background-image:radial-gradient(ellipse at center, var(--buffer-background) 0%, var(--buffer-background) 30%, transparent 30%);background-repeat:repeat-x;background-position:5px center;background-size:10px 10px;z-index:0;animation:buffering 450ms infinite linear}:host(.progress-bar-reversed){transform:scaleX(-1)}:host(.progress-paused) .indeterminate-bar-secondary,:host(.progress-paused) .indeterminate-bar-primary,:host(.progress-paused) .buffer-circles{animation-play-state:paused}:host(.ion-color) .progress-buffer-bar{background:rgba(var(--ion-color-base-rgb), 0.3)}:host(.ion-color) .buffer-circles{background-image:radial-gradient(ellipse at center, rgba(var(--ion-color-base-rgb), 0.3) 0%, rgba(var(--ion-color-base-rgb), 0.3) 30%, transparent 30%)}:host(.ion-color) .progress,:host(.ion-color) .progress-indeterminate{background:var(--ion-color-base)}@keyframes primary-indeterminate-translate{0%{transform:translateX(0)}20%{animation-timing-function:cubic-bezier(0.5, 0, 0.701732, 0.495819);transform:translateX(0)}59.15%{animation-timing-function:cubic-bezier(0.302435, 0.381352, 0.55, 0.956352);transform:translateX(83.67142%)}100%{transform:translateX(200.611057%)}}@keyframes primary-indeterminate-scale{0%{transform:scaleX(0.08)}36.65%{animation-timing-function:cubic-bezier(0.334731, 0.12482, 0.785844, 1);transform:scaleX(0.08)}69.15%{animation-timing-function:cubic-bezier(0.06, 0.11, 0.6, 1);transform:scaleX(0.661479)}100%{transform:scaleX(0.08)}}@keyframes secondary-indeterminate-translate{0%{animation-timing-function:cubic-bezier(0.15, 0, 0.515058, 0.409685);transform:translateX(0)}25%{animation-timing-function:cubic-bezier(0.31033, 0.284058, 0.8, 0.733712);transform:translateX(37.651913%)}48.35%{animation-timing-function:cubic-bezier(0.4, 0.627035, 0.6, 0.902026);transform:translateX(84.386165%)}100%{transform:translateX(160.277782%)}}@keyframes secondary-indeterminate-scale{0%{animation-timing-function:cubic-bezier(0.205028, 0.057051, 0.57661, 0.453971);transform:scaleX(0.08)}19.15%{animation-timing-function:cubic-bezier(0.152313, 0.196432, 0.648374, 1.004315);transform:scaleX(0.457104)}44.15%{animation-timing-function:cubic-bezier(0.257759, -0.003163, 0.211762, 1.38179);transform:scaleX(0.72796)}100%{transform:scaleX(0.08)}}@keyframes buffering{to{transform:translateX(-10px)}}:host{height:4px}";
|
|
1699
|
+
|
|
1700
|
+
const ProgressBar = class {
|
|
1701
|
+
constructor(hostRef) {
|
|
1702
|
+
index.registerInstance(this, hostRef);
|
|
1703
|
+
/**
|
|
1704
|
+
* The state of the progress bar, based on if the time the process takes is known or not.
|
|
1705
|
+
* Default options are: `"determinate"` (no animation), `"indeterminate"` (animate from left to right).
|
|
1706
|
+
*/
|
|
1707
|
+
this.type = 'determinate';
|
|
1708
|
+
/**
|
|
1709
|
+
* If true, reverse the progress bar direction.
|
|
1710
|
+
*/
|
|
1711
|
+
this.reversed = false;
|
|
1712
|
+
/**
|
|
1713
|
+
* The value determines how much of the active bar should display when the
|
|
1714
|
+
* `type` is `"determinate"`.
|
|
1715
|
+
* The value should be between [0, 1].
|
|
1716
|
+
*/
|
|
1717
|
+
this.value = 0;
|
|
1718
|
+
/**
|
|
1719
|
+
* If the buffer and value are smaller than 1, the buffer circles will show.
|
|
1720
|
+
* The buffer should be between [0, 1].
|
|
1721
|
+
*/
|
|
1722
|
+
this.buffer = 1;
|
|
1723
|
+
}
|
|
1724
|
+
render() {
|
|
1725
|
+
const { color, type, reversed, value, buffer } = this;
|
|
1726
|
+
const paused = ionicGlobal.config.getBoolean('_testing');
|
|
1727
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1728
|
+
return (index.h(index.Host, { role: "progressbar", "aria-valuenow": type === 'determinate' ? value : null, "aria-valuemin": "0", "aria-valuemax": "1", class: theme.createColorClasses(color, {
|
|
1729
|
+
[mode]: true,
|
|
1730
|
+
[`progress-bar-${type}`]: true,
|
|
1731
|
+
'progress-paused': paused,
|
|
1732
|
+
'progress-bar-reversed': document.dir === 'rtl' ? !reversed : reversed
|
|
1733
|
+
}) }, type === 'indeterminate'
|
|
1734
|
+
? renderIndeterminate()
|
|
1735
|
+
: renderProgress(value, buffer)));
|
|
1736
|
+
}
|
|
1737
|
+
};
|
|
1738
|
+
const renderIndeterminate = () => {
|
|
1739
|
+
return (index.h("div", { part: "track", class: "progress-buffer-bar" }, index.h("div", { class: "indeterminate-bar-primary" }, index.h("span", { part: "progress", class: "progress-indeterminate" })), index.h("div", { class: "indeterminate-bar-secondary" }, index.h("span", { part: "progress", class: "progress-indeterminate" }))));
|
|
1740
|
+
};
|
|
1741
|
+
const renderProgress = (value, buffer) => {
|
|
1742
|
+
const finalValue = helpers.clamp(0, value, 1);
|
|
1743
|
+
const finalBuffer = helpers.clamp(0, buffer, 1);
|
|
1744
|
+
return [
|
|
1745
|
+
index.h("div", { part: "progress", class: "progress", style: { transform: `scaleX(${finalValue})` } }),
|
|
1746
|
+
/**
|
|
1747
|
+
* Buffer circles with two container to move
|
|
1748
|
+
* the circles behind the buffer progress
|
|
1749
|
+
* with respecting the animation.
|
|
1750
|
+
* When finalBuffer === 1, we use display: none
|
|
1751
|
+
* instead of removing the element to avoid flickering.
|
|
1752
|
+
*/
|
|
1753
|
+
index.h("div", { class: { 'buffer-circles-container': true, 'ion-hide': finalBuffer === 1 }, style: { transform: `translateX(${finalBuffer * 100}%)` } }, index.h("div", { class: "buffer-circles-container", style: { transform: `translateX(-${finalBuffer * 100}%)` } }, index.h("div", { part: "stream", class: "buffer-circles" }))),
|
|
1754
|
+
index.h("div", { part: "track", class: "progress-buffer-bar", style: { transform: `scaleX(${finalBuffer})` } }),
|
|
1755
|
+
];
|
|
1756
|
+
};
|
|
1757
|
+
ProgressBar.style = {
|
|
1758
|
+
ios: progressBarIosCss,
|
|
1759
|
+
md: progressBarMdCss
|
|
1760
|
+
};
|
|
1761
|
+
|
|
1762
|
+
const rippleEffectCss = ":host{left:0;right:0;top:0;bottom:0;position:absolute;contain:strict;pointer-events:none}:host(.unbounded){contain:layout size style}.ripple-effect{border-radius:50%;position:absolute;background-color:currentColor;color:inherit;contain:strict;opacity:0;animation:225ms rippleAnimation forwards, 75ms fadeInAnimation forwards;will-change:transform, opacity;pointer-events:none}.fade-out{transform:translate(var(--translate-end)) scale(var(--final-scale, 1));animation:150ms fadeOutAnimation forwards}@keyframes rippleAnimation{from{animation-timing-function:cubic-bezier(0.4, 0, 0.2, 1);transform:scale(1)}to{transform:translate(var(--translate-end)) scale(var(--final-scale, 1))}}@keyframes fadeInAnimation{from{animation-timing-function:linear;opacity:0}to{opacity:0.16}}@keyframes fadeOutAnimation{from{animation-timing-function:linear;opacity:0.16}to{opacity:0}}";
|
|
1763
|
+
|
|
1764
|
+
const RippleEffect = class {
|
|
1765
|
+
constructor(hostRef) {
|
|
1766
|
+
index.registerInstance(this, hostRef);
|
|
1767
|
+
/**
|
|
1768
|
+
* Sets the type of ripple-effect:
|
|
1769
|
+
*
|
|
1770
|
+
* - `bounded`: the ripple effect expands from the user's click position
|
|
1771
|
+
* - `unbounded`: the ripple effect expands from the center of the button and overflows the container.
|
|
1772
|
+
*
|
|
1773
|
+
* NOTE: Surfaces for bounded ripples should have the overflow property set to hidden,
|
|
1774
|
+
* while surfaces for unbounded ripples should have it set to visible.
|
|
1775
|
+
*/
|
|
1776
|
+
this.type = 'bounded';
|
|
1777
|
+
}
|
|
1778
|
+
/**
|
|
1779
|
+
* Adds the ripple effect to the parent element.
|
|
1780
|
+
*
|
|
1781
|
+
* @param x The horizontal coordinate of where the ripple should start.
|
|
1782
|
+
* @param y The vertical coordinate of where the ripple should start.
|
|
1783
|
+
*/
|
|
1784
|
+
async addRipple(x, y) {
|
|
1785
|
+
return new Promise(resolve => {
|
|
1786
|
+
index.readTask(() => {
|
|
1787
|
+
const rect = this.el.getBoundingClientRect();
|
|
1788
|
+
const width = rect.width;
|
|
1789
|
+
const height = rect.height;
|
|
1790
|
+
const hypotenuse = Math.sqrt(width * width + height * height);
|
|
1791
|
+
const maxDim = Math.max(height, width);
|
|
1792
|
+
const maxRadius = this.unbounded ? maxDim : hypotenuse + PADDING;
|
|
1793
|
+
const initialSize = Math.floor(maxDim * INITIAL_ORIGIN_SCALE);
|
|
1794
|
+
const finalScale = maxRadius / initialSize;
|
|
1795
|
+
let posX = x - rect.left;
|
|
1796
|
+
let posY = y - rect.top;
|
|
1797
|
+
if (this.unbounded) {
|
|
1798
|
+
posX = width * 0.5;
|
|
1799
|
+
posY = height * 0.5;
|
|
1800
|
+
}
|
|
1801
|
+
const styleX = posX - initialSize * 0.5;
|
|
1802
|
+
const styleY = posY - initialSize * 0.5;
|
|
1803
|
+
const moveX = width * 0.5 - posX;
|
|
1804
|
+
const moveY = height * 0.5 - posY;
|
|
1805
|
+
index.writeTask(() => {
|
|
1806
|
+
const div = document.createElement('div');
|
|
1807
|
+
div.classList.add('ripple-effect');
|
|
1808
|
+
const style = div.style;
|
|
1809
|
+
style.top = styleY + 'px';
|
|
1810
|
+
style.left = styleX + 'px';
|
|
1811
|
+
style.width = style.height = initialSize + 'px';
|
|
1812
|
+
style.setProperty('--final-scale', `${finalScale}`);
|
|
1813
|
+
style.setProperty('--translate-end', `${moveX}px, ${moveY}px`);
|
|
1814
|
+
const container = this.el.shadowRoot || this.el;
|
|
1815
|
+
container.appendChild(div);
|
|
1816
|
+
setTimeout(() => {
|
|
1817
|
+
resolve(() => {
|
|
1818
|
+
removeRipple(div);
|
|
1819
|
+
});
|
|
1820
|
+
}, 225 + 100);
|
|
1821
|
+
});
|
|
1822
|
+
});
|
|
1823
|
+
});
|
|
1824
|
+
}
|
|
1825
|
+
get unbounded() {
|
|
1826
|
+
return this.type === 'unbounded';
|
|
1827
|
+
}
|
|
1828
|
+
render() {
|
|
1829
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1830
|
+
return (index.h(index.Host, { role: "presentation", class: {
|
|
1831
|
+
[mode]: true,
|
|
1832
|
+
'unbounded': this.unbounded
|
|
1833
|
+
} }));
|
|
1834
|
+
}
|
|
1835
|
+
get el() { return index.getElement(this); }
|
|
1836
|
+
};
|
|
1837
|
+
const removeRipple = (ripple) => {
|
|
1838
|
+
ripple.classList.add('fade-out');
|
|
1839
|
+
setTimeout(() => {
|
|
1840
|
+
ripple.remove();
|
|
1841
|
+
}, 200);
|
|
1842
|
+
};
|
|
1843
|
+
const PADDING = 10;
|
|
1844
|
+
const INITIAL_ORIGIN_SCALE = 0.5;
|
|
1845
|
+
RippleEffect.style = rippleEffectCss;
|
|
1846
|
+
|
|
1847
|
+
const rowCss = ":host{display:flex;flex-wrap:wrap}";
|
|
1848
|
+
|
|
1849
|
+
const Row = class {
|
|
1850
|
+
constructor(hostRef) {
|
|
1851
|
+
index.registerInstance(this, hostRef);
|
|
1852
|
+
}
|
|
1853
|
+
render() {
|
|
1854
|
+
return (index.h(index.Host, { class: ionicGlobal.getIonMode(this) }, index.h("slot", null)));
|
|
1855
|
+
}
|
|
1856
|
+
};
|
|
1857
|
+
Row.style = rowCss;
|
|
1858
|
+
|
|
1859
|
+
const titleIosCss = ":host{--color:initial;display:flex;flex:1;align-items:center;transform:translateZ(0);color:var(--color)}:host(.ion-color){color:var(--ion-color-base)}.toolbar-title{display:block;width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;pointer-events:auto}:host(.title-small) .toolbar-title{white-space:normal}:host{left:0;top:0;padding-left:90px;padding-right:90px;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);position:absolute;width:100%;height:100%;transform:translateZ(0);font-size:17px;font-weight:600;text-align:center;box-sizing:border-box;pointer-events:none}:host-context([dir=rtl]){left:unset;right:unset;right:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:90px;padding-inline-start:90px;-webkit-padding-end:90px;padding-inline-end:90px}}:host(.title-small){padding-left:9px;padding-right:9px;padding-top:6px;padding-bottom:16px;position:relative;font-size:13px;font-weight:normal}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host(.title-small){padding-left:unset;padding-right:unset;-webkit-padding-start:9px;padding-inline-start:9px;-webkit-padding-end:9px;padding-inline-end:9px}}:host(.title-large){padding-left:16px;padding-right:16px;padding-top:0;padding-bottom:0;transform-origin:left center;bottom:0;align-items:flex-end;min-width:100%;padding-bottom:6px;font-size:34px;font-weight:700;text-align:start}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host(.title-large){padding-left:unset;padding-right:unset;-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px}}:host(.title-large.title-rtl){transform-origin:right center}:host(.title-large.ion-cloned-element){--color:var(--ion-text-color, #000)}:host(.title-large) .toolbar-title{transform-origin:inherit}:host-context([dir=rtl]):host(.title-large) .toolbar-title,:host-context([dir=rtl]).title-large .toolbar-title{transform-origin:calc(100% - inherit)}";
|
|
1860
|
+
|
|
1861
|
+
const titleMdCss = ":host{--color:initial;display:flex;flex:1;align-items:center;transform:translateZ(0);color:var(--color)}:host(.ion-color){color:var(--ion-color-base)}.toolbar-title{display:block;width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;pointer-events:auto}:host(.title-small) .toolbar-title{white-space:normal}:host{padding-left:20px;padding-right:20px;padding-top:0;padding-bottom:0;font-size:20px;font-weight:500;letter-spacing:0.0125em}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px}}:host(.title-small){width:100%;height:100%;font-size:15px;font-weight:normal}";
|
|
1862
|
+
|
|
1863
|
+
const ToolbarTitle = class {
|
|
1864
|
+
constructor(hostRef) {
|
|
1865
|
+
index.registerInstance(this, hostRef);
|
|
1866
|
+
this.ionStyle = index.createEvent(this, "ionStyle", 7);
|
|
1867
|
+
}
|
|
1868
|
+
sizeChanged() {
|
|
1869
|
+
this.emitStyle();
|
|
1870
|
+
}
|
|
1871
|
+
connectedCallback() {
|
|
1872
|
+
this.emitStyle();
|
|
1873
|
+
}
|
|
1874
|
+
emitStyle() {
|
|
1875
|
+
const size = this.getSize();
|
|
1876
|
+
this.ionStyle.emit({
|
|
1877
|
+
[`title-${size}`]: true
|
|
1878
|
+
});
|
|
1879
|
+
}
|
|
1880
|
+
getSize() {
|
|
1881
|
+
return (this.size !== undefined) ? this.size : 'default';
|
|
1882
|
+
}
|
|
1883
|
+
render() {
|
|
1884
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1885
|
+
const size = this.getSize();
|
|
1886
|
+
return (index.h(index.Host, { class: theme.createColorClasses(this.color, {
|
|
1887
|
+
[mode]: true,
|
|
1888
|
+
[`title-${size}`]: true,
|
|
1889
|
+
'title-rtl': document.dir === 'rtl'
|
|
1890
|
+
}) }, index.h("div", { class: "toolbar-title" }, index.h("slot", null))));
|
|
1891
|
+
}
|
|
1892
|
+
get el() { return index.getElement(this); }
|
|
1893
|
+
static get watchers() { return {
|
|
1894
|
+
"size": ["sizeChanged"]
|
|
1895
|
+
}; }
|
|
1896
|
+
};
|
|
1897
|
+
ToolbarTitle.style = {
|
|
1898
|
+
ios: titleIosCss,
|
|
1899
|
+
md: titleMdCss
|
|
1900
|
+
};
|
|
1901
|
+
|
|
1902
|
+
const toolbarIosCss = ":host{--border-width:0;--border-style:solid;--opacity:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;padding-left:var(--ion-safe-area-left);padding-right:var(--ion-safe-area-right);display:block;position:relative;width:100%;color:var(--color);font-family:var(--ion-font-family, inherit);contain:content;z-index:10;box-sizing:border-box}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-safe-area-left);padding-inline-start:var(--ion-safe-area-left);-webkit-padding-end:var(--ion-safe-area-right);padding-inline-end:var(--ion-safe-area-right)}}:host(.ion-color){color:var(--ion-color-contrast)}:host(.ion-color) .toolbar-background{background:var(--ion-color-base)}.toolbar-container{padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:flex;position:relative;flex-direction:row;align-items:center;justify-content:space-between;width:100%;min-height:var(--min-height);contain:content;overflow:hidden;z-index:10;box-sizing:border-box}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.toolbar-container{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}.toolbar-background{left:0;right:0;top:0;bottom:0;position:absolute;transform:translateZ(0);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;opacity:var(--opacity);z-index:-1;pointer-events:none}::slotted(ion-progress-bar){left:0;right:0;bottom:0;position:absolute}:host{--background:var(--ion-toolbar-background, var(--ion-color-step-50, #fff));--color:var(--ion-toolbar-color, var(--ion-text-color, #000));--border-color:var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.2))));--padding-top:3px;--padding-bottom:3px;--padding-start:4px;--padding-end:4px;--min-height:44px}.toolbar-content{flex:1;order:4;min-width:0}:host(.toolbar-segment) .toolbar-content{display:inline-flex}:host(.toolbar-searchbar) .toolbar-container{padding-top:0;padding-bottom:0}:host(.toolbar-searchbar) ::slotted(*){align-self:start}:host(.toolbar-searchbar) ::slotted(ion-chip){margin-top:3px}:host(.toolbar-searchbar) ::slotted(ion-back-button){height:38px}::slotted(ion-buttons){min-height:38px}::slotted([slot=start]){order:2}::slotted([slot=secondary]){order:3}::slotted([slot=primary]){order:5;text-align:end}::slotted([slot=end]){order:6;text-align:end}:host(.toolbar-title-large) .toolbar-container{flex-wrap:wrap;align-items:flex-start}:host(.toolbar-title-large) .toolbar-content ion-title{flex:1;order:8;min-width:100%}";
|
|
1903
|
+
|
|
1904
|
+
const toolbarMdCss = ":host{--border-width:0;--border-style:solid;--opacity:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;padding-left:var(--ion-safe-area-left);padding-right:var(--ion-safe-area-right);display:block;position:relative;width:100%;color:var(--color);font-family:var(--ion-font-family, inherit);contain:content;z-index:10;box-sizing:border-box}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--ion-safe-area-left);padding-inline-start:var(--ion-safe-area-left);-webkit-padding-end:var(--ion-safe-area-right);padding-inline-end:var(--ion-safe-area-right)}}:host(.ion-color){color:var(--ion-color-contrast)}:host(.ion-color) .toolbar-background{background:var(--ion-color-base)}.toolbar-container{padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:flex;position:relative;flex-direction:row;align-items:center;justify-content:space-between;width:100%;min-height:var(--min-height);contain:content;overflow:hidden;z-index:10;box-sizing:border-box}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.toolbar-container{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}.toolbar-background{left:0;right:0;top:0;bottom:0;position:absolute;transform:translateZ(0);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;opacity:var(--opacity);z-index:-1;pointer-events:none}::slotted(ion-progress-bar){left:0;right:0;bottom:0;position:absolute}:host{--background:var(--ion-toolbar-background, var(--ion-background-color, #fff));--color:var(--ion-toolbar-color, var(--ion-text-color, #424242));--border-color:var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, #c1c4cd)));--padding-top:0;--padding-bottom:0;--padding-start:0;--padding-end:0;--min-height:56px}.toolbar-content{flex:1;order:3;min-width:0;max-width:100%}::slotted(ion-segment){min-height:var(--min-height)}::slotted(.buttons-first-slot){margin-left:4px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(.buttons-first-slot){margin-left:unset;-webkit-margin-start:4px;margin-inline-start:4px}}::slotted(.buttons-last-slot){margin-right:4px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted(.buttons-last-slot){margin-right:unset;-webkit-margin-end:4px;margin-inline-end:4px}}::slotted([slot=start]){order:2}::slotted([slot=secondary]){order:4}::slotted([slot=primary]){order:5;text-align:end}::slotted([slot=end]){order:6;text-align:end}";
|
|
1905
|
+
|
|
1906
|
+
const Toolbar = class {
|
|
1907
|
+
constructor(hostRef) {
|
|
1908
|
+
index.registerInstance(this, hostRef);
|
|
1909
|
+
this.childrenStyles = new Map();
|
|
1910
|
+
}
|
|
1911
|
+
componentWillLoad() {
|
|
1912
|
+
const buttons = Array.from(this.el.querySelectorAll('ion-buttons'));
|
|
1913
|
+
const firstButtons = buttons.find(button => {
|
|
1914
|
+
return button.slot === 'start';
|
|
1915
|
+
});
|
|
1916
|
+
if (firstButtons) {
|
|
1917
|
+
firstButtons.classList.add('buttons-first-slot');
|
|
1918
|
+
}
|
|
1919
|
+
const buttonsReversed = buttons.reverse();
|
|
1920
|
+
const lastButtons = buttonsReversed.find(button => button.slot === 'end') ||
|
|
1921
|
+
buttonsReversed.find(button => button.slot === 'primary') ||
|
|
1922
|
+
buttonsReversed.find(button => button.slot === 'secondary');
|
|
1923
|
+
if (lastButtons) {
|
|
1924
|
+
lastButtons.classList.add('buttons-last-slot');
|
|
1925
|
+
}
|
|
1926
|
+
}
|
|
1927
|
+
childrenStyle(ev) {
|
|
1928
|
+
ev.stopPropagation();
|
|
1929
|
+
const tagName = ev.target.tagName;
|
|
1930
|
+
const updatedStyles = ev.detail;
|
|
1931
|
+
const newStyles = {};
|
|
1932
|
+
const childStyles = this.childrenStyles.get(tagName) || {};
|
|
1933
|
+
let hasStyleChange = false;
|
|
1934
|
+
Object.keys(updatedStyles).forEach(key => {
|
|
1935
|
+
const childKey = `toolbar-${key}`;
|
|
1936
|
+
const newValue = updatedStyles[key];
|
|
1937
|
+
if (newValue !== childStyles[childKey]) {
|
|
1938
|
+
hasStyleChange = true;
|
|
1939
|
+
}
|
|
1940
|
+
if (newValue) {
|
|
1941
|
+
newStyles[childKey] = true;
|
|
1942
|
+
}
|
|
1943
|
+
});
|
|
1944
|
+
if (hasStyleChange) {
|
|
1945
|
+
this.childrenStyles.set(tagName, newStyles);
|
|
1946
|
+
index.forceUpdate(this);
|
|
1947
|
+
}
|
|
1948
|
+
}
|
|
1949
|
+
render() {
|
|
1950
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
1951
|
+
const childStyles = {};
|
|
1952
|
+
this.childrenStyles.forEach(value => {
|
|
1953
|
+
Object.assign(childStyles, value);
|
|
1954
|
+
});
|
|
1955
|
+
return (index.h(index.Host, { class: Object.assign(Object.assign({}, childStyles), theme.createColorClasses(this.color, {
|
|
1956
|
+
[mode]: true,
|
|
1957
|
+
'in-toolbar': theme.hostContext('ion-toolbar', this.el),
|
|
1958
|
+
})) }, index.h("div", { class: "toolbar-background" }), index.h("div", { class: "toolbar-container" }, index.h("slot", { name: "start" }), index.h("slot", { name: "secondary" }), index.h("div", { class: "toolbar-content" }, index.h("slot", null)), index.h("slot", { name: "primary" }), index.h("slot", { name: "end" }))));
|
|
1959
|
+
}
|
|
1960
|
+
get el() { return index.getElement(this); }
|
|
1961
|
+
};
|
|
1962
|
+
Toolbar.style = {
|
|
1963
|
+
ios: toolbarIosCss,
|
|
1964
|
+
md: toolbarMdCss
|
|
1965
|
+
};
|
|
1966
|
+
|
|
1967
|
+
const appendToMap = (map, propName, value) => {
|
|
1968
|
+
const items = map.get(propName);
|
|
1969
|
+
if (!items) {
|
|
1970
|
+
map.set(propName, [value]);
|
|
1971
|
+
}
|
|
1972
|
+
else if (!items.includes(value)) {
|
|
1973
|
+
items.push(value);
|
|
1974
|
+
}
|
|
1975
|
+
};
|
|
1976
|
+
const debounce = (fn, ms) => {
|
|
1977
|
+
let timeoutId;
|
|
1978
|
+
return (...args) => {
|
|
1979
|
+
if (timeoutId) {
|
|
1980
|
+
clearTimeout(timeoutId);
|
|
1981
|
+
}
|
|
1982
|
+
timeoutId = setTimeout(() => {
|
|
1983
|
+
timeoutId = 0;
|
|
1984
|
+
fn(...args);
|
|
1985
|
+
}, ms);
|
|
1986
|
+
};
|
|
1987
|
+
};
|
|
1988
|
+
|
|
1989
|
+
/**
|
|
1990
|
+
* Check if a possible element isConnected.
|
|
1991
|
+
* The property might not be there, so we check for it.
|
|
1992
|
+
*
|
|
1993
|
+
* We want it to return true if isConnected is not a property,
|
|
1994
|
+
* otherwise we would remove these elements and would not update.
|
|
1995
|
+
*
|
|
1996
|
+
* Better leak in Edge than to be useless.
|
|
1997
|
+
*/
|
|
1998
|
+
const isConnected = (maybeElement) => !('isConnected' in maybeElement) || maybeElement.isConnected;
|
|
1999
|
+
const cleanupElements = debounce((map) => {
|
|
2000
|
+
for (let key of map.keys()) {
|
|
2001
|
+
map.set(key, map.get(key).filter(isConnected));
|
|
2002
|
+
}
|
|
2003
|
+
}, 2000);
|
|
2004
|
+
const stencilSubscription = () => {
|
|
2005
|
+
if (typeof index.getRenderingRef !== 'function') {
|
|
2006
|
+
// If we are not in a stencil project, we do nothing.
|
|
2007
|
+
// This function is not really exported by @stencil/core.
|
|
2008
|
+
return {};
|
|
2009
|
+
}
|
|
2010
|
+
const elmsToUpdate = new Map();
|
|
2011
|
+
return {
|
|
2012
|
+
dispose: () => elmsToUpdate.clear(),
|
|
2013
|
+
get: (propName) => {
|
|
2014
|
+
const elm = index.getRenderingRef();
|
|
2015
|
+
if (elm) {
|
|
2016
|
+
appendToMap(elmsToUpdate, propName, elm);
|
|
2017
|
+
}
|
|
2018
|
+
},
|
|
2019
|
+
set: (propName) => {
|
|
2020
|
+
const elements = elmsToUpdate.get(propName);
|
|
2021
|
+
if (elements) {
|
|
2022
|
+
elmsToUpdate.set(propName, elements.filter(index.forceUpdate));
|
|
2023
|
+
}
|
|
2024
|
+
cleanupElements(elmsToUpdate);
|
|
2025
|
+
},
|
|
2026
|
+
reset: () => {
|
|
2027
|
+
elmsToUpdate.forEach((elms) => elms.forEach(index.forceUpdate));
|
|
2028
|
+
cleanupElements(elmsToUpdate);
|
|
2029
|
+
},
|
|
2030
|
+
};
|
|
2031
|
+
};
|
|
2032
|
+
|
|
2033
|
+
const createObservableMap = (defaultState, shouldUpdate = (a, b) => a !== b) => {
|
|
2034
|
+
let states = new Map(Object.entries(defaultState !== null && defaultState !== void 0 ? defaultState : {}));
|
|
2035
|
+
const handlers = {
|
|
2036
|
+
dispose: [],
|
|
2037
|
+
get: [],
|
|
2038
|
+
set: [],
|
|
2039
|
+
reset: [],
|
|
2040
|
+
};
|
|
2041
|
+
const reset = () => {
|
|
2042
|
+
states = new Map(Object.entries(defaultState !== null && defaultState !== void 0 ? defaultState : {}));
|
|
2043
|
+
handlers.reset.forEach((cb) => cb());
|
|
2044
|
+
};
|
|
2045
|
+
const dispose = () => {
|
|
2046
|
+
// Call first dispose as resetting the state would
|
|
2047
|
+
// cause less updates ;)
|
|
2048
|
+
handlers.dispose.forEach((cb) => cb());
|
|
2049
|
+
reset();
|
|
2050
|
+
};
|
|
2051
|
+
const get = (propName) => {
|
|
2052
|
+
handlers.get.forEach((cb) => cb(propName));
|
|
2053
|
+
return states.get(propName);
|
|
2054
|
+
};
|
|
2055
|
+
const set = (propName, value) => {
|
|
2056
|
+
const oldValue = states.get(propName);
|
|
2057
|
+
if (shouldUpdate(value, oldValue, propName)) {
|
|
2058
|
+
states.set(propName, value);
|
|
2059
|
+
handlers.set.forEach((cb) => cb(propName, value, oldValue));
|
|
2060
|
+
}
|
|
2061
|
+
};
|
|
2062
|
+
const state = (typeof Proxy === 'undefined'
|
|
2063
|
+
? {}
|
|
2064
|
+
: new Proxy(defaultState, {
|
|
2065
|
+
get(_, propName) {
|
|
2066
|
+
return get(propName);
|
|
2067
|
+
},
|
|
2068
|
+
ownKeys(_) {
|
|
2069
|
+
return Array.from(states.keys());
|
|
2070
|
+
},
|
|
2071
|
+
getOwnPropertyDescriptor() {
|
|
2072
|
+
return {
|
|
2073
|
+
enumerable: true,
|
|
2074
|
+
configurable: true,
|
|
2075
|
+
};
|
|
2076
|
+
},
|
|
2077
|
+
has(_, propName) {
|
|
2078
|
+
return states.has(propName);
|
|
2079
|
+
},
|
|
2080
|
+
set(_, propName, value) {
|
|
2081
|
+
set(propName, value);
|
|
2082
|
+
return true;
|
|
2083
|
+
},
|
|
2084
|
+
}));
|
|
2085
|
+
const on = (eventName, callback) => {
|
|
2086
|
+
handlers[eventName].push(callback);
|
|
2087
|
+
return () => {
|
|
2088
|
+
removeFromArray(handlers[eventName], callback);
|
|
2089
|
+
};
|
|
2090
|
+
};
|
|
2091
|
+
const onChange = (propName, cb) => {
|
|
2092
|
+
const unSet = on('set', (key, newValue) => {
|
|
2093
|
+
if (key === propName) {
|
|
2094
|
+
cb(newValue);
|
|
2095
|
+
}
|
|
2096
|
+
});
|
|
2097
|
+
const unReset = on('reset', () => cb(defaultState[propName]));
|
|
2098
|
+
return () => {
|
|
2099
|
+
unSet();
|
|
2100
|
+
unReset();
|
|
2101
|
+
};
|
|
2102
|
+
};
|
|
2103
|
+
const use = (...subscriptions) => {
|
|
2104
|
+
const unsubs = subscriptions.reduce((unsubs, subscription) => {
|
|
2105
|
+
if (subscription.set) {
|
|
2106
|
+
unsubs.push(on('set', subscription.set));
|
|
2107
|
+
}
|
|
2108
|
+
if (subscription.get) {
|
|
2109
|
+
unsubs.push(on('get', subscription.get));
|
|
2110
|
+
}
|
|
2111
|
+
if (subscription.reset) {
|
|
2112
|
+
unsubs.push(on('reset', subscription.reset));
|
|
2113
|
+
}
|
|
2114
|
+
if (subscription.dispose) {
|
|
2115
|
+
unsubs.push(on('dispose', subscription.dispose));
|
|
2116
|
+
}
|
|
2117
|
+
return unsubs;
|
|
2118
|
+
}, []);
|
|
2119
|
+
return () => unsubs.forEach((unsub) => unsub());
|
|
2120
|
+
};
|
|
2121
|
+
const forceUpdate = (key) => {
|
|
2122
|
+
const oldValue = states.get(key);
|
|
2123
|
+
handlers.set.forEach((cb) => cb(key, oldValue, oldValue));
|
|
2124
|
+
};
|
|
2125
|
+
return {
|
|
2126
|
+
state,
|
|
2127
|
+
get,
|
|
2128
|
+
set,
|
|
2129
|
+
on,
|
|
2130
|
+
onChange,
|
|
2131
|
+
use,
|
|
2132
|
+
dispose,
|
|
2133
|
+
reset,
|
|
2134
|
+
forceUpdate,
|
|
2135
|
+
};
|
|
2136
|
+
};
|
|
2137
|
+
const removeFromArray = (array, item) => {
|
|
2138
|
+
const index = array.indexOf(item);
|
|
2139
|
+
if (index >= 0) {
|
|
2140
|
+
array[index] = array[array.length - 1];
|
|
2141
|
+
array.length--;
|
|
2142
|
+
}
|
|
2143
|
+
};
|
|
2144
|
+
|
|
2145
|
+
const createStore = (defaultState, shouldUpdate) => {
|
|
2146
|
+
const map = createObservableMap(defaultState, shouldUpdate);
|
|
2147
|
+
map.use(stencilSubscription());
|
|
2148
|
+
return map;
|
|
2149
|
+
};
|
|
2150
|
+
|
|
2151
|
+
const getIdpUrl = () => prompt('Please enter your Identity Provider URL', 'http://localhost:3000');
|
|
2152
|
+
|
|
2153
|
+
const { state } = createStore({
|
|
2154
|
+
getIdpUrl,
|
|
2155
|
+
isLoggedIn: false,
|
|
2156
|
+
webId: '',
|
|
2157
|
+
});
|
|
2158
|
+
|
|
2159
|
+
const createPodOS = () => {
|
|
2160
|
+
// @ts-ignore
|
|
2161
|
+
return window.PodOS ? new window.PodOS.PodOS() : new Error('PodOS missing');
|
|
2162
|
+
};
|
|
2163
|
+
|
|
2164
|
+
const PosApp = class {
|
|
2165
|
+
constructor(hostRef) {
|
|
2166
|
+
index.registerInstance(this, hostRef);
|
|
2167
|
+
}
|
|
2168
|
+
componentWillLoad() {
|
|
2169
|
+
this.os = createPodOS();
|
|
2170
|
+
this.os.handleIncomingRedirect();
|
|
2171
|
+
this.os.trackSession(sessionInfo => {
|
|
2172
|
+
state.isLoggedIn = sessionInfo.isLoggedIn;
|
|
2173
|
+
state.webId = sessionInfo.webId;
|
|
2174
|
+
});
|
|
2175
|
+
}
|
|
2176
|
+
async consumeOs(event) {
|
|
2177
|
+
event.stopPropagation();
|
|
2178
|
+
event.detail(this.os);
|
|
2179
|
+
}
|
|
2180
|
+
render() {
|
|
2181
|
+
return (index.h("ion-app", null, index.h("slot", null)));
|
|
2182
|
+
}
|
|
2183
|
+
};
|
|
2184
|
+
|
|
2185
|
+
const PosDemoApp = class {
|
|
2186
|
+
constructor(hostRef) {
|
|
2187
|
+
index.registerInstance(this, hostRef);
|
|
2188
|
+
this.url = 'http://localhost:3000/alice/games/minecraft#it';
|
|
2189
|
+
}
|
|
2190
|
+
linkClicked(e) {
|
|
2191
|
+
this.url = e.detail;
|
|
2192
|
+
}
|
|
2193
|
+
render() {
|
|
2194
|
+
return (index.h("pos-app", null, index.h("ion-header", null, index.h("ion-toolbar", null, index.h("ion-title", { slot: "start" }, "pod os"), index.h("pos-login", null))), index.h("ion-content", { class: "ion-padding" }, index.h("pos-resource", { uri: this.url }, index.h("ion-grid", null, index.h("ion-row", null, index.h("ion-col", { size: "12", "size-sm": true }, index.h("ion-card", null, index.h("ion-card-header", null, index.h("img", { src: "https://upload.wikimedia.org/wikipedia/de/5/57/Minecraft_logo-SVG.svg" }), index.h("ion-card-subtitle", null, "VideoGame"), index.h("ion-card-title", null, index.h("pos-label", null))), index.h("ion-card-content", null, index.h("pos-description", null)))), index.h("ion-col", { size: "12", "size-sm": true }, index.h("pos-literals", null)), index.h("ion-col", { size: "12", "size-sm": true }, index.h("pos-relations", null)))))), index.h("ion-footer", null, index.h("ion-toolbar", null, index.h("ion-title", null, "Footer")))));
|
|
2195
|
+
}
|
|
2196
|
+
};
|
|
2197
|
+
|
|
2198
|
+
const PosDescription = class {
|
|
2199
|
+
constructor(hostRef) {
|
|
2200
|
+
index.registerInstance(this, hostRef);
|
|
2201
|
+
this.getResource = index.createEvent(this, "pod-os:resource", 7);
|
|
2202
|
+
this.setResource = async (resource) => {
|
|
2203
|
+
this.resource = resource;
|
|
2204
|
+
};
|
|
2205
|
+
}
|
|
2206
|
+
componentWillLoad() {
|
|
2207
|
+
this.getResource.emit(this.setResource);
|
|
2208
|
+
}
|
|
2209
|
+
render() {
|
|
2210
|
+
return this.resource ? this.resource.description() : null;
|
|
2211
|
+
}
|
|
2212
|
+
};
|
|
2213
|
+
|
|
2214
|
+
const PosLabel$1 = class {
|
|
2215
|
+
constructor(hostRef) {
|
|
2216
|
+
index.registerInstance(this, hostRef);
|
|
2217
|
+
this.getResource = index.createEvent(this, "pod-os:resource", 7);
|
|
2218
|
+
this.setResource = async (resource) => {
|
|
2219
|
+
this.resource = resource;
|
|
2220
|
+
};
|
|
2221
|
+
}
|
|
2222
|
+
componentWillLoad() {
|
|
2223
|
+
this.getResource.emit(this.setResource);
|
|
2224
|
+
}
|
|
2225
|
+
render() {
|
|
2226
|
+
return this.resource ? this.resource.label() : null;
|
|
2227
|
+
}
|
|
2228
|
+
};
|
|
2229
|
+
|
|
2230
|
+
const PosLiterals = class {
|
|
2231
|
+
constructor(hostRef) {
|
|
2232
|
+
index.registerInstance(this, hostRef);
|
|
2233
|
+
this.getResource = index.createEvent(this, "pod-os:resource", 7);
|
|
2234
|
+
this.data = [];
|
|
2235
|
+
this.setResource = async (resource) => {
|
|
2236
|
+
this.data = resource.literals();
|
|
2237
|
+
};
|
|
2238
|
+
}
|
|
2239
|
+
componentWillLoad() {
|
|
2240
|
+
this.getResource.emit(this.setResource);
|
|
2241
|
+
}
|
|
2242
|
+
render() {
|
|
2243
|
+
const items = this.data.map(it => (index.h("ion-item-group", null, index.h("ion-item-divider", null, index.h("ion-label", null, it.predicate)), it.values.map(value => (index.h("ion-item", null, index.h("ion-label", { class: "ion-text-wrap" }, value), ' '))))));
|
|
2244
|
+
return this.data.length > 0 ? index.h("ion-list", null, items) : null;
|
|
2245
|
+
}
|
|
2246
|
+
};
|
|
2247
|
+
|
|
2248
|
+
const PosLogin = class {
|
|
2249
|
+
constructor(hostRef) {
|
|
2250
|
+
index.registerInstance(this, hostRef);
|
|
2251
|
+
this.consumeOsEmitter = index.createEvent(this, "consumeOs", 7);
|
|
2252
|
+
this.setOs = async (os) => {
|
|
2253
|
+
this.os = os;
|
|
2254
|
+
};
|
|
2255
|
+
}
|
|
2256
|
+
componentWillLoad() {
|
|
2257
|
+
this.consumeOsEmitter.emit(this.setOs);
|
|
2258
|
+
}
|
|
2259
|
+
login() {
|
|
2260
|
+
const idp = state.getIdpUrl();
|
|
2261
|
+
this.os.login(idp);
|
|
2262
|
+
}
|
|
2263
|
+
logout() {
|
|
2264
|
+
this.os.logout();
|
|
2265
|
+
}
|
|
2266
|
+
render() {
|
|
2267
|
+
return (index.h(index.Host, null, state.isLoggedIn ? (index.h("pos-resource", { uri: state.webId }, index.h("pos-label", null))) : (''), !state.isLoggedIn && index.h("ion-button", { onClick: () => this.login() }, "Login"), state.isLoggedIn && index.h("ion-button", { onClick: () => this.logout() }, "Logout")));
|
|
2268
|
+
}
|
|
2269
|
+
};
|
|
2270
|
+
|
|
2271
|
+
const PosRelations = class {
|
|
2272
|
+
constructor(hostRef) {
|
|
2273
|
+
index.registerInstance(this, hostRef);
|
|
2274
|
+
this.getResource = index.createEvent(this, "pod-os:resource", 7);
|
|
2275
|
+
this.data = [];
|
|
2276
|
+
this.setResource = async (resource) => {
|
|
2277
|
+
this.data = resource.relations();
|
|
2278
|
+
};
|
|
2279
|
+
}
|
|
2280
|
+
componentWillLoad() {
|
|
2281
|
+
this.getResource.emit(this.setResource);
|
|
2282
|
+
}
|
|
2283
|
+
render() {
|
|
2284
|
+
const items = this.data.map(it => (index.h("ion-item-group", null, index.h("ion-item-divider", null, index.h("ion-label", null, it.predicate)), it.uris.map(uri => (index.h("pos-rich-link", { uri: uri }))))));
|
|
2285
|
+
return this.data.length > 0 ? index.h("ion-list", null, items) : null;
|
|
2286
|
+
}
|
|
2287
|
+
};
|
|
2288
|
+
|
|
2289
|
+
const PosResource = class {
|
|
2290
|
+
constructor(hostRef) {
|
|
2291
|
+
index.registerInstance(this, hostRef);
|
|
2292
|
+
this.consumeOsEmitter = index.createEvent(this, "consumeOs", 7);
|
|
2293
|
+
this.consumers = [];
|
|
2294
|
+
this.lazy = false;
|
|
2295
|
+
this.loading = true;
|
|
2296
|
+
this.setOs = async (os) => {
|
|
2297
|
+
this.os = os;
|
|
2298
|
+
};
|
|
2299
|
+
}
|
|
2300
|
+
componentWillLoad() {
|
|
2301
|
+
this.consumeOsEmitter.emit(this.setOs);
|
|
2302
|
+
}
|
|
2303
|
+
async provideResource(event) {
|
|
2304
|
+
event.stopPropagation();
|
|
2305
|
+
if (this.resource) {
|
|
2306
|
+
event.detail(this.resource);
|
|
2307
|
+
}
|
|
2308
|
+
this.consumers.push(event);
|
|
2309
|
+
}
|
|
2310
|
+
async loadResource() {
|
|
2311
|
+
await this.getResource(!this.lazy);
|
|
2312
|
+
}
|
|
2313
|
+
async fetch() {
|
|
2314
|
+
await this.getResource(true);
|
|
2315
|
+
}
|
|
2316
|
+
async getResource(fetch = false) {
|
|
2317
|
+
try {
|
|
2318
|
+
if (fetch) {
|
|
2319
|
+
this.loading = true;
|
|
2320
|
+
await this.os.fetch(this.uri);
|
|
2321
|
+
}
|
|
2322
|
+
this.resource = this.os.store.get(this.uri);
|
|
2323
|
+
this.consumers.forEach(consumer => {
|
|
2324
|
+
consumer.detail(this.resource);
|
|
2325
|
+
});
|
|
2326
|
+
}
|
|
2327
|
+
catch (err) {
|
|
2328
|
+
this.error = err;
|
|
2329
|
+
}
|
|
2330
|
+
finally {
|
|
2331
|
+
this.loading = false;
|
|
2332
|
+
}
|
|
2333
|
+
}
|
|
2334
|
+
render() {
|
|
2335
|
+
if (this.loading) {
|
|
2336
|
+
return index.h("ion-progress-bar", { type: "indeterminate" });
|
|
2337
|
+
}
|
|
2338
|
+
if (this.error) {
|
|
2339
|
+
return index.h("div", null, this.error.message);
|
|
2340
|
+
}
|
|
2341
|
+
return index.h("slot", null);
|
|
2342
|
+
}
|
|
2343
|
+
static get watchers() { return {
|
|
2344
|
+
"os": ["loadResource"],
|
|
2345
|
+
"uri": ["loadResource"]
|
|
2346
|
+
}; }
|
|
2347
|
+
};
|
|
2348
|
+
|
|
2349
|
+
const PosLabel = class {
|
|
2350
|
+
constructor(hostRef) {
|
|
2351
|
+
index.registerInstance(this, hostRef);
|
|
2352
|
+
this.linkEmitter = index.createEvent(this, "pod-os:link", 7);
|
|
2353
|
+
}
|
|
2354
|
+
render() {
|
|
2355
|
+
return (index.h("pos-resource", { lazy: true, uri: this.uri }, index.h("ion-item", { href: this.uri, onClick: e => {
|
|
2356
|
+
e.preventDefault();
|
|
2357
|
+
this.linkEmitter.emit(this.uri);
|
|
2358
|
+
} }, index.h("ion-label", null, index.h("h2", null, index.h("pos-label", null)), index.h("p", null, index.h("ion-label", { style: { maxWidth: '50rem' } }, index.h("pos-description", null))), index.h("p", null, index.h("a", { href: this.uri }, this.uri))))));
|
|
2359
|
+
}
|
|
2360
|
+
};
|
|
2361
|
+
|
|
2362
|
+
exports.ion_app = App;
|
|
2363
|
+
exports.ion_button = Button;
|
|
2364
|
+
exports.ion_card = Card;
|
|
2365
|
+
exports.ion_card_content = CardContent;
|
|
2366
|
+
exports.ion_card_header = CardHeader;
|
|
2367
|
+
exports.ion_card_subtitle = CardSubtitle;
|
|
2368
|
+
exports.ion_card_title = CardTitle;
|
|
2369
|
+
exports.ion_col = Col;
|
|
2370
|
+
exports.ion_content = Content;
|
|
2371
|
+
exports.ion_footer = Footer;
|
|
2372
|
+
exports.ion_grid = Grid;
|
|
2373
|
+
exports.ion_header = Header;
|
|
2374
|
+
exports.ion_icon = Icon;
|
|
2375
|
+
exports.ion_item = Item;
|
|
2376
|
+
exports.ion_item_divider = ItemDivider;
|
|
2377
|
+
exports.ion_item_group = ItemGroup;
|
|
2378
|
+
exports.ion_label = Label;
|
|
2379
|
+
exports.ion_list = List;
|
|
2380
|
+
exports.ion_progress_bar = ProgressBar;
|
|
2381
|
+
exports.ion_ripple_effect = RippleEffect;
|
|
2382
|
+
exports.ion_row = Row;
|
|
2383
|
+
exports.ion_title = ToolbarTitle;
|
|
2384
|
+
exports.ion_toolbar = Toolbar;
|
|
2385
|
+
exports.pos_app = PosApp;
|
|
2386
|
+
exports.pos_demo_app = PosDemoApp;
|
|
2387
|
+
exports.pos_description = PosDescription;
|
|
2388
|
+
exports.pos_label = PosLabel$1;
|
|
2389
|
+
exports.pos_literals = PosLiterals;
|
|
2390
|
+
exports.pos_login = PosLogin;
|
|
2391
|
+
exports.pos_relations = PosRelations;
|
|
2392
|
+
exports.pos_resource = PosResource;
|
|
2393
|
+
exports.pos_rich_link = PosLabel;
|