@mellow.io/ds 0.1.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/components/accordion/accordion-item.d.ts +16 -0
- package/dist/components/accordion/accordion-item.d.ts.map +1 -0
- package/dist/components/accordion/accordion-item.js +68 -0
- package/dist/components/accordion/accordion-item.js.map +1 -0
- package/dist/components/accordion/accordion.d.ts +15 -0
- package/dist/components/accordion/accordion.d.ts.map +1 -0
- package/dist/components/accordion/accordion.js +42 -0
- package/dist/components/accordion/accordion.js.map +1 -0
- package/dist/components/accordion/accordion.styles.d.ts +3 -0
- package/dist/components/accordion/accordion.styles.d.ts.map +1 -0
- package/dist/components/accordion/accordion.styles.js +76 -0
- package/dist/components/accordion/accordion.styles.js.map +1 -0
- package/dist/components/accordion/index.d.ts +3 -0
- package/dist/components/accordion/index.d.ts.map +1 -0
- package/dist/components/alert/alert.d.ts +16 -0
- package/dist/components/alert/alert.d.ts.map +1 -0
- package/dist/components/alert/alert.js +67 -0
- package/dist/components/alert/alert.js.map +1 -0
- package/dist/components/alert/alert.styles.d.ts +2 -0
- package/dist/components/alert/alert.styles.d.ts.map +1 -0
- package/dist/components/alert/alert.styles.js +160 -0
- package/dist/components/alert/alert.styles.js.map +1 -0
- package/dist/components/alert/index.d.ts +3 -0
- package/dist/components/alert/index.d.ts.map +1 -0
- package/dist/components/avatar/avatar.d.ts +19 -0
- package/dist/components/avatar/avatar.d.ts.map +1 -0
- package/dist/components/avatar/avatar.js +62 -0
- package/dist/components/avatar/avatar.js.map +1 -0
- package/dist/components/avatar/avatar.styles.d.ts +2 -0
- package/dist/components/avatar/avatar.styles.d.ts.map +1 -0
- package/dist/components/avatar/avatar.styles.js +67 -0
- package/dist/components/avatar/avatar.styles.js.map +1 -0
- package/dist/components/avatar/index.d.ts +3 -0
- package/dist/components/avatar/index.d.ts.map +1 -0
- package/dist/components/badge/badge.d.ts +15 -0
- package/dist/components/badge/badge.d.ts.map +1 -0
- package/dist/components/badge/badge.js +36 -0
- package/dist/components/badge/badge.js.map +1 -0
- package/dist/components/badge/badge.styles.d.ts +2 -0
- package/dist/components/badge/badge.styles.d.ts.map +1 -0
- package/dist/components/badge/badge.styles.js +106 -0
- package/dist/components/badge/badge.styles.js.map +1 -0
- package/dist/components/badge/index.d.ts +3 -0
- package/dist/components/badge/index.d.ts.map +1 -0
- package/dist/components/breadcrumb/breadcrumb-item.d.ts +16 -0
- package/dist/components/breadcrumb/breadcrumb-item.d.ts.map +1 -0
- package/dist/components/breadcrumb/breadcrumb-item.js +37 -0
- package/dist/components/breadcrumb/breadcrumb-item.js.map +1 -0
- package/dist/components/breadcrumb/breadcrumb.d.ts +14 -0
- package/dist/components/breadcrumb/breadcrumb.d.ts.map +1 -0
- package/dist/components/breadcrumb/breadcrumb.js +40 -0
- package/dist/components/breadcrumb/breadcrumb.js.map +1 -0
- package/dist/components/breadcrumb/breadcrumb.styles.d.ts +3 -0
- package/dist/components/breadcrumb/breadcrumb.styles.d.ts.map +1 -0
- package/dist/components/breadcrumb/breadcrumb.styles.js +57 -0
- package/dist/components/breadcrumb/breadcrumb.styles.js.map +1 -0
- package/dist/components/breadcrumb/index.d.ts +3 -0
- package/dist/components/breadcrumb/index.d.ts.map +1 -0
- package/dist/components/button/button.d.ts +18 -0
- package/dist/components/button/button.d.ts.map +1 -0
- package/dist/components/button/button.js +58 -0
- package/dist/components/button/button.js.map +1 -0
- package/dist/components/button/button.styles.d.ts +2 -0
- package/dist/components/button/button.styles.d.ts.map +1 -0
- package/dist/components/button/button.styles.js +185 -0
- package/dist/components/button/button.styles.js.map +1 -0
- package/dist/components/button/index.d.ts +3 -0
- package/dist/components/button/index.d.ts.map +1 -0
- package/dist/components/card/card.d.ts +18 -0
- package/dist/components/card/card.d.ts.map +1 -0
- package/dist/components/card/card.js +62 -0
- package/dist/components/card/card.js.map +1 -0
- package/dist/components/card/card.styles.d.ts +2 -0
- package/dist/components/card/card.styles.d.ts.map +1 -0
- package/dist/components/card/card.styles.js +129 -0
- package/dist/components/card/card.styles.js.map +1 -0
- package/dist/components/card/index.d.ts +3 -0
- package/dist/components/card/index.d.ts.map +1 -0
- package/dist/components/checkbox/checkbox.d.ts +24 -0
- package/dist/components/checkbox/checkbox.d.ts.map +1 -0
- package/dist/components/checkbox/checkbox.js +83 -0
- package/dist/components/checkbox/checkbox.js.map +1 -0
- package/dist/components/checkbox/checkbox.styles.d.ts +2 -0
- package/dist/components/checkbox/checkbox.styles.d.ts.map +1 -0
- package/dist/components/checkbox/checkbox.styles.js +118 -0
- package/dist/components/checkbox/checkbox.styles.js.map +1 -0
- package/dist/components/checkbox/index.d.ts +3 -0
- package/dist/components/checkbox/index.d.ts.map +1 -0
- package/dist/components/dialog/dialog.d.ts +21 -0
- package/dist/components/dialog/dialog.d.ts.map +1 -0
- package/dist/components/dialog/dialog.js +74 -0
- package/dist/components/dialog/dialog.js.map +1 -0
- package/dist/components/dialog/dialog.styles.d.ts +2 -0
- package/dist/components/dialog/dialog.styles.d.ts.map +1 -0
- package/dist/components/dialog/dialog.styles.js +81 -0
- package/dist/components/dialog/dialog.styles.js.map +1 -0
- package/dist/components/dialog/index.d.ts +3 -0
- package/dist/components/dialog/index.d.ts.map +1 -0
- package/dist/components/divider/divider.d.ts +15 -0
- package/dist/components/divider/divider.d.ts.map +1 -0
- package/dist/components/divider/divider.js +36 -0
- package/dist/components/divider/divider.js.map +1 -0
- package/dist/components/divider/divider.styles.d.ts +2 -0
- package/dist/components/divider/divider.styles.d.ts.map +1 -0
- package/dist/components/divider/divider.styles.js +64 -0
- package/dist/components/divider/divider.styles.js.map +1 -0
- package/dist/components/divider/index.d.ts +3 -0
- package/dist/components/divider/index.d.ts.map +1 -0
- package/dist/components/dropdown/dropdown-item.d.ts +15 -0
- package/dist/components/dropdown/dropdown-item.d.ts.map +1 -0
- package/dist/components/dropdown/dropdown-item.js +113 -0
- package/dist/components/dropdown/dropdown-item.js.map +1 -0
- package/dist/components/dropdown/dropdown.d.ts +29 -0
- package/dist/components/dropdown/dropdown.d.ts.map +1 -0
- package/dist/components/dropdown/dropdown.js +147 -0
- package/dist/components/dropdown/dropdown.js.map +1 -0
- package/dist/components/dropdown/dropdown.styles.d.ts +2 -0
- package/dist/components/dropdown/dropdown.styles.d.ts.map +1 -0
- package/dist/components/dropdown/dropdown.styles.js +139 -0
- package/dist/components/dropdown/dropdown.styles.js.map +1 -0
- package/dist/components/dropdown/index.d.ts +4 -0
- package/dist/components/dropdown/index.d.ts.map +1 -0
- package/dist/components/form-field/form-field.d.ts +17 -0
- package/dist/components/form-field/form-field.d.ts.map +1 -0
- package/dist/components/form-field/form-field.js +55 -0
- package/dist/components/form-field/form-field.js.map +1 -0
- package/dist/components/form-field/form-field.styles.d.ts +2 -0
- package/dist/components/form-field/form-field.styles.d.ts.map +1 -0
- package/dist/components/form-field/form-field.styles.js +61 -0
- package/dist/components/form-field/form-field.styles.js.map +1 -0
- package/dist/components/form-field/index.d.ts +2 -0
- package/dist/components/form-field/index.d.ts.map +1 -0
- package/dist/components/grid/grid.d.ts +18 -0
- package/dist/components/grid/grid.d.ts.map +1 -0
- package/dist/components/grid/grid.js +46 -0
- package/dist/components/grid/grid.js.map +1 -0
- package/dist/components/grid/grid.styles.d.ts +2 -0
- package/dist/components/grid/grid.styles.d.ts.map +1 -0
- package/dist/components/grid/grid.styles.js +57 -0
- package/dist/components/grid/grid.styles.js.map +1 -0
- package/dist/components/grid/index.d.ts +3 -0
- package/dist/components/grid/index.d.ts.map +1 -0
- package/dist/components/icon/icon-registry.d.ts +3 -0
- package/dist/components/icon/icon-registry.d.ts.map +1 -0
- package/dist/components/icon/icon-registry.js +12 -0
- package/dist/components/icon/icon-registry.js.map +1 -0
- package/dist/components/icon/icon.d.ts +18 -0
- package/dist/components/icon/icon.d.ts.map +1 -0
- package/dist/components/icon/icon.js +45 -0
- package/dist/components/icon/icon.js.map +1 -0
- package/dist/components/icon/icon.styles.d.ts +2 -0
- package/dist/components/icon/icon.styles.d.ts.map +1 -0
- package/dist/components/icon/icon.styles.js +46 -0
- package/dist/components/icon/icon.styles.js.map +1 -0
- package/dist/components/icon/index.d.ts +4 -0
- package/dist/components/icon/index.d.ts.map +1 -0
- package/dist/components/input/index.d.ts +3 -0
- package/dist/components/input/index.d.ts.map +1 -0
- package/dist/components/input/input.d.ts +30 -0
- package/dist/components/input/input.d.ts.map +1 -0
- package/dist/components/input/input.js +133 -0
- package/dist/components/input/input.js.map +1 -0
- package/dist/components/input/input.styles.d.ts +2 -0
- package/dist/components/input/input.styles.d.ts.map +1 -0
- package/dist/components/input/input.styles.js +211 -0
- package/dist/components/input/input.styles.js.map +1 -0
- package/dist/components/link/index.d.ts +3 -0
- package/dist/components/link/index.d.ts.map +1 -0
- package/dist/components/link/link.d.ts +16 -0
- package/dist/components/link/link.d.ts.map +1 -0
- package/dist/components/link/link.js +53 -0
- package/dist/components/link/link.js.map +1 -0
- package/dist/components/link/link.styles.d.ts +2 -0
- package/dist/components/link/link.styles.d.ts.map +1 -0
- package/dist/components/link/link.styles.js +57 -0
- package/dist/components/link/link.styles.js.map +1 -0
- package/dist/components/pagination/index.d.ts +3 -0
- package/dist/components/pagination/index.d.ts.map +1 -0
- package/dist/components/pagination/pagination.d.ts +28 -0
- package/dist/components/pagination/pagination.d.ts.map +1 -0
- package/dist/components/pagination/pagination.js +139 -0
- package/dist/components/pagination/pagination.js.map +1 -0
- package/dist/components/pagination/pagination.styles.d.ts +2 -0
- package/dist/components/pagination/pagination.styles.d.ts.map +1 -0
- package/dist/components/pagination/pagination.styles.js +86 -0
- package/dist/components/pagination/pagination.styles.js.map +1 -0
- package/dist/components/popover/index.d.ts +3 -0
- package/dist/components/popover/index.d.ts.map +1 -0
- package/dist/components/popover/popover.d.ts +26 -0
- package/dist/components/popover/popover.d.ts.map +1 -0
- package/dist/components/popover/popover.js +88 -0
- package/dist/components/popover/popover.js.map +1 -0
- package/dist/components/popover/popover.styles.d.ts +2 -0
- package/dist/components/popover/popover.styles.d.ts.map +1 -0
- package/dist/components/popover/popover.styles.js +61 -0
- package/dist/components/popover/popover.styles.js.map +1 -0
- package/dist/components/progress/index.d.ts +9 -0
- package/dist/components/progress/index.d.ts.map +1 -0
- package/dist/components/progress/progress.d.ts +17 -0
- package/dist/components/progress/progress.d.ts.map +1 -0
- package/dist/components/progress/progress.js +57 -0
- package/dist/components/progress/progress.js.map +1 -0
- package/dist/components/progress/progress.styles.d.ts +2 -0
- package/dist/components/progress/progress.styles.d.ts.map +1 -0
- package/dist/components/progress/progress.styles.js +57 -0
- package/dist/components/progress/progress.styles.js.map +1 -0
- package/dist/components/progress/step-timeline.d.ts +23 -0
- package/dist/components/progress/step-timeline.d.ts.map +1 -0
- package/dist/components/progress/step-timeline.js +52 -0
- package/dist/components/progress/step-timeline.js.map +1 -0
- package/dist/components/progress/step-timeline.styles.d.ts +2 -0
- package/dist/components/progress/step-timeline.styles.d.ts.map +1 -0
- package/dist/components/progress/step-timeline.styles.js +137 -0
- package/dist/components/progress/step-timeline.styles.js.map +1 -0
- package/dist/components/progress/step.d.ts +24 -0
- package/dist/components/progress/step.d.ts.map +1 -0
- package/dist/components/progress/step.js +76 -0
- package/dist/components/progress/step.js.map +1 -0
- package/dist/components/progress/step.styles.d.ts +2 -0
- package/dist/components/progress/step.styles.d.ts.map +1 -0
- package/dist/components/progress/step.styles.js +137 -0
- package/dist/components/progress/step.styles.js.map +1 -0
- package/dist/components/progress/stepper-dots.d.ts +19 -0
- package/dist/components/progress/stepper-dots.d.ts.map +1 -0
- package/dist/components/progress/stepper-dots.js +60 -0
- package/dist/components/progress/stepper-dots.js.map +1 -0
- package/dist/components/progress/stepper-dots.styles.d.ts +2 -0
- package/dist/components/progress/stepper-dots.styles.d.ts.map +1 -0
- package/dist/components/progress/stepper-dots.styles.js +29 -0
- package/dist/components/progress/stepper-dots.styles.js.map +1 -0
- package/dist/components/progress/stepper.d.ts +19 -0
- package/dist/components/progress/stepper.d.ts.map +1 -0
- package/dist/components/progress/stepper.js +60 -0
- package/dist/components/progress/stepper.js.map +1 -0
- package/dist/components/progress/stepper.styles.d.ts +2 -0
- package/dist/components/progress/stepper.styles.d.ts.map +1 -0
- package/dist/components/progress/stepper.styles.js +31 -0
- package/dist/components/progress/stepper.styles.js.map +1 -0
- package/dist/components/radio/index.d.ts +4 -0
- package/dist/components/radio/index.d.ts.map +1 -0
- package/dist/components/radio/radio-group.d.ts +24 -0
- package/dist/components/radio/radio-group.d.ts.map +1 -0
- package/dist/components/radio/radio-group.js +77 -0
- package/dist/components/radio/radio-group.js.map +1 -0
- package/dist/components/radio/radio.d.ts +19 -0
- package/dist/components/radio/radio.d.ts.map +1 -0
- package/dist/components/radio/radio.js +55 -0
- package/dist/components/radio/radio.js.map +1 -0
- package/dist/components/radio/radio.styles.d.ts +3 -0
- package/dist/components/radio/radio.styles.d.ts.map +1 -0
- package/dist/components/radio/radio.styles.js +117 -0
- package/dist/components/radio/radio.styles.js.map +1 -0
- package/dist/components/select/index.d.ts +3 -0
- package/dist/components/select/index.d.ts.map +1 -0
- package/dist/components/select/option.d.ts +15 -0
- package/dist/components/select/option.d.ts.map +1 -0
- package/dist/components/select/option.js +39 -0
- package/dist/components/select/option.js.map +1 -0
- package/dist/components/select/select.d.ts +32 -0
- package/dist/components/select/select.d.ts.map +1 -0
- package/dist/components/select/select.js +202 -0
- package/dist/components/select/select.js.map +1 -0
- package/dist/components/select/select.styles.d.ts +2 -0
- package/dist/components/select/select.styles.d.ts.map +1 -0
- package/dist/components/select/select.styles.js +257 -0
- package/dist/components/select/select.styles.js.map +1 -0
- package/dist/components/skeleton/index.d.ts +3 -0
- package/dist/components/skeleton/index.d.ts.map +1 -0
- package/dist/components/skeleton/skeleton.d.ts +18 -0
- package/dist/components/skeleton/skeleton.d.ts.map +1 -0
- package/dist/components/skeleton/skeleton.js +47 -0
- package/dist/components/skeleton/skeleton.js.map +1 -0
- package/dist/components/skeleton/skeleton.styles.d.ts +2 -0
- package/dist/components/skeleton/skeleton.styles.d.ts.map +1 -0
- package/dist/components/skeleton/skeleton.styles.js +72 -0
- package/dist/components/skeleton/skeleton.styles.js.map +1 -0
- package/dist/components/spinner/index.d.ts +3 -0
- package/dist/components/spinner/index.d.ts.map +1 -0
- package/dist/components/spinner/spinner.d.ts +16 -0
- package/dist/components/spinner/spinner.d.ts.map +1 -0
- package/dist/components/spinner/spinner.js +36 -0
- package/dist/components/spinner/spinner.js.map +1 -0
- package/dist/components/spinner/spinner.styles.d.ts +2 -0
- package/dist/components/spinner/spinner.styles.d.ts.map +1 -0
- package/dist/components/spinner/spinner.styles.js +43 -0
- package/dist/components/spinner/spinner.styles.js.map +1 -0
- package/dist/components/stack/index.d.ts +3 -0
- package/dist/components/stack/index.d.ts.map +1 -0
- package/dist/components/stack/stack.d.ts +20 -0
- package/dist/components/stack/stack.d.ts.map +1 -0
- package/dist/components/stack/stack.js +39 -0
- package/dist/components/stack/stack.js.map +1 -0
- package/dist/components/stack/stack.styles.d.ts +2 -0
- package/dist/components/stack/stack.styles.d.ts.map +1 -0
- package/dist/components/stack/stack.styles.js +97 -0
- package/dist/components/stack/stack.styles.js.map +1 -0
- package/dist/components/switch/index.d.ts +3 -0
- package/dist/components/switch/index.d.ts.map +1 -0
- package/dist/components/switch/switch.d.ts +23 -0
- package/dist/components/switch/switch.d.ts.map +1 -0
- package/dist/components/switch/switch.js +69 -0
- package/dist/components/switch/switch.js.map +1 -0
- package/dist/components/switch/switch.styles.d.ts +2 -0
- package/dist/components/switch/switch.styles.d.ts.map +1 -0
- package/dist/components/switch/switch.styles.js +100 -0
- package/dist/components/switch/switch.styles.js.map +1 -0
- package/dist/components/table/index.d.ts +3 -0
- package/dist/components/table/index.d.ts.map +1 -0
- package/dist/components/table/table.d.ts +39 -0
- package/dist/components/table/table.d.ts.map +1 -0
- package/dist/components/table/table.js +209 -0
- package/dist/components/table/table.js.map +1 -0
- package/dist/components/table/table.styles.d.ts +2 -0
- package/dist/components/table/table.styles.d.ts.map +1 -0
- package/dist/components/table/table.styles.js +261 -0
- package/dist/components/table/table.styles.js.map +1 -0
- package/dist/components/tabs/index.d.ts +6 -0
- package/dist/components/tabs/index.d.ts.map +1 -0
- package/dist/components/tabs/tab-panel.d.ts +12 -0
- package/dist/components/tabs/tab-panel.d.ts.map +1 -0
- package/dist/components/tabs/tab-panel.js +34 -0
- package/dist/components/tabs/tab-panel.js.map +1 -0
- package/dist/components/tabs/tab.d.ts +16 -0
- package/dist/components/tabs/tab.d.ts.map +1 -0
- package/dist/components/tabs/tab.js +37 -0
- package/dist/components/tabs/tab.js.map +1 -0
- package/dist/components/tabs/tabs.d.ts +27 -0
- package/dist/components/tabs/tabs.d.ts.map +1 -0
- package/dist/components/tabs/tabs.js +123 -0
- package/dist/components/tabs/tabs.js.map +1 -0
- package/dist/components/tabs/tabs.styles.d.ts +2 -0
- package/dist/components/tabs/tabs.styles.d.ts.map +1 -0
- package/dist/components/tabs/tabs.styles.js +184 -0
- package/dist/components/tabs/tabs.styles.js.map +1 -0
- package/dist/components/tag/index.d.ts +3 -0
- package/dist/components/tag/index.d.ts.map +1 -0
- package/dist/components/tag/tag.d.ts +18 -0
- package/dist/components/tag/tag.d.ts.map +1 -0
- package/dist/components/tag/tag.js +78 -0
- package/dist/components/tag/tag.js.map +1 -0
- package/dist/components/tag/tag.styles.d.ts +2 -0
- package/dist/components/tag/tag.styles.d.ts.map +1 -0
- package/dist/components/tag/tag.styles.js +137 -0
- package/dist/components/tag/tag.styles.js.map +1 -0
- package/dist/components/textarea/index.d.ts +3 -0
- package/dist/components/textarea/index.d.ts.map +1 -0
- package/dist/components/textarea/textarea.d.ts +28 -0
- package/dist/components/textarea/textarea.d.ts.map +1 -0
- package/dist/components/textarea/textarea.js +121 -0
- package/dist/components/textarea/textarea.js.map +1 -0
- package/dist/components/textarea/textarea.styles.d.ts +2 -0
- package/dist/components/textarea/textarea.styles.d.ts.map +1 -0
- package/dist/components/textarea/textarea.styles.js +146 -0
- package/dist/components/textarea/textarea.styles.js.map +1 -0
- package/dist/components/toast/index.d.ts +3 -0
- package/dist/components/toast/index.d.ts.map +1 -0
- package/dist/components/toast/toast.d.ts +31 -0
- package/dist/components/toast/toast.d.ts.map +1 -0
- package/dist/components/toast/toast.js +104 -0
- package/dist/components/toast/toast.js.map +1 -0
- package/dist/components/toast/toast.styles.d.ts +2 -0
- package/dist/components/toast/toast.styles.d.ts.map +1 -0
- package/dist/components/toast/toast.styles.js +176 -0
- package/dist/components/toast/toast.styles.js.map +1 -0
- package/dist/components/tooltip/index.d.ts +3 -0
- package/dist/components/tooltip/index.d.ts.map +1 -0
- package/dist/components/tooltip/tooltip.d.ts +26 -0
- package/dist/components/tooltip/tooltip.d.ts.map +1 -0
- package/dist/components/tooltip/tooltip.js +78 -0
- package/dist/components/tooltip/tooltip.js.map +1 -0
- package/dist/components/tooltip/tooltip.styles.d.ts +2 -0
- package/dist/components/tooltip/tooltip.styles.d.ts.map +1 -0
- package/dist/components/tooltip/tooltip.styles.js +157 -0
- package/dist/components/tooltip/tooltip.styles.js.map +1 -0
- package/dist/index.d.ts +32 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +90 -0
- package/dist/index.js.map +1 -0
- package/dist/react/index.d.ts +161 -0
- package/dist/react/index.d.ts.map +1 -0
- package/dist/styles/mixins.d.ts +4 -0
- package/dist/styles/mixins.d.ts.map +1 -0
- package/dist/styles/reset.d.ts +2 -0
- package/dist/styles/reset.d.ts.map +1 -0
- package/dist/tokens/extract.d.ts +2 -0
- package/dist/tokens/extract.d.ts.map +1 -0
- package/dist/tokens/generated/tokens.d.ts +162 -0
- package/dist/tokens/generated/tokens.d.ts.map +1 -0
- package/dist/tokens/transform-cli.d.ts +2 -0
- package/dist/tokens/transform-cli.d.ts.map +1 -0
- package/dist/tokens/transform.d.ts +3 -0
- package/dist/tokens/transform.d.ts.map +1 -0
- package/package.json +101 -0
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { LitElement } from 'lit';
|
|
2
|
+
export declare class MellowAccordionItem extends LitElement {
|
|
3
|
+
static styles: import("lit").CSSResult[];
|
|
4
|
+
open: boolean;
|
|
5
|
+
disabled: boolean;
|
|
6
|
+
header: string;
|
|
7
|
+
private _toggle;
|
|
8
|
+
private _handleKeydown;
|
|
9
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
10
|
+
}
|
|
11
|
+
declare global {
|
|
12
|
+
interface HTMLElementTagNameMap {
|
|
13
|
+
'mellow-accordion-item': MellowAccordionItem;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=accordion-item.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"accordion-item.d.ts","sourceRoot":"","sources":["../../../src/components/accordion/accordion-item.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAa,MAAM,KAAK,CAAA;AAU3C,qBACa,mBAAoB,SAAQ,UAAU;IACjD,OAAgB,MAAM,4BAAwB;IAG9C,IAAI,UAAQ;IAGZ,QAAQ,UAAQ;IAGhB,MAAM,SAAK;IAEX,OAAO,CAAC,OAAO;IAaf,OAAO,CAAC,cAAc;IAOb,MAAM;CAuBhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,uBAAuB,EAAE,mBAAmB,CAAA;KAC7C;CACF"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { svg as p, LitElement as c, html as h } from "lit";
|
|
2
|
+
import { property as d, customElement as u } from "lit/decorators.js";
|
|
3
|
+
import { accordionItemStyles as v } from "./accordion.styles.js";
|
|
4
|
+
var m = Object.defineProperty, f = Object.getOwnPropertyDescriptor, s = (e, t, l, n) => {
|
|
5
|
+
for (var o = n > 1 ? void 0 : n ? f(t, l) : t, i = e.length - 1, a; i >= 0; i--)
|
|
6
|
+
(a = e[i]) && (o = (n ? a(t, l, o) : a(o)) || o);
|
|
7
|
+
return n && o && m(t, l, o), o;
|
|
8
|
+
};
|
|
9
|
+
const g = p`
|
|
10
|
+
<svg class="chevron" viewBox="0 0 16 16" fill="none" width="16" height="16">
|
|
11
|
+
<path d="M4 6l4 4 4-4" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
|
|
12
|
+
</svg>
|
|
13
|
+
`;
|
|
14
|
+
let r = class extends c {
|
|
15
|
+
constructor() {
|
|
16
|
+
super(...arguments), this.open = !1, this.disabled = !1, this.header = "";
|
|
17
|
+
}
|
|
18
|
+
_toggle() {
|
|
19
|
+
if (this.disabled) return;
|
|
20
|
+
const e = !this.open;
|
|
21
|
+
this.open = e, this.dispatchEvent(new CustomEvent("mellow-toggle", {
|
|
22
|
+
detail: { open: e },
|
|
23
|
+
bubbles: !0,
|
|
24
|
+
composed: !0
|
|
25
|
+
}));
|
|
26
|
+
}
|
|
27
|
+
_handleKeydown(e) {
|
|
28
|
+
(e.key === "Enter" || e.key === " ") && (e.preventDefault(), this._toggle());
|
|
29
|
+
}
|
|
30
|
+
render() {
|
|
31
|
+
const e = "content", t = "header";
|
|
32
|
+
return h`
|
|
33
|
+
<button
|
|
34
|
+
id=${t}
|
|
35
|
+
class="header"
|
|
36
|
+
aria-expanded=${this.open ? "true" : "false"}
|
|
37
|
+
aria-controls=${e}
|
|
38
|
+
@click=${this._toggle}
|
|
39
|
+
@keydown=${this._handleKeydown}
|
|
40
|
+
>
|
|
41
|
+
<span>${this.header}</span>
|
|
42
|
+
${g}
|
|
43
|
+
</button>
|
|
44
|
+
<div class="content-wrapper" id=${e} role="region" aria-labelledby=${t}>
|
|
45
|
+
<div class="content">
|
|
46
|
+
<slot></slot>
|
|
47
|
+
</div>
|
|
48
|
+
</div>
|
|
49
|
+
`;
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
r.styles = [v];
|
|
53
|
+
s([
|
|
54
|
+
d({ type: Boolean, reflect: !0 })
|
|
55
|
+
], r.prototype, "open", 2);
|
|
56
|
+
s([
|
|
57
|
+
d({ type: Boolean, reflect: !0 })
|
|
58
|
+
], r.prototype, "disabled", 2);
|
|
59
|
+
s([
|
|
60
|
+
d()
|
|
61
|
+
], r.prototype, "header", 2);
|
|
62
|
+
r = s([
|
|
63
|
+
u("mellow-accordion-item")
|
|
64
|
+
], r);
|
|
65
|
+
export {
|
|
66
|
+
r as MellowAccordionItem
|
|
67
|
+
};
|
|
68
|
+
//# sourceMappingURL=accordion-item.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"accordion-item.js","sources":["../../../src/components/accordion/accordion-item.ts"],"sourcesContent":["import { LitElement, html, svg } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { accordionItemStyles } from './accordion.styles.js'\n\nconst chevronIcon = svg`\n <svg class=\"chevron\" viewBox=\"0 0 16 16\" fill=\"none\" width=\"16\" height=\"16\">\n <path d=\"M4 6l4 4 4-4\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n`\n\n@customElement('mellow-accordion-item')\nexport class MellowAccordionItem extends LitElement {\n static override styles = [accordionItemStyles]\n\n @property({ type: Boolean, reflect: true })\n open = false\n\n @property({ type: Boolean, reflect: true })\n disabled = false\n\n @property()\n header = ''\n\n private _toggle(): void {\n if (this.disabled) return\n\n const nextOpen = !this.open\n this.open = nextOpen\n\n this.dispatchEvent(new CustomEvent('mellow-toggle', {\n detail: { open: nextOpen },\n bubbles: true,\n composed: true,\n }))\n }\n\n private _handleKeydown(e: KeyboardEvent): void {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n this._toggle()\n }\n }\n\n override render() {\n const contentId = 'content'\n const headerId = 'header'\n\n return html`\n <button\n id=${headerId}\n class=\"header\"\n aria-expanded=${this.open ? 'true' : 'false'}\n aria-controls=${contentId}\n @click=${this._toggle}\n @keydown=${this._handleKeydown}\n >\n <span>${this.header}</span>\n ${chevronIcon}\n </button>\n <div class=\"content-wrapper\" id=${contentId} role=\"region\" aria-labelledby=${headerId}>\n <div class=\"content\">\n <slot></slot>\n </div>\n </div>\n `\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'mellow-accordion-item': MellowAccordionItem\n }\n}\n"],"names":["chevronIcon","svg","MellowAccordionItem","LitElement","nextOpen","contentId","headerId","html","accordionItemStyles","__decorateClass","property","customElement"],"mappings":";;;;;;;;AAIA,MAAMA,IAAcC;AAAA;AAAA;AAAA;AAAA;AAOb,IAAMC,IAAN,cAAkCC,EAAW;AAAA,EAA7C,cAAA;AAAA,UAAA,GAAA,SAAA,GAIL,KAAA,OAAO,IAGP,KAAA,WAAW,IAGX,KAAA,SAAS;AAAA,EAAA;AAAA,EAED,UAAgB;AACtB,QAAI,KAAK,SAAU;AAEnB,UAAMC,IAAW,CAAC,KAAK;AACvB,SAAK,OAAOA,GAEZ,KAAK,cAAc,IAAI,YAAY,iBAAiB;AAAA,MAClD,QAAQ,EAAE,MAAMA,EAAA;AAAA,MAChB,SAAS;AAAA,MACT,UAAU;AAAA,IAAA,CACX,CAAC;AAAA,EACJ;AAAA,EAEQ,eAAe,GAAwB;AAC7C,KAAI,EAAE,QAAQ,WAAW,EAAE,QAAQ,SACjC,EAAE,eAAA,GACF,KAAK,QAAA;AAAA,EAET;AAAA,EAES,SAAS;AAChB,UAAMC,IAAY,WACZC,IAAW;AAEjB,WAAOC;AAAA;AAAA,aAEED,CAAQ;AAAA;AAAA,wBAEG,KAAK,OAAO,SAAS,OAAO;AAAA,wBAC5BD,CAAS;AAAA,iBAChB,KAAK,OAAO;AAAA,mBACV,KAAK,cAAc;AAAA;AAAA,gBAEtB,KAAK,MAAM;AAAA,UACjBL,CAAW;AAAA;AAAA,wCAEmBK,CAAS,kCAAkCC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMzF;AACF;AAvDaJ,EACK,SAAS,CAACM,CAAmB;AAG7CC,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAH/BR,EAIX,WAAA,QAAA,CAAA;AAGAO,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAN/BR,EAOX,WAAA,YAAA,CAAA;AAGAO,EAAA;AAAA,EADCC,EAAA;AAAS,GATCR,EAUX,WAAA,UAAA,CAAA;AAVWA,IAANO,EAAA;AAAA,EADNE,EAAc,uBAAuB;AAAA,GACzBT,CAAA;"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { LitElement } from 'lit';
|
|
2
|
+
export declare class MellowAccordion extends LitElement {
|
|
3
|
+
static styles: import("lit").CSSResult[];
|
|
4
|
+
multiple: boolean;
|
|
5
|
+
connectedCallback(): void;
|
|
6
|
+
disconnectedCallback(): void;
|
|
7
|
+
private _handleToggle;
|
|
8
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
9
|
+
}
|
|
10
|
+
declare global {
|
|
11
|
+
interface HTMLElementTagNameMap {
|
|
12
|
+
'mellow-accordion': MellowAccordion;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=accordion.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"accordion.d.ts","sourceRoot":"","sources":["../../../src/components/accordion/accordion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAQ,MAAM,KAAK,CAAA;AAKtC,qBACa,eAAgB,SAAQ,UAAU;IAC7C,OAAgB,MAAM,4BAAoB;IAG1C,QAAQ,UAAQ;IAEP,iBAAiB,IAAI,IAAI;IAKzB,oBAAoB,IAAI,IAAI;IAKrC,OAAO,CAAC,aAAa,CAepB;IAEQ,MAAM;CAGhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,kBAAkB,EAAE,eAAe,CAAA;KACpC;CACF"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { LitElement as a, html as p } from "lit";
|
|
2
|
+
import { property as m, customElement as d } from "lit/decorators.js";
|
|
3
|
+
import { accordionStyles as f } from "./accordion.styles.js";
|
|
4
|
+
var u = Object.defineProperty, h = Object.getOwnPropertyDescriptor, i = (o, l, r, e) => {
|
|
5
|
+
for (var t = e > 1 ? void 0 : e ? h(l, r) : l, s = o.length - 1, c; s >= 0; s--)
|
|
6
|
+
(c = o[s]) && (t = (e ? c(l, r, t) : c(t)) || t);
|
|
7
|
+
return e && t && u(l, r, t), t;
|
|
8
|
+
};
|
|
9
|
+
let n = class extends a {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments), this.multiple = !1, this._handleToggle = (o) => {
|
|
12
|
+
if (this.multiple) return;
|
|
13
|
+
const l = o.target;
|
|
14
|
+
if (!o.detail.open) return;
|
|
15
|
+
Array.from(
|
|
16
|
+
this.querySelectorAll("mellow-accordion-item")
|
|
17
|
+
).forEach((e) => {
|
|
18
|
+
e !== l && e.open && (e.open = !1);
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
connectedCallback() {
|
|
23
|
+
super.connectedCallback(), this.addEventListener("mellow-toggle", this._handleToggle);
|
|
24
|
+
}
|
|
25
|
+
disconnectedCallback() {
|
|
26
|
+
super.disconnectedCallback(), this.removeEventListener("mellow-toggle", this._handleToggle);
|
|
27
|
+
}
|
|
28
|
+
render() {
|
|
29
|
+
return p`<slot></slot>`;
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
n.styles = [f];
|
|
33
|
+
i([
|
|
34
|
+
m({ type: Boolean })
|
|
35
|
+
], n.prototype, "multiple", 2);
|
|
36
|
+
n = i([
|
|
37
|
+
d("mellow-accordion")
|
|
38
|
+
], n);
|
|
39
|
+
export {
|
|
40
|
+
n as MellowAccordion
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=accordion.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"accordion.js","sources":["../../../src/components/accordion/accordion.ts"],"sourcesContent":["import { LitElement, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { accordionStyles } from './accordion.styles.js'\nimport type { MellowAccordionItem } from './accordion-item.js'\n\n@customElement('mellow-accordion')\nexport class MellowAccordion extends LitElement {\n static override styles = [accordionStyles]\n\n @property({ type: Boolean })\n multiple = false\n\n override connectedCallback(): void {\n super.connectedCallback()\n this.addEventListener('mellow-toggle', this._handleToggle as EventListener)\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback()\n this.removeEventListener('mellow-toggle', this._handleToggle as EventListener)\n }\n\n private _handleToggle = (e: CustomEvent<{ open: boolean }>): void => {\n if (this.multiple) return\n\n const target = e.target as MellowAccordionItem\n if (!e.detail.open) return\n\n const items = Array.from(\n this.querySelectorAll<MellowAccordionItem>('mellow-accordion-item')\n )\n\n items.forEach((item) => {\n if (item !== target && item.open) {\n item.open = false\n }\n })\n }\n\n override render() {\n return html`<slot></slot>`\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'mellow-accordion': MellowAccordion\n }\n}\n"],"names":["MellowAccordion","LitElement","e","target","item","html","accordionStyles","__decorateClass","property","customElement"],"mappings":";;;;;;;;AAMO,IAAMA,IAAN,cAA8BC,EAAW;AAAA,EAAzC,cAAA;AAAA,UAAA,GAAA,SAAA,GAIL,KAAA,WAAW,IAYX,KAAQ,gBAAgB,CAACC,MAA4C;AACnE,UAAI,KAAK,SAAU;AAEnB,YAAMC,IAASD,EAAE;AACjB,UAAI,CAACA,EAAE,OAAO,KAAM;AAMpB,MAJc,MAAM;AAAA,QAClB,KAAK,iBAAsC,uBAAuB;AAAA,MAAA,EAG9D,QAAQ,CAACE,MAAS;AACtB,QAAIA,MAASD,KAAUC,EAAK,SAC1BA,EAAK,OAAO;AAAA,MAEhB,CAAC;AAAA,IACH;AAAA,EAAA;AAAA,EAzBS,oBAA0B;AACjC,UAAM,kBAAA,GACN,KAAK,iBAAiB,iBAAiB,KAAK,aAA8B;AAAA,EAC5E;AAAA,EAES,uBAA6B;AACpC,UAAM,qBAAA,GACN,KAAK,oBAAoB,iBAAiB,KAAK,aAA8B;AAAA,EAC/E;AAAA,EAmBS,SAAS;AAChB,WAAOC;AAAA,EACT;AACF;AApCaL,EACK,SAAS,CAACM,CAAe;AAGzCC,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,QAAA,CAAS;AAAA,GAHhBR,EAIX,WAAA,YAAA,CAAA;AAJWA,IAANO,EAAA;AAAA,EADNE,EAAc,kBAAkB;AAAA,GACpBT,CAAA;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"accordion.styles.d.ts","sourceRoot":"","sources":["../../../src/components/accordion/accordion.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,eAAe,yBAO3B,CAAA;AAED,eAAO,MAAM,mBAAmB,yBA8D/B,CAAA"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { css as o } from "lit";
|
|
2
|
+
const t = o`
|
|
3
|
+
:host {
|
|
4
|
+
display: block;
|
|
5
|
+
border: 1px solid #f5eddf;
|
|
6
|
+
border-radius: 8px;
|
|
7
|
+
overflow: hidden;
|
|
8
|
+
}
|
|
9
|
+
`, r = o`
|
|
10
|
+
:host {
|
|
11
|
+
display: block;
|
|
12
|
+
border-bottom: 1px solid #f5eddf;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
:host(:last-child) {
|
|
16
|
+
border-bottom: none;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.header {
|
|
20
|
+
display: flex;
|
|
21
|
+
align-items: center;
|
|
22
|
+
justify-content: space-between;
|
|
23
|
+
width: 100%;
|
|
24
|
+
padding: 12px 16px;
|
|
25
|
+
background: none;
|
|
26
|
+
border: none;
|
|
27
|
+
cursor: pointer;
|
|
28
|
+
font-family: system-ui, sans-serif;
|
|
29
|
+
font-size: 14px;
|
|
30
|
+
font-weight: 500;
|
|
31
|
+
color: #232222;
|
|
32
|
+
text-align: left;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
.header:hover {
|
|
36
|
+
background: #faf5ed;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
:host([disabled]) .header {
|
|
40
|
+
opacity: 0.48;
|
|
41
|
+
cursor: not-allowed;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
.chevron {
|
|
45
|
+
width: 16px;
|
|
46
|
+
height: 16px;
|
|
47
|
+
color: #767676;
|
|
48
|
+
transition: transform 200ms ease;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
:host([open]) .chevron {
|
|
52
|
+
transform: rotate(180deg);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.content {
|
|
56
|
+
padding: 0 16px 12px;
|
|
57
|
+
font-size: 14px;
|
|
58
|
+
line-height: 20px;
|
|
59
|
+
color: #232222;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.content-wrapper {
|
|
63
|
+
overflow: hidden;
|
|
64
|
+
max-height: 0;
|
|
65
|
+
transition: max-height 200ms ease;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
:host([open]) .content-wrapper {
|
|
69
|
+
max-height: 500px;
|
|
70
|
+
}
|
|
71
|
+
`;
|
|
72
|
+
export {
|
|
73
|
+
r as accordionItemStyles,
|
|
74
|
+
t as accordionStyles
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=accordion.styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"accordion.styles.js","sources":["../../../src/components/accordion/accordion.styles.ts"],"sourcesContent":["import { css } from 'lit'\n\nexport const accordionStyles = css`\n :host {\n display: block;\n border: 1px solid #f5eddf;\n border-radius: 8px;\n overflow: hidden;\n }\n`\n\nexport const accordionItemStyles = css`\n :host {\n display: block;\n border-bottom: 1px solid #f5eddf;\n }\n\n :host(:last-child) {\n border-bottom: none;\n }\n\n .header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n padding: 12px 16px;\n background: none;\n border: none;\n cursor: pointer;\n font-family: system-ui, sans-serif;\n font-size: 14px;\n font-weight: 500;\n color: #232222;\n text-align: left;\n }\n\n .header:hover {\n background: #faf5ed;\n }\n\n :host([disabled]) .header {\n opacity: 0.48;\n cursor: not-allowed;\n }\n\n .chevron {\n width: 16px;\n height: 16px;\n color: #767676;\n transition: transform 200ms ease;\n }\n\n :host([open]) .chevron {\n transform: rotate(180deg);\n }\n\n .content {\n padding: 0 16px 12px;\n font-size: 14px;\n line-height: 20px;\n color: #232222;\n }\n\n .content-wrapper {\n overflow: hidden;\n max-height: 0;\n transition: max-height 200ms ease;\n }\n\n :host([open]) .content-wrapper {\n max-height: 500px;\n }\n`\n"],"names":["accordionStyles","css","accordionItemStyles"],"mappings":";AAEO,MAAMA,IAAkBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GASlBC,IAAsBD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/accordion/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AAChD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAA"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { LitElement, nothing } from 'lit';
|
|
2
|
+
export type AlertVariant = 'info' | 'accent' | 'danger' | 'warning' | 'success';
|
|
3
|
+
export declare class MellowAlert extends LitElement {
|
|
4
|
+
static styles: import("lit").CSSResult[];
|
|
5
|
+
variant: AlertVariant;
|
|
6
|
+
dismissible: boolean;
|
|
7
|
+
private _dismissed;
|
|
8
|
+
private _handleDismiss;
|
|
9
|
+
render(): import("lit-html").TemplateResult<1> | typeof nothing;
|
|
10
|
+
}
|
|
11
|
+
declare global {
|
|
12
|
+
interface HTMLElementTagNameMap {
|
|
13
|
+
'mellow-alert': MellowAlert;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=alert.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert.d.ts","sourceRoot":"","sources":["../../../src/components/alert/alert.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAa,OAAO,EAAE,MAAM,KAAK,CAAA;AAIpD,MAAM,MAAM,YAAY,GAAG,MAAM,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,SAAS,CAAA;AAgB/E,qBACa,WAAY,SAAQ,UAAU;IACzC,OAAgB,MAAM,4BAAgB;IAGtC,OAAO,EAAE,YAAY,CAAS;IAG9B,WAAW,UAAQ;IAGnB,OAAO,CAAC,UAAU,CAAQ;IAE1B,OAAO,CAAC,cAAc;IAQb,MAAM;CA0BhB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,cAAc,EAAE,WAAW,CAAA;KAC5B;CACF"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { svg as m, LitElement as p, nothing as a, html as d } from "lit";
|
|
2
|
+
import { property as h, state as u, customElement as v } from "lit/decorators.js";
|
|
3
|
+
import { alertStyles as f } from "./alert.styles.js";
|
|
4
|
+
var b = Object.defineProperty, w = Object.getOwnPropertyDescriptor, r = (c, e, o, i) => {
|
|
5
|
+
for (var t = i > 1 ? void 0 : i ? w(e, o) : e, l = c.length - 1, n; l >= 0; l--)
|
|
6
|
+
(n = c[l]) && (t = (i ? n(e, o, t) : n(t)) || t);
|
|
7
|
+
return i && t && b(e, o, t), t;
|
|
8
|
+
};
|
|
9
|
+
const _ = m`
|
|
10
|
+
<svg viewBox="0 0 20 20" fill="none" width="20" height="20">
|
|
11
|
+
<circle cx="10" cy="10" r="8.5" stroke="currentColor" stroke-width="1.2"/>
|
|
12
|
+
<path d="M10 9v4" stroke="currentColor" stroke-width="1.2" stroke-linecap="round"/>
|
|
13
|
+
<circle cx="10" cy="7" r="0.75" fill="currentColor"/>
|
|
14
|
+
</svg>
|
|
15
|
+
`, g = m`
|
|
16
|
+
<svg viewBox="0 0 16 16" fill="none" width="16" height="16">
|
|
17
|
+
<path d="M4 4l8 8M12 4l-8 8" stroke="currentColor" stroke-width="1.2" stroke-linecap="round"/>
|
|
18
|
+
</svg>
|
|
19
|
+
`;
|
|
20
|
+
let s = class extends p {
|
|
21
|
+
constructor() {
|
|
22
|
+
super(...arguments), this.variant = "info", this.dismissible = !1, this._dismissed = !1;
|
|
23
|
+
}
|
|
24
|
+
_handleDismiss() {
|
|
25
|
+
this._dismissed = !0, this.dispatchEvent(new CustomEvent("mellow-dismiss", {
|
|
26
|
+
bubbles: !0,
|
|
27
|
+
composed: !0
|
|
28
|
+
}));
|
|
29
|
+
}
|
|
30
|
+
render() {
|
|
31
|
+
return this._dismissed ? a : d`
|
|
32
|
+
<div class="alert" role="alert">
|
|
33
|
+
<div class="icon-frame">
|
|
34
|
+
<slot name="icon">${_}</slot>
|
|
35
|
+
</div>
|
|
36
|
+
<div class="content">
|
|
37
|
+
<slot name="title">
|
|
38
|
+
<slot></slot>
|
|
39
|
+
</slot>
|
|
40
|
+
<slot name="subtitle"></slot>
|
|
41
|
+
</div>
|
|
42
|
+
${this.dismissible ? d`<button
|
|
43
|
+
class="dismiss-btn"
|
|
44
|
+
aria-label="Dismiss"
|
|
45
|
+
@click=${this._handleDismiss}
|
|
46
|
+
>${g}</button>` : a}
|
|
47
|
+
</div>
|
|
48
|
+
`;
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
s.styles = [f];
|
|
52
|
+
r([
|
|
53
|
+
h({ reflect: !0 })
|
|
54
|
+
], s.prototype, "variant", 2);
|
|
55
|
+
r([
|
|
56
|
+
h({ type: Boolean, reflect: !0 })
|
|
57
|
+
], s.prototype, "dismissible", 2);
|
|
58
|
+
r([
|
|
59
|
+
u()
|
|
60
|
+
], s.prototype, "_dismissed", 2);
|
|
61
|
+
s = r([
|
|
62
|
+
v("mellow-alert")
|
|
63
|
+
], s);
|
|
64
|
+
export {
|
|
65
|
+
s as MellowAlert
|
|
66
|
+
};
|
|
67
|
+
//# sourceMappingURL=alert.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert.js","sources":["../../../src/components/alert/alert.ts"],"sourcesContent":["import { LitElement, html, svg, nothing } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { alertStyles } from './alert.styles.js'\n\nexport type AlertVariant = 'info' | 'accent' | 'danger' | 'warning' | 'success'\n\nconst infoIcon = svg`\n <svg viewBox=\"0 0 20 20\" fill=\"none\" width=\"20\" height=\"20\">\n <circle cx=\"10\" cy=\"10\" r=\"8.5\" stroke=\"currentColor\" stroke-width=\"1.2\"/>\n <path d=\"M10 9v4\" stroke=\"currentColor\" stroke-width=\"1.2\" stroke-linecap=\"round\"/>\n <circle cx=\"10\" cy=\"7\" r=\"0.75\" fill=\"currentColor\"/>\n </svg>\n`\n\nconst closeIcon = svg`\n <svg viewBox=\"0 0 16 16\" fill=\"none\" width=\"16\" height=\"16\">\n <path d=\"M4 4l8 8M12 4l-8 8\" stroke=\"currentColor\" stroke-width=\"1.2\" stroke-linecap=\"round\"/>\n </svg>\n`\n\n@customElement('mellow-alert')\nexport class MellowAlert extends LitElement {\n static override styles = [alertStyles]\n\n @property({ reflect: true })\n variant: AlertVariant = 'info'\n\n @property({ type: Boolean, reflect: true })\n dismissible = false\n\n @state()\n private _dismissed = false\n\n private _handleDismiss(): void {\n this._dismissed = true\n this.dispatchEvent(new CustomEvent('mellow-dismiss', {\n bubbles: true,\n composed: true,\n }))\n }\n\n override render() {\n if (this._dismissed) {\n return nothing\n }\n\n return html`\n <div class=\"alert\" role=\"alert\">\n <div class=\"icon-frame\">\n <slot name=\"icon\">${infoIcon}</slot>\n </div>\n <div class=\"content\">\n <slot name=\"title\">\n <slot></slot>\n </slot>\n <slot name=\"subtitle\"></slot>\n </div>\n ${this.dismissible\n ? html`<button\n class=\"dismiss-btn\"\n aria-label=\"Dismiss\"\n @click=${this._handleDismiss}\n >${closeIcon}</button>`\n : nothing}\n </div>\n `\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'mellow-alert': MellowAlert\n }\n}\n"],"names":["infoIcon","svg","closeIcon","MellowAlert","LitElement","nothing","html","alertStyles","__decorateClass","property","state","customElement"],"mappings":";;;;;;;;AAMA,MAAMA,IAAWC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQXC,IAAYD;AAAA;AAAA;AAAA;AAAA;AAOX,IAAME,IAAN,cAA0BC,EAAW;AAAA,EAArC,cAAA;AAAA,UAAA,GAAA,SAAA,GAIL,KAAA,UAAwB,QAGxB,KAAA,cAAc,IAGd,KAAQ,aAAa;AAAA,EAAA;AAAA,EAEb,iBAAuB;AAC7B,SAAK,aAAa,IAClB,KAAK,cAAc,IAAI,YAAY,kBAAkB;AAAA,MACnD,SAAS;AAAA,MACT,UAAU;AAAA,IAAA,CACX,CAAC;AAAA,EACJ;AAAA,EAES,SAAS;AAChB,WAAI,KAAK,aACAC,IAGFC;AAAA;AAAA;AAAA,8BAGmBN,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAQ5B,KAAK,cACHM;AAAA;AAAA;AAAA,uBAGW,KAAK,cAAc;AAAA,eAC3BJ,CAAS,cACZG,CAAO;AAAA;AAAA;AAAA,EAGjB;AACF;AA9CaF,EACK,SAAS,CAACI,CAAW;AAGrCC,EAAA;AAAA,EADCC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GAHhBN,EAIX,WAAA,WAAA,CAAA;AAGAK,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAN/BN,EAOX,WAAA,eAAA,CAAA;AAGQK,EAAA;AAAA,EADPE,EAAA;AAAM,GATIP,EAUH,WAAA,cAAA,CAAA;AAVGA,IAANK,EAAA;AAAA,EADNG,EAAc,cAAc;AAAA,GAChBR,CAAA;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert.styles.d.ts","sourceRoot":"","sources":["../../../src/components/alert/alert.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,WAAW,yBA0JvB,CAAA"}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { css as r } from "lit";
|
|
2
|
+
const e = r`
|
|
3
|
+
:host {
|
|
4
|
+
display: block;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
:host([hidden]) {
|
|
8
|
+
display: none;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
/* ---- Base ---- */
|
|
12
|
+
|
|
13
|
+
.alert {
|
|
14
|
+
display: flex;
|
|
15
|
+
gap: 8px;
|
|
16
|
+
align-items: flex-start;
|
|
17
|
+
padding: 15px;
|
|
18
|
+
border: 1px solid;
|
|
19
|
+
border-radius: 12px;
|
|
20
|
+
font-family: var(--mellow-typography-font-family-body, 'Suisse Int\\'l', system-ui, sans-serif);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/* ---- Variant: Info (default) ---- */
|
|
24
|
+
|
|
25
|
+
:host([variant='info']) .alert,
|
|
26
|
+
.alert {
|
|
27
|
+
background: var(--mellow-colors-bg-secondary, #ede2d6);
|
|
28
|
+
border-color: var(--mellow-colors-pearl-bush-300, #d3b69e);
|
|
29
|
+
color: var(--mellow-colors-primary-shark, #232222);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
/* ---- Variant: Accent ---- */
|
|
33
|
+
|
|
34
|
+
:host([variant='accent']) .alert {
|
|
35
|
+
background: var(--mellow-colors-orange-100, #f9e5d1);
|
|
36
|
+
border-color: var(--mellow-colors-primary-mellow-orange, #ff6f23);
|
|
37
|
+
color: var(--mellow-colors-primary-shark, #232222);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/* ---- Variant: Danger ---- */
|
|
41
|
+
|
|
42
|
+
:host([variant='danger']) .alert {
|
|
43
|
+
background: rgba(246, 132, 115, 0.16);
|
|
44
|
+
border-color: var(--mellow-colors-red-punch-600, #db4933);
|
|
45
|
+
color: var(--mellow-colors-red-punch-600, #db4933);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
/* ---- Variant: Warning ---- */
|
|
49
|
+
|
|
50
|
+
:host([variant='warning']) .alert {
|
|
51
|
+
background: rgba(255, 202, 27, 0.16);
|
|
52
|
+
border-color: var(--mellow-colors-yellow-sea-600, #e27f00);
|
|
53
|
+
color: var(--mellow-colors-yellow-sea-600, #e27f00);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/* ---- Variant: Success ---- */
|
|
57
|
+
|
|
58
|
+
:host([variant='success']) .alert {
|
|
59
|
+
background: rgba(94, 139, 127, 0.12);
|
|
60
|
+
border-color: var(--mellow-colors-viridian-green-400, #5e8b7f);
|
|
61
|
+
color: var(--mellow-colors-viridian-green-400, #5e8b7f);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/* ---- Info & Accent text stays primary ---- */
|
|
65
|
+
|
|
66
|
+
:host([variant='info']) .title,
|
|
67
|
+
:host([variant='info']) .subtitle,
|
|
68
|
+
:host([variant='accent']) .title,
|
|
69
|
+
:host([variant='accent']) .subtitle,
|
|
70
|
+
.title,
|
|
71
|
+
.subtitle {
|
|
72
|
+
color: var(--mellow-colors-primary-shark, #232222);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
:host([variant='danger']) .title,
|
|
76
|
+
:host([variant='danger']) .subtitle {
|
|
77
|
+
color: var(--mellow-colors-red-punch-600, #db4933);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
:host([variant='warning']) .title,
|
|
81
|
+
:host([variant='warning']) .subtitle {
|
|
82
|
+
color: var(--mellow-colors-yellow-sea-600, #e27f00);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
:host([variant='success']) .title,
|
|
86
|
+
:host([variant='success']) .subtitle {
|
|
87
|
+
color: var(--mellow-colors-viridian-green-400, #5e8b7f);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
/* ---- Icon ---- */
|
|
91
|
+
|
|
92
|
+
.icon-frame {
|
|
93
|
+
flex-shrink: 0;
|
|
94
|
+
width: 20px;
|
|
95
|
+
height: 22px;
|
|
96
|
+
display: flex;
|
|
97
|
+
align-items: center;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
.icon-frame ::slotted(*),
|
|
101
|
+
.icon-frame svg {
|
|
102
|
+
width: 20px;
|
|
103
|
+
height: 20px;
|
|
104
|
+
color: inherit;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/* ---- Content ---- */
|
|
108
|
+
|
|
109
|
+
.content {
|
|
110
|
+
flex: 1;
|
|
111
|
+
min-width: 0;
|
|
112
|
+
display: flex;
|
|
113
|
+
flex-direction: column;
|
|
114
|
+
gap: 4px;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
.title {
|
|
118
|
+
font-size: 16px;
|
|
119
|
+
font-weight: 500;
|
|
120
|
+
line-height: 22px;
|
|
121
|
+
margin: 0;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
.subtitle {
|
|
125
|
+
font-size: 14px;
|
|
126
|
+
font-weight: 400;
|
|
127
|
+
line-height: 18px;
|
|
128
|
+
margin: 0;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
/* ---- Dismiss button ---- */
|
|
132
|
+
|
|
133
|
+
.dismiss-btn {
|
|
134
|
+
flex-shrink: 0;
|
|
135
|
+
width: 16px;
|
|
136
|
+
height: 22px;
|
|
137
|
+
display: flex;
|
|
138
|
+
align-items: center;
|
|
139
|
+
justify-content: center;
|
|
140
|
+
background: none;
|
|
141
|
+
border: none;
|
|
142
|
+
cursor: pointer;
|
|
143
|
+
padding: 0;
|
|
144
|
+
color: inherit;
|
|
145
|
+
opacity: 0.7;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
.dismiss-btn:hover {
|
|
149
|
+
opacity: 1;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
.dismiss-btn svg {
|
|
153
|
+
width: 16px;
|
|
154
|
+
height: 16px;
|
|
155
|
+
}
|
|
156
|
+
`;
|
|
157
|
+
export {
|
|
158
|
+
e as alertStyles
|
|
159
|
+
};
|
|
160
|
+
//# sourceMappingURL=alert.styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert.styles.js","sources":["../../../src/components/alert/alert.styles.ts"],"sourcesContent":["import { css } from 'lit'\n\nexport const alertStyles = css`\n :host {\n display: block;\n }\n\n :host([hidden]) {\n display: none;\n }\n\n /* ---- Base ---- */\n\n .alert {\n display: flex;\n gap: 8px;\n align-items: flex-start;\n padding: 15px;\n border: 1px solid;\n border-radius: 12px;\n font-family: var(--mellow-typography-font-family-body, 'Suisse Int\\\\'l', system-ui, sans-serif);\n }\n\n /* ---- Variant: Info (default) ---- */\n\n :host([variant='info']) .alert,\n .alert {\n background: var(--mellow-colors-bg-secondary, #ede2d6);\n border-color: var(--mellow-colors-pearl-bush-300, #d3b69e);\n color: var(--mellow-colors-primary-shark, #232222);\n }\n\n /* ---- Variant: Accent ---- */\n\n :host([variant='accent']) .alert {\n background: var(--mellow-colors-orange-100, #f9e5d1);\n border-color: var(--mellow-colors-primary-mellow-orange, #ff6f23);\n color: var(--mellow-colors-primary-shark, #232222);\n }\n\n /* ---- Variant: Danger ---- */\n\n :host([variant='danger']) .alert {\n background: rgba(246, 132, 115, 0.16);\n border-color: var(--mellow-colors-red-punch-600, #db4933);\n color: var(--mellow-colors-red-punch-600, #db4933);\n }\n\n /* ---- Variant: Warning ---- */\n\n :host([variant='warning']) .alert {\n background: rgba(255, 202, 27, 0.16);\n border-color: var(--mellow-colors-yellow-sea-600, #e27f00);\n color: var(--mellow-colors-yellow-sea-600, #e27f00);\n }\n\n /* ---- Variant: Success ---- */\n\n :host([variant='success']) .alert {\n background: rgba(94, 139, 127, 0.12);\n border-color: var(--mellow-colors-viridian-green-400, #5e8b7f);\n color: var(--mellow-colors-viridian-green-400, #5e8b7f);\n }\n\n /* ---- Info & Accent text stays primary ---- */\n\n :host([variant='info']) .title,\n :host([variant='info']) .subtitle,\n :host([variant='accent']) .title,\n :host([variant='accent']) .subtitle,\n .title,\n .subtitle {\n color: var(--mellow-colors-primary-shark, #232222);\n }\n\n :host([variant='danger']) .title,\n :host([variant='danger']) .subtitle {\n color: var(--mellow-colors-red-punch-600, #db4933);\n }\n\n :host([variant='warning']) .title,\n :host([variant='warning']) .subtitle {\n color: var(--mellow-colors-yellow-sea-600, #e27f00);\n }\n\n :host([variant='success']) .title,\n :host([variant='success']) .subtitle {\n color: var(--mellow-colors-viridian-green-400, #5e8b7f);\n }\n\n /* ---- Icon ---- */\n\n .icon-frame {\n flex-shrink: 0;\n width: 20px;\n height: 22px;\n display: flex;\n align-items: center;\n }\n\n .icon-frame ::slotted(*),\n .icon-frame svg {\n width: 20px;\n height: 20px;\n color: inherit;\n }\n\n /* ---- Content ---- */\n\n .content {\n flex: 1;\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: 4px;\n }\n\n .title {\n font-size: 16px;\n font-weight: 500;\n line-height: 22px;\n margin: 0;\n }\n\n .subtitle {\n font-size: 14px;\n font-weight: 400;\n line-height: 18px;\n margin: 0;\n }\n\n /* ---- Dismiss button ---- */\n\n .dismiss-btn {\n flex-shrink: 0;\n width: 16px;\n height: 22px;\n display: flex;\n align-items: center;\n justify-content: center;\n background: none;\n border: none;\n cursor: pointer;\n padding: 0;\n color: inherit;\n opacity: 0.7;\n }\n\n .dismiss-btn:hover {\n opacity: 1;\n }\n\n .dismiss-btn svg {\n width: 16px;\n height: 16px;\n }\n`\n"],"names":["alertStyles","css"],"mappings":";AAEO,MAAMA,IAAcC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/alert/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AACxC,YAAY,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { LitElement } from 'lit';
|
|
2
|
+
export type AvatarSize = 'sm' | 'md' | 'lg';
|
|
3
|
+
export declare class MellowAvatar extends LitElement {
|
|
4
|
+
static styles: import("lit").CSSResult[];
|
|
5
|
+
src: string;
|
|
6
|
+
alt: string;
|
|
7
|
+
name: string;
|
|
8
|
+
size: AvatarSize;
|
|
9
|
+
private _imgError;
|
|
10
|
+
private _handleImgError;
|
|
11
|
+
private _renderContent;
|
|
12
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
13
|
+
}
|
|
14
|
+
declare global {
|
|
15
|
+
interface HTMLElementTagNameMap {
|
|
16
|
+
'mellow-avatar': MellowAvatar;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=avatar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"avatar.d.ts","sourceRoot":"","sources":["../../../src/components/avatar/avatar.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAa,MAAM,KAAK,CAAA;AAI3C,MAAM,MAAM,UAAU,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAA;AAc3C,qBACa,YAAa,SAAQ,UAAU;IAC1C,OAAgB,MAAM,4BAAiB;IAGvC,GAAG,SAAK;IAGR,GAAG,SAAK;IAGR,IAAI,SAAK;IAGT,IAAI,EAAE,UAAU,CAAO;IAGvB,OAAO,CAAC,SAAS,CAAQ;IAEzB,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,cAAc;IAgBb,MAAM;CAShB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,eAAe,EAAE,YAAY,CAAA;KAC9B;CACF"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { svg as p, LitElement as h, html as n } from "lit";
|
|
2
|
+
import { property as l, state as v, customElement as u } from "lit/decorators.js";
|
|
3
|
+
import { avatarStyles as f } from "./avatar.styles.js";
|
|
4
|
+
var _ = Object.defineProperty, g = Object.getOwnPropertyDescriptor, a = (e, i, o, s) => {
|
|
5
|
+
for (var t = s > 1 ? void 0 : s ? g(i, o) : i, m = e.length - 1, c; m >= 0; m--)
|
|
6
|
+
(c = e[m]) && (t = (s ? c(i, o, t) : c(t)) || t);
|
|
7
|
+
return s && t && _(i, o, t), t;
|
|
8
|
+
};
|
|
9
|
+
const d = p`
|
|
10
|
+
<svg viewBox="0 0 24 24" fill="currentColor" aria-hidden="true">
|
|
11
|
+
<path d="M12 12c2.7 0 4.8-2.1 4.8-4.8S14.7 2.4 12 2.4 7.2 4.5 7.2 7.2 9.3 12 12 12zm0 2.4c-3.2 0-9.6 1.6-9.6 4.8v2.4h19.2v-2.4c0-3.2-6.4-4.8-9.6-4.8z"/>
|
|
12
|
+
</svg>
|
|
13
|
+
`;
|
|
14
|
+
function y(e) {
|
|
15
|
+
return e.trim().split(/\s+/).slice(0, 2).map((s) => s.charAt(0)).join("");
|
|
16
|
+
}
|
|
17
|
+
let r = class extends h {
|
|
18
|
+
constructor() {
|
|
19
|
+
super(...arguments), this.src = "", this.alt = "", this.name = "", this.size = "md", this._imgError = !1;
|
|
20
|
+
}
|
|
21
|
+
_handleImgError() {
|
|
22
|
+
this._imgError = !0;
|
|
23
|
+
}
|
|
24
|
+
_renderContent() {
|
|
25
|
+
return this.src && !this._imgError ? n`<img
|
|
26
|
+
src=${this.src}
|
|
27
|
+
alt=${this.alt || this.name}
|
|
28
|
+
@error=${this._handleImgError}
|
|
29
|
+
/>` : this.name ? n`<span class="initials">${y(this.name)}</span>` : n`<span class="fallback-icon">${d}</span>`;
|
|
30
|
+
}
|
|
31
|
+
render() {
|
|
32
|
+
const e = this.alt || this.name || "avatar";
|
|
33
|
+
return n`
|
|
34
|
+
<div class="avatar" role="img" aria-label=${e}>
|
|
35
|
+
${this._renderContent()}
|
|
36
|
+
</div>
|
|
37
|
+
`;
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
r.styles = [f];
|
|
41
|
+
a([
|
|
42
|
+
l()
|
|
43
|
+
], r.prototype, "src", 2);
|
|
44
|
+
a([
|
|
45
|
+
l()
|
|
46
|
+
], r.prototype, "alt", 2);
|
|
47
|
+
a([
|
|
48
|
+
l()
|
|
49
|
+
], r.prototype, "name", 2);
|
|
50
|
+
a([
|
|
51
|
+
l({ reflect: !0 })
|
|
52
|
+
], r.prototype, "size", 2);
|
|
53
|
+
a([
|
|
54
|
+
v()
|
|
55
|
+
], r.prototype, "_imgError", 2);
|
|
56
|
+
r = a([
|
|
57
|
+
u("mellow-avatar")
|
|
58
|
+
], r);
|
|
59
|
+
export {
|
|
60
|
+
r as MellowAvatar
|
|
61
|
+
};
|
|
62
|
+
//# sourceMappingURL=avatar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"avatar.js","sources":["../../../src/components/avatar/avatar.ts"],"sourcesContent":["import { LitElement, html, svg } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { avatarStyles } from './avatar.styles.js'\n\nexport type AvatarSize = 'sm' | 'md' | 'lg'\n\nconst userIcon = svg`\n <svg viewBox=\"0 0 24 24\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M12 12c2.7 0 4.8-2.1 4.8-4.8S14.7 2.4 12 2.4 7.2 4.5 7.2 7.2 9.3 12 12 12zm0 2.4c-3.2 0-9.6 1.6-9.6 4.8v2.4h19.2v-2.4c0-3.2-6.4-4.8-9.6-4.8z\"/>\n </svg>\n`\n\nfunction getInitials(name: string): string {\n const words = name.trim().split(/\\s+/)\n const letters = words.slice(0, 2).map((w) => w.charAt(0))\n return letters.join('')\n}\n\n@customElement('mellow-avatar')\nexport class MellowAvatar extends LitElement {\n static override styles = [avatarStyles]\n\n @property()\n src = ''\n\n @property()\n alt = ''\n\n @property()\n name = ''\n\n @property({ reflect: true })\n size: AvatarSize = 'md'\n\n @state()\n private _imgError = false\n\n private _handleImgError(): void {\n this._imgError = true\n }\n\n private _renderContent() {\n if (this.src && !this._imgError) {\n return html`<img\n src=${this.src}\n alt=${this.alt || this.name}\n @error=${this._handleImgError}\n />`\n }\n\n if (this.name) {\n return html`<span class=\"initials\">${getInitials(this.name)}</span>`\n }\n\n return html`<span class=\"fallback-icon\">${userIcon}</span>`\n }\n\n override render() {\n const label = this.alt || this.name || 'avatar'\n\n return html`\n <div class=\"avatar\" role=\"img\" aria-label=${label}>\n ${this._renderContent()}\n </div>\n `\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'mellow-avatar': MellowAvatar\n }\n}\n"],"names":["userIcon","svg","getInitials","name","w","MellowAvatar","LitElement","html","label","avatarStyles","__decorateClass","property","state","customElement"],"mappings":";;;;;;;;AAMA,MAAMA,IAAWC;AAAA;AAAA;AAAA;AAAA;AAMjB,SAASC,EAAYC,GAAsB;AAGzC,SAFcA,EAAK,KAAA,EAAO,MAAM,KAAK,EACf,MAAM,GAAG,CAAC,EAAE,IAAI,CAACC,MAAMA,EAAE,OAAO,CAAC,CAAC,EACzC,KAAK,EAAE;AACxB;AAGO,IAAMC,IAAN,cAA2BC,EAAW;AAAA,EAAtC,cAAA;AAAA,UAAA,GAAA,SAAA,GAIL,KAAA,MAAM,IAGN,KAAA,MAAM,IAGN,KAAA,OAAO,IAGP,KAAA,OAAmB,MAGnB,KAAQ,YAAY;AAAA,EAAA;AAAA,EAEZ,kBAAwB;AAC9B,SAAK,YAAY;AAAA,EACnB;AAAA,EAEQ,iBAAiB;AACvB,WAAI,KAAK,OAAO,CAAC,KAAK,YACbC;AAAA,cACC,KAAK,GAAG;AAAA,cACR,KAAK,OAAO,KAAK,IAAI;AAAA,iBAClB,KAAK,eAAe;AAAA,YAI7B,KAAK,OACAA,2BAA8BL,EAAY,KAAK,IAAI,CAAC,YAGtDK,gCAAmCP,CAAQ;AAAA,EACpD;AAAA,EAES,SAAS;AAChB,UAAMQ,IAAQ,KAAK,OAAO,KAAK,QAAQ;AAEvC,WAAOD;AAAA,kDACuCC,CAAK;AAAA,UAC7C,KAAK,gBAAgB;AAAA;AAAA;AAAA,EAG7B;AACF;AA/CaH,EACK,SAAS,CAACI,CAAY;AAGtCC,EAAA;AAAA,EADCC,EAAA;AAAS,GAHCN,EAIX,WAAA,OAAA,CAAA;AAGAK,EAAA;AAAA,EADCC,EAAA;AAAS,GANCN,EAOX,WAAA,OAAA,CAAA;AAGAK,EAAA;AAAA,EADCC,EAAA;AAAS,GATCN,EAUX,WAAA,QAAA,CAAA;AAGAK,EAAA;AAAA,EADCC,EAAS,EAAE,SAAS,GAAA,CAAM;AAAA,GAZhBN,EAaX,WAAA,QAAA,CAAA;AAGQK,EAAA;AAAA,EADPE,EAAA;AAAM,GAfIP,EAgBH,WAAA,aAAA,CAAA;AAhBGA,IAANK,EAAA;AAAA,EADNG,EAAc,eAAe;AAAA,GACjBR,CAAA;"}
|