@nova-design-system/nova-webcomponents 3.12.0 → 3.14.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/collapse.animation-23b7d61b.js +221 -0
- package/dist/cjs/collapse.animation-23b7d61b.js.map +1 -0
- package/dist/cjs/{constants-aac59496.js → constants-f5633903.js} +15 -1
- package/dist/cjs/constants-f5633903.js.map +1 -0
- package/dist/cjs/fade.animation-9294e9ee.js +726 -0
- package/dist/cjs/fade.animation-9294e9ee.js.map +1 -0
- package/dist/cjs/{grow.animation-6d003803.js → grow.animation-f1cef0ad.js} +6 -5
- package/dist/cjs/grow.animation-f1cef0ad.js.map +1 -0
- package/dist/cjs/index-c56424e5.js +8 -0
- package/dist/cjs/index.cjs.js +24 -8
- package/dist/cjs/index.cjs.js.map +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/native.cjs.js +1 -1
- package/dist/cjs/nv-accordion-item.cjs.entry.js +72 -38
- package/dist/cjs/nv-accordion-item.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-accordion.cjs.entry.js +79 -65
- package/dist/cjs/nv-accordion.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-alert.cjs.entry.js +12 -12
- package/dist/cjs/nv-alert.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-avatar.cjs.entry.js +1 -1
- package/dist/cjs/nv-badge_2.cjs.entry.js +11 -11
- package/dist/cjs/nv-badge_2.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-button.cjs.entry.js +1 -1
- package/dist/cjs/nv-calendar.cjs.entry.js +14 -10
- package/dist/cjs/nv-calendar.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-datagrid.cjs.entry.js +1 -1
- package/dist/cjs/nv-dialog.cjs.entry.js +1 -1
- package/dist/cjs/nv-dialogfooter_2.cjs.entry.js +9 -6
- package/dist/cjs/nv-dialogfooter_2.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldcheckbox.cjs.entry.js +1 -1
- package/dist/cjs/nv-fieldcheckbox.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldmultiselect.cjs.entry.js +0 -30
- package/dist/cjs/nv-fieldmultiselect.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldnumber.cjs.entry.js +1 -1
- package/dist/cjs/nv-fieldnumber.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldslider.cjs.entry.js +24 -16
- package/dist/cjs/nv-fieldslider.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldtime.cjs.entry.js +1 -1
- package/dist/cjs/nv-icon.cjs.entry.js +2 -2
- package/dist/cjs/nv-icon.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-notification.cjs.entry.js +181 -0
- package/dist/cjs/nv-notification.cjs.entry.js.map +1 -0
- package/dist/cjs/nv-notificationcontainer.cjs.entry.js +43 -0
- package/dist/cjs/nv-notificationcontainer.cjs.entry.js.map +1 -0
- package/dist/cjs/nv-popover.cjs.entry.js +4 -4
- package/dist/cjs/nv-row.cjs.entry.js +1 -1
- package/dist/cjs/nv-stack.cjs.entry.js +1 -1
- package/dist/cjs/nv-table.cjs.entry.js +2 -2
- package/dist/cjs/nv-toggle.cjs.entry.js +2 -2
- package/dist/cjs/nv-togglebutton.cjs.entry.js +1 -1
- package/dist/cjs/nv-togglebuttongroup.cjs.entry.js +1 -1
- package/dist/cjs/nv-tooltip.cjs.entry.js +1 -1
- package/dist/cjs/slide.animation-8bc27ed6.js +92 -0
- package/dist/cjs/slide.animation-8bc27ed6.js.map +1 -0
- package/dist/cjs/{stylefire.es-717e022a.js → style-value-types.es-eea2f16f.js} +51 -696
- package/dist/cjs/style-value-types.es-eea2f16f.js.map +1 -0
- package/dist/cjs/{timeline.animation-155e8839.js → timeline.animation-2878afb6.js} +20 -1
- package/dist/cjs/timeline.animation-2878afb6.js.map +1 -0
- package/dist/collection/animations/collapse.animation.js +114 -51
- package/dist/collection/animations/collapse.animation.js.map +1 -1
- package/dist/collection/animations/fade.animation.js +2 -2
- package/dist/collection/animations/fade.animation.js.map +1 -1
- package/dist/collection/animations/index.js +1 -0
- package/dist/collection/animations/index.js.map +1 -1
- package/dist/collection/animations/slide.animation.js +87 -0
- package/dist/collection/animations/slide.animation.js.map +1 -0
- package/dist/collection/animations/timeline.animation.js +19 -1
- package/dist/collection/animations/timeline.animation.js.map +1 -1
- package/dist/collection/collection-manifest.json +2 -0
- package/dist/collection/components/nv-accordion/nv-accordion.docs.js +78 -20
- package/dist/collection/components/nv-accordion/nv-accordion.docs.js.map +1 -1
- package/dist/collection/components/nv-accordion/nv-accordion.js +88 -68
- package/dist/collection/components/nv-accordion/nv-accordion.js.map +1 -1
- package/dist/collection/components/nv-accordion-item/nv-accordion-item.js +70 -36
- package/dist/collection/components/nv-accordion-item/nv-accordion-item.js.map +1 -1
- package/dist/collection/components/nv-accordion-item/styles/nv-accordion-item.css +3 -0
- package/dist/collection/components/nv-alert/nv-alert.css +1 -1
- package/dist/collection/components/nv-alert/nv-alert.js +6 -6
- package/dist/collection/components/nv-alert/nv-alert.js.map +1 -1
- package/dist/collection/components/nv-badge/nv-badge.js +7 -7
- package/dist/collection/components/nv-badge/nv-badge.js.map +1 -1
- package/dist/collection/components/nv-calendar/nv-calendar.css +4 -0
- package/dist/collection/components/nv-calendar/nv-calendar.docs.js +14 -0
- package/dist/collection/components/nv-calendar/nv-calendar.docs.js.map +1 -1
- package/dist/collection/components/nv-calendar/nv-calendar.js +47 -3
- package/dist/collection/components/nv-calendar/nv-calendar.js.map +1 -1
- package/dist/collection/components/nv-calendar/partials/calendar-actions.js +2 -2
- package/dist/collection/components/nv-calendar/partials/calendar-actions.js.map +1 -1
- package/dist/collection/components/nv-dialog/nv-dialog.docs.js +8 -0
- package/dist/collection/components/nv-dialog/nv-dialog.docs.js.map +1 -1
- package/dist/collection/components/nv-dialogfooter/nv-dialogfooter.js +13 -11
- package/dist/collection/components/nv-dialogfooter/nv-dialogfooter.js.map +1 -1
- package/dist/collection/components/nv-fieldcheckbox/nv-fieldcheckbox.css +1 -0
- package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.js +0 -30
- package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.js.map +1 -1
- package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.js +1 -1
- package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.js.map +1 -1
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.docs.js +0 -1
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.docs.js.map +1 -1
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.js +10 -10
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.js.map +1 -1
- package/dist/collection/components/nv-fieldslider/partials/field-input.js +13 -5
- package/dist/collection/components/nv-fieldslider/partials/field-input.js.map +1 -1
- package/dist/collection/components/nv-fieldslider/styles/nv-fieldslider.css +27 -0
- package/dist/collection/components/nv-fieldtime/nv-fieldtime.docs.js +0 -1
- package/dist/collection/components/nv-fieldtime/nv-fieldtime.docs.js.map +1 -1
- package/dist/collection/components/nv-icon/nv-icons.js +2 -1
- package/dist/collection/components/nv-icon/nv-icons.js.map +1 -1
- package/dist/collection/components/nv-menuitem/nv-menuitem.js +1 -1
- package/dist/collection/components/nv-notification/nv-notification.docs.js +72 -0
- package/dist/collection/components/nv-notification/nv-notification.docs.js.map +1 -0
- package/dist/collection/components/nv-notification/nv-notification.js +431 -0
- package/dist/collection/components/nv-notification/nv-notification.js.map +1 -0
- package/dist/collection/components/nv-notification/styles/nv-notification.css +155 -0
- package/dist/collection/components/nv-notificationcontainer/nv-notificationcontainer.css +61 -0
- package/dist/collection/components/nv-notificationcontainer/nv-notificationcontainer.docs.js +7 -0
- package/dist/collection/components/nv-notificationcontainer/nv-notificationcontainer.docs.js.map +1 -0
- package/dist/collection/components/nv-notificationcontainer/nv-notificationcontainer.js +76 -0
- package/dist/collection/components/nv-notificationcontainer/nv-notificationcontainer.js.map +1 -0
- package/dist/collection/components/nv-popover/nv-popover.js +1 -1
- package/dist/collection/components/nv-row/nv-row.js +1 -1
- package/dist/collection/components/nv-stack/nv-stack.js +1 -1
- package/dist/collection/components/nv-table/nv-table.js +2 -2
- package/dist/collection/components/nv-toggle/nv-toggle.js +2 -2
- package/dist/collection/components/nv-togglebutton/nv-togglebutton.js +1 -1
- package/dist/collection/components/nv-togglebuttongroup/nv-togglebuttongroup.docs.js +0 -1
- package/dist/collection/components/nv-togglebuttongroup/nv-togglebuttongroup.docs.js.map +1 -1
- package/dist/collection/components/nv-togglebuttongroup/nv-togglebuttongroup.js +1 -1
- package/dist/collection/components/nv-tooltip/nv-tooltip.js +1 -1
- package/dist/collection/utils/constants.js +14 -0
- package/dist/collection/utils/constants.js.map +1 -1
- package/dist/components/index.js +11 -7
- package/dist/components/index.js.map +1 -1
- package/dist/components/nv-accordion-item.js +1 -1
- package/dist/components/nv-accordion.js +88 -71
- package/dist/components/nv-accordion.js.map +1 -1
- package/dist/components/nv-alert.js +13 -13
- package/dist/components/nv-alert.js.map +1 -1
- package/dist/components/nv-avatar.js +2 -2
- package/dist/components/nv-badge.js +1 -1
- package/dist/components/nv-breadcrumb.js +2 -2
- package/dist/components/nv-button.js +1 -1
- package/dist/components/nv-calendar.js +1 -1
- package/dist/components/nv-datagrid.js +3 -3
- package/dist/components/nv-dialog.js +4 -4
- package/dist/components/nv-dialogfooter.js +1 -1
- package/dist/components/nv-fieldcheckbox.js +1 -1
- package/dist/components/nv-fielddate.js +5 -5
- package/dist/components/nv-fielddaterange.js +5 -5
- package/dist/components/nv-fielddropdown.js +4 -4
- package/dist/components/nv-fielddropdownitem.js +1 -1
- package/dist/components/nv-fielddropdownitemcheck.js +1 -1
- package/dist/components/nv-fieldmultiselect.js +6 -36
- package/dist/components/nv-fieldmultiselect.js.map +1 -1
- package/dist/components/nv-fieldnumber.js +1 -1
- package/dist/components/nv-fieldpassword.js +2 -2
- package/dist/components/nv-fieldselect.js +2 -2
- package/dist/components/nv-fieldslider.js +27 -19
- package/dist/components/nv-fieldslider.js.map +1 -1
- package/dist/components/nv-fieldtext.js +1 -1
- package/dist/components/nv-fieldtime.js +4 -4
- package/dist/components/nv-icon.js +1 -1
- package/dist/components/nv-iconbutton.js +1 -1
- package/dist/components/nv-menu.js +3 -3
- package/dist/components/nv-menuitem.js +1 -1
- package/dist/components/nv-notification.d.ts +11 -0
- package/dist/components/nv-notification.js +213 -0
- package/dist/components/nv-notification.js.map +1 -0
- package/dist/components/nv-notificationcontainer.d.ts +11 -0
- package/dist/components/nv-notificationcontainer.js +59 -0
- package/dist/components/nv-notificationcontainer.js.map +1 -0
- package/dist/components/nv-popover.js +1 -1
- package/dist/components/nv-row.js +1 -1
- package/dist/components/nv-stack.js +1 -1
- package/dist/components/nv-table.js +2 -2
- package/dist/components/nv-toggle.js +2 -2
- package/dist/components/nv-togglebutton.js +1 -1
- package/dist/components/nv-togglebuttongroup.js +1 -1
- package/dist/components/nv-tooltip.js +1 -1
- package/dist/components/{p-1172e9bb.js → p-00cbf2a1.js} +2 -2
- package/dist/components/p-00cbf2a1.js.map +1 -0
- package/dist/components/{p-84f4b071.js → p-086a46af.js} +75 -41
- package/dist/components/p-086a46af.js.map +1 -0
- package/dist/components/{p-87079346.js → p-1af3591a.js} +3 -3
- package/dist/components/{p-87079346.js.map → p-1af3591a.js.map} +1 -1
- package/dist/components/{p-ddb7aa4e.js → p-368c8700.js} +13 -13
- package/dist/components/{p-ddb7aa4e.js.map → p-368c8700.js.map} +1 -1
- package/dist/components/p-3cd7a66f.js +219 -0
- package/dist/components/p-3cd7a66f.js.map +1 -0
- package/dist/components/{p-09cdd71f.js → p-42ea6b74.js} +34 -688
- package/dist/components/p-42ea6b74.js.map +1 -0
- package/dist/components/{p-b7629769.js → p-44862b81.js} +4 -4
- package/dist/components/p-44862b81.js.map +1 -0
- package/dist/components/{p-8d45dbfe.js → p-4697bd56.js} +3 -2
- package/dist/components/p-4697bd56.js.map +1 -0
- package/dist/components/{p-5f594b35.js → p-51602221.js} +16 -2
- package/dist/components/p-51602221.js.map +1 -0
- package/dist/components/{p-4c3dc7e4.js → p-51a43ac6.js} +13 -10
- package/dist/components/p-51a43ac6.js.map +1 -0
- package/dist/components/{p-b2c31970.js → p-54161bad.js} +17 -11
- package/dist/components/p-54161bad.js.map +1 -0
- package/dist/components/{p-7372258e.js → p-6926e6f6.js} +2 -2
- package/dist/components/{p-7372258e.js.map → p-6926e6f6.js.map} +1 -1
- package/dist/components/{p-ac91582e.js → p-7426b20f.js} +2 -2
- package/dist/components/{p-ac91582e.js.map → p-7426b20f.js.map} +1 -1
- package/dist/components/{p-095c8285.js → p-95857e4f.js} +2 -2
- package/dist/components/{p-095c8285.js.map → p-95857e4f.js.map} +1 -1
- package/dist/components/p-a271e3be.js +723 -0
- package/dist/components/p-a271e3be.js.map +1 -0
- package/dist/components/{p-2030d84d.js → p-a45cacdf.js} +2 -2
- package/dist/components/{p-2030d84d.js.map → p-a45cacdf.js.map} +1 -1
- package/dist/{esm/timeline.animation-adf35ecb.js → components/p-a52cd849.js} +20 -2
- package/dist/components/p-a52cd849.js.map +1 -0
- package/dist/components/{p-dc5dad90.js → p-a823b8e9.js} +2 -2
- package/dist/components/{p-dc5dad90.js.map → p-a823b8e9.js.map} +1 -1
- package/dist/components/{p-0b015832.js → p-aaf0b787.js} +2 -2
- package/dist/components/{p-0b015832.js.map → p-aaf0b787.js.map} +1 -1
- package/dist/components/p-c7401a7d.js +90 -0
- package/dist/components/p-c7401a7d.js.map +1 -0
- package/dist/components/{p-57ae32bc.js → p-c8956181.js} +2 -2
- package/dist/components/{p-57ae32bc.js.map → p-c8956181.js.map} +1 -1
- package/dist/components/{p-2ad58e41.js → p-ee8944f3.js} +5 -5
- package/dist/components/{p-2ad58e41.js.map → p-ee8944f3.js.map} +1 -1
- package/dist/components/p-f4ae2239.js +88 -0
- package/dist/components/p-f4ae2239.js.map +1 -0
- package/dist/esm/collapse.animation-6e0b08df.js +219 -0
- package/dist/esm/collapse.animation-6e0b08df.js.map +1 -0
- package/dist/esm/{constants-a857c476.js → constants-69bafca2.js} +16 -2
- package/dist/esm/constants-69bafca2.js.map +1 -0
- package/dist/esm/fade.animation-9b939939.js +723 -0
- package/dist/esm/fade.animation-9b939939.js.map +1 -0
- package/dist/esm/{grow.animation-f7b26024.js → grow.animation-03fa5c19.js} +3 -2
- package/dist/esm/grow.animation-03fa5c19.js.map +1 -0
- package/dist/esm/index-a1936cd0.js +8 -0
- package/dist/esm/index.js +12 -8
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/esm/native.js +1 -1
- package/dist/esm/nv-accordion-item.entry.js +72 -38
- package/dist/esm/nv-accordion-item.entry.js.map +1 -1
- package/dist/esm/nv-accordion.entry.js +80 -66
- package/dist/esm/nv-accordion.entry.js.map +1 -1
- package/dist/esm/nv-alert.entry.js +12 -12
- package/dist/esm/nv-alert.entry.js.map +1 -1
- package/dist/esm/nv-avatar.entry.js +1 -1
- package/dist/esm/nv-badge_2.entry.js +11 -11
- package/dist/esm/nv-badge_2.entry.js.map +1 -1
- package/dist/esm/nv-button.entry.js +1 -1
- package/dist/esm/nv-calendar.entry.js +14 -10
- package/dist/esm/nv-calendar.entry.js.map +1 -1
- package/dist/esm/nv-datagrid.entry.js +1 -1
- package/dist/esm/nv-dialog.entry.js +1 -1
- package/dist/esm/nv-dialogfooter_2.entry.js +9 -6
- package/dist/esm/nv-dialogfooter_2.entry.js.map +1 -1
- package/dist/esm/nv-fieldcheckbox.entry.js +1 -1
- package/dist/esm/nv-fieldcheckbox.entry.js.map +1 -1
- package/dist/esm/nv-fieldmultiselect.entry.js +0 -30
- package/dist/esm/nv-fieldmultiselect.entry.js.map +1 -1
- package/dist/esm/nv-fieldnumber.entry.js +1 -1
- package/dist/esm/nv-fieldnumber.entry.js.map +1 -1
- package/dist/esm/nv-fieldslider.entry.js +24 -16
- package/dist/esm/nv-fieldslider.entry.js.map +1 -1
- package/dist/esm/nv-fieldtime.entry.js +1 -1
- package/dist/esm/nv-icon.entry.js +2 -2
- package/dist/esm/nv-icon.entry.js.map +1 -1
- package/dist/esm/nv-notification.entry.js +177 -0
- package/dist/esm/nv-notification.entry.js.map +1 -0
- package/dist/esm/nv-notificationcontainer.entry.js +39 -0
- package/dist/esm/nv-notificationcontainer.entry.js.map +1 -0
- package/dist/esm/nv-popover.entry.js +4 -4
- package/dist/esm/nv-row.entry.js +1 -1
- package/dist/esm/nv-stack.entry.js +1 -1
- package/dist/esm/nv-table.entry.js +2 -2
- package/dist/esm/nv-toggle.entry.js +2 -2
- package/dist/esm/nv-togglebutton.entry.js +1 -1
- package/dist/esm/nv-togglebuttongroup.entry.js +1 -1
- package/dist/esm/nv-tooltip.entry.js +1 -1
- package/dist/esm/slide.animation-f761030b.js +90 -0
- package/dist/esm/slide.animation-f761030b.js.map +1 -0
- package/dist/esm/{stylefire.es-74da334a.js → style-value-types.es-f5d10b79.js} +34 -688
- package/dist/esm/style-value-types.es-f5d10b79.js.map +1 -0
- package/dist/esm/timeline.animation-79215cd4.js +41 -0
- package/dist/esm/timeline.animation-79215cd4.js.map +1 -0
- package/dist/native/index.esm.js +1 -1
- package/dist/native/index.esm.js.map +1 -1
- package/dist/native/native.css +1 -1
- package/dist/native/native.esm.js +1 -1
- package/dist/native/native.esm.js.map +1 -1
- package/dist/native/{p-47901c83.entry.js → p-08322093.entry.js} +2 -2
- package/dist/native/p-0a99c6fb.entry.js +2 -0
- package/dist/native/p-0a99c6fb.entry.js.map +1 -0
- package/dist/native/p-1504e28b.entry.js +2 -0
- package/dist/native/p-1504e28b.entry.js.map +1 -0
- package/dist/native/p-19090193.entry.js +2 -0
- package/dist/native/p-19090193.entry.js.map +1 -0
- package/dist/native/{p-3a8f65a9.entry.js → p-224b1a01.entry.js} +2 -2
- package/dist/native/p-29df974e.entry.js +2 -0
- package/dist/native/p-29df974e.entry.js.map +1 -0
- package/dist/native/{p-29ee7b1c.entry.js → p-29f68e07.entry.js} +2 -2
- package/dist/native/p-29f68e07.entry.js.map +1 -0
- package/dist/native/p-3cd7a66f.js +2 -0
- package/dist/native/p-3cd7a66f.js.map +1 -0
- package/dist/native/p-42ea6b74.js +16 -0
- package/dist/native/p-42ea6b74.js.map +1 -0
- package/dist/native/p-45506c37.entry.js +2 -0
- package/dist/native/p-45506c37.entry.js.map +1 -0
- package/dist/native/p-4697bd56.js +2 -0
- package/dist/native/{p-8d45dbfe.js.map → p-4697bd56.js.map} +1 -1
- package/dist/native/p-47da1926.entry.js +2 -0
- package/dist/native/p-47da1926.entry.js.map +1 -0
- package/dist/native/{p-e7a929e7.entry.js → p-48774d0c.entry.js} +2 -2
- package/dist/native/p-4ec61dec.entry.js +2 -0
- package/dist/native/p-4ec61dec.entry.js.map +1 -0
- package/dist/native/p-51602221.js +2 -0
- package/dist/native/p-51602221.js.map +1 -0
- package/dist/native/{p-ab1e1a96.entry.js → p-5c697133.entry.js} +2 -2
- package/dist/native/p-5c697133.entry.js.map +1 -0
- package/dist/native/{p-c3ad7617.entry.js → p-6c7a9a21.entry.js} +2 -2
- package/dist/native/p-6cb6679b.entry.js +2 -0
- package/dist/native/{p-62aa0531.entry.js → p-6d13a851.entry.js} +2 -2
- package/dist/native/p-74b129e9.entry.js +2 -0
- package/dist/native/{p-48cf2457.entry.js → p-758e0d4a.entry.js} +2 -2
- package/dist/native/p-9a46baa9.entry.js +2 -0
- package/dist/native/p-9a46baa9.entry.js.map +1 -0
- package/dist/native/p-a271e3be.js +2 -0
- package/dist/native/p-a271e3be.js.map +1 -0
- package/dist/native/p-a52cd849.js +2 -0
- package/dist/native/p-a52cd849.js.map +1 -0
- package/dist/native/p-b32d0a5a.entry.js +2 -0
- package/dist/native/p-b32d0a5a.entry.js.map +1 -0
- package/dist/native/{p-bcff76ab.entry.js → p-c66565f8.entry.js} +2 -2
- package/dist/native/p-c7401a7d.js +2 -0
- package/dist/native/p-c7401a7d.js.map +1 -0
- package/dist/native/p-c7b7ffaf.entry.js +2 -0
- package/dist/native/p-c7b7ffaf.entry.js.map +1 -0
- package/dist/native/{p-a63929db.entry.js → p-d2c9247b.entry.js} +3 -3
- package/dist/native/{p-f033c4ce.entry.js → p-d882f417.entry.js} +2 -2
- package/dist/native/{p-2d647761.entry.js → p-e2c99ce2.entry.js} +2 -2
- package/dist/native/p-f5120223.entry.js +2 -0
- package/dist/native/p-f5120223.entry.js.map +1 -0
- package/dist/native/{p-43071c3b.entry.js → p-fa177c39.entry.js} +2 -2
- package/dist/types/animations/collapse.animation.d.ts +10 -2
- package/dist/types/animations/index.d.ts +1 -0
- package/dist/types/animations/slide.animation.d.ts +22 -0
- package/dist/types/animations/timeline.animation.d.ts +17 -1
- package/dist/types/components/nv-accordion/nv-accordion.d.ts +5 -7
- package/dist/types/components/nv-accordion-item/nv-accordion-item.d.ts +23 -8
- package/dist/types/components/nv-alert/nv-alert.d.ts +1 -1
- package/dist/types/components/nv-badge/nv-badge.d.ts +1 -1
- package/dist/types/components/nv-calendar/nv-calendar.d.ts +4 -0
- package/dist/types/components/nv-calendar/partials/calendar-actions.d.ts +4 -0
- package/dist/types/components/nv-dialogfooter/nv-dialogfooter.d.ts +8 -4
- package/dist/types/components/nv-fieldslider/nv-fieldslider.d.ts +3 -2
- package/dist/types/components/nv-fieldslider/partials/field-input.d.ts +7 -3
- package/dist/types/components/nv-icon/nv-icons.d.ts +1 -1
- package/dist/types/components/nv-notification/nv-notification.d.ts +93 -0
- package/dist/types/components/nv-notification/nv-notification.docs.d.ts +4 -0
- package/dist/types/components/nv-notificationcontainer/nv-notificationcontainer.d.ts +19 -0
- package/dist/types/components/nv-notificationcontainer/nv-notificationcontainer.docs.d.ts +4 -0
- package/dist/types/components.d.ts +199 -9
- package/dist/types/nova-docs.d.ts +6 -0
- package/dist/types/utils/constants.d.ts +12 -0
- package/dist/vscode-data.json +120 -6
- package/hydrate/index.js +800 -274
- package/hydrate/index.mjs +800 -274
- package/package.json +9 -1
- package/readme.md +169 -42
- package/dist/cjs/collapse.animation-a129dc3f.js +0 -86
- package/dist/cjs/collapse.animation-a129dc3f.js.map +0 -1
- package/dist/cjs/constants-aac59496.js.map +0 -1
- package/dist/cjs/fade.animation-644b5c4d.js +0 -70
- package/dist/cjs/fade.animation-644b5c4d.js.map +0 -1
- package/dist/cjs/grow.animation-6d003803.js.map +0 -1
- package/dist/cjs/stylefire.es-717e022a.js.map +0 -1
- package/dist/cjs/timeline.animation-155e8839.js.map +0 -1
- package/dist/components/p-09cdd71f.js.map +0 -1
- package/dist/components/p-1172e9bb.js.map +0 -1
- package/dist/components/p-15aeab4d.js +0 -23
- package/dist/components/p-15aeab4d.js.map +0 -1
- package/dist/components/p-1cbacdba.js +0 -68
- package/dist/components/p-1cbacdba.js.map +0 -1
- package/dist/components/p-4c3dc7e4.js.map +0 -1
- package/dist/components/p-5f594b35.js.map +0 -1
- package/dist/components/p-84f4b071.js.map +0 -1
- package/dist/components/p-8d45dbfe.js.map +0 -1
- package/dist/components/p-9a263d0e.js +0 -84
- package/dist/components/p-9a263d0e.js.map +0 -1
- package/dist/components/p-b2c31970.js.map +0 -1
- package/dist/components/p-b3035205.js +0 -88
- package/dist/components/p-b3035205.js.map +0 -1
- package/dist/components/p-b7629769.js.map +0 -1
- package/dist/esm/collapse.animation-16e3af45.js +0 -84
- package/dist/esm/collapse.animation-16e3af45.js.map +0 -1
- package/dist/esm/constants-a857c476.js.map +0 -1
- package/dist/esm/fade.animation-71e8e34c.js +0 -68
- package/dist/esm/fade.animation-71e8e34c.js.map +0 -1
- package/dist/esm/grow.animation-f7b26024.js.map +0 -1
- package/dist/esm/stylefire.es-74da334a.js.map +0 -1
- package/dist/esm/timeline.animation-adf35ecb.js.map +0 -1
- package/dist/native/p-09cdd71f.js +0 -16
- package/dist/native/p-09cdd71f.js.map +0 -1
- package/dist/native/p-0da8f0d1.entry.js +0 -2
- package/dist/native/p-0da8f0d1.entry.js.map +0 -1
- package/dist/native/p-15aeab4d.js +0 -2
- package/dist/native/p-15aeab4d.js.map +0 -1
- package/dist/native/p-1cbacdba.js +0 -2
- package/dist/native/p-1cbacdba.js.map +0 -1
- package/dist/native/p-29ee7b1c.entry.js.map +0 -1
- package/dist/native/p-38af3aaf.entry.js +0 -2
- package/dist/native/p-38af3aaf.entry.js.map +0 -1
- package/dist/native/p-3fcaac6d.entry.js +0 -2
- package/dist/native/p-3fcaac6d.entry.js.map +0 -1
- package/dist/native/p-5d352456.entry.js +0 -2
- package/dist/native/p-5f594b35.js +0 -2
- package/dist/native/p-5f594b35.js.map +0 -1
- package/dist/native/p-63fea160.entry.js +0 -2
- package/dist/native/p-63fea160.entry.js.map +0 -1
- package/dist/native/p-67d861e2.entry.js +0 -2
- package/dist/native/p-67d861e2.entry.js.map +0 -1
- package/dist/native/p-7703c736.entry.js +0 -2
- package/dist/native/p-7703c736.entry.js.map +0 -1
- package/dist/native/p-8d45dbfe.js +0 -2
- package/dist/native/p-9a263d0e.js +0 -2
- package/dist/native/p-9a263d0e.js.map +0 -1
- package/dist/native/p-9e0fe7e8.entry.js +0 -2
- package/dist/native/p-9e0fe7e8.entry.js.map +0 -1
- package/dist/native/p-ab1e1a96.entry.js.map +0 -1
- package/dist/native/p-ac5496e7.entry.js +0 -2
- package/dist/native/p-d88c416f.entry.js +0 -2
- package/dist/native/p-d88c416f.entry.js.map +0 -1
- package/dist/native/p-e603c6ed.entry.js +0 -2
- package/dist/native/p-e603c6ed.entry.js.map +0 -1
- /package/dist/native/{p-47901c83.entry.js.map → p-08322093.entry.js.map} +0 -0
- /package/dist/native/{p-3a8f65a9.entry.js.map → p-224b1a01.entry.js.map} +0 -0
- /package/dist/native/{p-e7a929e7.entry.js.map → p-48774d0c.entry.js.map} +0 -0
- /package/dist/native/{p-c3ad7617.entry.js.map → p-6c7a9a21.entry.js.map} +0 -0
- /package/dist/native/{p-5d352456.entry.js.map → p-6cb6679b.entry.js.map} +0 -0
- /package/dist/native/{p-62aa0531.entry.js.map → p-6d13a851.entry.js.map} +0 -0
- /package/dist/native/{p-ac5496e7.entry.js.map → p-74b129e9.entry.js.map} +0 -0
- /package/dist/native/{p-48cf2457.entry.js.map → p-758e0d4a.entry.js.map} +0 -0
- /package/dist/native/{p-bcff76ab.entry.js.map → p-c66565f8.entry.js.map} +0 -0
- /package/dist/native/{p-a63929db.entry.js.map → p-d2c9247b.entry.js.map} +0 -0
- /package/dist/native/{p-f033c4ce.entry.js.map → p-d882f417.entry.js.map} +0 -0
- /package/dist/native/{p-2d647761.entry.js.map → p-e2c99ce2.entry.js.map} +0 -0
- /package/dist/native/{p-43071c3b.entry.js.map → p-fa177c39.entry.js.map} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["nvNotificationCss","NvNotificationStyle0","NvNotification","constructor","hostRef","this","uid","uuidv4","feedback","emphasis","dismissible","hidden","initiallyHidden","iconByFeedback","FeedbackColors","Warning","Information","Success","Error","Neutral","roleByFeedback","dismiss","dismissAnimation","show","showAnimation","getDefaultIcon","_a","getAriaRole","getAriaLive","getHeadingId","heading","getMessageId","message","setFadeIn","useFade","container","expand","useCollapse","el","duration","overflow","slideY","setSlideY","useSlide","parallel","from","to","start","hiddenChanged","emit","getSlideDestination","pos","NotificationPosition","TopRight","BottomRight","axis","TopLeft","BottomLeft","TopCenter","BottomCenter","position","closest","getAttribute","destination","fadeOut","slideX","setSlideReset","collapse","slide","componentWillLoad","headingSlot","querySelector","messageSlot","actionsSlot","render","h","Host","key","role","_b","tabindex","ref","type","onClick","bind","name","size","_c","icon","id"],"sources":["src/components/nv-notification/styles/nv-notification.scss?tag=nv-notification","src/components/nv-notification/nv-notification.tsx"],"sourcesContent":["@use \"sass:map\";\n@use \"./mixins\" as *;\n@import \"../../../styles/focus-ring\";\n\nnv-notification {\n @include root-styles();\n\n [data-scope=\"container\"] {\n @include container-styles();\n\n [data-scope=\"icon\"] {\n @include icon-styles();\n }\n\n [data-scope=\"dismiss\"] {\n @include dismiss-btn-styles();\n }\n\n [data-scope=\"content\"] {\n @include content-styles();\n\n [data-scope=\"heading\"] {\n @include header-styles();\n }\n\n [data-scope=\"message\"] {\n @include message-styles();\n }\n\n [data-scope=\"actions\"] {\n @include actions-styles();\n }\n }\n }\n\n @each $feedback in $feedback-variants {\n &[feedback=\"#{$feedback}\"] {\n [data-scope=\"container\"] {\n @include feedback-color($feedback);\n\n [data-scope=\"icon\"] {\n @include icon-color($feedback);\n }\n }\n\n & > [data-scope=\"close\"] {\n @include focus-ring(map.get($border-color-map, $feedback));\n }\n }\n }\n\n @each $emphasis in $emphasis-variants {\n &[emphasis=\"#{$emphasis}\"] {\n [data-scope=\"container\"] {\n @include emphasis-styles($emphasis);\n }\n }\n }\n}","import {\n Component,\n Host,\n h,\n Prop,\n Method,\n Element,\n Event,\n EventEmitter,\n} from '@stencil/core';\nimport { v4 as uuidv4 } from 'uuid';\n\nimport {\n FeedbackColors,\n NotificationEmphasis,\n NotificationPosition,\n} from '../../utils/constants';\nimport { type IconName } from '../nv-icon/nv-icons';\nimport { useCollapse, useFade, useSlide, parallel } from '../../animations';\n\ntype AriaRole = 'status' | 'alert';\ntype AriaLive = 'polite' | 'assertive';\n\n/**\n * @slot heading - Use this slot to insert HTML as the notification title.\n * @slot content - Use this slot to insert HTML as the notification message.\n * @slot actions - Use this slot for custom actions.\n */\n@Component({\n tag: 'nv-notification',\n styleUrl: 'styles/nv-notification.scss',\n shadow: false,\n})\nexport class NvNotification {\n @Element() el: HTMLNvNotificationElement;\n private container: HTMLElement;\n private headingSlot: HTMLElement;\n private messageSlot: HTMLElement;\n private actionsSlot: HTMLElement;\n\n /****************************************************************************/\n //#region PROPERTIES\n\n /**\n * Set a unique ID for the notification. Used for aria attributes and managing\n * multiple notifications.\n */\n @Prop({ reflect: true })\n readonly uid: string = uuidv4();\n\n /**\n * Specifies the notification type which determines the color and default icon.\n */\n @Prop({ reflect: true })\n readonly feedback: `${FeedbackColors}` = 'information';\n\n /**\n * Adjusts the emphasis to make the notification more or less visually\n * prominent to users. Use this to draw attention to important actions or\n * reduce focus on less critical ones\n */\n @Prop({ reflect: true })\n readonly emphasis: `${NotificationEmphasis}` = 'medium';\n\n /**\n * Short and concise text for the notification title.\n */\n @Prop({ reflect: true })\n readonly heading: string;\n\n /**\n * Main content for the notification. For more complex content, use the\n * content slot instead.\n */\n @Prop({ reflect: true })\n readonly message: string;\n\n /**\n * Icon associated with the notification, defaults vary based on the feedback\n * type.\n */\n @Prop({ reflect: true })\n readonly icon: string;\n\n /**\n * Allows the notification to be dismissed via a close button (x). The\n * notification is not dismissible unless explicitly enabled.\n */\n @Prop({ reflect: true })\n readonly dismissible: boolean = false;\n\n /**\n * Controls the visibility of the notification.\n */\n @Prop({ reflect: true, mutable: true })\n hidden: boolean = false; // eslint-disable-line @stencil-community/reserved-member-names\n\n /**\n * When true, the notification will be hidden initially, but internal changes\n * will not be in a controlled state. Good for animating the notification in.\n */\n @Prop({ reflect: true })\n readonly initiallyHidden: boolean = false;\n\n //#endregion PROPERTIES\n /****************************************************************************/\n //#region METHODS\n\n /**\n * Dismisses the notification with an animation, after the animation is\n * complete, the hiddenChanged event will be emitted with the value of true,\n * and the hidden prop will be set to true.\n */\n @Method()\n async dismiss() {\n await this.dismissAnimation();\n }\n\n /**\n * Sets the hidden prop to false, and shows the notification with an\n * animation, after the animation is complete, the hiddenChanged event will be\n * emitted with the value of false.\n */\n @Method()\n async show() {\n await this.showAnimation();\n }\n\n //#endregion METHODS\n /****************************************************************************/\n //#region EVENTS\n\n /**\n * Emits when the 'hidden' prop changes, reflecting a change in visibility.\n * Passes hidden value to the detail.\n * @bind hidden\n */\n @Event()\n hiddenChanged: EventEmitter<boolean>;\n\n //#endregion EVENTS\n /****************************************************************************/\n //#region INTERNAL\n\n private iconByFeedback: Record<FeedbackColors, IconName> = {\n [FeedbackColors.Warning]: 'alert-circle',\n [FeedbackColors.Information]: 'info-circle',\n [FeedbackColors.Success]: 'circle-check',\n [FeedbackColors.Error]: 'alert-triangle',\n [FeedbackColors.Neutral]: 'help',\n };\n\n private roleByFeedback: Record<FeedbackColors, AriaRole> = {\n [FeedbackColors.Error]: 'alert',\n [FeedbackColors.Warning]: 'alert',\n [FeedbackColors.Information]: 'status',\n [FeedbackColors.Success]: 'status',\n [FeedbackColors.Neutral]: 'status',\n };\n\n private getDefaultIcon(): IconName {\n return this.iconByFeedback[this.feedback] ?? 'info-circle';\n }\n\n private getAriaRole(): AriaRole {\n return this.roleByFeedback[this.feedback] ?? 'status';\n }\n\n private getAriaLive(): AriaLive {\n return this.getAriaRole() === 'alert' ? 'assertive' : 'polite';\n }\n\n private getHeadingId(): string | null {\n return this.heading ? `nv-notification-${this.uid}-heading` : null;\n }\n\n private getMessageId(): string | null {\n return this.message ? `nv-notification-${this.uid}-message` : null;\n }\n\n private async showAnimation() {\n this.hidden = false;\n\n const { setFadeIn } = useFade(this.container);\n const { expand } = useCollapse(this.el, {\n duration: 300,\n overflow: 'visible',\n });\n const { slideY, setSlideY } = useSlide(this.container, {\n duration: 300,\n });\n\n setSlideY(-100);\n setFadeIn();\n await parallel(slideY({ from: -100, to: 0 }), expand).start();\n\n this.hiddenChanged.emit(false);\n }\n\n private getSlideDestination(pos?: NotificationPosition): {\n /** The axis to slide. */\n axis: 'x' | 'y';\n /** The destination value. */\n to: number;\n } {\n switch (pos) {\n case NotificationPosition.TopRight:\n case NotificationPosition.BottomRight:\n return { axis: 'x', to: 100 }; // right\n case NotificationPosition.TopLeft:\n case NotificationPosition.BottomLeft:\n return { axis: 'x', to: -100 }; // left\n case NotificationPosition.TopCenter:\n return { axis: 'y', to: -100 }; // up\n case NotificationPosition.BottomCenter:\n return { axis: 'y', to: 100 }; // down\n default:\n return { axis: 'x', to: 100 }; // fallback\n }\n }\n\n private async dismissAnimation() {\n const position = this.el\n .closest('nv-notificationcontainer')\n ?.getAttribute('position') as NotificationPosition | undefined;\n\n const destination = this.getSlideDestination(position);\n\n const { fadeOut } = useFade(this.container, { duration: 300 });\n const { slideX, slideY, setSlideReset } = useSlide(this.container, {\n duration: 500,\n });\n const { collapse } = useCollapse(this.el, {\n duration: 500,\n overflow: 'visible',\n });\n const slide =\n destination.axis === 'x'\n ? slideX({ from: 0, to: destination.to })\n : slideY({ from: 0, to: destination.to });\n\n setSlideReset();\n await parallel(fadeOut, slide, collapse).start();\n\n this.hidden = true;\n this.hiddenChanged.emit(true);\n }\n\n //#endregion INTERNAL\n /****************************************************************************/\n //#region LIFECYCLE\n\n componentWillLoad() {\n this.headingSlot = this.el.querySelector('[slot=\"heading\"]');\n this.messageSlot = this.el.querySelector('[slot=\"content\"]');\n this.actionsSlot = this.el.querySelector('[slot=\"actions\"]');\n\n if (this.initiallyHidden) this.hidden = true;\n }\n\n //#endregion LIFECYCLE\n /****************************************************************************/\n //#region RENDER\n\n render() {\n return (\n <Host\n role={this.getAriaRole()}\n aria-live={this.getAriaLive()}\n aria-atomic\n aria-labelledby={this.getHeadingId() ?? null}\n aria-describedby={this.getMessageId() ?? null}\n tabindex=\"-1\"\n >\n <div data-scope=\"container\" ref={el => (this.container = el)}>\n {this.dismissible && (\n <button\n data-scope=\"dismiss\"\n type=\"button\"\n onClick={this.dismiss.bind(this)}\n >\n <nv-icon name=\"x\" size=\"sm\" />\n </button>\n )}\n\n <nv-icon\n name={this.icon ?? this.getDefaultIcon()}\n size=\"md\"\n data-scope=\"icon\"\n ></nv-icon>\n\n <div data-scope=\"content\">\n {(this.heading || this.headingSlot) && (\n <p id={this.getHeadingId()} data-scope=\"heading\">\n <slot name=\"heading\">{this.heading}</slot>\n </p>\n )}\n {(this.message || this.messageSlot) && (\n <p id={this.getMessageId()} data-scope=\"message\">\n <slot name=\"content\">{this.message}</slot>\n </p>\n )}\n\n {this.actionsSlot && (\n <div data-scope=\"actions\">\n <slot name=\"actions\"></slot>\n </div>\n )}\n </div>\n </div>\n </Host>\n );\n }\n // #endregion RENDER\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{r as n,c as e,h as r,H as i,g as o}from"./p-d0a33e64.js";import{v as t}from"./p-f5ff676c.js";const a='/* TODO: integrate this logic in the proper structure */\nnv-fieldslider .slider-container .track-container:has(.thumb:hover) .track-range {\n background: var(--components-slider-track-filled-hover);\n}\nnv-fieldslider .slider-container .track-container:has(.thumb:hover) .thumb {\n border-color: var(--components-slider-track-filled-hover);\n}\nnv-fieldslider .slider-container .track-container:has(.thumb:focus) .track-range {\n background: var(--components-slider-track-filled-focus);\n}\nnv-fieldslider .slider-container .track-container:has(.thumb:focus) .thumb {\n border-color: var(--components-slider-track-filled-focus);\n}\nnv-fieldslider[error] .slider-container .track-container .track .track-range {\n background: var(--components-slider-track-filled-error);\n}\nnv-fieldslider[error] .slider-container .track-container .track .thumb {\n border-color: var(--components-slider-track-filled-error);\n}\nnv-fieldslider[error] .slider-container .track-container .track .thumb:hover {\n border-color: var(--components-slider-track-filled-error);\n outline: calc(var(--focus-outline-stroke) * 1) solid var(--components-slider-track-filled-error);\n outline-offset: calc(var(--focus-outline-offset) * 1);\n background-color: var(--components-slider-handler-background-error);\n}\nnv-fieldslider[error] .slider-container .track-container .track .thumb:focus {\n border-color: var(--components-slider-track-filled-error);\n outline: calc(var(--focus-outline-stroke) * 1) solid var(--components-slider-track-filled-error);\n outline-offset: calc(var(--focus-outline-offset) * 1);\n background-color: var(--components-slider-track-filled-error);\n}\nnv-fieldslider[error] .slider-container .track-container:has(.thumb:hover) .track-range {\n background: var(--components-slider-track-filled-error);\n}\nnv-fieldslider[error] .slider-container .track-container:has(.thumb:hover) .thumb {\n border-color: var(--components-slider-track-filled-error);\n}\n\nnv-fieldnumber {\n --nv-field-border-default: var(--components-form-field-border-default);\n --nv-field-border-hover: var(--components-form-field-border-hover);\n --nv-field-border-focus: var(--components-form-field-border-focus);\n --nv-field-border-disabled: var(--components-form-field-border-default);\n --nv-field-border-readonly: var(--components-form-field-border-default);\n --nv-field-focus-box-shadow: var(--color-focus-brand);\n --nv-field-background: var(--components-form-field-background-default);\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: var(--form-gap-y);\n box-sizing: border-box;\n max-width: 480px;\n}\nnv-fieldnumber[fluid]:not([fluid=false]) {\n max-width: unset;\n}\nnv-fieldnumber[readonly]:not([readonly=false]) {\n --nv-field-border-default: var(--components-form-field-border-readonly);\n --nv-field-border-hover: var(--nv-field-border-default);\n --nv-field-border-focus: var(--components-form-field-border-focus);\n --nv-field-border-disabled: var(--nv-field-border-default);\n --nv-field-border-readonly: var(--nv-field-border-default);\n --nv-field-background: var(--components-form-field-background-readonly);\n}\nnv-fieldnumber[error]:not([error=false]) {\n --nv-field-border-default: var(--components-form-field-border-error);\n --nv-field-border-hover: var(--nv-field-border-default);\n --nv-field-border-focus: var(--nv-field-border-default);\n --nv-field-border-disabled: var(--nv-field-border-default);\n --nv-field-border-readonly: var(--nv-field-border-default);\n --nv-field-focus-box-shadow: var(--color-focus-destructive-in-field);\n}\nnv-fieldnumber[success]:not([success=false]) {\n --nv-field-border-default: var(--components-form-field-border-success);\n --nv-field-border-hover: var(--nv-field-border-default);\n --nv-field-border-focus: var(--nv-field-border-default);\n --nv-field-border-disabled: var(--nv-field-border-default);\n --nv-field-border-readonly: var(--nv-field-border-default);\n --nv-field-focus-box-shadow: var(--color-focus-success);\n}\nnv-fieldnumber[required]:not([required=false]) label::after {\n content: "*";\n color: var(--components-form-text-required);\n font-weight: 700;\n}\nnv-fieldnumber label {\n display: flex;\n align-items: center;\n gap: var(--form-label-gap);\n align-self: stretch;\n color: var(--components-form-text-label-default);\n font-family: "TT Norms Pro", sans-serif;\n font-size: var(--form-label-font-size);\n font-style: normal;\n font-weight: 500;\n line-height: var(--form-label-line-height);\n}\nnv-fieldnumber .input-wrapper {\n display: flex;\n flex-wrap: wrap;\n gap: var(--form-gap-x);\n align-items: stretch;\n align-self: stretch;\n}\nnv-fieldnumber .input-wrapper .input-container {\n display: flex;\n flex-grow: 1;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n border-radius: var(--form-field-radius);\n border-width: 1px;\n border-style: solid;\n border-color: var(--nv-field-border-default);\n opacity: var(--components-form-opacity-default, 1);\n background: var(--nv-field-background);\n transition: all 150ms ease-out;\n container-type: inline-size;\n container-name: field-number-input-container;\n overflow: hidden;\n position: relative;\n}\nnv-fieldnumber .input-wrapper .input-container:hover {\n border-color: var(--nv-field-border-hover);\n}\nnv-fieldnumber .input-wrapper .input-container:focus-within, nv-fieldnumber .input-wrapper .input-container:focus-within:hover, nv-fieldnumber .input-wrapper .input-container:focus, nv-fieldnumber .input-wrapper .input-container:focus:hover {\n border-color: var(--nv-field-border-focus);\n box-shadow: 0px 0px 0px var(--focus-field-stroke) var(--nv-field-focus-box-shadow);\n}\nnv-fieldnumber .input-wrapper .input-container:has(input:read-only) {\n opacity: 0.5;\n background-color: var(--components-form-field-background-readonly);\n border-color: var(--nv-field-border-readonly);\n}\nnv-fieldnumber .input-wrapper .input-container:has(input:disabled) {\n opacity: 0.5;\n background-color: var(--components-form-field-background-disabled);\n border-color: var(--nv-field-border-disabled);\n}\nnv-fieldnumber .input-wrapper .input-container input {\n display: flex;\n align-items: center;\n flex: 1 0 0;\n overflow: hidden;\n background-color: transparent;\n color: var(--components-form-field-content-text);\n padding: var(--form-field-padding-y) var(--form-field-padding-x);\n font-size: var(--form-field-font-size);\n font-style: normal;\n font-weight: 500;\n line-height: var(--form-field-line-height);\n width: 100%;\n /* Hide Edge built-in password reveal and clear icons */\n width: 100%;\n appearance: textfield;\n}\nnv-fieldnumber .input-wrapper .input-container input:focus {\n outline: none;\n}\nnv-fieldnumber .input-wrapper .input-container input::placeholder {\n overflow: hidden;\n color: var(--components-form-field-content-placeholder);\n text-overflow: ellipsis;\n font-family: "TT Norms Pro", sans-serif;\n font-size: var(--form-field-font-size);\n font-style: normal;\n font-weight: 400;\n line-height: var(--form-field-line-height);\n}\nnv-fieldnumber .input-wrapper .input-container input[type=password]::-ms-clear, nv-fieldnumber .input-wrapper .input-container input[type=password]::-ms-reveal {\n display: none;\n width: 0;\n height: 0;\n}\nnv-fieldnumber .input-wrapper .input-container input::-webkit-inner-spin-button, nv-fieldnumber .input-wrapper .input-container input::-webkit-outer-spin-button {\n appearance: none;\n margin: 0;\n}\nnv-fieldnumber .input-wrapper .input-container nv-icon.validation {\n color: var(--nv-field-border-default);\n margin-right: var(--form-field-gap);\n}\nnv-fieldnumber .input-wrapper .input-container > nv-iconbutton {\n border: 0px;\n border-radius: 0px;\n}\nnv-fieldnumber .input-wrapper .input-container > nv-iconbutton:focus-visible {\n border-radius: var(--button-md-border-radius);\n outline-offset: -3px;\n}\nnv-fieldnumber .input-wrapper .input-container > nv-iconbutton:last-of-type {\n border-top-right-radius: var(--form-field-radius);\n border-bottom-right-radius: var(--form-field-radius);\n}\nnv-fieldnumber .input-wrapper .input-container .stepper {\n display: flex;\n border-left: var(--notification-border-width-low-emphasis) solid var(--components-form-field-border-readonly);\n}\nnv-fieldnumber .input-wrapper .input-container .stepper > nv-iconbutton {\n border: 0px;\n border-radius: 0px;\n border-radius: 0px;\n}\nnv-fieldnumber .input-wrapper .input-container .stepper > nv-iconbutton:focus-visible {\n border-radius: var(--button-md-border-radius);\n outline-offset: -3px;\n}\nnv-fieldnumber .input-wrapper .input-container .stepper > nv-iconbutton:last-of-type {\n border-top-right-radius: var(--form-field-radius);\n border-bottom-right-radius: var(--form-field-radius);\n}\n@container field-number-input-container (width < 150px) {\n nv-fieldnumber .input-wrapper .input-container .stepper-spacer {\n display: none;\n }\n nv-fieldnumber .input-wrapper .input-container .stepper {\n display: none;\n }\n}\nnv-fieldnumber .description {\n display: flex;\n align-items: center;\n align-self: stretch;\n gap: var(--spacing-1);\n color: var(--components-form-text-description-default);\n font-family: "TT Norms Pro", sans-serif;\n font-size: var(--form-description-font-size);\n font-style: normal;\n line-height: var(--form-description-line-height);\n}\nnv-fieldnumber .error-description {\n display: flex;\n align-items: center;\n align-self: stretch;\n gap: var(--spacing-1);\n color: var(--components-form-text-description-default);\n font-family: "TT Norms Pro", sans-serif;\n font-size: var(--form-description-font-size);\n font-style: normal;\n line-height: var(--form-description-line-height);\n color: var(--components-form-text-description-error);\n}';const d=a;const l=class{constructor(r){n(this,r);this.valueChanged=e(this,"valueChanged",7);this.inputId=t();this.disabled=false;this.readonly=false;this.required=false;this.error=false;this.success=false;this.step=1;this.autofocus=false;this.fluid=false;this.handleInput=n=>{const e=n.target;this.value=Number(e.value)};this.handleInputContainerClick=()=>{this.inputElement.focus()};this.handlePlus=()=>{this.inputElement.stepUp();this.value=Number(this.inputElement.value)};this.handleMinus=()=>{this.inputElement.stepDown();this.value=Number(this.inputElement.value)};this.preventSelection=n=>{n.preventDefault()};this.isMinValueReached=()=>this.min!==undefined&&this.value<=this.min;this.isMaxValueReached=()=>this.max!==undefined&&this.value>=this.max}watchValueHandler(n){this.valueChanged.emit(n)}componentWillRender(){if(this.message){this.description=this.message}if(this.validation){this.errorDescription=this.validation;this.error=true}}render(){return r(i,{key:"1bbe4506220df2ebb5723e916edcf49b3c0295e4"},(this.label||this.el.querySelector('[slot="label"]'))&&r("label",{key:"56ed85a58e669e9c6aec04ed9ea7bc9664c478f8",htmlFor:this.inputId},r("slot",{key:"b4cf04b6bca34f0ff158fd9e7b14c56df7ea3e8a",name:"label"},this.label)),r("div",{key:"9c9432645591952acff5b1f73c5be8d8f1dae7fb",class:"input-wrapper"},r("slot",{key:"05bacf384b22fce12a66109864ec95fab403f8d7",name:"before-input"}),r("div",{key:"66f0c59c38b7309834ba22bbd767e94a04964781",class:"input-container",onClick:this.handleInputContainerClick},r("slot",{key:"7e2a7c766484b8c4c4caabab311ea635f95eb4fd",name:"leading-input"}),r("input",{key:"808f4f16b3a73d0b07efa7cff18dd5dd3f94bda4",id:this.inputId,ref:n=>this.inputElement=n,placeholder:this.placeholder,name:this.name,type:"number",autofocus:this.autofocus,required:this.required,max:this.max,min:this.min,step:this.step,value:this.value,disabled:this.disabled,readOnly:this.readonly,onInput:this.handleInput}),r("slot",{key:"65a7f356f2a9f650df9e78f53b98b43c7e179802",name:"trailing-input"}),this.error&&r("nv-icon",{key:"5eed73e177092188387abd35ccab6085a1bdb2cf",name:"alert-circle",class:"validation",size:"md"}),this.success&&r("nv-icon",{key:"74edadb953f9668e49a1b3ecd328bfd2999065ea",name:"circle-check",class:"validation",size:"md"}),r("div",{key:"e886fe1df175d5c4dcd9a4704ad47820e0af2474",class:"stepper"},r("nv-iconbutton",{key:"ff6247b57693f2a45c26e1eae67c9d86c473e0e3",size:"md",name:"minus",emphasis:"lower",onClick:this.handleMinus,disabled:this.isMinValueReached(),onMouseDown:this.preventSelection,tabindex:"-1"}),r("nv-iconbutton",{key:"aa12c105d159e08e874bdd37f56ab1837ba01c4f",size:"md",name:"plus",emphasis:"lower",onClick:this.handlePlus,disabled:this.isMaxValueReached(),onMouseDown:this.preventSelection,tabindex:"-1"}))),r("slot",{key:"c485ac2e1ca388b6e0998bdb1c5ca5876cd9e392",name:"after-input"})),(this.description||this.el.querySelector('[slot="description"]'))&&r("div",{key:"88d80f2f5b0061b0f8dab4bcc88bf2d196427800",class:"description"},r("slot",{key:"0380af6af9986d000ad58328e6c4b8250f86c22a",name:"description"},this.description)),(this.errorDescription||this.el.querySelector('[slot="error-description"]'))&&r("div",{key:"a2233d218f58376b6c7958efabe96a3e08c6e1f6",hidden:!this.error,class:"error-description"},r("slot",{key:"d90bc8abdcecc9711b271472a8da60b207aa04af",name:"error-description"},this.errorDescription)))}static get formAssociated(){return true}get el(){return o(this)}static get watchers(){return{value:["watchValueHandler"]}}};l.style=d;export{l as nv_fieldnumber};
|
|
2
|
-
//# sourceMappingURL=p-
|
|
1
|
+
import{r as n,c as e,h as r,H as i,g as o}from"./p-d0a33e64.js";import{v as t}from"./p-f5ff676c.js";const a='/* TODO: integrate this logic in the proper structure */\nnv-fieldslider .slider-container .track-container:has(.thumb:hover) .track-range {\n background: var(--components-slider-track-filled-hover);\n}\nnv-fieldslider .slider-container .track-container:has(.thumb:hover) .thumb {\n border-color: var(--components-slider-track-filled-hover);\n}\nnv-fieldslider .slider-container .track-container:has(.thumb:focus) .track-range {\n background: var(--components-slider-track-filled-focus);\n}\nnv-fieldslider .slider-container .track-container:has(.thumb:focus) .thumb {\n border-color: var(--components-slider-track-filled-focus);\n}\nnv-fieldslider[error] .slider-container .track-container .track .track-range {\n background: var(--components-slider-track-filled-error);\n}\nnv-fieldslider[error] .slider-container .track-container .track .thumb {\n border-color: var(--components-slider-track-filled-error);\n}\nnv-fieldslider[error] .slider-container .track-container .track .thumb:hover {\n border-color: var(--components-slider-track-filled-error);\n outline: calc(var(--focus-outline-stroke) * 1) solid var(--components-slider-track-filled-error);\n outline-offset: calc(var(--focus-outline-offset) * 1);\n background-color: var(--components-slider-handler-background-error);\n}\nnv-fieldslider[error] .slider-container .track-container .track .thumb:focus {\n border-color: var(--components-slider-track-filled-error);\n outline: calc(var(--focus-outline-stroke) * 1) solid var(--components-slider-track-filled-error);\n outline-offset: calc(var(--focus-outline-offset) * 1);\n background-color: var(--components-slider-track-filled-error);\n}\nnv-fieldslider[error] .slider-container .track-container:has(.thumb:hover) .track-range {\n background: var(--components-slider-track-filled-error);\n}\nnv-fieldslider[error] .slider-container .track-container:has(.thumb:hover) .thumb {\n border-color: var(--components-slider-track-filled-error);\n}\n\nnv-fieldnumber {\n --nv-field-border-default: var(--components-form-field-border-default);\n --nv-field-border-hover: var(--components-form-field-border-hover);\n --nv-field-border-focus: var(--components-form-field-border-focus);\n --nv-field-border-disabled: var(--components-form-field-border-default);\n --nv-field-border-readonly: var(--components-form-field-border-default);\n --nv-field-focus-box-shadow: var(--color-focus-brand);\n --nv-field-background: var(--components-form-field-background-default);\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: var(--form-gap-y);\n box-sizing: border-box;\n max-width: 480px;\n}\nnv-fieldnumber[fluid]:not([fluid=false]) {\n max-width: unset;\n}\nnv-fieldnumber[readonly]:not([readonly=false]) {\n --nv-field-border-default: var(--components-form-field-border-readonly);\n --nv-field-border-hover: var(--nv-field-border-default);\n --nv-field-border-focus: var(--components-form-field-border-focus);\n --nv-field-border-disabled: var(--nv-field-border-default);\n --nv-field-border-readonly: var(--nv-field-border-default);\n --nv-field-background: var(--components-form-field-background-readonly);\n}\nnv-fieldnumber[error]:not([error=false]) {\n --nv-field-border-default: var(--components-form-field-border-error);\n --nv-field-border-hover: var(--nv-field-border-default);\n --nv-field-border-focus: var(--nv-field-border-default);\n --nv-field-border-disabled: var(--nv-field-border-default);\n --nv-field-border-readonly: var(--nv-field-border-default);\n --nv-field-focus-box-shadow: var(--color-focus-destructive-in-field);\n}\nnv-fieldnumber[success]:not([success=false]) {\n --nv-field-border-default: var(--components-form-field-border-success);\n --nv-field-border-hover: var(--nv-field-border-default);\n --nv-field-border-focus: var(--nv-field-border-default);\n --nv-field-border-disabled: var(--nv-field-border-default);\n --nv-field-border-readonly: var(--nv-field-border-default);\n --nv-field-focus-box-shadow: var(--color-focus-success);\n}\nnv-fieldnumber[required]:not([required=false]) label::after {\n content: "*";\n color: var(--components-form-text-required);\n font-weight: 700;\n}\nnv-fieldnumber label {\n display: flex;\n align-items: center;\n gap: var(--form-label-gap);\n align-self: stretch;\n color: var(--components-form-text-label-default);\n font-family: "TT Norms Pro", sans-serif;\n font-size: var(--form-label-font-size);\n font-style: normal;\n font-weight: 500;\n line-height: var(--form-label-line-height);\n}\nnv-fieldnumber .input-wrapper {\n display: flex;\n flex-wrap: wrap;\n gap: var(--form-gap-x);\n align-items: stretch;\n align-self: stretch;\n}\nnv-fieldnumber .input-wrapper .input-container {\n display: flex;\n flex-grow: 1;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n border-radius: var(--form-field-radius);\n border-width: 1px;\n border-style: solid;\n border-color: var(--nv-field-border-default);\n opacity: var(--components-form-opacity-default, 1);\n background: var(--nv-field-background);\n transition: all 150ms ease-out;\n container-type: inline-size;\n container-name: field-number-input-container;\n overflow: hidden;\n position: relative;\n}\nnv-fieldnumber .input-wrapper .input-container:hover {\n border-color: var(--nv-field-border-hover);\n}\nnv-fieldnumber .input-wrapper .input-container:focus-within, nv-fieldnumber .input-wrapper .input-container:focus-within:hover, nv-fieldnumber .input-wrapper .input-container:focus, nv-fieldnumber .input-wrapper .input-container:focus:hover {\n border-color: var(--nv-field-border-focus);\n box-shadow: 0px 0px 0px var(--focus-field-stroke) var(--nv-field-focus-box-shadow);\n}\nnv-fieldnumber .input-wrapper .input-container:has(input:read-only) {\n opacity: 0.5;\n background-color: var(--components-form-field-background-readonly);\n border-color: var(--nv-field-border-readonly);\n}\nnv-fieldnumber .input-wrapper .input-container:has(input:disabled) {\n opacity: 0.5;\n background-color: var(--components-form-field-background-disabled);\n border-color: var(--nv-field-border-disabled);\n}\nnv-fieldnumber .input-wrapper .input-container input {\n display: flex;\n align-items: center;\n flex: 1 0 0;\n overflow: hidden;\n background-color: transparent;\n color: var(--components-form-field-content-text);\n padding: var(--form-field-padding-y) var(--form-field-padding-x);\n font-size: var(--form-field-font-size);\n font-style: normal;\n font-weight: 500;\n line-height: var(--form-field-line-height);\n width: 100%;\n /* Hide Edge built-in password reveal and clear icons */\n width: 100%;\n appearance: textfield;\n}\nnv-fieldnumber .input-wrapper .input-container input:focus {\n outline: none;\n}\nnv-fieldnumber .input-wrapper .input-container input::placeholder {\n overflow: hidden;\n color: var(--components-form-field-content-placeholder);\n text-overflow: ellipsis;\n font-family: "TT Norms Pro", sans-serif;\n font-size: var(--form-field-font-size);\n font-style: normal;\n font-weight: 400;\n line-height: var(--form-field-line-height);\n}\nnv-fieldnumber .input-wrapper .input-container input[type=password]::-ms-clear, nv-fieldnumber .input-wrapper .input-container input[type=password]::-ms-reveal {\n display: none;\n width: 0;\n height: 0;\n}\nnv-fieldnumber .input-wrapper .input-container input::-webkit-inner-spin-button, nv-fieldnumber .input-wrapper .input-container input::-webkit-outer-spin-button {\n appearance: none;\n margin: 0;\n}\nnv-fieldnumber .input-wrapper .input-container nv-icon.validation {\n color: var(--nv-field-border-default);\n margin-right: var(--form-field-gap);\n}\nnv-fieldnumber .input-wrapper .input-container > nv-iconbutton {\n border: 0px;\n border-radius: 0px;\n}\nnv-fieldnumber .input-wrapper .input-container > nv-iconbutton:focus-visible {\n border-radius: var(--button-md-border-radius);\n outline-offset: -3px;\n}\nnv-fieldnumber .input-wrapper .input-container > nv-iconbutton:last-of-type {\n border-top-right-radius: var(--form-field-radius);\n border-bottom-right-radius: var(--form-field-radius);\n}\nnv-fieldnumber .input-wrapper .input-container .stepper {\n display: flex;\n border-left: var(--notification-border-width-low-emphasis) solid var(--components-form-field-border-readonly);\n}\nnv-fieldnumber .input-wrapper .input-container .stepper > nv-iconbutton {\n border: 0px;\n border-radius: 0px;\n border-radius: 0px;\n}\nnv-fieldnumber .input-wrapper .input-container .stepper > nv-iconbutton:focus-visible {\n border-radius: var(--button-md-border-radius);\n outline-offset: -3px;\n}\nnv-fieldnumber .input-wrapper .input-container .stepper > nv-iconbutton:last-of-type {\n border-top-right-radius: var(--form-field-radius);\n border-bottom-right-radius: var(--form-field-radius);\n}\n@container field-number-input-container (width < 150px) {\n nv-fieldnumber .input-wrapper .input-container .stepper-spacer {\n display: none;\n }\n nv-fieldnumber .input-wrapper .input-container .stepper {\n display: none;\n }\n}\nnv-fieldnumber .description {\n display: flex;\n align-items: center;\n align-self: stretch;\n gap: var(--spacing-1);\n color: var(--components-form-text-description-default);\n font-family: "TT Norms Pro", sans-serif;\n font-size: var(--form-description-font-size);\n font-style: normal;\n line-height: var(--form-description-line-height);\n}\nnv-fieldnumber .error-description {\n display: flex;\n align-items: center;\n align-self: stretch;\n gap: var(--spacing-1);\n color: var(--components-form-text-description-default);\n font-family: "TT Norms Pro", sans-serif;\n font-size: var(--form-description-font-size);\n font-style: normal;\n line-height: var(--form-description-line-height);\n color: var(--components-form-text-description-error);\n}';const d=a;const l=class{constructor(r){n(this,r);this.valueChanged=e(this,"valueChanged",7);this.inputId=t();this.disabled=false;this.readonly=false;this.required=false;this.error=false;this.success=false;this.step=1;this.autofocus=false;this.fluid=false;this.handleInput=n=>{const e=n.target;this.value=e.valueAsNumber};this.handleInputContainerClick=()=>{this.inputElement.focus()};this.handlePlus=()=>{this.inputElement.stepUp();this.value=Number(this.inputElement.value)};this.handleMinus=()=>{this.inputElement.stepDown();this.value=Number(this.inputElement.value)};this.preventSelection=n=>{n.preventDefault()};this.isMinValueReached=()=>this.min!==undefined&&this.value<=this.min;this.isMaxValueReached=()=>this.max!==undefined&&this.value>=this.max}watchValueHandler(n){this.valueChanged.emit(n)}componentWillRender(){if(this.message){this.description=this.message}if(this.validation){this.errorDescription=this.validation;this.error=true}}render(){return r(i,{key:"1bbe4506220df2ebb5723e916edcf49b3c0295e4"},(this.label||this.el.querySelector('[slot="label"]'))&&r("label",{key:"56ed85a58e669e9c6aec04ed9ea7bc9664c478f8",htmlFor:this.inputId},r("slot",{key:"b4cf04b6bca34f0ff158fd9e7b14c56df7ea3e8a",name:"label"},this.label)),r("div",{key:"9c9432645591952acff5b1f73c5be8d8f1dae7fb",class:"input-wrapper"},r("slot",{key:"05bacf384b22fce12a66109864ec95fab403f8d7",name:"before-input"}),r("div",{key:"66f0c59c38b7309834ba22bbd767e94a04964781",class:"input-container",onClick:this.handleInputContainerClick},r("slot",{key:"7e2a7c766484b8c4c4caabab311ea635f95eb4fd",name:"leading-input"}),r("input",{key:"808f4f16b3a73d0b07efa7cff18dd5dd3f94bda4",id:this.inputId,ref:n=>this.inputElement=n,placeholder:this.placeholder,name:this.name,type:"number",autofocus:this.autofocus,required:this.required,max:this.max,min:this.min,step:this.step,value:this.value,disabled:this.disabled,readOnly:this.readonly,onInput:this.handleInput}),r("slot",{key:"65a7f356f2a9f650df9e78f53b98b43c7e179802",name:"trailing-input"}),this.error&&r("nv-icon",{key:"5eed73e177092188387abd35ccab6085a1bdb2cf",name:"alert-circle",class:"validation",size:"md"}),this.success&&r("nv-icon",{key:"74edadb953f9668e49a1b3ecd328bfd2999065ea",name:"circle-check",class:"validation",size:"md"}),r("div",{key:"e886fe1df175d5c4dcd9a4704ad47820e0af2474",class:"stepper"},r("nv-iconbutton",{key:"ff6247b57693f2a45c26e1eae67c9d86c473e0e3",size:"md",name:"minus",emphasis:"lower",onClick:this.handleMinus,disabled:this.isMinValueReached(),onMouseDown:this.preventSelection,tabindex:"-1"}),r("nv-iconbutton",{key:"aa12c105d159e08e874bdd37f56ab1837ba01c4f",size:"md",name:"plus",emphasis:"lower",onClick:this.handlePlus,disabled:this.isMaxValueReached(),onMouseDown:this.preventSelection,tabindex:"-1"}))),r("slot",{key:"c485ac2e1ca388b6e0998bdb1c5ca5876cd9e392",name:"after-input"})),(this.description||this.el.querySelector('[slot="description"]'))&&r("div",{key:"88d80f2f5b0061b0f8dab4bcc88bf2d196427800",class:"description"},r("slot",{key:"0380af6af9986d000ad58328e6c4b8250f86c22a",name:"description"},this.description)),(this.errorDescription||this.el.querySelector('[slot="error-description"]'))&&r("div",{key:"a2233d218f58376b6c7958efabe96a3e08c6e1f6",hidden:!this.error,class:"error-description"},r("slot",{key:"d90bc8abdcecc9711b271472a8da60b207aa04af",name:"error-description"},this.errorDescription)))}static get formAssociated(){return true}get el(){return o(this)}static get watchers(){return{value:["watchValueHandler"]}}};l.style=d;export{l as nv_fieldnumber};
|
|
2
|
+
//# sourceMappingURL=p-29f68e07.entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["nvFieldnumberCss","NvFieldnumberStyle0","NvFieldnumber","constructor","hostRef","this","inputId","uuidv4","disabled","readonly","required","error","success","step","autofocus","fluid","handleInput","event","input","target","value","valueAsNumber","handleInputContainerClick","inputElement","focus","handlePlus","stepUp","Number","handleMinus","stepDown","preventSelection","preventDefault","isMinValueReached","min","undefined","isMaxValueReached","max","watchValueHandler","newValue","valueChanged","emit","componentWillRender","message","description","validation","errorDescription","render","h","Host","key","label","el","querySelector","htmlFor","name","class","onClick","id","ref","e","placeholder","type","readOnly","onInput","size","emphasis","onMouseDown","tabindex","hidden"],"sources":["src/components/nv-fieldnumber/nv-fieldnumber.scss?tag=nv-fieldnumber","src/components/nv-fieldnumber/nv-fieldnumber.tsx"],"sourcesContent":["@import '../../styles/form-field';\n\nnv-fieldnumber {\n @include form-field-variables();\n @include form-field-root();\n\n &[fluid]:not([fluid=\"false\"]) {\n @include form-field-fluid();\n }\n\n &[readonly]:not([readonly='false']) {\n @include form-field-readonly-variables();\n }\n\n &[error]:not([error='false']) {\n @include form-field-error-variables();\n }\n\n &[success]:not([success='false']) {\n @include form-field-success-variables();\n }\n\n &[required]:not([required='false']) label {\n @include form-field-label-required();\n }\n\n label {\n @include form-field-label();\n }\n\n .input-wrapper {\n @include form-field-input-wrapper();\n\n .input-container {\n @include form-field-input-container();\n\n container-type: inline-size;\n container-name: field-number-input-container;\n overflow: hidden;\n position: relative;\n\n input {\n @include form-field-input();\n\n width: 100%;\n appearance: textfield;\n\n &::-webkit-inner-spin-button,\n &::-webkit-outer-spin-button {\n appearance: none;\n margin: 0;\n }\n }\n\n nv-icon.validation {\n @include form-field-icon();\n margin-right: var(--form-field-gap);\n }\n\n > nv-iconbutton {\n @include form-field-action();\n }\n\n .stepper {\n display: flex;\n border-left: var(--notification-border-width-low-emphasis) solid var(--components-form-field-border-readonly);\n > nv-iconbutton {\n @include form-field-action();\n border-radius: 0px;\n }\n }\n\n // container query to remove .stepper and and the spacer when the container is less than 150px\n // .. this needs to be an absolute value because container queries do not accept variables\n // .. using relative width (cqw) compared to a parent container would not work\n // .. because the parent container follows the child's width\n @container field-number-input-container (width < 150px) {\n .stepper-spacer {\n display: none;\n }\n\n .stepper {\n display: none;\n }\n }\n }\n }\n\n .description {\n @include form-field-description();\n }\n\n .error-description {\n @include form-field-error-description();\n }\n}","import {\n Component,\n Prop,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Watch,\n} from '@stencil/core';\nimport { v4 as uuidv4 } from 'uuid';\n\n/**\n * @slot leading-input - Content to be placed before the input text, within the input container.\n * @slot trailing-input - Content to be placed after the input text, within the input container.\n * @slot before-input - Content to be placed before the input text, outside the input container.\n * @slot after-input - Content to be placed after the input text, outside the input container.\n * @slot label - Content to be placed as the label, will override the label prop.\n * @slot description - Content to be placed as the description, will override the description prop.\n * @slot error-description - Content to be placed as the error description, will override the errorDescription prop.\n */\n@Component({\n tag: 'nv-fieldnumber',\n styleUrl: 'nv-fieldnumber.scss',\n shadow: false,\n formAssociated: true,\n})\nexport class NvFieldnumber {\n @Element() el: HTMLNvFieldnumberElement;\n private inputElement!: HTMLInputElement;\n\n /****************************************************************************/\n //#region DEPRECATED\n\n /**\n * Message defines a 'hint ' message for the number field.\n * @deprecated Use `description` instead.\n */\n @Prop({ reflect: true })\n readonly message: string;\n\n /**\n * Add the message to the validation state.\n * @deprecated Use `errorDescription` and set the error prop instead.\n */\n @Prop({ reflect: true })\n readonly validation: string;\n\n //#endregion DEPRECATED\n /****************************************************************************/\n //#region PROPERTIES\n\n /**\n * Sets the ID for the input element and the for attribute of the associated\n * label. If no ID is provided, a random one will be automatically generated\n * to ensure unique identification, facilitating proper label association and\n * accessibility.\n */\n @Prop({ reflect: true })\n readonly inputId: string = uuidv4();\n\n /**\n * Lets you define the text that explains what users should enter in the text\n * input field. It’s a crucial element for making forms clear and\n * user-friendly.\n */\n @Prop({ reflect: true })\n readonly label: string;\n\n /**\n * Add helpful hints or extra information under the text input field. This is\n * where you can clarify what users should enter or provide additional\n * instructions, making the form easier to fill out correctly.\n */\n @Prop({ reflect: true, mutable: true })\n description: string;\n\n /**\n * Display temporary text inside the input field to give users a hint about\n * what to type. It’s a great way to provide examples or suggestions directly\n * in the field before they start typing.\n */\n @Prop({ reflect: true })\n readonly placeholder: string;\n\n /**\n * Defines the name attribute of the input field, which is crucial for form\n * submission. This value is used as the key in the key-value pair sent to\n * the server, representing the input’s data in form submissions. It should be\n * unique within the form to avoid conflicts\n */\n @Prop({ reflect: true })\n readonly name: string;\n\n /**\n * The disabled prop lets you turn off the input field so that users can’t\n * type in it. When disabled, the field is grayed out and won’t respond to#\n * clicks or touches.\n */\n @Prop({ reflect: true })\n readonly disabled: boolean = false;\n\n /**\n * Display the input field’s content without allowing users to change it.\n * Users can still click on it, select, and copy the text, but they won’t be\n * able to type or delete anything.\n */\n @Prop({ reflect: true })\n readonly readonly: boolean = false;\n\n /**\n * Marks the input field as required, ensuring that the user must fill it out\n * before submitting the form.\n */\n @Prop({ reflect: true })\n readonly required: boolean = false;\n\n /**\n * Alters the input field’s appearance to indicate an error, helping users\n * identify fields that need correction.\n * @validator error\n */\n @Prop({ reflect: true, mutable: true })\n error: boolean = false;\n\n /**\n * Show a helpful message under the input field when there’s a problem. It\n * explains what’s wrong and how users can fix it, making the error easier to\n * understand and resolve.\n * @validator message\n */\n @Prop({ reflect: true, mutable: true })\n errorDescription: string;\n\n /**\n * Changes the input field’s appearance to indicate successful input or\n * validation.\n */\n @Prop({ reflect: true })\n readonly success: boolean = false;\n\n /**\n * The maximum value that the input field can accept. Use this in combination\n * with min to create a range of valid values.\n */\n @Prop({ reflect: true })\n readonly max: number;\n\n /**\n * The minimum value that the input field can accept. Use this in combination\n * with max to create a range of valid values.\n */\n @Prop({ reflect: true })\n readonly min: number;\n\n /**\n * Define the increment value for the input field. It determines how much the\n * value will increase or decrease when the user clicks the stepper buttons.\n */\n @Prop({ reflect: true })\n readonly step: number = 1;\n\n /**\n * The value of the input field. It’s the text that users type in or the value\n * that you set programmatically. This is the main way to interact with the\n * input field, and it’s essential for creating forms that users can fill out.\n */\n @Prop({ reflect: true, mutable: true })\n value: number;\n\n /**\n * Applies focus to the input field as soon as the component is mounted. This\n * is equivalent to setting the native autofocus attribute on an <input>\n * element.\n */\n @Prop({ reflect: true })\n // eslint-disable-next-line @stencil-community/reserved-member-names\n readonly autofocus: boolean = false;\n\n /**\n * Allows the field to stretch and fill the entire width of its container.\n */\n @Prop({ reflect: true })\n readonly fluid: boolean = false;\n\n //#endregion PROPERTIES\n /****************************************************************************/\n //#region EVENTS\n\n /**\n * Emitted when the input value changes.\n * @bind value\n */\n @Event()\n valueChanged: EventEmitter<number>;\n\n //#endregion EVENTS\n /****************************************************************************/\n //#region WATCHERS\n\n @Watch('value')\n watchValueHandler(newValue: number) {\n this.valueChanged.emit(newValue);\n }\n\n //#endregion WATCHERS\n /****************************************************************************/\n //#region METHODS\n\n private handleInput = (event: Event) => {\n const input = event.target as HTMLInputElement;\n this.value = input.valueAsNumber;\n };\n\n private handleInputContainerClick = () => {\n this.inputElement.focus();\n };\n\n private handlePlus = () => {\n this.inputElement.stepUp();\n this.value = Number(this.inputElement.value);\n };\n\n private handleMinus = () => {\n this.inputElement.stepDown();\n this.value = Number(this.inputElement.value);\n };\n\n // prevents text selection when clicking the buttons multiple times\n private preventSelection = (event: Event) => {\n event.preventDefault();\n };\n\n private isMinValueReached = (): boolean => {\n return this.min !== undefined && this.value <= this.min;\n };\n\n private isMaxValueReached = (): boolean => {\n return this.max !== undefined && this.value >= this.max;\n };\n\n //#endregion METHODS\n /****************************************************************************/\n //#region LIFECYCLE\n\n componentWillRender() {\n if (this.message) {\n this.description = this.message;\n }\n\n if (this.validation) {\n this.errorDescription = this.validation;\n this.error = true;\n }\n }\n\n //#endregion LIFECYCLE\n /****************************************************************************/\n //#region RENDER\n\n render() {\n return (\n <Host>\n {(this.label || this.el.querySelector('[slot=\"label\"]')) && (\n <label htmlFor={this.inputId}>\n <slot name=\"label\">{this.label}</slot>\n </label>\n )}\n\n <div class=\"input-wrapper\">\n <slot name=\"before-input\"></slot>\n\n <div class=\"input-container\" onClick={this.handleInputContainerClick}>\n <slot name=\"leading-input\"></slot>\n\n <input\n id={this.inputId}\n ref={e => (this.inputElement = e)}\n placeholder={this.placeholder}\n name={this.name}\n type=\"number\"\n autofocus={this.autofocus}\n required={this.required}\n max={this.max}\n min={this.min}\n step={this.step}\n value={this.value}\n disabled={this.disabled}\n readOnly={this.readonly}\n onInput={this.handleInput}\n />\n\n <slot name=\"trailing-input\"></slot>\n\n {this.error && (\n <nv-icon name=\"alert-circle\" class=\"validation\" size=\"md\" />\n )}\n {this.success && (\n <nv-icon name=\"circle-check\" class=\"validation\" size=\"md\" />\n )}\n\n <div class=\"stepper\">\n <nv-iconbutton\n size=\"md\"\n name=\"minus\"\n emphasis=\"lower\"\n onClick={this.handleMinus}\n disabled={this.isMinValueReached()}\n onMouseDown={this.preventSelection}\n tabindex=\"-1\"\n ></nv-iconbutton>\n <nv-iconbutton\n size=\"md\"\n name=\"plus\"\n emphasis=\"lower\"\n onClick={this.handlePlus}\n disabled={this.isMaxValueReached()}\n onMouseDown={this.preventSelection}\n tabindex=\"-1\"\n />\n </div>\n </div>\n\n <slot name=\"after-input\"></slot>\n </div>\n\n {(this.description ||\n this.el.querySelector('[slot=\"description\"]')) && (\n <div class=\"description\">\n <slot name=\"description\">{this.description}</slot>\n </div>\n )}\n\n {(this.errorDescription ||\n this.el.querySelector('[slot=\"error-description\"]')) && (\n <div hidden={!this.error} class=\"error-description\">\n <slot name=\"error-description\">{this.errorDescription}</slot>\n </div>\n )}\n </Host>\n );\n }\n\n //#endregion RENDER\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{l as t,a as o}from"./p-42ea6b74.js";const n=(t,o)=>1-3*o+3*t;const e=(t,o)=>3*o-6*t;const r=t=>3*t;const i=(t,o,i)=>((n(o,i)*t+e(o,i))*t+r(o))*t;const a=(t,o,i)=>3*n(o,i)*t*t+2*e(o,i)*t+r(o);const s=1e-7;const m=10;function c(t,o,n,e,r){let a;let c;let g=0;do{c=o+(n-o)/2;a=i(c,e,r)-t;if(a>0){n=c}else{o=c}}while(Math.abs(a)>s&&++g<m);return c}const g=8;const l=.001;function p(t,o,n,e){for(let r=0;r<g;++r){const r=a(o,n,e);if(r===0){return o}const s=i(o,n,e)-t;o-=s/r}return o}const h=11;const f=1/(h-1);function u(o,n,e,r){if(o===n&&e===r)return t;const s=new Float32Array(h);for(let t=0;t<h;++t){s[t]=i(t*f,o,e)}function m(t){let n=0;let r=1;const i=h-1;for(;r!==i&&s[r]<=t;++r){n+=f}--r;const m=(t-s[r])/(s[r+1]-s[r]);const g=n+m*f;const u=a(g,o,e);if(u>=l){return p(t,g,o,e)}else if(u===0){return g}else{return c(t,n,n+f,o,e)}}return t=>t===0||t===1?t:i(m(t),n,r)}function x(t){const o=t.getBoundingClientRect().height;const n=getComputedStyle(t);const e=parseFloat(n.marginTop)||0;const r=parseFloat(n.marginBottom)||0;const i=o+e+r;return{height:o,marginTop:e,marginBottom:r,total:i}}const w=(t,{duration:n=200,overflow:e="hidden"}={})=>{let r=null;const i=()=>{if(r){r.stop();r=null}};const a=o=>{for(const[n,e]of Object.entries(o)){t.style[n]=e}};function s(){i();a({height:"0px",marginTop:"0px",marginBottom:"0px",overflow:e})}function m(){i();a({height:"",marginTop:"",marginBottom:"",overflow:""})}function c(){i();return new Promise((i=>{const{height:s,marginTop:m,marginBottom:c,total:g}=x(t);a({height:`${s}px`,marginTop:`${m}px`,marginBottom:`${c}px`,overflow:e,willChange:"height, margin"});const l=g>0?g:1e-4;r=o({from:g,to:0,duration:n,ease:u(.2,0,0,1),onUpdate:t=>{const o=t/l;a({height:`${s*o}px`,marginTop:`${m*o}px`,marginBottom:`${c*o}px`})},onComplete:()=>{a({height:"0px",marginTop:"0px",marginBottom:"0px",willChange:""});i()}})}))}async function g(){i();await new Promise((t=>requestAnimationFrame(t)));return new Promise((i=>{a({height:"",marginTop:"",marginBottom:"",overflow:e});const{height:s,marginTop:m,marginBottom:c,total:g}=x(t);a({height:"0px",marginTop:"0px",marginBottom:"0px",willChange:"height, margin"});const l=g>0?g:1e-4;r=o({from:0,to:g,duration:n,ease:u(.2,0,0,1),onUpdate:t=>{const o=t/l;a({height:`${s*o}px`,marginTop:`${m*o}px`,marginBottom:`${c*o}px`})},onComplete:()=>{a({height:"",marginTop:"",marginBottom:"",overflow:"",willChange:""});i()}})}))}return{collapse:c,expand:g,setCollapsed:s,setExpanded:m}};export{w as u};
|
|
2
|
+
//# sourceMappingURL=p-3cd7a66f.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["a","a1","a2","b","c","calcBezier","t","getSlope","subdivisionPrecision","subdivisionMaxIterations","binarySubdivide","aX","aA","aB","mX1","mX2","currentX","currentT","i","Math","abs","newtonIterations","newtonMinSlope","newtonRaphsonIterate","aGuessT","currentSlope","kSplineTableSize","kSampleStepSize","cubicBezier","mY1","mY2","linear","sampleValues","Float32Array","getTForX","intervalStart","currentSample","lastSample","dist","guessForT","initialSlope","getBoxMetrics","node","rectHeight","getBoundingClientRect","height","style","getComputedStyle","marginTop","parseFloat","marginBottom","total","useCollapse","duration","overflow","currentAnimation","stop","setStyle","styles","k","v","Object","entries","setCollapsed","setExpanded","collapse","Promise","resolve","willChange","denom","animate","from","to","ease","onUpdate","ratio","onComplete","async","expand","requestAnimationFrame"],"sources":["../../node_modules/popmotion/dist/es/easing/cubic-bezier.mjs","src/animations/collapse.animation.ts"],"sourcesContent":["import { linear } from './index.mjs';\n\nconst a = (a1, a2) => 1.0 - 3.0 * a2 + 3.0 * a1;\nconst b = (a1, a2) => 3.0 * a2 - 6.0 * a1;\nconst c = (a1) => 3.0 * a1;\nconst calcBezier = (t, a1, a2) => ((a(a1, a2) * t + b(a1, a2)) * t + c(a1)) * t;\nconst getSlope = (t, a1, a2) => 3.0 * a(a1, a2) * t * t + 2.0 * b(a1, a2) * t + c(a1);\nconst subdivisionPrecision = 0.0000001;\nconst subdivisionMaxIterations = 10;\nfunction binarySubdivide(aX, aA, aB, mX1, mX2) {\n let currentX;\n let currentT;\n let i = 0;\n do {\n currentT = aA + (aB - aA) / 2.0;\n currentX = calcBezier(currentT, mX1, mX2) - aX;\n if (currentX > 0.0) {\n aB = currentT;\n }\n else {\n aA = currentT;\n }\n } while (Math.abs(currentX) > subdivisionPrecision &&\n ++i < subdivisionMaxIterations);\n return currentT;\n}\nconst newtonIterations = 8;\nconst newtonMinSlope = 0.001;\nfunction newtonRaphsonIterate(aX, aGuessT, mX1, mX2) {\n for (let i = 0; i < newtonIterations; ++i) {\n const currentSlope = getSlope(aGuessT, mX1, mX2);\n if (currentSlope === 0.0) {\n return aGuessT;\n }\n const currentX = calcBezier(aGuessT, mX1, mX2) - aX;\n aGuessT -= currentX / currentSlope;\n }\n return aGuessT;\n}\nconst kSplineTableSize = 11;\nconst kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);\nfunction cubicBezier(mX1, mY1, mX2, mY2) {\n if (mX1 === mY1 && mX2 === mY2)\n return linear;\n const sampleValues = new Float32Array(kSplineTableSize);\n for (let i = 0; i < kSplineTableSize; ++i) {\n sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n }\n function getTForX(aX) {\n let intervalStart = 0.0;\n let currentSample = 1;\n const lastSample = kSplineTableSize - 1;\n for (; currentSample !== lastSample && sampleValues[currentSample] <= aX; ++currentSample) {\n intervalStart += kSampleStepSize;\n }\n --currentSample;\n const dist = (aX - sampleValues[currentSample]) /\n (sampleValues[currentSample + 1] - sampleValues[currentSample]);\n const guessForT = intervalStart + dist * kSampleStepSize;\n const initialSlope = getSlope(guessForT, mX1, mX2);\n if (initialSlope >= newtonMinSlope) {\n return newtonRaphsonIterate(aX, guessForT, mX1, mX2);\n }\n else if (initialSlope === 0.0) {\n return guessForT;\n }\n else {\n return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize, mX1, mX2);\n }\n }\n return (t) => t === 0 || t === 1 ? t : calcBezier(getTForX(t), mY1, mY2);\n}\n\nexport { cubicBezier };\n","import { animate, cubicBezier } from 'popmotion';\n\nexport type CollapseOptions = {\n /**\n * Duration of the expand/collapse animation in milliseconds.\n * @default 200\n */\n duration?: number;\n\n /**\n * Set the overflow state while animating.\n * @default \"hidden\"\n */\n overflow?: 'hidden' | 'visible';\n};\n\n/**\n * Read current box metrics (height + vertical margins).\n * @param {HTMLElement} node - The element to measure.\n * @returns {object} The box metrics.\n */\nfunction getBoxMetrics(node: HTMLElement) {\n const rectHeight = node.getBoundingClientRect().height;\n const style = getComputedStyle(node);\n const marginTop = parseFloat(style.marginTop) || 0;\n const marginBottom = parseFloat(style.marginBottom) || 0;\n const total = rectHeight + marginTop + marginBottom;\n return { height: rectHeight, marginTop, marginBottom, total };\n}\n\nconst useCollapse = (\n node: HTMLElement,\n { duration = 200, overflow = 'hidden' }: CollapseOptions = {},\n) => {\n let currentAnimation: ReturnType<typeof animate> | null = null;\n\n const stop = () => {\n if (currentAnimation) {\n currentAnimation.stop();\n currentAnimation = null;\n }\n };\n\n const setStyle = (styles: Partial<CSSStyleDeclaration>) => {\n for (const [k, v] of Object.entries(styles)) {\n node.style[k] = v as string;\n }\n };\n\n /** Instantly apply collapsed styles (no animation). */\n function setCollapsed() {\n stop();\n setStyle({\n height: '0px',\n marginTop: '0px',\n marginBottom: '0px',\n overflow,\n });\n }\n\n /** Instantly apply expanded styles (no animation). */\n function setExpanded() {\n stop();\n setStyle({\n height: '',\n marginTop: '',\n marginBottom: '',\n overflow: '',\n });\n }\n\n /**\n * Collapse: animate from current box (height + margins) down to 0.\n */\n function collapse() {\n stop();\n return new Promise<void>(resolve => {\n const { height, marginTop, marginBottom, total } = getBoxMetrics(node);\n\n // Lock current box\n setStyle({\n height: `${height}px`,\n marginTop: `${marginTop}px`,\n marginBottom: `${marginBottom}px`,\n overflow,\n willChange: 'height, margin',\n });\n\n const denom = total > 0 ? total : 0.0001; // avoid divide-by-zero\n\n currentAnimation = animate({\n from: total,\n to: 0,\n duration,\n ease: cubicBezier(0.2, 0, 0, 1),\n onUpdate: v => {\n const ratio = v / denom;\n setStyle({\n height: `${height * ratio}px`,\n marginTop: `${marginTop * ratio}px`,\n marginBottom: `${marginBottom * ratio}px`,\n });\n },\n onComplete: () => {\n setStyle({\n height: '0px',\n marginTop: '0px',\n marginBottom: '0px',\n willChange: '',\n });\n resolve();\n },\n });\n });\n }\n\n /**\n * Expand: animate from 0 box to the element's natural box (height + margins),\n * then restore `height: auto` and computed margins.\n */\n async function expand() {\n stop();\n // Make sure any pending screen updates are done\n await new Promise(resolve => requestAnimationFrame(resolve));\n\n return new Promise<void>(resolve => {\n // Let the element size naturally to measure the target box\n // await next animation frame\n setStyle({\n height: '',\n marginTop: '',\n marginBottom: '',\n overflow,\n });\n const { height, marginTop, marginBottom, total } = getBoxMetrics(node);\n\n // Start locked at zero box\n setStyle({\n height: '0px',\n marginTop: '0px',\n marginBottom: '0px',\n willChange: 'height, margin',\n });\n\n const denom = total > 0 ? total : 0.0001;\n\n currentAnimation = animate({\n from: 0,\n to: total,\n duration,\n ease: cubicBezier(0.2, 0, 0, 1),\n onUpdate: v => {\n const ratio = v / denom;\n setStyle({\n height: `${height * ratio}px`,\n marginTop: `${marginTop * ratio}px`,\n marginBottom: `${marginBottom * ratio}px`,\n });\n },\n onComplete: () => {\n // Restore natural layout\n setStyle({\n height: '',\n marginTop: '',\n marginBottom: '',\n overflow: '',\n willChange: '',\n });\n resolve();\n },\n });\n });\n }\n\n return { collapse, expand, setCollapsed, setExpanded };\n};\n\nexport { useCollapse };\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
function t(t,n){var e={};for(var r in t)if(Object.prototype.hasOwnProperty.call(t,r)&&n.indexOf(r)<0)e[r]=t[r];if(t!=null&&typeof Object.getOwnPropertySymbols==="function")for(var o=0,r=Object.getOwnPropertySymbols(t);o<r.length;o++){if(n.indexOf(r[o])<0&&Object.prototype.propertyIsEnumerable.call(t,r[o]))e[r[o]]=t[r[o]]}return e}var n=function(){};const e=(t,n,e)=>Math.min(Math.max(e,t),n);const r=.001;const o=.01;const s=10;const a=.05;const c=1;function u({duration:t=800,bounce:u=.25,velocity:f=0,mass:p=1}){let d;let h;n(t<=s*1e3);let v=1-u;v=e(a,c,v);t=e(o,s,t/1e3);if(v<1){d=n=>{const e=n*v;const o=e*t;const s=e-f;const a=l(n,v);const c=Math.exp(-o);return r-s/a*c};h=n=>{const e=n*v;const o=e*t;const s=o*f+f;const a=Math.pow(v,2)*Math.pow(n,2)*t;const c=Math.exp(-o);const u=l(Math.pow(n,2),v);const i=-d(n)+r>0?-1:1;return i*((s-a)*c)/u}}else{d=n=>{const e=Math.exp(-n*t);const o=(n-f)*t+1;return-r+e*o};h=n=>{const e=Math.exp(-n*t);const r=(f-n)*(t*t);return e*r}}const m=5/t;const b=i(d,h,m);t=t*1e3;if(isNaN(b)){return{stiffness:100,damping:10,duration:t}}else{const n=Math.pow(b,2)*p;return{stiffness:n,damping:v*2*Math.sqrt(p*n),duration:t}}}const f=12;function i(t,n,e){let r=e;for(let e=1;e<f;e++){r=r-t(r)/n(r)}return r}function l(t,n){return t*Math.sqrt(1-n*n)}const p=["duration","bounce"];const d=["stiffness","damping","mass"];function h(t,n){return n.some((n=>t[n]!==undefined))}function v(t){let n=Object.assign({velocity:0,stiffness:100,damping:10,mass:1,isResolvedFromDuration:false},t);if(!h(t,d)&&h(t,p)){const e=u(t);n=Object.assign(Object.assign(Object.assign({},n),e),{velocity:0,mass:1});n.isResolvedFromDuration=true}return n}function m(n){var{from:e=0,to:r=1,restSpeed:o=2,restDelta:s}=n,a=t(n,["from","to","restSpeed","restDelta"]);const c={done:false,value:e};let{stiffness:u,damping:f,mass:i,velocity:p,duration:d,isResolvedFromDuration:h}=v(a);let m=b;let M=b;function g(){const t=p?-(p/1e3):0;const n=r-e;const o=f/(2*Math.sqrt(u*i));const a=Math.sqrt(u/i)/1e3;if(s===undefined){s=Math.min(Math.abs(r-e)/100,.4)}if(o<1){const e=l(a,o);m=s=>{const c=Math.exp(-o*a*s);return r-c*((t+o*a*n)/e*Math.sin(e*s)+n*Math.cos(e*s))};M=r=>{const s=Math.exp(-o*a*r);return o*a*s*(Math.sin(e*r)*(t+o*a*n)/e+n*Math.cos(e*r))-s*(Math.cos(e*r)*(t+o*a*n)-e*n*Math.sin(e*r))}}else if(o===1){m=e=>r-Math.exp(-a*e)*(n+(t+a*n)*e)}else{const e=a*Math.sqrt(o*o-1);m=s=>{const c=Math.exp(-o*a*s);const u=Math.min(e*s,300);return r-c*((t+o*a*n)*Math.sinh(u)+e*n*Math.cosh(u))/e}}}g();return{next:t=>{const n=m(t);if(!h){const e=M(t)*1e3;const a=Math.abs(e)<=o;const u=Math.abs(r-n)<=s;c.done=a&&u}else{c.done=t>=d}c.value=c.done?r:n;return c},flipTarget:()=>{p=-p;[e,r]=[r,e];g()}}}m.needsInterpolation=(t,n)=>typeof t==="string"||typeof n==="string";const b=t=>0;const M=(t,n,e)=>{const r=n-t;return r===0?1:(e-t)/r};const g=(t,n,e)=>-e*t+e*n+t;const y=(t,n)=>e=>Math.max(Math.min(e,n),t);const j=t=>t%1?Number(t.toFixed(5)):t;const O=/(-)?([\d]*\.?[\d])+/g;const F=/(#[0-9a-f]{6}|#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\((-?[\d\.]+%?[,\s]+){2}(-?[\d\.]+%?)\s*[\,\/]?\s*[\d\.]*%?\))/gi;const D=/^(#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\((-?[\d\.]+%?[,\s]+){2}(-?[\d\.]+%?)\s*[\,\/]?\s*[\d\.]*%?\))$/i;function R(t){return typeof t==="string"}const N={test:t=>typeof t==="number",parse:parseFloat,transform:t=>t};const S=Object.assign(Object.assign({},N),{transform:y(0,1)});Object.assign(Object.assign({},N),{default:1});const T=t=>({test:n=>R(n)&&n.endsWith(t)&&n.split(" ").length===1,parse:parseFloat,transform:n=>`${n}${t}`});const $=T("%");Object.assign(Object.assign({},$),{parse:t=>$.parse(t)/100,transform:t=>$.transform(t*100)});const w=(t,n)=>e=>Boolean(R(e)&&D.test(e)&&e.startsWith(t)||n&&Object.prototype.hasOwnProperty.call(e,n));const I=(t,n,e)=>r=>{if(!R(r))return r;const[o,s,a,c]=r.match(O);return{[t]:parseFloat(o),[n]:parseFloat(s),[e]:parseFloat(a),alpha:c!==undefined?parseFloat(c):1}};const x={test:w("hsl","hue"),parse:I("hue","saturation","lightness"),transform:({hue:t,saturation:n,lightness:e,alpha:r=1})=>"hsla("+Math.round(t)+", "+$.transform(j(n))+", "+$.transform(j(e))+", "+j(S.transform(r))+")"};const A=y(0,255);const k=Object.assign(Object.assign({},N),{transform:t=>Math.round(A(t))});const C={test:w("rgb","red"),parse:I("red","green","blue"),transform:({red:t,green:n,blue:e,alpha:r=1})=>"rgba("+k.transform(t)+", "+k.transform(n)+", "+k.transform(e)+", "+j(S.transform(r))+")"};function B(t){let n="";let e="";let r="";let o="";if(t.length>5){n=t.substr(1,2);e=t.substr(3,2);r=t.substr(5,2);o=t.substr(7,2)}else{n=t.substr(1,1);e=t.substr(2,1);r=t.substr(3,1);o=t.substr(4,1);n+=n;e+=e;r+=r;o+=o}return{red:parseInt(n,16),green:parseInt(e,16),blue:parseInt(r,16),alpha:o?parseInt(o,16)/255:1}}const P={test:w("#"),parse:B,transform:C.transform};const U={test:t=>C.test(t)||P.test(t)||x.test(t),parse:t=>{if(C.test(t)){return C.parse(t)}else if(x.test(t)){return x.parse(t)}else{return P.parse(t)}},transform:t=>R(t)?t:t.hasOwnProperty("red")?C.transform(t):x.transform(t)};const G="${c}";const H="${n}";function L(t){var n,e,r,o;return isNaN(t)&&R(t)&&((e=(n=t.match(O))===null||n===void 0?void 0:n.length)!==null&&e!==void 0?e:0)+((o=(r=t.match(F))===null||r===void 0?void 0:r.length)!==null&&o!==void 0?o:0)>0}function W(t){if(typeof t==="number")t=`${t}`;const n=[];let e=0;const r=t.match(F);if(r){e=r.length;t=t.replace(F,G);n.push(...r.map(U.parse))}const o=t.match(O);if(o){t=t.replace(O,H);n.push(...o.map(N.parse))}return{values:n,numColors:e,tokenised:t}}function _(t){return W(t).values}function q(t){const{values:n,numColors:e,tokenised:r}=W(t);const o=n.length;return t=>{let n=r;for(let r=0;r<o;r++){n=n.replace(r<e?G:H,r<e?U.transform(t[r]):j(t[r]))}return n}}const z=t=>typeof t==="number"?0:t;function E(t){const n=_(t);const e=q(t);return e(n.map(z))}const J={test:L,parse:_,createTransformer:q,getAnimatableNone:E};function K(t,n,e){if(e<0)e+=1;if(e>1)e-=1;if(e<1/6)return t+(n-t)*6*e;if(e<1/2)return n;if(e<2/3)return t+(n-t)*(2/3-e)*6;return t}function Q({hue:t,saturation:n,lightness:e,alpha:r}){t/=360;n/=100;e/=100;let o=0;let s=0;let a=0;if(!n){o=s=a=e}else{const r=e<.5?e*(1+n):e+n-e*n;const c=2*e-r;o=K(c,r,t+1/3);s=K(c,r,t);a=K(c,r,t-1/3)}return{red:Math.round(o*255),green:Math.round(s*255),blue:Math.round(a*255),alpha:r}}const V=(t,n,e)=>{const r=t*t;const o=n*n;return Math.sqrt(Math.max(0,e*(o-r)+r))};const X=[P,C,x];const Y=t=>X.find((n=>n.test(t)));const Z=(t,n)=>{let e=Y(t);let r=Y(n);let o=e.parse(t);let s=r.parse(n);if(e===x){o=Q(o);e=C}if(r===x){s=Q(s);r=C}const a=Object.assign({},o);return t=>{for(const n in a){if(n!=="alpha"){a[n]=V(o[n],s[n],t)}}a.alpha=g(o.alpha,s.alpha,t);return e.transform(a)}};const tt=t=>typeof t==="number";const nt=(t,n)=>e=>n(t(e));const et=(...t)=>t.reduce(nt);function rt(t,n){if(tt(t)){return e=>g(t,n,e)}else if(U.test(t)){return Z(t,n)}else{return ct(t,n)}}const ot=(t,n)=>{const e=[...t];const r=e.length;const o=t.map(((t,e)=>rt(t,n[e])));return t=>{for(let n=0;n<r;n++){e[n]=o[n](t)}return e}};const st=(t,n)=>{const e=Object.assign(Object.assign({},t),n);const r={};for(const o in e){if(t[o]!==undefined&&n[o]!==undefined){r[o]=rt(t[o],n[o])}}return t=>{for(const n in r){e[n]=r[n](t)}return e}};function at(t){const n=J.parse(t);const e=n.length;let r=0;let o=0;let s=0;for(let t=0;t<e;t++){if(r||typeof n[t]==="number"){r++}else{if(n[t].hue!==undefined){s++}else{o++}}}return{parsed:n,numNumbers:r,numRGB:o,numHSL:s}}const ct=(t,n)=>{const e=J.createTransformer(n);const r=at(t);const o=at(n);const s=r.numHSL===o.numHSL&&r.numRGB===o.numRGB&&r.numNumbers>=o.numNumbers;if(s){return et(ot(r.parsed,o.parsed),e)}else{return e=>`${e>0?n:t}`}};const ut=(t,n)=>e=>g(t,n,e);function ft(t){if(typeof t==="number"){return ut}else if(typeof t==="string"){if(U.test(t)){return Z}else{return ct}}else if(Array.isArray(t)){return ot}else if(typeof t==="object"){return st}}function it(t,n,e){const r=[];const o=e||ft(t[0]);const s=t.length-1;for(let e=0;e<s;e++){let s=o(t[e],t[e+1]);if(n){const t=Array.isArray(n)?n[e]:n;s=et(t,s)}r.push(s)}return r}function lt([t,n],[e]){return r=>e(M(t,n,r))}function pt(t,n){const e=t.length;const r=e-1;return o=>{let s=0;let a=false;if(o<=t[0]){a=true}else if(o>=t[r]){s=r-1;a=true}if(!a){let n=1;for(;n<e;n++){if(t[n]>o||n===r){break}}s=n-1}const c=M(t[s],t[s+1],o);return n[s](c)}}function dt(t,n,{clamp:r=true,ease:o,mixer:s}={}){const a=t.length;if(t[0]>t[a-1]){t=[].concat(t);n=[].concat(n);t.reverse();n.reverse()}const c=it(n,o,s);const u=a===2?lt(t,c):pt(t,c);return r?n=>u(e(t[0],t[a-1],n)):u}const ht=t=>n=>1-t(1-n);const vt=t=>n=>n<=.5?t(2*n)/2:(2-t(2*(1-n)))/2;const mt=t=>n=>Math.pow(n,t);const bt=t=>n=>n*n*((t+1)*n-t);const Mt=t=>{const n=bt(t);return t=>(t*=2)<1?.5*n(t):.5*(2-Math.pow(2,-10*(t-1)))};const gt=1.525;const yt=4/11;const jt=8/11;const Ot=9/10;const Ft=t=>t;const Dt=mt(2);const Rt=ht(Dt);const Nt=vt(Dt);const St=t=>1-Math.sin(Math.acos(t));const Tt=ht(St);vt(Tt);const $t=bt(gt);ht($t);vt($t);Mt(gt);const wt=4356/361;const It=35442/1805;const xt=16061/1805;const At=t=>{if(t===1||t===0)return t;const n=t*t;return t<yt?7.5625*n:t<jt?9.075*n-9.9*t+3.4:t<Ot?wt*n-It*t+xt:10.8*t*t-20.52*t+10.72};ht(At);function kt(t,n){return t.map((()=>n||Nt)).splice(0,t.length-1)}function Ct(t){const n=t.length;return t.map(((t,e)=>e!==0?e/(n-1):0))}function Bt(t,n){return t.map((t=>t*n))}function Pt({from:t=0,to:n=1,ease:e,offset:r,duration:o=300}){const s={done:false,value:t};const a=Array.isArray(n)?n:[t,n];const c=Bt(r&&r.length===a.length?r:Ct(a),o);function u(){return dt(c,a,{ease:Array.isArray(e)?e:kt(a,e)})}let f=u();return{next:t=>{s.value=f(t);s.done=t>=o;return s},flipTarget:()=>{a.reverse();f=u()}}}function Ut({velocity:t=0,from:n=0,power:e=.8,timeConstant:r=350,restDelta:o=.5,modifyTarget:s}){const a={done:false,value:n};let c=e*t;const u=n+c;const f=s===undefined?u:s(u);if(f!==u)c=f-n;return{next:t=>{const n=-c*Math.exp(-t/r);a.done=!(n>o||n<-o);a.value=a.done?f:f+n;return a},flipTarget:()=>{}}}const Gt={keyframes:Pt,spring:m,decay:Ut};function Ht(t){if(Array.isArray(t.to)){return Pt}else if(Gt[t.type]){return Gt[t.type]}const n=new Set(Object.keys(t));if(n.has("ease")||n.has("duration")&&!n.has("dampingRatio")){return Pt}else if(n.has("dampingRatio")||n.has("stiffness")||n.has("mass")||n.has("damping")||n.has("restSpeed")||n.has("restDelta")){return m}return Pt}const Lt=1/60*1e3;const Wt=typeof performance!=="undefined"?()=>performance.now():()=>Date.now();const _t=typeof window!=="undefined"?t=>window.requestAnimationFrame(t):t=>setTimeout((()=>t(Wt())),Lt);function qt(t){let n=[];let e=[];let r=0;let o=false;let s=false;const a=new WeakSet;const c={schedule:(t,s=false,c=false)=>{const u=c&&o;const f=u?n:e;if(s)a.add(t);if(f.indexOf(t)===-1){f.push(t);if(u&&o)r=n.length}return t},cancel:t=>{const n=e.indexOf(t);if(n!==-1)e.splice(n,1);a.delete(t)},process:u=>{if(o){s=true;return}o=true;[n,e]=[e,n];e.length=0;r=n.length;if(r){for(let e=0;e<r;e++){const r=n[e];r(u);if(a.has(r)){c.schedule(r);t()}}}o=false;if(s){s=false;c.process(u)}}};return c}const zt=40;let Et=true;let Jt=false;let Kt=false;const Qt={delta:0,timestamp:0};const Vt=["read","update","preRender","render","postRender"];const Xt=Vt.reduce(((t,n)=>{t[n]=qt((()=>Jt=true));return t}),{});const Yt=Vt.reduce(((t,n)=>{const e=Xt[n];t[n]=(t,n=false,r=false)=>{if(!Jt)en();return e.schedule(t,n,r)};return t}),{});const Zt=Vt.reduce(((t,n)=>{t[n]=Xt[n].cancel;return t}),{});Vt.reduce(((t,n)=>{t[n]=()=>Xt[n].process(Qt);return t}),{});const tn=t=>Xt[t].process(Qt);const nn=t=>{Jt=false;Qt.delta=Et?Lt:Math.max(Math.min(t-Qt.timestamp,zt),1);Qt.timestamp=t;Kt=true;Vt.forEach(tn);Kt=false;if(Jt){Et=false;_t(nn)}};const en=()=>{Jt=true;Et=true;if(!Kt)_t(nn)};const rn=Yt;function on(t,n,e=0){return t-n-e}function sn(t,n,e=0,r=true){return r?on(n+-t,n,e):n-(t-n)+e}function an(t,n,e,r){return r?t>=n+e:t<=-e}const cn=t=>{const n=({delta:n})=>t(n);return{start:()=>rn.update(n,true),stop:()=>Zt.update(n)}};function un(n){var e,r;var{from:o,autoplay:s=true,driver:a=cn,elapsed:c=0,repeat:u=0,repeatType:f="loop",repeatDelay:i=0,onPlay:l,onStop:p,onComplete:d,onRepeat:h,onUpdate:v}=n,m=t(n,["from","autoplay","driver","elapsed","repeat","repeatType","repeatDelay","onPlay","onStop","onComplete","onRepeat","onUpdate"]);let{to:b}=m;let M;let g=0;let y=m.duration;let j;let O=false;let F=true;let D;const R=Ht(m);if((r=(e=R).needsInterpolation)===null||r===void 0?void 0:r.call(e,o,b)){D=dt([0,100],[o,b],{clamp:false});o=0;b=100}const N=R(Object.assign(Object.assign({},m),{from:o,to:b}));function S(){g++;if(f==="reverse"){F=g%2===0;c=sn(c,y,i,F)}else{c=on(c,y,i);if(f==="mirror")N.flipTarget()}O=false;h&&h()}function T(){M.stop();d&&d()}function $(t){if(!F)t=-t;c+=t;if(!O){const t=N.next(Math.max(0,c));j=t.value;if(D)j=D(j);O=F?t.done:c<=0}v===null||v===void 0?void 0:v(j);if(O){if(g===0)y!==null&&y!==void 0?y:y=c;if(g<u){an(c,y,i,F)&&S()}else{T()}}}function w(){l===null||l===void 0?void 0:l();M=a($);M.start()}s&&w();return{stop:()=>{p===null||p===void 0?void 0:p();M.stop()}}}
|
|
2
|
+
/*! *****************************************************************************
|
|
3
|
+
Copyright (c) Microsoft Corporation.
|
|
4
|
+
|
|
5
|
+
Permission to use, copy, modify, and/or distribute this software for any
|
|
6
|
+
purpose with or without fee is hereby granted.
|
|
7
|
+
|
|
8
|
+
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
|
9
|
+
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
10
|
+
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
11
|
+
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
12
|
+
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
13
|
+
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
14
|
+
PERFORMANCE OF THIS SOFTWARE.
|
|
15
|
+
***************************************************************************** */var fn=function(){fn=Object.assign||function t(n){for(var e,r=1,o=arguments.length;r<o;r++){e=arguments[r];for(var s in e)if(Object.prototype.hasOwnProperty.call(e,s))n[s]=e[s]}return n};return fn.apply(this,arguments)};function ln(t,n){var e={};for(var r in t)if(Object.prototype.hasOwnProperty.call(t,r)&&n.indexOf(r)<0)e[r]=t[r];if(t!=null&&typeof Object.getOwnPropertySymbols==="function")for(var o=0,r=Object.getOwnPropertySymbols(t);o<r.length;o++){if(n.indexOf(r[o])<0&&Object.prototype.propertyIsEnumerable.call(t,r[o]))e[r[o]]=t[r[o]]}return e}var pn=function(t,n){return function(e){return Math.max(Math.min(e,n),t)}};var dn=function(t){return t%1?Number(t.toFixed(5)):t};var hn=/^(#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\((-?[\d\.]+%?[,\s]+){2,3}\s*\/*\s*[\d\.]+%?\))$/i;var vn={test:function(t){return typeof t==="number"},parse:parseFloat,transform:function(t){return t}};var mn=fn(fn({},vn),{transform:pn(0,1)});var bn=fn(fn({},vn),{default:1});var Mn=function(t){return{test:function(n){return typeof n==="string"&&n.endsWith(t)&&n.split(" ").length===1},parse:parseFloat,transform:function(n){return""+n+t}}};var gn=Mn("deg");var yn=Mn("%");var jn=Mn("px");var On=fn(fn({},yn),{parse:function(t){return yn.parse(t)/100},transform:function(t){return yn.transform(t*100)}});var Fn=function(t){return t.substring(t.indexOf("(")+1,t.lastIndexOf(")"))};var Dn=pn(0,255);var Rn=function(t){return t.red!==undefined};var Nn=function(t){return t.hue!==undefined};function Sn(t){return Fn(t).replace(/(,|\/)/g," ").split(/ \s*/)}var Tn=function(t){return function(n){if(typeof n!=="string")return n;var e={};var r=Sn(n);for(var o=0;o<4;o++){e[t[o]]=r[o]!==undefined?parseFloat(r[o]):1}return e}};var $n=function(t){var n=t.red,e=t.green,r=t.blue,o=t.alpha,s=o===void 0?1:o;return"rgba("+n+", "+e+", "+r+", "+s+")"};var wn=function(t){var n=t.hue,e=t.saturation,r=t.lightness,o=t.alpha,s=o===void 0?1:o;return"hsla("+n+", "+e+", "+r+", "+s+")"};var In=fn(fn({},vn),{transform:function(t){return Math.round(Dn(t))}});function xn(t,n){return t.startsWith(n)&&hn.test(t)}var An={test:function(t){return typeof t==="string"?xn(t,"rgb"):Rn(t)},parse:Tn(["red","green","blue","alpha"]),transform:function(t){var n=t.red,e=t.green,r=t.blue,o=t.alpha,s=o===void 0?1:o;return $n({red:In.transform(n),green:In.transform(e),blue:In.transform(r),alpha:dn(mn.transform(s))})}};var kn={test:function(t){return typeof t==="string"?xn(t,"hsl"):Nn(t)},parse:Tn(["hue","saturation","lightness","alpha"]),transform:function(t){var n=t.hue,e=t.saturation,r=t.lightness,o=t.alpha,s=o===void 0?1:o;return wn({hue:Math.round(n),saturation:yn.transform(dn(e)),lightness:yn.transform(dn(r)),alpha:dn(mn.transform(s))})}};var Cn=fn(fn({},An),{test:function(t){return typeof t==="string"&&xn(t,"#")},parse:function(t){var n="";var e="";var r="";if(t.length>4){n=t.substr(1,2);e=t.substr(3,2);r=t.substr(5,2)}else{n=t.substr(1,1);e=t.substr(2,1);r=t.substr(3,1);n+=n;e+=e;r+=r}return{red:parseInt(n,16),green:parseInt(e,16),blue:parseInt(r,16),alpha:1}}});var Bn={test:function(t){return typeof t==="string"&&hn.test(t)||Rn(t)||Nn(t)},parse:function(t){if(An.test(t)){return An.parse(t)}else if(kn.test(t)){return kn.parse(t)}else if(Cn.test(t)){return Cn.parse(t)}return t},transform:function(t){if(Rn(t)){return An.transform(t)}else if(Nn(t)){return kn.transform(t)}return t}};export{fn as _,un as a,ln as b,Bn as c,gn as d,mn as e,On as f,Rt as g,Ft as l,vn as n,jn as p,bn as s};
|
|
16
|
+
//# sourceMappingURL=p-42ea6b74.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["__rest","s","e","t","p","Object","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","i","length","propertyIsEnumerable","warning","clamp","min","max","v","Math","safeMin","minDuration","maxDuration","minDamping","maxDamping","findSpring","duration","bounce","velocity","mass","envelope","derivative","dampingRatio","undampedFreq","exponentialDecay","delta","a","b","calcAngularFreq","c","exp","d","pow","f","g","factor","initialGuess","approximateRoot","isNaN","stiffness","damping","sqrt","rootIterations","result","durationKeys","physicsKeys","isSpringType","options","keys","some","key","undefined","getSpringOptions","springOptions","assign","isResolvedFromDuration","derived","spring","_a","from","to","restSpeed","restDelta","state","done","value","resolveSpring","zero","resolveVelocity","createSpring","initialVelocity","initialDelta","undampedAngularFreq","abs","angularFreq","sin","cos","dampedAngularFreq","freqForT","sinh","cosh","next","current","currentVelocity","isBelowVelocityThreshold","isBelowDisplacementThreshold","flipTarget","needsInterpolation","_t","progress","toFromDifference","mix","sanitize","Number","toFixed","floatRegex","colorRegex","singleColorRegex","isString","number","test","parse","parseFloat","transform","alpha","default","createUnitType","unit","endsWith","split","percent","isColorString","type","testProp","Boolean","startsWith","splitColor","aName","bName","cName","match","hsla","hue","saturation","lightness","alpha$1","round","clampRgbUnit","rgbUnit","rgba","red","green","blue","parseHex","r","substr","parseInt","hex","color","colorToken","numberToken","_b","_c","_d","analyse","values","numColors","colors","replace","push","map","numbers","tokenised","createTransformer","numValues","output","convertNumbersToZero","getAnimatableNone","parsed","transformer","complex","hueToRgb","q","hslaToRgba","mixLinearColor","fromExpo","toExpo","colorTypes","getColorType","find","mixColor","fromColorType","toColorType","fromColor","toColor","blended","isNum","combineFunctions","pipe","transformers","reduce","getMixer","origin","target","mixComplex","mixArray","blendValue","fromThis","mixObject","numNumbers","numRGB","numHSL","template","originStats","targetStats","canInterpolate","mixNumber","detectMixerFactory","Array","isArray","createMixers","ease","customMixer","mixers","mixerFactory","numMixers","mixer","easingFunction","fastInterpolate","slowInterpolate","input","inputLength","lastInputIndex","mixerIndex","foundMixerIndex","progressInRange","interpolate","isClamp","concat","reverse","interpolator","reverseEasing","easing","mirrorEasing","createExpoIn","power","createBackIn","createAnticipate","backEasing","DEFAULT_OVERSHOOT_STRENGTH","BOUNCE_FIRST_THRESHOLD","BOUNCE_SECOND_THRESHOLD","BOUNCE_THIRD_THRESHOLD","linear","easeIn","easeOut","easeInOut","circIn","acos","circOut","backIn","ca","cb","cc","bounceOut","p2","defaultEasing","splice","defaultOffset","_value","convertOffsetToTimes","offset","o","keyframes","times","createInterpolator","decay","timeConstant","modifyTarget","amplitude","ideal","types","detectAnimationFromOptions","config","Set","has","defaultTimestep","getCurrentTime","performance","now","Date","onNextFrame","window","callback","requestAnimationFrame","setTimeout","createRenderStep","runNextFrame","toRun","toRunNextFrame","numToRun","isProcessing","flushNextFrame","toKeepAlive","WeakSet","step","schedule","keepAlive","immediate","addToCurrentFrame","buffer","add","cancel","index","delete","process","frameData","maxElapsed","useDefaultElapsed","frame","timestamp","stepsOrder","steps","acc","sync","startLoop","cancelSync","processStep","stepId","processFrame","forEach","sync$1","loopElapsed","elapsed","delay","reverseElapsed","isForwardPlayback","hasRepeatDelayElapsed","framesync","update","passTimestamp","start","stop","animate","autoplay","driver","repeat","repeatMax","repeatType","repeatDelay","onPlay","onStop","onComplete","onRepeat","onUpdate","driverControls","repeatCount","computedDuration","latest","isComplete","interpolateFromNumber","animator","animation","complete","play","__assign","n","arguments","apply","this","scale","degrees","px","progressPercentage","getValueFromFunctionString","substring","lastIndexOf","isRgba","isHsla","getValuesAsArray","splitColorValues","terms","valuesArray","rgbaTemplate","hslaTemplate","colorType"],"sources":["../../node_modules/popmotion/node_modules/tslib/tslib.es6.js","../../node_modules/hey-listen/dist/hey-listen.es.js","../../node_modules/popmotion/dist/es/utils/clamp.mjs","../../node_modules/popmotion/dist/es/animations/utils/find-spring.mjs","../../node_modules/popmotion/dist/es/animations/generators/spring.mjs","../../node_modules/popmotion/dist/es/utils/progress.mjs","../../node_modules/popmotion/dist/es/utils/mix.mjs","../../node_modules/style-value-types/dist/es/utils.mjs","../../node_modules/style-value-types/dist/es/numbers/index.mjs","../../node_modules/style-value-types/dist/es/numbers/units.mjs","../../node_modules/style-value-types/dist/es/color/utils.mjs","../../node_modules/style-value-types/dist/es/color/hsla.mjs","../../node_modules/style-value-types/dist/es/color/rgba.mjs","../../node_modules/style-value-types/dist/es/color/hex.mjs","../../node_modules/style-value-types/dist/es/color/index.mjs","../../node_modules/style-value-types/dist/es/complex/index.mjs","../../node_modules/popmotion/dist/es/utils/hsla-to-rgba.mjs","../../node_modules/popmotion/dist/es/utils/mix-color.mjs","../../node_modules/popmotion/dist/es/utils/inc.mjs","../../node_modules/popmotion/dist/es/utils/pipe.mjs","../../node_modules/popmotion/dist/es/utils/mix-complex.mjs","../../node_modules/popmotion/dist/es/utils/interpolate.mjs","../../node_modules/popmotion/dist/es/easing/utils.mjs","../../node_modules/popmotion/dist/es/easing/index.mjs","../../node_modules/popmotion/dist/es/animations/generators/keyframes.mjs","../../node_modules/popmotion/dist/es/animations/generators/decay.mjs","../../node_modules/popmotion/dist/es/animations/utils/detect-animation-from-options.mjs","../../node_modules/framesync/dist/es/on-next-frame.mjs","../../node_modules/framesync/dist/es/create-render-step.mjs","../../node_modules/framesync/dist/es/index.mjs","../../node_modules/popmotion/dist/es/animations/utils/elapsed.mjs","../../node_modules/popmotion/dist/es/animations/index.mjs","../../node_modules/stylefire/node_modules/tslib/tslib.es6.js","../../node_modules/stylefire/node_modules/style-value-types/dist/style-value-types.es.js"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","var warning = function () { };\r\nvar invariant = function () { };\r\nif (process.env.NODE_ENV !== 'production') {\r\n warning = function (check, message) {\r\n if (!check && typeof console !== 'undefined') {\r\n console.warn(message);\r\n }\r\n };\r\n invariant = function (check, message) {\r\n if (!check) {\r\n throw new Error(message);\r\n }\r\n };\r\n}\n\nexport { invariant, warning };\n","const clamp = (min, max, v) => Math.min(Math.max(v, min), max);\n\nexport { clamp };\n","import { warning } from 'hey-listen';\nimport { clamp } from '../../utils/clamp.mjs';\n\nconst safeMin = 0.001;\nconst minDuration = 0.01;\nconst maxDuration = 10.0;\nconst minDamping = 0.05;\nconst maxDamping = 1;\nfunction findSpring({ duration = 800, bounce = 0.25, velocity = 0, mass = 1, }) {\n let envelope;\n let derivative;\n warning(duration <= maxDuration * 1000, \"Spring duration must be 10 seconds or less\");\n let dampingRatio = 1 - bounce;\n dampingRatio = clamp(minDamping, maxDamping, dampingRatio);\n duration = clamp(minDuration, maxDuration, duration / 1000);\n if (dampingRatio < 1) {\n envelope = (undampedFreq) => {\n const exponentialDecay = undampedFreq * dampingRatio;\n const delta = exponentialDecay * duration;\n const a = exponentialDecay - velocity;\n const b = calcAngularFreq(undampedFreq, dampingRatio);\n const c = Math.exp(-delta);\n return safeMin - (a / b) * c;\n };\n derivative = (undampedFreq) => {\n const exponentialDecay = undampedFreq * dampingRatio;\n const delta = exponentialDecay * duration;\n const d = delta * velocity + velocity;\n const e = Math.pow(dampingRatio, 2) * Math.pow(undampedFreq, 2) * duration;\n const f = Math.exp(-delta);\n const g = calcAngularFreq(Math.pow(undampedFreq, 2), dampingRatio);\n const factor = -envelope(undampedFreq) + safeMin > 0 ? -1 : 1;\n return (factor * ((d - e) * f)) / g;\n };\n }\n else {\n envelope = (undampedFreq) => {\n const a = Math.exp(-undampedFreq * duration);\n const b = (undampedFreq - velocity) * duration + 1;\n return -safeMin + a * b;\n };\n derivative = (undampedFreq) => {\n const a = Math.exp(-undampedFreq * duration);\n const b = (velocity - undampedFreq) * (duration * duration);\n return a * b;\n };\n }\n const initialGuess = 5 / duration;\n const undampedFreq = approximateRoot(envelope, derivative, initialGuess);\n duration = duration * 1000;\n if (isNaN(undampedFreq)) {\n return {\n stiffness: 100,\n damping: 10,\n duration,\n };\n }\n else {\n const stiffness = Math.pow(undampedFreq, 2) * mass;\n return {\n stiffness,\n damping: dampingRatio * 2 * Math.sqrt(mass * stiffness),\n duration,\n };\n }\n}\nconst rootIterations = 12;\nfunction approximateRoot(envelope, derivative, initialGuess) {\n let result = initialGuess;\n for (let i = 1; i < rootIterations; i++) {\n result = result - envelope(result) / derivative(result);\n }\n return result;\n}\nfunction calcAngularFreq(undampedFreq, dampingRatio) {\n return undampedFreq * Math.sqrt(1 - dampingRatio * dampingRatio);\n}\n\nexport { calcAngularFreq, findSpring, maxDamping, maxDuration, minDamping, minDuration };\n","import { __rest } from 'tslib';\nimport { findSpring, calcAngularFreq } from '../utils/find-spring.mjs';\n\nconst durationKeys = [\"duration\", \"bounce\"];\nconst physicsKeys = [\"stiffness\", \"damping\", \"mass\"];\nfunction isSpringType(options, keys) {\n return keys.some((key) => options[key] !== undefined);\n}\nfunction getSpringOptions(options) {\n let springOptions = Object.assign({ velocity: 0.0, stiffness: 100, damping: 10, mass: 1.0, isResolvedFromDuration: false }, options);\n if (!isSpringType(options, physicsKeys) &&\n isSpringType(options, durationKeys)) {\n const derived = findSpring(options);\n springOptions = Object.assign(Object.assign(Object.assign({}, springOptions), derived), { velocity: 0.0, mass: 1.0 });\n springOptions.isResolvedFromDuration = true;\n }\n return springOptions;\n}\nfunction spring(_a) {\n var { from = 0.0, to = 1.0, restSpeed = 2, restDelta } = _a, options = __rest(_a, [\"from\", \"to\", \"restSpeed\", \"restDelta\"]);\n const state = { done: false, value: from };\n let { stiffness, damping, mass, velocity, duration, isResolvedFromDuration, } = getSpringOptions(options);\n let resolveSpring = zero;\n let resolveVelocity = zero;\n function createSpring() {\n const initialVelocity = velocity ? -(velocity / 1000) : 0.0;\n const initialDelta = to - from;\n const dampingRatio = damping / (2 * Math.sqrt(stiffness * mass));\n const undampedAngularFreq = Math.sqrt(stiffness / mass) / 1000;\n if (restDelta === undefined) {\n restDelta = Math.min(Math.abs(to - from) / 100, 0.4);\n }\n if (dampingRatio < 1) {\n const angularFreq = calcAngularFreq(undampedAngularFreq, dampingRatio);\n resolveSpring = (t) => {\n const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n return (to -\n envelope *\n (((initialVelocity +\n dampingRatio * undampedAngularFreq * initialDelta) /\n angularFreq) *\n Math.sin(angularFreq * t) +\n initialDelta * Math.cos(angularFreq * t)));\n };\n resolveVelocity = (t) => {\n const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n return (dampingRatio *\n undampedAngularFreq *\n envelope *\n ((Math.sin(angularFreq * t) *\n (initialVelocity +\n dampingRatio *\n undampedAngularFreq *\n initialDelta)) /\n angularFreq +\n initialDelta * Math.cos(angularFreq * t)) -\n envelope *\n (Math.cos(angularFreq * t) *\n (initialVelocity +\n dampingRatio *\n undampedAngularFreq *\n initialDelta) -\n angularFreq *\n initialDelta *\n Math.sin(angularFreq * t)));\n };\n }\n else if (dampingRatio === 1) {\n resolveSpring = (t) => to -\n Math.exp(-undampedAngularFreq * t) *\n (initialDelta +\n (initialVelocity + undampedAngularFreq * initialDelta) *\n t);\n }\n else {\n const dampedAngularFreq = undampedAngularFreq * Math.sqrt(dampingRatio * dampingRatio - 1);\n resolveSpring = (t) => {\n const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n const freqForT = Math.min(dampedAngularFreq * t, 300);\n return (to -\n (envelope *\n ((initialVelocity +\n dampingRatio * undampedAngularFreq * initialDelta) *\n Math.sinh(freqForT) +\n dampedAngularFreq *\n initialDelta *\n Math.cosh(freqForT))) /\n dampedAngularFreq);\n };\n }\n }\n createSpring();\n return {\n next: (t) => {\n const current = resolveSpring(t);\n if (!isResolvedFromDuration) {\n const currentVelocity = resolveVelocity(t) * 1000;\n const isBelowVelocityThreshold = Math.abs(currentVelocity) <= restSpeed;\n const isBelowDisplacementThreshold = Math.abs(to - current) <= restDelta;\n state.done =\n isBelowVelocityThreshold && isBelowDisplacementThreshold;\n }\n else {\n state.done = t >= duration;\n }\n state.value = state.done ? to : current;\n return state;\n },\n flipTarget: () => {\n velocity = -velocity;\n [from, to] = [to, from];\n createSpring();\n },\n };\n}\nspring.needsInterpolation = (a, b) => typeof a === \"string\" || typeof b === \"string\";\nconst zero = (_t) => 0;\n\nexport { spring };\n","const progress = (from, to, value) => {\n const toFromDifference = to - from;\n return toFromDifference === 0 ? 1 : (value - from) / toFromDifference;\n};\n\nexport { progress };\n","const mix = (from, to, progress) => -progress * from + progress * to + from;\n\nexport { mix };\n","const clamp = (min, max) => (v) => Math.max(Math.min(v, max), min);\nconst sanitize = (v) => (v % 1 ? Number(v.toFixed(5)) : v);\nconst floatRegex = /(-)?([\\d]*\\.?[\\d])+/g;\nconst colorRegex = /(#[0-9a-f]{6}|#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\\((-?[\\d\\.]+%?[,\\s]+){2}(-?[\\d\\.]+%?)\\s*[\\,\\/]?\\s*[\\d\\.]*%?\\))/gi;\nconst singleColorRegex = /^(#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\\((-?[\\d\\.]+%?[,\\s]+){2}(-?[\\d\\.]+%?)\\s*[\\,\\/]?\\s*[\\d\\.]*%?\\))$/i;\nfunction isString(v) {\n return typeof v === 'string';\n}\n\nexport { clamp, colorRegex, floatRegex, isString, sanitize, singleColorRegex };\n","import { clamp } from '../utils.mjs';\n\nconst number = {\n test: (v) => typeof v === 'number',\n parse: parseFloat,\n transform: (v) => v,\n};\nconst alpha = Object.assign(Object.assign({}, number), { transform: clamp(0, 1) });\nconst scale = Object.assign(Object.assign({}, number), { default: 1 });\n\nexport { alpha, number, scale };\n","import { isString } from '../utils.mjs';\n\nconst createUnitType = (unit) => ({\n test: (v) => isString(v) && v.endsWith(unit) && v.split(' ').length === 1,\n parse: parseFloat,\n transform: (v) => `${v}${unit}`,\n});\nconst degrees = createUnitType('deg');\nconst percent = createUnitType('%');\nconst px = createUnitType('px');\nconst vh = createUnitType('vh');\nconst vw = createUnitType('vw');\nconst progressPercentage = Object.assign(Object.assign({}, percent), { parse: (v) => percent.parse(v) / 100, transform: (v) => percent.transform(v * 100) });\n\nexport { degrees, percent, progressPercentage, px, vh, vw };\n","import { isString, singleColorRegex, floatRegex } from '../utils.mjs';\n\nconst isColorString = (type, testProp) => (v) => {\n return Boolean((isString(v) && singleColorRegex.test(v) && v.startsWith(type)) ||\n (testProp && Object.prototype.hasOwnProperty.call(v, testProp)));\n};\nconst splitColor = (aName, bName, cName) => (v) => {\n if (!isString(v))\n return v;\n const [a, b, c, alpha] = v.match(floatRegex);\n return {\n [aName]: parseFloat(a),\n [bName]: parseFloat(b),\n [cName]: parseFloat(c),\n alpha: alpha !== undefined ? parseFloat(alpha) : 1,\n };\n};\n\nexport { isColorString, splitColor };\n","import { alpha } from '../numbers/index.mjs';\nimport { percent } from '../numbers/units.mjs';\nimport { sanitize } from '../utils.mjs';\nimport { isColorString, splitColor } from './utils.mjs';\n\nconst hsla = {\n test: isColorString('hsl', 'hue'),\n parse: splitColor('hue', 'saturation', 'lightness'),\n transform: ({ hue, saturation, lightness, alpha: alpha$1 = 1 }) => {\n return ('hsla(' +\n Math.round(hue) +\n ', ' +\n percent.transform(sanitize(saturation)) +\n ', ' +\n percent.transform(sanitize(lightness)) +\n ', ' +\n sanitize(alpha.transform(alpha$1)) +\n ')');\n },\n};\n\nexport { hsla };\n","import { number, alpha } from '../numbers/index.mjs';\nimport { sanitize, clamp } from '../utils.mjs';\nimport { isColorString, splitColor } from './utils.mjs';\n\nconst clampRgbUnit = clamp(0, 255);\nconst rgbUnit = Object.assign(Object.assign({}, number), { transform: (v) => Math.round(clampRgbUnit(v)) });\nconst rgba = {\n test: isColorString('rgb', 'red'),\n parse: splitColor('red', 'green', 'blue'),\n transform: ({ red, green, blue, alpha: alpha$1 = 1 }) => 'rgba(' +\n rgbUnit.transform(red) +\n ', ' +\n rgbUnit.transform(green) +\n ', ' +\n rgbUnit.transform(blue) +\n ', ' +\n sanitize(alpha.transform(alpha$1)) +\n ')',\n};\n\nexport { rgbUnit, rgba };\n","import { rgba } from './rgba.mjs';\nimport { isColorString } from './utils.mjs';\n\nfunction parseHex(v) {\n let r = '';\n let g = '';\n let b = '';\n let a = '';\n if (v.length > 5) {\n r = v.substr(1, 2);\n g = v.substr(3, 2);\n b = v.substr(5, 2);\n a = v.substr(7, 2);\n }\n else {\n r = v.substr(1, 1);\n g = v.substr(2, 1);\n b = v.substr(3, 1);\n a = v.substr(4, 1);\n r += r;\n g += g;\n b += b;\n a += a;\n }\n return {\n red: parseInt(r, 16),\n green: parseInt(g, 16),\n blue: parseInt(b, 16),\n alpha: a ? parseInt(a, 16) / 255 : 1,\n };\n}\nconst hex = {\n test: isColorString('#'),\n parse: parseHex,\n transform: rgba.transform,\n};\n\nexport { hex };\n","import { isString } from '../utils.mjs';\nimport { hex } from './hex.mjs';\nimport { hsla } from './hsla.mjs';\nimport { rgba } from './rgba.mjs';\n\nconst color = {\n test: (v) => rgba.test(v) || hex.test(v) || hsla.test(v),\n parse: (v) => {\n if (rgba.test(v)) {\n return rgba.parse(v);\n }\n else if (hsla.test(v)) {\n return hsla.parse(v);\n }\n else {\n return hex.parse(v);\n }\n },\n transform: (v) => {\n return isString(v)\n ? v\n : v.hasOwnProperty('red')\n ? rgba.transform(v)\n : hsla.transform(v);\n },\n};\n\nexport { color };\n","import { color } from '../color/index.mjs';\nimport { number } from '../numbers/index.mjs';\nimport { isString, floatRegex, colorRegex, sanitize } from '../utils.mjs';\n\nconst colorToken = '${c}';\nconst numberToken = '${n}';\nfunction test(v) {\n var _a, _b, _c, _d;\n return (isNaN(v) &&\n isString(v) &&\n ((_b = (_a = v.match(floatRegex)) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0) + ((_d = (_c = v.match(colorRegex)) === null || _c === void 0 ? void 0 : _c.length) !== null && _d !== void 0 ? _d : 0) > 0);\n}\nfunction analyse(v) {\n if (typeof v === 'number')\n v = `${v}`;\n const values = [];\n let numColors = 0;\n const colors = v.match(colorRegex);\n if (colors) {\n numColors = colors.length;\n v = v.replace(colorRegex, colorToken);\n values.push(...colors.map(color.parse));\n }\n const numbers = v.match(floatRegex);\n if (numbers) {\n v = v.replace(floatRegex, numberToken);\n values.push(...numbers.map(number.parse));\n }\n return { values, numColors, tokenised: v };\n}\nfunction parse(v) {\n return analyse(v).values;\n}\nfunction createTransformer(v) {\n const { values, numColors, tokenised } = analyse(v);\n const numValues = values.length;\n return (v) => {\n let output = tokenised;\n for (let i = 0; i < numValues; i++) {\n output = output.replace(i < numColors ? colorToken : numberToken, i < numColors ? color.transform(v[i]) : sanitize(v[i]));\n }\n return output;\n };\n}\nconst convertNumbersToZero = (v) => typeof v === 'number' ? 0 : v;\nfunction getAnimatableNone(v) {\n const parsed = parse(v);\n const transformer = createTransformer(v);\n return transformer(parsed.map(convertNumbersToZero));\n}\nconst complex = { test, parse, createTransformer, getAnimatableNone };\n\nexport { complex };\n","function hueToRgb(p, q, t) {\n if (t < 0)\n t += 1;\n if (t > 1)\n t -= 1;\n if (t < 1 / 6)\n return p + (q - p) * 6 * t;\n if (t < 1 / 2)\n return q;\n if (t < 2 / 3)\n return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n}\nfunction hslaToRgba({ hue, saturation, lightness, alpha }) {\n hue /= 360;\n saturation /= 100;\n lightness /= 100;\n let red = 0;\n let green = 0;\n let blue = 0;\n if (!saturation) {\n red = green = blue = lightness;\n }\n else {\n const q = lightness < 0.5\n ? lightness * (1 + saturation)\n : lightness + saturation - lightness * saturation;\n const p = 2 * lightness - q;\n red = hueToRgb(p, q, hue + 1 / 3);\n green = hueToRgb(p, q, hue);\n blue = hueToRgb(p, q, hue - 1 / 3);\n }\n return {\n red: Math.round(red * 255),\n green: Math.round(green * 255),\n blue: Math.round(blue * 255),\n alpha,\n };\n}\n\nexport { hslaToRgba };\n","import { mix } from './mix.mjs';\nimport { hsla, rgba, hex } from 'style-value-types';\nimport { invariant } from 'hey-listen';\nimport { hslaToRgba } from './hsla-to-rgba.mjs';\n\nconst mixLinearColor = (from, to, v) => {\n const fromExpo = from * from;\n const toExpo = to * to;\n return Math.sqrt(Math.max(0, v * (toExpo - fromExpo) + fromExpo));\n};\nconst colorTypes = [hex, rgba, hsla];\nconst getColorType = (v) => colorTypes.find((type) => type.test(v));\nconst notAnimatable = (color) => `'${color}' is not an animatable color. Use the equivalent color code instead.`;\nconst mixColor = (from, to) => {\n let fromColorType = getColorType(from);\n let toColorType = getColorType(to);\n invariant(!!fromColorType, notAnimatable(from));\n invariant(!!toColorType, notAnimatable(to));\n let fromColor = fromColorType.parse(from);\n let toColor = toColorType.parse(to);\n if (fromColorType === hsla) {\n fromColor = hslaToRgba(fromColor);\n fromColorType = rgba;\n }\n if (toColorType === hsla) {\n toColor = hslaToRgba(toColor);\n toColorType = rgba;\n }\n const blended = Object.assign({}, fromColor);\n return (v) => {\n for (const key in blended) {\n if (key !== \"alpha\") {\n blended[key] = mixLinearColor(fromColor[key], toColor[key], v);\n }\n }\n blended.alpha = mix(fromColor.alpha, toColor.alpha, v);\n return fromColorType.transform(blended);\n };\n};\n\nexport { mixColor, mixLinearColor };\n","const zeroPoint = {\n x: 0,\n y: 0,\n z: 0\n};\nconst isNum = (v) => typeof v === 'number';\n\nexport { isNum, zeroPoint };\n","const combineFunctions = (a, b) => (v) => b(a(v));\nconst pipe = (...transformers) => transformers.reduce(combineFunctions);\n\nexport { pipe };\n","import { complex, color } from 'style-value-types';\nimport { mix } from './mix.mjs';\nimport { mixColor } from './mix-color.mjs';\nimport { isNum } from './inc.mjs';\nimport { pipe } from './pipe.mjs';\nimport { warning } from 'hey-listen';\n\nfunction getMixer(origin, target) {\n if (isNum(origin)) {\n return (v) => mix(origin, target, v);\n }\n else if (color.test(origin)) {\n return mixColor(origin, target);\n }\n else {\n return mixComplex(origin, target);\n }\n}\nconst mixArray = (from, to) => {\n const output = [...from];\n const numValues = output.length;\n const blendValue = from.map((fromThis, i) => getMixer(fromThis, to[i]));\n return (v) => {\n for (let i = 0; i < numValues; i++) {\n output[i] = blendValue[i](v);\n }\n return output;\n };\n};\nconst mixObject = (origin, target) => {\n const output = Object.assign(Object.assign({}, origin), target);\n const blendValue = {};\n for (const key in output) {\n if (origin[key] !== undefined && target[key] !== undefined) {\n blendValue[key] = getMixer(origin[key], target[key]);\n }\n }\n return (v) => {\n for (const key in blendValue) {\n output[key] = blendValue[key](v);\n }\n return output;\n };\n};\nfunction analyse(value) {\n const parsed = complex.parse(value);\n const numValues = parsed.length;\n let numNumbers = 0;\n let numRGB = 0;\n let numHSL = 0;\n for (let i = 0; i < numValues; i++) {\n if (numNumbers || typeof parsed[i] === \"number\") {\n numNumbers++;\n }\n else {\n if (parsed[i].hue !== undefined) {\n numHSL++;\n }\n else {\n numRGB++;\n }\n }\n }\n return { parsed, numNumbers, numRGB, numHSL };\n}\nconst mixComplex = (origin, target) => {\n const template = complex.createTransformer(target);\n const originStats = analyse(origin);\n const targetStats = analyse(target);\n const canInterpolate = originStats.numHSL === targetStats.numHSL &&\n originStats.numRGB === targetStats.numRGB &&\n originStats.numNumbers >= targetStats.numNumbers;\n if (canInterpolate) {\n return pipe(mixArray(originStats.parsed, targetStats.parsed), template);\n }\n else {\n warning(true, `Complex values '${origin}' and '${target}' too different to mix. Ensure all colors are of the same type, and that each contains the same quantity of number and color values. Falling back to instant transition.`);\n return (p) => `${p > 0 ? target : origin}`;\n }\n};\n\nexport { mixArray, mixComplex, mixObject };\n","import { progress } from './progress.mjs';\nimport { mix } from './mix.mjs';\nimport { mixColor } from './mix-color.mjs';\nimport { mixComplex, mixArray, mixObject } from './mix-complex.mjs';\nimport { color } from 'style-value-types';\nimport { clamp } from './clamp.mjs';\nimport { pipe } from './pipe.mjs';\nimport { invariant } from 'hey-listen';\n\nconst mixNumber = (from, to) => (p) => mix(from, to, p);\nfunction detectMixerFactory(v) {\n if (typeof v === 'number') {\n return mixNumber;\n }\n else if (typeof v === 'string') {\n if (color.test(v)) {\n return mixColor;\n }\n else {\n return mixComplex;\n }\n }\n else if (Array.isArray(v)) {\n return mixArray;\n }\n else if (typeof v === 'object') {\n return mixObject;\n }\n}\nfunction createMixers(output, ease, customMixer) {\n const mixers = [];\n const mixerFactory = customMixer || detectMixerFactory(output[0]);\n const numMixers = output.length - 1;\n for (let i = 0; i < numMixers; i++) {\n let mixer = mixerFactory(output[i], output[i + 1]);\n if (ease) {\n const easingFunction = Array.isArray(ease) ? ease[i] : ease;\n mixer = pipe(easingFunction, mixer);\n }\n mixers.push(mixer);\n }\n return mixers;\n}\nfunction fastInterpolate([from, to], [mixer]) {\n return (v) => mixer(progress(from, to, v));\n}\nfunction slowInterpolate(input, mixers) {\n const inputLength = input.length;\n const lastInputIndex = inputLength - 1;\n return (v) => {\n let mixerIndex = 0;\n let foundMixerIndex = false;\n if (v <= input[0]) {\n foundMixerIndex = true;\n }\n else if (v >= input[lastInputIndex]) {\n mixerIndex = lastInputIndex - 1;\n foundMixerIndex = true;\n }\n if (!foundMixerIndex) {\n let i = 1;\n for (; i < inputLength; i++) {\n if (input[i] > v || i === lastInputIndex) {\n break;\n }\n }\n mixerIndex = i - 1;\n }\n const progressInRange = progress(input[mixerIndex], input[mixerIndex + 1], v);\n return mixers[mixerIndex](progressInRange);\n };\n}\nfunction interpolate(input, output, { clamp: isClamp = true, ease, mixer } = {}) {\n const inputLength = input.length;\n invariant(inputLength === output.length, 'Both input and output ranges must be the same length');\n invariant(!ease || !Array.isArray(ease) || ease.length === inputLength - 1, 'Array of easing functions must be of length `input.length - 1`, as it applies to the transitions **between** the defined values.');\n if (input[0] > input[inputLength - 1]) {\n input = [].concat(input);\n output = [].concat(output);\n input.reverse();\n output.reverse();\n }\n const mixers = createMixers(output, ease, mixer);\n const interpolator = inputLength === 2\n ? fastInterpolate(input, mixers)\n : slowInterpolate(input, mixers);\n return isClamp\n ? (v) => interpolator(clamp(input[0], input[inputLength - 1], v))\n : interpolator;\n}\n\nexport { interpolate };\n","const reverseEasing = easing => p => 1 - easing(1 - p);\nconst mirrorEasing = easing => p => p <= 0.5 ? easing(2 * p) / 2 : (2 - easing(2 * (1 - p))) / 2;\nconst createExpoIn = (power) => p => Math.pow(p, power);\nconst createBackIn = (power) => p => p * p * ((power + 1) * p - power);\nconst createAnticipate = (power) => {\n const backEasing = createBackIn(power);\n return p => (p *= 2) < 1\n ? 0.5 * backEasing(p)\n : 0.5 * (2 - Math.pow(2, -10 * (p - 1)));\n};\n\nexport { createAnticipate, createBackIn, createExpoIn, mirrorEasing, reverseEasing };\n","import { createExpoIn, reverseEasing, mirrorEasing, createBackIn, createAnticipate } from './utils.mjs';\n\nconst DEFAULT_OVERSHOOT_STRENGTH = 1.525;\nconst BOUNCE_FIRST_THRESHOLD = 4.0 / 11.0;\nconst BOUNCE_SECOND_THRESHOLD = 8.0 / 11.0;\nconst BOUNCE_THIRD_THRESHOLD = 9.0 / 10.0;\nconst linear = p => p;\nconst easeIn = createExpoIn(2);\nconst easeOut = reverseEasing(easeIn);\nconst easeInOut = mirrorEasing(easeIn);\nconst circIn = p => 1 - Math.sin(Math.acos(p));\nconst circOut = reverseEasing(circIn);\nconst circInOut = mirrorEasing(circOut);\nconst backIn = createBackIn(DEFAULT_OVERSHOOT_STRENGTH);\nconst backOut = reverseEasing(backIn);\nconst backInOut = mirrorEasing(backIn);\nconst anticipate = createAnticipate(DEFAULT_OVERSHOOT_STRENGTH);\nconst ca = 4356.0 / 361.0;\nconst cb = 35442.0 / 1805.0;\nconst cc = 16061.0 / 1805.0;\nconst bounceOut = (p) => {\n if (p === 1 || p === 0)\n return p;\n const p2 = p * p;\n return p < BOUNCE_FIRST_THRESHOLD\n ? 7.5625 * p2\n : p < BOUNCE_SECOND_THRESHOLD\n ? 9.075 * p2 - 9.9 * p + 3.4\n : p < BOUNCE_THIRD_THRESHOLD\n ? ca * p2 - cb * p + cc\n : 10.8 * p * p - 20.52 * p + 10.72;\n};\nconst bounceIn = reverseEasing(bounceOut);\nconst bounceInOut = (p) => p < 0.5\n ? 0.5 * (1.0 - bounceOut(1.0 - p * 2.0))\n : 0.5 * bounceOut(p * 2.0 - 1.0) + 0.5;\n\nexport { anticipate, backIn, backInOut, backOut, bounceIn, bounceInOut, bounceOut, circIn, circInOut, circOut, easeIn, easeInOut, easeOut, linear };\n","import { interpolate } from '../../utils/interpolate.mjs';\nimport { easeInOut } from '../../easing/index.mjs';\n\nfunction defaultEasing(values, easing) {\n return values.map(() => easing || easeInOut).splice(0, values.length - 1);\n}\nfunction defaultOffset(values) {\n const numValues = values.length;\n return values.map((_value, i) => i !== 0 ? i / (numValues - 1) : 0);\n}\nfunction convertOffsetToTimes(offset, duration) {\n return offset.map((o) => o * duration);\n}\nfunction keyframes({ from = 0, to = 1, ease, offset, duration = 300, }) {\n const state = { done: false, value: from };\n const values = Array.isArray(to) ? to : [from, to];\n const times = convertOffsetToTimes(offset && offset.length === values.length\n ? offset\n : defaultOffset(values), duration);\n function createInterpolator() {\n return interpolate(times, values, {\n ease: Array.isArray(ease) ? ease : defaultEasing(values, ease),\n });\n }\n let interpolator = createInterpolator();\n return {\n next: (t) => {\n state.value = interpolator(t);\n state.done = t >= duration;\n return state;\n },\n flipTarget: () => {\n values.reverse();\n interpolator = createInterpolator();\n },\n };\n}\n\nexport { convertOffsetToTimes, defaultEasing, defaultOffset, keyframes };\n","function decay({ velocity = 0, from = 0, power = 0.8, timeConstant = 350, restDelta = 0.5, modifyTarget, }) {\n const state = { done: false, value: from };\n let amplitude = power * velocity;\n const ideal = from + amplitude;\n const target = modifyTarget === undefined ? ideal : modifyTarget(ideal);\n if (target !== ideal)\n amplitude = target - from;\n return {\n next: (t) => {\n const delta = -amplitude * Math.exp(-t / timeConstant);\n state.done = !(delta > restDelta || delta < -restDelta);\n state.value = state.done ? target : target + delta;\n return state;\n },\n flipTarget: () => { },\n };\n}\n\nexport { decay };\n","import { spring } from '../generators/spring.mjs';\nimport { keyframes } from '../generators/keyframes.mjs';\nimport { decay } from '../generators/decay.mjs';\n\nconst types = { keyframes, spring, decay };\nfunction detectAnimationFromOptions(config) {\n if (Array.isArray(config.to)) {\n return keyframes;\n }\n else if (types[config.type]) {\n return types[config.type];\n }\n const keys = new Set(Object.keys(config));\n if (keys.has(\"ease\") ||\n (keys.has(\"duration\") && !keys.has(\"dampingRatio\"))) {\n return keyframes;\n }\n else if (keys.has(\"dampingRatio\") ||\n keys.has(\"stiffness\") ||\n keys.has(\"mass\") ||\n keys.has(\"damping\") ||\n keys.has(\"restSpeed\") ||\n keys.has(\"restDelta\")) {\n return spring;\n }\n return keyframes;\n}\n\nexport { detectAnimationFromOptions };\n","const defaultTimestep = (1 / 60) * 1000;\nconst getCurrentTime = typeof performance !== \"undefined\"\n ? () => performance.now()\n : () => Date.now();\nconst onNextFrame = typeof window !== \"undefined\"\n ? (callback) => window.requestAnimationFrame(callback)\n : (callback) => setTimeout(() => callback(getCurrentTime()), defaultTimestep);\n\nexport { defaultTimestep, onNextFrame };\n","function createRenderStep(runNextFrame) {\n let toRun = [];\n let toRunNextFrame = [];\n let numToRun = 0;\n let isProcessing = false;\n let flushNextFrame = false;\n const toKeepAlive = new WeakSet();\n const step = {\n schedule: (callback, keepAlive = false, immediate = false) => {\n const addToCurrentFrame = immediate && isProcessing;\n const buffer = addToCurrentFrame ? toRun : toRunNextFrame;\n if (keepAlive)\n toKeepAlive.add(callback);\n if (buffer.indexOf(callback) === -1) {\n buffer.push(callback);\n if (addToCurrentFrame && isProcessing)\n numToRun = toRun.length;\n }\n return callback;\n },\n cancel: (callback) => {\n const index = toRunNextFrame.indexOf(callback);\n if (index !== -1)\n toRunNextFrame.splice(index, 1);\n toKeepAlive.delete(callback);\n },\n process: (frameData) => {\n if (isProcessing) {\n flushNextFrame = true;\n return;\n }\n isProcessing = true;\n [toRun, toRunNextFrame] = [toRunNextFrame, toRun];\n toRunNextFrame.length = 0;\n numToRun = toRun.length;\n if (numToRun) {\n for (let i = 0; i < numToRun; i++) {\n const callback = toRun[i];\n callback(frameData);\n if (toKeepAlive.has(callback)) {\n step.schedule(callback);\n runNextFrame();\n }\n }\n }\n isProcessing = false;\n if (flushNextFrame) {\n flushNextFrame = false;\n step.process(frameData);\n }\n },\n };\n return step;\n}\n\nexport { createRenderStep };\n","import { onNextFrame, defaultTimestep } from './on-next-frame.mjs';\nimport { createRenderStep } from './create-render-step.mjs';\n\nconst maxElapsed = 40;\nlet useDefaultElapsed = true;\nlet runNextFrame = false;\nlet isProcessing = false;\nconst frame = {\n delta: 0,\n timestamp: 0,\n};\nconst stepsOrder = [\n \"read\",\n \"update\",\n \"preRender\",\n \"render\",\n \"postRender\",\n];\nconst steps = stepsOrder.reduce((acc, key) => {\n acc[key] = createRenderStep(() => (runNextFrame = true));\n return acc;\n}, {});\nconst sync = stepsOrder.reduce((acc, key) => {\n const step = steps[key];\n acc[key] = (process, keepAlive = false, immediate = false) => {\n if (!runNextFrame)\n startLoop();\n return step.schedule(process, keepAlive, immediate);\n };\n return acc;\n}, {});\nconst cancelSync = stepsOrder.reduce((acc, key) => {\n acc[key] = steps[key].cancel;\n return acc;\n}, {});\nconst flushSync = stepsOrder.reduce((acc, key) => {\n acc[key] = () => steps[key].process(frame);\n return acc;\n}, {});\nconst processStep = (stepId) => steps[stepId].process(frame);\nconst processFrame = (timestamp) => {\n runNextFrame = false;\n frame.delta = useDefaultElapsed\n ? defaultTimestep\n : Math.max(Math.min(timestamp - frame.timestamp, maxElapsed), 1);\n frame.timestamp = timestamp;\n isProcessing = true;\n stepsOrder.forEach(processStep);\n isProcessing = false;\n if (runNextFrame) {\n useDefaultElapsed = false;\n onNextFrame(processFrame);\n }\n};\nconst startLoop = () => {\n runNextFrame = true;\n useDefaultElapsed = true;\n if (!isProcessing)\n onNextFrame(processFrame);\n};\nconst getFrameData = () => frame;\n\nexport default sync;\nexport { cancelSync, flushSync, getFrameData };\n","function loopElapsed(elapsed, duration, delay = 0) {\n return elapsed - duration - delay;\n}\nfunction reverseElapsed(elapsed, duration, delay = 0, isForwardPlayback = true) {\n return isForwardPlayback\n ? loopElapsed(duration + -elapsed, duration, delay)\n : duration - (elapsed - duration) + delay;\n}\nfunction hasRepeatDelayElapsed(elapsed, duration, delay, isForwardPlayback) {\n return isForwardPlayback ? elapsed >= duration + delay : elapsed <= -delay;\n}\n\nexport { hasRepeatDelayElapsed, loopElapsed, reverseElapsed };\n","import { __rest } from 'tslib';\nimport { detectAnimationFromOptions } from './utils/detect-animation-from-options.mjs';\nimport sync, { cancelSync } from 'framesync';\nimport { interpolate } from '../utils/interpolate.mjs';\nimport { hasRepeatDelayElapsed, reverseElapsed, loopElapsed } from './utils/elapsed.mjs';\n\nconst framesync = (update) => {\n const passTimestamp = ({ delta }) => update(delta);\n return {\n start: () => sync.update(passTimestamp, true),\n stop: () => cancelSync.update(passTimestamp),\n };\n};\nfunction animate(_a) {\n var _b, _c;\n var { from, autoplay = true, driver = framesync, elapsed = 0, repeat: repeatMax = 0, repeatType = \"loop\", repeatDelay = 0, onPlay, onStop, onComplete, onRepeat, onUpdate } = _a, options = __rest(_a, [\"from\", \"autoplay\", \"driver\", \"elapsed\", \"repeat\", \"repeatType\", \"repeatDelay\", \"onPlay\", \"onStop\", \"onComplete\", \"onRepeat\", \"onUpdate\"]);\n let { to } = options;\n let driverControls;\n let repeatCount = 0;\n let computedDuration = options.duration;\n let latest;\n let isComplete = false;\n let isForwardPlayback = true;\n let interpolateFromNumber;\n const animator = detectAnimationFromOptions(options);\n if ((_c = (_b = animator).needsInterpolation) === null || _c === void 0 ? void 0 : _c.call(_b, from, to)) {\n interpolateFromNumber = interpolate([0, 100], [from, to], {\n clamp: false,\n });\n from = 0;\n to = 100;\n }\n const animation = animator(Object.assign(Object.assign({}, options), { from, to }));\n function repeat() {\n repeatCount++;\n if (repeatType === \"reverse\") {\n isForwardPlayback = repeatCount % 2 === 0;\n elapsed = reverseElapsed(elapsed, computedDuration, repeatDelay, isForwardPlayback);\n }\n else {\n elapsed = loopElapsed(elapsed, computedDuration, repeatDelay);\n if (repeatType === \"mirror\")\n animation.flipTarget();\n }\n isComplete = false;\n onRepeat && onRepeat();\n }\n function complete() {\n driverControls.stop();\n onComplete && onComplete();\n }\n function update(delta) {\n if (!isForwardPlayback)\n delta = -delta;\n elapsed += delta;\n if (!isComplete) {\n const state = animation.next(Math.max(0, elapsed));\n latest = state.value;\n if (interpolateFromNumber)\n latest = interpolateFromNumber(latest);\n isComplete = isForwardPlayback ? state.done : elapsed <= 0;\n }\n onUpdate === null || onUpdate === void 0 ? void 0 : onUpdate(latest);\n if (isComplete) {\n if (repeatCount === 0)\n computedDuration !== null && computedDuration !== void 0 ? computedDuration : (computedDuration = elapsed);\n if (repeatCount < repeatMax) {\n hasRepeatDelayElapsed(elapsed, computedDuration, repeatDelay, isForwardPlayback) && repeat();\n }\n else {\n complete();\n }\n }\n }\n function play() {\n onPlay === null || onPlay === void 0 ? void 0 : onPlay();\n driverControls = driver(update);\n driverControls.start();\n }\n autoplay && play();\n return {\n stop: () => {\n onStop === null || onStop === void 0 ? void 0 : onStop();\n driverControls.stop();\n },\n };\n}\n\nexport { animate };\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport function __createBinding(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n result.default = mod;\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","import { __assign } from 'tslib';\n\nvar clamp = function (min, max) { return function (v) {\r\n return Math.max(Math.min(v, max), min);\r\n}; };\r\nvar sanitize = function (v) { return (v % 1 ? Number(v.toFixed(5)) : v); };\r\nvar floatRegex = /(-)?(\\d[\\d\\.]*)/g;\r\nvar colorRegex = /(#[0-9a-f]{6}|#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\\((-?[\\d\\.]+%?[,\\s]+){2,3}\\s*\\/*\\s*[\\d\\.]+%?\\))/gi;\r\nvar singleColorRegex = /^(#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\\((-?[\\d\\.]+%?[,\\s]+){2,3}\\s*\\/*\\s*[\\d\\.]+%?\\))$/i;\n\nvar number = {\r\n test: function (v) { return typeof v === 'number'; },\r\n parse: parseFloat,\r\n transform: function (v) { return v; }\r\n};\r\nvar alpha = __assign(__assign({}, number), { transform: clamp(0, 1) });\r\nvar scale = __assign(__assign({}, number), { default: 1 });\n\nvar createUnitType = function (unit) { return ({\r\n test: function (v) {\r\n return typeof v === 'string' && v.endsWith(unit) && v.split(' ').length === 1;\r\n },\r\n parse: parseFloat,\r\n transform: function (v) { return \"\" + v + unit; }\r\n}); };\r\nvar degrees = createUnitType('deg');\r\nvar percent = createUnitType('%');\r\nvar px = createUnitType('px');\r\nvar vh = createUnitType('vh');\r\nvar vw = createUnitType('vw');\r\nvar progressPercentage = __assign(__assign({}, percent), { parse: function (v) { return percent.parse(v) / 100; }, transform: function (v) { return percent.transform(v * 100); } });\n\nvar getValueFromFunctionString = function (value) {\r\n return value.substring(value.indexOf('(') + 1, value.lastIndexOf(')'));\r\n};\r\nvar clampRgbUnit = clamp(0, 255);\r\nvar isRgba = function (v) { return v.red !== undefined; };\r\nvar isHsla = function (v) { return v.hue !== undefined; };\r\nfunction getValuesAsArray(value) {\r\n return getValueFromFunctionString(value)\r\n .replace(/(,|\\/)/g, ' ')\r\n .split(/ \\s*/);\r\n}\r\nvar splitColorValues = function (terms) {\r\n return function (v) {\r\n if (typeof v !== 'string')\r\n return v;\r\n var values = {};\r\n var valuesArray = getValuesAsArray(v);\r\n for (var i = 0; i < 4; i++) {\r\n values[terms[i]] =\r\n valuesArray[i] !== undefined ? parseFloat(valuesArray[i]) : 1;\r\n }\r\n return values;\r\n };\r\n};\r\nvar rgbaTemplate = function (_a) {\r\n var red = _a.red, green = _a.green, blue = _a.blue, _b = _a.alpha, alpha = _b === void 0 ? 1 : _b;\r\n return \"rgba(\" + red + \", \" + green + \", \" + blue + \", \" + alpha + \")\";\r\n};\r\nvar hslaTemplate = function (_a) {\r\n var hue = _a.hue, saturation = _a.saturation, lightness = _a.lightness, _b = _a.alpha, alpha = _b === void 0 ? 1 : _b;\r\n return \"hsla(\" + hue + \", \" + saturation + \", \" + lightness + \", \" + alpha + \")\";\r\n};\r\nvar rgbUnit = __assign(__assign({}, number), { transform: function (v) { return Math.round(clampRgbUnit(v)); } });\r\nfunction isColorString(color, colorType) {\r\n return color.startsWith(colorType) && singleColorRegex.test(color);\r\n}\r\nvar rgba = {\r\n test: function (v) { return (typeof v === 'string' ? isColorString(v, 'rgb') : isRgba(v)); },\r\n parse: splitColorValues(['red', 'green', 'blue', 'alpha']),\r\n transform: function (_a) {\r\n var red = _a.red, green = _a.green, blue = _a.blue, _b = _a.alpha, alpha$1 = _b === void 0 ? 1 : _b;\r\n return rgbaTemplate({\r\n red: rgbUnit.transform(red),\r\n green: rgbUnit.transform(green),\r\n blue: rgbUnit.transform(blue),\r\n alpha: sanitize(alpha.transform(alpha$1))\r\n });\r\n }\r\n};\r\nvar hsla = {\r\n test: function (v) { return (typeof v === 'string' ? isColorString(v, 'hsl') : isHsla(v)); },\r\n parse: splitColorValues(['hue', 'saturation', 'lightness', 'alpha']),\r\n transform: function (_a) {\r\n var hue = _a.hue, saturation = _a.saturation, lightness = _a.lightness, _b = _a.alpha, alpha$1 = _b === void 0 ? 1 : _b;\r\n return hslaTemplate({\r\n hue: Math.round(hue),\r\n saturation: percent.transform(sanitize(saturation)),\r\n lightness: percent.transform(sanitize(lightness)),\r\n alpha: sanitize(alpha.transform(alpha$1))\r\n });\r\n }\r\n};\r\nvar hex = __assign(__assign({}, rgba), { test: function (v) { return typeof v === 'string' && isColorString(v, '#'); }, parse: function (v) {\r\n var r = '';\r\n var g = '';\r\n var b = '';\r\n if (v.length > 4) {\r\n r = v.substr(1, 2);\r\n g = v.substr(3, 2);\r\n b = v.substr(5, 2);\r\n }\r\n else {\r\n r = v.substr(1, 1);\r\n g = v.substr(2, 1);\r\n b = v.substr(3, 1);\r\n r += r;\r\n g += g;\r\n b += b;\r\n }\r\n return {\r\n red: parseInt(r, 16),\r\n green: parseInt(g, 16),\r\n blue: parseInt(b, 16),\r\n alpha: 1\r\n };\r\n } });\r\nvar color = {\r\n test: function (v) {\r\n return (typeof v === 'string' && singleColorRegex.test(v)) ||\r\n isRgba(v) ||\r\n isHsla(v);\r\n },\r\n parse: function (v) {\r\n if (rgba.test(v)) {\r\n return rgba.parse(v);\r\n }\r\n else if (hsla.test(v)) {\r\n return hsla.parse(v);\r\n }\r\n else if (hex.test(v)) {\r\n return hex.parse(v);\r\n }\r\n return v;\r\n },\r\n transform: function (v) {\r\n if (isRgba(v)) {\r\n return rgba.transform(v);\r\n }\r\n else if (isHsla(v)) {\r\n return hsla.transform(v);\r\n }\r\n return v;\r\n }\r\n};\n\nvar COLOR_TOKEN = '${c}';\r\nvar NUMBER_TOKEN = '${n}';\r\nvar convertNumbersToZero = function (v) {\r\n return typeof v === 'number' ? 0 : v;\r\n};\r\nvar complex = {\r\n test: function (v) {\r\n if (typeof v !== 'string' || !isNaN(v))\r\n return false;\r\n var numValues = 0;\r\n var foundNumbers = v.match(floatRegex);\r\n var foundColors = v.match(colorRegex);\r\n if (foundNumbers)\r\n numValues += foundNumbers.length;\r\n if (foundColors)\r\n numValues += foundColors.length;\r\n return numValues > 0;\r\n },\r\n parse: function (v) {\r\n var input = v;\r\n var parsed = [];\r\n var foundColors = input.match(colorRegex);\r\n if (foundColors) {\r\n input = input.replace(colorRegex, COLOR_TOKEN);\r\n parsed.push.apply(parsed, foundColors.map(color.parse));\r\n }\r\n var foundNumbers = input.match(floatRegex);\r\n if (foundNumbers) {\r\n parsed.push.apply(parsed, foundNumbers.map(number.parse));\r\n }\r\n return parsed;\r\n },\r\n createTransformer: function (prop) {\r\n var template = prop;\r\n var token = 0;\r\n var foundColors = prop.match(colorRegex);\r\n var numColors = foundColors ? foundColors.length : 0;\r\n if (foundColors) {\r\n for (var i = 0; i < numColors; i++) {\r\n template = template.replace(foundColors[i], COLOR_TOKEN);\r\n token++;\r\n }\r\n }\r\n var foundNumbers = template.match(floatRegex);\r\n var numNumbers = foundNumbers ? foundNumbers.length : 0;\r\n if (foundNumbers) {\r\n for (var i = 0; i < numNumbers; i++) {\r\n template = template.replace(foundNumbers[i], NUMBER_TOKEN);\r\n token++;\r\n }\r\n }\r\n return function (v) {\r\n var output = template;\r\n for (var i = 0; i < token; i++) {\r\n output = output.replace(i < numColors ? COLOR_TOKEN : NUMBER_TOKEN, i < numColors ? color.transform(v[i]) : sanitize(v[i]));\r\n }\r\n return output;\r\n };\r\n },\r\n getAnimatableNone: function (target) {\r\n var parsedTarget = complex.parse(target);\r\n var targetTransformer = complex.createTransformer(target);\r\n return targetTransformer(parsedTarget.map(convertNumbersToZero));\r\n }\r\n};\n\nexport { alpha, color, complex, degrees, hex, hsla, number, percent, progressPercentage, px, rgbUnit, rgba, scale, vh, vw };\n"],"mappings":"AA0CO,SAASA,EAAOC,EAAGC,GACtB,IAAIC,EAAI,GACR,IAAK,IAAIC,KAAKH,EAAG,GAAII,OAAOC,UAAUC,eAAeC,KAAKP,EAAGG,IAAMF,EAAEO,QAAQL,GAAK,EAC9ED,EAAEC,GAAKH,EAAEG,GACb,GAAIH,GAAK,aAAeI,OAAOK,wBAA0B,WACrD,IAAK,IAAIC,EAAI,EAAGP,EAAIC,OAAOK,sBAAsBT,GAAIU,EAAIP,EAAEQ,OAAQD,IAAK,CACpE,GAAIT,EAAEO,QAAQL,EAAEO,IAAM,GAAKN,OAAOC,UAAUO,qBAAqBL,KAAKP,EAAGG,EAAEO,IACvER,EAAEC,EAAEO,IAAMV,EAAEG,EAAEO,GAC9B,CACI,OAAOR,CACX,CCpDA,IAAIW,EAAU,WAAY,ECA1B,MAAMC,EAAQ,CAACC,EAAKC,EAAKC,IAAMC,KAAKH,IAAIG,KAAKF,IAAIC,EAAGF,GAAMC,GCG1D,MAAMG,EAAU,KAChB,MAAMC,EAAc,IACpB,MAAMC,EAAc,GACpB,MAAMC,EAAa,IACnB,MAAMC,EAAa,EACnB,SAASC,GAAWC,SAAEA,EAAW,IAAGC,OAAEA,EAAS,IAAIC,SAAEA,EAAW,EAACC,KAAEA,EAAO,IACtE,IAAIC,EACJ,IAAIC,EACJjB,EAAQY,GAAYJ,EAAc,KAClC,IAAIU,EAAe,EAAIL,EACvBK,EAAejB,EAAMQ,EAAYC,EAAYQ,GAC7CN,EAAWX,EAAMM,EAAaC,EAAaI,EAAW,KACtD,GAAIM,EAAe,EAAG,CAClBF,EAAYG,IACR,MAAMC,EAAmBD,EAAeD,EACxC,MAAMG,EAAQD,EAAmBR,EACjC,MAAMU,EAAIF,EAAmBN,EAC7B,MAAMS,EAAIC,EAAgBL,EAAcD,GACxC,MAAMO,EAAIpB,KAAKqB,KAAKL,GACpB,OAAOf,EAAWgB,EAAIC,EAAKE,CAAC,EAEhCR,EAAcE,IACV,MAAMC,EAAmBD,EAAeD,EACxC,MAAMG,EAAQD,EAAmBR,EACjC,MAAMe,EAAIN,EAAQP,EAAWA,EAC7B,MAAM1B,EAAIiB,KAAKuB,IAAIV,EAAc,GAAKb,KAAKuB,IAAIT,EAAc,GAAKP,EAClE,MAAMiB,EAAIxB,KAAKqB,KAAKL,GACpB,MAAMS,EAAIN,EAAgBnB,KAAKuB,IAAIT,EAAc,GAAID,GACrD,MAAMa,GAAUf,EAASG,GAAgBb,EAAU,GAAK,EAAI,EAC5D,OAAQyB,IAAWJ,EAAIvC,GAAKyC,GAAMC,CAAC,CAE/C,KACS,CACDd,EAAYG,IACR,MAAMG,EAAIjB,KAAKqB,KAAKP,EAAeP,GACnC,MAAMW,GAAKJ,EAAeL,GAAYF,EAAW,EACjD,OAAQN,EAAUgB,EAAIC,CAAC,EAE3BN,EAAcE,IACV,MAAMG,EAAIjB,KAAKqB,KAAKP,EAAeP,GACnC,MAAMW,GAAKT,EAAWK,IAAiBP,EAAWA,GAClD,OAAOU,EAAIC,CAAC,CAExB,CACI,MAAMS,EAAe,EAAIpB,EACzB,MAAMO,EAAec,EAAgBjB,EAAUC,EAAYe,GAC3DpB,EAAWA,EAAW,IACtB,GAAIsB,MAAMf,GAAe,CACrB,MAAO,CACHgB,UAAW,IACXC,QAAS,GACTxB,WAEZ,KACS,CACD,MAAMuB,EAAY9B,KAAKuB,IAAIT,EAAc,GAAKJ,EAC9C,MAAO,CACHoB,YACAC,QAASlB,EAAe,EAAIb,KAAKgC,KAAKtB,EAAOoB,GAC7CvB,WAEZ,CACA,CACA,MAAM0B,EAAiB,GACvB,SAASL,EAAgBjB,EAAUC,EAAYe,GAC3C,IAAIO,EAASP,EACb,IAAK,IAAInC,EAAI,EAAGA,EAAIyC,EAAgBzC,IAAK,CACrC0C,EAASA,EAASvB,EAASuB,GAAUtB,EAAWsB,EACxD,CACI,OAAOA,CACX,CACA,SAASf,EAAgBL,EAAcD,GACnC,OAAOC,EAAed,KAAKgC,KAAK,EAAInB,EAAeA,EACvD,CCzEA,MAAMsB,EAAe,CAAC,WAAY,UAClC,MAAMC,EAAc,CAAC,YAAa,UAAW,QAC7C,SAASC,EAAaC,EAASC,GAC3B,OAAOA,EAAKC,MAAMC,GAAQH,EAAQG,KAASC,WAC/C,CACA,SAASC,EAAiBL,GACtB,IAAIM,EAAgB1D,OAAO2D,OAAO,CAAEpC,SAAU,EAAKqB,UAAW,IAAKC,QAAS,GAAIrB,KAAM,EAAKoC,uBAAwB,OAASR,GAC5H,IAAKD,EAAaC,EAASF,IACvBC,EAAaC,EAASH,GAAe,CACrC,MAAMY,EAAUzC,EAAWgC,GAC3BM,EAAgB1D,OAAO2D,OAAO3D,OAAO2D,OAAO3D,OAAO2D,OAAO,GAAID,GAAgBG,GAAU,CAAEtC,SAAU,EAAKC,KAAM,IAC/GkC,EAAcE,uBAAyB,IAC/C,CACI,OAAOF,CACX,CACA,SAASI,EAAOC,GACZ,IAAIC,KAAEA,EAAO,EAAGC,GAAEA,EAAK,EAAGC,UAAEA,EAAY,EAACC,UAAEA,GAAcJ,EAAIX,EAAUzD,EAAOoE,EAAI,CAAC,OAAQ,KAAM,YAAa,cAC9G,MAAMK,EAAQ,CAAEC,KAAM,MAAOC,MAAON,GACpC,IAAIpB,UAAEA,EAASC,QAAEA,EAAOrB,KAAEA,EAAID,SAAEA,EAAQF,SAAEA,EAAQuC,uBAAEA,GAA4BH,EAAiBL,GACjG,IAAImB,EAAgBC,EACpB,IAAIC,EAAkBD,EACtB,SAASE,IACL,MAAMC,EAAkBpD,IAAaA,EAAW,KAAQ,EACxD,MAAMqD,EAAeX,EAAKD,EAC1B,MAAMrC,EAAekB,GAAW,EAAI/B,KAAKgC,KAAKF,EAAYpB,IAC1D,MAAMqD,EAAsB/D,KAAKgC,KAAKF,EAAYpB,GAAQ,IAC1D,GAAI2C,IAAcX,UAAW,CACzBW,EAAYrD,KAAKH,IAAIG,KAAKgE,IAAIb,EAAKD,GAAQ,IAAK,GAC5D,CACQ,GAAIrC,EAAe,EAAG,CAClB,MAAMoD,EAAc9C,EAAgB4C,EAAqBlD,GACzD4C,EAAiBzE,IACb,MAAM2B,EAAWX,KAAKqB,KAAKR,EAAekD,EAAsB/E,GAChE,OAAQmE,EACJxC,IACOkD,EACChD,EAAekD,EAAsBD,GACrCG,EACAjE,KAAKkE,IAAID,EAAcjF,GACvB8E,EAAe9D,KAAKmE,IAAIF,EAAcjF,GAAG,EAEzD2E,EAAmB3E,IACf,MAAM2B,EAAWX,KAAKqB,KAAKR,EAAekD,EAAsB/E,GAChE,OAAQ6B,EACJkD,EACApD,GACEX,KAAKkE,IAAID,EAAcjF,IACpB6E,EACGhD,EACIkD,EACAD,GACRG,EACAH,EAAe9D,KAAKmE,IAAIF,EAAcjF,IAC1C2B,GACKX,KAAKmE,IAAIF,EAAcjF,IACnB6E,EACGhD,EACIkD,EACAD,GACRG,EACIH,EACA9D,KAAKkE,IAAID,EAAcjF,GAAG,CAE1D,MACa,GAAI6B,IAAiB,EAAG,CACzB4C,EAAiBzE,GAAMmE,EACnBnD,KAAKqB,KAAK0C,EAAsB/E,IAC3B8E,GACID,EAAkBE,EAAsBD,GACrC9E,EAC5B,KACa,CACD,MAAMoF,EAAoBL,EAAsB/D,KAAKgC,KAAKnB,EAAeA,EAAe,GACxF4C,EAAiBzE,IACb,MAAM2B,EAAWX,KAAKqB,KAAKR,EAAekD,EAAsB/E,GAChE,MAAMqF,EAAWrE,KAAKH,IAAIuE,EAAoBpF,EAAG,KACjD,OAAQmE,EACHxC,IACKkD,EACEhD,EAAekD,EAAsBD,GACrC9D,KAAKsE,KAAKD,GACVD,EACIN,EACA9D,KAAKuE,KAAKF,IAClBD,CAAiB,CAEzC,CACA,CACIR,IACA,MAAO,CACHY,KAAOxF,IACH,MAAMyF,EAAUhB,EAAczE,GAC9B,IAAK8D,EAAwB,CACzB,MAAM4B,EAAkBf,EAAgB3E,GAAK,IAC7C,MAAM2F,EAA2B3E,KAAKgE,IAAIU,IAAoBtB,EAC9D,MAAMwB,EAA+B5E,KAAKgE,IAAIb,EAAKsB,IAAYpB,EAC/DC,EAAMC,KACFoB,GAA4BC,CAChD,KACiB,CACDtB,EAAMC,KAAOvE,GAAKuB,CAClC,CACY+C,EAAME,MAAQF,EAAMC,KAAOJ,EAAKsB,EAChC,OAAOnB,CAAK,EAEhBuB,WAAY,KACRpE,GAAYA,GACXyC,EAAMC,GAAM,CAACA,EAAID,GAClBU,GAAc,EAG1B,CACAZ,EAAO8B,mBAAqB,CAAC7D,EAAGC,WAAaD,IAAM,iBAAmBC,IAAM,SAC5E,MAAMwC,EAAQqB,GAAO,ECpHrB,MAAMC,EAAW,CAAC9B,EAAMC,EAAIK,KACxB,MAAMyB,EAAmB9B,EAAKD,EAC9B,OAAO+B,IAAqB,EAAI,GAAKzB,EAAQN,GAAQ+B,CAAgB,ECFzE,MAAMC,EAAM,CAAChC,EAAMC,EAAI6B,KAAcA,EAAW9B,EAAO8B,EAAW7B,EAAKD,ECAvE,MAAMtD,EAAQ,CAACC,EAAKC,IAASC,GAAMC,KAAKF,IAAIE,KAAKH,IAAIE,EAAGD,GAAMD,GAC9D,MAAMsF,EAAYpF,GAAOA,EAAI,EAAIqF,OAAOrF,EAAEsF,QAAQ,IAAMtF,EACxD,MAAMuF,EAAa,uBACnB,MAAMC,EAAa,+HACnB,MAAMC,EAAmB,mHACzB,SAASC,EAAS1F,GACd,cAAcA,IAAM,QACxB,CCLA,MAAM2F,EAAS,CACXC,KAAO5F,UAAaA,IAAM,SAC1B6F,MAAOC,WACPC,UAAY/F,GAAMA,GAEtB,MAAMgG,EAAQ7G,OAAO2D,OAAO3D,OAAO2D,OAAO,GAAI6C,GAAS,CAAEI,UAAWlG,EAAM,EAAG,KAC/DV,OAAO2D,OAAO3D,OAAO2D,OAAO,GAAI6C,GAAS,CAAEM,QAAS,ICNlE,MAAMC,EAAkBC,IAAI,CACxBP,KAAO5F,GAAM0F,EAAS1F,IAAMA,EAAEoG,SAASD,IAASnG,EAAEqG,MAAM,KAAK3G,SAAW,EACxEmG,MAAOC,WACPC,UAAY/F,GAAM,GAAGA,IAAImG,MAG7B,MAAMG,EAAUJ,EAAe,KAIJ/G,OAAO2D,OAAO3D,OAAO2D,OAAO,GAAIwD,GAAU,CAAET,MAAQ7F,GAAMsG,EAAQT,MAAM7F,GAAK,IAAK+F,UAAY/F,GAAMsG,EAAQP,UAAU/F,EAAI,OCVrJ,MAAMuG,EAAgB,CAACC,EAAMC,IAAczG,GAChC0G,QAAShB,EAAS1F,IAAMyF,EAAiBG,KAAK5F,IAAMA,EAAE2G,WAAWH,IACnEC,GAAYtH,OAAOC,UAAUC,eAAeC,KAAKU,EAAGyG,IAE7D,MAAMG,EAAa,CAACC,EAAOC,EAAOC,IAAW/G,IACzC,IAAK0F,EAAS1F,GACV,OAAOA,EACX,MAAOkB,EAAGC,EAAGE,EAAG2E,GAAShG,EAAEgH,MAAMzB,GACjC,MAAO,CACHsB,CAACA,GAAQf,WAAW5E,GACpB4F,CAACA,GAAQhB,WAAW3E,GACpB4F,CAACA,GAAQjB,WAAWzE,GACpB2E,MAAOA,IAAUrD,UAAYmD,WAAWE,GAAS,EACpD,ECVL,MAAMiB,EAAO,CACTrB,KAAMW,EAAc,MAAO,OAC3BV,MAAOe,EAAW,MAAO,aAAc,aACvCb,UAAW,EAAGmB,MAAKC,aAAYC,YAAWpB,MAAOqB,EAAU,KAC/C,QACJpH,KAAKqH,MAAMJ,GACX,KACAZ,EAAQP,UAAUX,EAAS+B,IAC3B,KACAb,EAAQP,UAAUX,EAASgC,IAC3B,KACAhC,EAASY,EAAMD,UAAUsB,IACzB,KCbZ,MAAME,EAAe1H,EAAM,EAAG,KAC9B,MAAM2H,EAAUrI,OAAO2D,OAAO3D,OAAO2D,OAAO,GAAI6C,GAAS,CAAEI,UAAY/F,GAAMC,KAAKqH,MAAMC,EAAavH,MACrG,MAAMyH,EAAO,CACT7B,KAAMW,EAAc,MAAO,OAC3BV,MAAOe,EAAW,MAAO,QAAS,QAClCb,UAAW,EAAG2B,MAAKC,QAAOC,OAAM5B,MAAOqB,EAAU,KAAQ,QACrDG,EAAQzB,UAAU2B,GAClB,KACAF,EAAQzB,UAAU4B,GAClB,KACAH,EAAQzB,UAAU6B,GAClB,KACAxC,EAASY,EAAMD,UAAUsB,IACzB,KCdR,SAASQ,EAAS7H,GACd,IAAI8H,EAAI,GACR,IAAIpG,EAAI,GACR,IAAIP,EAAI,GACR,IAAID,EAAI,GACR,GAAIlB,EAAEN,OAAS,EAAG,CACdoI,EAAI9H,EAAE+H,OAAO,EAAG,GAChBrG,EAAI1B,EAAE+H,OAAO,EAAG,GAChB5G,EAAInB,EAAE+H,OAAO,EAAG,GAChB7G,EAAIlB,EAAE+H,OAAO,EAAG,EACxB,KACS,CACDD,EAAI9H,EAAE+H,OAAO,EAAG,GAChBrG,EAAI1B,EAAE+H,OAAO,EAAG,GAChB5G,EAAInB,EAAE+H,OAAO,EAAG,GAChB7G,EAAIlB,EAAE+H,OAAO,EAAG,GAChBD,GAAKA,EACLpG,GAAKA,EACLP,GAAKA,EACLD,GAAKA,CACb,CACI,MAAO,CACHwG,IAAKM,SAASF,EAAG,IACjBH,MAAOK,SAAStG,EAAG,IACnBkG,KAAMI,SAAS7G,EAAG,IAClB6E,MAAO9E,EAAI8G,SAAS9G,EAAG,IAAM,IAAM,EAE3C,CACA,MAAM+G,EAAM,CACRrC,KAAMW,EAAc,KACpBV,MAAOgC,EACP9B,UAAW0B,EAAK1B,WC7BpB,MAAMmC,EAAQ,CACVtC,KAAO5F,GAAMyH,EAAK7B,KAAK5F,IAAMiI,EAAIrC,KAAK5F,IAAMiH,EAAKrB,KAAK5F,GACtD6F,MAAQ7F,IACJ,GAAIyH,EAAK7B,KAAK5F,GAAI,CACd,OAAOyH,EAAK5B,MAAM7F,EAC9B,MACa,GAAIiH,EAAKrB,KAAK5F,GAAI,CACnB,OAAOiH,EAAKpB,MAAM7F,EAC9B,KACa,CACD,OAAOiI,EAAIpC,MAAM7F,EAC7B,GAEI+F,UAAY/F,GACD0F,EAAS1F,GACVA,EACAA,EAAEX,eAAe,OACboI,EAAK1B,UAAU/F,GACfiH,EAAKlB,UAAU/F,ICnBjC,MAAMmI,EAAa,OACnB,MAAMC,EAAc,OACpB,SAASxC,EAAK5F,GACV,IAAIkD,EAAImF,EAAIC,EAAIC,EAChB,OAAQzG,MAAM9B,IACV0F,EAAS1F,MACPqI,GAAMnF,EAAKlD,EAAEgH,MAAMzB,MAAiB,MAAQrC,SAAY,OAAS,EAAIA,EAAGxD,UAAY,MAAQ2I,SAAY,EAAIA,EAAK,KAAOE,GAAMD,EAAKtI,EAAEgH,MAAMxB,MAAiB,MAAQ8C,SAAY,OAAS,EAAIA,EAAG5I,UAAY,MAAQ6I,SAAY,EAAIA,EAAK,GAAK,CACxP,CACA,SAASC,EAAQxI,GACb,UAAWA,IAAM,SACbA,EAAI,GAAGA,IACX,MAAMyI,EAAS,GACf,IAAIC,EAAY,EAChB,MAAMC,EAAS3I,EAAEgH,MAAMxB,GACvB,GAAImD,EAAQ,CACRD,EAAYC,EAAOjJ,OACnBM,EAAIA,EAAE4I,QAAQpD,EAAY2C,GAC1BM,EAAOI,QAAQF,EAAOG,IAAIZ,EAAMrC,OACxC,CACI,MAAMkD,EAAU/I,EAAEgH,MAAMzB,GACxB,GAAIwD,EAAS,CACT/I,EAAIA,EAAE4I,QAAQrD,EAAY6C,GAC1BK,EAAOI,QAAQE,EAAQD,IAAInD,EAAOE,OAC1C,CACI,MAAO,CAAE4C,SAAQC,YAAWM,UAAWhJ,EAC3C,CACA,SAAS6F,EAAM7F,GACX,OAAOwI,EAAQxI,GAAGyI,MACtB,CACA,SAASQ,EAAkBjJ,GACvB,MAAMyI,OAAEA,EAAMC,UAAEA,EAASM,UAAEA,GAAcR,EAAQxI,GACjD,MAAMkJ,EAAYT,EAAO/I,OACzB,OAAQM,IACJ,IAAImJ,EAASH,EACb,IAAK,IAAIvJ,EAAI,EAAGA,EAAIyJ,EAAWzJ,IAAK,CAChC0J,EAASA,EAAOP,QAAQnJ,EAAIiJ,EAAYP,EAAaC,EAAa3I,EAAIiJ,EAAYR,EAAMnC,UAAU/F,EAAEP,IAAM2F,EAASpF,EAAEP,IACjI,CACQ,OAAO0J,CAAM,CAErB,CACA,MAAMC,EAAwBpJ,UAAaA,IAAM,SAAW,EAAIA,EAChE,SAASqJ,EAAkBrJ,GACvB,MAAMsJ,EAASzD,EAAM7F,GACrB,MAAMuJ,EAAcN,EAAkBjJ,GACtC,OAAOuJ,EAAYD,EAAOR,IAAIM,GAClC,CACA,MAAMI,EAAU,CAAE5D,OAAMC,QAAOoD,oBAAmBI,qBClDlD,SAASI,EAASvK,EAAGwK,EAAGzK,GACpB,GAAIA,EAAI,EACJA,GAAK,EACT,GAAIA,EAAI,EACJA,GAAK,EACT,GAAIA,EAAI,EAAI,EACR,OAAOC,GAAKwK,EAAIxK,GAAK,EAAID,EAC7B,GAAIA,EAAI,EAAI,EACR,OAAOyK,EACX,GAAIzK,EAAI,EAAI,EACR,OAAOC,GAAKwK,EAAIxK,IAAM,EAAI,EAAID,GAAK,EACvC,OAAOC,CACX,CACA,SAASyK,GAAWzC,IAAEA,EAAGC,WAAEA,EAAUC,UAAEA,EAASpB,MAAEA,IAC9CkB,GAAO,IACPC,GAAc,IACdC,GAAa,IACb,IAAIM,EAAM,EACV,IAAIC,EAAQ,EACZ,IAAIC,EAAO,EACX,IAAKT,EAAY,CACbO,EAAMC,EAAQC,EAAOR,CAC7B,KACS,CACD,MAAMsC,EAAItC,EAAY,GAChBA,GAAa,EAAID,GACjBC,EAAYD,EAAaC,EAAYD,EAC3C,MAAMjI,EAAI,EAAIkI,EAAYsC,EAC1BhC,EAAM+B,EAASvK,EAAGwK,EAAGxC,EAAM,EAAI,GAC/BS,EAAQ8B,EAASvK,EAAGwK,EAAGxC,GACvBU,EAAO6B,EAASvK,EAAGwK,EAAGxC,EAAM,EAAI,EACxC,CACI,MAAO,CACHQ,IAAKzH,KAAKqH,MAAMI,EAAM,KACtBC,MAAO1H,KAAKqH,MAAMK,EAAQ,KAC1BC,KAAM3H,KAAKqH,MAAMM,EAAO,KACxB5B,QAER,CCjCA,MAAM4D,EAAiB,CAACzG,EAAMC,EAAIpD,KAC9B,MAAM6J,EAAW1G,EAAOA,EACxB,MAAM2G,EAAS1G,EAAKA,EACpB,OAAOnD,KAAKgC,KAAKhC,KAAKF,IAAI,EAAGC,GAAK8J,EAASD,GAAYA,GAAU,EAErE,MAAME,EAAa,CAAC9B,EAAKR,EAAMR,GAC/B,MAAM+C,EAAgBhK,GAAM+J,EAAWE,MAAMzD,GAASA,EAAKZ,KAAK5F,KAEhE,MAAMkK,EAAW,CAAC/G,EAAMC,KACpB,IAAI+G,EAAgBH,EAAa7G,GACjC,IAAIiH,EAAcJ,EAAa5G,GAG/B,IAAIiH,EAAYF,EAActE,MAAM1C,GACpC,IAAImH,EAAUF,EAAYvE,MAAMzC,GAChC,GAAI+G,IAAkBlD,EAAM,CACxBoD,EAAYV,EAAWU,GACvBF,EAAgB1C,CACxB,CACI,GAAI2C,IAAgBnD,EAAM,CACtBqD,EAAUX,EAAWW,GACrBF,EAAc3C,CACtB,CACI,MAAM8C,EAAUpL,OAAO2D,OAAO,GAAIuH,GAClC,OAAQrK,IACJ,IAAK,MAAM0C,KAAO6H,EAAS,CACvB,GAAI7H,IAAQ,QAAS,CACjB6H,EAAQ7H,GAAOkH,EAAeS,EAAU3H,GAAM4H,EAAQ5H,GAAM1C,EAC5E,CACA,CACQuK,EAAQvE,MAAQb,EAAIkF,EAAUrE,MAAOsE,EAAQtE,MAAOhG,GACpD,OAAOmK,EAAcpE,UAAUwE,EAAQ,CAC1C,EChCL,MAAMC,GAASxK,UAAaA,IAAM,SCLlC,MAAMyK,GAAmB,CAACvJ,EAAGC,IAAOnB,GAAMmB,EAAED,EAAElB,IAC9C,MAAM0K,GAAO,IAAIC,IAAiBA,EAAaC,OAAOH,ICMtD,SAASI,GAASC,EAAQC,GACtB,GAAIP,GAAMM,GAAS,CACf,OAAQ9K,GAAMmF,EAAI2F,EAAQC,EAAQ/K,EAC1C,MACS,GAAIkI,EAAMtC,KAAKkF,GAAS,CACzB,OAAOZ,EAASY,EAAQC,EAChC,KACS,CACD,OAAOC,GAAWF,EAAQC,EAClC,CACA,CACA,MAAME,GAAW,CAAC9H,EAAMC,KACpB,MAAM+F,EAAS,IAAIhG,GACnB,MAAM+F,EAAYC,EAAOzJ,OACzB,MAAMwL,EAAa/H,EAAK2F,KAAI,CAACqC,EAAU1L,IAAMoL,GAASM,EAAU/H,EAAG3D,MACnE,OAAQO,IACJ,IAAK,IAAIP,EAAI,EAAGA,EAAIyJ,EAAWzJ,IAAK,CAChC0J,EAAO1J,GAAKyL,EAAWzL,GAAGO,EACtC,CACQ,OAAOmJ,CAAM,CAChB,EAEL,MAAMiC,GAAY,CAACN,EAAQC,KACvB,MAAM5B,EAAShK,OAAO2D,OAAO3D,OAAO2D,OAAO,GAAIgI,GAASC,GACxD,MAAMG,EAAa,GACnB,IAAK,MAAMxI,KAAOyG,EAAQ,CACtB,GAAI2B,EAAOpI,KAASC,WAAaoI,EAAOrI,KAASC,UAAW,CACxDuI,EAAWxI,GAAOmI,GAASC,EAAOpI,GAAMqI,EAAOrI,GAC3D,CACA,CACI,OAAQ1C,IACJ,IAAK,MAAM0C,KAAOwI,EAAY,CAC1B/B,EAAOzG,GAAOwI,EAAWxI,GAAK1C,EAC1C,CACQ,OAAOmJ,CAAM,CAChB,EAEL,SAASX,GAAQ/E,GACb,MAAM6F,EAASE,EAAQ3D,MAAMpC,GAC7B,MAAMyF,EAAYI,EAAO5J,OACzB,IAAI2L,EAAa,EACjB,IAAIC,EAAS,EACb,IAAIC,EAAS,EACb,IAAK,IAAI9L,EAAI,EAAGA,EAAIyJ,EAAWzJ,IAAK,CAChC,GAAI4L,UAAqB/B,EAAO7J,KAAO,SAAU,CAC7C4L,GACZ,KACa,CACD,GAAI/B,EAAO7J,GAAGyH,MAAQvE,UAAW,CAC7B4I,GAChB,KACiB,CACDD,GAChB,CACA,CACA,CACI,MAAO,CAAEhC,SAAQ+B,aAAYC,SAAQC,SACzC,CACA,MAAMP,GAAa,CAACF,EAAQC,KACxB,MAAMS,EAAWhC,EAAQP,kBAAkB8B,GAC3C,MAAMU,EAAcjD,GAAQsC,GAC5B,MAAMY,EAAclD,GAAQuC,GAC5B,MAAMY,EAAiBF,EAAYF,SAAWG,EAAYH,QACtDE,EAAYH,SAAWI,EAAYJ,QACnCG,EAAYJ,YAAcK,EAAYL,WAC1C,GAAIM,EAAgB,CAChB,OAAOjB,GAAKO,GAASQ,EAAYnC,OAAQoC,EAAYpC,QAASkC,EACtE,KACS,CAED,OAAQtM,GAAM,GAAGA,EAAI,EAAI6L,EAASD,GAC1C,GCrEA,MAAMc,GAAY,CAACzI,EAAMC,IAAQlE,GAAMiG,EAAIhC,EAAMC,EAAIlE,GACrD,SAAS2M,GAAmB7L,GACxB,UAAWA,IAAM,SAAU,CACvB,OAAO4L,EACf,MACS,UAAW5L,IAAM,SAAU,CAC5B,GAAIkI,EAAMtC,KAAK5F,GAAI,CACf,OAAOkK,CACnB,KACa,CACD,OAAOc,EACnB,CACA,MACS,GAAIc,MAAMC,QAAQ/L,GAAI,CACvB,OAAOiL,EACf,MACS,UAAWjL,IAAM,SAAU,CAC5B,OAAOoL,EACf,CACA,CACA,SAASY,GAAa7C,EAAQ8C,EAAMC,GAChC,MAAMC,EAAS,GACf,MAAMC,EAAeF,GAAeL,GAAmB1C,EAAO,IAC9D,MAAMkD,EAAYlD,EAAOzJ,OAAS,EAClC,IAAK,IAAID,EAAI,EAAGA,EAAI4M,EAAW5M,IAAK,CAChC,IAAI6M,EAAQF,EAAajD,EAAO1J,GAAI0J,EAAO1J,EAAI,IAC/C,GAAIwM,EAAM,CACN,MAAMM,EAAiBT,MAAMC,QAAQE,GAAQA,EAAKxM,GAAKwM,EACvDK,EAAQ5B,GAAK6B,EAAgBD,EACzC,CACQH,EAAOtD,KAAKyD,EACpB,CACI,OAAOH,CACX,CACA,SAASK,IAAiBrJ,EAAMC,IAAMkJ,IAClC,OAAQtM,GAAMsM,EAAMrH,EAAS9B,EAAMC,EAAIpD,GAC3C,CACA,SAASyM,GAAgBC,EAAOP,GAC5B,MAAMQ,EAAcD,EAAMhN,OAC1B,MAAMkN,EAAiBD,EAAc,EACrC,OAAQ3M,IACJ,IAAI6M,EAAa,EACjB,IAAIC,EAAkB,MACtB,GAAI9M,GAAK0M,EAAM,GAAI,CACfI,EAAkB,IAC9B,MACa,GAAI9M,GAAK0M,EAAME,GAAiB,CACjCC,EAAaD,EAAiB,EAC9BE,EAAkB,IAC9B,CACQ,IAAKA,EAAiB,CAClB,IAAIrN,EAAI,EACR,KAAOA,EAAIkN,EAAalN,IAAK,CACzB,GAAIiN,EAAMjN,GAAKO,GAAKP,IAAMmN,EAAgB,CACtC,KACpB,CACA,CACYC,EAAapN,EAAI,CAC7B,CACQ,MAAMsN,EAAkB9H,EAASyH,EAAMG,GAAaH,EAAMG,EAAa,GAAI7M,GAC3E,OAAOmM,EAAOU,GAAYE,EAAgB,CAElD,CACA,SAASC,GAAYN,EAAOvD,GAAUtJ,MAAOoN,EAAU,KAAIhB,KAAEA,EAAIK,MAAEA,GAAU,IACzE,MAAMK,EAAcD,EAAMhN,OAG1B,GAAIgN,EAAM,GAAKA,EAAMC,EAAc,GAAI,CACnCD,EAAQ,GAAGQ,OAAOR,GAClBvD,EAAS,GAAG+D,OAAO/D,GACnBuD,EAAMS,UACNhE,EAAOgE,SACf,CACI,MAAMhB,EAASH,GAAa7C,EAAQ8C,EAAMK,GAC1C,MAAMc,EAAeT,IAAgB,EAC/BH,GAAgBE,EAAOP,GACvBM,GAAgBC,EAAOP,GAC7B,OAAOc,EACAjN,GAAMoN,EAAavN,EAAM6M,EAAM,GAAIA,EAAMC,EAAc,GAAI3M,IAC5DoN,CACV,CCzFA,MAAMC,GAAgBC,GAAUpO,GAAK,EAAIoO,EAAO,EAAIpO,GACpD,MAAMqO,GAAeD,GAAUpO,GAAKA,GAAK,GAAMoO,EAAO,EAAIpO,GAAK,GAAK,EAAIoO,EAAO,GAAK,EAAIpO,KAAO,EAC/F,MAAMsO,GAAgBC,GAAUvO,GAAKe,KAAKuB,IAAItC,EAAGuO,GACjD,MAAMC,GAAgBD,GAAUvO,GAAKA,EAAIA,IAAMuO,EAAQ,GAAKvO,EAAIuO,GAChE,MAAME,GAAoBF,IACtB,MAAMG,EAAaF,GAAaD,GAChC,OAAOvO,IAAMA,GAAK,GAAK,EACjB,GAAM0O,EAAW1O,GACjB,IAAO,EAAIe,KAAKuB,IAAI,GAAI,IAAMtC,EAAI,IAAI,ECNhD,MAAM2O,GAA6B,MACnC,MAAMC,GAAyB,EAAM,GACrC,MAAMC,GAA0B,EAAM,GACtC,MAAMC,GAAyB,EAAM,GAChC,MAACC,GAAS/O,GAAKA,EACpB,MAAMgP,GAASV,GAAa,GACvB,MAACW,GAAUd,GAAca,IAC9B,MAAME,GAAYb,GAAaW,IAC/B,MAAMG,GAASnP,GAAK,EAAIe,KAAKkE,IAAIlE,KAAKqO,KAAKpP,IAC3C,MAAMqP,GAAUlB,GAAcgB,IACZd,GAAagB,IAC/B,MAAMC,GAASd,GAAaG,IACZR,GAAcmB,IACZjB,GAAaiB,IACZb,GAAiBE,IACpC,MAAMY,GAAK,KAAS,IACpB,MAAMC,GAAK,MAAU,KACrB,MAAMC,GAAK,MAAU,KACrB,MAAMC,GAAa1P,IACf,GAAIA,IAAM,GAAKA,IAAM,EACjB,OAAOA,EACX,MAAM2P,EAAK3P,EAAIA,EACf,OAAOA,EAAI4O,GACL,OAASe,EACT3P,EAAI6O,GACA,MAAQc,EAAK,IAAM3P,EAAI,IACvBA,EAAI8O,GACAS,GAAKI,EAAKH,GAAKxP,EAAIyP,GACnB,KAAOzP,EAAIA,EAAI,MAAQA,EAAI,KAAK,EAEjCmO,GAAcuB,IC7B/B,SAASE,GAAcrG,EAAQ6E,GAC3B,OAAO7E,EAAOK,KAAI,IAAMwE,GAAUc,KAAWW,OAAO,EAAGtG,EAAO/I,OAAS,EAC3E,CACA,SAASsP,GAAcvG,GACnB,MAAMS,EAAYT,EAAO/I,OACzB,OAAO+I,EAAOK,KAAI,CAACmG,EAAQxP,IAAMA,IAAM,EAAIA,GAAKyJ,EAAY,GAAK,GACrE,CACA,SAASgG,GAAqBC,EAAQ3O,GAClC,OAAO2O,EAAOrG,KAAKsG,GAAMA,EAAI5O,GACjC,CACA,SAAS6O,IAAUlM,KAAEA,EAAO,EAACC,GAAEA,EAAK,EAAC6I,KAAEA,EAAIkD,OAAEA,EAAM3O,SAAEA,EAAW,MAC5D,MAAM+C,EAAQ,CAAEC,KAAM,MAAOC,MAAON,GACpC,MAAMsF,EAASqD,MAAMC,QAAQ3I,GAAMA,EAAK,CAACD,EAAMC,GAC/C,MAAMkM,EAAQJ,GAAqBC,GAAUA,EAAOzP,SAAW+I,EAAO/I,OAChEyP,EACAH,GAAcvG,GAASjI,GAC7B,SAAS+O,IACL,OAAOvC,GAAYsC,EAAO7G,EAAQ,CAC9BwD,KAAMH,MAAMC,QAAQE,GAAQA,EAAO6C,GAAcrG,EAAQwD,IAErE,CACI,IAAImB,EAAemC,IACnB,MAAO,CACH9K,KAAOxF,IACHsE,EAAME,MAAQ2J,EAAanO,GAC3BsE,EAAMC,KAAOvE,GAAKuB,EAClB,OAAO+C,CAAK,EAEhBuB,WAAY,KACR2D,EAAO0E,UACPC,EAAemC,GAAoB,EAG/C,CCpCA,SAASC,IAAM9O,SAAEA,EAAW,EAACyC,KAAEA,EAAO,EAACsK,MAAEA,EAAQ,GAAGgC,aAAEA,EAAe,IAAGnM,UAAEA,EAAY,GAAGoM,aAAEA,IACvF,MAAMnM,EAAQ,CAAEC,KAAM,MAAOC,MAAON,GACpC,IAAIwM,EAAYlC,EAAQ/M,EACxB,MAAMkP,EAAQzM,EAAOwM,EACrB,MAAM5E,EAAS2E,IAAiB/M,UAAYiN,EAAQF,EAAaE,GACjE,GAAI7E,IAAW6E,EACXD,EAAY5E,EAAS5H,EACzB,MAAO,CACHsB,KAAOxF,IACH,MAAMgC,GAAS0O,EAAY1P,KAAKqB,KAAKrC,EAAIwQ,GACzClM,EAAMC,OAASvC,EAAQqC,GAAarC,GAASqC,GAC7CC,EAAME,MAAQF,EAAMC,KAAOuH,EAASA,EAAS9J,EAC7C,OAAOsC,CAAK,EAEhBuB,WAAY,OAEpB,CCZA,MAAM+K,GAAQ,CAAER,aAAWpM,SAAQuM,UACnC,SAASM,GAA2BC,GAChC,GAAIjE,MAAMC,QAAQgE,EAAO3M,IAAK,CAC1B,OAAOiM,EACf,MACS,GAAIQ,GAAME,EAAOvJ,MAAO,CACzB,OAAOqJ,GAAME,EAAOvJ,KAC5B,CACI,MAAMhE,EAAO,IAAIwN,IAAI7Q,OAAOqD,KAAKuN,IACjC,GAAIvN,EAAKyN,IAAI,SACRzN,EAAKyN,IAAI,cAAgBzN,EAAKyN,IAAI,gBAAkB,CACrD,OAAOZ,EACf,MACS,GAAI7M,EAAKyN,IAAI,iBACdzN,EAAKyN,IAAI,cACTzN,EAAKyN,IAAI,SACTzN,EAAKyN,IAAI,YACTzN,EAAKyN,IAAI,cACTzN,EAAKyN,IAAI,aAAc,CACvB,OAAOhN,CACf,CACI,OAAOoM,EACX,CC1BA,MAAMa,GAAmB,EAAI,GAAM,IACnC,MAAMC,UAAwBC,cAAgB,YACxC,IAAMA,YAAYC,MAClB,IAAMC,KAAKD,MACjB,MAAME,UAAqBC,SAAW,YAC/BC,GAAaD,OAAOE,sBAAsBD,GAC1CA,GAAaE,YAAW,IAAMF,EAASN,OAAmBD,ICNjE,SAASU,GAAiBC,GACtB,IAAIC,EAAQ,GACZ,IAAIC,EAAiB,GACrB,IAAIC,EAAW,EACf,IAAIC,EAAe,MACnB,IAAIC,EAAiB,MACrB,MAAMC,EAAc,IAAIC,QACxB,MAAMC,EAAO,CACTC,SAAU,CAACb,EAAUc,EAAY,MAAOC,EAAY,SAChD,MAAMC,EAAoBD,GAAaP,EACvC,MAAMS,EAASD,EAAoBX,EAAQC,EAC3C,GAAIQ,EACAJ,EAAYQ,IAAIlB,GACpB,GAAIiB,EAAOnS,QAAQkR,MAAe,EAAG,CACjCiB,EAAO7I,KAAK4H,GACZ,GAAIgB,GAAqBR,EACrBD,EAAWF,EAAMpR,MACrC,CACY,OAAO+Q,CAAQ,EAEnBmB,OAASnB,IACL,MAAMoB,EAAQd,EAAexR,QAAQkR,GACrC,GAAIoB,KAAW,EACXd,EAAehC,OAAO8C,EAAO,GACjCV,EAAYW,OAAOrB,EAAS,EAEhCsB,QAAUC,IACN,GAAIf,EAAc,CACdC,EAAiB,KACjB,MAChB,CACYD,EAAe,MACdH,EAAOC,GAAkB,CAACA,EAAgBD,GAC3CC,EAAerR,OAAS,EACxBsR,EAAWF,EAAMpR,OACjB,GAAIsR,EAAU,CACV,IAAK,IAAIvR,EAAI,EAAGA,EAAIuR,EAAUvR,IAAK,CAC/B,MAAMgR,EAAWK,EAAMrR,GACvBgR,EAASuB,GACT,GAAIb,EAAYlB,IAAIQ,GAAW,CAC3BY,EAAKC,SAASb,GACdI,GACxB,CACA,CACA,CACYI,EAAe,MACf,GAAIC,EAAgB,CAChBA,EAAiB,MACjBG,EAAKU,QAAQC,EAC7B,IAGI,OAAOX,CACX,CClDA,MAAMY,GAAa,GACnB,IAAIC,GAAoB,KACxB,IAAIrB,GAAe,MACnB,IAAII,GAAe,MACnB,MAAMkB,GAAQ,CACVlR,MAAO,EACPmR,UAAW,GAEf,MAAMC,GAAa,CACf,OACA,SACA,YACA,SACA,cAEJ,MAAMC,GAAQD,GAAWzH,QAAO,CAAC2H,EAAK7P,KAClC6P,EAAI7P,GAAOkO,IAAiB,IAAOC,GAAe,OAClD,OAAO0B,CAAG,GACX,IACH,MAAMC,GAAOH,GAAWzH,QAAO,CAAC2H,EAAK7P,KACjC,MAAM2O,EAAOiB,GAAM5P,GACnB6P,EAAI7P,GAAO,CAACqP,EAASR,EAAY,MAAOC,EAAY,SAChD,IAAKX,GACD4B,KACJ,OAAOpB,EAAKC,SAASS,EAASR,EAAWC,EAAU,EAEvD,OAAOe,CAAG,GACX,IACH,MAAMG,GAAaL,GAAWzH,QAAO,CAAC2H,EAAK7P,KACvC6P,EAAI7P,GAAO4P,GAAM5P,GAAKkP,OACtB,OAAOW,CAAG,GACX,IACeF,GAAWzH,QAAO,CAAC2H,EAAK7P,KACtC6P,EAAI7P,GAAO,IAAM4P,GAAM5P,GAAKqP,QAAQI,IACpC,OAAOI,CAAG,GACX,IACH,MAAMI,GAAeC,GAAWN,GAAMM,GAAQb,QAAQI,IACtD,MAAMU,GAAgBT,IAClBvB,GAAe,MACfsB,GAAMlR,MAAQiR,GACRhC,GACAjQ,KAAKF,IAAIE,KAAKH,IAAIsS,EAAYD,GAAMC,UAAWH,IAAa,GAClEE,GAAMC,UAAYA,EAClBnB,GAAe,KACfoB,GAAWS,QAAQH,IACnB1B,GAAe,MACf,GAAIJ,GAAc,CACdqB,GAAoB,MACpB3B,GAAYsC,GACpB,GAEA,MAAMJ,GAAY,KACd5B,GAAe,KACfqB,GAAoB,KACpB,IAAKjB,GACDV,GAAYsC,GAAa,EAIjC,MAAAE,GAAeP,GC9Df,SAASQ,GAAYC,EAASzS,EAAU0S,EAAQ,GAC5C,OAAOD,EAAUzS,EAAW0S,CAChC,CACA,SAASC,GAAeF,EAASzS,EAAU0S,EAAQ,EAAGE,EAAoB,MACtE,OAAOA,EACDJ,GAAYxS,GAAYyS,EAASzS,EAAU0S,GAC3C1S,GAAYyS,EAAUzS,GAAY0S,CAC5C,CACA,SAASG,GAAsBJ,EAASzS,EAAU0S,EAAOE,GACrD,OAAOA,EAAoBH,GAAWzS,EAAW0S,EAAQD,IAAYC,CACzE,CCJA,MAAMI,GAAaC,IACf,MAAMC,EAAgB,EAAGvS,WAAYsS,EAAOtS,GAC5C,MAAO,CACHwS,MAAO,IAAMjB,GAAKe,OAAOC,EAAe,MACxCE,KAAM,IAAMhB,GAAWa,OAAOC,GACjC,EAEL,SAASG,GAAQzQ,GACb,IAAImF,EAAIC,EACR,IAAInF,KAAEA,EAAIyQ,SAAEA,EAAW,KAAIC,OAAEA,EAASP,GAASL,QAAEA,EAAU,EAAGa,OAAQC,EAAY,EAACC,WAAEA,EAAa,OAAMC,YAAEA,EAAc,EAACC,OAAEA,EAAMC,OAAEA,EAAMC,WAAEA,EAAUC,SAAEA,EAAQC,SAAEA,GAAapR,EAAIX,EAAUzD,EAAOoE,EAAI,CAAC,OAAQ,WAAY,SAAU,UAAW,SAAU,aAAc,cAAe,SAAU,SAAU,aAAc,WAAY,aACtU,IAAIE,GAAEA,GAAOb,EACb,IAAIgS,EACJ,IAAIC,EAAc,EAClB,IAAIC,EAAmBlS,EAAQ/B,SAC/B,IAAIkU,EACJ,IAAIC,EAAa,MACjB,IAAIvB,EAAoB,KACxB,IAAIwB,EACJ,MAAMC,EAAW/E,GAA2BvN,GAC5C,IAAK+F,GAAMD,EAAKwM,GAAU9P,sBAAwB,MAAQuD,SAAY,OAAS,EAAIA,EAAGhJ,KAAK+I,EAAIlF,EAAMC,GAAK,CACtGwR,EAAwB5H,GAAY,CAAC,EAAG,KAAM,CAAC7J,EAAMC,GAAK,CACtDvD,MAAO,QAEXsD,EAAO,EACPC,EAAK,GACb,CACI,MAAM0R,EAAYD,EAAS1V,OAAO2D,OAAO3D,OAAO2D,OAAO,GAAIP,GAAU,CAAEY,OAAMC,QAC7E,SAAS0Q,IACLU,IACA,GAAIR,IAAe,UAAW,CAC1BZ,EAAoBoB,EAAc,IAAM,EACxCvB,EAAUE,GAAeF,EAASwB,EAAkBR,EAAab,EAC7E,KACa,CACDH,EAAUD,GAAYC,EAASwB,EAAkBR,GACjD,GAAID,IAAe,SACfc,EAAUhQ,YAC1B,CACQ6P,EAAa,MACbN,GAAYA,GACpB,CACI,SAASU,IACLR,EAAeb,OACfU,GAAcA,GACtB,CACI,SAASb,EAAOtS,GACZ,IAAKmS,EACDnS,GAASA,EACbgS,GAAWhS,EACX,IAAK0T,EAAY,CACb,MAAMpR,EAAQuR,EAAUrQ,KAAKxE,KAAKF,IAAI,EAAGkT,IACzCyB,EAASnR,EAAME,MACf,GAAImR,EACAF,EAASE,EAAsBF,GACnCC,EAAavB,EAAoB7P,EAAMC,KAAOyP,GAAW,CACrE,CACQqB,IAAa,MAAQA,SAAkB,OAAS,EAAIA,EAASI,GAC7D,GAAIC,EAAY,CACZ,GAAIH,IAAgB,EAChBC,IAAqB,MAAQA,SAA0B,EAAIA,EAAoBA,EAAmBxB,EACtG,GAAIuB,EAAcT,EAAW,CACzBV,GAAsBJ,EAASwB,EAAkBR,EAAab,IAAsBU,GACpG,KACiB,CACDiB,GAChB,CACA,CACA,CACI,SAASC,IACLd,IAAW,MAAQA,SAAgB,OAAS,EAAIA,IAChDK,EAAiBV,EAAON,GACxBgB,EAAed,OACvB,CACIG,GAAYoB,IACZ,MAAO,CACHtB,KAAM,KACFS,IAAW,MAAQA,SAAgB,OAAS,EAAIA,IAChDI,EAAeb,MAAM,EAGjC;;;;;;;;;;;;;;gFCzDU,IAACuB,GAAW,WAClBA,GAAW9V,OAAO2D,QAAU,SAASmS,EAAShW,GAC1C,IAAK,IAAIF,EAAGU,EAAI,EAAGyV,EAAIC,UAAUzV,OAAQD,EAAIyV,EAAGzV,IAAK,CACjDV,EAAIoW,UAAU1V,GACd,IAAK,IAAIP,KAAKH,EAAG,GAAII,OAAOC,UAAUC,eAAeC,KAAKP,EAAGG,GAAID,EAAEC,GAAKH,EAAEG,EACtF,CACQ,OAAOD,CACf,EACI,OAAOgW,GAASG,MAAMC,KAAMF,UAChC,EAEO,SAASrW,GAAOC,EAAGC,GACtB,IAAIC,EAAI,GACR,IAAK,IAAIC,KAAKH,EAAG,GAAII,OAAOC,UAAUC,eAAeC,KAAKP,EAAGG,IAAMF,EAAEO,QAAQL,GAAK,EAC9ED,EAAEC,GAAKH,EAAEG,GACb,GAAIH,GAAK,aAAeI,OAAOK,wBAA0B,WACrD,IAAK,IAAIC,EAAI,EAAGP,EAAIC,OAAOK,sBAAsBT,GAAIU,EAAIP,EAAEQ,OAAQD,IAAK,CACpE,GAAIT,EAAEO,QAAQL,EAAEO,IAAM,GAAKN,OAAOC,UAAUO,qBAAqBL,KAAKP,EAAGG,EAAEO,IACvER,EAAEC,EAAEO,IAAMV,EAAEG,EAAEO,GAC9B,CACI,OAAOR,CACX,CChDA,IAAIY,GAAQ,SAAUC,EAAKC,GAAO,OAAO,SAAUC,GAC/C,OAAOC,KAAKF,IAAIE,KAAKH,IAAIE,EAAGD,GAAMD,EACtC,CAAE,EACF,IAAIsF,GAAW,SAAUpF,GAAK,OAAQA,EAAI,EAAIqF,OAAOrF,EAAEsF,QAAQ,IAAMtF,CAAG,EAGxE,IAAIyF,GAAmB,oGAEpB,IAACE,GAAS,CACTC,KAAM,SAAU5F,GAAK,cAAcA,IAAM,QAAS,EAClD6F,MAAOC,WACPC,UAAW,SAAU/F,GAAK,OAAOA,CAAE,GAEpC,IAACgG,GAAQiP,GAASA,GAAS,GAAItP,IAAS,CAAEI,UAAWlG,GAAM,EAAG,KAC9D,IAACyV,GAAQL,GAASA,GAAS,GAAItP,IAAS,CAAEM,QAAS,IAEtD,IAAIC,GAAiB,SAAUC,GAAQ,OACnCP,KAAM,SAAU5F,GACZ,cAAcA,IAAM,UAAYA,EAAEoG,SAASD,IAASnG,EAAEqG,MAAM,KAAK3G,SAAW,CACpF,EACImG,MAAOC,WACPC,UAAW,SAAU/F,GAAK,MAAO,GAAKA,EAAImG,CAAK,EAChD,EACA,IAACoP,GAAUrP,GAAe,OAC7B,IAAII,GAAUJ,GAAe,KAC1B,IAACsP,GAAKtP,GAAe,MAGrB,IAACuP,GAAqBR,GAASA,GAAS,GAAI3O,IAAU,CAAET,MAAO,SAAU7F,GAAK,OAAOsG,GAAQT,MAAM7F,GAAK,GAAI,EAAI+F,UAAW,SAAU/F,GAAK,OAAOsG,GAAQP,UAAU/F,EAAI,IAAK,IAE/K,IAAI0V,GAA6B,SAAUjS,GACvC,OAAOA,EAAMkS,UAAUlS,EAAMlE,QAAQ,KAAO,EAAGkE,EAAMmS,YAAY,KACrE,EACA,IAAIrO,GAAe1H,GAAM,EAAG,KAC5B,IAAIgW,GAAS,SAAU7V,GAAK,OAAOA,EAAE0H,MAAQ/E,SAAU,EACvD,IAAImT,GAAS,SAAU9V,GAAK,OAAOA,EAAEkH,MAAQvE,SAAU,EACvD,SAASoT,GAAiBtS,GACtB,OAAOiS,GAA2BjS,GAC7BmF,QAAQ,UAAW,KACnBvC,MAAM,OACf,CACA,IAAI2P,GAAmB,SAAUC,GAC7B,OAAO,SAAUjW,GACb,UAAWA,IAAM,SACb,OAAOA,EACX,IAAIyI,EAAS,GACb,IAAIyN,EAAcH,GAAiB/V,GACnC,IAAK,IAAIP,EAAI,EAAGA,EAAI,EAAGA,IAAK,CACxBgJ,EAAOwN,EAAMxW,IACTyW,EAAYzW,KAAOkD,UAAYmD,WAAWoQ,EAAYzW,IAAM,CAC5E,CACQ,OAAOgJ,CACf,CACA,EACA,IAAI0N,GAAe,SAAUjT,GACzB,IAAIwE,EAAMxE,EAAGwE,IAAKC,EAAQzE,EAAGyE,MAAOC,EAAO1E,EAAG0E,KAAMS,EAAKnF,EAAG8C,MAAOA,EAAQqC,SAAY,EAAI,EAAIA,EAC/F,MAAO,QAAUX,EAAM,KAAOC,EAAQ,KAAOC,EAAO,KAAO5B,EAAQ,GACvE,EACA,IAAIoQ,GAAe,SAAUlT,GACzB,IAAIgE,EAAMhE,EAAGgE,IAAKC,EAAajE,EAAGiE,WAAYC,EAAYlE,EAAGkE,UAAWiB,EAAKnF,EAAG8C,MAAOA,EAAQqC,SAAY,EAAI,EAAIA,EACnH,MAAO,QAAUnB,EAAM,KAAOC,EAAa,KAAOC,EAAY,KAAOpB,EAAQ,GACjF,EACA,IAAIwB,GAAUyN,GAASA,GAAS,GAAItP,IAAS,CAAEI,UAAW,SAAU/F,GAAK,OAAOC,KAAKqH,MAAMC,GAAavH,GAAI,IAC5G,SAASuG,GAAc2B,EAAOmO,GAC1B,OAAOnO,EAAMvB,WAAW0P,IAAc5Q,GAAiBG,KAAKsC,EAChE,CACA,IAAIT,GAAO,CACP7B,KAAM,SAAU5F,GAAK,cAAeA,IAAM,SAAWuG,GAAcvG,EAAG,OAAS6V,GAAO7V,EAAI,EAC1F6F,MAAOmQ,GAAiB,CAAC,MAAO,QAAS,OAAQ,UACjDjQ,UAAW,SAAU7C,GACjB,IAAIwE,EAAMxE,EAAGwE,IAAKC,EAAQzE,EAAGyE,MAAOC,EAAO1E,EAAG0E,KAAMS,EAAKnF,EAAG8C,MAAOqB,EAAUgB,SAAY,EAAI,EAAIA,EACjG,OAAO8N,GAAa,CAChBzO,IAAKF,GAAQzB,UAAU2B,GACvBC,MAAOH,GAAQzB,UAAU4B,GACzBC,KAAMJ,GAAQzB,UAAU6B,GACxB5B,MAAOZ,GAASY,GAAMD,UAAUsB,KAE5C,GAEA,IAAIJ,GAAO,CACPrB,KAAM,SAAU5F,GAAK,cAAeA,IAAM,SAAWuG,GAAcvG,EAAG,OAAS8V,GAAO9V,EAAI,EAC1F6F,MAAOmQ,GAAiB,CAAC,MAAO,aAAc,YAAa,UAC3DjQ,UAAW,SAAU7C,GACjB,IAAIgE,EAAMhE,EAAGgE,IAAKC,EAAajE,EAAGiE,WAAYC,EAAYlE,EAAGkE,UAAWiB,EAAKnF,EAAG8C,MAAOqB,EAAUgB,SAAY,EAAI,EAAIA,EACrH,OAAO+N,GAAa,CAChBlP,IAAKjH,KAAKqH,MAAMJ,GAChBC,WAAYb,GAAQP,UAAUX,GAAS+B,IACvCC,UAAWd,GAAQP,UAAUX,GAASgC,IACtCpB,MAAOZ,GAASY,GAAMD,UAAUsB,KAE5C,GAEA,IAAIY,GAAMgN,GAASA,GAAS,GAAIxN,IAAO,CAAE7B,KAAM,SAAU5F,GAAK,cAAcA,IAAM,UAAYuG,GAAcvG,EAAG,IAAK,EAAI6F,MAAO,SAAU7F,GACjI,IAAI8H,EAAI,GACR,IAAIpG,EAAI,GACR,IAAIP,EAAI,GACR,GAAInB,EAAEN,OAAS,EAAG,CACdoI,EAAI9H,EAAE+H,OAAO,EAAG,GAChBrG,EAAI1B,EAAE+H,OAAO,EAAG,GAChB5G,EAAInB,EAAE+H,OAAO,EAAG,EAC5B,KACa,CACDD,EAAI9H,EAAE+H,OAAO,EAAG,GAChBrG,EAAI1B,EAAE+H,OAAO,EAAG,GAChB5G,EAAInB,EAAE+H,OAAO,EAAG,GAChBD,GAAKA,EACLpG,GAAKA,EACLP,GAAKA,CACjB,CACQ,MAAO,CACHuG,IAAKM,SAASF,EAAG,IACjBH,MAAOK,SAAStG,EAAG,IACnBkG,KAAMI,SAAS7G,EAAG,IAClB6E,MAAO,EAEnB,IACG,IAACkC,GAAQ,CACRtC,KAAM,SAAU5F,GACZ,cAAeA,IAAM,UAAYyF,GAAiBG,KAAK5F,IACnD6V,GAAO7V,IACP8V,GAAO9V,EACnB,EACI6F,MAAO,SAAU7F,GACb,GAAIyH,GAAK7B,KAAK5F,GAAI,CACd,OAAOyH,GAAK5B,MAAM7F,EAC9B,MACa,GAAIiH,GAAKrB,KAAK5F,GAAI,CACnB,OAAOiH,GAAKpB,MAAM7F,EAC9B,MACa,GAAIiI,GAAIrC,KAAK5F,GAAI,CAClB,OAAOiI,GAAIpC,MAAM7F,EAC7B,CACQ,OAAOA,CACf,EACI+F,UAAW,SAAU/F,GACjB,GAAI6V,GAAO7V,GAAI,CACX,OAAOyH,GAAK1B,UAAU/F,EAClC,MACa,GAAI8V,GAAO9V,GAAI,CAChB,OAAOiH,GAAKlB,UAAU/F,EAClC,CACQ,OAAOA,CACf,U","ignoreList":[]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{r as e,c as o,h as c,H as i,g as n}from"./p-d0a33e64.js";import{c as t}from"./p-8a1a6e56.js";import{v as r}from"./p-f5ff676c.js";const a='nv-fieldcheckbox{--nv-fieldcheckbox-border-default:var(\n --components-form-field-border-default\n );--nv-fieldcheckbox-border-hover:var(--components-form-field-border-hover);--nv-fieldcheckbox-border-focus:var(--components-form-field-border-default);--nv-fieldcheckbox-background-default:var(\n --components-form-field-background-default\n );--nv-fieldcheckbox-background-checked:var(\n --components-form-field-background-checked\n );--nv-fieldcheckbox-background-disabled:var(\n --components-form-field-background-disabled\n );--nv-fieldcheckbox-focus-box-shadow:var(--color-focus-brand);--nv-fieldcheckbox-color-checked:var(\n --components-form-shape-foreground-default\n );--nv-fieldcheckbox-color-disabled:var(\n --components-form-shape-foreground-disabled\n );--nv-fieldcheckbox-outline-color:var(--color-focus-brand);display:inline-flex;align-items:flex-start;gap:var(--form-gap-x);position:relative}nv-fieldcheckbox:not([disabled],[readonly]) input,nv-fieldcheckbox:not([disabled],[readonly]) label{cursor:pointer}nv-fieldcheckbox.error>.input-container{--nv-fieldcheckbox-border-default:var(--components-form-field-border-error);--nv-fieldcheckbox-border-hover:var(--nv-fieldcheckbox-border-default);--nv-fieldcheckbox-border-focus:var(--components-form-field-border-error);--nv-fieldcheckbox-focus-box-shadow:var(--color-focus-destructive);--nv-fieldcheckbox-color-disabled:var(\n --components-form-shape-foreground-disabled-error\n );--nv-fieldcheckbox-background-checked:var(\n --components-form-field-background-error\n );--nv-fieldcheckbox-outline-color:var(--color-focus-destructive)}nv-fieldcheckbox.label-placement-before{flex-direction:row-reverse}nv-fieldcheckbox[disabled]:not([disabled=false]){opacity:0.5}nv-fieldcheckbox>.input-container{position:relative;color:var(--nv-fieldcheckbox-color-checked)}nv-fieldcheckbox>.input-container input[type=checkbox][readonly]{opacity:0.5}nv-fieldcheckbox>.input-container:has(input[type=checkbox]:disabled:not([readonly])){color:var(--nv-fieldcheckbox-color-disabled)}nv-fieldcheckbox>.input-container input[type=checkbox]{appearance:none;position:relative;display:flex;width:var(--form-checkbox-size);height:var(--form-checkbox-size);flex-direction:column;align-items:flex-start;border-radius:var(--form-checkbox-radius);border-width:var(--form-checkbox-border-width);border-style:solid;border-color:var(--nv-fieldcheckbox-border-default);background:var(--nv-fieldcheckbox-background-default)}nv-fieldcheckbox>.input-container input[type=checkbox]:hover{border-color:var(--nv-fieldcheckbox-border-hover)}nv-fieldcheckbox>.input-container input[type=checkbox]:focus{border-color:var(--nv-fieldcheckbox-border-focus)}nv-fieldcheckbox>.input-container input[type=checkbox]:focus,nv-fieldcheckbox>.input-container input[type=checkbox]:focus-within{outline:none}nv-fieldcheckbox>.input-container input[type=checkbox]:focus-visible,nv-fieldcheckbox>.input-container input[type=checkbox]:has(:focus-visible){outline:calc(var(--focus-outline-stroke) * 1) solid var(--nv-fieldcheckbox-outline-color);outline-offset:calc(var(--focus-outline-offset) * 1)}nv-fieldcheckbox>.input-container input[type=checkbox]:checked,nv-fieldcheckbox>.input-container input[type=checkbox]:indeterminate{background:var(--nv-fieldcheckbox-background-checked);border-color:var(--nv-fieldcheckbox-background-checked)}nv-fieldcheckbox>.input-container input[type=checkbox]:disabled:not([readonly]){background:var(--nv-fieldcheckbox-background-disabled);border-color:var(--nv-fieldcheckbox-border-default)}nv-fieldcheckbox>.input-container input[type=checkbox][readonly]{opacity:0.5}nv-fieldcheckbox>.input-container .icon{pointer-events:none;position:absolute;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center}nv-fieldcheckbox>.input-container .icon svg{width:var(--form-checkbox-icon-size);height:var(--form-checkbox-icon-size);fill:none;stroke:currentcolor;stroke-width:var(--form-checkbox-icon-stroke);flex-shrink:0}nv-fieldcheckbox>.text-container{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0}nv-fieldcheckbox>.text-container label{align-self:stretch;text-align:left;color:var(--components-form-text-label-default);font-family:"TT Norms Pro", sans-serif;font-size:var(--form-label-font-size);font-style:normal;font-weight:var(--form-label-font-weight);line-height:var(--form-label-line-height)}nv-fieldcheckbox>.text-container label.visually-hidden{position:absolute;padding:0;border:0;overflow:hidden;white-space:nowrap;width:1px;height:1px;margin:-1px;clip:rect(0, 0, 0, 0)}nv-fieldcheckbox>.text-container .description{align-self:stretch;color:var(--components-form-text-description-default);font-family:"TT Norms Pro", sans-serif;font-size:var(--form-description-font-size);font-style:normal;font-weight:var(--form-description-font-weight);line-height:var(--form-description-line-height)}nv-fieldcheckbox>.text-container .error-description{align-self:stretch;color:var(--components-form-text-description-default);font-family:"TT Norms Pro", sans-serif;font-size:var(--form-description-font-size);font-style:normal;font-weight:var(--form-description-font-weight);line-height:var(--form-description-line-height);color:var(--components-form-text-description-error)}';const d=a;const l=class{constructor(c){e(this,c);this.checkedChanged=o(this,"checkedChanged",7);this.labelBefore=false;this.inputId=r();this.hideLabel=false;this.error=false;this.checked=false;this.indeterminate=false;this.disabled=false;this.readonly=false;this.required=false;this.autofocus=false}handleChange(e){const o=e.target;if(o.type==="checkbox"&&o.id===this.inputId){if(this.readonly||this.disabled){e.preventDefault();return}if(this.indeterminate){this.indeterminate=false}this.checked=o.checked}}onCheckedChanged(e){this.checkedChanged.emit(e)}componentWillRender(){if(this.message){this.description=this.message}if(this.labelBefore){this.labelPlacement="before"}if(this.validation){this.errorDescription=this.validation;this.error=true}}render(){return c(i,{key:"62195333f84808381f19ca4017916380d20d493f",class:t(this.labelPlacement==="before"&&"label-placement-before",this.error&&"error")},c("div",{key:"65f02aee06eacecf83c5297d87130bbe9f85b19c",class:"input-container"},c("input",{key:"c3e8fcb41c835f0eba254f9e77de749b7dc6349e",type:"checkbox",id:this.inputId,name:this.name,autofocus:this.autofocus,autocomplete:"off",value:this.value,checked:Boolean(this.checked),disabled:this.disabled||this.readonly,readonly:this.readonly&&!this.required,required:this.required,indeterminate:this.indeterminate,ref:e=>{if(e){e.indeterminate=this.indeterminate}}}),c("span",{key:"439a8c467373d734293012514cdb22c419b534ae",class:"icon"},this.checked&&!this.indeterminate&&c("slot",{key:"335a92ed1431fe96af3c7c6fac2f4245c0d4caaa",name:"checked-icon"},c("svg",{key:"67d97efca27a97c7db77d9f8c182a21fbd21d13c",xmlns:"http://www.w3.org/2000/svg",width:"14",height:"14",viewBox:"0 0 14 14",fill:"none"},c("path",{key:"9cb6730b00813e8d4fe6fa14549de6f2a41ea068",d:"M11.6667 3.5L5.25004 9.91667L2.33337 7","stroke-linecap":"round","stroke-linejoin":"round"}))),this.indeterminate&&c("slot",{key:"e47b17269156f72ddaf7af1ecc818ae5b6b8c0d3",name:"indeterminate-icon"},c("svg",{key:"4748acc27a70e74f9228cdb6e41eae4b1ae82559",class:"indeterminate-svg",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 14 14",fill:"none"},c("path",{key:"40748b36b277c1ed6ea8fc8f82f4cd687b2f6e3a",d:"M2.9165 7H11.0832","stroke-linecap":"round","stroke-linejoin":"round"}))))),c("slot",{key:"0fa9e559cefb8169c20b171fcbb6c1786fd6b3ae"}),c("div",{key:"44eef633025d1a7606979d4d8374c2a04081f45c",class:"text-container"},c("slot",{key:"b43251a02b15431f5399c3bced485b89741e069e",name:"main"},(this.label||this.el.querySelector('[slot="label"]'))&&c("label",{key:"7781451a357961ce1606b18c590baa344df4ff95",htmlFor:this.inputId,class:t(this.hideLabel&&"visually-hidden")},c("slot",{key:"b420ad1dbdc05a5c57d0b45e62176866ec0527ca",name:"label"},this.label)),(this.description||this.el.querySelector('[slot="description"]'))&&c("div",{key:"67715bef879e0778b58648b83135edefdbdba53d",class:"description"},c("slot",{key:"b1d4d21e83130e19e94efa915abd6661c027bbce",name:"description"},this.description))),(this.errorDescription||this.el.querySelector('[slot="error-description"]'))&&c("div",{key:"157df3faf2cadb4014ba8475c99cf68d86da9f63",hidden:!this.error,class:"error-description"},c("slot",{key:"42aa95b2332618120d846fa481a1b30b7edeccca",name:"error-description"},this.errorDescription))))}static get formAssociated(){return true}get el(){return n(this)}static get watchers(){return{checked:["onCheckedChanged"]}}};l.style=d;export{l as nv_fieldcheckbox};
|
|
2
|
+
//# sourceMappingURL=p-45506c37.entry.js.map
|