@amwaljs/checkout-button 0.3.2 → 0.3.3
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/checkout/checkout.esm.js +2 -1
- package/dist/checkout/checkout.esm.js.map +1 -0
- package/dist/checkout/index.esm.js +2 -0
- package/dist/checkout/index.esm.js.map +1 -0
- package/dist/checkout/p-01ad898f.js +2 -1
- package/dist/checkout/p-01ad898f.js.map +1 -0
- package/dist/checkout/p-07356b55.entry.js +17 -0
- package/dist/checkout/p-07356b55.entry.js.map +1 -0
- package/dist/checkout/p-0992beec.entry.js +2 -0
- package/dist/checkout/p-0992beec.entry.js.map +1 -0
- package/dist/checkout/p-0c62eb68.entry.js +2 -0
- package/dist/checkout/p-0c62eb68.entry.js.map +1 -0
- package/dist/checkout/p-0db836ba.entry.js +2 -0
- package/dist/checkout/p-0db836ba.entry.js.map +1 -0
- package/dist/checkout/p-0ea6c36e.entry.js +20 -0
- package/dist/checkout/p-0ea6c36e.entry.js.map +1 -0
- package/dist/checkout/p-0f03cd28.js +3 -2
- package/dist/checkout/p-0f03cd28.js.map +1 -0
- package/dist/checkout/p-112455b1.js +2 -1
- package/dist/checkout/p-112455b1.js.map +1 -0
- package/dist/checkout/p-13245fd4.js +2 -1
- package/dist/checkout/p-13245fd4.js.map +1 -0
- package/dist/checkout/p-16f30bee.entry.js +5 -0
- package/dist/checkout/p-16f30bee.entry.js.map +1 -0
- package/dist/checkout/p-17dd911b.entry.js +2 -0
- package/dist/checkout/p-17dd911b.entry.js.map +1 -0
- package/dist/checkout/p-19c1876e.entry.js +5 -0
- package/dist/checkout/p-19c1876e.entry.js.map +1 -0
- package/dist/checkout/p-1bce3237.entry.js +5 -0
- package/dist/checkout/p-1bce3237.entry.js.map +1 -0
- package/dist/checkout/p-1c7ee6b2.entry.js +2 -0
- package/dist/checkout/p-1c7ee6b2.entry.js.map +1 -0
- package/dist/checkout/p-1ead2bd7.entry.js +2 -0
- package/dist/checkout/p-1ead2bd7.entry.js.map +1 -0
- package/dist/checkout/p-215ced8f.entry.js +20 -0
- package/dist/checkout/p-215ced8f.entry.js.map +1 -0
- package/dist/checkout/p-230d69f0.entry.js +5 -0
- package/dist/checkout/p-230d69f0.entry.js.map +1 -0
- package/dist/checkout/p-253aa3a2.entry.js +2 -0
- package/dist/checkout/p-253aa3a2.entry.js.map +1 -0
- package/dist/checkout/p-2e7e60da.entry.js +2 -0
- package/dist/checkout/p-2e7e60da.entry.js.map +1 -0
- package/dist/checkout/p-350e7423.js +2 -1
- package/dist/checkout/p-350e7423.js.map +1 -0
- package/dist/checkout/p-361649c3.js +2 -1
- package/dist/checkout/p-361649c3.js.map +1 -0
- package/dist/checkout/p-37da8c1d.entry.js +2 -0
- package/dist/checkout/p-37da8c1d.entry.js.map +1 -0
- package/dist/checkout/p-39ad94cf.js +18 -2
- package/dist/checkout/p-39ad94cf.js.map +1 -0
- package/dist/checkout/p-3b75b22a.js +6 -2
- package/dist/checkout/p-3b75b22a.js.map +1 -0
- package/dist/checkout/p-3b80783d.js +19 -4
- package/dist/checkout/p-3b80783d.js.map +1 -0
- package/dist/checkout/p-3d3eefc3.js +2 -1
- package/dist/checkout/p-3d3eefc3.js.map +1 -0
- package/dist/checkout/p-3e1e3453.js +3 -2
- package/dist/checkout/p-3e1e3453.js.map +1 -0
- package/dist/checkout/p-3e681e57.js +3 -2
- package/dist/checkout/p-3e681e57.js.map +1 -0
- package/dist/checkout/p-40853e46.entry.js +2 -0
- package/dist/checkout/p-40853e46.entry.js.map +1 -0
- package/dist/checkout/p-44d3d00c.entry.js +2 -0
- package/dist/checkout/p-44d3d00c.entry.js.map +1 -0
- package/dist/checkout/p-465e36be.entry.js +2 -0
- package/dist/checkout/p-465e36be.entry.js.map +1 -0
- package/dist/checkout/p-4be20bf2.js +4 -3
- package/dist/checkout/p-4be20bf2.js.map +1 -0
- package/dist/checkout/p-4f78d3a0.js +2 -1
- package/dist/checkout/p-4f78d3a0.js.map +1 -0
- package/dist/checkout/p-52b4c112.js +2 -1
- package/dist/checkout/p-52b4c112.js.map +1 -0
- package/dist/checkout/p-53607c6e.entry.js +2 -0
- package/dist/checkout/p-53607c6e.entry.js.map +1 -0
- package/dist/checkout/p-536a0294.js +3 -2
- package/dist/checkout/p-536a0294.js.map +1 -0
- package/dist/checkout/p-53a0e933.entry.js +2 -0
- package/dist/checkout/p-53a0e933.entry.js.map +1 -0
- package/dist/checkout/p-53a6466f.entry.js +2 -0
- package/dist/checkout/p-53a6466f.entry.js.map +1 -0
- package/dist/checkout/p-53b7882e.entry.js +29 -0
- package/dist/checkout/p-53b7882e.entry.js.map +1 -0
- package/dist/checkout/p-55a37fe3.entry.js +2 -0
- package/dist/checkout/p-55a37fe3.entry.js.map +1 -0
- package/dist/checkout/p-560649cc.entry.js +2 -0
- package/dist/checkout/p-560649cc.entry.js.map +1 -0
- package/dist/checkout/p-58b1ac84.entry.js +2 -0
- package/dist/checkout/p-58b1ac84.entry.js.map +1 -0
- package/dist/checkout/p-5a106d81.entry.js +2 -0
- package/dist/checkout/p-5a106d81.entry.js.map +1 -0
- package/dist/checkout/p-5ad690d7.entry.js +14 -0
- package/dist/checkout/p-5ad690d7.entry.js.map +1 -0
- package/dist/checkout/p-5c0e8652.entry.js +2 -0
- package/dist/checkout/p-5c0e8652.entry.js.map +1 -0
- package/dist/checkout/p-5d8ae3a1.entry.js +32 -0
- package/dist/checkout/p-5d8ae3a1.entry.js.map +1 -0
- package/dist/checkout/p-5ea4b04d.entry.js +2 -0
- package/dist/checkout/p-5ea4b04d.entry.js.map +1 -0
- package/dist/checkout/p-5fff6cf6.entry.js +2 -0
- package/dist/checkout/p-5fff6cf6.entry.js.map +1 -0
- package/dist/checkout/p-620fa0ec.js +2 -1
- package/dist/checkout/p-620fa0ec.js.map +1 -0
- package/dist/checkout/p-6ae8b017.entry.js +2 -0
- package/dist/checkout/p-6ae8b017.entry.js.map +1 -0
- package/dist/checkout/p-6f2eaada.entry.js +2 -0
- package/dist/checkout/p-6f2eaada.entry.js.map +1 -0
- package/dist/checkout/p-6fa979e3.js +2 -1
- package/dist/checkout/p-6fa979e3.js.map +1 -0
- package/dist/checkout/p-73ebba38.entry.js +8 -0
- package/dist/checkout/p-73ebba38.entry.js.map +1 -0
- package/dist/checkout/p-76e7e8fb.entry.js +2 -0
- package/dist/checkout/p-76e7e8fb.entry.js.map +1 -0
- package/dist/checkout/p-77104220.js +9 -2
- package/dist/checkout/p-77104220.js.map +1 -0
- package/dist/checkout/p-7a5ca4ae.entry.js +2 -0
- package/dist/checkout/p-7a5ca4ae.entry.js.map +1 -0
- package/dist/checkout/p-7f0004c9.js +6 -2
- package/dist/checkout/p-7f0004c9.js.map +1 -0
- package/dist/checkout/p-7f223616.entry.js +2 -0
- package/dist/checkout/p-7f223616.entry.js.map +1 -0
- package/dist/checkout/p-801a8293.entry.js +2 -0
- package/dist/checkout/p-801a8293.entry.js.map +1 -0
- package/dist/checkout/p-817492ae.entry.js +2 -0
- package/dist/checkout/p-817492ae.entry.js.map +1 -0
- package/dist/checkout/p-86caa486.entry.js +2 -0
- package/dist/checkout/p-86caa486.entry.js.map +1 -0
- package/dist/checkout/p-8845543b.entry.js +2 -0
- package/dist/checkout/p-8845543b.entry.js.map +1 -0
- package/dist/checkout/p-88abdf59.js +2 -1
- package/dist/checkout/p-88abdf59.js.map +1 -0
- package/dist/checkout/p-8b838f6e.entry.js +2 -0
- package/dist/checkout/p-8b838f6e.entry.js.map +1 -0
- package/dist/checkout/p-8c8e3669.entry.js +2 -0
- package/dist/checkout/p-8c8e3669.entry.js.map +1 -0
- package/dist/checkout/p-9387cd0d.entry.js +2 -0
- package/dist/checkout/p-9387cd0d.entry.js.map +1 -0
- package/dist/checkout/p-94286cc3.js +2 -1
- package/dist/checkout/p-94286cc3.js.map +1 -0
- package/dist/checkout/p-94f20379.entry.js +2 -0
- package/dist/checkout/p-94f20379.entry.js.map +1 -0
- package/dist/checkout/p-99e447f9.js +2 -1
- package/dist/checkout/p-99e447f9.js.map +1 -0
- package/dist/checkout/p-9b519de5.js +6 -2
- package/dist/checkout/p-9b519de5.js.map +1 -0
- package/dist/checkout/p-9c833a37.entry.js +2 -0
- package/dist/checkout/p-9c833a37.entry.js.map +1 -0
- package/dist/checkout/p-9dfc5c78.entry.js +2 -0
- package/dist/checkout/p-9dfc5c78.entry.js.map +1 -0
- package/dist/checkout/p-9efbca93.js +2 -1
- package/dist/checkout/p-9efbca93.js.map +1 -0
- package/dist/checkout/p-9f4ac833.js +2 -1
- package/dist/checkout/p-9f4ac833.js.map +1 -0
- package/dist/checkout/p-9f4c1150.entry.js +2 -0
- package/dist/checkout/p-9f4c1150.entry.js.map +1 -0
- package/dist/checkout/p-9f6c714a.entry.js +2 -0
- package/dist/checkout/p-9f6c714a.entry.js.map +1 -0
- package/dist/checkout/p-9f8a3105.entry.js +2 -0
- package/dist/checkout/p-9f8a3105.entry.js.map +1 -0
- package/dist/checkout/p-a26500c0.entry.js +2 -0
- package/dist/checkout/p-a26500c0.entry.js.map +1 -0
- package/dist/checkout/p-a3ea4b97.entry.js +2 -0
- package/dist/checkout/p-a3ea4b97.entry.js.map +1 -0
- package/dist/checkout/p-a4edfb4e.entry.js +2 -0
- package/dist/checkout/p-a4edfb4e.entry.js.map +1 -0
- package/dist/checkout/p-a697247b.entry.js +2 -0
- package/dist/checkout/p-a697247b.entry.js.map +1 -0
- package/dist/checkout/p-a718ae17.entry.js +5 -0
- package/dist/checkout/p-a718ae17.entry.js.map +1 -0
- package/dist/checkout/p-a84091c3.entry.js +5 -0
- package/dist/checkout/p-a84091c3.entry.js.map +1 -0
- package/dist/checkout/p-aa91cbc3.entry.js +2 -0
- package/dist/checkout/p-aa91cbc3.entry.js.map +1 -0
- package/dist/checkout/p-ab16e6ce.js +2 -1
- package/dist/checkout/p-ab16e6ce.js.map +1 -0
- package/dist/checkout/p-adaf2312.entry.js +2 -0
- package/dist/checkout/p-adaf2312.entry.js.map +1 -0
- package/dist/checkout/p-afba621c.entry.js +2 -0
- package/dist/checkout/p-afba621c.entry.js.map +1 -0
- package/dist/checkout/p-b038db20.js +2 -1
- package/dist/checkout/p-b038db20.js.map +1 -0
- package/dist/checkout/p-b0ebfdfe.entry.js +2 -0
- package/dist/checkout/p-b0ebfdfe.entry.js.map +1 -0
- package/dist/checkout/p-b2289937.js +3 -2
- package/dist/checkout/p-b2289937.js.map +1 -0
- package/dist/checkout/p-b2ddb12a.entry.js +8 -0
- package/dist/checkout/p-b2ddb12a.entry.js.map +1 -0
- package/dist/checkout/p-b339d32f.entry.js +2 -0
- package/dist/checkout/p-b339d32f.entry.js.map +1 -0
- package/dist/checkout/p-b7be2ec0.js +6 -2
- package/dist/checkout/p-b7be2ec0.js.map +1 -0
- package/dist/checkout/p-b7f7fba2.entry.js +2 -0
- package/dist/checkout/p-b7f7fba2.entry.js.map +1 -0
- package/dist/checkout/p-b802b8c1.entry.js +2 -0
- package/dist/checkout/p-b802b8c1.entry.js.map +1 -0
- package/dist/checkout/p-b84d9e44.js +2 -1
- package/dist/checkout/p-b84d9e44.js.map +1 -0
- package/dist/checkout/p-b8fdd517.js +2 -1
- package/dist/checkout/p-b8fdd517.js.map +1 -0
- package/dist/checkout/p-bb1f698e.js +3 -2
- package/dist/checkout/p-bb1f698e.js.map +1 -0
- package/dist/checkout/p-bc65d8c9.entry.js +2 -0
- package/dist/checkout/p-bc65d8c9.entry.js.map +1 -0
- package/dist/checkout/p-bd17be25.js +3 -2
- package/dist/checkout/p-bd17be25.js.map +1 -0
- package/dist/checkout/p-c152bdea.js +3 -2
- package/dist/checkout/p-c152bdea.js.map +1 -0
- package/dist/checkout/p-c30e2b28.js +13 -3
- package/dist/checkout/p-c30e2b28.js.map +1 -0
- package/dist/checkout/p-c3861883.entry.js +2 -0
- package/dist/checkout/p-c3861883.entry.js.map +1 -0
- package/dist/checkout/p-c397acca.entry.js +2 -0
- package/dist/checkout/p-c397acca.entry.js.map +1 -0
- package/dist/checkout/p-c54daf41.entry.js +2 -0
- package/dist/checkout/p-c54daf41.entry.js.map +1 -0
- package/dist/checkout/p-ca00d816.entry.js +2 -0
- package/dist/checkout/p-ca00d816.entry.js.map +1 -0
- package/dist/checkout/p-cb7f4d94.entry.js +2 -0
- package/dist/checkout/p-cb7f4d94.entry.js.map +1 -0
- package/dist/checkout/p-cd3a4752.entry.js +2 -0
- package/dist/checkout/p-cd3a4752.entry.js.map +1 -0
- package/dist/checkout/p-cdc9d9f2.entry.js +2 -0
- package/dist/checkout/p-cdc9d9f2.entry.js.map +1 -0
- package/dist/checkout/p-cee1b2d9.entry.js +2 -0
- package/dist/checkout/p-cee1b2d9.entry.js.map +1 -0
- package/dist/checkout/p-d0b3af3d.entry.js +2 -0
- package/dist/checkout/p-d0b3af3d.entry.js.map +1 -0
- package/dist/checkout/p-d5862637.js +2 -1
- package/dist/checkout/p-d5862637.js.map +1 -0
- package/dist/checkout/p-d60b2328.js +3 -2
- package/dist/checkout/p-d60b2328.js.map +1 -0
- package/dist/checkout/p-d7a430bf.js +3 -2
- package/dist/checkout/p-d7a430bf.js.map +1 -0
- package/dist/checkout/p-d7fe59ee.js +2 -1
- package/dist/checkout/p-d7fe59ee.js.map +1 -0
- package/dist/checkout/p-d839c693.js +2 -1
- package/dist/checkout/p-d839c693.js.map +1 -0
- package/dist/checkout/p-dc51d318.js +2 -1
- package/dist/checkout/p-dc51d318.js.map +1 -0
- package/dist/checkout/p-ddd2534e.entry.js +2 -0
- package/dist/checkout/p-ddd2534e.entry.js.map +1 -0
- package/dist/checkout/p-e187a77c.js +2 -1
- package/dist/checkout/p-e187a77c.js.map +1 -0
- package/dist/checkout/p-e66d942d.entry.js +2 -0
- package/dist/checkout/p-e66d942d.entry.js.map +1 -0
- package/dist/checkout/p-e6c9b000.entry.js +2 -0
- package/dist/checkout/p-e6c9b000.entry.js.map +1 -0
- package/dist/checkout/p-f3fbc676.entry.js +2 -0
- package/dist/checkout/p-f3fbc676.entry.js.map +1 -0
- package/dist/checkout/p-f6bb71fb.entry.js +2 -0
- package/dist/checkout/p-f6bb71fb.entry.js.map +1 -0
- package/dist/checkout/p-f728a68f.js +2 -1
- package/dist/checkout/p-f728a68f.js.map +1 -0
- package/dist/checkout/p-f9ec47f2.entry.js +2 -0
- package/dist/checkout/p-f9ec47f2.entry.js.map +1 -0
- package/dist/checkout/p-faada48e.entry.js +2 -0
- package/dist/checkout/p-faada48e.entry.js.map +1 -0
- package/dist/checkout/p-faf06441.js +3 -2
- package/dist/checkout/p-faf06441.js.map +1 -0
- package/dist/checkout/p-fc4aaf1a.entry.js +2 -0
- package/dist/checkout/p-fc4aaf1a.entry.js.map +1 -0
- package/dist/checkout/p-ff1cb129.entry.js +2 -0
- package/dist/checkout/p-ff1cb129.entry.js.map +1 -0
- package/dist/cjs/_commonjsHelpers-537d719a.js +2 -0
- package/dist/cjs/_commonjsHelpers-537d719a.js.map +1 -0
- package/dist/cjs/amwal-checkout-button_5.cjs.entry.js +6 -4
- package/dist/cjs/amwal-checkout-button_5.cjs.entry.js.map +1 -0
- package/dist/cjs/amwal-installments-guide.cjs.entry.js +2 -0
- package/dist/cjs/amwal-installments-guide.cjs.entry.js.map +1 -0
- package/dist/cjs/amwal-pos.cjs.entry.js +2 -0
- package/dist/cjs/amwal-pos.cjs.entry.js.map +1 -0
- package/dist/cjs/amwal-widget-modal.cjs.entry.js +10 -3
- package/dist/cjs/amwal-widget-modal.cjs.entry.js.map +1 -0
- package/dist/cjs/amwal-widget.cjs.entry.js +3 -1
- package/dist/cjs/amwal-widget.cjs.entry.js.map +1 -0
- package/dist/cjs/animation-26241cb2.js +2 -0
- package/dist/cjs/animation-26241cb2.js.map +1 -0
- package/dist/cjs/app-globals-42a13029.js +2 -0
- package/dist/cjs/app-globals-42a13029.js.map +1 -0
- package/dist/cjs/ar-3a6829a4.js +2 -0
- package/dist/cjs/ar-3a6829a4.js.map +1 -0
- package/dist/cjs/capacitor-a9365f60.js +2 -0
- package/dist/cjs/capacitor-a9365f60.js.map +1 -0
- package/dist/cjs/checkout.cjs.js +3 -1
- package/dist/cjs/checkout.cjs.js.map +1 -0
- package/dist/cjs/compare-with-utils-adbe64a6.js +2 -0
- package/dist/cjs/compare-with-utils-adbe64a6.js.map +1 -0
- package/dist/cjs/config-e2a8c0c7.js +2 -0
- package/dist/cjs/config-e2a8c0c7.js.map +1 -0
- package/dist/cjs/cubic-bezier-5ff9b04e.js +2 -0
- package/dist/cjs/cubic-bezier-5ff9b04e.js.map +1 -0
- package/dist/cjs/data-19081291.js +2 -0
- package/dist/cjs/data-19081291.js.map +1 -0
- package/dist/cjs/dir-374f13f2.js +2 -0
- package/dist/cjs/dir-374f13f2.js.map +1 -0
- package/dist/cjs/focus-visible-b7381162.js +2 -0
- package/dist/cjs/focus-visible-b7381162.js.map +1 -0
- package/dist/cjs/form-controller-3ffb27b1.js +2 -0
- package/dist/cjs/form-controller-3ffb27b1.js.map +1 -0
- package/dist/cjs/framework-delegate-ab2cc190.js +2 -0
- package/dist/cjs/framework-delegate-ab2cc190.js.map +1 -0
- package/dist/cjs/gesture-controller-b1c0efac.js +2 -0
- package/dist/cjs/gesture-controller-b1c0efac.js.map +1 -0
- package/dist/cjs/haptic-80174512.js +2 -0
- package/dist/cjs/haptic-80174512.js.map +1 -0
- package/dist/cjs/hardware-back-button-ddfefd22.js +2 -0
- package/dist/cjs/hardware-back-button-ddfefd22.js.map +1 -0
- package/dist/cjs/helpers-72ba682d.js +2 -0
- package/dist/cjs/helpers-72ba682d.js.map +1 -0
- package/dist/cjs/i18n-18ad02d5.js +2 -0
- package/dist/cjs/i18n-18ad02d5.js.map +1 -0
- package/dist/cjs/index-071786b4.js +2 -0
- package/dist/cjs/index-071786b4.js.map +1 -0
- package/dist/cjs/index-0d0b84fb.js +2 -0
- package/dist/cjs/index-0d0b84fb.js.map +1 -0
- package/dist/cjs/index-2602a653.js +2 -0
- package/dist/cjs/index-2602a653.js.map +1 -0
- package/dist/cjs/index-2cd1a895.js +2 -0
- package/dist/cjs/index-2cd1a895.js.map +1 -0
- package/dist/cjs/index-7522b3a9.js +2 -0
- package/dist/cjs/index-7522b3a9.js.map +1 -0
- package/dist/cjs/index-9b7d2c31.js +2 -0
- package/dist/cjs/index-9b7d2c31.js.map +1 -0
- package/dist/cjs/index-a281cac3.js +2 -0
- package/dist/cjs/index-a281cac3.js.map +1 -0
- package/dist/cjs/index-ce06e6a3.js +2 -0
- package/dist/cjs/index-ce06e6a3.js.map +1 -0
- package/dist/cjs/index-da554121.js +2 -0
- package/dist/cjs/index-da554121.js.map +1 -0
- package/dist/cjs/index.cjs.js +2 -0
- package/dist/cjs/index.cjs.js.map +1 -0
- package/dist/cjs/input-shims-1a8ed779.js +2 -0
- package/dist/cjs/input-shims-1a8ed779.js.map +1 -0
- package/dist/cjs/input.utils-67143876.js +2 -0
- package/dist/cjs/input.utils-67143876.js.map +1 -0
- package/dist/cjs/ion-accordion-group.cjs.entry.js +2 -0
- package/dist/cjs/ion-accordion-group.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-accordion.cjs.entry.js +2 -0
- package/dist/cjs/ion-accordion.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-action-sheet_3.cjs.entry.js +2 -0
- package/dist/cjs/ion-action-sheet_3.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-app.cjs.entry.js +2 -0
- package/dist/cjs/ion-app.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-avatar.cjs.entry.js +2 -0
- package/dist/cjs/ion-avatar.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-back-button.cjs.entry.js +2 -0
- package/dist/cjs/ion-back-button.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-backdrop.cjs.entry.js +2 -0
- package/dist/cjs/ion-backdrop.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-badge.cjs.entry.js +2 -0
- package/dist/cjs/ion-badge.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-breadcrumb.cjs.entry.js +2 -0
- package/dist/cjs/ion-breadcrumb.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-breadcrumbs.cjs.entry.js +2 -0
- package/dist/cjs/ion-breadcrumbs.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-buttons_3.cjs.entry.js +2 -0
- package/dist/cjs/ion-buttons_3.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-card-content.cjs.entry.js +2 -0
- package/dist/cjs/ion-card-content.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-card-header.cjs.entry.js +2 -0
- package/dist/cjs/ion-card-header.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-card-subtitle.cjs.entry.js +2 -0
- package/dist/cjs/ion-card-subtitle.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-card-title.cjs.entry.js +2 -0
- package/dist/cjs/ion-card-title.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-card.cjs.entry.js +2 -0
- package/dist/cjs/ion-card.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-checkbox_7.cjs.entry.js +2 -0
- package/dist/cjs/ion-checkbox_7.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-chip.cjs.entry.js +2 -0
- package/dist/cjs/ion-chip.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-col.cjs.entry.js +2 -0
- package/dist/cjs/ion-col.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-content.cjs.entry.js +2 -0
- package/dist/cjs/ion-content.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-datetime-button.cjs.entry.js +2 -0
- package/dist/cjs/ion-datetime-button.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-datetime.cjs.entry.js +2 -0
- package/dist/cjs/ion-datetime.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-fab-button.cjs.entry.js +2 -0
- package/dist/cjs/ion-fab-button.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-fab-list.cjs.entry.js +2 -0
- package/dist/cjs/ion-fab-list.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-fab.cjs.entry.js +2 -0
- package/dist/cjs/ion-fab.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-footer.cjs.entry.js +2 -0
- package/dist/cjs/ion-footer.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-grid.cjs.entry.js +2 -0
- package/dist/cjs/ion-grid.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-header.cjs.entry.js +2 -0
- package/dist/cjs/ion-header.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-icon.cjs.entry.js +2 -0
- package/dist/cjs/ion-icon.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-img.cjs.entry.js +2 -0
- package/dist/cjs/ion-img.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-infinite-scroll-content.cjs.entry.js +2 -0
- package/dist/cjs/ion-infinite-scroll-content.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-infinite-scroll.cjs.entry.js +2 -0
- package/dist/cjs/ion-infinite-scroll.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-input.cjs.entry.js +2 -0
- package/dist/cjs/ion-input.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-item-divider.cjs.entry.js +2 -0
- package/dist/cjs/ion-item-divider.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-item-group.cjs.entry.js +2 -0
- package/dist/cjs/ion-item-group.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-item-option.cjs.entry.js +2 -0
- package/dist/cjs/ion-item-option.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-item-options.cjs.entry.js +2 -0
- package/dist/cjs/ion-item-options.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-item-sliding.cjs.entry.js +2 -0
- package/dist/cjs/ion-item-sliding.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-loading.cjs.entry.js +2 -0
- package/dist/cjs/ion-loading.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-menu-button.cjs.entry.js +2 -0
- package/dist/cjs/ion-menu-button.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-menu-toggle.cjs.entry.js +2 -0
- package/dist/cjs/ion-menu-toggle.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-menu.cjs.entry.js +2 -0
- package/dist/cjs/ion-menu.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-modal.cjs.entry.js +2 -0
- package/dist/cjs/ion-modal.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-nav-link.cjs.entry.js +2 -0
- package/dist/cjs/ion-nav-link.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-nav.cjs.entry.js +2 -0
- package/dist/cjs/ion-nav.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-note.cjs.entry.js +2 -0
- package/dist/cjs/ion-note.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-picker-column.cjs.entry.js +2 -0
- package/dist/cjs/ion-picker-column.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-picker.cjs.entry.js +2 -0
- package/dist/cjs/ion-picker.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-popover.cjs.entry.js +2 -0
- package/dist/cjs/ion-popover.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-progress-bar.cjs.entry.js +2 -0
- package/dist/cjs/ion-progress-bar.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-range.cjs.entry.js +2 -0
- package/dist/cjs/ion-range.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-refresher-content.cjs.entry.js +2 -0
- package/dist/cjs/ion-refresher-content.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-refresher.cjs.entry.js +2 -0
- package/dist/cjs/ion-refresher.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-reorder-group.cjs.entry.js +2 -0
- package/dist/cjs/ion-reorder-group.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-reorder.cjs.entry.js +2 -0
- package/dist/cjs/ion-reorder.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-route-redirect.cjs.entry.js +2 -0
- package/dist/cjs/ion-route-redirect.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-route.cjs.entry.js +2 -0
- package/dist/cjs/ion-route.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-router-link.cjs.entry.js +2 -0
- package/dist/cjs/ion-router-link.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-router-outlet.cjs.entry.js +2 -0
- package/dist/cjs/ion-router-outlet.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-router.cjs.entry.js +2 -0
- package/dist/cjs/ion-router.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-row.cjs.entry.js +2 -0
- package/dist/cjs/ion-row.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-searchbar.cjs.entry.js +2 -0
- package/dist/cjs/ion-searchbar.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-segment-button.cjs.entry.js +2 -0
- package/dist/cjs/ion-segment-button.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-segment.cjs.entry.js +2 -0
- package/dist/cjs/ion-segment.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-select-option.cjs.entry.js +2 -0
- package/dist/cjs/ion-select-option.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-select.cjs.entry.js +2 -0
- package/dist/cjs/ion-select.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-skeleton-text.cjs.entry.js +2 -0
- package/dist/cjs/ion-skeleton-text.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-spinner.cjs.entry.js +2 -0
- package/dist/cjs/ion-spinner.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-split-pane.cjs.entry.js +2 -0
- package/dist/cjs/ion-split-pane.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-tab-bar.cjs.entry.js +2 -0
- package/dist/cjs/ion-tab-bar.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-tab-button.cjs.entry.js +2 -0
- package/dist/cjs/ion-tab-button.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-tab.cjs.entry.js +2 -0
- package/dist/cjs/ion-tab.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-tabs.cjs.entry.js +2 -0
- package/dist/cjs/ion-tabs.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-textarea.cjs.entry.js +2 -0
- package/dist/cjs/ion-textarea.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-thumbnail.cjs.entry.js +2 -0
- package/dist/cjs/ion-thumbnail.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-title.cjs.entry.js +2 -0
- package/dist/cjs/ion-title.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-toast.cjs.entry.js +2 -0
- package/dist/cjs/ion-toast.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-toggle.cjs.entry.js +2 -0
- package/dist/cjs/ion-toggle.cjs.entry.js.map +1 -0
- package/dist/cjs/ion-toolbar.cjs.entry.js +2 -0
- package/dist/cjs/ion-toolbar.cjs.entry.js.map +1 -0
- package/dist/cjs/ionic-global-3915f1f1.js +2 -0
- package/dist/cjs/ionic-global-3915f1f1.js.map +1 -0
- package/dist/cjs/ios.transition-b9c0b967.js +2 -0
- package/dist/cjs/ios.transition-b9c0b967.js.map +1 -0
- package/dist/cjs/keyboard-5d4b83b3.js +2 -0
- package/dist/cjs/keyboard-5d4b83b3.js.map +1 -0
- package/dist/cjs/keyboard-bc8ebbf7.js +2 -0
- package/dist/cjs/keyboard-bc8ebbf7.js.map +1 -0
- package/dist/cjs/keyboard-controller-c6633754.js +2 -0
- package/dist/cjs/keyboard-controller-c6633754.js.map +1 -0
- package/dist/cjs/loader.cjs.js +3 -1
- package/dist/cjs/loader.cjs.js.map +1 -0
- package/dist/cjs/lock-controller-e2dfece6.js +2 -0
- package/dist/cjs/lock-controller-e2dfece6.js.map +1 -0
- package/dist/cjs/md.transition-830acbb7.js +2 -0
- package/dist/cjs/md.transition-830acbb7.js.map +1 -0
- package/dist/cjs/menu-toggle-util-315c26b3.js +2 -0
- package/dist/cjs/menu-toggle-util-315c26b3.js.map +1 -0
- package/dist/cjs/notch-controller-dcf09601.js +2 -0
- package/dist/cjs/notch-controller-dcf09601.js.map +1 -0
- package/dist/cjs/overlays-08819e3f.js +2 -0
- package/dist/cjs/overlays-08819e3f.js.map +1 -0
- package/dist/cjs/refresher.utils-e41509f7.js +2 -0
- package/dist/cjs/refresher.utils-e41509f7.js.map +1 -0
- package/dist/cjs/spinner-configs-036ebfd8.js +2 -0
- package/dist/cjs/spinner-configs-036ebfd8.js.map +1 -0
- package/dist/cjs/status-tap-ec021cb4.js +2 -0
- package/dist/cjs/status-tap-ec021cb4.js.map +1 -0
- package/dist/cjs/swipe-back-3d3a5129.js +2 -0
- package/dist/cjs/swipe-back-3d3a5129.js.map +1 -0
- package/dist/cjs/theme-12dec869.js +2 -0
- package/dist/cjs/theme-12dec869.js.map +1 -0
- package/dist/cjs/watch-options-1cccbe6a.js +2 -0
- package/dist/cjs/watch-options-1cccbe6a.js.map +1 -0
- package/dist/collection/components/amwal-checkout-button/amwal-checkout-button.js +1 -0
- package/dist/collection/components/amwal-checkout-button/amwal-checkout-button.js.map +1 -0
- package/dist/collection/components/amwal-checkout-button/amwal-checkout-button.stories.js +1 -0
- package/dist/collection/components/amwal-checkout-button/amwal-checkout-button.stories.js.map +1 -0
- package/dist/collection/components/amwal-installments-guide/amwal-installments-guide.js +1 -0
- package/dist/collection/components/amwal-installments-guide/amwal-installments-guide.js.map +1 -0
- package/dist/collection/components/amwal-installments-guide/amwal-installments-guide.stories.js +1 -0
- package/dist/collection/components/amwal-installments-guide/amwal-installments-guide.stories.js.map +1 -0
- package/dist/collection/components/amwal-installments-timeline/amwal-installments-timeline.js +1 -0
- package/dist/collection/components/amwal-installments-timeline/amwal-installments-timeline.js.map +1 -0
- package/dist/collection/components/amwal-installments-timeline/amwal-installments-timeline.stories.js +1 -0
- package/dist/collection/components/amwal-installments-timeline/amwal-installments-timeline.stories.js.map +1 -0
- package/dist/collection/components/amwal-pos/amwal-pos.js +1 -0
- package/dist/collection/components/amwal-pos/amwal-pos.js.map +1 -0
- package/dist/collection/components/amwal-pos/amwal-pos.stories.js +1 -0
- package/dist/collection/components/amwal-pos/amwal-pos.stories.js.map +1 -0
- package/dist/collection/components/amwal-widget/amwal-widget-modal.css +14 -4
- package/dist/collection/components/amwal-widget/amwal-widget-modal.js +14 -2
- package/dist/collection/components/amwal-widget/amwal-widget-modal.js.map +1 -0
- package/dist/collection/components/amwal-widget/amwal-widget.css +11 -8
- package/dist/collection/components/amwal-widget/amwal-widget.js +1 -0
- package/dist/collection/components/amwal-widget/amwal-widget.js.map +1 -0
- package/dist/collection/components/amwal-widget/amwal-widget.stories.js +1 -0
- package/dist/collection/components/amwal-widget/amwal-widget.stories.js.map +1 -0
- package/dist/collection/lang/i18n.js +1 -0
- package/dist/collection/lang/i18n.js.map +1 -0
- package/dist/components/amwal-checkout-button.js +6 -4
- package/dist/components/amwal-checkout-button.js.map +1 -0
- package/dist/components/amwal-installments-guide.js +2 -0
- package/dist/components/amwal-installments-guide.js.map +1 -0
- package/dist/components/amwal-installments-timeline.js +2 -0
- package/dist/components/amwal-installments-timeline.js.map +1 -0
- package/dist/components/amwal-pos.js +2 -0
- package/dist/components/amwal-pos.js.map +1 -0
- package/dist/components/amwal-widget-modal.js +3 -1
- package/dist/components/amwal-widget-modal.js.map +1 -0
- package/dist/components/amwal-widget.js +4 -2
- package/dist/components/amwal-widget.js.map +1 -0
- package/dist/components/index.js +2 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/ion-accordion-group.js +2 -0
- package/dist/components/ion-accordion-group.js.map +1 -0
- package/dist/components/ion-accordion.js +2 -0
- package/dist/components/ion-accordion.js.map +1 -0
- package/dist/components/ion-action-sheet.js +2 -0
- package/dist/components/ion-action-sheet.js.map +1 -0
- package/dist/components/ion-alert.js +2 -0
- package/dist/components/ion-alert.js.map +1 -0
- package/dist/components/ion-app.js +2 -0
- package/dist/components/ion-app.js.map +1 -0
- package/dist/components/ion-avatar.js +2 -0
- package/dist/components/ion-avatar.js.map +1 -0
- package/dist/components/ion-back-button.js +2 -0
- package/dist/components/ion-back-button.js.map +1 -0
- package/dist/components/ion-backdrop.js +2 -0
- package/dist/components/ion-backdrop.js.map +1 -0
- package/dist/components/ion-badge.js +2 -0
- package/dist/components/ion-badge.js.map +1 -0
- package/dist/components/ion-breadcrumb.js +2 -0
- package/dist/components/ion-breadcrumb.js.map +1 -0
- package/dist/components/ion-breadcrumbs.js +2 -0
- package/dist/components/ion-breadcrumbs.js.map +1 -0
- package/dist/components/ion-button.js +2 -0
- package/dist/components/ion-button.js.map +1 -0
- package/dist/components/ion-buttons.js +2 -0
- package/dist/components/ion-buttons.js.map +1 -0
- package/dist/components/ion-card-content.js +2 -0
- package/dist/components/ion-card-content.js.map +1 -0
- package/dist/components/ion-card-header.js +2 -0
- package/dist/components/ion-card-header.js.map +1 -0
- package/dist/components/ion-card-subtitle.js +2 -0
- package/dist/components/ion-card-subtitle.js.map +1 -0
- package/dist/components/ion-card-title.js +2 -0
- package/dist/components/ion-card-title.js.map +1 -0
- package/dist/components/ion-card.js +2 -0
- package/dist/components/ion-card.js.map +1 -0
- package/dist/components/ion-checkbox.js +2 -0
- package/dist/components/ion-checkbox.js.map +1 -0
- package/dist/components/ion-chip.js +2 -0
- package/dist/components/ion-chip.js.map +1 -0
- package/dist/components/ion-col.js +2 -0
- package/dist/components/ion-col.js.map +1 -0
- package/dist/components/ion-content.js +2 -0
- package/dist/components/ion-content.js.map +1 -0
- package/dist/components/ion-datetime-button.js +2 -0
- package/dist/components/ion-datetime-button.js.map +1 -0
- package/dist/components/ion-datetime.js +2 -0
- package/dist/components/ion-datetime.js.map +1 -0
- package/dist/components/ion-fab-button.js +2 -0
- package/dist/components/ion-fab-button.js.map +1 -0
- package/dist/components/ion-fab-list.js +2 -0
- package/dist/components/ion-fab-list.js.map +1 -0
- package/dist/components/ion-fab.js +2 -0
- package/dist/components/ion-fab.js.map +1 -0
- package/dist/components/ion-footer.js +2 -0
- package/dist/components/ion-footer.js.map +1 -0
- package/dist/components/ion-grid.js +2 -0
- package/dist/components/ion-grid.js.map +1 -0
- package/dist/components/ion-header.js +2 -0
- package/dist/components/ion-header.js.map +1 -0
- package/dist/components/ion-icon.js +2 -0
- package/dist/components/ion-icon.js.map +1 -0
- package/dist/components/ion-img.js +2 -0
- package/dist/components/ion-img.js.map +1 -0
- package/dist/components/ion-infinite-scroll-content.js +2 -0
- package/dist/components/ion-infinite-scroll-content.js.map +1 -0
- package/dist/components/ion-infinite-scroll.js +2 -0
- package/dist/components/ion-infinite-scroll.js.map +1 -0
- package/dist/components/ion-input.js +2 -0
- package/dist/components/ion-input.js.map +1 -0
- package/dist/components/ion-item-divider.js +2 -0
- package/dist/components/ion-item-divider.js.map +1 -0
- package/dist/components/ion-item-group.js +2 -0
- package/dist/components/ion-item-group.js.map +1 -0
- package/dist/components/ion-item-option.js +2 -0
- package/dist/components/ion-item-option.js.map +1 -0
- package/dist/components/ion-item-options.js +2 -0
- package/dist/components/ion-item-options.js.map +1 -0
- package/dist/components/ion-item-sliding.js +2 -0
- package/dist/components/ion-item-sliding.js.map +1 -0
- package/dist/components/ion-item.js +2 -0
- package/dist/components/ion-item.js.map +1 -0
- package/dist/components/ion-label.js +2 -0
- package/dist/components/ion-label.js.map +1 -0
- package/dist/components/ion-list-header.js +2 -0
- package/dist/components/ion-list-header.js.map +1 -0
- package/dist/components/ion-list.js +2 -0
- package/dist/components/ion-list.js.map +1 -0
- package/dist/components/ion-loading.js +2 -0
- package/dist/components/ion-loading.js.map +1 -0
- package/dist/components/ion-menu-button.js +2 -0
- package/dist/components/ion-menu-button.js.map +1 -0
- package/dist/components/ion-menu-toggle.js +2 -0
- package/dist/components/ion-menu-toggle.js.map +1 -0
- package/dist/components/ion-menu.js +2 -0
- package/dist/components/ion-menu.js.map +1 -0
- package/dist/components/ion-modal.js +2 -0
- package/dist/components/ion-modal.js.map +1 -0
- package/dist/components/ion-nav-link.js +2 -0
- package/dist/components/ion-nav-link.js.map +1 -0
- package/dist/components/ion-nav.js +2 -0
- package/dist/components/ion-nav.js.map +1 -0
- package/dist/components/ion-note.js +2 -0
- package/dist/components/ion-note.js.map +1 -0
- package/dist/components/ion-picker-column-internal.js +2 -0
- package/dist/components/ion-picker-column-internal.js.map +1 -0
- package/dist/components/ion-picker-column.js +2 -0
- package/dist/components/ion-picker-column.js.map +1 -0
- package/dist/components/ion-picker-internal.js +2 -0
- package/dist/components/ion-picker-internal.js.map +1 -0
- package/dist/components/ion-picker.js +2 -0
- package/dist/components/ion-picker.js.map +1 -0
- package/dist/components/ion-popover.js +2 -0
- package/dist/components/ion-popover.js.map +1 -0
- package/dist/components/ion-progress-bar.js +2 -0
- package/dist/components/ion-progress-bar.js.map +1 -0
- package/dist/components/ion-radio-group.js +2 -0
- package/dist/components/ion-radio-group.js.map +1 -0
- package/dist/components/ion-radio.js +2 -0
- package/dist/components/ion-radio.js.map +1 -0
- package/dist/components/ion-range.js +2 -0
- package/dist/components/ion-range.js.map +1 -0
- package/dist/components/ion-refresher-content.js +2 -0
- package/dist/components/ion-refresher-content.js.map +1 -0
- package/dist/components/ion-refresher.js +2 -0
- package/dist/components/ion-refresher.js.map +1 -0
- package/dist/components/ion-reorder-group.js +2 -0
- package/dist/components/ion-reorder-group.js.map +1 -0
- package/dist/components/ion-reorder.js +2 -0
- package/dist/components/ion-reorder.js.map +1 -0
- package/dist/components/ion-ripple-effect.js +2 -0
- package/dist/components/ion-ripple-effect.js.map +1 -0
- package/dist/components/ion-route-redirect.js +2 -0
- package/dist/components/ion-route-redirect.js.map +1 -0
- package/dist/components/ion-route.js +2 -0
- package/dist/components/ion-route.js.map +1 -0
- package/dist/components/ion-router-link.js +2 -0
- package/dist/components/ion-router-link.js.map +1 -0
- package/dist/components/ion-router-outlet.js +2 -0
- package/dist/components/ion-router-outlet.js.map +1 -0
- package/dist/components/ion-router.js +2 -0
- package/dist/components/ion-router.js.map +1 -0
- package/dist/components/ion-row.js +2 -0
- package/dist/components/ion-row.js.map +1 -0
- package/dist/components/ion-searchbar.js +2 -0
- package/dist/components/ion-searchbar.js.map +1 -0
- package/dist/components/ion-segment-button.js +2 -0
- package/dist/components/ion-segment-button.js.map +1 -0
- package/dist/components/ion-segment.js +2 -0
- package/dist/components/ion-segment.js.map +1 -0
- package/dist/components/ion-select-option.js +2 -0
- package/dist/components/ion-select-option.js.map +1 -0
- package/dist/components/ion-select-popover.js +2 -0
- package/dist/components/ion-select-popover.js.map +1 -0
- package/dist/components/ion-select.js +2 -0
- package/dist/components/ion-select.js.map +1 -0
- package/dist/components/ion-skeleton-text.js +2 -0
- package/dist/components/ion-skeleton-text.js.map +1 -0
- package/dist/components/ion-spinner.js +2 -0
- package/dist/components/ion-spinner.js.map +1 -0
- package/dist/components/ion-split-pane.js +2 -0
- package/dist/components/ion-split-pane.js.map +1 -0
- package/dist/components/ion-tab-bar.js +2 -0
- package/dist/components/ion-tab-bar.js.map +1 -0
- package/dist/components/ion-tab-button.js +2 -0
- package/dist/components/ion-tab-button.js.map +1 -0
- package/dist/components/ion-tab.js +2 -0
- package/dist/components/ion-tab.js.map +1 -0
- package/dist/components/ion-tabs.js +2 -0
- package/dist/components/ion-tabs.js.map +1 -0
- package/dist/components/ion-text.js +2 -0
- package/dist/components/ion-text.js.map +1 -0
- package/dist/components/ion-textarea.js +2 -0
- package/dist/components/ion-textarea.js.map +1 -0
- package/dist/components/ion-thumbnail.js +2 -0
- package/dist/components/ion-thumbnail.js.map +1 -0
- package/dist/components/ion-title.js +2 -0
- package/dist/components/ion-title.js.map +1 -0
- package/dist/components/ion-toast.js +2 -0
- package/dist/components/ion-toast.js.map +1 -0
- package/dist/components/ion-toggle.js +2 -0
- package/dist/components/ion-toggle.js.map +1 -0
- package/dist/components/ion-toolbar.js +2 -0
- package/dist/components/ion-toolbar.js.map +1 -0
- package/dist/components/p-01ad898f.js +2 -0
- package/dist/components/p-01ad898f.js.map +1 -0
- package/dist/components/p-01b49f83.js +2 -0
- package/dist/components/p-01b49f83.js.map +1 -0
- package/dist/components/p-02b77441.js +2 -0
- package/dist/components/p-02b77441.js.map +1 -0
- package/dist/components/p-031ed92d.js +2 -0
- package/dist/components/p-031ed92d.js.map +1 -0
- package/dist/components/p-03803c7d.js +2 -0
- package/dist/components/p-03803c7d.js.map +1 -0
- package/dist/components/p-089e034e.js +2 -0
- package/dist/components/p-089e034e.js.map +1 -0
- package/dist/components/p-0dc7a5ff.js +2 -0
- package/dist/components/p-0dc7a5ff.js.map +1 -0
- package/dist/components/p-110f8490.js +2 -0
- package/dist/components/p-110f8490.js.map +1 -0
- package/dist/components/p-112455b1.js +2 -0
- package/dist/components/p-112455b1.js.map +1 -0
- package/dist/components/p-1596e301.js +2 -0
- package/dist/components/p-1596e301.js.map +1 -0
- package/dist/components/p-1785e30a.js +2 -0
- package/dist/components/p-1785e30a.js.map +1 -0
- package/dist/components/p-2bb89b46.js +2 -0
- package/dist/components/p-2bb89b46.js.map +1 -0
- package/dist/components/p-2d7d745d.js +2 -0
- package/dist/components/p-2d7d745d.js.map +1 -0
- package/dist/components/p-2fc99fef.js +2 -0
- package/dist/components/p-2fc99fef.js.map +1 -0
- package/dist/components/p-3296ebd9.js +2 -0
- package/dist/components/p-3296ebd9.js.map +1 -0
- package/dist/components/p-350e7423.js +2 -0
- package/dist/components/p-350e7423.js.map +1 -0
- package/dist/components/p-39ad94cf.js +2 -0
- package/dist/components/p-39ad94cf.js.map +1 -0
- package/dist/components/p-3d3eefc3.js +2 -0
- package/dist/components/p-3d3eefc3.js.map +1 -0
- package/dist/components/p-3e1d2896.js +2 -0
- package/dist/components/p-3e1d2896.js.map +1 -0
- package/dist/components/p-3e1e3453.js +2 -0
- package/dist/components/p-3e1e3453.js.map +1 -0
- package/dist/components/p-503328f2.js +2 -0
- package/dist/components/p-503328f2.js.map +1 -0
- package/dist/components/p-51c44f42.js +2 -0
- package/dist/components/p-51c44f42.js.map +1 -0
- package/dist/components/p-5280b372.js +2 -0
- package/dist/components/p-5280b372.js.map +1 -0
- package/dist/components/p-53e2dbe4.js +2 -0
- package/dist/components/p-53e2dbe4.js.map +1 -0
- package/dist/components/p-5441c730.js +2 -0
- package/dist/components/p-5441c730.js.map +1 -0
- package/dist/components/p-620fa0ec.js +2 -0
- package/dist/components/p-620fa0ec.js.map +1 -0
- package/dist/components/p-74e68924.js +2 -0
- package/dist/components/p-74e68924.js.map +1 -0
- package/dist/components/p-76525f0f.js +2 -0
- package/dist/components/p-76525f0f.js.map +1 -0
- package/dist/components/p-77104220.js +2 -0
- package/dist/components/p-77104220.js.map +1 -0
- package/dist/components/p-77ccb793.js +2 -0
- package/dist/components/p-77ccb793.js.map +1 -0
- package/dist/components/p-83e529db.js +2 -0
- package/dist/components/p-83e529db.js.map +1 -0
- package/dist/components/p-89c4c5cb.js +2 -0
- package/dist/components/p-89c4c5cb.js.map +1 -0
- package/dist/components/p-8b3d1e06.js +2 -0
- package/dist/components/p-8b3d1e06.js.map +1 -0
- package/dist/components/p-901c16c5.js +2 -0
- package/dist/components/p-901c16c5.js.map +1 -0
- package/dist/components/p-93e2a608.js +2 -0
- package/dist/components/p-93e2a608.js.map +1 -0
- package/dist/components/p-94286cc3.js +2 -0
- package/dist/components/p-94286cc3.js.map +1 -0
- package/dist/components/p-95c79593.js +2 -0
- package/dist/components/p-95c79593.js.map +1 -0
- package/dist/components/p-96073863.js +2 -0
- package/dist/components/p-96073863.js.map +1 -0
- package/dist/components/p-99e447f9.js +2 -0
- package/dist/components/p-99e447f9.js.map +1 -0
- package/dist/components/p-9b519de5.js +2 -0
- package/dist/components/p-9b519de5.js.map +1 -0
- package/dist/components/p-9d350d61.js +2 -0
- package/dist/components/p-9d350d61.js.map +1 -0
- package/dist/components/p-9df67c24.js +2 -0
- package/dist/components/p-9df67c24.js.map +1 -0
- package/dist/components/p-9f4ac833.js +2 -0
- package/dist/components/p-9f4ac833.js.map +1 -0
- package/dist/components/p-a0e691dd.js +2 -0
- package/dist/components/p-a0e691dd.js.map +1 -0
- package/dist/components/p-ab10d1ae.js +2 -0
- package/dist/components/p-ab10d1ae.js.map +1 -0
- package/dist/components/p-abc01c5d.js +2 -0
- package/dist/components/p-abc01c5d.js.map +1 -0
- package/dist/components/p-abd248d1.js +2 -0
- package/dist/components/p-abd248d1.js.map +1 -0
- package/dist/components/p-af073aaf.js +2 -0
- package/dist/components/p-af073aaf.js.map +1 -0
- package/dist/components/p-b2289937.js +2 -0
- package/dist/components/p-b2289937.js.map +1 -0
- package/dist/components/p-b32529b9.js +2 -0
- package/dist/components/p-b32529b9.js.map +1 -0
- package/dist/components/{p-02bc6b21.js → p-b7484b7a.js} +11 -4
- package/dist/components/p-b7484b7a.js.map +1 -0
- package/dist/components/p-b8fdd517.js +2 -0
- package/dist/components/p-b8fdd517.js.map +1 -0
- package/dist/components/p-cebc113f.js +2 -0
- package/dist/components/p-cebc113f.js.map +1 -0
- package/dist/components/p-d25fd077.js +2 -0
- package/dist/components/p-d25fd077.js.map +1 -0
- package/dist/components/p-d3596f64.js +2 -0
- package/dist/components/p-d3596f64.js.map +1 -0
- package/dist/components/p-d5862637.js +2 -0
- package/dist/components/p-d5862637.js.map +1 -0
- package/dist/components/p-d60b2328.js +2 -0
- package/dist/components/p-d60b2328.js.map +1 -0
- package/dist/components/p-d69dc32f.js +2 -0
- package/dist/components/p-d69dc32f.js.map +1 -0
- package/dist/components/p-d72e8d7b.js +2 -0
- package/dist/components/p-d72e8d7b.js.map +1 -0
- package/dist/components/p-d7fe59ee.js +2 -0
- package/dist/components/p-d7fe59ee.js.map +1 -0
- package/dist/components/p-d839c693.js +2 -0
- package/dist/components/p-d839c693.js.map +1 -0
- package/dist/components/p-e187a77c.js +2 -0
- package/dist/components/p-e187a77c.js.map +1 -0
- package/dist/components/p-e65ea9fb.js +2 -0
- package/dist/components/p-e65ea9fb.js.map +1 -0
- package/dist/components/p-ec0e3f3f.js +2 -0
- package/dist/components/p-ec0e3f3f.js.map +1 -0
- package/dist/components/p-ecb4db1c.js +2 -0
- package/dist/components/p-ecb4db1c.js.map +1 -0
- package/dist/components/p-f728a68f.js +2 -0
- package/dist/components/p-f728a68f.js.map +1 -0
- package/dist/components/p-f7e3c502.js +2 -0
- package/dist/components/p-f7e3c502.js.map +1 -0
- package/dist/components/p-fe463a42.js +2 -0
- package/dist/components/p-fe463a42.js.map +1 -0
- package/dist/esm/_commonjsHelpers-9943807e.js +2 -0
- package/dist/esm/_commonjsHelpers-9943807e.js.map +1 -0
- package/dist/esm/amwal-checkout-button_5.entry.js +6 -4
- package/dist/esm/amwal-checkout-button_5.entry.js.map +1 -0
- package/dist/esm/amwal-installments-guide.entry.js +2 -0
- package/dist/esm/amwal-installments-guide.entry.js.map +1 -0
- package/dist/esm/amwal-pos.entry.js +2 -0
- package/dist/esm/amwal-pos.entry.js.map +1 -0
- package/dist/esm/amwal-widget-modal.entry.js +10 -3
- package/dist/esm/amwal-widget-modal.entry.js.map +1 -0
- package/dist/esm/amwal-widget.entry.js +3 -1
- package/dist/esm/amwal-widget.entry.js.map +1 -0
- package/dist/esm/animation-a6d5c3b1.js +2 -0
- package/dist/esm/animation-a6d5c3b1.js.map +1 -0
- package/dist/esm/app-globals-c817b28b.js +2 -0
- package/dist/esm/app-globals-c817b28b.js.map +1 -0
- package/dist/esm/ar-7d2629bf.js +2 -0
- package/dist/esm/ar-7d2629bf.js.map +1 -0
- package/dist/esm/capacitor-ba4337da.js +2 -0
- package/dist/esm/capacitor-ba4337da.js.map +1 -0
- package/dist/esm/checkout.js +3 -1
- package/dist/esm/checkout.js.map +1 -0
- package/dist/esm/compare-with-utils-d58be312.js +2 -0
- package/dist/esm/compare-with-utils-d58be312.js.map +1 -0
- package/dist/esm/config-8e06237c.js +2 -0
- package/dist/esm/config-8e06237c.js.map +1 -0
- package/dist/esm/cubic-bezier-874f336d.js +2 -0
- package/dist/esm/cubic-bezier-874f336d.js.map +1 -0
- package/dist/esm/data-8916315d.js +2 -0
- package/dist/esm/data-8916315d.js.map +1 -0
- package/dist/esm/dir-1d4aa386.js +2 -0
- package/dist/esm/dir-1d4aa386.js.map +1 -0
- package/dist/esm/focus-visible-32968d3d.js +2 -0
- package/dist/esm/focus-visible-32968d3d.js.map +1 -0
- package/dist/esm/form-controller-b1aa7393.js +2 -0
- package/dist/esm/form-controller-b1aa7393.js.map +1 -0
- package/dist/esm/framework-delegate-de1aa369.js +2 -0
- package/dist/esm/framework-delegate-de1aa369.js.map +1 -0
- package/dist/esm/gesture-controller-58ffa500.js +2 -0
- package/dist/esm/gesture-controller-58ffa500.js.map +1 -0
- package/dist/esm/haptic-4d4d8eb1.js +2 -0
- package/dist/esm/haptic-4d4d8eb1.js.map +1 -0
- package/dist/esm/hardware-back-button-f93acff0.js +2 -0
- package/dist/esm/hardware-back-button-f93acff0.js.map +1 -0
- package/dist/esm/helpers-f0dcbd72.js +2 -0
- package/dist/esm/helpers-f0dcbd72.js.map +1 -0
- package/dist/esm/i18n-53f85411.js +2 -0
- package/dist/esm/i18n-53f85411.js.map +1 -0
- package/dist/esm/index-0b560278.js +2 -0
- package/dist/esm/index-0b560278.js.map +1 -0
- package/dist/esm/index-5894dd63.js +2 -0
- package/dist/esm/index-5894dd63.js.map +1 -0
- package/dist/esm/index-5a126e54.js +2 -0
- package/dist/esm/index-5a126e54.js.map +1 -0
- package/dist/esm/index-5e663431.js +2 -0
- package/dist/esm/index-5e663431.js.map +1 -0
- package/dist/esm/index-8cc94b11.js +2 -0
- package/dist/esm/index-8cc94b11.js.map +1 -0
- package/dist/esm/index-afdf867c.js +2 -0
- package/dist/esm/index-afdf867c.js.map +1 -0
- package/dist/esm/index-d9b41a43.js +2 -0
- package/dist/esm/index-d9b41a43.js.map +1 -0
- package/dist/esm/index-f6dce931.js +2 -0
- package/dist/esm/index-f6dce931.js.map +1 -0
- package/dist/esm/index-fb97e55c.js +2 -0
- package/dist/esm/index-fb97e55c.js.map +1 -0
- package/dist/esm/index.js +2 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/input-shims-75d4750d.js +2 -0
- package/dist/esm/input-shims-75d4750d.js.map +1 -0
- package/dist/esm/input.utils-79bde07f.js +2 -0
- package/dist/esm/input.utils-79bde07f.js.map +1 -0
- package/dist/esm/ion-accordion-group.entry.js +2 -0
- package/dist/esm/ion-accordion-group.entry.js.map +1 -0
- package/dist/esm/ion-accordion.entry.js +2 -0
- package/dist/esm/ion-accordion.entry.js.map +1 -0
- package/dist/esm/ion-action-sheet_3.entry.js +2 -0
- package/dist/esm/ion-action-sheet_3.entry.js.map +1 -0
- package/dist/esm/ion-app.entry.js +2 -0
- package/dist/esm/ion-app.entry.js.map +1 -0
- package/dist/esm/ion-avatar.entry.js +2 -0
- package/dist/esm/ion-avatar.entry.js.map +1 -0
- package/dist/esm/ion-back-button.entry.js +2 -0
- package/dist/esm/ion-back-button.entry.js.map +1 -0
- package/dist/esm/ion-backdrop.entry.js +2 -0
- package/dist/esm/ion-backdrop.entry.js.map +1 -0
- package/dist/esm/ion-badge.entry.js +2 -0
- package/dist/esm/ion-badge.entry.js.map +1 -0
- package/dist/esm/ion-breadcrumb.entry.js +2 -0
- package/dist/esm/ion-breadcrumb.entry.js.map +1 -0
- package/dist/esm/ion-breadcrumbs.entry.js +2 -0
- package/dist/esm/ion-breadcrumbs.entry.js.map +1 -0
- package/dist/esm/ion-buttons_3.entry.js +2 -0
- package/dist/esm/ion-buttons_3.entry.js.map +1 -0
- package/dist/esm/ion-card-content.entry.js +2 -0
- package/dist/esm/ion-card-content.entry.js.map +1 -0
- package/dist/esm/ion-card-header.entry.js +2 -0
- package/dist/esm/ion-card-header.entry.js.map +1 -0
- package/dist/esm/ion-card-subtitle.entry.js +2 -0
- package/dist/esm/ion-card-subtitle.entry.js.map +1 -0
- package/dist/esm/ion-card-title.entry.js +2 -0
- package/dist/esm/ion-card-title.entry.js.map +1 -0
- package/dist/esm/ion-card.entry.js +2 -0
- package/dist/esm/ion-card.entry.js.map +1 -0
- package/dist/esm/ion-checkbox_7.entry.js +2 -0
- package/dist/esm/ion-checkbox_7.entry.js.map +1 -0
- package/dist/esm/ion-chip.entry.js +2 -0
- package/dist/esm/ion-chip.entry.js.map +1 -0
- package/dist/esm/ion-col.entry.js +2 -0
- package/dist/esm/ion-col.entry.js.map +1 -0
- package/dist/esm/ion-content.entry.js +2 -0
- package/dist/esm/ion-content.entry.js.map +1 -0
- package/dist/esm/ion-datetime-button.entry.js +2 -0
- package/dist/esm/ion-datetime-button.entry.js.map +1 -0
- package/dist/esm/ion-datetime.entry.js +2 -0
- package/dist/esm/ion-datetime.entry.js.map +1 -0
- package/dist/esm/ion-fab-button.entry.js +2 -0
- package/dist/esm/ion-fab-button.entry.js.map +1 -0
- package/dist/esm/ion-fab-list.entry.js +2 -0
- package/dist/esm/ion-fab-list.entry.js.map +1 -0
- package/dist/esm/ion-fab.entry.js +2 -0
- package/dist/esm/ion-fab.entry.js.map +1 -0
- package/dist/esm/ion-footer.entry.js +2 -0
- package/dist/esm/ion-footer.entry.js.map +1 -0
- package/dist/esm/ion-grid.entry.js +2 -0
- package/dist/esm/ion-grid.entry.js.map +1 -0
- package/dist/esm/ion-header.entry.js +2 -0
- package/dist/esm/ion-header.entry.js.map +1 -0
- package/dist/esm/ion-icon.entry.js +2 -0
- package/dist/esm/ion-icon.entry.js.map +1 -0
- package/dist/esm/ion-img.entry.js +2 -0
- package/dist/esm/ion-img.entry.js.map +1 -0
- package/dist/esm/ion-infinite-scroll-content.entry.js +2 -0
- package/dist/esm/ion-infinite-scroll-content.entry.js.map +1 -0
- package/dist/esm/ion-infinite-scroll.entry.js +2 -0
- package/dist/esm/ion-infinite-scroll.entry.js.map +1 -0
- package/dist/esm/ion-input.entry.js +2 -0
- package/dist/esm/ion-input.entry.js.map +1 -0
- package/dist/esm/ion-item-divider.entry.js +2 -0
- package/dist/esm/ion-item-divider.entry.js.map +1 -0
- package/dist/esm/ion-item-group.entry.js +2 -0
- package/dist/esm/ion-item-group.entry.js.map +1 -0
- package/dist/esm/ion-item-option.entry.js +2 -0
- package/dist/esm/ion-item-option.entry.js.map +1 -0
- package/dist/esm/ion-item-options.entry.js +2 -0
- package/dist/esm/ion-item-options.entry.js.map +1 -0
- package/dist/esm/ion-item-sliding.entry.js +2 -0
- package/dist/esm/ion-item-sliding.entry.js.map +1 -0
- package/dist/esm/ion-loading.entry.js +2 -0
- package/dist/esm/ion-loading.entry.js.map +1 -0
- package/dist/esm/ion-menu-button.entry.js +2 -0
- package/dist/esm/ion-menu-button.entry.js.map +1 -0
- package/dist/esm/ion-menu-toggle.entry.js +2 -0
- package/dist/esm/ion-menu-toggle.entry.js.map +1 -0
- package/dist/esm/ion-menu.entry.js +2 -0
- package/dist/esm/ion-menu.entry.js.map +1 -0
- package/dist/esm/ion-modal.entry.js +2 -0
- package/dist/esm/ion-modal.entry.js.map +1 -0
- package/dist/esm/ion-nav-link.entry.js +2 -0
- package/dist/esm/ion-nav-link.entry.js.map +1 -0
- package/dist/esm/ion-nav.entry.js +2 -0
- package/dist/esm/ion-nav.entry.js.map +1 -0
- package/dist/esm/ion-note.entry.js +2 -0
- package/dist/esm/ion-note.entry.js.map +1 -0
- package/dist/esm/ion-picker-column.entry.js +2 -0
- package/dist/esm/ion-picker-column.entry.js.map +1 -0
- package/dist/esm/ion-picker.entry.js +2 -0
- package/dist/esm/ion-picker.entry.js.map +1 -0
- package/dist/esm/ion-popover.entry.js +2 -0
- package/dist/esm/ion-popover.entry.js.map +1 -0
- package/dist/esm/ion-progress-bar.entry.js +2 -0
- package/dist/esm/ion-progress-bar.entry.js.map +1 -0
- package/dist/esm/ion-range.entry.js +2 -0
- package/dist/esm/ion-range.entry.js.map +1 -0
- package/dist/esm/ion-refresher-content.entry.js +2 -0
- package/dist/esm/ion-refresher-content.entry.js.map +1 -0
- package/dist/esm/ion-refresher.entry.js +2 -0
- package/dist/esm/ion-refresher.entry.js.map +1 -0
- package/dist/esm/ion-reorder-group.entry.js +2 -0
- package/dist/esm/ion-reorder-group.entry.js.map +1 -0
- package/dist/esm/ion-reorder.entry.js +2 -0
- package/dist/esm/ion-reorder.entry.js.map +1 -0
- package/dist/esm/ion-route-redirect.entry.js +2 -0
- package/dist/esm/ion-route-redirect.entry.js.map +1 -0
- package/dist/esm/ion-route.entry.js +2 -0
- package/dist/esm/ion-route.entry.js.map +1 -0
- package/dist/esm/ion-router-link.entry.js +2 -0
- package/dist/esm/ion-router-link.entry.js.map +1 -0
- package/dist/esm/ion-router-outlet.entry.js +2 -0
- package/dist/esm/ion-router-outlet.entry.js.map +1 -0
- package/dist/esm/ion-router.entry.js +2 -0
- package/dist/esm/ion-router.entry.js.map +1 -0
- package/dist/esm/ion-row.entry.js +2 -0
- package/dist/esm/ion-row.entry.js.map +1 -0
- package/dist/esm/ion-searchbar.entry.js +2 -0
- package/dist/esm/ion-searchbar.entry.js.map +1 -0
- package/dist/esm/ion-segment-button.entry.js +2 -0
- package/dist/esm/ion-segment-button.entry.js.map +1 -0
- package/dist/esm/ion-segment.entry.js +2 -0
- package/dist/esm/ion-segment.entry.js.map +1 -0
- package/dist/esm/ion-select-option.entry.js +2 -0
- package/dist/esm/ion-select-option.entry.js.map +1 -0
- package/dist/esm/ion-select.entry.js +2 -0
- package/dist/esm/ion-select.entry.js.map +1 -0
- package/dist/esm/ion-skeleton-text.entry.js +2 -0
- package/dist/esm/ion-skeleton-text.entry.js.map +1 -0
- package/dist/esm/ion-spinner.entry.js +2 -0
- package/dist/esm/ion-spinner.entry.js.map +1 -0
- package/dist/esm/ion-split-pane.entry.js +2 -0
- package/dist/esm/ion-split-pane.entry.js.map +1 -0
- package/dist/esm/ion-tab-bar.entry.js +2 -0
- package/dist/esm/ion-tab-bar.entry.js.map +1 -0
- package/dist/esm/ion-tab-button.entry.js +2 -0
- package/dist/esm/ion-tab-button.entry.js.map +1 -0
- package/dist/esm/ion-tab.entry.js +2 -0
- package/dist/esm/ion-tab.entry.js.map +1 -0
- package/dist/esm/ion-tabs.entry.js +2 -0
- package/dist/esm/ion-tabs.entry.js.map +1 -0
- package/dist/esm/ion-textarea.entry.js +2 -0
- package/dist/esm/ion-textarea.entry.js.map +1 -0
- package/dist/esm/ion-thumbnail.entry.js +2 -0
- package/dist/esm/ion-thumbnail.entry.js.map +1 -0
- package/dist/esm/ion-title.entry.js +2 -0
- package/dist/esm/ion-title.entry.js.map +1 -0
- package/dist/esm/ion-toast.entry.js +2 -0
- package/dist/esm/ion-toast.entry.js.map +1 -0
- package/dist/esm/ion-toggle.entry.js +2 -0
- package/dist/esm/ion-toggle.entry.js.map +1 -0
- package/dist/esm/ion-toolbar.entry.js +2 -0
- package/dist/esm/ion-toolbar.entry.js.map +1 -0
- package/dist/esm/ionic-global-0b7766cb.js +2 -0
- package/dist/esm/ionic-global-0b7766cb.js.map +1 -0
- package/dist/esm/ios.transition-22fb53bc.js +2 -0
- package/dist/esm/ios.transition-22fb53bc.js.map +1 -0
- package/dist/esm/keyboard-1f073554.js +2 -0
- package/dist/esm/keyboard-1f073554.js.map +1 -0
- package/dist/esm/keyboard-96b6e80b.js +2 -0
- package/dist/esm/keyboard-96b6e80b.js.map +1 -0
- package/dist/esm/keyboard-controller-5a2f625f.js +2 -0
- package/dist/esm/keyboard-controller-5a2f625f.js.map +1 -0
- package/dist/esm/loader.js +3 -1
- package/dist/esm/loader.js.map +1 -0
- package/dist/esm/lock-controller-632e3c10.js +2 -0
- package/dist/esm/lock-controller-632e3c10.js.map +1 -0
- package/dist/esm/md.transition-f6ff9834.js +2 -0
- package/dist/esm/md.transition-f6ff9834.js.map +1 -0
- package/dist/esm/menu-toggle-util-594849ff.js +2 -0
- package/dist/esm/menu-toggle-util-594849ff.js.map +1 -0
- package/dist/esm/notch-controller-d511b3b3.js +2 -0
- package/dist/esm/notch-controller-d511b3b3.js.map +1 -0
- package/dist/esm/overlays-642a91df.js +2 -0
- package/dist/esm/overlays-642a91df.js.map +1 -0
- package/dist/esm/refresher.utils-19137568.js +2 -0
- package/dist/esm/refresher.utils-19137568.js.map +1 -0
- package/dist/esm/spinner-configs-c9fb0813.js +2 -0
- package/dist/esm/spinner-configs-c9fb0813.js.map +1 -0
- package/dist/esm/status-tap-bb6959a8.js +2 -0
- package/dist/esm/status-tap-bb6959a8.js.map +1 -0
- package/dist/esm/swipe-back-6cec4c33.js +2 -0
- package/dist/esm/swipe-back-6cec4c33.js.map +1 -0
- package/dist/esm/theme-35c700b7.js +2 -0
- package/dist/esm/theme-35c700b7.js.map +1 -0
- package/dist/esm/watch-options-7bf43687.js +2 -0
- package/dist/esm/watch-options-7bf43687.js.map +1 -0
- package/dist/types/components/amwal-widget/amwal-widget-modal.d.ts +1 -0
- package/package.json +3 -2
- package/dist/checkout/p-00045a8c.entry.js +0 -1
- package/dist/checkout/p-01bbe74f.entry.js +0 -1
- package/dist/checkout/p-051412fa.entry.js +0 -1
- package/dist/checkout/p-09cbe586.entry.js +0 -4
- package/dist/checkout/p-0a85a01f.entry.js +0 -7
- package/dist/checkout/p-0bbfeb3c.entry.js +0 -1
- package/dist/checkout/p-0d96b482.entry.js +0 -1
- package/dist/checkout/p-104d7733.entry.js +0 -1
- package/dist/checkout/p-10ad151a.entry.js +0 -14
- package/dist/checkout/p-11beffea.entry.js +0 -1
- package/dist/checkout/p-13741a94.entry.js +0 -1
- package/dist/checkout/p-14ea2c82.entry.js +0 -1
- package/dist/checkout/p-167dc7a7.entry.js +0 -4
- package/dist/checkout/p-1a749b59.entry.js +0 -1
- package/dist/checkout/p-1c718939.entry.js +0 -1
- package/dist/checkout/p-1cbb13f2.entry.js +0 -1
- package/dist/checkout/p-20df5234.entry.js +0 -1
- package/dist/checkout/p-24068b1c.entry.js +0 -1
- package/dist/checkout/p-28ccecc7.entry.js +0 -4
- package/dist/checkout/p-3e8da476.entry.js +0 -4
- package/dist/checkout/p-4028c0d2.entry.js +0 -1
- package/dist/checkout/p-44c91c42.entry.js +0 -1
- package/dist/checkout/p-464f5a60.entry.js +0 -1
- package/dist/checkout/p-46b7ee7f.entry.js +0 -1
- package/dist/checkout/p-48784250.entry.js +0 -1
- package/dist/checkout/p-529bce3f.entry.js +0 -1
- package/dist/checkout/p-5eecd5ef.entry.js +0 -1
- package/dist/checkout/p-64257c8d.entry.js +0 -1
- package/dist/checkout/p-64bd1dd3.entry.js +0 -1
- package/dist/checkout/p-68a4caba.entry.js +0 -1
- package/dist/checkout/p-69242ed6.entry.js +0 -1
- package/dist/checkout/p-6d886d7e.entry.js +0 -1
- package/dist/checkout/p-6fb474f3.entry.js +0 -1
- package/dist/checkout/p-79ec3e4b.entry.js +0 -1
- package/dist/checkout/p-7b51bf67.entry.js +0 -7
- package/dist/checkout/p-7fe50ab4.entry.js +0 -1
- package/dist/checkout/p-880b451c.entry.js +0 -4
- package/dist/checkout/p-886dad62.entry.js +0 -1
- package/dist/checkout/p-886e8746.entry.js +0 -1
- package/dist/checkout/p-8a97a411.entry.js +0 -1
- package/dist/checkout/p-8af3c6cc.entry.js +0 -1
- package/dist/checkout/p-8c022f5d.entry.js +0 -1
- package/dist/checkout/p-91855eae.entry.js +0 -1
- package/dist/checkout/p-9185e55b.entry.js +0 -1
- package/dist/checkout/p-926eda98.entry.js +0 -1
- package/dist/checkout/p-93e5b313.entry.js +0 -4
- package/dist/checkout/p-97024acb.entry.js +0 -1
- package/dist/checkout/p-9b65a6e5.entry.js +0 -1
- package/dist/checkout/p-9cc1fdfb.entry.js +0 -1
- package/dist/checkout/p-9f26fb71.entry.js +0 -1
- package/dist/checkout/p-9f41a631.entry.js +0 -1
- package/dist/checkout/p-a2ce8858.entry.js +0 -1
- package/dist/checkout/p-a3fca65c.entry.js +0 -1
- package/dist/checkout/p-a6056eb1.entry.js +0 -4
- package/dist/checkout/p-a7b2cbb9.entry.js +0 -1
- package/dist/checkout/p-ab9a18c4.entry.js +0 -1
- package/dist/checkout/p-b4ad8642.entry.js +0 -1
- package/dist/checkout/p-b4cf78ad.entry.js +0 -1
- package/dist/checkout/p-b9d8ab12.entry.js +0 -1
- package/dist/checkout/p-bd4df0bc.entry.js +0 -1
- package/dist/checkout/p-c61a3d5d.entry.js +0 -1
- package/dist/checkout/p-c6ee4bb6.entry.js +0 -1
- package/dist/checkout/p-c771a565.entry.js +0 -1
- package/dist/checkout/p-c82b2823.entry.js +0 -1
- package/dist/checkout/p-c8f7d1b5.entry.js +0 -1
- package/dist/checkout/p-ceef30cd.entry.js +0 -1
- package/dist/checkout/p-d5733333.entry.js +0 -1
- package/dist/checkout/p-d5bba69c.entry.js +0 -1
- package/dist/checkout/p-d60e05e2.entry.js +0 -1
- package/dist/checkout/p-d6b04157.entry.js +0 -1
- package/dist/checkout/p-d9dfb3ae.entry.js +0 -7
- package/dist/checkout/p-ddbe30b8.entry.js +0 -1
- package/dist/checkout/p-de418dd1.entry.js +0 -1
- package/dist/checkout/p-defa5f72.entry.js +0 -4
- package/dist/checkout/p-df0fa5e1.entry.js +0 -7
- package/dist/checkout/p-e0f073f1.entry.js +0 -7
- package/dist/checkout/p-e237d611.entry.js +0 -1
- package/dist/checkout/p-ea71fb8d.entry.js +0 -1
- package/dist/checkout/p-eda93a0b.entry.js +0 -1
- package/dist/checkout/p-eee05053.entry.js +0 -1
- package/dist/checkout/p-f8460dc4.entry.js +0 -1
- package/dist/checkout/p-f875507d.entry.js +0 -1
- package/dist/checkout/p-fb147065.entry.js +0 -1
- package/dist/checkout/p-fb45cdd1.entry.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["lastOverlayIndex","lastId","activeAnimations","WeakMap","createController","tagName","create","options","createOverlay","dismiss","data","role","id","dismissOverlay","document","async","getPresentedOverlay","alertController","actionSheetController","modalController","popoverController","prepareOverlay","el","connectListeners","overlayIndex","setOverlayId","hasAttribute","opts","window","customElements","whenDefined","then","element","createElement","classList","add","Object","assign","hasController","getAppRoot","appendChild","Promise","resolve","componentOnReady","focusableQueryString","isOverlayHidden","overlay","contains","focusFirstDescendant","ref","firstInput","querySelector","focusElementInOverlay","focusLastDescendant","inputs","Array","from","querySelectorAll","lastInput","length","hostToFocus","elementToFocus","shadowRoot","focusVisibleElement","focus","trapKeyboardFocus","ev","doc","lastOverlay","target","trapScopedFocus","lastFocus","undefined","overlayRoot","getElementRoot","overlayWrapper","activeElement","trapShadowFocus","addEventListener","backdropDismiss","detail","register","OVERLAY_BACK_BUTTON_PRIORITY","BACKDROP","shouldUseCloseWatcher","key","overlayTag","reject","getOverlays","selector","filter","c","getPresentedOverlays","o","overlays","find","setRootAriaHidden","hidden","root","viewContainer","setAttribute","removeAttribute","present","name","iosEnterAnimation","mdEnterAnimation","_a","_b","presented","hideOverlaysFromScreenReaders","willPresent","emit","willPresentShorthand","mode","getIonMode","animationBuilder","enterAnimation","config","get","completed","overlayAnimation","didPresent","didPresentShorthand","restoreElementFocus","keyboardClose","overlayEl","previousElement","onDidDismiss","body","iosLeaveAnimation","mdLeaveAnimation","style","setProperty","willDismiss","willDismissShorthand","leaveAnimation","GESTURE","didDismiss","didDismissShorthand","animations","forEach","ani","destroy","delete","removeProperty","err","console","error","remove","revealOverlaysToScreenReaders","baseEl","aniRoot","animation","animated","getBoolean","duration","beforeAddWrite","ownerDocument","matches","blur","activeAni","set","play","eventMethod","eventName","promise","r","onceEvent","event","callback","handler","removeEventListener","isCancel","defaultGate","h","safeCall","arg","jmp","e","OVERLAY_GESTURE_PRIORITY","createDelegateController","inline","workingDelegate","coreDelegate","CoreDelegate","getDelegate","force","delegate","parentEl","parentNode","attachViewToDom","component","Error","removeViewFromDom","parentElement","createTriggerController","destroyTriggerInteraction","removeClickListener","addClickListener","trigger","triggerEl","getElementById","printIonWarning","configureTriggerInteraction","targetEl","openOverlay","newTopMostOverlay","i","presentedOverlay","nextPresentedOverlay","currentOverlay"],"sources":["./node_modules/@ionic/core/dist/collection/utils/overlays.js"],"sourcesContent":["/*!\n * (C) Ionic http://ionicframework.com - MIT License\n */\nimport { doc } from \"./browser/index\";\nimport { shouldUseCloseWatcher } from \"./hardware-back-button\";\nimport { config } from \"../global/config\";\nimport { getIonMode } from \"../global/ionic-global\";\nimport { CoreDelegate } from \"./framework-delegate\";\nimport { OVERLAY_BACK_BUTTON_PRIORITY } from \"./hardware-back-button\";\nimport { addEventListener, componentOnReady, focusVisibleElement, getElementRoot, removeEventListener, } from \"./helpers\";\nimport { printIonWarning } from \"./logging\";\nlet lastOverlayIndex = 0;\nlet lastId = 0;\nexport const activeAnimations = new WeakMap();\nconst createController = (tagName) => {\n return {\n create(options) {\n return createOverlay(tagName, options);\n },\n dismiss(data, role, id) {\n return dismissOverlay(document, data, role, tagName, id);\n },\n async getTop() {\n return getPresentedOverlay(document, tagName);\n },\n };\n};\nexport const alertController = /*@__PURE__*/ createController('ion-alert');\nexport const actionSheetController = /*@__PURE__*/ createController('ion-action-sheet');\nexport const loadingController = /*@__PURE__*/ createController('ion-loading');\nexport const modalController = /*@__PURE__*/ createController('ion-modal');\nexport const pickerController = /*@__PURE__*/ createController('ion-picker');\nexport const popoverController = /*@__PURE__*/ createController('ion-popover');\nexport const toastController = /*@__PURE__*/ createController('ion-toast');\n/**\n * Prepares the overlay element to be presented.\n */\nexport const prepareOverlay = (el) => {\n if (typeof document !== 'undefined') {\n /**\n * Adds a single instance of event listeners for application behaviors:\n *\n * - Escape Key behavior to dismiss an overlay\n * - Trapping focus within an overlay\n * - Back button behavior to dismiss an overlay\n *\n * This only occurs when the first overlay is created.\n */\n connectListeners(document);\n }\n const overlayIndex = lastOverlayIndex++;\n /**\n * overlayIndex is used in the overlay components to set a zIndex.\n * This ensures that the most recently presented overlay will be\n * on top.\n */\n el.overlayIndex = overlayIndex;\n};\n/**\n * Assigns an incrementing id to an overlay element, that does not\n * already have an id assigned to it.\n *\n * Used to track unique instances of an overlay element.\n */\nexport const setOverlayId = (el) => {\n if (!el.hasAttribute('id')) {\n el.id = `ion-overlay-${++lastId}`;\n }\n return el.id;\n};\nexport const createOverlay = (tagName, opts) => {\n // eslint-disable-next-line @typescript-eslint/prefer-optional-chain\n if (typeof window !== 'undefined' && typeof window.customElements !== 'undefined') {\n return window.customElements.whenDefined(tagName).then(() => {\n const element = document.createElement(tagName);\n element.classList.add('overlay-hidden');\n /**\n * Convert the passed in overlay options into props\n * that get passed down into the new overlay.\n */\n Object.assign(element, Object.assign(Object.assign({}, opts), { hasController: true }));\n // append the overlay element to the document body\n getAppRoot(document).appendChild(element);\n return new Promise((resolve) => componentOnReady(element, resolve));\n });\n }\n return Promise.resolve();\n};\n/**\n * This query string selects elements that\n * are eligible to receive focus. We select\n * interactive elements that meet the following\n * criteria:\n * 1. Element does not have a negative tabindex\n * 2. Element does not have `hidden`\n * 3. Element does not have `disabled` for non-Ionic components.\n * 4. Element does not have `disabled` or `disabled=\"true\"` for Ionic components.\n * Note: We need this distinction because `disabled=\"false\"` is\n * valid usage for the disabled property on ion-button.\n */\nconst focusableQueryString = '[tabindex]:not([tabindex^=\"-\"]):not([hidden]):not([disabled]), input:not([type=hidden]):not([tabindex^=\"-\"]):not([hidden]):not([disabled]), textarea:not([tabindex^=\"-\"]):not([hidden]):not([disabled]), button:not([tabindex^=\"-\"]):not([hidden]):not([disabled]), select:not([tabindex^=\"-\"]):not([hidden]):not([disabled]), .ion-focusable:not([tabindex^=\"-\"]):not([hidden]):not([disabled]), .ion-focusable[disabled=\"false\"]:not([tabindex^=\"-\"]):not([hidden])';\nconst isOverlayHidden = (overlay) => overlay.classList.contains('overlay-hidden');\n/**\n * Focuses the first descendant in an overlay\n * that can receive focus. If none exists,\n * the entire overlay will be focused.\n */\nexport const focusFirstDescendant = (ref, overlay) => {\n const firstInput = ref.querySelector(focusableQueryString);\n focusElementInOverlay(firstInput, overlay);\n};\n/**\n * Focuses the last descendant in an overlay\n * that can receive focus. If none exists,\n * the entire overlay will be focused.\n */\nconst focusLastDescendant = (ref, overlay) => {\n const inputs = Array.from(ref.querySelectorAll(focusableQueryString));\n const lastInput = inputs.length > 0 ? inputs[inputs.length - 1] : null;\n focusElementInOverlay(lastInput, overlay);\n};\n/**\n * Focuses a particular element in an overlay. If the element\n * doesn't have anything focusable associated with it then\n * the overlay itself will be focused.\n * This should be used instead of the focus() method\n * on most elements because the focusable element\n * may not be the host element.\n *\n * For example, if an ion-button should be focused\n * then we should actually focus the native <button>\n * element inside of ion-button's shadow root, not\n * the host element itself.\n */\nconst focusElementInOverlay = (hostToFocus, overlay) => {\n let elementToFocus = hostToFocus;\n const shadowRoot = hostToFocus === null || hostToFocus === void 0 ? void 0 : hostToFocus.shadowRoot;\n if (shadowRoot) {\n // If there are no inner focusable elements, just focus the host element.\n elementToFocus = shadowRoot.querySelector(focusableQueryString) || hostToFocus;\n }\n if (elementToFocus) {\n focusVisibleElement(elementToFocus);\n }\n else {\n // Focus overlay instead of letting focus escape\n overlay.focus();\n }\n};\n/**\n * Traps keyboard focus inside of overlay components.\n * Based on https://w3c.github.io/aria-practices/examples/dialog-modal/alertdialog.html\n * This includes the following components: Action Sheet, Alert, Loading, Modal,\n * Picker, and Popover.\n * Should NOT include: Toast\n */\nconst trapKeyboardFocus = (ev, doc) => {\n const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker,ion-popover');\n const target = ev.target;\n /**\n * If no active overlay, ignore this event.\n *\n * If this component uses the shadow dom,\n * this global listener is pointless\n * since it will not catch the focus\n * traps as they are inside the shadow root.\n * We need to add a listener to the shadow root\n * itself to ensure the focus trap works.\n */\n if (!lastOverlay || !target) {\n return;\n }\n /**\n * If the ion-disable-focus-trap class\n * is present on an overlay, then this component\n * instance has opted out of focus trapping.\n * An example of this is when the sheet modal\n * has a backdrop that is disabled. The content\n * behind the sheet should be focusable until\n * the backdrop is enabled.\n */\n if (lastOverlay.classList.contains('ion-disable-focus-trap')) {\n return;\n }\n const trapScopedFocus = () => {\n /**\n * If we are focusing the overlay, clear\n * the last focused element so that hitting\n * tab activates the first focusable element\n * in the overlay wrapper.\n */\n if (lastOverlay === target) {\n lastOverlay.lastFocus = undefined;\n /**\n * Toasts can be presented from an overlay.\n * However, focus should still be returned to\n * the overlay when clicking a toast. Normally,\n * focus would be returned to the last focusable\n * descendant in the overlay which may not always be\n * the button that the toast was presented from. In this case,\n * the focus may be returned to an unexpected element.\n * To account for this, we make sure to return focus to the\n * last focused element in the overlay if focus is\n * moved to the toast.\n */\n }\n else if (target.tagName === 'ION-TOAST') {\n focusElementInOverlay(lastOverlay.lastFocus, lastOverlay);\n /**\n * Otherwise, we must be focusing an element\n * inside of the overlay. The two possible options\n * here are an input/button/etc or the ion-focus-trap\n * element. The focus trap element is used to prevent\n * the keyboard focus from leaving the overlay when\n * using Tab or screen assistants.\n */\n }\n else {\n /**\n * We do not want to focus the traps, so get the overlay\n * wrapper element as the traps live outside of the wrapper.\n */\n const overlayRoot = getElementRoot(lastOverlay);\n if (!overlayRoot.contains(target)) {\n return;\n }\n const overlayWrapper = overlayRoot.querySelector('.ion-overlay-wrapper');\n if (!overlayWrapper) {\n return;\n }\n /**\n * If the target is inside the wrapper, let the browser\n * focus as normal and keep a log of the last focused element.\n * Additionally, if the backdrop was tapped we should not\n * move focus back inside the wrapper as that could cause\n * an interactive elements focus state to activate.\n */\n if (overlayWrapper.contains(target) || target === overlayRoot.querySelector('ion-backdrop')) {\n lastOverlay.lastFocus = target;\n }\n else {\n /**\n * Otherwise, we must have focused one of the focus traps.\n * We need to wrap the focus to either the first element\n * or the last element.\n */\n /**\n * Once we call `focusFirstDescendant` and focus the first\n * descendant, another focus event will fire which will\n * cause `lastOverlay.lastFocus` to be updated before\n * we can run the code after that. We will cache the value\n * here to avoid that.\n */\n const lastFocus = lastOverlay.lastFocus;\n // Focus the first element in the overlay wrapper\n focusFirstDescendant(overlayWrapper, lastOverlay);\n /**\n * If the cached last focused element is the\n * same as the active element, then we need\n * to wrap focus to the last descendant. This happens\n * when the first descendant is focused, and the user\n * presses Shift + Tab. The previous line will focus\n * the same descendant again (the first one), causing\n * last focus to equal the active element.\n */\n if (lastFocus === doc.activeElement) {\n focusLastDescendant(overlayWrapper, lastOverlay);\n }\n lastOverlay.lastFocus = doc.activeElement;\n }\n }\n };\n const trapShadowFocus = () => {\n /**\n * If the target is inside the wrapper, let the browser\n * focus as normal and keep a log of the last focused element.\n */\n if (lastOverlay.contains(target)) {\n lastOverlay.lastFocus = target;\n /**\n * Toasts can be presented from an overlay.\n * However, focus should still be returned to\n * the overlay when clicking a toast. Normally,\n * focus would be returned to the last focusable\n * descendant in the overlay which may not always be\n * the button that the toast was presented from. In this case,\n * the focus may be returned to an unexpected element.\n * To account for this, we make sure to return focus to the\n * last focused element in the overlay if focus is\n * moved to the toast.\n */\n }\n else if (target.tagName === 'ION-TOAST') {\n focusElementInOverlay(lastOverlay.lastFocus, lastOverlay);\n }\n else {\n /**\n * Otherwise, we are about to have focus\n * go out of the overlay. We need to wrap\n * the focus to either the first element\n * or the last element.\n */\n /**\n * Once we call `focusFirstDescendant` and focus the first\n * descendant, another focus event will fire which will\n * cause `lastOverlay.lastFocus` to be updated before\n * we can run the code after that. We will cache the value\n * here to avoid that.\n */\n const lastFocus = lastOverlay.lastFocus;\n // Focus the first element in the overlay wrapper\n focusFirstDescendant(lastOverlay, lastOverlay);\n /**\n * If the cached last focused element is the\n * same as the active element, then we need\n * to wrap focus to the last descendant. This happens\n * when the first descendant is focused, and the user\n * presses Shift + Tab. The previous line will focus\n * the same descendant again (the first one), causing\n * last focus to equal the active element.\n */\n if (lastFocus === doc.activeElement) {\n focusLastDescendant(lastOverlay, lastOverlay);\n }\n lastOverlay.lastFocus = doc.activeElement;\n }\n };\n if (lastOverlay.shadowRoot) {\n trapShadowFocus();\n }\n else {\n trapScopedFocus();\n }\n};\nconst connectListeners = (doc) => {\n if (lastOverlayIndex === 0) {\n lastOverlayIndex = 1;\n doc.addEventListener('focus', (ev) => {\n trapKeyboardFocus(ev, doc);\n }, true);\n // handle back-button click\n doc.addEventListener('ionBackButton', (ev) => {\n const lastOverlay = getPresentedOverlay(doc);\n if (lastOverlay === null || lastOverlay === void 0 ? void 0 : lastOverlay.backdropDismiss) {\n ev.detail.register(OVERLAY_BACK_BUTTON_PRIORITY, () => {\n /**\n * Do not return this promise otherwise\n * the hardware back button utility will\n * be blocked until the overlay dismisses.\n * This is important for a modal with canDismiss.\n * If the application presents a confirmation alert\n * in the \"canDismiss\" callback, then it will be impossible\n * to use the hardware back button to dismiss the alert\n * dialog because the hardware back button utility\n * is blocked on waiting for the modal to dismiss.\n */\n lastOverlay.dismiss(undefined, BACKDROP);\n });\n }\n });\n /**\n * Handle ESC to close overlay.\n * CloseWatcher also handles pressing the Esc\n * key, so if a browser supports CloseWatcher then\n * this behavior will be handled via the ionBackButton\n * event.\n */\n if (!shouldUseCloseWatcher()) {\n doc.addEventListener('keydown', (ev) => {\n if (ev.key === 'Escape') {\n const lastOverlay = getPresentedOverlay(doc);\n if (lastOverlay === null || lastOverlay === void 0 ? void 0 : lastOverlay.backdropDismiss) {\n lastOverlay.dismiss(undefined, BACKDROP);\n }\n }\n });\n }\n }\n};\nexport const dismissOverlay = (doc, data, role, overlayTag, id) => {\n const overlay = getPresentedOverlay(doc, overlayTag, id);\n if (!overlay) {\n return Promise.reject('overlay does not exist');\n }\n return overlay.dismiss(data, role);\n};\n/**\n * Returns a list of all overlays in the DOM even if they are not presented.\n */\nexport const getOverlays = (doc, selector) => {\n if (selector === undefined) {\n selector = 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker,ion-popover,ion-toast';\n }\n return Array.from(doc.querySelectorAll(selector)).filter((c) => c.overlayIndex > 0);\n};\n/**\n * Returns a list of all presented overlays.\n * Inline overlays can exist in the DOM but not be presented,\n * so there are times when we want to exclude those.\n * @param doc The document to find the element within.\n * @param overlayTag The selector for the overlay, defaults to Ionic overlay components.\n */\nconst getPresentedOverlays = (doc, overlayTag) => {\n return getOverlays(doc, overlayTag).filter((o) => !isOverlayHidden(o));\n};\n/**\n * Returns a presented overlay element.\n * @param doc The document to find the element within.\n * @param overlayTag The selector for the overlay, defaults to Ionic overlay components.\n * @param id The unique identifier for the overlay instance.\n * @returns The overlay element or `undefined` if no overlay element is found.\n */\nexport const getPresentedOverlay = (doc, overlayTag, id) => {\n const overlays = getPresentedOverlays(doc, overlayTag);\n return id === undefined ? overlays[overlays.length - 1] : overlays.find((o) => o.id === id);\n};\n/**\n * When an overlay is presented, the main\n * focus is the overlay not the page content.\n * We need to remove the page content from the\n * accessibility tree otherwise when\n * users use \"read screen from top\" gestures with\n * TalkBack and VoiceOver, the screen reader will begin\n * to read the content underneath the overlay.\n *\n * We need a container where all page components\n * exist that is separate from where the overlays\n * are added in the DOM. For most apps, this element\n * is the top most ion-router-outlet. In the event\n * that devs are not using a router,\n * they will need to add the \"ion-view-container-root\"\n * id to the element that contains all of their views.\n *\n * TODO: If Framework supports having multiple top\n * level router outlets we would need to update this.\n * Example: One outlet for side menu and one outlet\n * for main content.\n */\nexport const setRootAriaHidden = (hidden = false) => {\n const root = getAppRoot(document);\n const viewContainer = root.querySelector('ion-router-outlet, ion-nav, #ion-view-container-root');\n if (!viewContainer) {\n return;\n }\n if (hidden) {\n viewContainer.setAttribute('aria-hidden', 'true');\n }\n else {\n viewContainer.removeAttribute('aria-hidden');\n }\n};\nexport const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, opts) => {\n var _a, _b;\n if (overlay.presented) {\n return;\n }\n setRootAriaHidden(true);\n hideOverlaysFromScreenReaders(overlay.el);\n overlay.presented = true;\n overlay.willPresent.emit();\n (_a = overlay.willPresentShorthand) === null || _a === void 0 ? void 0 : _a.emit();\n const mode = getIonMode(overlay);\n // get the user's animation fn if one was provided\n const animationBuilder = overlay.enterAnimation\n ? overlay.enterAnimation\n : config.get(name, mode === 'ios' ? iosEnterAnimation : mdEnterAnimation);\n const completed = await overlayAnimation(overlay, animationBuilder, overlay.el, opts);\n if (completed) {\n overlay.didPresent.emit();\n (_b = overlay.didPresentShorthand) === null || _b === void 0 ? void 0 : _b.emit();\n }\n /**\n * When an overlay that steals focus\n * is dismissed, focus should be returned\n * to the element that was focused\n * prior to the overlay opening. Toast\n * does not steal focus and is excluded\n * from returning focus as a result.\n */\n if (overlay.el.tagName !== 'ION-TOAST') {\n restoreElementFocus(overlay.el);\n }\n /**\n * If the focused element is already\n * inside the overlay component then\n * focus should not be moved from that\n * to the overlay container.\n */\n if (overlay.keyboardClose && (document.activeElement === null || !overlay.el.contains(document.activeElement))) {\n overlay.el.focus();\n }\n /**\n * If this overlay was previously dismissed without being\n * the topmost one (such as by manually calling dismiss()),\n * it would still have aria-hidden on being presented again.\n * Removing it here ensures the overlay is visible to screen\n * readers.\n */\n overlay.el.removeAttribute('aria-hidden');\n};\n/**\n * When an overlay component is dismissed,\n * focus should be returned to the element\n * that presented the overlay. Otherwise\n * focus will be set on the body which\n * means that people using screen readers\n * or tabbing will need to re-navigate\n * to where they were before they\n * opened the overlay.\n */\nconst restoreElementFocus = async (overlayEl) => {\n let previousElement = document.activeElement;\n if (!previousElement) {\n return;\n }\n const shadowRoot = previousElement === null || previousElement === void 0 ? void 0 : previousElement.shadowRoot;\n if (shadowRoot) {\n // If there are no inner focusable elements, just focus the host element.\n previousElement = shadowRoot.querySelector(focusableQueryString) || previousElement;\n }\n await overlayEl.onDidDismiss();\n /**\n * After onDidDismiss, the overlay loses focus\n * because it is removed from the document\n *\n * > An element will also lose focus [...]\n * > if the element is removed from the document)\n *\n * https://developer.mozilla.org/en-US/docs/Web/API/Element/blur_event\n *\n * Additionally, `document.activeElement` returns:\n *\n * > The Element which currently has focus,\n * > `<body>` or null if there is\n * > no focused element.\n *\n * https://developer.mozilla.org/en-US/docs/Web/API/Document/activeElement#value\n *\n * However, if the user has already focused\n * an element sometime between onWillDismiss\n * and onDidDismiss (for example, focusing a\n * text box after tapping a button in an\n * action sheet) then don't restore focus to\n * previous element\n */\n if (document.activeElement === null || document.activeElement === document.body) {\n previousElement.focus();\n }\n};\nexport const dismiss = async (overlay, data, role, name, iosLeaveAnimation, mdLeaveAnimation, opts) => {\n var _a, _b;\n if (!overlay.presented) {\n return false;\n }\n /**\n * If this is the last visible overlay then\n * we want to re-add the root to the accessibility tree.\n */\n if (doc !== undefined && getPresentedOverlays(doc).length === 1) {\n setRootAriaHidden(false);\n }\n overlay.presented = false;\n try {\n // Overlay contents should not be clickable during dismiss\n overlay.el.style.setProperty('pointer-events', 'none');\n overlay.willDismiss.emit({ data, role });\n (_a = overlay.willDismissShorthand) === null || _a === void 0 ? void 0 : _a.emit({ data, role });\n const mode = getIonMode(overlay);\n const animationBuilder = overlay.leaveAnimation\n ? overlay.leaveAnimation\n : config.get(name, mode === 'ios' ? iosLeaveAnimation : mdLeaveAnimation);\n // If dismissed via gesture, no need to play leaving animation again\n if (role !== GESTURE) {\n await overlayAnimation(overlay, animationBuilder, overlay.el, opts);\n }\n overlay.didDismiss.emit({ data, role });\n (_b = overlay.didDismissShorthand) === null || _b === void 0 ? void 0 : _b.emit({ data, role });\n // Get a reference to all animations currently assigned to this overlay\n // Then tear them down to return the overlay to its initial visual state\n const animations = activeAnimations.get(overlay) || [];\n animations.forEach((ani) => ani.destroy());\n activeAnimations.delete(overlay);\n /**\n * Make overlay hidden again in case it is being reused.\n * We can safely remove pointer-events: none as\n * overlay-hidden will set display: none.\n */\n overlay.el.classList.add('overlay-hidden');\n overlay.el.style.removeProperty('pointer-events');\n /**\n * Clear any focus trapping references\n * when the overlay is dismissed.\n */\n if (overlay.el.lastFocus !== undefined) {\n overlay.el.lastFocus = undefined;\n }\n }\n catch (err) {\n console.error(err);\n }\n overlay.el.remove();\n revealOverlaysToScreenReaders();\n return true;\n};\nconst getAppRoot = (doc) => {\n return doc.querySelector('ion-app') || doc.body;\n};\nconst overlayAnimation = async (overlay, animationBuilder, baseEl, opts) => {\n // Make overlay visible in case it's hidden\n baseEl.classList.remove('overlay-hidden');\n const aniRoot = overlay.el;\n const animation = animationBuilder(aniRoot, opts);\n if (!overlay.animated || !config.getBoolean('animated', true)) {\n animation.duration(0);\n }\n if (overlay.keyboardClose) {\n animation.beforeAddWrite(() => {\n const activeElement = baseEl.ownerDocument.activeElement;\n if (activeElement === null || activeElement === void 0 ? void 0 : activeElement.matches('input,ion-input, ion-textarea')) {\n activeElement.blur();\n }\n });\n }\n const activeAni = activeAnimations.get(overlay) || [];\n activeAnimations.set(overlay, [...activeAni, animation]);\n await animation.play();\n return true;\n};\nexport const eventMethod = (element, eventName) => {\n let resolve;\n const promise = new Promise((r) => (resolve = r));\n onceEvent(element, eventName, (event) => {\n resolve(event.detail);\n });\n return promise;\n};\nexport const onceEvent = (element, eventName, callback) => {\n const handler = (ev) => {\n removeEventListener(element, eventName, handler);\n callback(ev);\n };\n addEventListener(element, eventName, handler);\n};\nexport const isCancel = (role) => {\n return role === 'cancel' || role === BACKDROP;\n};\nconst defaultGate = (h) => h();\n/**\n * Calls a developer provided method while avoiding\n * Angular Zones. Since the handler is provided by\n * the developer, we should throw any errors\n * received so that developer-provided bug\n * tracking software can log it.\n */\nexport const safeCall = (handler, arg) => {\n if (typeof handler === 'function') {\n const jmp = config.get('_zoneGate', defaultGate);\n return jmp(() => {\n try {\n return handler(arg);\n }\n catch (e) {\n throw e;\n }\n });\n }\n return undefined;\n};\nexport const BACKDROP = 'backdrop';\nexport const GESTURE = 'gesture';\nexport const OVERLAY_GESTURE_PRIORITY = 39;\n/**\n * Creates a delegate controller.\n *\n * Requires that the component has the following properties:\n * - `el: HTMLElement`\n * - `hasController: boolean`\n * - `delegate?: FrameworkDelegate`\n *\n * @param ref The component class instance.\n */\nexport const createDelegateController = (ref) => {\n let inline = false;\n let workingDelegate;\n const coreDelegate = CoreDelegate();\n /**\n * Determines whether or not an overlay is being used\n * inline or via a controller/JS and returns the correct delegate.\n * By default, subsequent calls to getDelegate will use\n * a cached version of the delegate.\n * This is useful for calling dismiss after present,\n * so that the correct delegate is given.\n * @param force `true` to force the non-cached version of the delegate.\n * @returns The delegate to use and whether or not the overlay is inline.\n */\n const getDelegate = (force = false) => {\n if (workingDelegate && !force) {\n return {\n delegate: workingDelegate,\n inline,\n };\n }\n const { el, hasController, delegate } = ref;\n /**\n * If using overlay inline\n * we potentially need to use the coreDelegate\n * so that this works in vanilla JS apps.\n * If a developer has presented this component\n * via a controller, then we can assume\n * the component is already in the\n * correct place.\n */\n const parentEl = el.parentNode;\n inline = parentEl !== null && !hasController;\n workingDelegate = inline ? delegate || coreDelegate : delegate;\n return { inline, delegate: workingDelegate };\n };\n /**\n * Attaches a component in the DOM. Teleports the component\n * to the root of the app.\n * @param component The component to optionally construct and append to the element.\n */\n const attachViewToDom = async (component) => {\n const { delegate } = getDelegate(true);\n if (delegate) {\n return await delegate.attachViewToDom(ref.el, component);\n }\n const { hasController } = ref;\n if (hasController && component !== undefined) {\n throw new Error('framework delegate is missing');\n }\n return null;\n };\n /**\n * Moves a component back to its original location in the DOM.\n */\n const removeViewFromDom = () => {\n const { delegate } = getDelegate();\n if (delegate && ref.el !== undefined) {\n delegate.removeViewFromDom(ref.el.parentElement, ref.el);\n }\n };\n return {\n attachViewToDom,\n removeViewFromDom,\n };\n};\n/**\n * Constructs a trigger interaction for an overlay.\n * Presents an overlay when the trigger is clicked.\n *\n * Usage:\n * ```ts\n * triggerController = createTriggerController();\n * triggerController.addClickListener(el, trigger);\n * ```\n */\nexport const createTriggerController = () => {\n let destroyTriggerInteraction;\n /**\n * Removes the click listener from the trigger element.\n */\n const removeClickListener = () => {\n if (destroyTriggerInteraction) {\n destroyTriggerInteraction();\n destroyTriggerInteraction = undefined;\n }\n };\n /**\n * Adds a click listener to the trigger element.\n * Presents the overlay when the trigger is clicked.\n * @param el The overlay element.\n * @param trigger The ID of the element to add a click listener to.\n */\n const addClickListener = (el, trigger) => {\n removeClickListener();\n const triggerEl = trigger !== undefined ? document.getElementById(trigger) : null;\n if (!triggerEl) {\n printIonWarning(`A trigger element with the ID \"${trigger}\" was not found in the DOM. The trigger element must be in the DOM when the \"trigger\" property is set on an overlay component.`, el);\n return;\n }\n const configureTriggerInteraction = (targetEl, overlayEl) => {\n const openOverlay = () => {\n overlayEl.present();\n };\n targetEl.addEventListener('click', openOverlay);\n return () => {\n targetEl.removeEventListener('click', openOverlay);\n };\n };\n destroyTriggerInteraction = configureTriggerInteraction(triggerEl, el);\n };\n return {\n addClickListener,\n removeClickListener,\n };\n};\n/**\n * Ensure that underlying overlays have aria-hidden if necessary so that screen readers\n * cannot move focus to these elements. Note that we cannot rely on focus/focusin/focusout\n * events here because those events do not fire when the screen readers moves to a non-focusable\n * element such as text.\n * Without this logic screen readers would be able to move focus outside of the top focus-trapped overlay.\n *\n * @param newTopMostOverlay - The overlay that is being presented. Since the overlay has not been\n * fully presented yet at the time this function is called it will not be included in the getPresentedOverlays result.\n */\nconst hideOverlaysFromScreenReaders = (newTopMostOverlay) => {\n var _a;\n if (doc === undefined)\n return;\n const overlays = getPresentedOverlays(doc);\n for (let i = overlays.length - 1; i >= 0; i--) {\n const presentedOverlay = overlays[i];\n const nextPresentedOverlay = (_a = overlays[i + 1]) !== null && _a !== void 0 ? _a : newTopMostOverlay;\n /**\n * If next overlay has aria-hidden then all remaining overlays will have it too.\n * Or, if the next overlay is a Toast that does not have aria-hidden then current overlay\n * should not have aria-hidden either so focus can remain in the current overlay.\n */\n if (nextPresentedOverlay.hasAttribute('aria-hidden') || nextPresentedOverlay.tagName !== 'ION-TOAST') {\n presentedOverlay.setAttribute('aria-hidden', 'true');\n }\n }\n};\n/**\n * When dismissing an overlay we need to reveal the new top-most overlay to screen readers.\n * If the top-most overlay is a Toast we potentially need to reveal more overlays since\n * focus is never automatically moved to the Toast.\n */\nconst revealOverlaysToScreenReaders = () => {\n if (doc === undefined)\n return;\n const overlays = getPresentedOverlays(doc);\n for (let i = overlays.length - 1; i >= 0; i--) {\n const currentOverlay = overlays[i];\n /**\n * If the current we are looking at is a Toast then we can remove aria-hidden.\n * However, we potentially need to keep looking at the overlay stack because there\n * could be more Toasts underneath. Additionally, we need to unhide the closest non-Toast\n * overlay too so focus can move there since focus is never automatically moved to the Toast.\n */\n currentOverlay.removeAttribute('aria-hidden');\n /**\n * If we found a non-Toast element then we can just remove aria-hidden and stop searching entirely\n * since this overlay should always receive focus. As a result, all underlying overlays should still\n * be hidden from screen readers.\n */\n if (currentOverlay.tagName !== 'ION-TOAST') {\n break;\n }\n }\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{r as t,d as e,w as a,h as i,H as r,e as o,i as n}from"./p-d7a430bf.js";import{c as s}from"./p-faf06441.js";import{c as l}from"./p-536a0294.js";import{l as d,i as c,d as x,c as p,m as h}from"./p-b84d9e44.js";import{p as m}from"./p-e187a77c.js";import{c as g,g as b}from"./p-4be20bf2.js";import{c as u,h as f}from"./p-350e7423.js";import{g as v}from"./p-3b75b22a.js";import"./p-d7fe59ee.js";const w='.sc-ion-textarea-ios-h{--background:initial;--color:initial;--placeholder-color:initial;--placeholder-font-style:initial;--placeholder-font-weight:initial;--placeholder-opacity:0.6;--padding-top:0;--padding-end:0;--padding-bottom:0;--padding-start:0;--border-radius:0;--border-style:solid;--highlight-color-focused:var(--ion-color-primary, #3880ff);--highlight-color-valid:var(--ion-color-success, #2dd36f);--highlight-color-invalid:var(--ion-color-danger, #eb445a);--highlight-color:var(--highlight-color-focused);display:block;position:relative;width:100%;color:var(--color);font-family:var(--ion-font-family, inherit);z-index:2;box-sizing:border-box}.sc-ion-textarea-ios-h:not(.legacy-textarea){min-height:44px}.textarea-label-placement-floating.sc-ion-textarea-ios-h,.textarea-label-placement-stacked.sc-ion-textarea-ios-h{--padding-top:0px;min-height:56px}[cols].sc-ion-textarea-ios-h:not([auto-grow]){width:fit-content}.legacy-textarea.sc-ion-textarea-ios-h{flex:1;background:var(--background);white-space:pre-wrap}.legacy-textarea.ion-color.sc-ion-textarea-ios-h{color:var(--ion-color-base)}.sc-ion-textarea-ios-h:not(.legacy-textarea){--padding-bottom:8px}.ion-color.sc-ion-textarea-ios-h{--highlight-color-focused:var(--ion-color-base);background:initial}ion-item.sc-ion-textarea-ios-h,ion-item .sc-ion-textarea-ios-h{align-self:baseline}ion-item.sc-ion-textarea-ios-h:not(.item-label),ion-item:not(.item-label) .sc-ion-textarea-ios-h{--padding-start:0}ion-item[slot=start].sc-ion-textarea-ios-h,ion-item [slot=start].sc-ion-textarea-ios-h,ion-item[slot=end].sc-ion-textarea-ios-h,ion-item [slot=end].sc-ion-textarea-ios-h{width:auto}.native-textarea.sc-ion-textarea-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;display:block;position:relative;flex:1;width:100%;max-width:100%;max-height:100%;border:0;outline:none;background:transparent;white-space:pre-wrap;z-index:1;box-sizing:border-box;resize:none;appearance:none}.native-textarea.sc-ion-textarea-ios::placeholder{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.legacy-textarea.sc-ion-textarea-ios-h .native-textarea.sc-ion-textarea-ios{white-space:inherit}.legacy-textarea.sc-ion-textarea-ios-h .native-textarea.sc-ion-textarea-ios,.legacy-textarea.sc-ion-textarea-ios-h .textarea-legacy-wrapper.sc-ion-textarea-ios::after{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);border-radius:var(--border-radius)}.native-textarea.sc-ion-textarea-ios{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;grid-area:1/1/2/2;word-break:break-word}.legacy-textarea.sc-ion-textarea-ios-h .textarea-legacy-wrapper.sc-ion-textarea-ios::after{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;grid-area:1/1/2/2;word-break:break-word}.cloned-input.sc-ion-textarea-ios{top:0;bottom:0;position:absolute;pointer-events:none}@supports (inset-inline-start: 0){.cloned-input.sc-ion-textarea-ios{inset-inline-start:0}}@supports not (inset-inline-start: 0){.cloned-input.sc-ion-textarea-ios{left:0}[dir=rtl].sc-ion-textarea-ios-h .cloned-input.sc-ion-textarea-ios,[dir=rtl] .sc-ion-textarea-ios-h .cloned-input.sc-ion-textarea-ios{left:unset;right:unset;right:0}[dir=rtl].sc-ion-textarea-ios .cloned-input.sc-ion-textarea-ios{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.cloned-input.sc-ion-textarea-ios:dir(rtl){left:unset;right:unset;right:0}}}.cloned-input.sc-ion-textarea-ios:disabled{opacity:1}.legacy-textarea[auto-grow].sc-ion-textarea-ios-h .cloned-input.sc-ion-textarea-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}[auto-grow].sc-ion-textarea-ios-h .cloned-input.sc-ion-textarea-ios{height:100%}[auto-grow].sc-ion-textarea-ios-h .native-textarea.sc-ion-textarea-ios{overflow:hidden}.item-label-floating.item-has-placeholder.sc-ion-textarea-ios-h:not(.item-has-value),.item-label-floating.item-has-placeholder:not(.item-has-value) .sc-ion-textarea-ios-h{opacity:0}.item-label-floating.item-has-placeholder.sc-ion-textarea-ios-h:not(.item-has-value).item-has-focus,.item-label-floating.item-has-placeholder:not(.item-has-value).item-has-focus .sc-ion-textarea-ios-h{transition:opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1);opacity:1}.textarea-wrapper.sc-ion-textarea-ios{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:0px;padding-bottom:0px;border-radius:var(--border-radius);display:flex;position:relative;flex-grow:1;align-items:flex-start;height:inherit;min-height:inherit;transition:background-color 15ms linear;background:var(--background);line-height:normal}.native-wrapper.sc-ion-textarea-ios{position:relative;width:100%;height:100%}.has-focus.sc-ion-textarea-ios-h textarea.sc-ion-textarea-ios{caret-color:var(--highlight-color)}.native-wrapper.sc-ion-textarea-ios textarea.sc-ion-textarea-ios{-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom)}.native-wrapper.sc-ion-textarea-ios,.textarea-legacy-wrapper.sc-ion-textarea-ios{display:grid;min-width:inherit;max-width:inherit;min-height:inherit;max-height:inherit;grid-auto-rows:100%}.native-wrapper.sc-ion-textarea-ios::after,.textarea-legacy-wrapper.sc-ion-textarea-ios::after{white-space:pre-wrap;content:attr(data-replicated-value) " ";visibility:hidden}.native-wrapper.sc-ion-textarea-ios::after{padding-left:0;padding-right:0;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;border-radius:var(--border-radius);color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;grid-area:1/1/2/2;word-break:break-word}.textarea-wrapper-inner.sc-ion-textarea-ios{display:flex;width:100%;min-height:inherit}.ion-touched.ion-invalid.sc-ion-textarea-ios-h{--highlight-color:var(--highlight-color-invalid)}.ion-valid.sc-ion-textarea-ios-h{--highlight-color:var(--highlight-color-valid)}.textarea-bottom.sc-ion-textarea-ios{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:5px;padding-bottom:0;display:flex;justify-content:space-between;border-top:var(--border-width) var(--border-style) var(--border-color);font-size:0.75rem}.has-focus.ion-valid.sc-ion-textarea-ios-h,.ion-touched.ion-invalid.sc-ion-textarea-ios-h{--border-color:var(--highlight-color)}.textarea-bottom.sc-ion-textarea-ios .error-text.sc-ion-textarea-ios{display:none;color:var(--highlight-color-invalid)}.textarea-bottom.sc-ion-textarea-ios .helper-text.sc-ion-textarea-ios{display:block;color:var(--ion-color-step-550, #737373)}.ion-touched.ion-invalid.sc-ion-textarea-ios-h .textarea-bottom.sc-ion-textarea-ios .error-text.sc-ion-textarea-ios{display:block}.ion-touched.ion-invalid.sc-ion-textarea-ios-h .textarea-bottom.sc-ion-textarea-ios .helper-text.sc-ion-textarea-ios{display:none}.textarea-bottom.sc-ion-textarea-ios .counter.sc-ion-textarea-ios{-webkit-margin-start:auto;margin-inline-start:auto;color:var(--ion-color-step-550, #737373);white-space:nowrap;padding-inline-start:16px}.label-text-wrapper.sc-ion-textarea-ios{-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);max-width:200px;transition:color 150ms cubic-bezier(0.4, 0, 0.2, 1), transform 150ms cubic-bezier(0.4, 0, 0.2, 1);pointer-events:none}.label-text.sc-ion-textarea-ios,.sc-ion-textarea-ios-s>[slot=label]{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.label-text-wrapper-hidden.sc-ion-textarea-ios,.textarea-outline-notch-hidden.sc-ion-textarea-ios{display:none}.textarea-wrapper.sc-ion-textarea-ios textarea.sc-ion-textarea-ios{transition:opacity 150ms cubic-bezier(0.4, 0, 0.2, 1)}.textarea-label-placement-start.sc-ion-textarea-ios-h .textarea-wrapper.sc-ion-textarea-ios{flex-direction:row}.textarea-label-placement-start.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:16px;margin-inline-end:16px;margin-top:0;margin-bottom:0}.textarea-label-placement-end.sc-ion-textarea-ios-h .textarea-wrapper.sc-ion-textarea-ios{flex-direction:row-reverse}.textarea-label-placement-end.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios{-webkit-margin-start:16px;margin-inline-start:16px;-webkit-margin-end:0;margin-inline-end:0;margin-top:0;margin-bottom:0}.textarea-label-placement-fixed.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:16px;margin-inline-end:16px;margin-top:0;margin-bottom:0}.textarea-label-placement-fixed.sc-ion-textarea-ios-h .label-text.sc-ion-textarea-ios{flex:0 0 100px;width:100px;min-width:100px;max-width:200px}.textarea-label-placement-stacked.sc-ion-textarea-ios-h .textarea-wrapper.sc-ion-textarea-ios,.textarea-label-placement-floating.sc-ion-textarea-ios-h .textarea-wrapper.sc-ion-textarea-ios{flex-direction:column;align-items:start}.textarea-label-placement-stacked.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios,.textarea-label-placement-floating.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios{transform-origin:left top;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;max-width:100%;z-index:2}[dir=rtl].sc-ion-textarea-ios-h -no-combinator.textarea-label-placement-stacked.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios,[dir=rtl] .sc-ion-textarea-ios-h -no-combinator.textarea-label-placement-stacked.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios,[dir=rtl].textarea-label-placement-stacked.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios,[dir=rtl] .textarea-label-placement-stacked.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios,[dir=rtl].sc-ion-textarea-ios-h -no-combinator.textarea-label-placement-floating.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios,[dir=rtl] .sc-ion-textarea-ios-h -no-combinator.textarea-label-placement-floating.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios,[dir=rtl].textarea-label-placement-floating.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios,[dir=rtl] .textarea-label-placement-floating.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios{transform-origin:right top}@supports selector(:dir(rtl)){.textarea-label-placement-stacked.sc-ion-textarea-ios-h:dir(rtl) .label-text-wrapper.sc-ion-textarea-ios,.textarea-label-placement-floating.sc-ion-textarea-ios-h:dir(rtl) .label-text-wrapper.sc-ion-textarea-ios{transform-origin:right top}}.textarea-label-placement-stacked.sc-ion-textarea-ios-h textarea.sc-ion-textarea-ios,.textarea-label-placement-floating.sc-ion-textarea-ios-h textarea.sc-ion-textarea-ios,.textarea-label-placement-stacked[auto-grow].sc-ion-textarea-ios-h .native-wrapper.sc-ion-textarea-ios::after,.textarea-label-placement-floating[auto-grow].sc-ion-textarea-ios-h .native-wrapper.sc-ion-textarea-ios::after{-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:8px;margin-bottom:0px}.sc-ion-textarea-ios-h.textarea-label-placement-stacked .sc-ion-textarea-ios-s>[slot=start],.sc-ion-textarea-ios-h.textarea-label-placement-stacked .sc-ion-textarea-ios-s>[slot=end],.sc-ion-textarea-ios-h.textarea-label-placement-floating .sc-ion-textarea-ios-s>[slot=start],.sc-ion-textarea-ios-h.textarea-label-placement-floating .sc-ion-textarea-ios-s>[slot=end]{margin-top:8px}.textarea-label-placement-floating.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios{transform:translateY(100%) scale(1)}.textarea-label-placement-floating.sc-ion-textarea-ios-h textarea.sc-ion-textarea-ios{opacity:0}.has-focus.textarea-label-placement-floating.sc-ion-textarea-ios-h textarea.sc-ion-textarea-ios,.has-value.textarea-label-placement-floating.sc-ion-textarea-ios-h textarea.sc-ion-textarea-ios{opacity:1}.label-floating.sc-ion-textarea-ios-h .label-text-wrapper.sc-ion-textarea-ios{transform:translateY(50%) scale(0.75);max-width:calc(100% / 0.75)}.start-slot-wrapper.sc-ion-textarea-ios,.end-slot-wrapper.sc-ion-textarea-ios{padding-left:0;padding-right:0;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:flex;flex-shrink:0;align-self:start}.sc-ion-textarea-ios-s>[slot=start],.sc-ion-textarea-ios-s>[slot=end]{margin-top:0}.sc-ion-textarea-ios-s>[slot=start]{margin-inline-end:16px;margin-inline-start:0}.sc-ion-textarea-ios-s>[slot=end]{margin-inline-start:16px;margin-inline-end:0}.sc-ion-textarea-ios-h{--border-width:0.55px;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, #c8c7cc)));--padding-top:10px;--padding-end:0px;--padding-bottom:8px;--padding-start:0px;font-size:inherit}.legacy-textarea.sc-ion-textarea-ios-h{--padding-top:10px;--padding-end:8px;--padding-bottom:10px;--padding-start:0}.item-label-stacked.sc-ion-textarea-ios-h,.item-label-stacked .sc-ion-textarea-ios-h,.item-label-floating.sc-ion-textarea-ios-h,.item-label-floating .sc-ion-textarea-ios-h{--padding-top:8px;--padding-bottom:8px;--padding-start:0px}.legacy-textarea.sc-ion-textarea-ios-h .native-textarea[disabled].sc-ion-textarea-ios,.textarea-disabled.sc-ion-textarea-ios-h{opacity:0.3}.sc-ion-textarea-ios-s>ion-button[slot=start].button-has-icon-only,.sc-ion-textarea-ios-s>ion-button[slot=end].button-has-icon-only{--border-radius:50%;--padding-start:0;--padding-end:0;--padding-top:0;--padding-bottom:0;aspect-ratio:1}';const y='.sc-ion-textarea-md-h{--background:initial;--color:initial;--placeholder-color:initial;--placeholder-font-style:initial;--placeholder-font-weight:initial;--placeholder-opacity:0.6;--padding-top:0;--padding-end:0;--padding-bottom:0;--padding-start:0;--border-radius:0;--border-style:solid;--highlight-color-focused:var(--ion-color-primary, #3880ff);--highlight-color-valid:var(--ion-color-success, #2dd36f);--highlight-color-invalid:var(--ion-color-danger, #eb445a);--highlight-color:var(--highlight-color-focused);display:block;position:relative;width:100%;color:var(--color);font-family:var(--ion-font-family, inherit);z-index:2;box-sizing:border-box}.sc-ion-textarea-md-h:not(.legacy-textarea){min-height:44px}.textarea-label-placement-floating.sc-ion-textarea-md-h,.textarea-label-placement-stacked.sc-ion-textarea-md-h{--padding-top:0px;min-height:56px}[cols].sc-ion-textarea-md-h:not([auto-grow]){width:fit-content}.legacy-textarea.sc-ion-textarea-md-h{flex:1;background:var(--background);white-space:pre-wrap}.legacy-textarea.ion-color.sc-ion-textarea-md-h{color:var(--ion-color-base)}.sc-ion-textarea-md-h:not(.legacy-textarea){--padding-bottom:8px}.ion-color.sc-ion-textarea-md-h{--highlight-color-focused:var(--ion-color-base);background:initial}ion-item.sc-ion-textarea-md-h,ion-item .sc-ion-textarea-md-h{align-self:baseline}ion-item.sc-ion-textarea-md-h:not(.item-label),ion-item:not(.item-label) .sc-ion-textarea-md-h{--padding-start:0}ion-item[slot=start].sc-ion-textarea-md-h,ion-item [slot=start].sc-ion-textarea-md-h,ion-item[slot=end].sc-ion-textarea-md-h,ion-item [slot=end].sc-ion-textarea-md-h{width:auto}.native-textarea.sc-ion-textarea-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;display:block;position:relative;flex:1;width:100%;max-width:100%;max-height:100%;border:0;outline:none;background:transparent;white-space:pre-wrap;z-index:1;box-sizing:border-box;resize:none;appearance:none}.native-textarea.sc-ion-textarea-md::placeholder{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;color:var(--placeholder-color);font-family:inherit;font-style:var(--placeholder-font-style);font-weight:var(--placeholder-font-weight);opacity:var(--placeholder-opacity)}.legacy-textarea.sc-ion-textarea-md-h .native-textarea.sc-ion-textarea-md{white-space:inherit}.legacy-textarea.sc-ion-textarea-md-h .native-textarea.sc-ion-textarea-md,.legacy-textarea.sc-ion-textarea-md-h .textarea-legacy-wrapper.sc-ion-textarea-md::after{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);border-radius:var(--border-radius)}.native-textarea.sc-ion-textarea-md{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;grid-area:1/1/2/2;word-break:break-word}.legacy-textarea.sc-ion-textarea-md-h .textarea-legacy-wrapper.sc-ion-textarea-md::after{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;grid-area:1/1/2/2;word-break:break-word}.cloned-input.sc-ion-textarea-md{top:0;bottom:0;position:absolute;pointer-events:none}@supports (inset-inline-start: 0){.cloned-input.sc-ion-textarea-md{inset-inline-start:0}}@supports not (inset-inline-start: 0){.cloned-input.sc-ion-textarea-md{left:0}[dir=rtl].sc-ion-textarea-md-h .cloned-input.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h .cloned-input.sc-ion-textarea-md{left:unset;right:unset;right:0}[dir=rtl].sc-ion-textarea-md .cloned-input.sc-ion-textarea-md{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.cloned-input.sc-ion-textarea-md:dir(rtl){left:unset;right:unset;right:0}}}.cloned-input.sc-ion-textarea-md:disabled{opacity:1}.legacy-textarea[auto-grow].sc-ion-textarea-md-h .cloned-input.sc-ion-textarea-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}[auto-grow].sc-ion-textarea-md-h .cloned-input.sc-ion-textarea-md{height:100%}[auto-grow].sc-ion-textarea-md-h .native-textarea.sc-ion-textarea-md{overflow:hidden}.item-label-floating.item-has-placeholder.sc-ion-textarea-md-h:not(.item-has-value),.item-label-floating.item-has-placeholder:not(.item-has-value) .sc-ion-textarea-md-h{opacity:0}.item-label-floating.item-has-placeholder.sc-ion-textarea-md-h:not(.item-has-value).item-has-focus,.item-label-floating.item-has-placeholder:not(.item-has-value).item-has-focus .sc-ion-textarea-md-h{transition:opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1);opacity:1}.textarea-wrapper.sc-ion-textarea-md{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:0px;padding-bottom:0px;border-radius:var(--border-radius);display:flex;position:relative;flex-grow:1;align-items:flex-start;height:inherit;min-height:inherit;transition:background-color 15ms linear;background:var(--background);line-height:normal}.native-wrapper.sc-ion-textarea-md{position:relative;width:100%;height:100%}.has-focus.sc-ion-textarea-md-h textarea.sc-ion-textarea-md{caret-color:var(--highlight-color)}.native-wrapper.sc-ion-textarea-md textarea.sc-ion-textarea-md{-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom)}.native-wrapper.sc-ion-textarea-md,.textarea-legacy-wrapper.sc-ion-textarea-md{display:grid;min-width:inherit;max-width:inherit;min-height:inherit;max-height:inherit;grid-auto-rows:100%}.native-wrapper.sc-ion-textarea-md::after,.textarea-legacy-wrapper.sc-ion-textarea-md::after{white-space:pre-wrap;content:attr(data-replicated-value) " ";visibility:hidden}.native-wrapper.sc-ion-textarea-md::after{padding-left:0;padding-right:0;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;border-radius:var(--border-radius);color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;grid-area:1/1/2/2;word-break:break-word}.textarea-wrapper-inner.sc-ion-textarea-md{display:flex;width:100%;min-height:inherit}.ion-touched.ion-invalid.sc-ion-textarea-md-h{--highlight-color:var(--highlight-color-invalid)}.ion-valid.sc-ion-textarea-md-h{--highlight-color:var(--highlight-color-valid)}.textarea-bottom.sc-ion-textarea-md{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:5px;padding-bottom:0;display:flex;justify-content:space-between;border-top:var(--border-width) var(--border-style) var(--border-color);font-size:0.75rem}.has-focus.ion-valid.sc-ion-textarea-md-h,.ion-touched.ion-invalid.sc-ion-textarea-md-h{--border-color:var(--highlight-color)}.textarea-bottom.sc-ion-textarea-md .error-text.sc-ion-textarea-md{display:none;color:var(--highlight-color-invalid)}.textarea-bottom.sc-ion-textarea-md .helper-text.sc-ion-textarea-md{display:block;color:var(--ion-color-step-550, #737373)}.ion-touched.ion-invalid.sc-ion-textarea-md-h .textarea-bottom.sc-ion-textarea-md .error-text.sc-ion-textarea-md{display:block}.ion-touched.ion-invalid.sc-ion-textarea-md-h .textarea-bottom.sc-ion-textarea-md .helper-text.sc-ion-textarea-md{display:none}.textarea-bottom.sc-ion-textarea-md .counter.sc-ion-textarea-md{-webkit-margin-start:auto;margin-inline-start:auto;color:var(--ion-color-step-550, #737373);white-space:nowrap;padding-inline-start:16px}.label-text-wrapper.sc-ion-textarea-md{-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);max-width:200px;transition:color 150ms cubic-bezier(0.4, 0, 0.2, 1), transform 150ms cubic-bezier(0.4, 0, 0.2, 1);pointer-events:none}.label-text.sc-ion-textarea-md,.sc-ion-textarea-md-s>[slot=label]{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.label-text-wrapper-hidden.sc-ion-textarea-md,.textarea-outline-notch-hidden.sc-ion-textarea-md{display:none}.textarea-wrapper.sc-ion-textarea-md textarea.sc-ion-textarea-md{transition:opacity 150ms cubic-bezier(0.4, 0, 0.2, 1)}.textarea-label-placement-start.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md{flex-direction:row}.textarea-label-placement-start.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:16px;margin-inline-end:16px;margin-top:0;margin-bottom:0}.textarea-label-placement-end.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md{flex-direction:row-reverse}.textarea-label-placement-end.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{-webkit-margin-start:16px;margin-inline-start:16px;-webkit-margin-end:0;margin-inline-end:0;margin-top:0;margin-bottom:0}.textarea-label-placement-fixed.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:16px;margin-inline-end:16px;margin-top:0;margin-bottom:0}.textarea-label-placement-fixed.sc-ion-textarea-md-h .label-text.sc-ion-textarea-md{flex:0 0 100px;width:100px;min-width:100px;max-width:200px}.textarea-label-placement-stacked.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md,.textarea-label-placement-floating.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md{flex-direction:column;align-items:start}.textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,.textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{transform-origin:left top;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;max-width:100%;z-index:2}[dir=rtl].sc-ion-textarea-md-h -no-combinator.textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h -no-combinator.textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl].textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl] .textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl].sc-ion-textarea-md-h -no-combinator.textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h -no-combinator.textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl].textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl] .textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{transform-origin:right top}@supports selector(:dir(rtl)){.textarea-label-placement-stacked.sc-ion-textarea-md-h:dir(rtl) .label-text-wrapper.sc-ion-textarea-md,.textarea-label-placement-floating.sc-ion-textarea-md-h:dir(rtl) .label-text-wrapper.sc-ion-textarea-md{transform-origin:right top}}.textarea-label-placement-stacked.sc-ion-textarea-md-h textarea.sc-ion-textarea-md,.textarea-label-placement-floating.sc-ion-textarea-md-h textarea.sc-ion-textarea-md,.textarea-label-placement-stacked[auto-grow].sc-ion-textarea-md-h .native-wrapper.sc-ion-textarea-md::after,.textarea-label-placement-floating[auto-grow].sc-ion-textarea-md-h .native-wrapper.sc-ion-textarea-md::after{-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:8px;margin-bottom:0px}.sc-ion-textarea-md-h.textarea-label-placement-stacked .sc-ion-textarea-md-s>[slot=start],.sc-ion-textarea-md-h.textarea-label-placement-stacked .sc-ion-textarea-md-s>[slot=end],.sc-ion-textarea-md-h.textarea-label-placement-floating .sc-ion-textarea-md-s>[slot=start],.sc-ion-textarea-md-h.textarea-label-placement-floating .sc-ion-textarea-md-s>[slot=end]{margin-top:8px}.textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{transform:translateY(100%) scale(1)}.textarea-label-placement-floating.sc-ion-textarea-md-h textarea.sc-ion-textarea-md{opacity:0}.has-focus.textarea-label-placement-floating.sc-ion-textarea-md-h textarea.sc-ion-textarea-md,.has-value.textarea-label-placement-floating.sc-ion-textarea-md-h textarea.sc-ion-textarea-md{opacity:1}.label-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{transform:translateY(50%) scale(0.75);max-width:calc(100% / 0.75)}.start-slot-wrapper.sc-ion-textarea-md,.end-slot-wrapper.sc-ion-textarea-md{padding-left:0;padding-right:0;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:flex;flex-shrink:0;align-self:start}.sc-ion-textarea-md-s>[slot=start],.sc-ion-textarea-md-s>[slot=end]{margin-top:0}.sc-ion-textarea-md-s>[slot=start]{margin-inline-end:16px;margin-inline-start:0}.sc-ion-textarea-md-s>[slot=end]{margin-inline-start:16px;margin-inline-end:0}.textarea-fill-solid.sc-ion-textarea-md-h{--background:var(--ion-color-step-50, #f2f2f2);--border-color:var(--ion-color-step-500, gray);--border-radius:4px;--padding-start:16px;--padding-end:16px;min-height:56px}.textarea-fill-solid.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md{border-bottom:var(--border-width) var(--border-style) var(--border-color)}.has-focus.textarea-fill-solid.ion-valid.sc-ion-textarea-md-h,.textarea-fill-solid.ion-touched.ion-invalid.sc-ion-textarea-md-h{--border-color:var(--highlight-color)}.textarea-fill-solid.sc-ion-textarea-md-h .textarea-bottom.sc-ion-textarea-md{border-top:none}@media (any-hover: hover){.textarea-fill-solid.sc-ion-textarea-md-h:hover{--background:var(--ion-color-step-100, #e6e6e6);--border-color:var(--ion-color-step-750, #404040)}}.textarea-fill-solid.has-focus.sc-ion-textarea-md-h{--background:var(--ion-color-step-150, #d9d9d9);--border-color:var(--ion-color-step-750, #404040)}.textarea-fill-solid.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md{border-top-left-radius:var(--border-radius);border-top-right-radius:var(--border-radius);border-bottom-right-radius:0px;border-bottom-left-radius:0px}[dir=rtl].sc-ion-textarea-md-h -no-combinator.textarea-fill-solid.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h -no-combinator.textarea-fill-solid.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md,[dir=rtl].textarea-fill-solid.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md,[dir=rtl] .textarea-fill-solid.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md{border-top-left-radius:var(--border-radius);border-top-right-radius:var(--border-radius);border-bottom-right-radius:0px;border-bottom-left-radius:0px}@supports selector(:dir(rtl)){.textarea-fill-solid.sc-ion-textarea-md-h:dir(rtl) .textarea-wrapper.sc-ion-textarea-md{border-top-left-radius:var(--border-radius);border-top-right-radius:var(--border-radius);border-bottom-right-radius:0px;border-bottom-left-radius:0px}}.label-floating.textarea-fill-solid.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{max-width:calc(100% / 0.75)}.textarea-fill-outline.sc-ion-textarea-md-h{--border-color:var(--ion-color-step-300, #b3b3b3);--border-radius:4px;--padding-start:16px;--padding-end:16px;min-height:56px}.textarea-fill-outline.textarea-shape-round.sc-ion-textarea-md-h{--border-radius:28px;--padding-start:32px;--padding-end:32px}.has-focus.textarea-fill-outline.ion-valid.sc-ion-textarea-md-h,.textarea-fill-outline.ion-touched.ion-invalid.sc-ion-textarea-md-h{--border-color:var(--highlight-color)}@media (any-hover: hover){.textarea-fill-outline.sc-ion-textarea-md-h:hover{--border-color:var(--ion-color-step-750, #404040)}}.textarea-fill-outline.has-focus.sc-ion-textarea-md-h{--border-width:2px;--border-color:var(--highlight-color)}.textarea-fill-outline.sc-ion-textarea-md-h .textarea-bottom.sc-ion-textarea-md{border-top:none}.textarea-fill-outline.sc-ion-textarea-md-h .textarea-wrapper.sc-ion-textarea-md{border-bottom:none}.textarea-fill-outline.textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,.textarea-fill-outline.textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{transform-origin:left top;position:absolute;max-width:calc(100% - var(--padding-start) - var(--padding-end))}[dir=rtl].sc-ion-textarea-md-h -no-combinator.textarea-fill-outline.textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h -no-combinator.textarea-fill-outline.textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl].textarea-fill-outline.textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl] .textarea-fill-outline.textarea-label-placement-stacked.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl].sc-ion-textarea-md-h -no-combinator.textarea-fill-outline.textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h -no-combinator.textarea-fill-outline.textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl].textarea-fill-outline.textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,[dir=rtl] .textarea-fill-outline.textarea-label-placement-floating.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{transform-origin:right top}@supports selector(:dir(rtl)){.textarea-fill-outline.textarea-label-placement-stacked.sc-ion-textarea-md-h:dir(rtl) .label-text-wrapper.sc-ion-textarea-md,.textarea-fill-outline.textarea-label-placement-floating.sc-ion-textarea-md-h:dir(rtl) .label-text-wrapper.sc-ion-textarea-md{transform-origin:right top}}.textarea-fill-outline.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{position:relative}.label-floating.textarea-fill-outline.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{transform:translateY(-32%) scale(0.75);margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;max-width:calc(\n (100% - var(--padding-start) - var(--padding-end) - 8px) / 0.75\n )}.textarea-fill-outline.textarea-label-placement-stacked.sc-ion-textarea-md-h textarea.sc-ion-textarea-md,.textarea-fill-outline.textarea-label-placement-floating.sc-ion-textarea-md-h textarea.sc-ion-textarea-md,.textarea-fill-outline.textarea-label-placement-stacked[auto-grow].sc-ion-textarea-md-h .native-wrapper.sc-ion-textarea-md::after,.textarea-fill-outline.textarea-label-placement-floating[auto-grow].sc-ion-textarea-md-h .native-wrapper.sc-ion-textarea-md::after{-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:12px;margin-bottom:0px}.sc-ion-textarea-md-h.textarea-fill-outline.textarea-label-placement-stacked .sc-ion-textarea-md-s>[slot=start],.sc-ion-textarea-md-h.textarea-fill-outline.textarea-label-placement-stacked .sc-ion-textarea-md-s>[slot=end],.sc-ion-textarea-md-h.textarea-fill-outline.textarea-label-placement-floating .sc-ion-textarea-md-s>[slot=start],.sc-ion-textarea-md-h.textarea-fill-outline.textarea-label-placement-floating .sc-ion-textarea-md-s>[slot=end]{margin-top:12px}.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-container.sc-ion-textarea-md{left:0;right:0;top:0;bottom:0;display:flex;position:absolute;width:100%;height:100%}.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-start.sc-ion-textarea-md,.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-end.sc-ion-textarea-md{pointer-events:none}.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-start.sc-ion-textarea-md,.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-notch.sc-ion-textarea-md,.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-end.sc-ion-textarea-md{border-top:var(--border-width) var(--border-style) var(--border-color);border-bottom:var(--border-width) var(--border-style) var(--border-color)}.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-notch.sc-ion-textarea-md{max-width:calc(100% - var(--padding-start) - var(--padding-end))}.textarea-fill-outline.sc-ion-textarea-md-h .notch-spacer.sc-ion-textarea-md{-webkit-padding-end:8px;padding-inline-end:8px;font-size:calc(1em * 0.75);opacity:0;pointer-events:none;box-sizing:content-box}.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-start.sc-ion-textarea-md{border-top-left-radius:var(--border-radius);border-top-right-radius:0px;border-bottom-right-radius:0px;border-bottom-left-radius:var(--border-radius);-webkit-border-start:var(--border-width) var(--border-style) var(--border-color);border-inline-start:var(--border-width) var(--border-style) var(--border-color);width:calc(var(--padding-start) - 4px)}[dir=rtl].sc-ion-textarea-md-h -no-combinator.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-start.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h -no-combinator.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-start.sc-ion-textarea-md,[dir=rtl].textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-start.sc-ion-textarea-md,[dir=rtl] .textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-start.sc-ion-textarea-md{border-top-left-radius:0px;border-top-right-radius:var(--border-radius);border-bottom-right-radius:var(--border-radius);border-bottom-left-radius:0px}@supports selector(:dir(rtl)){.textarea-fill-outline.sc-ion-textarea-md-h:dir(rtl) .textarea-outline-start.sc-ion-textarea-md{border-top-left-radius:0px;border-top-right-radius:var(--border-radius);border-bottom-right-radius:var(--border-radius);border-bottom-left-radius:0px}}.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-end.sc-ion-textarea-md{-webkit-border-end:var(--border-width) var(--border-style) var(--border-color);border-inline-end:var(--border-width) var(--border-style) var(--border-color);border-top-left-radius:0px;border-top-right-radius:var(--border-radius);border-bottom-right-radius:var(--border-radius);border-bottom-left-radius:0px;flex-grow:1}[dir=rtl].sc-ion-textarea-md-h -no-combinator.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-end.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h -no-combinator.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-end.sc-ion-textarea-md,[dir=rtl].textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-end.sc-ion-textarea-md,[dir=rtl] .textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-end.sc-ion-textarea-md{border-top-left-radius:var(--border-radius);border-top-right-radius:0px;border-bottom-right-radius:0px;border-bottom-left-radius:var(--border-radius)}@supports selector(:dir(rtl)){.textarea-fill-outline.sc-ion-textarea-md-h:dir(rtl) .textarea-outline-end.sc-ion-textarea-md{border-top-left-radius:var(--border-radius);border-top-right-radius:0px;border-bottom-right-radius:0px;border-bottom-left-radius:var(--border-radius)}}.label-floating.textarea-fill-outline.sc-ion-textarea-md-h .textarea-outline-notch.sc-ion-textarea-md{border-top:none}.sc-ion-textarea-md-h{--border-width:1px;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));--padding-top:18px;--padding-end:0px;--padding-bottom:8px;--padding-start:0px;font-size:inherit}.legacy-textarea.sc-ion-textarea-md-h{--padding-top:10px;--padding-end:0;--padding-bottom:11px;--padding-start:8px;margin-left:0;margin-right:0;margin-top:8px;margin-bottom:0}.item-label-stacked.sc-ion-textarea-md-h,.item-label-stacked .sc-ion-textarea-md-h,.item-label-floating.sc-ion-textarea-md-h,.item-label-floating .sc-ion-textarea-md-h{--padding-top:8px;--padding-bottom:8px;--padding-start:0}.textarea-bottom.sc-ion-textarea-md .counter.sc-ion-textarea-md{letter-spacing:0.0333333333em}.textarea-label-placement-floating.has-focus.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,.textarea-label-placement-stacked.has-focus.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{color:var(--highlight-color)}.has-focus.textarea-label-placement-floating.ion-valid.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,.textarea-label-placement-floating.ion-touched.ion-invalid.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,.has-focus.textarea-label-placement-stacked.ion-valid.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md,.textarea-label-placement-stacked.ion-touched.ion-invalid.sc-ion-textarea-md-h .label-text-wrapper.sc-ion-textarea-md{color:var(--highlight-color)}.legacy-textarea.sc-ion-textarea-md-h .native-textarea[disabled].sc-ion-textarea-md,.textarea-disabled.sc-ion-textarea-md-h{opacity:0.38}.textarea-highlight.sc-ion-textarea-md{bottom:-1px;position:absolute;width:100%;height:2px;transform:scale(0);transition:transform 200ms;background:var(--highlight-color)}@supports (inset-inline-start: 0){.textarea-highlight.sc-ion-textarea-md{inset-inline-start:0}}@supports not (inset-inline-start: 0){.textarea-highlight.sc-ion-textarea-md{left:0}[dir=rtl].sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md{left:unset;right:unset;right:0}[dir=rtl].sc-ion-textarea-md .textarea-highlight.sc-ion-textarea-md{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.textarea-highlight.sc-ion-textarea-md:dir(rtl){left:unset;right:unset;right:0}}}.has-focus.sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md{transform:scale(1)}.in-item.sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md{bottom:0}@supports (inset-inline-start: 0){.in-item.sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md{inset-inline-start:0}}@supports not (inset-inline-start: 0){.in-item.sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md{left:0}[dir=rtl].sc-ion-textarea-md-h -no-combinator.in-item.sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md,[dir=rtl] .sc-ion-textarea-md-h -no-combinator.in-item.sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md,[dir=rtl].in-item.sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md,[dir=rtl] .in-item.sc-ion-textarea-md-h .textarea-highlight.sc-ion-textarea-md{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.in-item.sc-ion-textarea-md-h:dir(rtl) .textarea-highlight.sc-ion-textarea-md{left:unset;right:unset;right:0}}}.textarea-shape-round.sc-ion-textarea-md-h{--border-radius:16px}.sc-ion-textarea-md-s>ion-button[slot=start].button-has-icon-only,.sc-ion-textarea-md-s>ion-button[slot=end].button-has-icon-only{--border-radius:50%;--padding-start:8px;--padding-end:8px;--padding-top:8px;--padding-bottom:8px;aspect-ratio:1;min-height:40px}';const k=class{constructor(a){t(this,a);this.ionChange=e(this,"ionChange",7);this.ionInput=e(this,"ionInput",7);this.ionStyle=e(this,"ionStyle",7);this.ionBlur=e(this,"ionBlur",7);this.ionFocus=e(this,"ionFocus",7);this.inputId=`ion-textarea-${z++}`;this.didTextareaClearOnEdit=false;this.inheritedAttributes={};this.hasLoggedDeprecationWarning=false;this.onInput=t=>{const e=t.target;if(e){this.value=e.value||""}this.emitInputChange(t)};this.onChange=t=>{this.emitValueChange(t)};this.onFocus=t=>{this.hasFocus=true;this.focusedValue=this.value;this.focusChange();this.ionFocus.emit(t)};this.onBlur=t=>{this.hasFocus=false;this.focusChange();if(this.focusedValue!==this.value){this.emitValueChange(t)}this.didTextareaClearOnEdit=false;this.ionBlur.emit(t)};this.onKeyDown=t=>{this.checkClearOnEdit(t)};this.hasFocus=false;this.color=undefined;this.autocapitalize="none";this.autofocus=false;this.clearOnEdit=false;this.debounce=undefined;this.disabled=false;this.fill=undefined;this.inputmode=undefined;this.enterkeyhint=undefined;this.maxlength=undefined;this.minlength=undefined;this.name=this.inputId;this.placeholder=undefined;this.readonly=false;this.required=false;this.spellcheck=false;this.cols=undefined;this.rows=undefined;this.wrap=undefined;this.autoGrow=false;this.value="";this.counter=false;this.counterFormatter=undefined;this.errorText=undefined;this.helperText=undefined;this.label=undefined;this.labelPlacement="start";this.legacy=undefined;this.shape=undefined}debounceChanged(){const{ionInput:t,debounce:e,originalIonInput:a}=this;this.ionInput=e===undefined?a!==null&&a!==void 0?a:t:d(t,e)}disabledChanged(){this.emitStyle()}valueChanged(){const t=this.nativeInput;const e=this.getValue();if(t&&t.value!==e){t.value=e}this.runAutoGrow();this.emitStyle()}connectedCallback(){const{el:t}=this;this.legacyFormController=s(t);this.slotMutationController=g(t,["label","start","end"],(()=>n(this)));this.notchController=l(t,(()=>this.notchSpacerEl),(()=>this.labelSlot));this.emitStyle();this.debounceChanged();{document.dispatchEvent(new CustomEvent("ionInputDidLoad",{detail:t}))}}disconnectedCallback(){{document.dispatchEvent(new CustomEvent("ionInputDidUnload",{detail:this.el}))}if(this.slotMutationController){this.slotMutationController.destroy();this.slotMutationController=undefined}if(this.notchController){this.notchController.destroy();this.notchController=undefined}}componentWillLoad(){this.inheritedAttributes=Object.assign(Object.assign({},c(this.el)),x(this.el,["data-form-type","title","tabindex"]))}componentDidLoad(){this.originalIonInput=this.ionInput;this.runAutoGrow()}componentDidRender(){var t;(t=this.notchController)===null||t===void 0?void 0:t.calculateNotchWidth()}async setFocus(){if(this.nativeInput){this.nativeInput.focus()}}async getInputElement(){if(!this.nativeInput){await new Promise((t=>p(this.el,t)))}return Promise.resolve(this.nativeInput)}emitStyle(){if(this.legacyFormController.hasLegacyControl()){this.ionStyle.emit({interactive:true,textarea:true,input:true,"interactive-disabled":this.disabled,"has-placeholder":this.placeholder!==undefined,"has-value":this.hasValue(),"has-focus":this.hasFocus,legacy:!!this.legacy})}}emitValueChange(t){const{value:e}=this;const a=e==null?e:e.toString();this.focusedValue=a;this.ionChange.emit({value:a,event:t})}emitInputChange(t){const{value:e}=this;this.ionInput.emit({value:e,event:t})}runAutoGrow(){if(this.nativeInput&&this.autoGrow){a((()=>{var t;if(this.textareaWrapper){this.textareaWrapper.dataset.replicatedValue=(t=this.value)!==null&&t!==void 0?t:""}}))}}checkClearOnEdit(t){if(!this.clearOnEdit){return}const e=["Tab","Shift","Meta","Alt","Control"];const a=e.includes(t.key);if(!this.didTextareaClearOnEdit&&this.hasValue()&&!a){this.value="";this.emitInputChange(t)}if(!a){this.didTextareaClearOnEdit=true}}focusChange(){this.emitStyle()}hasValue(){return this.getValue()!==""}getValue(){return this.value||""}renderLegacyTextarea(){if(!this.hasLoggedDeprecationWarning){m(`ion-textarea 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-textarea label="Comments"></ion-textarea>\nExample with aria-label: <ion-textarea aria-label="Comments"></ion-textarea>\n\nFor textareas 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 textarea 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);this.hasLoggedDeprecationWarning=true}const t=v(this);const e=this.getValue();const a=this.inputId+"-lbl";const o=h(this.el);if(o){o.id=a}return i(r,{"aria-disabled":this.disabled?"true":null,class:u(this.color,{[t]:true,"legacy-textarea":true})},i("div",{class:"textarea-legacy-wrapper",ref:t=>this.textareaWrapper=t},i("textarea",Object.assign({class:"native-textarea","aria-labelledby":o?o.id:null,ref:t=>this.nativeInput=t,autoCapitalize:this.autocapitalize,autoFocus:this.autofocus,enterKeyHint:this.enterkeyhint,inputMode:this.inputmode,disabled:this.disabled,maxLength:this.maxlength,minLength:this.minlength,name:this.name,placeholder:this.placeholder||"",readOnly:this.readonly,required:this.required,spellcheck:this.spellcheck,cols:this.cols,rows:this.rows,wrap:this.wrap,onInput:this.onInput,onChange:this.onChange,onBlur:this.onBlur,onFocus:this.onFocus,onKeyDown:this.onKeyDown},this.inheritedAttributes),e)))}renderLabel(){const{label:t}=this;return i("div",{class:{"label-text-wrapper":true,"label-text-wrapper-hidden":!this.hasLabel}},t===undefined?i("slot",{name:"label"}):i("div",{class:"label-text"},t))}get labelSlot(){return this.el.querySelector('[slot="label"]')}get hasLabel(){return this.label!==undefined||this.labelSlot!==null}renderLabelContainer(){const t=v(this);const e=t==="md"&&this.fill==="outline";if(e){return[i("div",{class:"textarea-outline-container"},i("div",{class:"textarea-outline-start"}),i("div",{class:{"textarea-outline-notch":true,"textarea-outline-notch-hidden":!this.hasLabel}},i("div",{class:"notch-spacer","aria-hidden":"true",ref:t=>this.notchSpacerEl=t},this.label)),i("div",{class:"textarea-outline-end"})),this.renderLabel()]}return this.renderLabel()}renderHintText(){const{helperText:t,errorText:e}=this;return[i("div",{class:"helper-text"},t),i("div",{class:"error-text"},e)]}renderCounter(){const{counter:t,maxlength:e,counterFormatter:a,value:r}=this;if(t!==true||e===undefined){return}return i("div",{class:"counter"},b(r,e,a))}renderBottomContent(){const{counter:t,helperText:e,errorText:a,maxlength:r}=this;const o=!!e||!!a;const n=t===true&&r!==undefined;if(!o&&!n){return}return i("div",{class:"textarea-bottom"},this.renderHintText(),this.renderCounter())}renderTextarea(){const{inputId:t,disabled:e,fill:a,shape:o,labelPlacement:n,el:s,hasFocus:l}=this;const d=v(this);const c=this.getValue();const x=f("ion-item",this.el);const p=d==="md"&&a!=="outline"&&!x;const h=this.hasValue();const m=s.querySelector('[slot="start"], [slot="end"]')!==null;const g=n==="stacked"||n==="floating"&&(h||l||m);return i(r,{class:u(this.color,{[d]:true,"has-value":h,"has-focus":l,"label-floating":g,[`textarea-fill-${a}`]:a!==undefined,[`textarea-shape-${o}`]:o!==undefined,[`textarea-label-placement-${n}`]:true,"textarea-disabled":e})},i("label",{class:"textarea-wrapper",htmlFor:t},this.renderLabelContainer(),i("div",{class:"textarea-wrapper-inner"},i("div",{class:"start-slot-wrapper"},i("slot",{name:"start"})),i("div",{class:"native-wrapper",ref:t=>this.textareaWrapper=t},i("textarea",Object.assign({class:"native-textarea",ref:t=>this.nativeInput=t,id:t,disabled:e,autoCapitalize:this.autocapitalize,autoFocus:this.autofocus,enterKeyHint:this.enterkeyhint,inputMode:this.inputmode,minLength:this.minlength,maxLength:this.maxlength,name:this.name,placeholder:this.placeholder||"",readOnly:this.readonly,required:this.required,spellcheck:this.spellcheck,cols:this.cols,rows:this.rows,wrap:this.wrap,onInput:this.onInput,onChange:this.onChange,onBlur:this.onBlur,onFocus:this.onFocus,onKeyDown:this.onKeyDown},this.inheritedAttributes),c)),i("div",{class:"end-slot-wrapper"},i("slot",{name:"end"}))),p&&i("div",{class:"textarea-highlight"})),this.renderBottomContent())}render(){const{legacyFormController:t}=this;return t.hasLegacyControl()?this.renderLegacyTextarea():this.renderTextarea()}get el(){return o(this)}static get watchers(){return{debounce:["debounceChanged"],disabled:["disabledChanged"],value:["valueChanged"]}}};let z=0;k.style={ios:w,md:y};export{k as ion_textarea};
|
|
2
|
+
//# sourceMappingURL=p-40853e46.entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["textareaIosCss","textareaMdCss","Textarea","constructor","hostRef","this","inputId","textareaIds","didTextareaClearOnEdit","inheritedAttributes","hasLoggedDeprecationWarning","onInput","ev","input","target","value","emitInputChange","onChange","emitValueChange","onFocus","hasFocus","focusedValue","focusChange","ionFocus","emit","onBlur","ionBlur","onKeyDown","checkClearOnEdit","color","undefined","autocapitalize","autofocus","clearOnEdit","debounce","disabled","fill","inputmode","enterkeyhint","maxlength","minlength","name","placeholder","readonly","required","spellcheck","cols","rows","wrap","autoGrow","counter","counterFormatter","errorText","helperText","label","labelPlacement","legacy","shape","debounceChanged","ionInput","originalIonInput","debounceEvent","disabledChanged","emitStyle","valueChanged","nativeInput","getValue","runAutoGrow","connectedCallback","el","legacyFormController","createLegacyFormController","slotMutationController","createSlotMutationController","forceUpdate","notchController","createNotchController","notchSpacerEl","labelSlot","document","dispatchEvent","CustomEvent","detail","disconnectedCallback","destroy","componentWillLoad","Object","assign","inheritAriaAttributes","inheritAttributes","componentDidLoad","componentDidRender","_a","calculateNotchWidth","async","focus","Promise","resolve","componentOnReady","hasLegacyControl","ionStyle","interactive","textarea","hasValue","event","newValue","toString","ionChange","writeTask","textareaWrapper","dataset","replicatedValue","IGNORED_KEYS","pressedIgnoredKey","includes","key","renderLegacyTextarea","printIonWarning","mode","getIonMode","labelId","findItemLabel","id","h","Host","class","createColorClasses","ref","autoCapitalize","autoFocus","enterKeyHint","inputMode","maxLength","minLength","readOnly","renderLabel","hasLabel","querySelector","renderLabelContainer","hasOutlineFill","renderHintText","renderCounter","getCounterText","renderBottomContent","hasHintText","hasCounter","renderTextarea","inItem","hostContext","shouldRenderHighlight","hasStartEndSlots","labelShouldFloat","htmlFor","render"],"sources":["./node_modules/@ionic/core/dist/collection/components/textarea/textarea.ios.css?tag=ion-textarea&mode=ios&encapsulation=scoped","./node_modules/@ionic/core/dist/collection/components/textarea/textarea.md.css?tag=ion-textarea&mode=md&encapsulation=scoped","./node_modules/@ionic/core/dist/collection/components/textarea/textarea.js"],"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 textarea\n *\n * @prop --border-radius: Border radius of the textarea\n * @prop --border-color: Color of the border below the textarea when using helper text, error text, or counter\n * @prop --border-radius: Radius of the textarea border. 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 textarea when using helper text, error text, or counter\n * @prop --border-width: Width of the border below the textarea when using helper text, error text, or counter\n *\n * @prop --color: Color of the text\n *\n * @prop --placeholder-color: Color of the placeholder text\n * @prop --placeholder-font-style: Style of the placeholder text\n * @prop --placeholder-font-weight: Weight of the placeholder text\n * @prop --placeholder-opacity: Opacity of the placeholder text\n *\n * @prop --highlight-color-focused: The color of the highlight on the textarea when focused\n * @prop --highlight-color-valid: The color of the highlight on the textarea when valid\n * @prop --highlight-color-invalid: The color of the highlight on the textarea when invalid\n *\n * @prop --padding-top: Top padding of the textarea\n * @prop --padding-end: Right padding if direction is left-to-right, and left padding if direction is right-to-left of the textarea\n * @prop --padding-bottom: Bottom padding of the textarea\n * @prop --padding-start: Left padding if direction is left-to-right, and right padding if direction is right-to-left of the textarea\n */\n --background: initial;\n --color: initial;\n --placeholder-color: initial;\n --placeholder-font-style: initial;\n --placeholder-font-weight: initial;\n --placeholder-opacity: 0.6;\n --padding-top: 0;\n --padding-end: 0;\n --padding-bottom: 0;\n --padding-start: 0;\n --border-radius: 0;\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 color: var(--color);\n font-family: var(--ion-font-family, inherit);\n z-index: 2;\n box-sizing: border-box;\n}\n\n:host(:not(.legacy-textarea)) {\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 textarea text.\n * Also, floating and stacked labels should not\n * push the label down since it it\n * sits on top of the textarea.\n */\n:host(.textarea-label-placement-floating),\n:host(.textarea-label-placement-stacked) {\n --padding-top: 0px;\n min-height: 56px;\n}\n\n/**\n * When the cols property is set we should\n * respect that width instead of defaulting\n * to taking up the entire line.\n * Requires both the cols and autoGrow\n * properties to be reflected as attributes\n * on the host.\n *\n * cols does not work with autoGrow because\n * autoGrow would prevent line breaks from naturally\n * occurring until the textarea takes up the entire line width.\n */\n:host([cols]:not([auto-grow])) {\n width: fit-content;\n}\n\n:host(.legacy-textarea) {\n flex: 1;\n background: var(--background);\n white-space: pre-wrap;\n}\n\n:host(.legacy-textarea.ion-color) {\n color: var(--ion-color-base);\n}\n\n:host(:not(.legacy-textarea)) {\n --padding-bottom: 8px;\n}\n\n:host(.ion-color) {\n --highlight-color-focused: var(--ion-color-base);\n background: initial;\n}\n\n:host-context(ion-item) {\n align-self: baseline;\n}\n\n:host-context(ion-item:not(.item-label)) {\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.native-textarea {\n margin-left: 0;\n margin-right: 0;\n margin-top: 0;\n margin-bottom: 0;\n padding-left: 0;\n padding-right: 0;\n padding-top: 0;\n padding-bottom: 0;\n display: 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 white-space: pre-wrap;\n /**\n * This ensures the textarea\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 textarea.\n */\n z-index: 1;\n box-sizing: border-box;\n resize: none;\n appearance: none;\n}\n.native-textarea::placeholder {\n padding-left: 0;\n padding-right: 0;\n padding-top: 0;\n padding-bottom: 0;\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\n:host(.legacy-textarea) .native-textarea {\n white-space: inherit;\n}\n\n:host(.legacy-textarea) .native-textarea,\n:host(.legacy-textarea) .textarea-legacy-wrapper::after {\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.native-textarea {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-style: inherit;\n font-weight: inherit;\n letter-spacing: inherit;\n text-align: inherit;\n text-decoration: inherit;\n text-indent: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n grid-area: 1/1/2/2;\n word-break: break-word;\n}\n\n:host(.legacy-textarea) .textarea-legacy-wrapper::after {\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 grid-area: 1/1/2/2;\n word-break: break-word;\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-textarea[auto-grow]) .cloned-input {\n margin-left: 0;\n margin-right: 0;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n:host([auto-grow]) .cloned-input {\n height: 100%;\n}\n\n:host([auto-grow]) .native-textarea {\n overflow: hidden;\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.textarea-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: 0px;\n padding-bottom: 0px;\n border-radius: var(--border-radius);\n display: flex;\n position: relative;\n flex-grow: 1;\n align-items: flex-start;\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 position: relative;\n width: 100%;\n height: 100%;\n}\n\n:host(.has-focus) textarea {\n caret-color: var(--highlight-color);\n}\n\n.native-wrapper textarea {\n -webkit-padding-start: 0px;\n padding-inline-start: 0px;\n -webkit-padding-end: 0px;\n padding-inline-end: 0px;\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n}\n\n.native-wrapper,\n.textarea-legacy-wrapper {\n display: grid;\n min-width: inherit;\n max-width: inherit;\n min-height: inherit;\n max-height: inherit;\n /**\n * This avoids a WebKit bug where\n * the height of the inner textarea\n * is incorrect and flows outside the\n * parent container: https://bugs.webkit.org/show_bug.cgi?id=256781\n * TODO FW-4734\n */\n grid-auto-rows: 100%;\n}\n.native-wrapper::after,\n.textarea-legacy-wrapper::after {\n white-space: pre-wrap;\n content: attr(data-replicated-value) \" \";\n visibility: hidden;\n}\n\n.native-wrapper::after {\n padding-left: 0;\n padding-right: 0;\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n margin-left: 0;\n margin-right: 0;\n margin-top: 0;\n margin-bottom: 0;\n border-radius: var(--border-radius);\n /**\n * Note: Do not use @include text-inherit()\n * as that sets white-space: inherit\n * Instead, we use white-space: pre-wrap above.\n */\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-style: inherit;\n font-weight: inherit;\n letter-spacing: inherit;\n text-align: inherit;\n text-decoration: inherit;\n text-indent: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n grid-area: 1/1/2/2;\n word-break: break-word;\n}\n\n.textarea-wrapper-inner {\n display: flex;\n width: 100%;\n min-height: inherit;\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 touched/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.textarea-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 textarea.\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 textarea 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/**\n * Error text should only be shown when .ion-invalid is\n * present on the textarea. Otherwise the helper text should\n * be shown.\n */\n.textarea-bottom .error-text {\n display: none;\n color: var(--highlight-color-invalid);\n}\n\n.textarea-bottom .helper-text {\n display: block;\n color: var(--ion-color-step-550, #737373);\n}\n\n:host(.ion-touched.ion-invalid) .textarea-bottom .error-text {\n display: block;\n}\n\n:host(.ion-touched.ion-invalid) .textarea-bottom .helper-text {\n display: none;\n}\n\n.textarea-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.label-text-wrapper {\n -webkit-padding-start: 0px;\n padding-inline-start: 0px;\n -webkit-padding-end: 0px;\n padding-inline-end: 0px;\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n /**\n * Label text should not extend\n * beyond the bounds of the textarea.\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 textarea\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 textarea 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.textarea-outline-notch-hidden {\n display: none;\n}\n\n.textarea-wrapper textarea {\n /**\n * When the floating label appears on top of the\n * textarea, we need to fade the textarea 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 textarea in LTR and\n * on the right in RTL.\n */\n:host(.textarea-label-placement-start) .textarea-wrapper {\n flex-direction: row;\n}\n\n:host(.textarea-label-placement-start) .label-text-wrapper {\n /**\n * The margin between the label and\n * the textarea 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 textarea in LTR and\n * on the left in RTL.\n */\n:host(.textarea-label-placement-end) .textarea-wrapper {\n flex-direction: row-reverse;\n}\n\n/**\n * The margin between the label and\n * the textarea should be on the start\n * when the label sits at the end.\n */\n:host(.textarea-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(.textarea-label-placement-fixed) .label-text-wrapper {\n /**\n * The margin between the label and\n * the textarea 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 textarea in LTR and\n * on the right in RTL. Label also has a fixed width.\n */\n:host(.textarea-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 textarea and is scaled down.\n * Floating: Label sits over the textarea when the textarea has no\n * value and is blurred. Label sits above the textarea and is scaled\n * down when the textarea is focused or has a value.\n *\n */\n:host(.textarea-label-placement-stacked) .textarea-wrapper,\n:host(.textarea-label-placement-floating) .textarea-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(.textarea-label-placement-stacked) .label-text-wrapper,\n:host(.textarea-label-placement-floating) .label-text-wrapper {\n transform-origin: left top;\n -webkit-padding-start: 0px;\n padding-inline-start: 0px;\n -webkit-padding-end: 0px;\n padding-inline-end: 0px;\n padding-top: 0px;\n padding-bottom: 0px;\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(.textarea-label-placement-stacked) .label-text-wrapper, :host-context([dir=rtl]).textarea-label-placement-stacked .label-text-wrapper, :host-context([dir=rtl]):host(.textarea-label-placement-floating) .label-text-wrapper, :host-context([dir=rtl]).textarea-label-placement-floating .label-text-wrapper {\n transform-origin: right top;\n}\n\n@supports selector(:dir(rtl)) {\n :host(.textarea-label-placement-stacked:dir(rtl)) .label-text-wrapper, :host(.textarea-label-placement-floating:dir(rtl)) .label-text-wrapper {\n transform-origin: right top;\n }\n}\n\n/**\n * Ensures the textarea does not\n * overlap the label.\n */\n:host(.textarea-label-placement-stacked) textarea,\n:host(.textarea-label-placement-floating) textarea,\n:host(.textarea-label-placement-stacked[auto-grow]) .native-wrapper::after,\n:host(.textarea-label-placement-floating[auto-grow]) .native-wrapper::after {\n -webkit-margin-start: 0px;\n margin-inline-start: 0px;\n -webkit-margin-end: 0px;\n margin-inline-end: 0px;\n margin-top: 8px;\n margin-bottom: 0px;\n}\n\n:host(.textarea-label-placement-stacked) ::slotted([slot=start]),\n:host(.textarea-label-placement-stacked) ::slotted([slot=end]),\n:host(.textarea-label-placement-floating) ::slotted([slot=start]),\n:host(.textarea-label-placement-floating) ::slotted([slot=end]) {\n margin-top: 8px;\n}\n\n/**\n * This makes the label sit over the textarea\n * when the textarea is blurred and has no value.\n */\n:host(.textarea-label-placement-floating) .label-text-wrapper {\n transform: translateY(100%) scale(1);\n}\n\n/**\n * The textarea should be hidden when the label\n * is on top of the textarea. This prevents the label\n * from overlapping any placeholder value.\n */\n:host(.textarea-label-placement-floating) textarea {\n opacity: 0;\n}\n\n:host(.has-focus.textarea-label-placement-floating) textarea,\n:host(.has-value.textarea-label-placement-floating) textarea {\n opacity: 1;\n}\n\n/**\n * This makes the label sit above the textarea.\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 textarea.\n */\n max-width: calc(100% / 0.75);\n}\n\n.start-slot-wrapper, .end-slot-wrapper {\n padding-left: 0;\n padding-right: 0;\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n display: flex;\n flex-shrink: 0;\n align-self: start;\n}\n\n::slotted([slot=start]),\n::slotted([slot=end]) {\n margin-top: 0;\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 {\n --border-width: 0.55px;\n --border-color: var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, #c8c7cc)));\n --padding-top: 10px;\n --padding-end: 0px;\n --padding-bottom: 8px;\n --padding-start: 0px;\n font-size: inherit;\n}\n\n:host(.legacy-textarea) {\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:host(.legacy-textarea) .native-textarea[disabled],\n:host(.textarea-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 textarea\n *\n * @prop --border-radius: Border radius of the textarea\n * @prop --border-color: Color of the border below the textarea when using helper text, error text, or counter\n * @prop --border-radius: Radius of the textarea border. 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 textarea when using helper text, error text, or counter\n * @prop --border-width: Width of the border below the textarea when using helper text, error text, or counter\n *\n * @prop --color: Color of the text\n *\n * @prop --placeholder-color: Color of the placeholder text\n * @prop --placeholder-font-style: Style of the placeholder text\n * @prop --placeholder-font-weight: Weight of the placeholder text\n * @prop --placeholder-opacity: Opacity of the placeholder text\n *\n * @prop --highlight-color-focused: The color of the highlight on the textarea when focused\n * @prop --highlight-color-valid: The color of the highlight on the textarea when valid\n * @prop --highlight-color-invalid: The color of the highlight on the textarea when invalid\n *\n * @prop --padding-top: Top padding of the textarea\n * @prop --padding-end: Right padding if direction is left-to-right, and left padding if direction is right-to-left of the textarea\n * @prop --padding-bottom: Bottom padding of the textarea\n * @prop --padding-start: Left padding if direction is left-to-right, and right padding if direction is right-to-left of the textarea\n */\n --background: initial;\n --color: initial;\n --placeholder-color: initial;\n --placeholder-font-style: initial;\n --placeholder-font-weight: initial;\n --placeholder-opacity: 0.6;\n --padding-top: 0;\n --padding-end: 0;\n --padding-bottom: 0;\n --padding-start: 0;\n --border-radius: 0;\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 color: var(--color);\n font-family: var(--ion-font-family, inherit);\n z-index: 2;\n box-sizing: border-box;\n}\n\n:host(:not(.legacy-textarea)) {\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 textarea text.\n * Also, floating and stacked labels should not\n * push the label down since it it\n * sits on top of the textarea.\n */\n:host(.textarea-label-placement-floating),\n:host(.textarea-label-placement-stacked) {\n --padding-top: 0px;\n min-height: 56px;\n}\n\n/**\n * When the cols property is set we should\n * respect that width instead of defaulting\n * to taking up the entire line.\n * Requires both the cols and autoGrow\n * properties to be reflected as attributes\n * on the host.\n *\n * cols does not work with autoGrow because\n * autoGrow would prevent line breaks from naturally\n * occurring until the textarea takes up the entire line width.\n */\n:host([cols]:not([auto-grow])) {\n width: fit-content;\n}\n\n:host(.legacy-textarea) {\n flex: 1;\n background: var(--background);\n white-space: pre-wrap;\n}\n\n:host(.legacy-textarea.ion-color) {\n color: var(--ion-color-base);\n}\n\n:host(:not(.legacy-textarea)) {\n --padding-bottom: 8px;\n}\n\n:host(.ion-color) {\n --highlight-color-focused: var(--ion-color-base);\n background: initial;\n}\n\n:host-context(ion-item) {\n align-self: baseline;\n}\n\n:host-context(ion-item:not(.item-label)) {\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.native-textarea {\n margin-left: 0;\n margin-right: 0;\n margin-top: 0;\n margin-bottom: 0;\n padding-left: 0;\n padding-right: 0;\n padding-top: 0;\n padding-bottom: 0;\n display: 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 white-space: pre-wrap;\n /**\n * This ensures the textarea\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 textarea.\n */\n z-index: 1;\n box-sizing: border-box;\n resize: none;\n appearance: none;\n}\n.native-textarea::placeholder {\n padding-left: 0;\n padding-right: 0;\n padding-top: 0;\n padding-bottom: 0;\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\n:host(.legacy-textarea) .native-textarea {\n white-space: inherit;\n}\n\n:host(.legacy-textarea) .native-textarea,\n:host(.legacy-textarea) .textarea-legacy-wrapper::after {\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.native-textarea {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-style: inherit;\n font-weight: inherit;\n letter-spacing: inherit;\n text-align: inherit;\n text-decoration: inherit;\n text-indent: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n grid-area: 1/1/2/2;\n word-break: break-word;\n}\n\n:host(.legacy-textarea) .textarea-legacy-wrapper::after {\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 grid-area: 1/1/2/2;\n word-break: break-word;\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-textarea[auto-grow]) .cloned-input {\n margin-left: 0;\n margin-right: 0;\n margin-top: 0;\n margin-bottom: 0;\n}\n\n:host([auto-grow]) .cloned-input {\n height: 100%;\n}\n\n:host([auto-grow]) .native-textarea {\n overflow: hidden;\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.textarea-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: 0px;\n padding-bottom: 0px;\n border-radius: var(--border-radius);\n display: flex;\n position: relative;\n flex-grow: 1;\n align-items: flex-start;\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 position: relative;\n width: 100%;\n height: 100%;\n}\n\n:host(.has-focus) textarea {\n caret-color: var(--highlight-color);\n}\n\n.native-wrapper textarea {\n -webkit-padding-start: 0px;\n padding-inline-start: 0px;\n -webkit-padding-end: 0px;\n padding-inline-end: 0px;\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n}\n\n.native-wrapper,\n.textarea-legacy-wrapper {\n display: grid;\n min-width: inherit;\n max-width: inherit;\n min-height: inherit;\n max-height: inherit;\n /**\n * This avoids a WebKit bug where\n * the height of the inner textarea\n * is incorrect and flows outside the\n * parent container: https://bugs.webkit.org/show_bug.cgi?id=256781\n * TODO FW-4734\n */\n grid-auto-rows: 100%;\n}\n.native-wrapper::after,\n.textarea-legacy-wrapper::after {\n white-space: pre-wrap;\n content: attr(data-replicated-value) \" \";\n visibility: hidden;\n}\n\n.native-wrapper::after {\n padding-left: 0;\n padding-right: 0;\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n margin-left: 0;\n margin-right: 0;\n margin-top: 0;\n margin-bottom: 0;\n border-radius: var(--border-radius);\n /**\n * Note: Do not use @include text-inherit()\n * as that sets white-space: inherit\n * Instead, we use white-space: pre-wrap above.\n */\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-style: inherit;\n font-weight: inherit;\n letter-spacing: inherit;\n text-align: inherit;\n text-decoration: inherit;\n text-indent: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n grid-area: 1/1/2/2;\n word-break: break-word;\n}\n\n.textarea-wrapper-inner {\n display: flex;\n width: 100%;\n min-height: inherit;\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 touched/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.textarea-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 textarea.\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 textarea 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/**\n * Error text should only be shown when .ion-invalid is\n * present on the textarea. Otherwise the helper text should\n * be shown.\n */\n.textarea-bottom .error-text {\n display: none;\n color: var(--highlight-color-invalid);\n}\n\n.textarea-bottom .helper-text {\n display: block;\n color: var(--ion-color-step-550, #737373);\n}\n\n:host(.ion-touched.ion-invalid) .textarea-bottom .error-text {\n display: block;\n}\n\n:host(.ion-touched.ion-invalid) .textarea-bottom .helper-text {\n display: none;\n}\n\n.textarea-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.label-text-wrapper {\n -webkit-padding-start: 0px;\n padding-inline-start: 0px;\n -webkit-padding-end: 0px;\n padding-inline-end: 0px;\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n /**\n * Label text should not extend\n * beyond the bounds of the textarea.\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 textarea\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 textarea 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.textarea-outline-notch-hidden {\n display: none;\n}\n\n.textarea-wrapper textarea {\n /**\n * When the floating label appears on top of the\n * textarea, we need to fade the textarea 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 textarea in LTR and\n * on the right in RTL.\n */\n:host(.textarea-label-placement-start) .textarea-wrapper {\n flex-direction: row;\n}\n\n:host(.textarea-label-placement-start) .label-text-wrapper {\n /**\n * The margin between the label and\n * the textarea 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 textarea in LTR and\n * on the left in RTL.\n */\n:host(.textarea-label-placement-end) .textarea-wrapper {\n flex-direction: row-reverse;\n}\n\n/**\n * The margin between the label and\n * the textarea should be on the start\n * when the label sits at the end.\n */\n:host(.textarea-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(.textarea-label-placement-fixed) .label-text-wrapper {\n /**\n * The margin between the label and\n * the textarea 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 textarea in LTR and\n * on the right in RTL. Label also has a fixed width.\n */\n:host(.textarea-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 textarea and is scaled down.\n * Floating: Label sits over the textarea when the textarea has no\n * value and is blurred. Label sits above the textarea and is scaled\n * down when the textarea is focused or has a value.\n *\n */\n:host(.textarea-label-placement-stacked) .textarea-wrapper,\n:host(.textarea-label-placement-floating) .textarea-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(.textarea-label-placement-stacked) .label-text-wrapper,\n:host(.textarea-label-placement-floating) .label-text-wrapper {\n transform-origin: left top;\n -webkit-padding-start: 0px;\n padding-inline-start: 0px;\n -webkit-padding-end: 0px;\n padding-inline-end: 0px;\n padding-top: 0px;\n padding-bottom: 0px;\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(.textarea-label-placement-stacked) .label-text-wrapper, :host-context([dir=rtl]).textarea-label-placement-stacked .label-text-wrapper, :host-context([dir=rtl]):host(.textarea-label-placement-floating) .label-text-wrapper, :host-context([dir=rtl]).textarea-label-placement-floating .label-text-wrapper {\n transform-origin: right top;\n}\n\n@supports selector(:dir(rtl)) {\n :host(.textarea-label-placement-stacked:dir(rtl)) .label-text-wrapper, :host(.textarea-label-placement-floating:dir(rtl)) .label-text-wrapper {\n transform-origin: right top;\n }\n}\n\n/**\n * Ensures the textarea does not\n * overlap the label.\n */\n:host(.textarea-label-placement-stacked) textarea,\n:host(.textarea-label-placement-floating) textarea,\n:host(.textarea-label-placement-stacked[auto-grow]) .native-wrapper::after,\n:host(.textarea-label-placement-floating[auto-grow]) .native-wrapper::after {\n -webkit-margin-start: 0px;\n margin-inline-start: 0px;\n -webkit-margin-end: 0px;\n margin-inline-end: 0px;\n margin-top: 8px;\n margin-bottom: 0px;\n}\n\n:host(.textarea-label-placement-stacked) ::slotted([slot=start]),\n:host(.textarea-label-placement-stacked) ::slotted([slot=end]),\n:host(.textarea-label-placement-floating) ::slotted([slot=start]),\n:host(.textarea-label-placement-floating) ::slotted([slot=end]) {\n margin-top: 8px;\n}\n\n/**\n * This makes the label sit over the textarea\n * when the textarea is blurred and has no value.\n */\n:host(.textarea-label-placement-floating) .label-text-wrapper {\n transform: translateY(100%) scale(1);\n}\n\n/**\n * The textarea should be hidden when the label\n * is on top of the textarea. This prevents the label\n * from overlapping any placeholder value.\n */\n:host(.textarea-label-placement-floating) textarea {\n opacity: 0;\n}\n\n:host(.has-focus.textarea-label-placement-floating) textarea,\n:host(.has-value.textarea-label-placement-floating) textarea {\n opacity: 1;\n}\n\n/**\n * This makes the label sit above the textarea.\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 textarea.\n */\n max-width: calc(100% / 0.75);\n}\n\n.start-slot-wrapper, .end-slot-wrapper {\n padding-left: 0;\n padding-right: 0;\n padding-top: var(--padding-top);\n padding-bottom: var(--padding-bottom);\n display: flex;\n flex-shrink: 0;\n align-self: start;\n}\n\n::slotted([slot=start]),\n::slotted([slot=end]) {\n margin-top: 0;\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/**\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(.textarea-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 textarea wrapper.\n * As a result, the border on the \"bottom\n * content\" is not needed.\n */\n:host(.textarea-fill-solid) .textarea-wrapper {\n border-bottom: var(--border-width) var(--border-style) var(--border-color);\n}\n\n/**\n * If the textarea has a validity state, the\n * border should reflect that as a color.\n */\n:host(.has-focus.textarea-fill-solid.ion-valid),\n:host(.textarea-fill-solid.ion-touched.ion-invalid) {\n --border-color: var(--highlight-color);\n}\n\n:host(.textarea-fill-solid) .textarea-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(.textarea-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(.textarea-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(.textarea-fill-solid) .textarea-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(.textarea-fill-solid) .textarea-wrapper, :host-context([dir=rtl]).textarea-fill-solid .textarea-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(.textarea-fill-solid:dir(rtl)) .textarea-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.textarea-fill-solid) .label-text-wrapper {\n /**\n * Label text should not extend\n * beyond the bounds of the textarea.\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(.textarea-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(.textarea-fill-outline.textarea-shape-round) {\n --border-radius: 28px;\n --padding-start: 32px;\n --padding-end: 32px;\n}\n\n/**\n * If the textarea has a validity state, the\n * border should reflect that as a color.\n */\n:host(.has-focus.textarea-fill-outline.ion-valid),\n:host(.textarea-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(.textarea-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 textarea is focused.\n */\n:host(.textarea-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(.textarea-fill-outline) .textarea-bottom {\n border-top: none;\n}\n\n/**\n * Outline textarea do not have a bottom border.\n * Instead, they have a border that wraps the\n * textarea + label.\n */\n:host(.textarea-fill-outline) .textarea-wrapper {\n border-bottom: none;\n}\n\n:host(.textarea-fill-outline.textarea-label-placement-stacked) .label-text-wrapper,\n:host(.textarea-fill-outline.textarea-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 textarea.\n */\n max-width: calc(100% - var(--padding-start) - var(--padding-end));\n}\n:host-context([dir=rtl]):host(.textarea-fill-outline.textarea-label-placement-stacked) .label-text-wrapper, :host-context([dir=rtl]).textarea-fill-outline.textarea-label-placement-stacked .label-text-wrapper, :host-context([dir=rtl]):host(.textarea-fill-outline.textarea-label-placement-floating) .label-text-wrapper, :host-context([dir=rtl]).textarea-fill-outline.textarea-label-placement-floating .label-text-wrapper {\n transform-origin: right top;\n}\n\n@supports selector(:dir(rtl)) {\n :host(.textarea-fill-outline.textarea-label-placement-stacked:dir(rtl)) .label-text-wrapper, :host(.textarea-fill-outline.textarea-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(.textarea-fill-outline) .label-text-wrapper,\n:host(.textarea-fill-outline) .label-text-wrapper {\n position: relative;\n}\n\n/**\n * This makes the label sit above the textarea.\n */\n:host(.label-floating.textarea-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 textarea.\n */\n max-width: calc(\n (100% - var(--padding-start) - var(--padding-end) - 8px) / 0.75\n );\n}\n\n/**\n * This ensures that the textarea does not\n * overlap the floating label while still\n * remaining visually centered.\n */\n:host(.textarea-fill-outline.textarea-label-placement-stacked) textarea,\n:host(.textarea-fill-outline.textarea-label-placement-floating) textarea,\n:host(.textarea-fill-outline.textarea-label-placement-stacked[auto-grow]) .native-wrapper::after,\n:host(.textarea-fill-outline.textarea-label-placement-floating[auto-grow]) .native-wrapper::after {\n -webkit-margin-start: 0px;\n margin-inline-start: 0px;\n -webkit-margin-end: 0px;\n margin-inline-end: 0px;\n margin-top: 12px;\n margin-bottom: 0px;\n}\n\n:host(.textarea-fill-outline.textarea-label-placement-stacked) ::slotted([slot=start]),\n:host(.textarea-fill-outline.textarea-label-placement-stacked) ::slotted([slot=end]),\n:host(.textarea-fill-outline.textarea-label-placement-floating) ::slotted([slot=start]),\n:host(.textarea-fill-outline.textarea-label-placement-floating) ::slotted([slot=end]) {\n margin-top: 12px;\n}\n\n:host(.textarea-fill-outline) .textarea-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(.textarea-fill-outline) .textarea-outline-start,\n:host(.textarea-fill-outline) .textarea-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(.textarea-fill-outline) .textarea-outline-start,\n:host(.textarea-fill-outline) .textarea-outline-notch,\n:host(.textarea-fill-outline) .textarea-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(.textarea-fill-outline) .textarea-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(.textarea-fill-outline) .notch-spacer {\n /**\n * We need $textarea-md-floating-label-padding of padding on the right.\n * However, we also subtracted $textarea-md-floating-label-padding from\n * the width of .textarea-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 textarea is updated\n * to use the Shadow DOM.\n */\n box-sizing: content-box;\n}\n\n:host(.textarea-fill-outline) .textarea-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 .textarea-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 textarea. 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(.textarea-fill-outline) .textarea-outline-start, :host-context([dir=rtl]).textarea-fill-outline .textarea-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(.textarea-fill-outline:dir(rtl)) .textarea-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(.textarea-fill-outline) .textarea-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(.textarea-fill-outline) .textarea-outline-end, :host-context([dir=rtl]).textarea-fill-outline .textarea-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(.textarea-fill-outline:dir(rtl)) .textarea-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 textarea 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.textarea-fill-outline) .textarea-outline-notch {\n border-top: none;\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 --padding-top: 18px;\n --padding-end: 0px;\n --padding-bottom: 8px;\n --padding-start: 0px;\n font-size: inherit;\n}\n\n:host(.legacy-textarea) {\n --padding-top: 10px;\n --padding-end: 0;\n --padding-bottom: 11px;\n --padding-start: 8px;\n margin-left: 0;\n margin-right: 0;\n margin-top: 8px;\n margin-bottom: 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: 0;\n}\n\n.textarea-bottom .counter {\n letter-spacing: 0.0333333333em;\n}\n\n/**\n * When the textarea is focused the label should\n * take on the highlight color. This should\n * only apply to floating or stacked labels.\n */\n:host(.textarea-label-placement-floating.has-focus) .label-text-wrapper,\n:host(.textarea-label-placement-stacked.has-focus) .label-text-wrapper {\n color: var(--highlight-color);\n}\n\n:host(.has-focus.textarea-label-placement-floating.ion-valid) .label-text-wrapper,\n:host(.textarea-label-placement-floating.ion-touched.ion-invalid) .label-text-wrapper,\n:host(.has-focus.textarea-label-placement-stacked.ion-valid) .label-text-wrapper,\n:host(.textarea-label-placement-stacked.ion-touched.ion-invalid) .label-text-wrapper {\n color: var(--highlight-color);\n}\n\n:host(.legacy-textarea) .native-textarea[disabled],\n:host(.textarea-disabled) {\n opacity: 0.38;\n}\n\n.textarea-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 .textarea-highlight {\n inset-inline-start: 0;\n }\n}\n@supports not (inset-inline-start: 0) {\n .textarea-highlight {\n left: 0;\n }\n :host-context([dir=rtl]) .textarea-highlight {\n left: unset;\n right: unset;\n right: 0;\n }\n [dir=rtl] .textarea-highlight {\n left: unset;\n right: unset;\n right: 0;\n }\n @supports selector(:dir(rtl)) {\n .textarea-highlight:dir(rtl) {\n left: unset;\n right: unset;\n right: 0;\n }\n }\n}\n\n:host(.has-focus) .textarea-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) .textarea-highlight {\n bottom: 0;\n}\n@supports (inset-inline-start: 0) {\n :host(.in-item) .textarea-highlight {\n inset-inline-start: 0;\n }\n}\n@supports not (inset-inline-start: 0) {\n :host(.in-item) .textarea-highlight {\n left: 0;\n }\n :host-context([dir=rtl]):host(.in-item) .textarea-highlight, :host-context([dir=rtl]).in-item .textarea-highlight {\n left: unset;\n right: unset;\n right: 0;\n }\n @supports selector(:dir(rtl)) {\n :host(.in-item:dir(rtl)) .textarea-highlight {\n left: unset;\n right: unset;\n right: 0;\n }\n }\n}\n\n:host(.textarea-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, writeTask, } 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 { getIonMode } from \"../../global/ionic-global\";\nimport { getCounterText } from \"../input/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 textarea. Use the `labelPlacement` property to control where the label is placed relative to the textarea. 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 textarea. (EXPERIMENTAL)\n * @slot end - Content to display at the trailing edge of the textarea. (EXPERIMENTAL)\n */\nexport class Textarea {\n constructor() {\n this.inputId = `ion-textarea-${textareaIds++}`;\n /**\n * `true` if the textarea was cleared as a result of the user typing\n * with `clearOnEdit` enabled.\n *\n * Resets when the textarea loses focus.\n */\n this.didTextareaClearOnEdit = false;\n this.inheritedAttributes = {};\n // This flag ensures we log the deprecation warning at most once.\n this.hasLoggedDeprecationWarning = false;\n // `Event` type is used instead of `InputEvent`\n // since the types from Stencil are not derived\n // from the element (e.g. textarea and input\n // should be InputEvent, but all other elements\n // should be Event).\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.onFocus = (ev) => {\n this.hasFocus = true;\n this.focusedValue = this.value;\n this.focusChange();\n this.ionFocus.emit(ev);\n };\n this.onBlur = (ev) => {\n this.hasFocus = false;\n this.focusChange();\n if (this.focusedValue !== this.value) {\n /**\n * Emits the `ionChange` event when the textarea value\n * is different than the value when the textarea was focused.\n */\n this.emitValueChange(ev);\n }\n this.didTextareaClearOnEdit = false;\n this.ionBlur.emit(ev);\n };\n this.onKeyDown = (ev) => {\n this.checkClearOnEdit(ev);\n };\n this.hasFocus = false;\n this.color = undefined;\n this.autocapitalize = 'none';\n this.autofocus = false;\n this.clearOnEdit = false;\n this.debounce = undefined;\n this.disabled = false;\n this.fill = undefined;\n this.inputmode = undefined;\n this.enterkeyhint = undefined;\n this.maxlength = undefined;\n this.minlength = undefined;\n this.name = this.inputId;\n this.placeholder = undefined;\n this.readonly = false;\n this.required = false;\n this.spellcheck = false;\n this.cols = undefined;\n this.rows = undefined;\n this.wrap = undefined;\n this.autoGrow = false;\n this.value = '';\n this.counter = false;\n this.counterFormatter = undefined;\n this.errorText = undefined;\n this.helperText = undefined;\n this.label = undefined;\n this.labelPlacement = 'start';\n this.legacy = undefined;\n this.shape = undefined;\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 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) {\n nativeInput.value = value;\n }\n this.runAutoGrow();\n this.emitStyle();\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: el,\n }));\n }\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 componentWillLoad() {\n this.inheritedAttributes = Object.assign(Object.assign({}, inheritAriaAttributes(this.el)), inheritAttributes(this.el, ['data-form-type', 'title', 'tabindex']));\n }\n componentDidLoad() {\n this.originalIonInput = this.ionInput;\n this.runAutoGrow();\n }\n componentDidRender() {\n var _a;\n (_a = this.notchController) === null || _a === void 0 ? void 0 : _a.calculateNotchWidth();\n }\n /**\n * Sets focus on the native `textarea` in `ion-textarea`. Use this method instead of the global\n * `textarea.focus()`.\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 `<textarea>` 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 emitStyle() {\n if (this.legacyFormController.hasLegacyControl()) {\n this.ionStyle.emit({\n interactive: true,\n textarea: true,\n input: true,\n 'interactive-disabled': this.disabled,\n 'has-placeholder': this.placeholder !== undefined,\n 'has-value': this.hasValue(),\n 'has-focus': this.hasFocus,\n // TODO(FW-2876): remove this\n legacy: !!this.legacy,\n });\n }\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 this.ionInput.emit({ value, event });\n }\n runAutoGrow() {\n if (this.nativeInput && this.autoGrow) {\n writeTask(() => {\n var _a;\n if (this.textareaWrapper) {\n // Replicated value is an attribute to be used in the stylesheet\n // to set the inner contents of a pseudo element.\n this.textareaWrapper.dataset.replicatedValue = (_a = this.value) !== null && _a !== void 0 ? _a : '';\n }\n });\n }\n }\n /**\n * Check if we need to clear the text input if clearOnEdit is enabled\n */\n checkClearOnEdit(ev) {\n if (!this.clearOnEdit) {\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 textarea.\n *\n * We can't check to see if the value of the textarea\n * was changed because we call checkClearOnEdit\n * in a keydown listener, and the key has not yet\n * been added to the textarea.\n *\n * Unlike ion-input, the \"Enter\" key does modify the\n * textarea by adding a new line, so \"Enter\" is not\n * included in the IGNORED_KEYS array.\n */\n const IGNORED_KEYS = ['Tab', 'Shift', 'Meta', 'Alt', 'Control'];\n const pressedIgnoredKey = IGNORED_KEYS.includes(ev.key);\n /**\n * Clear the textarea if the control has not been previously cleared\n * during focus.\n */\n if (!this.didTextareaClearOnEdit && 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.didTextareaClearOnEdit = true;\n }\n }\n focusChange() {\n this.emitStyle();\n }\n hasValue() {\n return this.getValue() !== '';\n }\n getValue() {\n return this.value || '';\n }\n // TODO: FW-2876 - Remove this render function\n renderLegacyTextarea() {\n if (!this.hasLoggedDeprecationWarning) {\n printIonWarning(`ion-textarea 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-textarea label=\"Comments\"></ion-textarea>\nExample with aria-label: <ion-textarea aria-label=\"Comments\"></ion-textarea>\n\nFor textareas 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 textarea 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 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 'legacy-textarea': true,\n }) }, h(\"div\", { class: \"textarea-legacy-wrapper\", ref: (el) => (this.textareaWrapper = el) }, h(\"textarea\", Object.assign({ class: \"native-textarea\", \"aria-labelledby\": label ? label.id : null, ref: (el) => (this.nativeInput = el), autoCapitalize: this.autocapitalize, autoFocus: this.autofocus, enterKeyHint: this.enterkeyhint, inputMode: this.inputmode, disabled: this.disabled, maxLength: this.maxlength, minLength: this.minlength, name: this.name, placeholder: this.placeholder || '', readOnly: this.readonly, required: this.required, spellcheck: this.spellcheck, cols: this.cols, rows: this.rows, wrap: this.wrap, onInput: this.onInput, onChange: this.onChange, onBlur: this.onBlur, onFocus: this.onFocus, onKeyDown: this.onKeyDown }, this.inheritedAttributes), value))));\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 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 textarea 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: \"textarea-outline-container\" }, h(\"div\", { class: \"textarea-outline-start\" }), h(\"div\", { class: {\n 'textarea-outline-notch': true,\n 'textarea-outline-notch-hidden': !this.hasLabel,\n } }, h(\"div\", { class: \"notch-spacer\", \"aria-hidden\": \"true\", ref: (el) => (this.notchSpacerEl = el) }, this.label)), h(\"div\", { class: \"textarea-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 /**\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: \"textarea-bottom\" }, this.renderHintText(), this.renderCounter()));\n }\n renderTextarea() {\n const { inputId, disabled, fill, shape, 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 textarea.\n * For floating labels, the label should move above the textarea if\n * the textarea 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 textarea 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 [`textarea-fill-${fill}`]: fill !== undefined,\n [`textarea-shape-${shape}`]: shape !== undefined,\n [`textarea-label-placement-${labelPlacement}`]: true,\n 'textarea-disabled': disabled,\n }) }, h(\"label\", { class: \"textarea-wrapper\", htmlFor: inputId }, this.renderLabelContainer(), h(\"div\", { class: \"textarea-wrapper-inner\" }, h(\"div\", { class: \"start-slot-wrapper\" }, h(\"slot\", { name: \"start\" })), h(\"div\", { class: \"native-wrapper\", ref: (el) => (this.textareaWrapper = el) }, h(\"textarea\", Object.assign({ class: \"native-textarea\", ref: (el) => (this.nativeInput = el), id: inputId, disabled: disabled, autoCapitalize: this.autocapitalize, autoFocus: this.autofocus, enterKeyHint: this.enterkeyhint, inputMode: this.inputmode, minLength: this.minlength, maxLength: this.maxlength, name: this.name, placeholder: this.placeholder || '', readOnly: this.readonly, required: this.required, spellcheck: this.spellcheck, cols: this.cols, rows: this.rows, wrap: this.wrap, onInput: this.onInput, onChange: this.onChange, onBlur: this.onBlur, onFocus: this.onFocus, onKeyDown: this.onKeyDown }, this.inheritedAttributes), value)), h(\"div\", { class: \"end-slot-wrapper\" }, h(\"slot\", { name: \"end\" }))), shouldRenderHighlight && h(\"div\", { class: \"textarea-highlight\" })), this.renderBottomContent()));\n }\n render() {\n const { legacyFormController } = this;\n return legacyFormController.hasLegacyControl() ? this.renderLegacyTextarea() : this.renderTextarea();\n }\n static get is() { return \"ion-textarea\"; }\n static get encapsulation() { return \"scoped\"; }\n static get originalStyleUrls() {\n return {\n \"ios\": [\"textarea.ios.scss\"],\n \"md\": [\"textarea.md.scss\"]\n };\n }\n static get styleUrls() {\n return {\n \"ios\": [\"textarea.ios.css\"],\n \"md\": [\"textarea.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 \"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\": \"'none'\"\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 \"clearOnEdit\": {\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 value will be cleared after focus upon edit.\"\n },\n \"attribute\": \"clear-on-edit\",\n \"reflect\": false,\n \"defaultValue\": \"false\"\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 textarea.\"\n },\n \"attribute\": \"disabled\",\n \"reflect\": false,\n \"defaultValue\": \"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 \"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 \"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\": \"This attribute specifies the maximum number of characters that the user can enter.\"\n },\n \"attribute\": \"maxlength\",\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\": \"This attribute specifies the minimum number of characters that the user can enter.\"\n },\n \"attribute\": \"minlength\",\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 \"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.\"\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 \"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 \"cols\": {\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\": \"The visible width of the text control, in average character widths. If it is specified, it must be a positive integer.\"\n },\n \"attribute\": \"cols\",\n \"reflect\": true\n },\n \"rows\": {\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\": \"The number of visible text lines for the control.\"\n },\n \"attribute\": \"rows\",\n \"reflect\": false\n },\n \"wrap\": {\n \"type\": \"string\",\n \"mutable\": false,\n \"complexType\": {\n \"original\": \"'hard' | 'soft' | 'off'\",\n \"resolved\": \"\\\"hard\\\" | \\\"off\\\" | \\\"soft\\\" | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"Indicates how the control wraps text.\"\n },\n \"attribute\": \"wrap\",\n \"reflect\": false\n },\n \"autoGrow\": {\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 textarea container will grow and shrink based\\non the contents of the textarea.\"\n },\n \"attribute\": \"auto-grow\",\n \"reflect\": true,\n \"defaultValue\": \"false\"\n },\n \"value\": {\n \"type\": \"string\",\n \"mutable\": true,\n \"complexType\": {\n \"original\": \"string | null\",\n \"resolved\": \"null | string | undefined\",\n \"references\": {}\n },\n \"required\": false,\n \"optional\": true,\n \"docs\": {\n \"tags\": [],\n \"text\": \"The value of the textarea.\"\n },\n \"attribute\": \"value\",\n \"reflect\": false,\n \"defaultValue\": \"''\"\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.\\nDevelopers 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 \"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 textarea and displayed when an error is detected.\"\n },\n \"attribute\": \"error-text\",\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 textarea 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 textarea.\\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 textarea.\\n`\\\"start\\\"`: The label will appear to the left of the textarea in LTR and to the right in RTL.\\n`\\\"end\\\"`: The label will appear to the right of the textarea in LTR and to the left in RTL.\\n`\\\"floating\\\"`: The label will appear smaller and above the textarea when the textarea is focused or it has a value. Otherwise it will appear on top of the textarea.\\n`\\\"stacked\\\"`: The label will appear smaller and above the textarea regardless even when the textarea 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 default slot that contains\\nthe label text. As a result, the `legacy` property should only be used as\\nan escape hatch when you want to avoid 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 \"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 textarea. If \\\"round\\\" it will have an increased border radius.\"\n },\n \"attribute\": \"shape\",\n \"reflect\": false\n }\n };\n }\n static get states() {\n return {\n \"hasFocus\": {}\n };\n }\n static get events() {\n return [{\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 textarea's value.\\nUnlike the `ionInput` event, the `ionChange` event is fired when\\nthe element loses focus after its value has been modified.\"\n },\n \"complexType\": {\n \"original\": \"TextareaChangeEventDetail\",\n \"resolved\": \"TextareaChangeEventDetail\",\n \"references\": {\n \"TextareaChangeEventDetail\": {\n \"location\": \"import\",\n \"path\": \"./textarea-interface\",\n \"id\": \"src/components/textarea/textarea-interface.ts::TextareaChangeEventDetail\"\n }\n }\n }\n }, {\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 textarea's value.\\nUnlike the `ionChange` event, the `ionInput` event is fired for each alteration\\nto the textarea's value. This typically happens for each keystroke as the user types.\\n\\nWhen `clearOnEdit` is enabled, the `ionInput` event will be fired when\\nthe user clears the textarea by performing a keydown event.\"\n },\n \"complexType\": {\n \"original\": \"TextareaInputEventDetail\",\n \"resolved\": \"TextareaInputEventDetail\",\n \"references\": {\n \"TextareaInputEventDetail\": {\n \"location\": \"import\",\n \"path\": \"./textarea-interface\",\n \"id\": \"src/components/textarea/textarea-interface.ts::TextareaInputEventDetail\"\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 \"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 }\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 `textarea` in `ion-textarea`. Use this method instead of the global\\n`textarea.focus()`.\\n\\nSee [managing focus](/docs/developing/managing-focus) for more information.\",\n \"tags\": []\n }\n },\n \"getInputElement\": {\n \"complexType\": {\n \"signature\": \"() => Promise<HTMLTextAreaElement>\",\n \"parameters\": [],\n \"references\": {\n \"Promise\": {\n \"location\": \"global\",\n \"id\": \"global::Promise\"\n },\n \"HTMLTextAreaElement\": {\n \"location\": \"global\",\n \"id\": \"global::HTMLTextAreaElement\"\n }\n },\n \"return\": \"Promise<HTMLTextAreaElement>\"\n },\n \"docs\": {\n \"text\": \"Returns the native `<textarea>` 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\": \"value\",\n \"methodName\": \"valueChanged\"\n }];\n }\n}\nlet textareaIds = 0;\n"],"mappings":"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"}
|