@pod-os/elements 0.25.2 → 0.25.3-rc.2f9e99a.0
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/dist/cjs/elements.cjs.js +1 -1
- package/dist/cjs/ion-badge_2.cjs.entry.js +92 -0
- package/dist/cjs/ion-badge_2.cjs.entry.js.map +1 -0
- package/dist/cjs/{ion-badge_8.cjs.entry.js → ion-card-title_6.cjs.entry.js} +3 -84
- package/dist/cjs/ion-card-title_6.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-card_34.cjs.entry.js +26 -26
- package/dist/cjs/ion-card_34.cjs.entry.js.map +1 -1
- package/dist/cjs/{ion-checkbox_6.cjs.entry.js → ion-checkbox_7.cjs.entry.js} +274 -1
- package/dist/cjs/ion-checkbox_7.cjs.entry.js.map +1 -0
- package/dist/cjs/{ion-input_2.cjs.entry.js → ion-input.cjs.entry.js} +1 -21
- package/dist/cjs/ion-input.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-note.cjs.entry.js +34 -0
- package/dist/cjs/ion-note.cjs.entry.js.map +1 -0
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/pos-app-generic.cjs.entry.js +1 -1
- package/dist/cjs/pos-app-generic.cjs.entry.js.map +1 -1
- package/dist/cjs/pos-app-rdf-document.cjs.entry.js +5 -1
- package/dist/cjs/pos-app-rdf-document.cjs.entry.js.map +1 -1
- package/dist/cjs/pos-container-contents.cjs.entry.js.map +1 -1
- package/dist/cjs/pos-container-item.cjs.entry.js +5 -1
- package/dist/cjs/pos-container-item.cjs.entry.js.map +1 -1
- package/dist/cjs/pos-document.cjs.entry.js +1 -1
- package/dist/cjs/pos-document.cjs.entry.js.map +1 -1
- package/dist/cjs/pos-predicate.cjs.entry.js +28 -0
- package/dist/cjs/pos-predicate.cjs.entry.js.map +1 -0
- package/dist/cjs/pos-relations_2.cjs.entry.js +2 -2
- package/dist/cjs/pos-relations_2.cjs.entry.js.map +1 -1
- package/dist/cjs/pos-subjects.cjs.entry.js +1 -1
- package/dist/cjs/pos-subjects.cjs.entry.js.map +1 -1
- package/dist/collection/apps/pos-app-browser/pos-app-browser.css +5 -4
- package/dist/collection/apps/pos-app-dashboard/pos-app-dashboard.css +0 -2
- package/dist/collection/apps/pos-app-dashboard/pos-example-resources/pos-example-resources.css +2 -2
- package/dist/collection/apps/pos-app-dashboard/pos-getting-started/pos-getting-started.css +2 -3
- package/dist/collection/apps/pos-app-generic/pos-app-generic.css +2 -1
- package/dist/collection/apps/pos-app-rdf-document/pos-app-rdf-document.css +39 -0
- package/dist/collection/apps/pos-app-rdf-document/pos-app-rdf-document.js +13 -2
- package/dist/collection/apps/pos-app-rdf-document/pos-app-rdf-document.js.map +1 -1
- package/dist/collection/apps/pos-app-settings/pos-app-settings.css +0 -2
- package/dist/collection/apps/pos-app-settings/pos-app-settings.js +1 -1
- package/dist/collection/apps/pos-app-settings/pos-setting-offline-cache/pos-setting-offline-cache.css +4 -2
- package/dist/collection/apps/pos-app-settings/pos-setting-offline-cache/pos-setting-offline-cache.js +1 -1
- package/dist/collection/components/pos-add-literal-value/pos-add-literal-value.css +15 -0
- package/dist/collection/components/pos-add-literal-value/pos-add-literal-value.js +2 -2
- package/dist/collection/components/pos-add-literal-value/pos-add-literal-value.js.map +1 -1
- package/dist/collection/components/pos-add-new-thing/pos-add-new-thing.js +1 -1
- package/dist/collection/components/pos-app/pos-app.js +1 -1
- package/dist/collection/components/pos-container-contents/pos-container-contents.css +1 -1
- package/dist/collection/components/pos-container-contents/pos-container-contents.js.map +1 -1
- package/dist/collection/components/pos-container-contents/pos-container-item.css +16 -0
- package/dist/collection/components/pos-container-contents/pos-container-item.js +11 -1
- package/dist/collection/components/pos-container-contents/pos-container-item.js.map +1 -1
- package/dist/collection/components/pos-dialog/pos-dialog.css +35 -3
- package/dist/collection/components/pos-dialog/pos-dialog.js +1 -1
- package/dist/collection/components/pos-document/pos-document.css +5 -8
- package/dist/collection/components/pos-error-toast/pos-error-toast.js +1 -1
- package/dist/collection/components/pos-literals/pos-literals.css +1 -1
- package/dist/collection/components/pos-literals/pos-literals.js +1 -1
- package/dist/collection/components/pos-login/pos-login.js +1 -1
- package/dist/collection/components/pos-login-form/pos-login-form.css +6 -3
- package/dist/collection/components/pos-login-form/pos-login-form.js +1 -1
- package/dist/collection/components/pos-navigation-bar/pos-navigation-bar.css +7 -10
- package/dist/collection/components/pos-navigation-bar/pos-navigation-bar.js +1 -1
- package/dist/collection/components/pos-new-thing-form/pos-new-thing-form.css +11 -6
- package/dist/collection/components/pos-new-thing-form/pos-new-thing-form.js +1 -1
- package/dist/collection/components/pos-relations/pos-relations.css +1 -1
- package/dist/collection/components/pos-reverse-relations/pos-reverse-relations.css +1 -1
- package/dist/collection/components/pos-rich-link/pos-rich-link.css +3 -3
- package/dist/collection/components/pos-rich-link/pos-rich-link.js +2 -2
- package/dist/collection/components/pos-router/pos-router.js +1 -1
- package/dist/collection/components/pos-select-term/pos-select-term.css +2 -0
- package/dist/collection/components/pos-select-term/pos-select-term.js +1 -1
- package/dist/collection/components/pos-subjects/pos-subjects.css +1 -1
- package/dist/components/ion-input.js +566 -1
- package/dist/components/ion-input.js.map +1 -1
- package/dist/components/pos-add-literal-value2.js +5 -11
- package/dist/components/pos-add-literal-value2.js.map +1 -1
- package/dist/components/pos-add-new-thing2.js +1 -1
- package/dist/components/pos-app-browser.js +1 -1
- package/dist/components/pos-app-browser.js.map +1 -1
- package/dist/components/pos-app-dashboard2.js +1 -1
- package/dist/components/pos-app-dashboard2.js.map +1 -1
- package/dist/components/pos-app-document-viewer.js +14 -20
- package/dist/components/pos-app-document-viewer.js.map +1 -1
- package/dist/components/pos-app-generic.js +11 -17
- package/dist/components/pos-app-generic.js.map +1 -1
- package/dist/components/pos-app-image-viewer.js +14 -20
- package/dist/components/pos-app-image-viewer.js.map +1 -1
- package/dist/components/pos-app-ldp-container.js +16 -34
- package/dist/components/pos-app-ldp-container.js.map +1 -1
- package/dist/components/pos-app-rdf-document.js +22 -47
- package/dist/components/pos-app-rdf-document.js.map +1 -1
- package/dist/components/pos-app-settings2.js +2 -2
- package/dist/components/pos-app-settings2.js.map +1 -1
- package/dist/components/pos-app2.js +1 -1
- package/dist/components/pos-container-contents2.js +8 -20
- package/dist/components/pos-container-contents2.js.map +1 -1
- package/dist/components/pos-container-item2.js +7 -21
- package/dist/components/pos-container-item2.js.map +1 -1
- package/dist/components/pos-dialog2.js +2 -2
- package/dist/components/pos-dialog2.js.map +1 -1
- package/dist/components/pos-document2.js +1 -1
- package/dist/components/pos-document2.js.map +1 -1
- package/dist/components/pos-error-toast2.js +1 -1
- package/dist/components/pos-example-resources2.js +1 -1
- package/dist/components/pos-example-resources2.js.map +1 -1
- package/dist/components/pos-getting-started2.js +1 -1
- package/dist/components/pos-getting-started2.js.map +1 -1
- package/dist/components/pos-literals2.js +4 -10
- package/dist/components/pos-literals2.js.map +1 -1
- package/dist/components/pos-login-form2.js +2 -2
- package/dist/components/pos-login-form2.js.map +1 -1
- package/dist/components/pos-login2.js +1 -1
- package/dist/components/pos-navigation-bar2.js +2 -2
- package/dist/components/pos-navigation-bar2.js.map +1 -1
- package/dist/components/pos-new-thing-form2.js +2 -2
- package/dist/components/pos-new-thing-form2.js.map +1 -1
- package/dist/components/pos-relations2.js +1 -1
- package/dist/components/pos-relations2.js.map +1 -1
- package/dist/components/pos-reverse-relations2.js +1 -1
- package/dist/components/pos-reverse-relations2.js.map +1 -1
- package/dist/components/pos-rich-link2.js +3 -3
- package/dist/components/pos-rich-link2.js.map +1 -1
- package/dist/components/pos-router2.js +1 -1
- package/dist/components/pos-select-term2.js +2 -2
- package/dist/components/pos-select-term2.js.map +1 -1
- package/dist/components/pos-setting-offline-cache2.js +2 -2
- package/dist/components/pos-setting-offline-cache2.js.map +1 -1
- package/dist/components/pos-subjects2.js +1 -1
- package/dist/components/pos-subjects2.js.map +1 -1
- package/dist/elements/elements.css +21 -1
- package/dist/elements/elements.esm.js +1 -1
- package/dist/elements/elements.esm.js.map +1 -1
- package/dist/elements/{p-714cb336.entry.js → p-00c0e726.entry.js} +2 -2
- package/dist/elements/{p-34d3ff03.js → p-09c0b7ec.js} +3 -3
- package/dist/elements/p-0c94ec29.entry.js +2 -0
- package/dist/elements/{p-abed69a9.entry.js.map → p-0c94ec29.entry.js.map} +1 -1
- package/dist/elements/p-10bbe079.entry.js +2 -0
- package/dist/elements/p-10bbe079.entry.js.map +1 -0
- package/dist/elements/{p-0ffd76fc.entry.js → p-133e29f8.entry.js} +2 -2
- package/dist/elements/{p-097747f2.entry.js → p-18e5369d.entry.js} +2 -2
- package/dist/elements/{p-b25dd1f1.js → p-19e2dbee.js} +3 -3
- package/dist/elements/{p-a9df5a3a.entry.js → p-1d8d3167.entry.js} +2 -2
- package/dist/elements/{p-dcd16290.js → p-24118aa1.js} +3 -3
- package/dist/elements/p-248a0d89.entry.js +2 -0
- package/dist/elements/p-248a0d89.entry.js.map +1 -0
- package/dist/elements/{p-e11f2e70.entry.js → p-2543ef78.entry.js} +8 -8
- package/dist/elements/{p-e11f2e70.entry.js.map → p-2543ef78.entry.js.map} +1 -1
- package/dist/elements/{p-b725d322.entry.js → p-25b5a86a.entry.js} +2 -2
- package/dist/elements/{p-2d13e141.entry.js → p-27a5048e.entry.js} +2 -2
- package/dist/elements/{p-2d5448aa.entry.js → p-2cce9f72.entry.js} +2 -2
- package/dist/elements/{p-970fce25.entry.js → p-2d89b617.entry.js} +2 -2
- package/dist/elements/{p-66812011.entry.js → p-2e2753e7.entry.js} +2 -2
- package/dist/elements/{p-4cb77968.js → p-3856e0a0.js} +2 -2
- package/dist/elements/{p-e04e65b9.entry.js → p-3bc60b5c.entry.js} +2 -2
- package/dist/elements/{p-ec9d0fd2.entry.js → p-428e79f5.entry.js} +2 -2
- package/dist/elements/p-43d3f9dd.entry.js +2 -0
- package/dist/elements/p-43d3f9dd.entry.js.map +1 -0
- package/dist/elements/{p-62a60344.entry.js → p-489909a3.entry.js} +2 -2
- package/dist/elements/p-4c78c8c9.js +5 -0
- package/dist/elements/p-57740997.entry.js +2 -0
- package/dist/elements/{p-ec0d5d03.entry.js → p-58ad0789.entry.js} +2 -2
- package/dist/elements/{p-b250dee1.entry.js → p-616c23ad.entry.js} +3 -3
- package/dist/elements/{p-8b22dca0.entry.js → p-686bf509.entry.js} +2 -2
- package/dist/elements/{p-1c44ef41.entry.js → p-6bc1057e.entry.js} +2 -2
- package/dist/elements/{p-dcd0a40c.entry.js → p-7105c21a.entry.js} +2 -2
- package/dist/elements/{p-25270f1a.js → p-71ee259b.js} +2 -2
- package/dist/elements/{p-33b22cc6.entry.js → p-73331353.entry.js} +2 -2
- package/dist/elements/{p-df24c396.entry.js → p-77f496ea.entry.js} +2 -2
- package/dist/elements/p-7bef9b1b.entry.js +2 -0
- package/dist/elements/p-7bef9b1b.entry.js.map +1 -0
- package/dist/elements/{p-00c6a8f5.entry.js → p-849fec0f.entry.js} +2 -2
- package/dist/elements/{p-163e3e87.js → p-89aef852.js} +2 -2
- package/dist/elements/{p-a8afe4ef.entry.js → p-8c1eba2d.entry.js} +2 -2
- package/dist/elements/{p-d016e7e0.entry.js → p-8e747572.entry.js} +2 -2
- package/dist/elements/p-91fccb8b.entry.js +2 -0
- package/dist/elements/p-91fccb8b.entry.js.map +1 -0
- package/dist/elements/p-932de51e.js +8 -0
- package/dist/elements/{p-1df0edde.entry.js → p-93dc5bee.entry.js} +2 -2
- package/dist/elements/{p-20e2e8c1.js → p-949b115f.js} +2 -2
- package/dist/elements/p-983da5af.entry.js +2 -0
- package/dist/elements/p-983da5af.entry.js.map +1 -0
- package/dist/elements/{p-a3af481c.js → p-a03499f7.js} +2 -2
- package/dist/elements/{p-d0c67d7c.entry.js → p-a41edaa5.entry.js} +2 -2
- package/dist/elements/{p-34f376f2.entry.js → p-acf6cab4.entry.js} +2 -2
- package/dist/elements/{p-76351ab7.entry.js → p-ad55e9ab.entry.js} +2 -2
- package/dist/elements/p-b3117c79.entry.js +2 -0
- package/dist/elements/p-b3117c79.entry.js.map +1 -0
- package/dist/elements/{p-0cf27008.entry.js → p-b8363813.entry.js} +2 -2
- package/dist/elements/{p-da0cfe0c.entry.js → p-c13052f5.entry.js} +2 -2
- package/dist/elements/{p-bb3054a3.js → p-c191e6df.js} +8 -8
- package/dist/elements/{p-b9e14ed6.entry.js → p-c19ba914.entry.js} +4 -4
- package/dist/elements/{p-bcd11997.entry.js → p-c34f0243.entry.js} +2 -2
- package/dist/elements/p-c452a2e9.js +5 -0
- package/dist/elements/{p-1651e9a7.entry.js → p-c992243d.entry.js} +2 -2
- package/dist/elements/{p-592177e8.js → p-cbf050d6.js} +2 -2
- package/dist/elements/{p-3ab4f8b6.js → p-cdb96cf2.js} +2 -2
- package/dist/elements/p-d03f5902.entry.js +2 -0
- package/dist/elements/p-d03f5902.entry.js.map +1 -0
- package/dist/elements/{p-f7490d6e.js → p-d164af48.js} +2 -2
- package/dist/elements/{p-4d6e48bf.js → p-d1e7b393.js} +2 -2
- package/dist/elements/{p-6189fb02.entry.js → p-d7c83052.entry.js} +2 -2
- package/dist/elements/{p-59feb185.js → p-dd97c7d1.js} +3 -3
- package/dist/elements/p-e5ce5615.entry.js +5 -0
- package/dist/elements/p-e5ce5615.entry.js.map +1 -0
- package/dist/elements/p-e7a69dd3.entry.js +2 -0
- package/dist/elements/p-e7a69dd3.entry.js.map +1 -0
- package/dist/elements/p-eba70ed1.js +6 -0
- package/dist/elements/{p-ab68c761.entry.js → p-ef4ffce6.entry.js} +2 -2
- package/dist/elements/{p-04c9fe91.entry.js → p-ef87f5dd.entry.js} +2 -2
- package/dist/elements/{p-07df0400.entry.js → p-f74b9191.entry.js} +2 -2
- package/dist/elements/p-f74b9191.entry.js.map +1 -0
- package/dist/elements/{p-3e1b5fc4.entry.js → p-f9b993ab.entry.js} +4 -4
- package/dist/elements/p-fb766a59.entry.js.map +1 -1
- package/dist/elements/{p-925bb96a.entry.js → p-fd4ecbf1.entry.js} +2 -2
- package/dist/elements/p-fe4821db.entry.js +2 -0
- package/dist/elements/p-fe4821db.entry.js.map +1 -0
- package/dist/esm/{animation-8c622dae.js → animation-43b39c85.js} +2 -2
- package/dist/esm/{animation-8c622dae.js.map → animation-43b39c85.js.map} +1 -1
- package/dist/esm/elements.js +1 -1
- package/dist/esm/{form-controller-1f70ed52.js → form-controller-3b50bf52.js} +2 -2
- package/dist/esm/{form-controller-1f70ed52.js.map → form-controller-3b50bf52.js.map} +1 -1
- package/dist/esm/{framework-delegate-b5751311.js → framework-delegate-c5179013.js} +2 -2
- package/dist/esm/{framework-delegate-b5751311.js.map → framework-delegate-c5179013.js.map} +1 -1
- package/dist/esm/{helpers-a93a8cd2.js → helpers-c51da066.js} +2 -2
- package/dist/esm/{helpers-a93a8cd2.js.map → helpers-c51da066.js.map} +1 -1
- package/dist/esm/{index-432e7c6f.js → index-12e18dab.js} +2 -2
- package/dist/esm/{index-432e7c6f.js.map → index-12e18dab.js.map} +1 -1
- package/dist/esm/{index-f69a875d.js → index-842e2941.js} +2 -2
- package/dist/esm/{index-f69a875d.js.map → index-842e2941.js.map} +1 -1
- package/dist/esm/{index-2ac08fda.js → index-a753fbce.js} +4 -4
- package/dist/esm/{index-2ac08fda.js.map → index-a753fbce.js.map} +1 -1
- package/dist/esm/{index-d511bcdc.js → index-e268d85c.js} +3 -3
- package/dist/esm/{index-d511bcdc.js.map → index-e268d85c.js.map} +1 -1
- package/dist/esm/{input-shims-212ee02f.js → input-shims-0cb1bad1.js} +3 -3
- package/dist/esm/{input-shims-212ee02f.js.map → input-shims-0cb1bad1.js.map} +1 -1
- package/dist/esm/{input.utils-d2c917c3.js → input.utils-0e2bf61a.js} +2 -2
- package/dist/esm/{input.utils-d2c917c3.js.map → input.utils-0e2bf61a.js.map} +1 -1
- package/dist/esm/ion-accordion.entry.js +1 -1
- package/dist/esm/ion-action-sheet_3.entry.js +4 -4
- package/dist/esm/ion-app.entry.js +3 -3
- package/dist/esm/ion-back-button.entry.js +1 -1
- package/dist/esm/ion-badge_2.entry.js +87 -0
- package/dist/esm/ion-badge_2.entry.js.map +1 -0
- package/dist/esm/ion-breadcrumb.entry.js +1 -1
- package/dist/esm/ion-button_4.entry.js +1 -1
- package/dist/esm/{ion-badge_8.entry.js → ion-card-title_6.entry.js} +4 -83
- package/dist/esm/ion-card-title_6.entry.js.map +1 -0
- package/dist/esm/ion-card_34.entry.js +30 -30
- package/dist/esm/ion-card_34.entry.js.map +1 -1
- package/dist/esm/{ion-checkbox_6.entry.js → ion-checkbox_7.entry.js} +279 -7
- package/dist/esm/ion-checkbox_7.entry.js.map +1 -0
- package/dist/esm/ion-content.entry.js +1 -1
- package/dist/esm/ion-datetime-button.entry.js +1 -1
- package/dist/esm/ion-datetime.entry.js +1 -1
- package/dist/esm/ion-fab-button.entry.js +1 -1
- package/dist/esm/ion-footer.entry.js +2 -2
- package/dist/esm/ion-header.entry.js +2 -2
- package/dist/esm/ion-img.entry.js +1 -1
- package/dist/esm/ion-infinite-scroll.entry.js +2 -2
- package/dist/esm/{ion-input_2.entry.js → ion-input.entry.js} +6 -25
- package/dist/esm/ion-input.entry.js.map +1 -0
- package/dist/esm/ion-item-options.entry.js +1 -1
- package/dist/esm/ion-item-sliding.entry.js +2 -2
- package/dist/esm/ion-loading.entry.js +4 -4
- package/dist/esm/ion-menu-button.entry.js +4 -4
- package/dist/esm/ion-menu-toggle.entry.js +4 -4
- package/dist/esm/ion-menu.entry.js +5 -5
- package/dist/esm/ion-modal.entry.js +6 -6
- package/dist/esm/ion-nav.entry.js +4 -4
- package/dist/esm/ion-note.entry.js +30 -0
- package/dist/esm/ion-note.entry.js.map +1 -0
- package/dist/esm/ion-picker-column.entry.js +1 -1
- package/dist/esm/ion-picker.entry.js +4 -4
- package/dist/esm/ion-popover.entry.js +5 -5
- package/dist/esm/ion-range.entry.js +3 -3
- package/dist/esm/ion-refresher-content.entry.js +3 -3
- package/dist/esm/ion-refresher.entry.js +4 -4
- package/dist/esm/ion-reorder-group.entry.js +2 -2
- package/dist/esm/ion-router-outlet.entry.js +4 -4
- package/dist/esm/ion-router.entry.js +1 -1
- package/dist/esm/ion-segment-button.entry.js +1 -1
- package/dist/esm/ion-segment.entry.js +1 -1
- package/dist/esm/ion-select.entry.js +5 -5
- package/dist/esm/ion-tab-button.entry.js +1 -1
- package/dist/esm/ion-tab.entry.js +2 -2
- package/dist/esm/ion-textarea.entry.js +4 -4
- package/dist/esm/ion-toggle.entry.js +2 -2
- package/dist/esm/{ios.transition-82aca0a1.js → ios.transition-42a569f1.js} +4 -4
- package/dist/esm/{ios.transition-82aca0a1.js.map → ios.transition-42a569f1.js.map} +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/esm/{md.transition-8ab6c7b8.js → md.transition-646de6a5.js} +4 -4
- package/dist/esm/{md.transition-8ab6c7b8.js.map → md.transition-646de6a5.js.map} +1 -1
- package/dist/esm/{menu-toggle-util-1b366cd3.js → menu-toggle-util-8d0172e3.js} +2 -2
- package/dist/esm/{menu-toggle-util-1b366cd3.js.map → menu-toggle-util-8d0172e3.js.map} +1 -1
- package/dist/esm/{notch-controller-ae856621.js → notch-controller-79926902.js} +2 -2
- package/dist/esm/{notch-controller-ae856621.js.map → notch-controller-79926902.js.map} +1 -1
- package/dist/esm/{overlays-75a54062.js → overlays-4b3bb757.js} +3 -3
- package/dist/esm/{overlays-75a54062.js.map → overlays-4b3bb757.js.map} +1 -1
- package/dist/esm/pos-app-generic.entry.js +1 -1
- package/dist/esm/pos-app-generic.entry.js.map +1 -1
- package/dist/esm/pos-app-rdf-document.entry.js +6 -2
- package/dist/esm/pos-app-rdf-document.entry.js.map +1 -1
- package/dist/esm/pos-container-contents.entry.js.map +1 -1
- package/dist/esm/pos-container-item.entry.js +5 -1
- package/dist/esm/pos-container-item.entry.js.map +1 -1
- package/dist/esm/pos-document.entry.js +1 -1
- package/dist/esm/pos-document.entry.js.map +1 -1
- package/dist/esm/pos-predicate.entry.js +24 -0
- package/dist/esm/pos-predicate.entry.js.map +1 -0
- package/dist/esm/pos-relations_2.entry.js +2 -2
- package/dist/esm/pos-relations_2.entry.js.map +1 -1
- package/dist/esm/pos-subjects.entry.js +1 -1
- package/dist/esm/pos-subjects.entry.js.map +1 -1
- package/dist/esm/{refresher.utils-b1770bf3.js → refresher.utils-0e6b5f97.js} +3 -3
- package/dist/esm/{refresher.utils-b1770bf3.js.map → refresher.utils-0e6b5f97.js.map} +1 -1
- package/dist/esm/{status-tap-e14d7459.js → status-tap-e90a7a0d.js} +3 -3
- package/dist/esm/{status-tap-e14d7459.js.map → status-tap-e90a7a0d.js.map} +1 -1
- package/dist/esm/{swipe-back-5993fe10.js → swipe-back-698e6532.js} +2 -2
- package/dist/esm/{swipe-back-5993fe10.js.map → swipe-back-698e6532.js.map} +1 -1
- package/package.json +1 -1
- package/dist/cjs/ion-badge_8.cjs.entry.js.map +0 -1
- package/dist/cjs/ion-checkbox_6.cjs.entry.js.map +0 -1
- package/dist/cjs/ion-input_2.cjs.entry.js.map +0 -1
- package/dist/cjs/ion-item_2.cjs.entry.js +0 -309
- package/dist/cjs/ion-item_2.cjs.entry.js.map +0 -1
- package/dist/components/input.js +0 -570
- package/dist/components/input.js.map +0 -1
- package/dist/elements/p-06d453ad.entry.js +0 -2
- package/dist/elements/p-06d453ad.entry.js.map +0 -1
- package/dist/elements/p-07df0400.entry.js.map +0 -1
- package/dist/elements/p-305e6eb1.entry.js +0 -2
- package/dist/elements/p-305e6eb1.entry.js.map +0 -1
- package/dist/elements/p-39c3380c.entry.js +0 -2
- package/dist/elements/p-39c3380c.entry.js.map +0 -1
- package/dist/elements/p-7a563988.js +0 -5
- package/dist/elements/p-8206b1f1.js +0 -6
- package/dist/elements/p-a4b77d8f.entry.js +0 -2
- package/dist/elements/p-a4b77d8f.entry.js.map +0 -1
- package/dist/elements/p-abed69a9.entry.js +0 -2
- package/dist/elements/p-bed596af.entry.js +0 -2
- package/dist/elements/p-bed596af.entry.js.map +0 -1
- package/dist/elements/p-bfaa6328.entry.js +0 -2
- package/dist/elements/p-bfaa6328.entry.js.map +0 -1
- package/dist/elements/p-c2690129.js +0 -5
- package/dist/elements/p-ca453b3d.js +0 -8
- package/dist/elements/p-d80f77af.entry.js +0 -2
- package/dist/elements/p-defde894.entry.js +0 -2
- package/dist/elements/p-defde894.entry.js.map +0 -1
- package/dist/elements/p-e41c7c26.entry.js +0 -5
- package/dist/elements/p-e41c7c26.entry.js.map +0 -1
- package/dist/elements/p-f02106b8.entry.js +0 -2
- package/dist/elements/p-f02106b8.entry.js.map +0 -1
- package/dist/esm/ion-badge_8.entry.js.map +0 -1
- package/dist/esm/ion-checkbox_6.entry.js.map +0 -1
- package/dist/esm/ion-input_2.entry.js.map +0 -1
- package/dist/esm/ion-item_2.entry.js +0 -304
- package/dist/esm/ion-item_2.entry.js.map +0 -1
- /package/dist/elements/{p-714cb336.entry.js.map → p-00c0e726.entry.js.map} +0 -0
- /package/dist/elements/{p-34d3ff03.js.map → p-09c0b7ec.js.map} +0 -0
- /package/dist/elements/{p-0ffd76fc.entry.js.map → p-133e29f8.entry.js.map} +0 -0
- /package/dist/elements/{p-097747f2.entry.js.map → p-18e5369d.entry.js.map} +0 -0
- /package/dist/elements/{p-b25dd1f1.js.map → p-19e2dbee.js.map} +0 -0
- /package/dist/elements/{p-a9df5a3a.entry.js.map → p-1d8d3167.entry.js.map} +0 -0
- /package/dist/elements/{p-dcd16290.js.map → p-24118aa1.js.map} +0 -0
- /package/dist/elements/{p-b725d322.entry.js.map → p-25b5a86a.entry.js.map} +0 -0
- /package/dist/elements/{p-2d13e141.entry.js.map → p-27a5048e.entry.js.map} +0 -0
- /package/dist/elements/{p-2d5448aa.entry.js.map → p-2cce9f72.entry.js.map} +0 -0
- /package/dist/elements/{p-970fce25.entry.js.map → p-2d89b617.entry.js.map} +0 -0
- /package/dist/elements/{p-66812011.entry.js.map → p-2e2753e7.entry.js.map} +0 -0
- /package/dist/elements/{p-4cb77968.js.map → p-3856e0a0.js.map} +0 -0
- /package/dist/elements/{p-e04e65b9.entry.js.map → p-3bc60b5c.entry.js.map} +0 -0
- /package/dist/elements/{p-ec9d0fd2.entry.js.map → p-428e79f5.entry.js.map} +0 -0
- /package/dist/elements/{p-62a60344.entry.js.map → p-489909a3.entry.js.map} +0 -0
- /package/dist/elements/{p-c2690129.js.map → p-4c78c8c9.js.map} +0 -0
- /package/dist/elements/{p-d80f77af.entry.js.map → p-57740997.entry.js.map} +0 -0
- /package/dist/elements/{p-ec0d5d03.entry.js.map → p-58ad0789.entry.js.map} +0 -0
- /package/dist/elements/{p-b250dee1.entry.js.map → p-616c23ad.entry.js.map} +0 -0
- /package/dist/elements/{p-8b22dca0.entry.js.map → p-686bf509.entry.js.map} +0 -0
- /package/dist/elements/{p-1c44ef41.entry.js.map → p-6bc1057e.entry.js.map} +0 -0
- /package/dist/elements/{p-dcd0a40c.entry.js.map → p-7105c21a.entry.js.map} +0 -0
- /package/dist/elements/{p-25270f1a.js.map → p-71ee259b.js.map} +0 -0
- /package/dist/elements/{p-33b22cc6.entry.js.map → p-73331353.entry.js.map} +0 -0
- /package/dist/elements/{p-df24c396.entry.js.map → p-77f496ea.entry.js.map} +0 -0
- /package/dist/elements/{p-00c6a8f5.entry.js.map → p-849fec0f.entry.js.map} +0 -0
- /package/dist/elements/{p-163e3e87.js.map → p-89aef852.js.map} +0 -0
- /package/dist/elements/{p-a8afe4ef.entry.js.map → p-8c1eba2d.entry.js.map} +0 -0
- /package/dist/elements/{p-d016e7e0.entry.js.map → p-8e747572.entry.js.map} +0 -0
- /package/dist/elements/{p-ca453b3d.js.map → p-932de51e.js.map} +0 -0
- /package/dist/elements/{p-1df0edde.entry.js.map → p-93dc5bee.entry.js.map} +0 -0
- /package/dist/elements/{p-20e2e8c1.js.map → p-949b115f.js.map} +0 -0
- /package/dist/elements/{p-a3af481c.js.map → p-a03499f7.js.map} +0 -0
- /package/dist/elements/{p-d0c67d7c.entry.js.map → p-a41edaa5.entry.js.map} +0 -0
- /package/dist/elements/{p-34f376f2.entry.js.map → p-acf6cab4.entry.js.map} +0 -0
- /package/dist/elements/{p-76351ab7.entry.js.map → p-ad55e9ab.entry.js.map} +0 -0
- /package/dist/elements/{p-0cf27008.entry.js.map → p-b8363813.entry.js.map} +0 -0
- /package/dist/elements/{p-da0cfe0c.entry.js.map → p-c13052f5.entry.js.map} +0 -0
- /package/dist/elements/{p-bb3054a3.js.map → p-c191e6df.js.map} +0 -0
- /package/dist/elements/{p-b9e14ed6.entry.js.map → p-c19ba914.entry.js.map} +0 -0
- /package/dist/elements/{p-bcd11997.entry.js.map → p-c34f0243.entry.js.map} +0 -0
- /package/dist/elements/{p-7a563988.js.map → p-c452a2e9.js.map} +0 -0
- /package/dist/elements/{p-1651e9a7.entry.js.map → p-c992243d.entry.js.map} +0 -0
- /package/dist/elements/{p-592177e8.js.map → p-cbf050d6.js.map} +0 -0
- /package/dist/elements/{p-3ab4f8b6.js.map → p-cdb96cf2.js.map} +0 -0
- /package/dist/elements/{p-f7490d6e.js.map → p-d164af48.js.map} +0 -0
- /package/dist/elements/{p-4d6e48bf.js.map → p-d1e7b393.js.map} +0 -0
- /package/dist/elements/{p-6189fb02.entry.js.map → p-d7c83052.entry.js.map} +0 -0
- /package/dist/elements/{p-59feb185.js.map → p-dd97c7d1.js.map} +0 -0
- /package/dist/elements/{p-8206b1f1.js.map → p-eba70ed1.js.map} +0 -0
- /package/dist/elements/{p-ab68c761.entry.js.map → p-ef4ffce6.entry.js.map} +0 -0
- /package/dist/elements/{p-04c9fe91.entry.js.map → p-ef87f5dd.entry.js.map} +0 -0
- /package/dist/elements/{p-3e1b5fc4.entry.js.map → p-f9b993ab.entry.js.map} +0 -0
- /package/dist/elements/{p-925bb96a.entry.js.map → p-fd4ecbf1.entry.js.map} +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"file":"ion-input.pos-predicate.entry.js","mappings":"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","names":[],"sources":["../node_modules/@ionic/core/dist/collection/components/input/input.ios.css?tag=ion-input&mode=ios&encapsulation=scoped","../node_modules/@ionic/core/dist/collection/components/input/input.md.css?tag=ion-input&mode=md&encapsulation=scoped","../node_modules/@ionic/core/dist/collection/components/input/input.js","src/components/pos-predicate/pos-predicate.css?tag=pos-predicate&encapsulation=shadow","src/components/pos-predicate/pos-predicate.tsx"],"sourcesContent":["/**\n * Convert a font size to a dynamic font size.\n * Fonts that participate in Dynamic Type should use\n * dynamic font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param unit (optional) - The unit to convert to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a maximum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a minimum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * maximum and minimum font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n:host {\n /**\n * @prop --background: Background of the input\n *\n * @prop --color: Color of the input text\n *\n * @prop --padding-top: Top padding of the input\n * @prop --padding-end: Right padding if direction is left-to-right, and left padding if direction is right-to-left of the input\n * @prop --padding-bottom: Bottom padding of the input\n * @prop --padding-start: Left padding if direction is left-to-right, and right padding if direction is right-to-left of the input\n *\n * @prop --placeholder-color: Color of the input placeholder text\n * @prop --placeholder-font-style: Font style of the input placeholder text\n * @prop --placeholder-font-weight: Font weight of the input placeholder text\n * @prop --placeholder-opacity: Opacity of the input placeholder text\n *\n * @prop --highlight-color-focused: The color of the highlight on the input when focused\n * @prop --highlight-color-valid: The color of the highlight on the input when valid\n * @prop --highlight-color-invalid: The color of the highlight on the input when invalid\n *\n * @prop --border-color: Color of the border below the input when using helper text, error text, or counter\n * @prop --border-radius: Radius of the input. A large radius may display unevenly when using fill=\"outline\"; if needed, use shape=\"round\" instead or increase --padding-start.\n * @prop --border-style: Style of the border below the input when using helper text, error text, or counter\n * @prop --border-width: Width of the border below the input when using helper text, error text, or counter\n */\n --placeholder-color: initial;\n --placeholder-font-style: initial;\n --placeholder-font-weight: initial;\n --placeholder-opacity: 0.6;\n --padding-top: 0px;\n --padding-end: 0px;\n --padding-bottom: 0px;\n --padding-start: 0px;\n --background: transparent;\n --color: initial;\n --border-style: solid;\n --highlight-color-focused: var(--ion-color-primary, #3880ff);\n --highlight-color-valid: var(--ion-color-success, #2dd36f);\n --highlight-color-invalid: var(--ion-color-danger, #eb445a);\n /**\n * This is a private API that is used to switch\n * out the highlight color based on the state\n * of the component without having to write\n * different selectors for different fill variants.\n */\n --highlight-color: var(--highlight-color-focused);\n display: block;\n position: relative;\n width: 100%;\n /* stylelint-disable-next-line all */\n padding: 0 !important;\n color: var(--color);\n font-family: var(--ion-font-family, inherit);\n z-index: 2;\n}\n\n:host(.legacy-input) {\n display: flex;\n flex: 1;\n align-items: center;\n background: var(--background);\n}\n\n:host(.legacy-input) .native-input {\n -webkit-padding-start: var(--padding-start);\n padding-inline-start: var(--padding-start);\n -webkit-padding-end: var(--padding-end);\n padding-inline-end: var(--padding-end);\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n border-radius: var(--border-radius);\n}\n\n:host-context(ion-item:not(.item-label):not(.item-has-modern-input)) {\n --padding-start: 0;\n}\n\n:host-context(ion-item)[slot=start],\n:host-context(ion-item)[slot=end] {\n width: auto;\n}\n\n:host(.legacy-input.ion-color) {\n color: var(--ion-color-base);\n}\n\n:host(.ion-color) {\n --highlight-color-focused: var(--ion-color-base);\n}\n\n:host(:not(.legacy-input)) {\n min-height: 44px;\n}\n\n/**\n * Since the label sits on top of the element,\n * the component needs to be taller otherwise the\n * label will appear too close to the input text.\n */\n:host(.input-label-placement-floating),\n:host(.input-label-placement-stacked) {\n min-height: 56px;\n}\n\n.native-input {\n padding-left: 0;\n padding-right: 0;\n padding-top: 0;\n padding-bottom: 0;\n font-family: inherit;\n font-size: inherit;\n font-style: inherit;\n font-weight: inherit;\n letter-spacing: inherit;\n text-decoration: inherit;\n text-indent: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n text-align: inherit;\n white-space: inherit;\n color: inherit;\n display: inline-block;\n position: relative;\n flex: 1;\n width: 100%;\n max-width: 100%;\n max-height: 100%;\n border: 0;\n outline: none;\n background: transparent;\n box-sizing: border-box;\n appearance: none;\n /**\n * This ensures the input\n * remains on top of any decoration\n * that we render (particularly the\n * outline border when fill=\"outline\").\n * If we did not do this then Axe would\n * be unable to determine the color\n * contrast of the input.\n */\n z-index: 1;\n}\n.native-input::placeholder {\n color: var(--placeholder-color);\n font-family: inherit;\n font-style: var(--placeholder-font-style);\n font-weight: var(--placeholder-font-weight);\n opacity: var(--placeholder-opacity);\n}\n.native-input:-webkit-autofill {\n background-color: transparent;\n}\n.native-input:invalid {\n box-shadow: none;\n}\n.native-input::-ms-clear {\n display: none;\n}\n\n.cloned-input {\n top: 0;\n bottom: 0;\n position: absolute;\n pointer-events: none;\n}\n@supports (inset-inline-start: 0) {\n .cloned-input {\n inset-inline-start: 0;\n }\n}\n@supports not (inset-inline-start: 0) {\n .cloned-input {\n left: 0;\n }\n :host-context([dir=rtl]) .cloned-input {\n left: unset;\n right: unset;\n right: 0;\n }\n [dir=rtl] .cloned-input {\n left: unset;\n right: unset;\n right: 0;\n }\n @supports selector(:dir(rtl)) {\n .cloned-input:dir(rtl) {\n left: unset;\n right: unset;\n right: 0;\n }\n }\n}\n\n/**\n * The cloned input needs to be disabled on\n * Android otherwise the viewport will still\n * shift when running scroll assist.\n */\n.cloned-input:disabled {\n opacity: 1;\n}\n\n:host(.legacy-input) .input-clear-icon {\n margin-left: 0;\n margin-right: 0;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n.input-clear-icon {\n -webkit-margin-start: auto;\n margin-inline-start: auto;\n -webkit-margin-end: auto;\n margin-inline-end: auto;\n margin-top: auto;\n margin-bottom: auto;\n padding-left: 0;\n padding-right: 0;\n padding-top: 0;\n padding-bottom: 0;\n background-position: center;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 30px;\n height: 30px;\n border: 0;\n outline: none;\n background-color: transparent;\n background-repeat: no-repeat;\n color: var(--ion-color-step-600, #666666);\n visibility: hidden;\n appearance: none;\n}\n\n:host(.in-item-color) .input-clear-icon {\n color: inherit;\n}\n\n/**\n * Normally, we would not want to use :focus\n * here because that would mean tapping the button\n * on mobile would focus it (and keep it focused).\n * However, the clear button always disappears after\n * being activated, so we never get to that state.\n */\n.input-clear-icon:focus {\n opacity: 0.5;\n}\n\n:host(.has-value) .input-clear-icon {\n visibility: visible;\n}\n\n:host(.has-focus.legacy-input) {\n pointer-events: none;\n}\n\n:host(.has-focus.legacy-input) input,\n:host(.has-focus.legacy-input) a,\n:host(.has-focus.legacy-input) button {\n pointer-events: auto;\n}\n\n:host-context(.item-label-floating.item-has-placeholder:not(.item-has-value)) {\n opacity: 0;\n}\n\n:host-context(.item-label-floating.item-has-placeholder:not(.item-has-value).item-has-focus) {\n transition: opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1);\n opacity: 1;\n}\n\n.input-wrapper {\n -webkit-padding-start: var(--padding-start);\n padding-inline-start: var(--padding-start);\n -webkit-padding-end: var(--padding-end);\n padding-inline-end: var(--padding-end);\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n border-radius: var(--border-radius);\n display: flex;\n position: relative;\n flex-grow: 1;\n align-items: stretch;\n height: inherit;\n min-height: inherit;\n transition: background-color 15ms linear;\n background: var(--background);\n line-height: normal;\n}\n\n.native-wrapper {\n display: flex;\n position: relative;\n flex-grow: 1;\n align-items: center;\n width: 100%;\n}\n\n:host(.ion-touched.ion-invalid) {\n --highlight-color: var(--highlight-color-invalid);\n}\n\n/**\n * The component highlight is only shown\n * on focus, so we can safely set the valid\n * color state when valid. If we\n * set it when .has-focus is present then\n * the highlight color would change\n * from the valid color to the component's\n * color during the transition after the\n * component loses focus.\n */\n:host(.ion-valid) {\n --highlight-color: var(--highlight-color-valid);\n}\n\n.input-bottom {\n /**\n * The bottom content should take on the start and end\n * padding so it is always aligned with either the label\n * or the start of the text input.\n */\n -webkit-padding-start: var(--padding-start);\n padding-inline-start: var(--padding-start);\n -webkit-padding-end: var(--padding-end);\n padding-inline-end: var(--padding-end);\n padding-top: 5px;\n padding-bottom: 0;\n display: flex;\n justify-content: space-between;\n border-top: var(--border-width) var(--border-style) var(--border-color);\n font-size: 0.75rem;\n}\n\n/**\n * If the input has a validity state, the\n * border and label should reflect that as a color.\n * The invalid state should show if the input is\n * invalid and has already been touched.\n * The valid state should show if the input\n * is valid, has already been touched, and\n * is currently focused. Do not show the valid\n * highlight when the input is blurred.\n */\n:host(.has-focus.ion-valid),\n:host(.ion-touched.ion-invalid) {\n --border-color: var(--highlight-color);\n}\n\n/**\n * Error text should only be shown when .ion-invalid is\n * present on the input. Otherwise the helper text should\n * be shown.\n */\n.input-bottom .error-text {\n display: none;\n color: var(--highlight-color-invalid);\n}\n\n.input-bottom .helper-text {\n display: block;\n color: var(--ion-color-step-550, #737373);\n}\n\n:host(.ion-touched.ion-invalid) .input-bottom .error-text {\n display: block;\n}\n\n:host(.ion-touched.ion-invalid) .input-bottom .helper-text {\n display: none;\n}\n\n.input-bottom .counter {\n /**\n * Counter should always be at\n * the end of the container even\n * when no helper/error texts are used.\n */\n -webkit-margin-start: auto;\n margin-inline-start: auto;\n color: var(--ion-color-step-550, #737373);\n white-space: nowrap;\n padding-inline-start: 16px;\n}\n\n:host(.has-focus) input {\n caret-color: var(--highlight-color);\n}\n\n.label-text-wrapper {\n /**\n * This causes the label to take up\n * the entire height of its container\n * while still keeping the text centered.\n */\n display: flex;\n align-items: center;\n /**\n * Label text should not extend\n * beyond the bounds of the input.\n * However, we do not set the max\n * width to 100% because then\n * only the label would show and users\n * would not be able to see what they are typing.\n */\n max-width: 200px;\n transition: color 150ms cubic-bezier(0.4, 0, 0.2, 1), transform 150ms cubic-bezier(0.4, 0, 0.2, 1);\n /**\n * This ensures that double tapping this text\n * clicks the <label> and focuses the input\n * when a screen reader is enabled.\n */\n pointer-events: none;\n}\n\n/**\n * We need to use two elements instead of\n * one. The .label-text-wrapper is responsible\n * for centering the label text vertically regardless\n * of the input height using flexbox.\n *\n * The .label-text element is responsible for controlling\n * overflow when label-placement=\"fixed\".\n * We want the ellipses to show up when the\n * fixed label overflows, but text-overflow: ellipsis only\n * works on block-level elements. A flex item is\n * considered blockified (https://www.w3.org/TR/css-display-3/#blockify).\n */\n.label-text,\n::slotted([slot=label]) {\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n}\n\n/**\n * If no label text is placed into the slot\n * then the element should be hidden otherwise\n * there will be additional margins added.\n */\n.label-text-wrapper-hidden,\n.input-outline-notch-hidden {\n display: none;\n}\n\n.input-wrapper input {\n /**\n * When the floating label appears on top of the\n * input, we need to fade the input out so that the\n * label does not overlap with the placeholder.\n */\n transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1);\n}\n\n/**\n * Label is on the left of the input in LTR and\n * on the right in RTL.\n */\n:host(.input-label-placement-start) .input-wrapper {\n flex-direction: row;\n}\n\n:host(.input-label-placement-start) .label-text-wrapper {\n /**\n * The margin between the label and\n * the input should be on the end\n * when the label sits at the start.\n */\n -webkit-margin-start: 0;\n margin-inline-start: 0;\n -webkit-margin-end: 16px;\n margin-inline-end: 16px;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n/**\n * Label is on the right of the input in LTR and\n * on the left in RTL.\n */\n:host(.input-label-placement-end) .input-wrapper {\n flex-direction: row-reverse;\n}\n\n/**\n * The margin between the label and\n * the input should be on the start\n * when the label sits at the end.\n */\n:host(.input-label-placement-end) .label-text-wrapper {\n -webkit-margin-start: 16px;\n margin-inline-start: 16px;\n -webkit-margin-end: 0;\n margin-inline-end: 0;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n:host(.input-label-placement-fixed) .label-text-wrapper {\n /**\n * The margin between the label and\n * the input should be on the end\n * when the label sits at the start.\n */\n -webkit-margin-start: 0;\n margin-inline-start: 0;\n -webkit-margin-end: 16px;\n margin-inline-end: 16px;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n/**\n * Label is on the left of the input in LTR and\n * on the right in RTL. Label also has a fixed width.\n */\n:host(.input-label-placement-fixed) .label-text {\n flex: 0 0 100px;\n width: 100px;\n min-width: 100px;\n max-width: 200px;\n}\n\n/**\n * Stacked: Label sits above the input and is scaled down.\n * Floating: Label sits over the input when the input has no\n * value and is blurred. Label sits above the input and is scaled\n * down when the input is focused or has a value.\n *\n */\n:host(.input-label-placement-stacked) .input-wrapper,\n:host(.input-label-placement-floating) .input-wrapper {\n flex-direction: column;\n align-items: start;\n}\n\n/**\n * Ensures that the label animates\n * up and to the left in LTR or\n * up and to the right in RTL.\n */\n:host(.input-label-placement-stacked) .label-text-wrapper,\n:host(.input-label-placement-floating) .label-text-wrapper {\n transform-origin: left top;\n max-width: 100%;\n /**\n * The 2 ensures the label\n * remains on top of any browser\n * autofill background too.\n */\n z-index: 2;\n}\n:host-context([dir=rtl]):host(.input-label-placement-stacked) .label-text-wrapper, :host-context([dir=rtl]).input-label-placement-stacked .label-text-wrapper, :host-context([dir=rtl]):host(.input-label-placement-floating) .label-text-wrapper, :host-context([dir=rtl]).input-label-placement-floating .label-text-wrapper {\n transform-origin: right top;\n}\n\n@supports selector(:dir(rtl)) {\n :host(.input-label-placement-stacked:dir(rtl)) .label-text-wrapper, :host(.input-label-placement-floating:dir(rtl)) .label-text-wrapper {\n transform-origin: right top;\n }\n}\n\n/**\n * Ensures the input does not\n * overlap the label.\n */\n:host(.input-label-placement-stacked) input,\n:host(.input-label-placement-floating) input {\n margin-left: 0;\n margin-right: 0;\n margin-top: 1px;\n margin-bottom: 0;\n}\n\n/**\n * This makes the label sit over the input\n * when the input is blurred and has no value.\n */\n:host(.input-label-placement-floating) .label-text-wrapper {\n transform: translateY(100%) scale(1);\n}\n\n/**\n * The input should be hidden when the label\n * is on top of the input. This prevents the label\n * from overlapping any placeholder value.\n */\n:host(.input-label-placement-floating) input {\n opacity: 0;\n}\n\n:host(.has-focus.input-label-placement-floating) input,\n:host(.has-value.input-label-placement-floating) input {\n opacity: 1;\n}\n\n/**\n * This makes the label sit above the input.\n */\n:host(.label-floating) .label-text-wrapper {\n transform: translateY(50%) scale(0.75);\n /**\n * Label text should not extend\n * beyond the bounds of the input.\n */\n max-width: calc(100% / 0.75);\n}\n\n::slotted([slot=start]) {\n margin-inline-end: 16px;\n margin-inline-start: 0;\n}\n\n::slotted([slot=end]) {\n margin-inline-start: 16px;\n margin-inline-end: 0;\n}\n\n/**\n * Convert a font size to a dynamic font size.\n * Fonts that participate in Dynamic Type should use\n * dynamic font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param unit (optional) - The unit to convert to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a maximum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a minimum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * maximum and minimum font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n/**\n * Convert a font size to a dynamic font size.\n * Fonts that participate in Dynamic Type should use\n * dynamic font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param unit (optional) - The unit to convert to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a maximum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a minimum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * maximum and minimum font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n:host {\n --border-width: 0.55px;\n --border-color: var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, #c8c7cc)));\n font-size: inherit;\n}\n\n:host(.legacy-input) {\n --padding-top: 10px;\n --padding-end: 8px;\n --padding-bottom: 10px;\n --padding-start: 0;\n}\n\n:host-context(.item-label-stacked),\n:host-context(.item-label-floating) {\n --padding-top: 8px;\n --padding-bottom: 8px;\n --padding-start: 0px;\n}\n\n.input-clear-icon ion-icon {\n width: 18px;\n height: 18px;\n}\n\n:host(.legacy-input) .native-input[disabled],\n:host(.input-disabled) {\n opacity: 0.3;\n}\n\n/**\n * Slotted buttons have a lot of default padding that can\n * cause them to look misaligned from other pieces such\n * as the control's label, especially when using a clear\n * fill. We also make them circular to ensure that non-\n * clear buttons and the focus/hover state on clear ones\n * don't look too crowded.\n */\n::slotted(ion-button[slot=start].button-has-icon-only),\n::slotted(ion-button[slot=end].button-has-icon-only) {\n --border-radius: 50%;\n --padding-start: 0;\n --padding-end: 0;\n --padding-top: 0;\n --padding-bottom: 0;\n aspect-ratio: 1;\n}","/**\n * Convert a font size to a dynamic font size.\n * Fonts that participate in Dynamic Type should use\n * dynamic font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param unit (optional) - The unit to convert to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a maximum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a minimum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * maximum and minimum font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n:host {\n /**\n * @prop --background: Background of the input\n *\n * @prop --color: Color of the input text\n *\n * @prop --padding-top: Top padding of the input\n * @prop --padding-end: Right padding if direction is left-to-right, and left padding if direction is right-to-left of the input\n * @prop --padding-bottom: Bottom padding of the input\n * @prop --padding-start: Left padding if direction is left-to-right, and right padding if direction is right-to-left of the input\n *\n * @prop --placeholder-color: Color of the input placeholder text\n * @prop --placeholder-font-style: Font style of the input placeholder text\n * @prop --placeholder-font-weight: Font weight of the input placeholder text\n * @prop --placeholder-opacity: Opacity of the input placeholder text\n *\n * @prop --highlight-color-focused: The color of the highlight on the input when focused\n * @prop --highlight-color-valid: The color of the highlight on the input when valid\n * @prop --highlight-color-invalid: The color of the highlight on the input when invalid\n *\n * @prop --border-color: Color of the border below the input when using helper text, error text, or counter\n * @prop --border-radius: Radius of the input. A large radius may display unevenly when using fill=\"outline\"; if needed, use shape=\"round\" instead or increase --padding-start.\n * @prop --border-style: Style of the border below the input when using helper text, error text, or counter\n * @prop --border-width: Width of the border below the input when using helper text, error text, or counter\n */\n --placeholder-color: initial;\n --placeholder-font-style: initial;\n --placeholder-font-weight: initial;\n --placeholder-opacity: 0.6;\n --padding-top: 0px;\n --padding-end: 0px;\n --padding-bottom: 0px;\n --padding-start: 0px;\n --background: transparent;\n --color: initial;\n --border-style: solid;\n --highlight-color-focused: var(--ion-color-primary, #3880ff);\n --highlight-color-valid: var(--ion-color-success, #2dd36f);\n --highlight-color-invalid: var(--ion-color-danger, #eb445a);\n /**\n * This is a private API that is used to switch\n * out the highlight color based on the state\n * of the component without having to write\n * different selectors for different fill variants.\n */\n --highlight-color: var(--highlight-color-focused);\n display: block;\n position: relative;\n width: 100%;\n /* stylelint-disable-next-line all */\n padding: 0 !important;\n color: var(--color);\n font-family: var(--ion-font-family, inherit);\n z-index: 2;\n}\n\n:host(.legacy-input) {\n display: flex;\n flex: 1;\n align-items: center;\n background: var(--background);\n}\n\n:host(.legacy-input) .native-input {\n -webkit-padding-start: var(--padding-start);\n padding-inline-start: var(--padding-start);\n -webkit-padding-end: var(--padding-end);\n padding-inline-end: var(--padding-end);\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n border-radius: var(--border-radius);\n}\n\n:host-context(ion-item:not(.item-label):not(.item-has-modern-input)) {\n --padding-start: 0;\n}\n\n:host-context(ion-item)[slot=start],\n:host-context(ion-item)[slot=end] {\n width: auto;\n}\n\n:host(.legacy-input.ion-color) {\n color: var(--ion-color-base);\n}\n\n:host(.ion-color) {\n --highlight-color-focused: var(--ion-color-base);\n}\n\n:host(:not(.legacy-input)) {\n min-height: 44px;\n}\n\n/**\n * Since the label sits on top of the element,\n * the component needs to be taller otherwise the\n * label will appear too close to the input text.\n */\n:host(.input-label-placement-floating),\n:host(.input-label-placement-stacked) {\n min-height: 56px;\n}\n\n.native-input {\n padding-left: 0;\n padding-right: 0;\n padding-top: 0;\n padding-bottom: 0;\n font-family: inherit;\n font-size: inherit;\n font-style: inherit;\n font-weight: inherit;\n letter-spacing: inherit;\n text-decoration: inherit;\n text-indent: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n text-align: inherit;\n white-space: inherit;\n color: inherit;\n display: inline-block;\n position: relative;\n flex: 1;\n width: 100%;\n max-width: 100%;\n max-height: 100%;\n border: 0;\n outline: none;\n background: transparent;\n box-sizing: border-box;\n appearance: none;\n /**\n * This ensures the input\n * remains on top of any decoration\n * that we render (particularly the\n * outline border when fill=\"outline\").\n * If we did not do this then Axe would\n * be unable to determine the color\n * contrast of the input.\n */\n z-index: 1;\n}\n.native-input::placeholder {\n color: var(--placeholder-color);\n font-family: inherit;\n font-style: var(--placeholder-font-style);\n font-weight: var(--placeholder-font-weight);\n opacity: var(--placeholder-opacity);\n}\n.native-input:-webkit-autofill {\n background-color: transparent;\n}\n.native-input:invalid {\n box-shadow: none;\n}\n.native-input::-ms-clear {\n display: none;\n}\n\n.cloned-input {\n top: 0;\n bottom: 0;\n position: absolute;\n pointer-events: none;\n}\n@supports (inset-inline-start: 0) {\n .cloned-input {\n inset-inline-start: 0;\n }\n}\n@supports not (inset-inline-start: 0) {\n .cloned-input {\n left: 0;\n }\n :host-context([dir=rtl]) .cloned-input {\n left: unset;\n right: unset;\n right: 0;\n }\n [dir=rtl] .cloned-input {\n left: unset;\n right: unset;\n right: 0;\n }\n @supports selector(:dir(rtl)) {\n .cloned-input:dir(rtl) {\n left: unset;\n right: unset;\n right: 0;\n }\n }\n}\n\n/**\n * The cloned input needs to be disabled on\n * Android otherwise the viewport will still\n * shift when running scroll assist.\n */\n.cloned-input:disabled {\n opacity: 1;\n}\n\n:host(.legacy-input) .input-clear-icon {\n margin-left: 0;\n margin-right: 0;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n.input-clear-icon {\n -webkit-margin-start: auto;\n margin-inline-start: auto;\n -webkit-margin-end: auto;\n margin-inline-end: auto;\n margin-top: auto;\n margin-bottom: auto;\n padding-left: 0;\n padding-right: 0;\n padding-top: 0;\n padding-bottom: 0;\n background-position: center;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 30px;\n height: 30px;\n border: 0;\n outline: none;\n background-color: transparent;\n background-repeat: no-repeat;\n color: var(--ion-color-step-600, #666666);\n visibility: hidden;\n appearance: none;\n}\n\n:host(.in-item-color) .input-clear-icon {\n color: inherit;\n}\n\n/**\n * Normally, we would not want to use :focus\n * here because that would mean tapping the button\n * on mobile would focus it (and keep it focused).\n * However, the clear button always disappears after\n * being activated, so we never get to that state.\n */\n.input-clear-icon:focus {\n opacity: 0.5;\n}\n\n:host(.has-value) .input-clear-icon {\n visibility: visible;\n}\n\n:host(.has-focus.legacy-input) {\n pointer-events: none;\n}\n\n:host(.has-focus.legacy-input) input,\n:host(.has-focus.legacy-input) a,\n:host(.has-focus.legacy-input) button {\n pointer-events: auto;\n}\n\n:host-context(.item-label-floating.item-has-placeholder:not(.item-has-value)) {\n opacity: 0;\n}\n\n:host-context(.item-label-floating.item-has-placeholder:not(.item-has-value).item-has-focus) {\n transition: opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1);\n opacity: 1;\n}\n\n.input-wrapper {\n -webkit-padding-start: var(--padding-start);\n padding-inline-start: var(--padding-start);\n -webkit-padding-end: var(--padding-end);\n padding-inline-end: var(--padding-end);\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n border-radius: var(--border-radius);\n display: flex;\n position: relative;\n flex-grow: 1;\n align-items: stretch;\n height: inherit;\n min-height: inherit;\n transition: background-color 15ms linear;\n background: var(--background);\n line-height: normal;\n}\n\n.native-wrapper {\n display: flex;\n position: relative;\n flex-grow: 1;\n align-items: center;\n width: 100%;\n}\n\n:host(.ion-touched.ion-invalid) {\n --highlight-color: var(--highlight-color-invalid);\n}\n\n/**\n * The component highlight is only shown\n * on focus, so we can safely set the valid\n * color state when valid. If we\n * set it when .has-focus is present then\n * the highlight color would change\n * from the valid color to the component's\n * color during the transition after the\n * component loses focus.\n */\n:host(.ion-valid) {\n --highlight-color: var(--highlight-color-valid);\n}\n\n.input-bottom {\n /**\n * The bottom content should take on the start and end\n * padding so it is always aligned with either the label\n * or the start of the text input.\n */\n -webkit-padding-start: var(--padding-start);\n padding-inline-start: var(--padding-start);\n -webkit-padding-end: var(--padding-end);\n padding-inline-end: var(--padding-end);\n padding-top: 5px;\n padding-bottom: 0;\n display: flex;\n justify-content: space-between;\n border-top: var(--border-width) var(--border-style) var(--border-color);\n font-size: 0.75rem;\n}\n\n/**\n * If the input has a validity state, the\n * border and label should reflect that as a color.\n * The invalid state should show if the input is\n * invalid and has already been touched.\n * The valid state should show if the input\n * is valid, has already been touched, and\n * is currently focused. Do not show the valid\n * highlight when the input is blurred.\n */\n:host(.has-focus.ion-valid),\n:host(.ion-touched.ion-invalid) {\n --border-color: var(--highlight-color);\n}\n\n/**\n * Error text should only be shown when .ion-invalid is\n * present on the input. Otherwise the helper text should\n * be shown.\n */\n.input-bottom .error-text {\n display: none;\n color: var(--highlight-color-invalid);\n}\n\n.input-bottom .helper-text {\n display: block;\n color: var(--ion-color-step-550, #737373);\n}\n\n:host(.ion-touched.ion-invalid) .input-bottom .error-text {\n display: block;\n}\n\n:host(.ion-touched.ion-invalid) .input-bottom .helper-text {\n display: none;\n}\n\n.input-bottom .counter {\n /**\n * Counter should always be at\n * the end of the container even\n * when no helper/error texts are used.\n */\n -webkit-margin-start: auto;\n margin-inline-start: auto;\n color: var(--ion-color-step-550, #737373);\n white-space: nowrap;\n padding-inline-start: 16px;\n}\n\n:host(.has-focus) input {\n caret-color: var(--highlight-color);\n}\n\n.label-text-wrapper {\n /**\n * This causes the label to take up\n * the entire height of its container\n * while still keeping the text centered.\n */\n display: flex;\n align-items: center;\n /**\n * Label text should not extend\n * beyond the bounds of the input.\n * However, we do not set the max\n * width to 100% because then\n * only the label would show and users\n * would not be able to see what they are typing.\n */\n max-width: 200px;\n transition: color 150ms cubic-bezier(0.4, 0, 0.2, 1), transform 150ms cubic-bezier(0.4, 0, 0.2, 1);\n /**\n * This ensures that double tapping this text\n * clicks the <label> and focuses the input\n * when a screen reader is enabled.\n */\n pointer-events: none;\n}\n\n/**\n * We need to use two elements instead of\n * one. The .label-text-wrapper is responsible\n * for centering the label text vertically regardless\n * of the input height using flexbox.\n *\n * The .label-text element is responsible for controlling\n * overflow when label-placement=\"fixed\".\n * We want the ellipses to show up when the\n * fixed label overflows, but text-overflow: ellipsis only\n * works on block-level elements. A flex item is\n * considered blockified (https://www.w3.org/TR/css-display-3/#blockify).\n */\n.label-text,\n::slotted([slot=label]) {\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n}\n\n/**\n * If no label text is placed into the slot\n * then the element should be hidden otherwise\n * there will be additional margins added.\n */\n.label-text-wrapper-hidden,\n.input-outline-notch-hidden {\n display: none;\n}\n\n.input-wrapper input {\n /**\n * When the floating label appears on top of the\n * input, we need to fade the input out so that the\n * label does not overlap with the placeholder.\n */\n transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1);\n}\n\n/**\n * Label is on the left of the input in LTR and\n * on the right in RTL.\n */\n:host(.input-label-placement-start) .input-wrapper {\n flex-direction: row;\n}\n\n:host(.input-label-placement-start) .label-text-wrapper {\n /**\n * The margin between the label and\n * the input should be on the end\n * when the label sits at the start.\n */\n -webkit-margin-start: 0;\n margin-inline-start: 0;\n -webkit-margin-end: 16px;\n margin-inline-end: 16px;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n/**\n * Label is on the right of the input in LTR and\n * on the left in RTL.\n */\n:host(.input-label-placement-end) .input-wrapper {\n flex-direction: row-reverse;\n}\n\n/**\n * The margin between the label and\n * the input should be on the start\n * when the label sits at the end.\n */\n:host(.input-label-placement-end) .label-text-wrapper {\n -webkit-margin-start: 16px;\n margin-inline-start: 16px;\n -webkit-margin-end: 0;\n margin-inline-end: 0;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n:host(.input-label-placement-fixed) .label-text-wrapper {\n /**\n * The margin between the label and\n * the input should be on the end\n * when the label sits at the start.\n */\n -webkit-margin-start: 0;\n margin-inline-start: 0;\n -webkit-margin-end: 16px;\n margin-inline-end: 16px;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n/**\n * Label is on the left of the input in LTR and\n * on the right in RTL. Label also has a fixed width.\n */\n:host(.input-label-placement-fixed) .label-text {\n flex: 0 0 100px;\n width: 100px;\n min-width: 100px;\n max-width: 200px;\n}\n\n/**\n * Stacked: Label sits above the input and is scaled down.\n * Floating: Label sits over the input when the input has no\n * value and is blurred. Label sits above the input and is scaled\n * down when the input is focused or has a value.\n *\n */\n:host(.input-label-placement-stacked) .input-wrapper,\n:host(.input-label-placement-floating) .input-wrapper {\n flex-direction: column;\n align-items: start;\n}\n\n/**\n * Ensures that the label animates\n * up and to the left in LTR or\n * up and to the right in RTL.\n */\n:host(.input-label-placement-stacked) .label-text-wrapper,\n:host(.input-label-placement-floating) .label-text-wrapper {\n transform-origin: left top;\n max-width: 100%;\n /**\n * The 2 ensures the label\n * remains on top of any browser\n * autofill background too.\n */\n z-index: 2;\n}\n:host-context([dir=rtl]):host(.input-label-placement-stacked) .label-text-wrapper, :host-context([dir=rtl]).input-label-placement-stacked .label-text-wrapper, :host-context([dir=rtl]):host(.input-label-placement-floating) .label-text-wrapper, :host-context([dir=rtl]).input-label-placement-floating .label-text-wrapper {\n transform-origin: right top;\n}\n\n@supports selector(:dir(rtl)) {\n :host(.input-label-placement-stacked:dir(rtl)) .label-text-wrapper, :host(.input-label-placement-floating:dir(rtl)) .label-text-wrapper {\n transform-origin: right top;\n }\n}\n\n/**\n * Ensures the input does not\n * overlap the label.\n */\n:host(.input-label-placement-stacked) input,\n:host(.input-label-placement-floating) input {\n margin-left: 0;\n margin-right: 0;\n margin-top: 1px;\n margin-bottom: 0;\n}\n\n/**\n * This makes the label sit over the input\n * when the input is blurred and has no value.\n */\n:host(.input-label-placement-floating) .label-text-wrapper {\n transform: translateY(100%) scale(1);\n}\n\n/**\n * The input should be hidden when the label\n * is on top of the input. This prevents the label\n * from overlapping any placeholder value.\n */\n:host(.input-label-placement-floating) input {\n opacity: 0;\n}\n\n:host(.has-focus.input-label-placement-floating) input,\n:host(.has-value.input-label-placement-floating) input {\n opacity: 1;\n}\n\n/**\n * This makes the label sit above the input.\n */\n:host(.label-floating) .label-text-wrapper {\n transform: translateY(50%) scale(0.75);\n /**\n * Label text should not extend\n * beyond the bounds of the input.\n */\n max-width: calc(100% / 0.75);\n}\n\n::slotted([slot=start]) {\n margin-inline-end: 16px;\n margin-inline-start: 0;\n}\n\n::slotted([slot=end]) {\n margin-inline-start: 16px;\n margin-inline-end: 0;\n}\n\n/**\n * Convert a font size to a dynamic font size.\n * Fonts that participate in Dynamic Type should use\n * dynamic font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param unit (optional) - The unit to convert to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a maximum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a minimum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * maximum and minimum font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n/**\n * Convert a font size to a dynamic font size.\n * Fonts that participate in Dynamic Type should use\n * dynamic font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param unit (optional) - The unit to convert to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a maximum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a minimum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * maximum and minimum font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n/**\n * Convert a font size to a dynamic font size.\n * Fonts that participate in Dynamic Type should use\n * dynamic font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param unit (optional) - The unit to convert to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a maximum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a minimum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * maximum and minimum font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n:host(.input-fill-solid) {\n --background: var(--ion-color-step-50, #f2f2f2);\n --border-color: var(--ion-color-step-500, gray);\n --border-radius: 4px;\n --padding-start: 16px;\n --padding-end: 16px;\n min-height: 56px;\n}\n\n/**\n * The solid fill style has a border\n * at the bottom of the input wrapper.\n * As a result, the border on the \"bottom\n * content\" is not needed.\n */\n:host(.input-fill-solid) .input-wrapper {\n border-bottom: var(--border-width) var(--border-style) var(--border-color);\n}\n\n/**\n * If the input has a validity state, the\n * border should reflect that as a color.\n */\n:host(.has-focus.input-fill-solid.ion-valid),\n:host(.input-fill-solid.ion-touched.ion-invalid) {\n --border-color: var(--highlight-color);\n}\n\n:host(.input-fill-solid) .input-bottom {\n border-top: none;\n}\n\n/**\n * Background and border should be\n * slightly darker on hover.\n */\n@media (any-hover: hover) {\n :host(.input-fill-solid:hover) {\n --background: var(--ion-color-step-100, #e6e6e6);\n --border-color: var(--ion-color-step-750, #404040);\n }\n}\n/**\n * Background and border should be\n * much darker on focus.\n */\n:host(.input-fill-solid.has-focus) {\n --background: var(--ion-color-step-150, #d9d9d9);\n --border-color: var(--ion-color-step-750, #404040);\n}\n\n:host(.input-fill-solid) .input-wrapper {\n /**\n * Only the top left and top right borders should.\n * have a radius when using a solid fill.\n */\n border-top-left-radius: var(--border-radius);\n border-top-right-radius: var(--border-radius);\n border-bottom-right-radius: 0px;\n border-bottom-left-radius: 0px;\n}\n:host-context([dir=rtl]):host(.input-fill-solid) .input-wrapper, :host-context([dir=rtl]).input-fill-solid .input-wrapper {\n border-top-left-radius: var(--border-radius);\n border-top-right-radius: var(--border-radius);\n border-bottom-right-radius: 0px;\n border-bottom-left-radius: 0px;\n}\n\n@supports selector(:dir(rtl)) {\n :host(.input-fill-solid:dir(rtl)) .input-wrapper {\n border-top-left-radius: var(--border-radius);\n border-top-right-radius: var(--border-radius);\n border-bottom-right-radius: 0px;\n border-bottom-left-radius: 0px;\n }\n}\n\n:host(.label-floating.input-fill-solid.input-label-placement-floating) .label-text-wrapper {\n /**\n * Label text should not extend\n * beyond the bounds of the input.\n */\n max-width: calc(100% / 0.75);\n}\n\n/**\n * Convert a font size to a dynamic font size.\n * Fonts that participate in Dynamic Type should use\n * dynamic font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param unit (optional) - The unit to convert to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a maximum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a minimum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * maximum and minimum font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n:host(.input-fill-outline) {\n --border-color: var(--ion-color-step-300, #b3b3b3);\n --border-radius: 4px;\n --padding-start: 16px;\n --padding-end: 16px;\n min-height: 56px;\n}\n\n:host(.input-fill-outline.input-shape-round) {\n --border-radius: 28px;\n --padding-start: 32px;\n --padding-end: 32px;\n}\n\n/**\n * If the input has a validity state, the\n * border should reflect that as a color.\n */\n:host(.has-focus.input-fill-outline.ion-valid),\n:host(.input-fill-outline.ion-touched.ion-invalid) {\n --border-color: var(--highlight-color);\n}\n\n/**\n * Border should be\n * slightly darker on hover.\n */\n@media (any-hover: hover) {\n :host(.input-fill-outline:hover) {\n --border-color: var(--ion-color-step-750, #404040);\n }\n}\n/**\n * The border should get thicker\n * and take on component color when\n * the input is focused.\n */\n:host(.input-fill-outline.has-focus) {\n --border-width: 2px;\n --border-color: var(--highlight-color);\n}\n\n/**\n * The bottom content should never have\n * a border with the outline style.\n */\n:host(.input-fill-outline) .input-bottom {\n border-top: none;\n}\n\n/**\n * Outline inputs do not have a bottom border.\n * Instead, they have a border that wraps the\n * input + label.\n */\n:host(.input-fill-outline) .input-wrapper {\n border-bottom: none;\n}\n\n:host(.input-fill-outline.input-label-placement-stacked) .label-text-wrapper,\n:host(.input-fill-outline.input-label-placement-floating) .label-text-wrapper {\n transform-origin: left top;\n position: absolute;\n /**\n * Label text should not extend\n * beyond the bounds of the input.\n */\n max-width: calc(100% - var(--padding-start) - var(--padding-end));\n}\n:host-context([dir=rtl]):host(.input-fill-outline.input-label-placement-stacked) .label-text-wrapper, :host-context([dir=rtl]).input-fill-outline.input-label-placement-stacked .label-text-wrapper, :host-context([dir=rtl]):host(.input-fill-outline.input-label-placement-floating) .label-text-wrapper, :host-context([dir=rtl]).input-fill-outline.input-label-placement-floating .label-text-wrapper {\n transform-origin: right top;\n}\n\n@supports selector(:dir(rtl)) {\n :host(.input-fill-outline.input-label-placement-stacked:dir(rtl)) .label-text-wrapper, :host(.input-fill-outline.input-label-placement-floating:dir(rtl)) .label-text-wrapper {\n transform-origin: right top;\n }\n}\n\n/**\n * The label should appear on top of an outline\n * container that overlaps it so it is always clickable.\n */\n:host(.input-fill-outline) .label-text-wrapper,\n:host(.input-fill-outline) .label-text-wrapper {\n position: relative;\n}\n\n/**\n * This makes the label sit above the input.\n */\n:host(.label-floating.input-fill-outline) .label-text-wrapper {\n transform: translateY(-32%) scale(0.75);\n margin-left: 0;\n margin-right: 0;\n margin-top: 0;\n margin-bottom: 0;\n /**\n * Label text should not extend\n * beyond the bounds of the input.\n */\n max-width: calc((100% - var(--padding-start) - var(--padding-end) - 8px) / 0.75);\n}\n\n/**\n * This ensures that the input does not\n * overlap the floating label while still\n * remaining visually centered.\n */\n:host(.input-fill-outline.input-label-placement-stacked) input,\n:host(.input-fill-outline.input-label-placement-floating) input {\n margin-left: 0;\n margin-right: 0;\n margin-top: 6px;\n margin-bottom: 6px;\n}\n\n:host(.input-fill-outline) .input-outline-container {\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n display: flex;\n position: absolute;\n width: 100%;\n height: 100%;\n}\n\n:host(.input-fill-outline) .input-outline-start,\n:host(.input-fill-outline) .input-outline-end {\n pointer-events: none;\n}\n\n/**\n * By default, each piece of the container should have\n * a top and bottom border. This gives the appearance\n * of a unified container with a border.\n */\n:host(.input-fill-outline) .input-outline-start,\n:host(.input-fill-outline) .input-outline-notch,\n:host(.input-fill-outline) .input-outline-end {\n border-top: var(--border-width) var(--border-style) var(--border-color);\n border-bottom: var(--border-width) var(--border-style) var(--border-color);\n}\n\n/**\n * Ensures long labels do not cause the notch to flow\n * out of bounds.\n */\n:host(.input-fill-outline) .input-outline-notch {\n max-width: calc(100% - var(--padding-start) - var(--padding-end));\n}\n\n/**\n * This element ensures that the notch used\n * the size of the scaled text so that the\n * border cut out is the correct width.\n * The text in this element should not\n * be interactive.\n */\n:host(.input-fill-outline) .notch-spacer {\n /**\n * We need $input-md-floating-label-padding of padding on the right.\n * However, we also subtracted $input-md-floating-label-padding from\n * the width of .input-outline-start\n * to create space, so we need to take\n * that into consideration here.\n */\n -webkit-padding-end: 8px;\n padding-inline-end: 8px;\n font-size: calc(1em * 0.75);\n opacity: 0;\n pointer-events: none;\n /**\n * The spacer currently inherits\n * border-box sizing from the Ionic reset styles.\n * However, we do not want to include padding in\n * the calculation of the element dimensions.\n * This code can be removed if input is updated\n * to use the Shadow DOM.\n */\n box-sizing: content-box;\n}\n\n:host(.input-fill-outline) .input-outline-start {\n border-top-left-radius: var(--border-radius);\n border-top-right-radius: 0px;\n border-bottom-right-radius: 0px;\n border-bottom-left-radius: var(--border-radius);\n -webkit-border-start: var(--border-width) var(--border-style) var(--border-color);\n border-inline-start: var(--border-width) var(--border-style) var(--border-color);\n /**\n * There should be spacing between the translated text\n * and .input-outline-start. However, we can't add this\n * spacing onto the notch because it would cause the\n * label to look like it is not aligned with the\n * text input. Instead, we subtract a few pixels from\n * this element.\n */\n width: calc(var(--padding-start) - 4px);\n}\n:host-context([dir=rtl]):host(.input-fill-outline) .input-outline-start, :host-context([dir=rtl]).input-fill-outline .input-outline-start {\n border-top-left-radius: 0px;\n border-top-right-radius: var(--border-radius);\n border-bottom-right-radius: var(--border-radius);\n border-bottom-left-radius: 0px;\n}\n\n@supports selector(:dir(rtl)) {\n :host(.input-fill-outline:dir(rtl)) .input-outline-start {\n border-top-left-radius: 0px;\n border-top-right-radius: var(--border-radius);\n border-bottom-right-radius: var(--border-radius);\n border-bottom-left-radius: 0px;\n }\n}\n\n:host(.input-fill-outline) .input-outline-end {\n -webkit-border-end: var(--border-width) var(--border-style) var(--border-color);\n border-inline-end: var(--border-width) var(--border-style) var(--border-color);\n border-top-left-radius: 0px;\n border-top-right-radius: var(--border-radius);\n border-bottom-right-radius: var(--border-radius);\n border-bottom-left-radius: 0px;\n /**\n * The ending outline fragment\n * should take up the remaining free space.\n */\n flex-grow: 1;\n}\n:host-context([dir=rtl]):host(.input-fill-outline) .input-outline-end, :host-context([dir=rtl]).input-fill-outline .input-outline-end {\n border-top-left-radius: var(--border-radius);\n border-top-right-radius: 0px;\n border-bottom-right-radius: 0px;\n border-bottom-left-radius: var(--border-radius);\n}\n\n@supports selector(:dir(rtl)) {\n :host(.input-fill-outline:dir(rtl)) .input-outline-end {\n border-top-left-radius: var(--border-radius);\n border-top-right-radius: 0px;\n border-bottom-right-radius: 0px;\n border-bottom-left-radius: var(--border-radius);\n }\n}\n\n/**\n * When the input either has focus or a value,\n * there should be a \"cut out\" at the top for\n * the floating/stacked label. We simulate this \"cut out\"\n * by removing the top border from the notch fragment.\n */\n:host(.label-floating.input-fill-outline) .input-outline-notch {\n border-top: none;\n}\n\n/**\n * Convert a font size to a dynamic font size.\n * Fonts that participate in Dynamic Type should use\n * dynamic font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param unit (optional) - The unit to convert to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a maximum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * a minimum font size.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * Convert a font size to a dynamic font size but impose\n * maximum and minimum font sizes.\n * @param size - The initial font size including the unit (i.e. px or pt)\n * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).\n * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).\n * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to\n * convert to a unit other than $baselineUnit.\n */\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n:host {\n --border-width: 1px;\n --border-color: var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));\n font-size: inherit;\n}\n\n:host(.legacy-input) {\n --padding-top: 10px;\n --padding-end: 0;\n --padding-bottom: 10px;\n --padding-start: 8px;\n}\n\n:host-context(.item-label-stacked),\n:host-context(.item-label-floating) {\n --padding-top: 8px;\n --padding-bottom: 8px;\n --padding-start: 0;\n}\n\n.input-clear-icon ion-icon {\n width: 22px;\n height: 22px;\n}\n\n:host(.legacy-input) .native-input[disabled],\n:host(.input-disabled) {\n opacity: 0.38;\n}\n\n/**\n * If the input has a validity state, the\n * border and label should reflect that as a color.\n */\n:host(.has-focus.ion-valid),\n:host(.ion-touched.ion-invalid) {\n --border-color: var(--highlight-color);\n}\n\n.input-bottom .counter {\n letter-spacing: 0.0333333333em;\n}\n\n/**\n * When the input is focused the label should\n * take on the highlight color. This should\n * only apply to floating or stacked labels.\n */\n:host(.input-label-placement-floating.has-focus) .label-text-wrapper,\n:host(.input-label-placement-stacked.has-focus) .label-text-wrapper {\n color: var(--highlight-color);\n}\n\n:host(.has-focus.input-label-placement-floating.ion-valid) .label-text-wrapper,\n:host(.input-label-placement-floating.ion-touched.ion-invalid) .label-text-wrapper,\n:host(.has-focus.input-label-placement-stacked.ion-valid) .label-text-wrapper,\n:host(.input-label-placement-stacked.ion-touched.ion-invalid) .label-text-wrapper {\n color: var(--highlight-color);\n}\n\n.input-highlight {\n bottom: -1px;\n position: absolute;\n width: 100%;\n height: 2px;\n transform: scale(0);\n transition: transform 200ms;\n background: var(--highlight-color);\n}\n@supports (inset-inline-start: 0) {\n .input-highlight {\n inset-inline-start: 0;\n }\n}\n@supports not (inset-inline-start: 0) {\n .input-highlight {\n left: 0;\n }\n :host-context([dir=rtl]) .input-highlight {\n left: unset;\n right: unset;\n right: 0;\n }\n [dir=rtl] .input-highlight {\n left: unset;\n right: unset;\n right: 0;\n }\n @supports selector(:dir(rtl)) {\n .input-highlight:dir(rtl) {\n left: unset;\n right: unset;\n right: 0;\n }\n }\n}\n\n:host(.has-focus) .input-highlight {\n transform: scale(1);\n}\n\n/**\n * Adjust the highlight up by 1px\n * so it is not cut off by the\n * the item's line (if one is present).\n */\n:host(.in-item) .input-highlight {\n bottom: 0;\n}\n@supports (inset-inline-start: 0) {\n :host(.in-item) .input-highlight {\n inset-inline-start: 0;\n }\n}\n@supports not (inset-inline-start: 0) {\n :host(.in-item) .input-highlight {\n left: 0;\n }\n :host-context([dir=rtl]):host(.in-item) .input-highlight, :host-context([dir=rtl]).in-item .input-highlight {\n left: unset;\n right: unset;\n right: 0;\n }\n @supports selector(:dir(rtl)) {\n :host(.in-item:dir(rtl)) .input-highlight {\n left: unset;\n right: unset;\n right: 0;\n }\n }\n}\n\n:host(.input-shape-round) {\n --border-radius: 16px;\n}\n\n/**\n * Slotted buttons have a lot of default padding that can\n * cause them to look misaligned from other pieces such\n * as the control's label, especially when using a clear\n * fill. We also make them circular to ensure that non-\n * clear buttons and the focus/hover state on clear ones\n * don't look too crowded.\n */\n::slotted(ion-button[slot=start].button-has-icon-only),\n::slotted(ion-button[slot=end].button-has-icon-only) {\n --border-radius: 50%;\n --padding-start: 8px;\n --padding-end: 8px;\n --padding-top: 8px;\n --padding-bottom: 8px;\n aspect-ratio: 1;\n min-height: 40px;\n}","/*!\n * (C) Ionic http://ionicframework.com - MIT License\n */\nimport { Build, Host, forceUpdate, h } from \"@stencil/core\";\nimport { createLegacyFormController, createNotchController } from \"../../utils/forms/index\";\nimport { inheritAriaAttributes, debounceEvent, findItemLabel, inheritAttributes, componentOnReady, } from \"../../utils/helpers\";\nimport { printIonWarning } from \"../../utils/logging/index\";\nimport { createSlotMutationController } from \"../../utils/slot-mutation-controller\";\nimport { createColorClasses, hostContext } from \"../../utils/theme\";\nimport { closeCircle, closeSharp } from \"ionicons/icons\";\nimport { getIonMode } from \"../../global/ionic-global\";\nimport { getCounterText } from \"./input.utils\";\n/**\n * @virtualProp {\"ios\" | \"md\"} mode - The mode determines which platform styles to use.\n *\n * @slot label - The label text to associate with the input. Use the `labelPlacement` property to control where the label is placed relative to the input. Use this if you need to render a label with custom HTML. (EXPERIMENTAL)\n * @slot start - Content to display at the leading edge of the input. (EXPERIMENTAL)\n * @slot end - Content to display at the trailing edge of the input. (EXPERIMENTAL)\n */\nexport class Input {\n constructor() {\n this.inputId = `ion-input-${inputIds++}`;\n this.inheritedAttributes = {};\n this.isComposing = false;\n // This flag ensures we log the deprecation warning at most once.\n this.hasLoggedDeprecationWarning = false;\n /**\n * `true` if the input was cleared as a result of the user typing\n * with `clearOnEdit` enabled.\n *\n * Resets when the input loses focus.\n */\n this.didInputClearOnEdit = false;\n this.onInput = (ev) => {\n const input = ev.target;\n if (input) {\n this.value = input.value || '';\n }\n this.emitInputChange(ev);\n };\n this.onChange = (ev) => {\n this.emitValueChange(ev);\n };\n this.onBlur = (ev) => {\n this.hasFocus = false;\n this.emitStyle();\n if (this.focusedValue !== this.value) {\n /**\n * Emits the `ionChange` event when the input value\n * is different than the value when the input was focused.\n */\n this.emitValueChange(ev);\n }\n this.didInputClearOnEdit = false;\n this.ionBlur.emit(ev);\n };\n this.onFocus = (ev) => {\n this.hasFocus = true;\n this.focusedValue = this.value;\n this.emitStyle();\n this.ionFocus.emit(ev);\n };\n this.onKeydown = (ev) => {\n this.checkClearOnEdit(ev);\n };\n this.onCompositionStart = () => {\n this.isComposing = true;\n };\n this.onCompositionEnd = () => {\n this.isComposing = false;\n };\n this.clearTextInput = (ev) => {\n if (this.clearInput && !this.readonly && !this.disabled && ev) {\n ev.preventDefault();\n ev.stopPropagation();\n // Attempt to focus input again after pressing clear button\n this.setFocus();\n }\n this.value = '';\n this.emitInputChange(ev);\n };\n this.hasFocus = false;\n this.color = undefined;\n this.accept = undefined;\n this.autocapitalize = 'off';\n this.autocomplete = 'off';\n this.autocorrect = 'off';\n this.autofocus = false;\n this.clearInput = false;\n this.clearOnEdit = undefined;\n this.counter = false;\n this.counterFormatter = undefined;\n this.debounce = undefined;\n this.disabled = false;\n this.enterkeyhint = undefined;\n this.errorText = undefined;\n this.fill = undefined;\n this.inputmode = undefined;\n this.helperText = undefined;\n this.label = undefined;\n this.labelPlacement = 'start';\n this.legacy = undefined;\n this.max = undefined;\n this.maxlength = undefined;\n this.min = undefined;\n this.minlength = undefined;\n this.multiple = undefined;\n this.name = this.inputId;\n this.pattern = undefined;\n this.placeholder = undefined;\n this.readonly = false;\n this.required = false;\n this.shape = undefined;\n this.spellcheck = false;\n this.step = undefined;\n this.size = undefined;\n this.type = 'text';\n this.value = '';\n }\n debounceChanged() {\n const { ionInput, debounce, originalIonInput } = this;\n /**\n * If debounce is undefined, we have to manually revert the ionInput emitter in case\n * debounce used to be set to a number. Otherwise, the event would stay debounced.\n */\n this.ionInput = debounce === undefined ? originalIonInput !== null && originalIonInput !== void 0 ? originalIonInput : ionInput : debounceEvent(ionInput, debounce);\n }\n disabledChanged() {\n this.emitStyle();\n }\n /**\n * Update the item classes when the placeholder changes\n */\n placeholderChanged() {\n this.emitStyle();\n }\n /**\n * Update the native input element when the value changes\n */\n valueChanged() {\n const nativeInput = this.nativeInput;\n const value = this.getValue();\n if (nativeInput && nativeInput.value !== value && !this.isComposing) {\n /**\n * Assigning the native input's value on attribute\n * value change, allows `ionInput` implementations\n * to override the control's value.\n *\n * Used for patterns such as input trimming (removing whitespace),\n * or input masking.\n */\n nativeInput.value = value;\n }\n this.emitStyle();\n }\n componentWillLoad() {\n this.inheritedAttributes = Object.assign(Object.assign({}, inheritAriaAttributes(this.el)), inheritAttributes(this.el, ['tabindex', 'title', 'data-form-type']));\n }\n connectedCallback() {\n const { el } = this;\n this.legacyFormController = createLegacyFormController(el);\n this.slotMutationController = createSlotMutationController(el, ['label', 'start', 'end'], () => forceUpdate(this));\n this.notchController = createNotchController(el, () => this.notchSpacerEl, () => this.labelSlot);\n this.emitStyle();\n this.debounceChanged();\n if (Build.isBrowser) {\n document.dispatchEvent(new CustomEvent('ionInputDidLoad', {\n detail: this.el,\n }));\n }\n }\n componentDidLoad() {\n this.originalIonInput = this.ionInput;\n }\n componentDidRender() {\n var _a;\n (_a = this.notchController) === null || _a === void 0 ? void 0 : _a.calculateNotchWidth();\n }\n disconnectedCallback() {\n if (Build.isBrowser) {\n document.dispatchEvent(new CustomEvent('ionInputDidUnload', {\n detail: this.el,\n }));\n }\n if (this.slotMutationController) {\n this.slotMutationController.destroy();\n this.slotMutationController = undefined;\n }\n if (this.notchController) {\n this.notchController.destroy();\n this.notchController = undefined;\n }\n }\n /**\n * Sets focus on the native `input` in `ion-input`. Use this method instead of the global\n * `input.focus()`.\n *\n * Developers who wish to focus an input when a page enters\n * should call `setFocus()` in the `ionViewDidEnter()` lifecycle method.\n *\n * Developers who wish to focus an input when an overlay is presented\n * should call `setFocus` after `didPresent` has resolved.\n *\n * See [managing focus](/docs/developing/managing-focus) for more information.\n */\n async setFocus() {\n if (this.nativeInput) {\n this.nativeInput.focus();\n }\n }\n /**\n * Returns the native `<input>` element used under the hood.\n */\n async getInputElement() {\n /**\n * If this gets called in certain early lifecycle hooks (ex: Vue onMounted),\n * nativeInput won't be defined yet with the custom elements build, so wait for it to load in.\n */\n if (!this.nativeInput) {\n await new Promise((resolve) => componentOnReady(this.el, resolve));\n }\n return Promise.resolve(this.nativeInput);\n }\n /**\n * Emits an `ionChange` event.\n *\n * This API should be called for user committed changes.\n * This API should not be used for external value changes.\n */\n emitValueChange(event) {\n const { value } = this;\n // Checks for both null and undefined values\n const newValue = value == null ? value : value.toString();\n // Emitting a value change should update the internal state for tracking the focused value\n this.focusedValue = newValue;\n this.ionChange.emit({ value: newValue, event });\n }\n /**\n * Emits an `ionInput` event.\n */\n emitInputChange(event) {\n const { value } = this;\n // Checks for both null and undefined values\n const newValue = value == null ? value : value.toString();\n this.ionInput.emit({ value: newValue, event });\n }\n shouldClearOnEdit() {\n const { type, clearOnEdit } = this;\n return clearOnEdit === undefined ? type === 'password' : clearOnEdit;\n }\n getValue() {\n return typeof this.value === 'number' ? this.value.toString() : (this.value || '').toString();\n }\n emitStyle() {\n if (this.legacyFormController.hasLegacyControl()) {\n this.ionStyle.emit({\n interactive: true,\n input: true,\n 'has-placeholder': this.placeholder !== undefined,\n 'has-value': this.hasValue(),\n 'has-focus': this.hasFocus,\n 'interactive-disabled': this.disabled,\n // TODO(FW-2764): remove this\n legacy: !!this.legacy,\n });\n }\n }\n checkClearOnEdit(ev) {\n if (!this.shouldClearOnEdit()) {\n return;\n }\n /**\n * The following keys do not modify the\n * contents of the input. As a result, pressing\n * them should not edit the input.\n *\n * We can't check to see if the value of the input\n * was changed because we call checkClearOnEdit\n * in a keydown listener, and the key has not yet\n * been added to the input.\n */\n const IGNORED_KEYS = ['Enter', 'Tab', 'Shift', 'Meta', 'Alt', 'Control'];\n const pressedIgnoredKey = IGNORED_KEYS.includes(ev.key);\n /**\n * Clear the input if the control has not been previously cleared during focus.\n * Do not clear if the user hitting enter to submit a form.\n */\n if (!this.didInputClearOnEdit && this.hasValue() && !pressedIgnoredKey) {\n this.value = '';\n this.emitInputChange(ev);\n }\n /**\n * Pressing an IGNORED_KEYS first and\n * then an allowed key will cause the input to not\n * be cleared.\n */\n if (!pressedIgnoredKey) {\n this.didInputClearOnEdit = true;\n }\n }\n hasValue() {\n return this.getValue().length > 0;\n }\n /**\n * Renders the helper text or error text values\n */\n renderHintText() {\n const { helperText, errorText } = this;\n return [h(\"div\", { class: \"helper-text\" }, helperText), h(\"div\", { class: \"error-text\" }, errorText)];\n }\n renderCounter() {\n const { counter, maxlength, counterFormatter, value } = this;\n if (counter !== true || maxlength === undefined) {\n return;\n }\n return h(\"div\", { class: \"counter\" }, getCounterText(value, maxlength, counterFormatter));\n }\n /**\n * Responsible for rendering helper text,\n * error text, and counter. This element should only\n * be rendered if hint text is set or counter is enabled.\n */\n renderBottomContent() {\n const { counter, helperText, errorText, maxlength } = this;\n /**\n * undefined and empty string values should\n * be treated as not having helper/error text.\n */\n const hasHintText = !!helperText || !!errorText;\n const hasCounter = counter === true && maxlength !== undefined;\n if (!hasHintText && !hasCounter) {\n return;\n }\n return (h(\"div\", { class: \"input-bottom\" }, this.renderHintText(), this.renderCounter()));\n }\n renderLabel() {\n const { label } = this;\n return (h(\"div\", { class: {\n 'label-text-wrapper': true,\n 'label-text-wrapper-hidden': !this.hasLabel,\n } }, label === undefined ? h(\"slot\", { name: \"label\" }) : h(\"div\", { class: \"label-text\" }, label)));\n }\n /**\n * Gets any content passed into the `label` slot,\n * not the <slot> definition.\n */\n get labelSlot() {\n return this.el.querySelector('[slot=\"label\"]');\n }\n /**\n * Returns `true` if label content is provided\n * either by a prop or a content. If you want\n * to get the plaintext value of the label use\n * the `labelText` getter instead.\n */\n get hasLabel() {\n return this.label !== undefined || this.labelSlot !== null;\n }\n /**\n * Renders the border container\n * when fill=\"outline\".\n */\n renderLabelContainer() {\n const mode = getIonMode(this);\n const hasOutlineFill = mode === 'md' && this.fill === 'outline';\n if (hasOutlineFill) {\n /**\n * The outline fill has a special outline\n * that appears around the input and the label.\n * Certain stacked and floating label placements cause the\n * label to translate up and create a \"cut out\"\n * inside of that border by using the notch-spacer element.\n */\n return [\n h(\"div\", { class: \"input-outline-container\" }, h(\"div\", { class: \"input-outline-start\" }), h(\"div\", { class: {\n 'input-outline-notch': true,\n 'input-outline-notch-hidden': !this.hasLabel,\n } }, h(\"div\", { class: \"notch-spacer\", \"aria-hidden\": \"true\", ref: (el) => (this.notchSpacerEl = el) }, this.label)), h(\"div\", { class: \"input-outline-end\" })),\n this.renderLabel(),\n ];\n }\n /**\n * If not using the outline style,\n * we can render just the label.\n */\n return this.renderLabel();\n }\n renderInput() {\n const { disabled, fill, readonly, shape, inputId, labelPlacement, el, hasFocus } = this;\n const mode = getIonMode(this);\n const value = this.getValue();\n const inItem = hostContext('ion-item', this.el);\n const shouldRenderHighlight = mode === 'md' && fill !== 'outline' && !inItem;\n const hasValue = this.hasValue();\n const hasStartEndSlots = el.querySelector('[slot=\"start\"], [slot=\"end\"]') !== null;\n /**\n * If the label is stacked, it should always sit above the input.\n * For floating labels, the label should move above the input if\n * the input has a value, is focused, or has anything in either\n * the start or end slot.\n *\n * If there is content in the start slot, the label would overlap\n * it if not forced to float. This is also applied to the end slot\n * because with the default or solid fills, the input is not\n * vertically centered in the container, but the label is. This\n * causes the slots and label to appear vertically offset from each\n * other when the label isn't floating above the input. This doesn't\n * apply to the outline fill, but this was not accounted for to keep\n * things consistent.\n *\n * TODO(FW-5592): Remove hasStartEndSlots condition\n */\n const labelShouldFloat = labelPlacement === 'stacked' || (labelPlacement === 'floating' && (hasValue || hasFocus || hasStartEndSlots));\n return (h(Host, { class: createColorClasses(this.color, {\n [mode]: true,\n 'has-value': hasValue,\n 'has-focus': hasFocus,\n 'label-floating': labelShouldFloat,\n [`input-fill-${fill}`]: fill !== undefined,\n [`input-shape-${shape}`]: shape !== undefined,\n [`input-label-placement-${labelPlacement}`]: true,\n 'in-item': inItem,\n 'in-item-color': hostContext('ion-item.ion-color', this.el),\n 'input-disabled': disabled,\n }) }, h(\"label\", { class: \"input-wrapper\", htmlFor: inputId }, this.renderLabelContainer(), h(\"div\", { class: \"native-wrapper\" }, h(\"slot\", { name: \"start\" }), h(\"input\", Object.assign({ class: \"native-input\", ref: (input) => (this.nativeInput = input), id: inputId, disabled: disabled, accept: this.accept, autoCapitalize: this.autocapitalize, autoComplete: this.autocomplete, autoCorrect: this.autocorrect, autoFocus: this.autofocus, enterKeyHint: this.enterkeyhint, inputMode: this.inputmode, min: this.min, max: this.max, minLength: this.minlength, maxLength: this.maxlength, multiple: this.multiple, name: this.name, pattern: this.pattern, placeholder: this.placeholder || '', readOnly: readonly, required: this.required, spellcheck: this.spellcheck, step: this.step, size: this.size, type: this.type, value: value, onInput: this.onInput, onChange: this.onChange, onBlur: this.onBlur, onFocus: this.onFocus, onKeyDown: this.onKeydown, onCompositionstart: this.onCompositionStart, onCompositionend: this.onCompositionEnd }, this.inheritedAttributes)), this.clearInput && !readonly && !disabled && (h(\"button\", { \"aria-label\": \"reset\", type: \"button\", class: \"input-clear-icon\", onPointerDown: (ev) => {\n /**\n * This prevents mobile browsers from\n * blurring the input when the clear\n * button is activated.\n */\n ev.preventDefault();\n }, onFocusin: (ev) => {\n /**\n * Prevent the focusin event from bubbling otherwise it will cause the focusin\n * event listener in scroll assist to fire. When this fires, focus will be moved\n * back to the input even if the clear button was never tapped. This poses issues\n * for screen readers as it means users would be unable to swipe past the clear button.\n */\n ev.stopPropagation();\n }, onClick: this.clearTextInput }, h(\"ion-icon\", { \"aria-hidden\": \"true\", icon: mode === 'ios' ? closeCircle : closeSharp }))), h(\"slot\", { name: \"end\" })), shouldRenderHighlight && h(\"div\", { class: \"input-highlight\" })), this.renderBottomContent()));\n }\n // TODO FW-2764 Remove this\n renderLegacyInput() {\n if (!this.hasLoggedDeprecationWarning) {\n printIonWarning(`ion-input now requires providing a label with either the \"label\" property or the \"aria-label\" attribute. To migrate, remove any usage of \"ion-label\" and pass the label text to either the \"label\" property or the \"aria-label\" attribute.\n\nExample: <ion-input label=\"Email\"></ion-input>\nExample with aria-label: <ion-input aria-label=\"Email\"></ion-input>\n\nFor inputs that do not render the label immediately next to the input, developers may continue to use \"ion-label\" but must manually associate the label with the input by using \"aria-labelledby\".\n\nDevelopers can use the \"legacy\" property to continue using the legacy form markup. This property will be removed in an upcoming major release of Ionic where this form control will use the modern form markup.`, this.el);\n if (this.legacy) {\n printIonWarning(`ion-input is being used with the \"legacy\" property enabled which will forcibly enable the legacy form markup. This property will be removed in an upcoming major release of Ionic where this form control will use the modern form markup.\n\nDevelopers can dismiss this warning by removing their usage of the \"legacy\" property and using the new input syntax.`, this.el);\n }\n this.hasLoggedDeprecationWarning = true;\n }\n const mode = getIonMode(this);\n const value = this.getValue();\n const labelId = this.inputId + '-lbl';\n const label = findItemLabel(this.el);\n if (label) {\n label.id = labelId;\n }\n return (h(Host, { \"aria-disabled\": this.disabled ? 'true' : null, class: createColorClasses(this.color, {\n [mode]: true,\n 'has-value': this.hasValue(),\n 'has-focus': this.hasFocus,\n 'legacy-input': true,\n 'in-item-color': hostContext('ion-item.ion-color', this.el),\n }) }, h(\"input\", Object.assign({ class: \"native-input\", ref: (input) => (this.nativeInput = input), \"aria-labelledby\": label ? label.id : null, disabled: this.disabled, accept: this.accept, autoCapitalize: this.autocapitalize, autoComplete: this.autocomplete, autoCorrect: this.autocorrect, autoFocus: this.autofocus, enterKeyHint: this.enterkeyhint, inputMode: this.inputmode, min: this.min, max: this.max, minLength: this.minlength, maxLength: this.maxlength, multiple: this.multiple, name: this.name, pattern: this.pattern, placeholder: this.placeholder || '', readOnly: this.readonly, required: this.required, spellcheck: this.spellcheck, step: this.step, size: this.size, type: this.type, value: value, onInput: this.onInput, onChange: this.onChange, onBlur: this.onBlur, onFocus: this.onFocus, onKeyDown: this.onKeydown }, this.inheritedAttributes)), this.clearInput && !this.readonly && !this.disabled && (h(\"button\", { \"aria-label\": \"reset\", type: \"button\", class: \"input-clear-icon\", onPointerDown: (ev) => {\n /**\n * This prevents mobile browsers from\n * blurring the input when the clear\n * button is activated.\n */\n ev.preventDefault();\n }, onClick: this.clearTextInput }, h(\"ion-icon\", { \"aria-hidden\": \"true\", icon: mode === 'ios' ? closeCircle : closeSharp })))));\n }\n render() {\n const { legacyFormController } = this;\n return legacyFormController.hasLegacyControl() ? this.renderLegacyInput() : this.renderInput();\n }\n static get is() { return \"ion-input\"; }\n static get encapsulation() { return \"scoped\"; }\n static get originalStyleUrls() {\n return {\n \"ios\": [\"input.ios.scss\"],\n \"md\": [\"input.md.scss\"]\n };\n }\n static get styleUrls() {\n return {\n \"ios\": [\"input.ios.css\"],\n \"md\": [\"input.md.css\"]\n };\n }\n static get properties() {\n return {\n \"color\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"Color\",\n \"resolved\": \"\\\"danger\\\" | \\\"dark\\\" | \\\"light\\\" | \\\"medium\\\" | \\\"primary\\\" | \\\"secondary\\\" | \\\"success\\\" | \\\"tertiary\\\" | \\\"warning\\\" | string & Record<never, never> | undefined\",\n \"references\": {\n \"Color\": {\n \"location\": \"import\",\n \"path\": \"../../interface\",\n \"id\": \"src/interface.d.ts::Color\"\n }\n }\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The color to use from your application's color palette.\\nDefault options are: `\\\"primary\\\"`, `\\\"secondary\\\"`, `\\\"tertiary\\\"`, `\\\"success\\\"`, `\\\"warning\\\"`, `\\\"danger\\\"`, `\\\"light\\\"`, `\\\"medium\\\"`, and `\\\"dark\\\"`.\\nFor more information on colors, see [theming](/docs/theming/basics).\"\n },\n \"attribute\": \"color\",\n \"reflect\": true\n },\n \"accept\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string\",\n \"resolved\": \"string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [{\n \"name\": \"deprecated\",\n \"text\": undefined\n }],\n \"text\": \"This attribute is ignored.\"\n },\n \"attribute\": \"accept\",\n \"reflect\": false\n },\n \"autocapitalize\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string\",\n \"resolved\": \"string\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Indicates whether and how the text value should be automatically capitalized as it is entered/edited by the user.\\nAvailable options: `\\\"off\\\"`, `\\\"none\\\"`, `\\\"on\\\"`, `\\\"sentences\\\"`, `\\\"words\\\"`, `\\\"characters\\\"`.\"\n },\n \"attribute\": \"autocapitalize\",\n \"reflect\": false,\n \"defaultValue\": \"'off'\"\n },\n \"autocomplete\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"AutocompleteTypes\",\n \"resolved\": \"\\\"name\\\" | \\\"email\\\" | \\\"tel\\\" | \\\"url\\\" | \\\"on\\\" | \\\"off\\\" | \\\"honorific-prefix\\\" | \\\"given-name\\\" | \\\"additional-name\\\" | \\\"family-name\\\" | \\\"honorific-suffix\\\" | \\\"nickname\\\" | \\\"username\\\" | \\\"new-password\\\" | \\\"current-password\\\" | \\\"one-time-code\\\" | \\\"organization-title\\\" | \\\"organization\\\" | \\\"street-address\\\" | \\\"address-line1\\\" | \\\"address-line2\\\" | \\\"address-line3\\\" | \\\"address-level4\\\" | \\\"address-level3\\\" | \\\"address-level2\\\" | \\\"address-level1\\\" | \\\"country\\\" | \\\"country-name\\\" | \\\"postal-code\\\" | \\\"cc-name\\\" | \\\"cc-given-name\\\" | \\\"cc-additional-name\\\" | \\\"cc-family-name\\\" | \\\"cc-number\\\" | \\\"cc-exp\\\" | \\\"cc-exp-month\\\" | \\\"cc-exp-year\\\" | \\\"cc-csc\\\" | \\\"cc-type\\\" | \\\"transaction-currency\\\" | \\\"transaction-amount\\\" | \\\"language\\\" | \\\"bday\\\" | \\\"bday-day\\\" | \\\"bday-month\\\" | \\\"bday-year\\\" | \\\"sex\\\" | \\\"tel-country-code\\\" | \\\"tel-national\\\" | \\\"tel-area-code\\\" | \\\"tel-local\\\" | \\\"tel-extension\\\" | \\\"impp\\\" | \\\"photo\\\"\",\n \"references\": {\n \"AutocompleteTypes\": {\n \"location\": \"import\",\n \"path\": \"../../interface\",\n \"id\": \"src/interface.d.ts::AutocompleteTypes\"\n }\n }\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Indicates whether the value of the control can be automatically completed by the browser.\"\n },\n \"attribute\": \"autocomplete\",\n \"reflect\": false,\n \"defaultValue\": \"'off'\"\n },\n \"autocorrect\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"'on' | 'off'\",\n \"resolved\": \"\\\"off\\\" | \\\"on\\\"\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Whether auto correction should be enabled when the user is entering/editing the text value.\"\n },\n \"attribute\": \"autocorrect\",\n \"reflect\": false,\n \"defaultValue\": \"'off'\"\n },\n \"autofocus\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Sets the [`autofocus` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/autofocus) on the native input element.\\n\\nThis may not be sufficient for the element to be focused on page load. See [managing focus](/docs/developing/managing-focus) for more information.\"\n },\n \"attribute\": \"autofocus\",\n \"reflect\": false,\n \"defaultValue\": \"false\"\n },\n \"clearInput\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If `true`, a clear icon will appear in the input when there is a value. Clicking it clears the input.\"\n },\n \"attribute\": \"clear-input\",\n \"reflect\": false,\n \"defaultValue\": \"false\"\n },\n \"clearOnEdit\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If `true`, the value will be cleared after focus upon edit. Defaults to `true` when `type` is `\\\"password\\\"`, `false` for all other types.\"\n },\n \"attribute\": \"clear-on-edit\",\n \"reflect\": false\n },\n \"counter\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If `true`, a character counter will display the ratio of characters used and the total character limit. Developers must also set the `maxlength` property for the counter to be calculated correctly.\"\n },\n \"attribute\": \"counter\",\n \"reflect\": false,\n \"defaultValue\": \"false\"\n },\n \"counterFormatter\": {\n \"type\": \"unknown\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"(inputLength: number, maxLength: number) => string\",\n \"resolved\": \"((inputLength: number, maxLength: number) => string) | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"A callback used to format the counter text.\\nBy default the counter text is set to \\\"itemLength / maxLength\\\".\\n\\nSee https://ionicframework.com/docs/troubleshooting/runtime#accessing-this\\nif you need to access `this` from within the callback.\"\n }\n },\n \"debounce\": {\n \"type\": \"number\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"number\",\n \"resolved\": \"number | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Set the amount of time, in milliseconds, to wait to trigger the `ionInput` event after each keystroke.\"\n },\n \"attribute\": \"debounce\",\n \"reflect\": false\n },\n \"disabled\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If `true`, the user cannot interact with the input.\"\n },\n \"attribute\": \"disabled\",\n \"reflect\": false,\n \"defaultValue\": \"false\"\n },\n \"enterkeyhint\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"'enter' | 'done' | 'go' | 'next' | 'previous' | 'search' | 'send'\",\n \"resolved\": \"\\\"done\\\" | \\\"enter\\\" | \\\"go\\\" | \\\"next\\\" | \\\"previous\\\" | \\\"search\\\" | \\\"send\\\" | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"A hint to the browser for which enter key to display.\\nPossible values: `\\\"enter\\\"`, `\\\"done\\\"`, `\\\"go\\\"`, `\\\"next\\\"`,\\n`\\\"previous\\\"`, `\\\"search\\\"`, and `\\\"send\\\"`.\"\n },\n \"attribute\": \"enterkeyhint\",\n \"reflect\": false\n },\n \"errorText\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string\",\n \"resolved\": \"string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Text that is placed under the input and displayed when an error is detected.\"\n },\n \"attribute\": \"error-text\",\n \"reflect\": false\n },\n \"fill\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"'outline' | 'solid'\",\n \"resolved\": \"\\\"outline\\\" | \\\"solid\\\" | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The fill for the item. If `\\\"solid\\\"` the item will have a background. If\\n`\\\"outline\\\"` the item will be transparent with a border. Only available in `md` mode.\"\n },\n \"attribute\": \"fill\",\n \"reflect\": false\n },\n \"inputmode\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"'none' | 'text' | 'tel' | 'url' | 'email' | 'numeric' | 'decimal' | 'search'\",\n \"resolved\": \"\\\"decimal\\\" | \\\"email\\\" | \\\"none\\\" | \\\"numeric\\\" | \\\"search\\\" | \\\"tel\\\" | \\\"text\\\" | \\\"url\\\" | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"A hint to the browser for which keyboard to display.\\nPossible values: `\\\"none\\\"`, `\\\"text\\\"`, `\\\"tel\\\"`, `\\\"url\\\"`,\\n`\\\"email\\\"`, `\\\"numeric\\\"`, `\\\"decimal\\\"`, and `\\\"search\\\"`.\"\n },\n \"attribute\": \"inputmode\",\n \"reflect\": false\n },\n \"helperText\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string\",\n \"resolved\": \"string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Text that is placed under the input and displayed when no error is detected.\"\n },\n \"attribute\": \"helper-text\",\n \"reflect\": false\n },\n \"label\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string\",\n \"resolved\": \"string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The visible label associated with the input.\\n\\nUse this if you need to render a plaintext label.\\n\\nThe `label` property will take priority over the `label` slot if both are used.\"\n },\n \"attribute\": \"label\",\n \"reflect\": false\n },\n \"labelPlacement\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"'start' | 'end' | 'floating' | 'stacked' | 'fixed'\",\n \"resolved\": \"\\\"end\\\" | \\\"fixed\\\" | \\\"floating\\\" | \\\"stacked\\\" | \\\"start\\\"\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Where to place the label relative to the input.\\n`\\\"start\\\"`: The label will appear to the left of the input in LTR and to the right in RTL.\\n`\\\"end\\\"`: The label will appear to the right of the input in LTR and to the left in RTL.\\n`\\\"floating\\\"`: The label will appear smaller and above the input when the input is focused or it has a value. Otherwise it will appear on top of the input.\\n`\\\"stacked\\\"`: The label will appear smaller and above the input regardless even when the input is blurred or has no value.\\n`\\\"fixed\\\"`: The label has the same behavior as `\\\"start\\\"` except it also has a fixed width. Long text will be truncated with ellipses (\\\"...\\\").\"\n },\n \"attribute\": \"label-placement\",\n \"reflect\": false,\n \"defaultValue\": \"'start'\"\n },\n \"legacy\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Set the `legacy` property to `true` to forcibly use the legacy form control markup.\\nIonic will only opt components in to the modern form markup when they are\\nusing either the `aria-label` attribute or the `label` property. As a result,\\nthe `legacy` property should only be used as an escape hatch when you want to\\navoid this automatic opt-in behavior.\\nNote that this property will be removed in an upcoming major release\\nof Ionic, and all form components will be opted-in to using the modern form markup.\"\n },\n \"attribute\": \"legacy\",\n \"reflect\": false\n },\n \"max\": {\n \"type\": \"any\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string | number\",\n \"resolved\": \"number | string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The maximum value, which must not be less than its minimum (min attribute) value.\"\n },\n \"attribute\": \"max\",\n \"reflect\": false\n },\n \"maxlength\": {\n \"type\": \"number\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"number\",\n \"resolved\": \"number | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If the value of the type attribute is `text`, `email`, `search`, `password`, `tel`, or `url`, this attribute specifies the maximum number of characters that the user can enter.\"\n },\n \"attribute\": \"maxlength\",\n \"reflect\": false\n },\n \"min\": {\n \"type\": \"any\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string | number\",\n \"resolved\": \"number | string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The minimum value, which must not be greater than its maximum (max attribute) value.\"\n },\n \"attribute\": \"min\",\n \"reflect\": false\n },\n \"minlength\": {\n \"type\": \"number\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"number\",\n \"resolved\": \"number | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If the value of the type attribute is `text`, `email`, `search`, `password`, `tel`, or `url`, this attribute specifies the minimum number of characters that the user can enter.\"\n },\n \"attribute\": \"minlength\",\n \"reflect\": false\n },\n \"multiple\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If `true`, the user can enter more than one value. This attribute applies when the type attribute is set to `\\\"email\\\"`, otherwise it is ignored.\"\n },\n \"attribute\": \"multiple\",\n \"reflect\": false\n },\n \"name\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string\",\n \"resolved\": \"string\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The name of the control, which is submitted with the form data.\"\n },\n \"attribute\": \"name\",\n \"reflect\": false,\n \"defaultValue\": \"this.inputId\"\n },\n \"pattern\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string\",\n \"resolved\": \"string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"A regular expression that the value is checked against. The pattern must match the entire value, not just some subset. Use the title attribute to describe the pattern to help the user. This attribute applies when the value of the type attribute is `\\\"text\\\"`, `\\\"search\\\"`, `\\\"tel\\\"`, `\\\"url\\\"`, `\\\"email\\\"`, `\\\"date\\\"`, or `\\\"password\\\"`, otherwise it is ignored. When the type attribute is `\\\"date\\\"`, `pattern` will only be used in browsers that do not support the `\\\"date\\\"` input type natively. See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/date for more information.\"\n },\n \"attribute\": \"pattern\",\n \"reflect\": false\n },\n \"placeholder\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string\",\n \"resolved\": \"string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Instructional text that shows before the input has a value.\\nThis property applies only when the `type` property is set to `\\\"email\\\"`,\\n`\\\"number\\\"`, `\\\"password\\\"`, `\\\"search\\\"`, `\\\"tel\\\"`, `\\\"text\\\"`, or `\\\"url\\\"`, otherwise it is ignored.\"\n },\n \"attribute\": \"placeholder\",\n \"reflect\": false\n },\n \"readonly\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If `true`, the user cannot modify the value.\"\n },\n \"attribute\": \"readonly\",\n \"reflect\": false,\n \"defaultValue\": \"false\"\n },\n \"required\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If `true`, the user must fill in a value before submitting a form.\"\n },\n \"attribute\": \"required\",\n \"reflect\": false,\n \"defaultValue\": \"false\"\n },\n \"shape\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"'round'\",\n \"resolved\": \"\\\"round\\\" | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The shape of the input. If \\\"round\\\" it will have an increased border radius.\"\n },\n \"attribute\": \"shape\",\n \"reflect\": false\n },\n \"spellcheck\": {\n \"type\": \"boolean\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"boolean\",\n \"resolved\": \"boolean\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"If `true`, the element will have its spelling and grammar checked.\"\n },\n \"attribute\": \"spellcheck\",\n \"reflect\": false,\n \"defaultValue\": \"false\"\n },\n \"step\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"string\",\n \"resolved\": \"string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Works with the min and max attributes to limit the increments at which a value can be set.\\nPossible values are: `\\\"any\\\"` or a positive floating point number.\"\n },\n \"attribute\": \"step\",\n \"reflect\": false\n },\n \"size\": {\n \"type\": \"number\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"number\",\n \"resolved\": \"number | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"\"\n },\n \"attribute\": \"size\",\n \"reflect\": false\n },\n \"type\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"TextFieldTypes\",\n \"resolved\": \"\\\"date\\\" | \\\"datetime-local\\\" | \\\"email\\\" | \\\"month\\\" | \\\"number\\\" | \\\"password\\\" | \\\"search\\\" | \\\"tel\\\" | \\\"text\\\" | \\\"time\\\" | \\\"url\\\" | \\\"week\\\"\",\n \"references\": {\n \"TextFieldTypes\": {\n \"location\": \"import\",\n \"path\": \"../../interface\",\n \"id\": \"src/interface.d.ts::TextFieldTypes\"\n }\n }\n },\n \"required\": false,\n \"optional\": false,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The type of control to display. The default type is text.\"\n },\n \"attribute\": \"type\",\n \"reflect\": false,\n \"defaultValue\": \"'text'\"\n },\n \"value\": {\n \"type\": \"any\",\n \"mutable\": true,\n \"complexType\": {\n \"original\": \"string | number | null\",\n \"resolved\": \"null | number | string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The value of the input.\"\n },\n \"attribute\": \"value\",\n \"reflect\": false,\n \"defaultValue\": \"''\"\n }\n };\n }\n static get states() {\n return {\n \"hasFocus\": {}\n };\n }\n static get events() {\n return [{\n \"method\": \"ionInput\",\n \"name\": \"ionInput\",\n \"bubbles\": true,\n \"cancelable\": true,\n \"composed\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The `ionInput` event is fired each time the user modifies the input's value.\\nUnlike the `ionChange` event, the `ionInput` event is fired for each alteration\\nto the input's value. This typically happens for each keystroke as the user types.\\n\\nFor elements that accept text input (`type=text`, `type=tel`, etc.), the interface\\nis [`InputEvent`](https://developer.mozilla.org/en-US/docs/Web/API/InputEvent); for others,\\nthe interface is [`Event`](https://developer.mozilla.org/en-US/docs/Web/API/Event). If\\nthe input is cleared on edit, the type is `null`.\"\n },\n \"complexType\": {\n \"original\": \"InputInputEventDetail\",\n \"resolved\": \"InputInputEventDetail\",\n \"references\": {\n \"InputInputEventDetail\": {\n \"location\": \"import\",\n \"path\": \"./input-interface\",\n \"id\": \"src/components/input/input-interface.ts::InputInputEventDetail\"\n }\n }\n }\n }, {\n \"method\": \"ionChange\",\n \"name\": \"ionChange\",\n \"bubbles\": true,\n \"cancelable\": true,\n \"composed\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The `ionChange` event is fired when the user modifies the input's value.\\nUnlike the `ionInput` event, the `ionChange` event is only fired when changes\\nare committed, not as the user types.\\n\\nDepending on the way the users interacts with the element, the `ionChange`\\nevent fires at a different moment:\\n- When the user commits the change explicitly (e.g. by selecting a date\\nfrom a date picker for `<ion-input type=\\\"date\\\">`, pressing the \\\"Enter\\\" key, etc.).\\n- When the element loses focus after its value has changed: for elements\\nwhere the user's interaction is typing.\"\n },\n \"complexType\": {\n \"original\": \"InputChangeEventDetail\",\n \"resolved\": \"InputChangeEventDetail\",\n \"references\": {\n \"InputChangeEventDetail\": {\n \"location\": \"import\",\n \"path\": \"./input-interface\",\n \"id\": \"src/components/input/input-interface.ts::InputChangeEventDetail\"\n }\n }\n }\n }, {\n \"method\": \"ionBlur\",\n \"name\": \"ionBlur\",\n \"bubbles\": true,\n \"cancelable\": true,\n \"composed\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Emitted when the input loses focus.\"\n },\n \"complexType\": {\n \"original\": \"FocusEvent\",\n \"resolved\": \"FocusEvent\",\n \"references\": {\n \"FocusEvent\": {\n \"location\": \"global\",\n \"id\": \"global::FocusEvent\"\n }\n }\n }\n }, {\n \"method\": \"ionFocus\",\n \"name\": \"ionFocus\",\n \"bubbles\": true,\n \"cancelable\": true,\n \"composed\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Emitted when the input has focus.\"\n },\n \"complexType\": {\n \"original\": \"FocusEvent\",\n \"resolved\": \"FocusEvent\",\n \"references\": {\n \"FocusEvent\": {\n \"location\": \"global\",\n \"id\": \"global::FocusEvent\"\n }\n }\n }\n }, {\n \"method\": \"ionStyle\",\n \"name\": \"ionStyle\",\n \"bubbles\": true,\n \"cancelable\": true,\n \"composed\": true,\n \"docs\": {\n \"tags\": [{\n \"name\": \"internal\",\n \"text\": undefined\n }],\n \"text\": \"Emitted when the styles change.\"\n },\n \"complexType\": {\n \"original\": \"StyleEventDetail\",\n \"resolved\": \"StyleEventDetail\",\n \"references\": {\n \"StyleEventDetail\": {\n \"location\": \"import\",\n \"path\": \"../../interface\",\n \"id\": \"src/interface.d.ts::StyleEventDetail\"\n }\n }\n }\n }];\n }\n static get methods() {\n return {\n \"setFocus\": {\n \"complexType\": {\n \"signature\": \"() => Promise<void>\",\n \"parameters\": [],\n \"references\": {\n \"Promise\": {\n \"location\": \"global\",\n \"id\": \"global::Promise\"\n }\n },\n \"return\": \"Promise<void>\"\n },\n \"docs\": {\n \"text\": \"Sets focus on the native `input` in `ion-input`. Use this method instead of the global\\n`input.focus()`.\\n\\nDevelopers who wish to focus an input when a page enters\\nshould call `setFocus()` in the `ionViewDidEnter()` lifecycle method.\\n\\nDevelopers who wish to focus an input when an overlay is presented\\nshould call `setFocus` after `didPresent` has resolved.\\n\\nSee [managing focus](/docs/developing/managing-focus) for more information.\",\n \"tags\": []\n }\n },\n \"getInputElement\": {\n \"complexType\": {\n \"signature\": \"() => Promise<HTMLInputElement>\",\n \"parameters\": [],\n \"references\": {\n \"Promise\": {\n \"location\": \"global\",\n \"id\": \"global::Promise\"\n },\n \"HTMLInputElement\": {\n \"location\": \"global\",\n \"id\": \"global::HTMLInputElement\"\n }\n },\n \"return\": \"Promise<HTMLInputElement>\"\n },\n \"docs\": {\n \"text\": \"Returns the native `<input>` element used under the hood.\",\n \"tags\": []\n }\n }\n };\n }\n static get elementRef() { return \"el\"; }\n static get watchers() {\n return [{\n \"propName\": \"debounce\",\n \"methodName\": \"debounceChanged\"\n }, {\n \"propName\": \"disabled\",\n \"methodName\": \"disabledChanged\"\n }, {\n \"propName\": \"placeholder\",\n \"methodName\": \"placeholderChanged\"\n }, {\n \"propName\": \"value\",\n \"methodName\": \"valueChanged\"\n }];\n }\n}\nlet inputIds = 0;\n",":host {\n --text-color: var(--pos-primary-color);\n font-family: var(--font-sans);\n}\n\nbutton {\n line-height: var(--scale-0);\n font-family: inherit;\n margin: 0;\n padding: 0;\n display: flex;\n background: none;\n border: none;\n cursor: pointer;\n}\n\nbutton,\na {\n color: var(--text-color);\n font-weight: var(--weight-light);\n line-height: var(--scale-0);\n font-size: var(--scale-0);\n font-family: inherit;\n}\n\n.container {\n display: flex;\n gap: var(--size-1);\n flex-direction: row;\n align-items: center;\n line-height: var(--scale-0);\n}\n","import { Component, h, Prop, State } from '@stencil/core';\n\n@Component({\n tag: 'pos-predicate',\n shadow: true,\n styleUrl: './pos-predicate.css',\n})\nexport class PosPredicate {\n @Prop()\n uri: string;\n\n @Prop()\n label: string;\n\n @State()\n expanded: boolean = false;\n\n render() {\n if (this.expanded) {\n return (\n <div class=\"container\">\n <a href={this.uri}>{this.uri}</a>\n <button aria-label={`collapse URI to ${this.label}`} onClick={() => (this.expanded = false)}>\n <ion-icon name=\"chevron-back-circle-outline\"></ion-icon>\n </button>\n </div>\n );\n } else {\n return (\n <button onClick={() => (this.expanded = true)} title={this.uri}>\n {this.label}\n </button>\n );\n }\n }\n}\n"],"version":3}
|