@semantic-components/ui 0.65.0 → 0.67.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/esm2022/lib/components/accordion/accordion-body.js +33 -0
- package/esm2022/lib/components/accordion/accordion-body.js.map +1 -0
- package/esm2022/lib/components/accordion/accordion-content.js +16 -0
- package/esm2022/lib/components/accordion/accordion-content.js.map +1 -0
- package/esm2022/lib/components/accordion/accordion-group.js +35 -0
- package/esm2022/lib/components/accordion/accordion-group.js.map +1 -0
- package/esm2022/lib/components/accordion/accordion-header.js +20 -0
- package/esm2022/lib/components/accordion/accordion-header.js.map +1 -0
- package/esm2022/lib/components/accordion/accordion-item.js +27 -0
- package/esm2022/lib/components/accordion/accordion-item.js.map +1 -0
- package/esm2022/lib/components/accordion/accordion-panel.js +35 -0
- package/esm2022/lib/components/accordion/accordion-panel.js.map +1 -0
- package/esm2022/lib/components/accordion/accordion-trigger.js +58 -0
- package/esm2022/lib/components/accordion/accordion-trigger.js.map +1 -0
- package/esm2022/lib/components/accordion/index.js +8 -0
- package/esm2022/lib/components/accordion/index.js.map +1 -0
- package/esm2022/lib/components/alert/alert-action.js +20 -0
- package/esm2022/lib/components/alert/alert-action.js.map +1 -0
- package/esm2022/lib/components/alert/alert-description.js +20 -0
- package/esm2022/lib/components/alert/alert-description.js.map +1 -0
- package/esm2022/lib/components/alert/alert-title.js +20 -0
- package/esm2022/lib/components/alert/alert-title.js.map +1 -0
- package/esm2022/lib/components/alert/alert.js +34 -0
- package/esm2022/lib/components/alert/alert.js.map +1 -0
- package/esm2022/lib/components/alert/index.js +5 -0
- package/esm2022/lib/components/alert/index.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-action.js +30 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-action.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-cancel.js +30 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-cancel.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-description.js +23 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-description.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-footer.js +20 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-footer.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-header.js +20 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-header.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-media.js +20 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-media.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-portal.js +14 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-portal.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-provider.js +122 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-provider.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-title.js +23 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-title.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-trigger.js +29 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog-trigger.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog.js +61 -0
- package/esm2022/lib/components/alert-dialog/alert-dialog.js.map +1 -0
- package/esm2022/lib/components/alert-dialog/index.js +12 -0
- package/esm2022/lib/components/alert-dialog/index.js.map +1 -0
- package/esm2022/lib/components/aspect-ratio/aspect-ratio.js +22 -0
- package/esm2022/lib/components/aspect-ratio/aspect-ratio.js.map +1 -0
- package/esm2022/lib/components/aspect-ratio/index.js +2 -0
- package/esm2022/lib/components/aspect-ratio/index.js.map +1 -0
- package/esm2022/lib/components/avatar/avatar-badge.js +20 -0
- package/esm2022/lib/components/avatar/avatar-badge.js.map +1 -0
- package/esm2022/lib/components/avatar/avatar-fallback.js +25 -0
- package/esm2022/lib/components/avatar/avatar-fallback.js.map +1 -0
- package/esm2022/lib/components/avatar/avatar-group-count.js +20 -0
- package/esm2022/lib/components/avatar/avatar-group-count.js.map +1 -0
- package/esm2022/lib/components/avatar/avatar-group.js +20 -0
- package/esm2022/lib/components/avatar/avatar-group.js.map +1 -0
- package/esm2022/lib/components/avatar/avatar-image.js +36 -0
- package/esm2022/lib/components/avatar/avatar-image.js.map +1 -0
- package/esm2022/lib/components/avatar/avatar.js +24 -0
- package/esm2022/lib/components/avatar/avatar.js.map +1 -0
- package/esm2022/lib/components/avatar/index.js +7 -0
- package/esm2022/lib/components/avatar/index.js.map +1 -0
- package/esm2022/lib/components/backdrop/backdrop.js +53 -0
- package/esm2022/lib/components/backdrop/backdrop.js.map +1 -0
- package/esm2022/lib/components/backdrop/index.js +2 -0
- package/esm2022/lib/components/backdrop/index.js.map +1 -0
- package/esm2022/lib/components/badge/badge.js +37 -0
- package/esm2022/lib/components/badge/badge.js.map +1 -0
- package/esm2022/lib/components/badge/index.js +2 -0
- package/esm2022/lib/components/badge/index.js.map +1 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-ellipsis.js +33 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-ellipsis.js.map +1 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-item.js +20 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-item.js.map +1 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-link.js +20 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-link.js.map +1 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-list.js +20 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-list.js.map +1 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-page.js +23 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-page.js.map +1 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-separator.js +35 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb-separator.js.map +1 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb.js +17 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb.js.map +1 -0
- package/esm2022/lib/components/breadcrumb/index.js +8 -0
- package/esm2022/lib/components/breadcrumb/index.js.map +1 -0
- package/esm2022/lib/components/button/button.js +4 -4
- package/esm2022/lib/components/button/button.js.map +1 -1
- package/esm2022/lib/components/button-group/button-group-separator.js +24 -0
- package/esm2022/lib/components/button-group/button-group-separator.js.map +1 -0
- package/esm2022/lib/components/button-group/button-group-text.js +20 -0
- package/esm2022/lib/components/button-group/button-group-text.js.map +1 -0
- package/esm2022/lib/components/button-group/button-group.js +34 -0
- package/esm2022/lib/components/button-group/button-group.js.map +1 -0
- package/esm2022/lib/components/button-group/index.js +4 -0
- package/esm2022/lib/components/button-group/index.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar-day-view.js +323 -0
- package/esm2022/lib/components/calendar/calendar-day-view.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar-header.js +93 -0
- package/esm2022/lib/components/calendar/calendar-header.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar-month-view.js +185 -0
- package/esm2022/lib/components/calendar/calendar-month-view.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar-year-view.js +174 -0
- package/esm2022/lib/components/calendar/calendar-year-view.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar.js +282 -0
- package/esm2022/lib/components/calendar/calendar.js.map +1 -0
- package/esm2022/lib/components/calendar/index.js +2 -0
- package/esm2022/lib/components/calendar/index.js.map +1 -0
- package/esm2022/lib/components/card/card-action.js +20 -0
- package/esm2022/lib/components/card/card-action.js.map +1 -0
- package/esm2022/lib/components/card/card-body.js +20 -0
- package/esm2022/lib/components/card/card-body.js.map +1 -0
- package/esm2022/lib/components/card/card-description.js +20 -0
- package/esm2022/lib/components/card/card-description.js.map +1 -0
- package/esm2022/lib/components/card/card-footer.js +20 -0
- package/esm2022/lib/components/card/card-footer.js.map +1 -0
- package/esm2022/lib/components/card/card-header.js +20 -0
- package/esm2022/lib/components/card/card-header.js.map +1 -0
- package/esm2022/lib/components/card/card-title.js +20 -0
- package/esm2022/lib/components/card/card-title.js.map +1 -0
- package/esm2022/lib/components/card/card.js +22 -0
- package/esm2022/lib/components/card/card.js.map +1 -0
- package/esm2022/lib/components/card/index.js +8 -0
- package/esm2022/lib/components/card/index.js.map +1 -0
- package/esm2022/lib/components/checkbox/checkbox-field.js +64 -0
- package/esm2022/lib/components/checkbox/checkbox-field.js.map +1 -0
- package/esm2022/lib/components/checkbox/checkbox-types.js +3 -0
- package/esm2022/lib/components/checkbox/checkbox-types.js.map +1 -0
- package/esm2022/lib/components/checkbox/checkbox-visual.js +41 -0
- package/esm2022/lib/components/checkbox/checkbox-visual.js.map +1 -0
- package/esm2022/lib/components/checkbox/checkbox.js +54 -0
- package/esm2022/lib/components/checkbox/checkbox.js.map +1 -0
- package/esm2022/lib/components/checkbox/index.js +5 -0
- package/esm2022/lib/components/checkbox/index.js.map +1 -0
- package/esm2022/lib/components/collapsible/collapsible-body.js +33 -0
- package/esm2022/lib/components/collapsible/collapsible-body.js.map +1 -0
- package/esm2022/lib/components/collapsible/collapsible-content.js +16 -0
- package/esm2022/lib/components/collapsible/collapsible-content.js.map +1 -0
- package/esm2022/lib/components/collapsible/collapsible-panel.js +35 -0
- package/esm2022/lib/components/collapsible/collapsible-panel.js.map +1 -0
- package/esm2022/lib/components/collapsible/collapsible-trigger.js +45 -0
- package/esm2022/lib/components/collapsible/collapsible-trigger.js.map +1 -0
- package/esm2022/lib/components/collapsible/collapsible.js +35 -0
- package/esm2022/lib/components/collapsible/collapsible.js.map +1 -0
- package/esm2022/lib/components/collapsible/index.js +6 -0
- package/esm2022/lib/components/collapsible/index.js.map +1 -0
- package/esm2022/lib/components/date-picker/date-picker.js +134 -0
- package/esm2022/lib/components/date-picker/date-picker.js.map +1 -0
- package/esm2022/lib/components/date-picker/index.js +2 -0
- package/esm2022/lib/components/date-picker/index.js.map +1 -0
- package/esm2022/lib/components/dialog/dialog-close.js +30 -0
- package/esm2022/lib/components/dialog/dialog-close.js.map +1 -0
- package/esm2022/lib/components/dialog/dialog-description.js +23 -0
- package/esm2022/lib/components/dialog/dialog-description.js.map +1 -0
- package/esm2022/lib/components/dialog/dialog-footer.js +20 -0
- package/esm2022/lib/components/dialog/dialog-footer.js.map +1 -0
- package/esm2022/lib/components/dialog/dialog-header.js +20 -0
- package/esm2022/lib/components/dialog/dialog-header.js.map +1 -0
- package/esm2022/lib/components/dialog/dialog-portal.js +14 -0
- package/esm2022/lib/components/dialog/dialog-portal.js.map +1 -0
- package/esm2022/lib/components/dialog/dialog-provider.js +159 -0
- package/esm2022/lib/components/dialog/dialog-provider.js.map +1 -0
- package/esm2022/lib/components/dialog/dialog-title.js +23 -0
- package/esm2022/lib/components/dialog/dialog-title.js.map +1 -0
- package/esm2022/lib/components/dialog/dialog-trigger.js +29 -0
- package/esm2022/lib/components/dialog/dialog-trigger.js.map +1 -0
- package/esm2022/lib/components/dialog/dialog.js +59 -0
- package/esm2022/lib/components/dialog/dialog.js.map +1 -0
- package/esm2022/lib/components/dialog/index.js +10 -0
- package/esm2022/lib/components/dialog/index.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer-close.js +23 -0
- package/esm2022/lib/components/drawer/drawer-close.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer-description.js +20 -0
- package/esm2022/lib/components/drawer/drawer-description.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer-footer.js +20 -0
- package/esm2022/lib/components/drawer/drawer-footer.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer-handle.js +20 -0
- package/esm2022/lib/components/drawer/drawer-handle.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer-header.js +20 -0
- package/esm2022/lib/components/drawer/drawer-header.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer-portal.js +14 -0
- package/esm2022/lib/components/drawer/drawer-portal.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer-provider.js +127 -0
- package/esm2022/lib/components/drawer/drawer-provider.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer-title.js +20 -0
- package/esm2022/lib/components/drawer/drawer-title.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer-trigger.js +28 -0
- package/esm2022/lib/components/drawer/drawer-trigger.js.map +1 -0
- package/esm2022/lib/components/drawer/drawer.js +50 -0
- package/esm2022/lib/components/drawer/drawer.js.map +1 -0
- package/esm2022/lib/components/drawer/index.js +11 -0
- package/esm2022/lib/components/drawer/index.js.map +1 -0
- package/esm2022/lib/components/empty/empty-body.js +20 -0
- package/esm2022/lib/components/empty/empty-body.js.map +1 -0
- package/esm2022/lib/components/empty/empty-description.js +20 -0
- package/esm2022/lib/components/empty/empty-description.js.map +1 -0
- package/esm2022/lib/components/empty/empty-header.js +20 -0
- package/esm2022/lib/components/empty/empty-header.js.map +1 -0
- package/esm2022/lib/components/empty/empty-media.js +34 -0
- package/esm2022/lib/components/empty/empty-media.js.map +1 -0
- package/esm2022/lib/components/empty/empty-title.js +20 -0
- package/esm2022/lib/components/empty/empty-title.js.map +1 -0
- package/esm2022/lib/components/empty/empty.js +20 -0
- package/esm2022/lib/components/empty/empty.js.map +1 -0
- package/esm2022/lib/components/empty/index.js +7 -0
- package/esm2022/lib/components/empty/index.js.map +1 -0
- package/esm2022/lib/components/field/field-body.js +20 -0
- package/esm2022/lib/components/field/field-body.js.map +1 -0
- package/esm2022/lib/components/field/field-description.js +20 -0
- package/esm2022/lib/components/field/field-description.js.map +1 -0
- package/esm2022/lib/components/field/field-error.js +21 -0
- package/esm2022/lib/components/field/field-error.js.map +1 -0
- package/esm2022/lib/components/field/field-group.js +20 -0
- package/esm2022/lib/components/field/field-group.js.map +1 -0
- package/esm2022/lib/components/field/field-separator.js +20 -0
- package/esm2022/lib/components/field/field-separator.js.map +1 -0
- package/esm2022/lib/components/field/field-title.js +20 -0
- package/esm2022/lib/components/field/field-title.js.map +1 -0
- package/esm2022/lib/components/field/field.js +75 -0
- package/esm2022/lib/components/field/field.js.map +1 -0
- package/esm2022/lib/components/field/fieldset.js +20 -0
- package/esm2022/lib/components/field/fieldset.js.map +1 -0
- package/esm2022/lib/components/field/index.js +10 -0
- package/esm2022/lib/components/field/index.js.map +1 -0
- package/esm2022/lib/components/field/legend.js +22 -0
- package/esm2022/lib/components/field/legend.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload-dropzone.js +91 -0
- package/esm2022/lib/components/file-upload/file-upload-dropzone.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload-item-delete.js +29 -0
- package/esm2022/lib/components/file-upload/file-upload-item-delete.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload-item-name.js +20 -0
- package/esm2022/lib/components/file-upload/file-upload-item-name.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload-item-preview.js +51 -0
- package/esm2022/lib/components/file-upload/file-upload-item-preview.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload-item-progress.js +34 -0
- package/esm2022/lib/components/file-upload/file-upload-item-progress.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload-item-size.js +37 -0
- package/esm2022/lib/components/file-upload/file-upload-item-size.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload-item.js +29 -0
- package/esm2022/lib/components/file-upload/file-upload-item.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload-list.js +20 -0
- package/esm2022/lib/components/file-upload/file-upload-list.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload-trigger.js +66 -0
- package/esm2022/lib/components/file-upload/file-upload-trigger.js.map +1 -0
- package/esm2022/lib/components/file-upload/file-upload.js +118 -0
- package/esm2022/lib/components/file-upload/file-upload.js.map +1 -0
- package/esm2022/lib/components/file-upload/index.js +11 -0
- package/esm2022/lib/components/file-upload/index.js.map +1 -0
- package/esm2022/lib/components/hover-card/hover-card-portal.js +14 -0
- package/esm2022/lib/components/hover-card/hover-card-portal.js.map +1 -0
- package/esm2022/lib/components/hover-card/hover-card-provider.js +185 -0
- package/esm2022/lib/components/hover-card/hover-card-provider.js.map +1 -0
- package/esm2022/lib/components/hover-card/hover-card-trigger.js +72 -0
- package/esm2022/lib/components/hover-card/hover-card-trigger.js.map +1 -0
- package/esm2022/lib/components/hover-card/hover-card.js +74 -0
- package/esm2022/lib/components/hover-card/hover-card.js.map +1 -0
- package/esm2022/lib/components/hover-card/index.js +5 -0
- package/esm2022/lib/components/hover-card/index.js.map +1 -0
- package/esm2022/lib/components/index.js +50 -0
- package/esm2022/lib/components/index.js.map +1 -1
- package/esm2022/lib/components/input/index.js +2 -0
- package/esm2022/lib/components/input/index.js.map +1 -0
- package/esm2022/lib/components/input/input.js +41 -0
- package/esm2022/lib/components/input/input.js.map +1 -0
- package/esm2022/lib/components/input-group/index.js +5 -0
- package/esm2022/lib/components/input-group/index.js.map +1 -0
- package/esm2022/lib/components/input-group/input-group-addon.js +37 -0
- package/esm2022/lib/components/input-group/input-group-addon.js.map +1 -0
- package/esm2022/lib/components/input-group/input-group-button.js +39 -0
- package/esm2022/lib/components/input-group/input-group-button.js.map +1 -0
- package/esm2022/lib/components/input-group/input-group-text.js +20 -0
- package/esm2022/lib/components/input-group/input-group-text.js.map +1 -0
- package/esm2022/lib/components/input-group/input-group.js +21 -0
- package/esm2022/lib/components/input-group/input-group.js.map +1 -0
- package/esm2022/lib/components/item/index.js +11 -0
- package/esm2022/lib/components/item/index.js.map +1 -0
- package/esm2022/lib/components/item/item-actions.js +20 -0
- package/esm2022/lib/components/item/item-actions.js.map +1 -0
- package/esm2022/lib/components/item/item-body.js +20 -0
- package/esm2022/lib/components/item/item-body.js.map +1 -0
- package/esm2022/lib/components/item/item-description.js +20 -0
- package/esm2022/lib/components/item/item-description.js.map +1 -0
- package/esm2022/lib/components/item/item-footer.js +20 -0
- package/esm2022/lib/components/item/item-footer.js.map +1 -0
- package/esm2022/lib/components/item/item-group.js +21 -0
- package/esm2022/lib/components/item/item-group.js.map +1 -0
- package/esm2022/lib/components/item/item-header.js +20 -0
- package/esm2022/lib/components/item/item-header.js.map +1 -0
- package/esm2022/lib/components/item/item-media.js +35 -0
- package/esm2022/lib/components/item/item-media.js.map +1 -0
- package/esm2022/lib/components/item/item-separator.js +21 -0
- package/esm2022/lib/components/item/item-separator.js.map +1 -0
- package/esm2022/lib/components/item/item-title.js +20 -0
- package/esm2022/lib/components/item/item-title.js.map +1 -0
- package/esm2022/lib/components/item/item.js +43 -0
- package/esm2022/lib/components/item/item.js.map +1 -0
- package/esm2022/lib/components/kbd/index.js +3 -0
- package/esm2022/lib/components/kbd/index.js.map +1 -0
- package/esm2022/lib/components/kbd/kbd-group.js +20 -0
- package/esm2022/lib/components/kbd/kbd-group.js.map +1 -0
- package/esm2022/lib/components/kbd/kbd.js +20 -0
- package/esm2022/lib/components/kbd/kbd.js.map +1 -0
- package/esm2022/lib/components/label/index.js +2 -0
- package/esm2022/lib/components/label/index.js.map +1 -0
- package/esm2022/lib/components/label/label.js +29 -0
- package/esm2022/lib/components/label/label.js.map +1 -0
- package/esm2022/lib/components/link/link.js +4 -4
- package/esm2022/lib/components/link/link.js.map +1 -1
- package/esm2022/lib/components/menu/index.js +8 -0
- package/esm2022/lib/components/menu/index.js.map +1 -0
- package/esm2022/lib/components/menu/menu-content.js +16 -0
- package/esm2022/lib/components/menu/menu-content.js.map +1 -0
- package/esm2022/lib/components/menu/menu-item.js +96 -0
- package/esm2022/lib/components/menu/menu-item.js.map +1 -0
- package/esm2022/lib/components/menu/menu-portal.js +15 -0
- package/esm2022/lib/components/menu/menu-portal.js.map +1 -0
- package/esm2022/lib/components/menu/menu-provider.js +102 -0
- package/esm2022/lib/components/menu/menu-provider.js.map +1 -0
- package/esm2022/lib/components/menu/menu-separator.js +22 -0
- package/esm2022/lib/components/menu/menu-separator.js.map +1 -0
- package/esm2022/lib/components/menu/menu-trigger.js +34 -0
- package/esm2022/lib/components/menu/menu-trigger.js.map +1 -0
- package/esm2022/lib/components/menu/menu.js +37 -0
- package/esm2022/lib/components/menu/menu.js.map +1 -0
- package/esm2022/lib/components/menu-bar/index.js +3 -0
- package/esm2022/lib/components/menu-bar/index.js.map +1 -0
- package/esm2022/lib/components/menu-bar/menu-bar-item.js +103 -0
- package/esm2022/lib/components/menu-bar/menu-bar-item.js.map +1 -0
- package/esm2022/lib/components/menu-bar/menu-bar.js +28 -0
- package/esm2022/lib/components/menu-bar/menu-bar.js.map +1 -0
- package/esm2022/lib/components/native-select/index.js +6 -0
- package/esm2022/lib/components/native-select/index.js.map +1 -0
- package/esm2022/lib/components/native-select/native-select-container.js +20 -0
- package/esm2022/lib/components/native-select/native-select-container.js.map +1 -0
- package/esm2022/lib/components/native-select/native-select-icon.js +20 -0
- package/esm2022/lib/components/native-select/native-select-icon.js.map +1 -0
- package/esm2022/lib/components/native-select/native-select-optgroup.js +20 -0
- package/esm2022/lib/components/native-select/native-select-optgroup.js.map +1 -0
- package/esm2022/lib/components/native-select/native-select-option.js +20 -0
- package/esm2022/lib/components/native-select/native-select-option.js.map +1 -0
- package/esm2022/lib/components/native-select/native-select.js +29 -0
- package/esm2022/lib/components/native-select/native-select.js.map +1 -0
- package/esm2022/lib/components/navigation-menu/index.js +8 -0
- package/esm2022/lib/components/navigation-menu/index.js.map +1 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-content.js +37 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-content.js.map +1 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-item.js +118 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-item.js.map +1 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-link.js +22 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-link.js.map +1 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-list.js +20 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-list.js.map +1 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-portal.js +14 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-portal.js.map +1 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-trigger-icon.js +22 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-trigger-icon.js.map +1 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-trigger.js +41 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu-trigger.js.map +1 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu.js +32 -0
- package/esm2022/lib/components/navigation-menu/navigation-menu.js.map +1 -0
- package/esm2022/lib/components/pagination/index.js +11 -0
- package/esm2022/lib/components/pagination/index.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination-ellipsis.js +21 -0
- package/esm2022/lib/components/pagination/pagination-ellipsis.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination-first.js +51 -0
- package/esm2022/lib/components/pagination/pagination-first.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination-item.js +20 -0
- package/esm2022/lib/components/pagination/pagination-item.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination-last.js +52 -0
- package/esm2022/lib/components/pagination/pagination-last.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination-link.js +50 -0
- package/esm2022/lib/components/pagination/pagination-link.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination-list.js +20 -0
- package/esm2022/lib/components/pagination/pagination-list.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination-next.js +52 -0
- package/esm2022/lib/components/pagination/pagination-next.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination-page-size-select.js +37 -0
- package/esm2022/lib/components/pagination/pagination-page-size-select.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination-previous.js +52 -0
- package/esm2022/lib/components/pagination/pagination-previous.js.map +1 -0
- package/esm2022/lib/components/pagination/pagination.js +135 -0
- package/esm2022/lib/components/pagination/pagination.js.map +1 -0
- package/esm2022/lib/components/popover/index.js +9 -0
- package/esm2022/lib/components/popover/index.js.map +1 -0
- package/esm2022/lib/components/popover/popover-close.js +26 -0
- package/esm2022/lib/components/popover/popover-close.js.map +1 -0
- package/esm2022/lib/components/popover/popover-description.js +20 -0
- package/esm2022/lib/components/popover/popover-description.js.map +1 -0
- package/esm2022/lib/components/popover/popover-header.js +20 -0
- package/esm2022/lib/components/popover/popover-header.js.map +1 -0
- package/esm2022/lib/components/popover/popover-portal.js +14 -0
- package/esm2022/lib/components/popover/popover-portal.js.map +1 -0
- package/esm2022/lib/components/popover/popover-provider.js +203 -0
- package/esm2022/lib/components/popover/popover-provider.js.map +1 -0
- package/esm2022/lib/components/popover/popover-title.js +20 -0
- package/esm2022/lib/components/popover/popover-title.js.map +1 -0
- package/esm2022/lib/components/popover/popover-trigger.js +32 -0
- package/esm2022/lib/components/popover/popover-trigger.js.map +1 -0
- package/esm2022/lib/components/popover/popover.js +50 -0
- package/esm2022/lib/components/popover/popover.js.map +1 -0
- package/esm2022/lib/components/progress/index.js +2 -0
- package/esm2022/lib/components/progress/index.js.map +1 -0
- package/esm2022/lib/components/progress/progress-indicator.js +26 -0
- package/esm2022/lib/components/progress/progress-indicator.js.map +1 -0
- package/esm2022/lib/components/progress/progress.js +50 -0
- package/esm2022/lib/components/progress/progress.js.map +1 -0
- package/esm2022/lib/components/radio-group/index.js +4 -0
- package/esm2022/lib/components/radio-group/index.js.map +1 -0
- package/esm2022/lib/components/radio-group/radio-field.js +38 -0
- package/esm2022/lib/components/radio-group/radio-field.js.map +1 -0
- package/esm2022/lib/components/radio-group/radio-group.js +21 -0
- package/esm2022/lib/components/radio-group/radio-group.js.map +1 -0
- package/esm2022/lib/components/radio-group/radio.js +22 -0
- package/esm2022/lib/components/radio-group/radio.js.map +1 -0
- package/esm2022/lib/components/range-slider/index.js +4 -0
- package/esm2022/lib/components/range-slider/index.js.map +1 -0
- package/esm2022/lib/components/range-slider/range-slider-max.js +38 -0
- package/esm2022/lib/components/range-slider/range-slider-max.js.map +1 -0
- package/esm2022/lib/components/range-slider/range-slider-min.js +38 -0
- package/esm2022/lib/components/range-slider/range-slider-min.js.map +1 -0
- package/esm2022/lib/components/range-slider/range-slider-thumb-base.js +24 -0
- package/esm2022/lib/components/range-slider/range-slider-thumb-base.js.map +1 -0
- package/esm2022/lib/components/range-slider/range-slider.js +62 -0
- package/esm2022/lib/components/range-slider/range-slider.js.map +1 -0
- package/esm2022/lib/components/select/index.js +12 -0
- package/esm2022/lib/components/select/index.js.map +1 -0
- package/esm2022/lib/components/select/select-group-label.js +28 -0
- package/esm2022/lib/components/select/select-group-label.js.map +1 -0
- package/esm2022/lib/components/select/select-group.js +28 -0
- package/esm2022/lib/components/select/select-group.js.map +1 -0
- package/esm2022/lib/components/select/select-input.js +27 -0
- package/esm2022/lib/components/select/select-input.js.map +1 -0
- package/esm2022/lib/components/select/select-item-icon.js +21 -0
- package/esm2022/lib/components/select/select-item-icon.js.map +1 -0
- package/esm2022/lib/components/select/select-item-indicator.js +20 -0
- package/esm2022/lib/components/select/select-item-indicator.js.map +1 -0
- package/esm2022/lib/components/select/select-item.js +49 -0
- package/esm2022/lib/components/select/select-item.js.map +1 -0
- package/esm2022/lib/components/select/select-list.js +33 -0
- package/esm2022/lib/components/select/select-list.js.map +1 -0
- package/esm2022/lib/components/select/select-popup.js +32 -0
- package/esm2022/lib/components/select/select-popup.js.map +1 -0
- package/esm2022/lib/components/select/select-portal.js +14 -0
- package/esm2022/lib/components/select/select-portal.js.map +1 -0
- package/esm2022/lib/components/select/select-separator.js +22 -0
- package/esm2022/lib/components/select/select-separator.js.map +1 -0
- package/esm2022/lib/components/select/select-trigger-icon.js +22 -0
- package/esm2022/lib/components/select/select-trigger-icon.js.map +1 -0
- package/esm2022/lib/components/select/select-trigger.js +49 -0
- package/esm2022/lib/components/select/select-trigger.js.map +1 -0
- package/esm2022/lib/components/select/select-value.js +28 -0
- package/esm2022/lib/components/select/select-value.js.map +1 -0
- package/esm2022/lib/components/select/select.js +93 -0
- package/esm2022/lib/components/select/select.js.map +1 -0
- package/esm2022/lib/components/separator/index.js +2 -0
- package/esm2022/lib/components/separator/index.js.map +1 -0
- package/esm2022/lib/components/separator/separator.js +26 -0
- package/esm2022/lib/components/separator/separator.js.map +1 -0
- package/esm2022/lib/components/sheet/index.js +10 -0
- package/esm2022/lib/components/sheet/index.js.map +1 -0
- package/esm2022/lib/components/sheet/sheet-close.js +29 -0
- package/esm2022/lib/components/sheet/sheet-close.js.map +1 -0
- package/esm2022/lib/components/sheet/sheet-description.js +23 -0
- package/esm2022/lib/components/sheet/sheet-description.js.map +1 -0
- package/esm2022/lib/components/sheet/sheet-footer.js +20 -0
- package/esm2022/lib/components/sheet/sheet-footer.js.map +1 -0
- package/esm2022/lib/components/sheet/sheet-header.js +20 -0
- package/esm2022/lib/components/sheet/sheet-header.js.map +1 -0
- package/esm2022/lib/components/sheet/sheet-portal.js +14 -0
- package/esm2022/lib/components/sheet/sheet-portal.js.map +1 -0
- package/esm2022/lib/components/sheet/sheet-provider.js +127 -0
- package/esm2022/lib/components/sheet/sheet-provider.js.map +1 -0
- package/esm2022/lib/components/sheet/sheet-title.js +23 -0
- package/esm2022/lib/components/sheet/sheet-title.js.map +1 -0
- package/esm2022/lib/components/sheet/sheet-trigger.js +28 -0
- package/esm2022/lib/components/sheet/sheet-trigger.js.map +1 -0
- package/esm2022/lib/components/sheet/sheet.js +64 -0
- package/esm2022/lib/components/sheet/sheet.js.map +1 -0
- package/esm2022/lib/components/skeleton/index.js +2 -0
- package/esm2022/lib/components/skeleton/index.js.map +1 -0
- package/esm2022/lib/components/skeleton/skeleton.js +20 -0
- package/esm2022/lib/components/skeleton/skeleton.js.map +1 -0
- package/esm2022/lib/components/slider/index.js +2 -0
- package/esm2022/lib/components/slider/index.js.map +1 -0
- package/esm2022/lib/components/slider/slider.js +46 -0
- package/esm2022/lib/components/slider/slider.js.map +1 -0
- package/esm2022/lib/components/spinner/index.js +2 -0
- package/esm2022/lib/components/spinner/index.js.map +1 -0
- package/esm2022/lib/components/spinner/spinner.js +23 -0
- package/esm2022/lib/components/spinner/spinner.js.map +1 -0
- package/esm2022/lib/components/switch/index.js +5 -0
- package/esm2022/lib/components/switch/index.js.map +1 -0
- package/esm2022/lib/components/switch/switch-field.js +57 -0
- package/esm2022/lib/components/switch/switch-field.js.map +1 -0
- package/esm2022/lib/components/switch/switch-types.js +3 -0
- package/esm2022/lib/components/switch/switch-types.js.map +1 -0
- package/esm2022/lib/components/switch/switch-visual.js +34 -0
- package/esm2022/lib/components/switch/switch-visual.js.map +1 -0
- package/esm2022/lib/components/switch/switch.js +45 -0
- package/esm2022/lib/components/switch/switch.js.map +1 -0
- package/esm2022/lib/components/table/index.js +9 -0
- package/esm2022/lib/components/table/index.js.map +1 -0
- package/esm2022/lib/components/table/table-body.js +20 -0
- package/esm2022/lib/components/table/table-body.js.map +1 -0
- package/esm2022/lib/components/table/table-caption.js +20 -0
- package/esm2022/lib/components/table/table-caption.js.map +1 -0
- package/esm2022/lib/components/table/table-cell.js +20 -0
- package/esm2022/lib/components/table/table-cell.js.map +1 -0
- package/esm2022/lib/components/table/table-footer.js +20 -0
- package/esm2022/lib/components/table/table-footer.js.map +1 -0
- package/esm2022/lib/components/table/table-header-cell.js +20 -0
- package/esm2022/lib/components/table/table-header-cell.js.map +1 -0
- package/esm2022/lib/components/table/table-header.js +20 -0
- package/esm2022/lib/components/table/table-header.js.map +1 -0
- package/esm2022/lib/components/table/table-row.js +20 -0
- package/esm2022/lib/components/table/table-row.js.map +1 -0
- package/esm2022/lib/components/table/table.js +20 -0
- package/esm2022/lib/components/table/table.js.map +1 -0
- package/esm2022/lib/components/tabs/index.js +6 -0
- package/esm2022/lib/components/tabs/index.js.map +1 -0
- package/esm2022/lib/components/tabs/tab-content.js +16 -0
- package/esm2022/lib/components/tabs/tab-content.js.map +1 -0
- package/esm2022/lib/components/tabs/tab-list.js +57 -0
- package/esm2022/lib/components/tabs/tab-list.js.map +1 -0
- package/esm2022/lib/components/tabs/tab-panel.js +35 -0
- package/esm2022/lib/components/tabs/tab-panel.js.map +1 -0
- package/esm2022/lib/components/tabs/tab.js +34 -0
- package/esm2022/lib/components/tabs/tab.js.map +1 -0
- package/esm2022/lib/components/tabs/tabs.js +36 -0
- package/esm2022/lib/components/tabs/tabs.js.map +1 -0
- package/esm2022/lib/components/textarea/index.js +2 -0
- package/esm2022/lib/components/textarea/index.js.map +1 -0
- package/esm2022/lib/components/textarea/textarea.js +41 -0
- package/esm2022/lib/components/textarea/textarea.js.map +1 -0
- package/esm2022/lib/components/time-picker/index.js +10 -0
- package/esm2022/lib/components/time-picker/index.js.map +1 -0
- package/esm2022/lib/components/time-picker/time-picker-hours-input.js +67 -0
- package/esm2022/lib/components/time-picker/time-picker-hours-input.js.map +1 -0
- package/esm2022/lib/components/time-picker/time-picker-input.js +26 -0
- package/esm2022/lib/components/time-picker/time-picker-input.js.map +1 -0
- package/esm2022/lib/components/time-picker/time-picker-minutes-input.js +57 -0
- package/esm2022/lib/components/time-picker/time-picker-minutes-input.js.map +1 -0
- package/esm2022/lib/components/time-picker/time-picker-period-am.js +26 -0
- package/esm2022/lib/components/time-picker/time-picker-period-am.js.map +1 -0
- package/esm2022/lib/components/time-picker/time-picker-period-pm.js +26 -0
- package/esm2022/lib/components/time-picker/time-picker-period-pm.js.map +1 -0
- package/esm2022/lib/components/time-picker/time-picker-period.js +46 -0
- package/esm2022/lib/components/time-picker/time-picker-period.js.map +1 -0
- package/esm2022/lib/components/time-picker/time-picker-seconds-input.js +57 -0
- package/esm2022/lib/components/time-picker/time-picker-seconds-input.js.map +1 -0
- package/esm2022/lib/components/time-picker/time-picker-separator.js +20 -0
- package/esm2022/lib/components/time-picker/time-picker-separator.js.map +1 -0
- package/esm2022/lib/components/time-picker/time-picker.js +58 -0
- package/esm2022/lib/components/time-picker/time-picker.js.map +1 -0
- package/esm2022/lib/components/toast/index.js +7 -0
- package/esm2022/lib/components/toast/index.js.map +1 -0
- package/esm2022/lib/components/toast/toast-action.js +21 -0
- package/esm2022/lib/components/toast/toast-action.js.map +1 -0
- package/esm2022/lib/components/toast/toast-close.js +25 -0
- package/esm2022/lib/components/toast/toast-close.js.map +1 -0
- package/esm2022/lib/components/toast/toast-description.js +20 -0
- package/esm2022/lib/components/toast/toast-description.js.map +1 -0
- package/esm2022/lib/components/toast/toast-stack.js +182 -0
- package/esm2022/lib/components/toast/toast-stack.js.map +1 -0
- package/esm2022/lib/components/toast/toast-title.js +20 -0
- package/esm2022/lib/components/toast/toast-title.js.map +1 -0
- package/esm2022/lib/components/toast/toast.js +58 -0
- package/esm2022/lib/components/toast/toast.js.map +1 -0
- package/esm2022/lib/components/toast/toast.types.js +1 -0
- package/esm2022/lib/components/toast/toast.types.js.map +1 -0
- package/esm2022/lib/components/toast/toaster.js +149 -0
- package/esm2022/lib/components/toast/toaster.js.map +1 -0
- package/esm2022/lib/components/toggle/index.js +2 -0
- package/esm2022/lib/components/toggle/index.js.map +1 -0
- package/esm2022/lib/components/toggle/toggle.js +52 -0
- package/esm2022/lib/components/toggle/toggle.js.map +1 -0
- package/esm2022/lib/components/toggle-group/index.js +3 -0
- package/esm2022/lib/components/toggle-group/index.js.map +1 -0
- package/esm2022/lib/components/toggle-group/toggle-group-item.js +45 -0
- package/esm2022/lib/components/toggle-group/toggle-group-item.js.map +1 -0
- package/esm2022/lib/components/toggle-group/toggle-group.js +61 -0
- package/esm2022/lib/components/toggle-group/toggle-group.js.map +1 -0
- package/esm2022/lib/components/toolbar/index.js +5 -0
- package/esm2022/lib/components/toolbar/index.js.map +1 -0
- package/esm2022/lib/components/toolbar/toolbar-separator.js +29 -0
- package/esm2022/lib/components/toolbar/toolbar-separator.js.map +1 -0
- package/esm2022/lib/components/toolbar/toolbar-widget-group.js +35 -0
- package/esm2022/lib/components/toolbar/toolbar-widget-group.js.map +1 -0
- package/esm2022/lib/components/toolbar/toolbar-widget.js +39 -0
- package/esm2022/lib/components/toolbar/toolbar-widget.js.map +1 -0
- package/esm2022/lib/components/toolbar/toolbar.js +38 -0
- package/esm2022/lib/components/toolbar/toolbar.js.map +1 -0
- package/esm2022/lib/components/tooltip/index.js +3 -0
- package/esm2022/lib/components/tooltip/index.js.map +1 -0
- package/esm2022/lib/components/tooltip/tooltip-manager.js +165 -0
- package/esm2022/lib/components/tooltip/tooltip-manager.js.map +1 -0
- package/esm2022/lib/components/tooltip/tooltip-trigger.js +115 -0
- package/esm2022/lib/components/tooltip/tooltip-trigger.js.map +1 -0
- package/esm2022/lib/components/tooltip/tooltip.js +66 -0
- package/esm2022/lib/components/tooltip/tooltip.js.map +1 -0
- package/lib/components/accordion/accordion-body.d.ts +7 -0
- package/lib/components/accordion/accordion-content.d.ts +6 -0
- package/lib/components/accordion/accordion-group.d.ts +8 -0
- package/lib/components/accordion/accordion-header.d.ts +7 -0
- package/lib/components/accordion/accordion-item.d.ts +7 -0
- package/lib/components/accordion/accordion-panel.d.ts +8 -0
- package/lib/components/accordion/accordion-trigger.d.ts +8 -0
- package/lib/components/accordion/index.d.ts +7 -0
- package/lib/components/alert/alert-action.d.ts +7 -0
- package/lib/components/alert/alert-description.d.ts +7 -0
- package/lib/components/alert/alert-title.d.ts +7 -0
- package/lib/components/alert/alert.d.ts +14 -0
- package/lib/components/alert/index.d.ts +4 -0
- package/lib/components/alert-dialog/alert-dialog-action.d.ts +11 -0
- package/lib/components/alert-dialog/alert-dialog-cancel.d.ts +11 -0
- package/lib/components/alert-dialog/alert-dialog-description.d.ts +9 -0
- package/lib/components/alert-dialog/alert-dialog-footer.d.ts +7 -0
- package/lib/components/alert-dialog/alert-dialog-header.d.ts +7 -0
- package/lib/components/alert-dialog/alert-dialog-media.d.ts +7 -0
- package/lib/components/alert-dialog/alert-dialog-portal.d.ts +7 -0
- package/lib/components/alert-dialog/alert-dialog-provider.d.ts +22 -0
- package/lib/components/alert-dialog/alert-dialog-title.d.ts +9 -0
- package/lib/components/alert-dialog/alert-dialog-trigger.d.ts +10 -0
- package/lib/components/alert-dialog/alert-dialog.d.ts +19 -0
- package/lib/components/alert-dialog/index.d.ts +11 -0
- package/lib/components/aspect-ratio/aspect-ratio.d.ts +8 -0
- package/lib/components/aspect-ratio/index.d.ts +1 -0
- package/lib/components/avatar/avatar-badge.d.ts +7 -0
- package/lib/components/avatar/avatar-fallback.d.ts +8 -0
- package/lib/components/avatar/avatar-group-count.d.ts +7 -0
- package/lib/components/avatar/avatar-group.d.ts +7 -0
- package/lib/components/avatar/avatar-image.d.ts +12 -0
- package/lib/components/avatar/avatar.d.ts +12 -0
- package/lib/components/avatar/index.d.ts +6 -0
- package/lib/components/backdrop/backdrop.d.ts +23 -0
- package/lib/components/backdrop/index.d.ts +1 -0
- package/lib/components/badge/badge.d.ts +14 -0
- package/lib/components/badge/index.d.ts +1 -0
- package/lib/components/breadcrumb/breadcrumb-ellipsis.d.ts +7 -0
- package/lib/components/breadcrumb/breadcrumb-item.d.ts +7 -0
- package/lib/components/breadcrumb/breadcrumb-link.d.ts +7 -0
- package/lib/components/breadcrumb/breadcrumb-list.d.ts +7 -0
- package/lib/components/breadcrumb/breadcrumb-page.d.ts +7 -0
- package/lib/components/breadcrumb/breadcrumb-separator.d.ts +7 -0
- package/lib/components/breadcrumb/breadcrumb.d.ts +5 -0
- package/lib/components/breadcrumb/index.d.ts +7 -0
- package/lib/components/button/button.d.ts +5 -5
- package/lib/components/button-group/button-group-separator.d.ts +9 -0
- package/lib/components/button-group/button-group-text.d.ts +7 -0
- package/lib/components/button-group/button-group.d.ts +13 -0
- package/lib/components/button-group/index.d.ts +3 -0
- package/lib/components/calendar/calendar-day-view.d.ts +40 -0
- package/lib/components/calendar/calendar-header.d.ts +13 -0
- package/lib/components/calendar/calendar-month-view.d.ts +28 -0
- package/lib/components/calendar/calendar-year-view.d.ts +28 -0
- package/lib/components/calendar/calendar.d.ts +40 -0
- package/lib/components/calendar/index.d.ts +1 -0
- package/lib/components/card/card-action.d.ts +7 -0
- package/lib/components/card/card-body.d.ts +7 -0
- package/lib/components/card/card-description.d.ts +7 -0
- package/lib/components/card/card-footer.d.ts +7 -0
- package/lib/components/card/card-header.d.ts +7 -0
- package/lib/components/card/card-title.d.ts +7 -0
- package/lib/components/card/card.d.ts +8 -0
- package/lib/components/card/index.d.ts +7 -0
- package/lib/components/checkbox/checkbox-field.d.ts +16 -0
- package/lib/components/checkbox/checkbox-types.d.ts +9 -0
- package/lib/components/checkbox/checkbox-visual.d.ts +8 -0
- package/lib/components/checkbox/checkbox.d.ts +19 -0
- package/lib/components/checkbox/index.d.ts +4 -0
- package/lib/components/collapsible/collapsible-body.d.ts +7 -0
- package/lib/components/collapsible/collapsible-content.d.ts +6 -0
- package/lib/components/collapsible/collapsible-panel.d.ts +8 -0
- package/lib/components/collapsible/collapsible-trigger.d.ts +14 -0
- package/lib/components/collapsible/collapsible.d.ts +8 -0
- package/lib/components/collapsible/index.d.ts +5 -0
- package/lib/components/date-picker/date-picker.d.ts +23 -0
- package/lib/components/date-picker/index.d.ts +1 -0
- package/lib/components/dialog/dialog-close.d.ts +11 -0
- package/lib/components/dialog/dialog-description.d.ts +9 -0
- package/lib/components/dialog/dialog-footer.d.ts +7 -0
- package/lib/components/dialog/dialog-header.d.ts +7 -0
- package/lib/components/dialog/dialog-portal.d.ts +7 -0
- package/lib/components/dialog/dialog-provider.d.ts +44 -0
- package/lib/components/dialog/dialog-title.d.ts +9 -0
- package/lib/components/dialog/dialog-trigger.d.ts +10 -0
- package/lib/components/dialog/dialog.d.ts +18 -0
- package/lib/components/dialog/index.d.ts +9 -0
- package/lib/components/drawer/drawer-close.d.ts +7 -0
- package/lib/components/drawer/drawer-description.d.ts +7 -0
- package/lib/components/drawer/drawer-footer.d.ts +7 -0
- package/lib/components/drawer/drawer-handle.d.ts +7 -0
- package/lib/components/drawer/drawer-header.d.ts +7 -0
- package/lib/components/drawer/drawer-portal.d.ts +7 -0
- package/lib/components/drawer/drawer-provider.d.ts +25 -0
- package/lib/components/drawer/drawer-title.d.ts +7 -0
- package/lib/components/drawer/drawer-trigger.d.ts +10 -0
- package/lib/components/drawer/drawer.d.ts +15 -0
- package/lib/components/drawer/index.d.ts +11 -0
- package/lib/components/empty/empty-body.d.ts +7 -0
- package/lib/components/empty/empty-description.d.ts +7 -0
- package/lib/components/empty/empty-header.d.ts +7 -0
- package/lib/components/empty/empty-media.d.ts +13 -0
- package/lib/components/empty/empty-title.d.ts +7 -0
- package/lib/components/empty/empty.d.ts +7 -0
- package/lib/components/empty/index.d.ts +6 -0
- package/lib/components/field/field-body.d.ts +7 -0
- package/lib/components/field/field-description.d.ts +7 -0
- package/lib/components/field/field-error.d.ts +7 -0
- package/lib/components/field/field-group.d.ts +7 -0
- package/lib/components/field/field-separator.d.ts +7 -0
- package/lib/components/field/field-title.d.ts +7 -0
- package/lib/components/field/field.d.ts +27 -0
- package/lib/components/field/fieldset.d.ts +7 -0
- package/lib/components/field/index.d.ts +10 -0
- package/lib/components/field/legend.d.ts +9 -0
- package/lib/components/file-upload/file-upload-dropzone.d.ts +15 -0
- package/lib/components/file-upload/file-upload-item-delete.d.ts +10 -0
- package/lib/components/file-upload/file-upload-item-name.d.ts +7 -0
- package/lib/components/file-upload/file-upload-item-preview.d.ts +11 -0
- package/lib/components/file-upload/file-upload-item-progress.d.ts +9 -0
- package/lib/components/file-upload/file-upload-item-size.d.ts +10 -0
- package/lib/components/file-upload/file-upload-item.d.ts +9 -0
- package/lib/components/file-upload/file-upload-list.d.ts +7 -0
- package/lib/components/file-upload/file-upload-trigger.d.ts +11 -0
- package/lib/components/file-upload/file-upload.d.ts +32 -0
- package/lib/components/file-upload/index.d.ts +11 -0
- package/lib/components/hover-card/hover-card-portal.d.ts +7 -0
- package/lib/components/hover-card/hover-card-provider.d.ts +34 -0
- package/lib/components/hover-card/hover-card-trigger.d.ts +22 -0
- package/lib/components/hover-card/hover-card.d.ts +21 -0
- package/lib/components/hover-card/index.d.ts +5 -0
- package/lib/components/index.d.ts +50 -0
- package/lib/components/input/index.d.ts +1 -0
- package/lib/components/input/input.d.ts +17 -0
- package/lib/components/input-group/index.d.ts +4 -0
- package/lib/components/input-group/input-group-addon.d.ts +14 -0
- package/lib/components/input-group/input-group-button.d.ts +15 -0
- package/lib/components/input-group/input-group-text.d.ts +7 -0
- package/lib/components/input-group/input-group.d.ts +7 -0
- package/lib/components/item/index.d.ts +10 -0
- package/lib/components/item/item-actions.d.ts +7 -0
- package/lib/components/item/item-body.d.ts +7 -0
- package/lib/components/item/item-description.d.ts +7 -0
- package/lib/components/item/item-footer.d.ts +7 -0
- package/lib/components/item/item-group.d.ts +7 -0
- package/lib/components/item/item-header.d.ts +7 -0
- package/lib/components/item/item-media.d.ts +13 -0
- package/lib/components/item/item-separator.d.ts +7 -0
- package/lib/components/item/item-title.d.ts +7 -0
- package/lib/components/item/item.d.ts +15 -0
- package/lib/components/kbd/index.d.ts +2 -0
- package/lib/components/kbd/kbd-group.d.ts +7 -0
- package/lib/components/kbd/kbd.d.ts +7 -0
- package/lib/components/label/index.d.ts +1 -0
- package/lib/components/label/label.d.ts +10 -0
- package/lib/components/link/link.d.ts +3 -3
- package/lib/components/menu/index.d.ts +7 -0
- package/lib/components/menu/menu-content.d.ts +6 -0
- package/lib/components/menu/menu-item.d.ts +17 -0
- package/lib/components/menu/menu-portal.d.ts +9 -0
- package/lib/components/menu/menu-provider.d.ts +15 -0
- package/lib/components/menu/menu-separator.d.ts +7 -0
- package/lib/components/menu/menu-trigger.d.ts +14 -0
- package/lib/components/menu/menu.d.ts +12 -0
- package/lib/components/menu-bar/index.d.ts +2 -0
- package/lib/components/menu-bar/menu-bar-item.d.ts +18 -0
- package/lib/components/menu-bar/menu-bar.d.ts +10 -0
- package/lib/components/native-select/index.d.ts +5 -0
- package/lib/components/native-select/native-select-container.d.ts +7 -0
- package/lib/components/native-select/native-select-icon.d.ts +7 -0
- package/lib/components/native-select/native-select-optgroup.d.ts +7 -0
- package/lib/components/native-select/native-select-option.d.ts +7 -0
- package/lib/components/native-select/native-select.d.ts +12 -0
- package/lib/components/navigation-menu/index.d.ts +7 -0
- package/lib/components/navigation-menu/navigation-menu-content.d.ts +10 -0
- package/lib/components/navigation-menu/navigation-menu-item.d.ts +27 -0
- package/lib/components/navigation-menu/navigation-menu-link.d.ts +8 -0
- package/lib/components/navigation-menu/navigation-menu-list.d.ts +7 -0
- package/lib/components/navigation-menu/navigation-menu-portal.d.ts +7 -0
- package/lib/components/navigation-menu/navigation-menu-trigger-icon.d.ts +8 -0
- package/lib/components/navigation-menu/navigation-menu-trigger.d.ts +12 -0
- package/lib/components/navigation-menu/navigation-menu.d.ts +10 -0
- package/lib/components/pagination/index.d.ts +10 -0
- package/lib/components/pagination/pagination-ellipsis.d.ts +7 -0
- package/lib/components/pagination/pagination-first.d.ts +15 -0
- package/lib/components/pagination/pagination-item.d.ts +7 -0
- package/lib/components/pagination/pagination-last.d.ts +15 -0
- package/lib/components/pagination/pagination-link.d.ts +16 -0
- package/lib/components/pagination/pagination-list.d.ts +7 -0
- package/lib/components/pagination/pagination-next.d.ts +15 -0
- package/lib/components/pagination/pagination-page-size-select.d.ts +14 -0
- package/lib/components/pagination/pagination-previous.d.ts +15 -0
- package/lib/components/pagination/pagination.d.ts +38 -0
- package/lib/components/popover/index.d.ts +9 -0
- package/lib/components/popover/popover-close.d.ts +9 -0
- package/lib/components/popover/popover-description.d.ts +7 -0
- package/lib/components/popover/popover-header.d.ts +7 -0
- package/lib/components/popover/popover-portal.d.ts +7 -0
- package/lib/components/popover/popover-provider.d.ts +39 -0
- package/lib/components/popover/popover-title.d.ts +7 -0
- package/lib/components/popover/popover-trigger.d.ts +13 -0
- package/lib/components/popover/popover.d.ts +15 -0
- package/lib/components/progress/index.d.ts +1 -0
- package/lib/components/progress/progress-indicator.d.ts +9 -0
- package/lib/components/progress/progress.d.ts +12 -0
- package/lib/components/radio-group/index.d.ts +3 -0
- package/lib/components/radio-group/radio-field.d.ts +10 -0
- package/lib/components/radio-group/radio-group.d.ts +7 -0
- package/lib/components/radio-group/radio.d.ts +8 -0
- package/lib/components/range-slider/index.d.ts +3 -0
- package/lib/components/range-slider/range-slider-max.d.ts +10 -0
- package/lib/components/range-slider/range-slider-min.d.ts +10 -0
- package/lib/components/range-slider/range-slider-thumb-base.d.ts +2 -0
- package/lib/components/range-slider/range-slider.d.ts +21 -0
- package/lib/components/select/index.d.ts +11 -0
- package/lib/components/select/select-group-label.d.ts +7 -0
- package/lib/components/select/select-group.d.ts +7 -0
- package/lib/components/select/select-input.d.ts +8 -0
- package/lib/components/select/select-item-icon.d.ts +7 -0
- package/lib/components/select/select-item-indicator.d.ts +7 -0
- package/lib/components/select/select-item.d.ts +11 -0
- package/lib/components/select/select-list.d.ts +10 -0
- package/lib/components/select/select-popup.d.ts +8 -0
- package/lib/components/select/select-portal.d.ts +7 -0
- package/lib/components/select/select-separator.d.ts +7 -0
- package/lib/components/select/select-trigger-icon.d.ts +8 -0
- package/lib/components/select/select-trigger.d.ts +12 -0
- package/lib/components/select/select-value.d.ts +7 -0
- package/lib/components/select/select.d.ts +21 -0
- package/lib/components/separator/index.d.ts +1 -0
- package/lib/components/separator/separator.d.ts +10 -0
- package/lib/components/sheet/index.d.ts +10 -0
- package/lib/components/sheet/sheet-close.d.ts +11 -0
- package/lib/components/sheet/sheet-description.d.ts +9 -0
- package/lib/components/sheet/sheet-footer.d.ts +7 -0
- package/lib/components/sheet/sheet-header.d.ts +7 -0
- package/lib/components/sheet/sheet-portal.d.ts +7 -0
- package/lib/components/sheet/sheet-provider.d.ts +25 -0
- package/lib/components/sheet/sheet-title.d.ts +9 -0
- package/lib/components/sheet/sheet-trigger.d.ts +10 -0
- package/lib/components/sheet/sheet.d.ts +18 -0
- package/lib/components/skeleton/index.d.ts +1 -0
- package/lib/components/skeleton/skeleton.d.ts +7 -0
- package/lib/components/slider/index.d.ts +1 -0
- package/lib/components/slider/slider.d.ts +15 -0
- package/lib/components/spinner/index.d.ts +1 -0
- package/lib/components/spinner/spinner.d.ts +8 -0
- package/lib/components/switch/index.d.ts +4 -0
- package/lib/components/switch/switch-field.d.ts +15 -0
- package/lib/components/switch/switch-types.d.ts +8 -0
- package/lib/components/switch/switch-visual.d.ts +9 -0
- package/lib/components/switch/switch.d.ts +18 -0
- package/lib/components/table/index.d.ts +8 -0
- package/lib/components/table/table-body.d.ts +7 -0
- package/lib/components/table/table-caption.d.ts +7 -0
- package/lib/components/table/table-cell.d.ts +7 -0
- package/lib/components/table/table-footer.d.ts +7 -0
- package/lib/components/table/table-header-cell.d.ts +7 -0
- package/lib/components/table/table-header.d.ts +7 -0
- package/lib/components/table/table-row.d.ts +7 -0
- package/lib/components/table/table.d.ts +7 -0
- package/lib/components/tabs/index.d.ts +5 -0
- package/lib/components/tabs/tab-content.d.ts +6 -0
- package/lib/components/tabs/tab-list.d.ts +12 -0
- package/lib/components/tabs/tab-panel.d.ts +8 -0
- package/lib/components/tabs/tab.d.ts +8 -0
- package/lib/components/tabs/tabs.d.ts +9 -0
- package/lib/components/textarea/index.d.ts +1 -0
- package/lib/components/textarea/textarea.d.ts +17 -0
- package/lib/components/time-picker/index.d.ts +10 -0
- package/lib/components/time-picker/time-picker-hours-input.d.ts +14 -0
- package/lib/components/time-picker/time-picker-input.d.ts +9 -0
- package/lib/components/time-picker/time-picker-minutes-input.d.ts +12 -0
- package/lib/components/time-picker/time-picker-period-am.d.ts +8 -0
- package/lib/components/time-picker/time-picker-period-pm.d.ts +8 -0
- package/lib/components/time-picker/time-picker-period.d.ts +12 -0
- package/lib/components/time-picker/time-picker-seconds-input.d.ts +12 -0
- package/lib/components/time-picker/time-picker-separator.d.ts +7 -0
- package/lib/components/time-picker/time-picker.d.ts +26 -0
- package/lib/components/toast/index.d.ts +7 -0
- package/lib/components/toast/toast-action.d.ts +7 -0
- package/lib/components/toast/toast-close.d.ts +9 -0
- package/lib/components/toast/toast-description.d.ts +7 -0
- package/lib/components/toast/toast-stack.d.ts +12 -0
- package/lib/components/toast/toast-title.d.ts +7 -0
- package/lib/components/toast/toast.d.ts +17 -0
- package/lib/components/toast/toast.types.d.ts +24 -0
- package/lib/components/toast/toaster.d.ts +50 -0
- package/lib/components/toggle/index.d.ts +1 -0
- package/lib/components/toggle/toggle.d.ts +18 -0
- package/lib/components/toggle-group/index.d.ts +2 -0
- package/lib/components/toggle-group/toggle-group-item.d.ts +16 -0
- package/lib/components/toggle-group/toggle-group.d.ts +16 -0
- package/lib/components/toolbar/index.d.ts +4 -0
- package/lib/components/toolbar/toolbar-separator.d.ts +9 -0
- package/lib/components/toolbar/toolbar-widget-group.d.ts +8 -0
- package/lib/components/toolbar/toolbar-widget.d.ts +10 -0
- package/lib/components/toolbar/toolbar.d.ts +10 -0
- package/lib/components/tooltip/index.d.ts +3 -0
- package/lib/components/tooltip/tooltip-manager.d.ts +22 -0
- package/lib/components/tooltip/tooltip-trigger.d.ts +35 -0
- package/lib/components/tooltip/tooltip.d.ts +22 -0
- package/package.json +9 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toggle-group-item.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/toggle-group/toggle-group-item.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AACjC,OAAO,EAAE,cAAc,EAAyB,MAAM,kBAAkB,CAAC;AACzE,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;;AAiB/C,MAAM,OAAO,iBAAiB;IACT,KAAK,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;IAExC,UAAU,GAAG,KAAK,CAAS,EAAE,uDAAI,KAAK,EAAE,OAAO,GAAG,CAAC;IACnD,KAAK,GAAG,KAAK,CAAC,QAAQ,gDAAU,CAAC;IACjC,QAAQ,GAAG,KAAK,CAAU,KAAK,oDAAC,CAAC;IACjC,OAAO,GAAG,KAAK,CAA8B,SAAS,mDAAC,CAAC;IACxD,IAAI,GAAG,KAAK,CAA2B,SAAS,gDAAC,CAAC;IAExC,UAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAC5C,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,sDACpC,CAAC;IAEiB,UAAU,GAAG,QAAQ,CACtC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,sDAC/C,CAAC;IAEiB,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,CACvC,EAAE,CACA,ovBAAovB,EACpvB,cAAc,CAAC;QACb,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,OAAO,EAAE;QAC/C,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE;KACvC,CAAC,EACF,IAAI,CAAC,UAAU,EAAE,CAClB,iDACF,CAAC;IAEQ,OAAO;QACf,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;YACvB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;uGAhCU,iBAAiB;2FAAjB,iBAAiB;;2FAAjB,iBAAiB;kBAf7B,SAAS;mBAAC;oBACT,QAAQ,EAAE,2BAA2B;oBACrC,IAAI,EAAE;wBACJ,WAAW,EAAE,mBAAmB;wBAChC,IAAI,EAAE,QAAQ;wBACd,qBAAqB,EAAE,8BAA8B;wBACrD,kBAAkB,EAAE,wBAAwB;wBAC5C,qBAAqB,EAAE,iBAAiB;wBACxC,qBAAqB,EAAE,cAAc;wBACrC,mBAAmB,EAAE,6BAA6B;wBAClD,YAAY,EAAE,cAAc;wBAC5B,SAAS,EAAE,SAAS;wBACpB,SAAS,EAAE,WAAW;qBACvB;iBACF","sourcesContent":["import { computed, Directive, inject, input } from '@angular/core';\nimport { cn } from '../../utils';\nimport { toggleVariants, type ScToggleVariants } from '../toggle/toggle';\nimport { ScToggleGroup } from './toggle-group';\n\n@Directive({\n selector: 'button[scToggleGroupItem]',\n host: {\n 'data-slot': 'toggle-group-item',\n type: 'button',\n '[attr.data-variant]': 'group.variant() || variant()',\n '[attr.data-size]': 'group.size() || size()',\n '[attr.data-spacing]': 'group.spacing()',\n '[attr.aria-pressed]': 'isSelected()',\n '[attr.data-state]': 'isSelected() ? \"on\" : \"off\"',\n '[disabled]': 'isDisabled()',\n '[class]': 'class()',\n '(click)': 'onClick()',\n },\n})\nexport class ScToggleGroupItem {\n protected readonly group = inject(ScToggleGroup);\n\n readonly classInput = input<string>('', { alias: 'class' });\n readonly value = input.required<string>();\n readonly disabled = input<boolean>(false);\n readonly variant = input<ScToggleVariants['variant']>('default');\n readonly size = input<ScToggleVariants['size']>('default');\n\n protected readonly isSelected = computed(() =>\n this.group.isSelected(this.value()),\n );\n\n protected readonly isDisabled = computed(\n () => this.disabled() || this.group.disabled(),\n );\n\n protected readonly class = computed(() =>\n cn(\n 'group-data-[spacing=0]/toggle-group:rounded-none group-data-[spacing=0]/toggle-group:px-2 group-data-horizontal/toggle-group:data-[spacing=0]:first:rounded-l-lg group-data-vertical/toggle-group:data-[spacing=0]:first:rounded-t-lg group-data-horizontal/toggle-group:data-[spacing=0]:last:rounded-r-lg group-data-vertical/toggle-group:data-[spacing=0]:last:rounded-b-lg shrink-0 focus:z-10 focus-visible:z-10 group-data-horizontal/toggle-group:data-[spacing=0]:data-[variant=outline]:border-l-0 group-data-vertical/toggle-group:data-[spacing=0]:data-[variant=outline]:border-t-0 group-data-horizontal/toggle-group:data-[spacing=0]:data-[variant=outline]:first:border-l group-data-vertical/toggle-group:data-[spacing=0]:data-[variant=outline]:first:border-t',\n toggleVariants({\n variant: this.group.variant() || this.variant(),\n size: this.group.size() || this.size(),\n }),\n this.classInput(),\n ),\n );\n\n protected onClick(): void {\n if (!this.isDisabled()) {\n this.group.toggle(this.value());\n }\n }\n}\n"]}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { computed, Directive, input, model } from '@angular/core';
|
|
2
|
+
import { cn } from '../../utils';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ScToggleGroup {
|
|
5
|
+
classInput = input('', { ...(ngDevMode ? { debugName: "classInput" } : {}), alias: 'class' });
|
|
6
|
+
type = input('single', ...(ngDevMode ? [{ debugName: "type" }] : []));
|
|
7
|
+
value = model(null, ...(ngDevMode ? [{ debugName: "value" }] : []));
|
|
8
|
+
disabled = input(false, ...(ngDevMode ? [{ debugName: "disabled" }] : []));
|
|
9
|
+
variant = input('default', ...(ngDevMode ? [{ debugName: "variant" }] : []));
|
|
10
|
+
size = input('default', ...(ngDevMode ? [{ debugName: "size" }] : []));
|
|
11
|
+
spacing = input(0, ...(ngDevMode ? [{ debugName: "spacing" }] : []));
|
|
12
|
+
orientation = input('horizontal', ...(ngDevMode ? [{ debugName: "orientation" }] : []));
|
|
13
|
+
class = computed(() => cn('rounded-lg data-[size=sm]:rounded-[min(var(--radius-md),10px)] group/toggle-group flex w-fit flex-row items-center gap-[--spacing(var(--gap))] data-vertical:flex-col data-vertical:items-stretch', this.classInput()), ...(ngDevMode ? [{ debugName: "class" }] : []));
|
|
14
|
+
isSelected(itemValue) {
|
|
15
|
+
const currentValue = this.value();
|
|
16
|
+
if (this.type() === 'single') {
|
|
17
|
+
return currentValue === itemValue;
|
|
18
|
+
}
|
|
19
|
+
return Array.isArray(currentValue) && currentValue.includes(itemValue);
|
|
20
|
+
}
|
|
21
|
+
toggle(itemValue) {
|
|
22
|
+
if (this.disabled())
|
|
23
|
+
return;
|
|
24
|
+
if (this.type() === 'single') {
|
|
25
|
+
this.value.set(this.value() === itemValue ? null : itemValue);
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
const currentValue = this.value();
|
|
29
|
+
const arr = Array.isArray(currentValue) ? [...currentValue] : [];
|
|
30
|
+
const index = arr.indexOf(itemValue);
|
|
31
|
+
if (index === -1) {
|
|
32
|
+
arr.push(itemValue);
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
arr.splice(index, 1);
|
|
36
|
+
}
|
|
37
|
+
this.value.set(arr);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToggleGroup, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
41
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "21.1.5", type: ScToggleGroup, isStandalone: true, selector: "div[scToggleGroup]", inputs: { classInput: { classPropertyName: "classInput", publicName: "class", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, spacing: { classPropertyName: "spacing", publicName: "spacing", isSignal: true, isRequired: false, transformFunction: null }, orientation: { classPropertyName: "orientation", publicName: "orientation", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { value: "valueChange" }, host: { attributes: { "data-slot": "toggle-group", "role": "group" }, properties: { "attr.data-variant": "variant()", "attr.data-size": "size()", "attr.data-spacing": "spacing()", "attr.data-orientation": "orientation()", "attr.data-horizontal": "orientation() === \"horizontal\" ? \"\" : null", "attr.data-vertical": "orientation() === \"vertical\" ? \"\" : null", "style.--gap": "spacing()", "class": "class()" } }, ngImport: i0 });
|
|
42
|
+
}
|
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToggleGroup, decorators: [{
|
|
44
|
+
type: Directive,
|
|
45
|
+
args: [{
|
|
46
|
+
selector: 'div[scToggleGroup]',
|
|
47
|
+
host: {
|
|
48
|
+
'data-slot': 'toggle-group',
|
|
49
|
+
role: 'group',
|
|
50
|
+
'[attr.data-variant]': 'variant()',
|
|
51
|
+
'[attr.data-size]': 'size()',
|
|
52
|
+
'[attr.data-spacing]': 'spacing()',
|
|
53
|
+
'[attr.data-orientation]': 'orientation()',
|
|
54
|
+
'[attr.data-horizontal]': 'orientation() === "horizontal" ? "" : null',
|
|
55
|
+
'[attr.data-vertical]': 'orientation() === "vertical" ? "" : null',
|
|
56
|
+
'[style.--gap]': 'spacing()',
|
|
57
|
+
'[class]': 'class()',
|
|
58
|
+
},
|
|
59
|
+
}]
|
|
60
|
+
}], propDecorators: { classInput: [{ type: i0.Input, args: [{ isSignal: true, alias: "class", required: false }] }], type: [{ type: i0.Input, args: [{ isSignal: true, alias: "type", required: false }] }], value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }, { type: i0.Output, args: ["valueChange"] }], disabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "disabled", required: false }] }], variant: [{ type: i0.Input, args: [{ isSignal: true, alias: "variant", required: false }] }], size: [{ type: i0.Input, args: [{ isSignal: true, alias: "size", required: false }] }], spacing: [{ type: i0.Input, args: [{ isSignal: true, alias: "spacing", required: false }] }], orientation: [{ type: i0.Input, args: [{ isSignal: true, alias: "orientation", required: false }] }] } });
|
|
61
|
+
//# sourceMappingURL=toggle-group.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toggle-group.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/toggle-group/toggle-group.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAClE,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;;AAkBjC,MAAM,OAAO,aAAa;IACf,UAAU,GAAG,KAAK,CAAS,EAAE,uDAAI,KAAK,EAAE,OAAO,GAAG,CAAC;IACnD,IAAI,GAAG,KAAK,CAAwB,QAAQ,gDAAC,CAAC;IAC9C,KAAK,GAAG,KAAK,CAA2B,IAAI,iDAAC,CAAC;IAC9C,QAAQ,GAAG,KAAK,CAAU,KAAK,oDAAC,CAAC;IACjC,OAAO,GAAG,KAAK,CAA8B,SAAS,mDAAC,CAAC;IACxD,IAAI,GAAG,KAAK,CAA2B,SAAS,gDAAC,CAAC;IAClD,OAAO,GAAG,KAAK,CAAS,CAAC,mDAAC,CAAC;IAC3B,WAAW,GAAG,KAAK,CAA4B,YAAY,uDAAC,CAAC;IAEnD,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,CACvC,EAAE,CACA,mMAAmM,EACnM,IAAI,CAAC,UAAU,EAAE,CAClB,iDACF,CAAC;IAEF,UAAU,CAAC,SAAiB;QAC1B,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,QAAQ,EAAE,CAAC;YAC7B,OAAO,YAAY,KAAK,SAAS,CAAC;QACpC,CAAC;QACD,OAAO,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IACzE,CAAC;IAED,MAAM,CAAC,SAAiB;QACtB,IAAI,IAAI,CAAC,QAAQ,EAAE;YAAE,OAAO;QAE5B,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,QAAQ,EAAE,CAAC;YAC7B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QAChE,CAAC;aAAM,CAAC;YACN,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YAClC,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACjE,MAAM,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YACrC,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;gBACjB,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACtB,CAAC;iBAAM,CAAC;gBACN,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YACvB,CAAC;YACD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACtB,CAAC;IACH,CAAC;uGAzCU,aAAa;2FAAb,aAAa;;2FAAb,aAAa;kBAfzB,SAAS;mBAAC;oBACT,QAAQ,EAAE,oBAAoB;oBAC9B,IAAI,EAAE;wBACJ,WAAW,EAAE,cAAc;wBAC3B,IAAI,EAAE,OAAO;wBACb,qBAAqB,EAAE,WAAW;wBAClC,kBAAkB,EAAE,QAAQ;wBAC5B,qBAAqB,EAAE,WAAW;wBAClC,yBAAyB,EAAE,eAAe;wBAC1C,wBAAwB,EAAE,4CAA4C;wBACtE,sBAAsB,EAAE,0CAA0C;wBAClE,eAAe,EAAE,WAAW;wBAC5B,SAAS,EAAE,SAAS;qBACrB;iBACF","sourcesContent":["import { computed, Directive, input, model } from '@angular/core';\nimport { cn } from '../../utils';\nimport { type ScToggleVariants } from '../toggle/toggle';\n\n@Directive({\n selector: 'div[scToggleGroup]',\n host: {\n 'data-slot': 'toggle-group',\n role: 'group',\n '[attr.data-variant]': 'variant()',\n '[attr.data-size]': 'size()',\n '[attr.data-spacing]': 'spacing()',\n '[attr.data-orientation]': 'orientation()',\n '[attr.data-horizontal]': 'orientation() === \"horizontal\" ? \"\" : null',\n '[attr.data-vertical]': 'orientation() === \"vertical\" ? \"\" : null',\n '[style.--gap]': 'spacing()',\n '[class]': 'class()',\n },\n})\nexport class ScToggleGroup {\n readonly classInput = input<string>('', { alias: 'class' });\n readonly type = input<'single' | 'multiple'>('single');\n readonly value = model<string | string[] | null>(null);\n readonly disabled = input<boolean>(false);\n readonly variant = input<ScToggleVariants['variant']>('default');\n readonly size = input<ScToggleVariants['size']>('default');\n readonly spacing = input<number>(0);\n readonly orientation = input<'horizontal' | 'vertical'>('horizontal');\n\n protected readonly class = computed(() =>\n cn(\n 'rounded-lg data-[size=sm]:rounded-[min(var(--radius-md),10px)] group/toggle-group flex w-fit flex-row items-center gap-[--spacing(var(--gap))] data-vertical:flex-col data-vertical:items-stretch',\n this.classInput(),\n ),\n );\n\n isSelected(itemValue: string): boolean {\n const currentValue = this.value();\n if (this.type() === 'single') {\n return currentValue === itemValue;\n }\n return Array.isArray(currentValue) && currentValue.includes(itemValue);\n }\n\n toggle(itemValue: string): void {\n if (this.disabled()) return;\n\n if (this.type() === 'single') {\n this.value.set(this.value() === itemValue ? null : itemValue);\n } else {\n const currentValue = this.value();\n const arr = Array.isArray(currentValue) ? [...currentValue] : [];\n const index = arr.indexOf(itemValue);\n if (index === -1) {\n arr.push(itemValue);\n } else {\n arr.splice(index, 1);\n }\n this.value.set(arr);\n }\n }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/toolbar/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC","sourcesContent":["export { ScToolbar } from './toolbar';\nexport { ScToolbarWidget } from './toolbar-widget';\nexport { ScToolbarWidgetGroup } from './toolbar-widget-group';\nexport { ScToolbarSeparator } from './toolbar-separator';\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Toolbar } from '@angular/aria/toolbar';
|
|
2
|
+
import { computed, Directive, inject, input } from '@angular/core';
|
|
3
|
+
import { cn } from '../../utils';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class ScToolbarSeparator {
|
|
6
|
+
toolbar = inject(Toolbar);
|
|
7
|
+
classInput = input('', { ...(ngDevMode ? { debugName: "classInput" } : {}), alias: 'class' });
|
|
8
|
+
separatorOrientation = computed(() => this.toolbar.orientation() === 'horizontal' ? 'vertical' : 'horizontal', ...(ngDevMode ? [{ debugName: "separatorOrientation" }] : []));
|
|
9
|
+
class = computed(() => {
|
|
10
|
+
const isVertical = this.separatorOrientation() === 'vertical';
|
|
11
|
+
return cn('shrink-0 bg-border', isVertical ? 'mx-1 h-full w-px' : 'my-1 h-px w-full', this.classInput());
|
|
12
|
+
}, ...(ngDevMode ? [{ debugName: "class" }] : []));
|
|
13
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToolbarSeparator, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
14
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "21.1.5", type: ScToolbarSeparator, isStandalone: true, selector: "div[scToolbarSeparator]", inputs: { classInput: { classPropertyName: "classInput", publicName: "class", isSignal: true, isRequired: false, transformFunction: null } }, host: { attributes: { "data-slot": "toolbar-separator", "role": "separator" }, properties: { "attr.aria-orientation": "separatorOrientation()", "attr.data-orientation": "separatorOrientation()", "class": "class()" } }, ngImport: i0 });
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToolbarSeparator, decorators: [{
|
|
17
|
+
type: Directive,
|
|
18
|
+
args: [{
|
|
19
|
+
selector: 'div[scToolbarSeparator]',
|
|
20
|
+
host: {
|
|
21
|
+
'data-slot': 'toolbar-separator',
|
|
22
|
+
role: 'separator',
|
|
23
|
+
'[attr.aria-orientation]': 'separatorOrientation()',
|
|
24
|
+
'[attr.data-orientation]': 'separatorOrientation()',
|
|
25
|
+
'[class]': 'class()',
|
|
26
|
+
},
|
|
27
|
+
}]
|
|
28
|
+
}], propDecorators: { classInput: [{ type: i0.Input, args: [{ isSignal: true, alias: "class", required: false }] }] } });
|
|
29
|
+
//# sourceMappingURL=toolbar-separator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolbar-separator.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/toolbar/toolbar-separator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;;AAYjC,MAAM,OAAO,kBAAkB;IACZ,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;IAElC,UAAU,GAAG,KAAK,CAAS,EAAE,uDAAI,KAAK,EAAE,OAAO,GAAG,CAAC;IAEzC,oBAAoB,GAAG,QAAQ,CAAC,GAAG,EAAE,CACtD,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,gEACxE,CAAC;IAEiB,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE;QACvC,MAAM,UAAU,GAAG,IAAI,CAAC,oBAAoB,EAAE,KAAK,UAAU,CAAC;QAC9D,OAAO,EAAE,CACP,oBAAoB,EACpB,UAAU,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,kBAAkB,EACpD,IAAI,CAAC,UAAU,EAAE,CAClB,CAAC;IACJ,CAAC,iDAAC,CAAC;uGAhBQ,kBAAkB;2FAAlB,kBAAkB;;2FAAlB,kBAAkB;kBAV9B,SAAS;mBAAC;oBACT,QAAQ,EAAE,yBAAyB;oBACnC,IAAI,EAAE;wBACJ,WAAW,EAAE,mBAAmB;wBAChC,IAAI,EAAE,WAAW;wBACjB,yBAAyB,EAAE,wBAAwB;wBACnD,yBAAyB,EAAE,wBAAwB;wBACnD,SAAS,EAAE,SAAS;qBACrB;iBACF","sourcesContent":["import { Toolbar } from '@angular/aria/toolbar';\nimport { computed, Directive, inject, input } from '@angular/core';\nimport { cn } from '../../utils';\n\n@Directive({\n selector: 'div[scToolbarSeparator]',\n host: {\n 'data-slot': 'toolbar-separator',\n role: 'separator',\n '[attr.aria-orientation]': 'separatorOrientation()',\n '[attr.data-orientation]': 'separatorOrientation()',\n '[class]': 'class()',\n },\n})\nexport class ScToolbarSeparator {\n private readonly toolbar = inject(Toolbar);\n\n readonly classInput = input<string>('', { alias: 'class' });\n\n protected readonly separatorOrientation = computed(() =>\n this.toolbar.orientation() === 'horizontal' ? 'vertical' : 'horizontal',\n );\n\n protected readonly class = computed(() => {\n const isVertical = this.separatorOrientation() === 'vertical';\n return cn(\n 'shrink-0 bg-border',\n isVertical ? 'mx-1 h-full w-px' : 'my-1 h-px w-full',\n this.classInput(),\n );\n });\n}\n"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { ToolbarWidgetGroup } from '@angular/aria/toolbar';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, input, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { cn } from '../../utils';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/aria/toolbar";
|
|
6
|
+
export class ScToolbarWidgetGroup {
|
|
7
|
+
classInput = input('', { ...(ngDevMode ? { debugName: "classInput" } : {}), alias: 'class' });
|
|
8
|
+
class = computed(() => cn('flex items-center gap-0.5', this.classInput()), ...(ngDevMode ? [{ debugName: "class" }] : []));
|
|
9
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToolbarWidgetGroup, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "21.1.5", type: ScToolbarWidgetGroup, isStandalone: true, selector: "div[scToolbarWidgetGroup]", inputs: { classInput: { classPropertyName: "classInput", publicName: "class", isSignal: true, isRequired: false, transformFunction: null } }, host: { attributes: { "data-slot": "toolbar-widget-group" }, properties: { "class": "class()" } }, hostDirectives: [{ directive: i1.ToolbarWidgetGroup, inputs: ["disabled", "disabled", "multi", "multi"] }], ngImport: i0, template: `
|
|
11
|
+
<ng-content />
|
|
12
|
+
`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
13
|
+
}
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToolbarWidgetGroup, decorators: [{
|
|
15
|
+
type: Component,
|
|
16
|
+
args: [{
|
|
17
|
+
selector: 'div[scToolbarWidgetGroup]',
|
|
18
|
+
hostDirectives: [
|
|
19
|
+
{
|
|
20
|
+
directive: ToolbarWidgetGroup,
|
|
21
|
+
inputs: ['disabled', 'multi'],
|
|
22
|
+
},
|
|
23
|
+
],
|
|
24
|
+
template: `
|
|
25
|
+
<ng-content />
|
|
26
|
+
`,
|
|
27
|
+
host: {
|
|
28
|
+
'data-slot': 'toolbar-widget-group',
|
|
29
|
+
'[class]': 'class()',
|
|
30
|
+
},
|
|
31
|
+
encapsulation: ViewEncapsulation.None,
|
|
32
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
33
|
+
}]
|
|
34
|
+
}], propDecorators: { classInput: [{ type: i0.Input, args: [{ isSignal: true, alias: "class", required: false }] }] } });
|
|
35
|
+
//# sourceMappingURL=toolbar-widget-group.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolbar-widget-group.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/toolbar/toolbar-widget-group.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,QAAQ,EACR,KAAK,EACL,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;;;AAoBjC,MAAM,OAAO,oBAAoB;IACtB,UAAU,GAAG,KAAK,CAAS,EAAE,uDAAI,KAAK,EAAE,OAAO,GAAG,CAAC;IAEzC,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,CACvC,EAAE,CAAC,2BAA2B,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,iDACnD,CAAC;uGALS,oBAAoB;2FAApB,oBAAoB,kbAVrB;;GAET;;2FAQU,oBAAoB;kBAlBhC,SAAS;mBAAC;oBACT,QAAQ,EAAE,2BAA2B;oBACrC,cAAc,EAAE;wBACd;4BACE,SAAS,EAAE,kBAAkB;4BAC7B,MAAM,EAAE,CAAC,UAAU,EAAE,OAAO,CAAC;yBAC9B;qBACF;oBACD,QAAQ,EAAE;;GAET;oBACD,IAAI,EAAE;wBACJ,WAAW,EAAE,sBAAsB;wBACnC,SAAS,EAAE,SAAS;qBACrB;oBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD","sourcesContent":["import { ToolbarWidgetGroup } from '@angular/aria/toolbar';\nimport {\n ChangeDetectionStrategy,\n Component,\n computed,\n input,\n ViewEncapsulation,\n} from '@angular/core';\nimport { cn } from '../../utils';\n\n@Component({\n selector: 'div[scToolbarWidgetGroup]',\n hostDirectives: [\n {\n directive: ToolbarWidgetGroup,\n inputs: ['disabled', 'multi'],\n },\n ],\n template: `\n <ng-content />\n `,\n host: {\n 'data-slot': 'toolbar-widget-group',\n '[class]': 'class()',\n },\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScToolbarWidgetGroup {\n readonly classInput = input<string>('', { alias: 'class' });\n\n protected readonly class = computed(() =>\n cn('flex items-center gap-0.5', this.classInput()),\n );\n}\n"]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { ToolbarWidget } from '@angular/aria/toolbar';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, inject, input, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { cn } from '../../utils';
|
|
4
|
+
import { toggleVariants } from '../toggle/toggle';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/aria/toolbar";
|
|
7
|
+
export class ScToolbarWidget {
|
|
8
|
+
widget = inject(ToolbarWidget);
|
|
9
|
+
classInput = input('', { ...(ngDevMode ? { debugName: "classInput" } : {}), alias: 'class' });
|
|
10
|
+
class = computed(() => cn(toggleVariants({ variant: 'default', size: 'default' }), 'data-[state=on]:bg-muted', this.classInput()), ...(ngDevMode ? [{ debugName: "class" }] : []));
|
|
11
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToolbarWidget, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "21.1.5", type: ScToolbarWidget, isStandalone: true, selector: "button[scToolbarWidget]", inputs: { classInput: { classPropertyName: "classInput", publicName: "class", isSignal: true, isRequired: false, transformFunction: null } }, host: { attributes: { "data-slot": "toolbar-widget", "type": "button" }, properties: { "attr.data-state": "widget.selected() ? \"on\" : \"off\"", "class": "class()" } }, hostDirectives: [{ directive: i1.ToolbarWidget, inputs: ["value", "value", "disabled", "disabled"] }], ngImport: i0, template: `
|
|
13
|
+
<ng-content />
|
|
14
|
+
`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToolbarWidget, decorators: [{
|
|
17
|
+
type: Component,
|
|
18
|
+
args: [{
|
|
19
|
+
selector: 'button[scToolbarWidget]',
|
|
20
|
+
hostDirectives: [
|
|
21
|
+
{
|
|
22
|
+
directive: ToolbarWidget,
|
|
23
|
+
inputs: ['value', 'disabled'],
|
|
24
|
+
},
|
|
25
|
+
],
|
|
26
|
+
template: `
|
|
27
|
+
<ng-content />
|
|
28
|
+
`,
|
|
29
|
+
host: {
|
|
30
|
+
'data-slot': 'toolbar-widget',
|
|
31
|
+
type: 'button',
|
|
32
|
+
'[attr.data-state]': 'widget.selected() ? "on" : "off"',
|
|
33
|
+
'[class]': 'class()',
|
|
34
|
+
},
|
|
35
|
+
encapsulation: ViewEncapsulation.None,
|
|
36
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
37
|
+
}]
|
|
38
|
+
}], propDecorators: { classInput: [{ type: i0.Input, args: [{ isSignal: true, alias: "class", required: false }] }] } });
|
|
39
|
+
//# sourceMappingURL=toolbar-widget.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolbar-widget.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/toolbar/toolbar-widget.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,QAAQ,EACR,MAAM,EACN,KAAK,EACL,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AACjC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;;;AAsBlD,MAAM,OAAO,eAAe;IACP,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;IAEzC,UAAU,GAAG,KAAK,CAAS,EAAE,uDAAI,KAAK,EAAE,OAAO,GAAG,CAAC;IAEzC,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,CACvC,EAAE,CACA,cAAc,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,EACvD,0BAA0B,EAC1B,IAAI,CAAC,UAAU,EAAE,CAClB,iDACF,CAAC;uGAXS,eAAe;2FAAf,eAAe,kfAZhB;;GAET;;2FAUU,eAAe;kBApB3B,SAAS;mBAAC;oBACT,QAAQ,EAAE,yBAAyB;oBACnC,cAAc,EAAE;wBACd;4BACE,SAAS,EAAE,aAAa;4BACxB,MAAM,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC;yBAC9B;qBACF;oBACD,QAAQ,EAAE;;GAET;oBACD,IAAI,EAAE;wBACJ,WAAW,EAAE,gBAAgB;wBAC7B,IAAI,EAAE,QAAQ;wBACd,mBAAmB,EAAE,kCAAkC;wBACvD,SAAS,EAAE,SAAS;qBACrB;oBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD","sourcesContent":["import { ToolbarWidget } from '@angular/aria/toolbar';\nimport {\n ChangeDetectionStrategy,\n Component,\n computed,\n inject,\n input,\n ViewEncapsulation,\n} from '@angular/core';\nimport { cn } from '../../utils';\nimport { toggleVariants } from '../toggle/toggle';\n\n@Component({\n selector: 'button[scToolbarWidget]',\n hostDirectives: [\n {\n directive: ToolbarWidget,\n inputs: ['value', 'disabled'],\n },\n ],\n template: `\n <ng-content />\n `,\n host: {\n 'data-slot': 'toolbar-widget',\n type: 'button',\n '[attr.data-state]': 'widget.selected() ? \"on\" : \"off\"',\n '[class]': 'class()',\n },\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScToolbarWidget {\n protected readonly widget = inject(ToolbarWidget);\n\n readonly classInput = input<string>('', { alias: 'class' });\n\n protected readonly class = computed(() =>\n cn(\n toggleVariants({ variant: 'default', size: 'default' }),\n 'data-[state=on]:bg-muted',\n this.classInput(),\n ),\n );\n}\n"]}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Toolbar } from '@angular/aria/toolbar';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, inject, input, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { cn } from '../../utils';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/aria/toolbar";
|
|
6
|
+
export class ScToolbar {
|
|
7
|
+
toolbar = inject(Toolbar);
|
|
8
|
+
classInput = input('', { ...(ngDevMode ? { debugName: "classInput" } : {}), alias: 'class' });
|
|
9
|
+
class = computed(() => cn('flex w-fit items-center gap-1 rounded-lg border bg-background p-1', this.toolbar.orientation() === 'vertical' && 'flex-col items-stretch', this.classInput()), ...(ngDevMode ? [{ debugName: "class" }] : []));
|
|
10
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToolbar, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
11
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "21.1.5", type: ScToolbar, isStandalone: true, selector: "div[scToolbar]", inputs: { classInput: { classPropertyName: "classInput", publicName: "class", isSignal: true, isRequired: false, transformFunction: null } }, host: { attributes: { "data-slot": "toolbar" }, properties: { "attr.data-orientation": "toolbar.orientation()", "class": "class()" } }, hostDirectives: [{ directive: i1.Toolbar, inputs: ["orientation", "orientation", "disabled", "disabled", "wrap", "wrap", "values", "values", "softDisabled", "softDisabled"], outputs: ["valuesChange", "valuesChange"] }], ngImport: i0, template: `
|
|
12
|
+
<ng-content />
|
|
13
|
+
`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScToolbar, decorators: [{
|
|
16
|
+
type: Component,
|
|
17
|
+
args: [{
|
|
18
|
+
selector: 'div[scToolbar]',
|
|
19
|
+
hostDirectives: [
|
|
20
|
+
{
|
|
21
|
+
directive: Toolbar,
|
|
22
|
+
inputs: ['orientation', 'disabled', 'wrap', 'values', 'softDisabled'],
|
|
23
|
+
outputs: ['valuesChange'],
|
|
24
|
+
},
|
|
25
|
+
],
|
|
26
|
+
template: `
|
|
27
|
+
<ng-content />
|
|
28
|
+
`,
|
|
29
|
+
host: {
|
|
30
|
+
'data-slot': 'toolbar',
|
|
31
|
+
'[attr.data-orientation]': 'toolbar.orientation()',
|
|
32
|
+
'[class]': 'class()',
|
|
33
|
+
},
|
|
34
|
+
encapsulation: ViewEncapsulation.None,
|
|
35
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
36
|
+
}]
|
|
37
|
+
}], propDecorators: { classInput: [{ type: i0.Input, args: [{ isSignal: true, alias: "class", required: false }] }] } });
|
|
38
|
+
//# sourceMappingURL=toolbar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolbar.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/toolbar/toolbar.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AAChD,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,QAAQ,EACR,MAAM,EACN,KAAK,EACL,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;;;AAsBjC,MAAM,OAAO,SAAS;IACD,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;IAEpC,UAAU,GAAG,KAAK,CAAS,EAAE,uDAAI,KAAK,EAAE,OAAO,GAAG,CAAC;IAEzC,KAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,CACvC,EAAE,CACA,mEAAmE,EACnE,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,UAAU,IAAI,wBAAwB,EACrE,IAAI,CAAC,UAAU,EAAE,CAClB,iDACF,CAAC;uGAXS,SAAS;2FAAT,SAAS,4jBAXV;;GAET;;2FASU,SAAS;kBApBrB,SAAS;mBAAC;oBACT,QAAQ,EAAE,gBAAgB;oBAC1B,cAAc,EAAE;wBACd;4BACE,SAAS,EAAE,OAAO;4BAClB,MAAM,EAAE,CAAC,aAAa,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,cAAc,CAAC;4BACrE,OAAO,EAAE,CAAC,cAAc,CAAC;yBAC1B;qBACF;oBACD,QAAQ,EAAE;;GAET;oBACD,IAAI,EAAE;wBACJ,WAAW,EAAE,SAAS;wBACtB,yBAAyB,EAAE,uBAAuB;wBAClD,SAAS,EAAE,SAAS;qBACrB;oBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD","sourcesContent":["import { Toolbar } from '@angular/aria/toolbar';\nimport {\n ChangeDetectionStrategy,\n Component,\n computed,\n inject,\n input,\n ViewEncapsulation,\n} from '@angular/core';\nimport { cn } from '../../utils';\n\n@Component({\n selector: 'div[scToolbar]',\n hostDirectives: [\n {\n directive: Toolbar,\n inputs: ['orientation', 'disabled', 'wrap', 'values', 'softDisabled'],\n outputs: ['valuesChange'],\n },\n ],\n template: `\n <ng-content />\n `,\n host: {\n 'data-slot': 'toolbar',\n '[attr.data-orientation]': 'toolbar.orientation()',\n '[class]': 'class()',\n },\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScToolbar {\n protected readonly toolbar = inject(Toolbar);\n\n readonly classInput = input<string>('', { alias: 'class' });\n\n protected readonly class = computed(() =>\n cn(\n 'flex w-fit items-center gap-1 rounded-lg border bg-background p-1',\n this.toolbar.orientation() === 'vertical' && 'flex-col items-stretch',\n this.classInput(),\n ),\n );\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/tooltip/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC","sourcesContent":["export { ScTooltipTrigger } from './tooltip-trigger';\nexport { ScTooltipManager } from './tooltip-manager';\nexport type { ScTooltipPosition } from './tooltip-manager';\n"]}
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
2
|
+
import { ComponentPortal } from '@angular/cdk/portal';
|
|
3
|
+
import { inject, Injectable, Injector, } from '@angular/core';
|
|
4
|
+
import { ScTooltip, SC_TOOLTIP_DATA } from './tooltip';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
const positionMap = {
|
|
7
|
+
top: [
|
|
8
|
+
{
|
|
9
|
+
originX: 'center',
|
|
10
|
+
originY: 'top',
|
|
11
|
+
overlayX: 'center',
|
|
12
|
+
overlayY: 'bottom',
|
|
13
|
+
offsetY: -8,
|
|
14
|
+
},
|
|
15
|
+
{
|
|
16
|
+
originX: 'center',
|
|
17
|
+
originY: 'bottom',
|
|
18
|
+
overlayX: 'center',
|
|
19
|
+
overlayY: 'top',
|
|
20
|
+
offsetY: 8,
|
|
21
|
+
},
|
|
22
|
+
],
|
|
23
|
+
bottom: [
|
|
24
|
+
{
|
|
25
|
+
originX: 'center',
|
|
26
|
+
originY: 'bottom',
|
|
27
|
+
overlayX: 'center',
|
|
28
|
+
overlayY: 'top',
|
|
29
|
+
offsetY: 8,
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
originX: 'center',
|
|
33
|
+
originY: 'top',
|
|
34
|
+
overlayX: 'center',
|
|
35
|
+
overlayY: 'bottom',
|
|
36
|
+
offsetY: -8,
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
left: [
|
|
40
|
+
{
|
|
41
|
+
originX: 'start',
|
|
42
|
+
originY: 'center',
|
|
43
|
+
overlayX: 'end',
|
|
44
|
+
overlayY: 'center',
|
|
45
|
+
offsetX: -8,
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
originX: 'end',
|
|
49
|
+
originY: 'center',
|
|
50
|
+
overlayX: 'start',
|
|
51
|
+
overlayY: 'center',
|
|
52
|
+
offsetX: 8,
|
|
53
|
+
},
|
|
54
|
+
],
|
|
55
|
+
right: [
|
|
56
|
+
{
|
|
57
|
+
originX: 'end',
|
|
58
|
+
originY: 'center',
|
|
59
|
+
overlayX: 'start',
|
|
60
|
+
overlayY: 'center',
|
|
61
|
+
offsetX: 8,
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
originX: 'start',
|
|
65
|
+
originY: 'center',
|
|
66
|
+
overlayX: 'end',
|
|
67
|
+
overlayY: 'center',
|
|
68
|
+
offsetX: -8,
|
|
69
|
+
},
|
|
70
|
+
],
|
|
71
|
+
};
|
|
72
|
+
export class ScTooltipManager {
|
|
73
|
+
overlay = inject(Overlay);
|
|
74
|
+
injector = inject(Injector);
|
|
75
|
+
overlayRef = null;
|
|
76
|
+
tooltipRef = null;
|
|
77
|
+
currentTooltipId = null;
|
|
78
|
+
animationSubscription = null;
|
|
79
|
+
positionSubscription = null;
|
|
80
|
+
show(elementRef, config, tooltipId) {
|
|
81
|
+
// Immediately dispose any existing tooltip (skip close animation to avoid race conditions)
|
|
82
|
+
if (this.overlayRef) {
|
|
83
|
+
this.disposeTooltip();
|
|
84
|
+
}
|
|
85
|
+
this.currentTooltipId = tooltipId;
|
|
86
|
+
const positionStrategy = this.overlay
|
|
87
|
+
.position()
|
|
88
|
+
.flexibleConnectedTo(elementRef)
|
|
89
|
+
.withPositions(positionMap[config.position])
|
|
90
|
+
.withPush(true);
|
|
91
|
+
this.overlayRef = this.overlay.create({
|
|
92
|
+
positionStrategy,
|
|
93
|
+
scrollStrategy: this.overlay.scrollStrategies.reposition(),
|
|
94
|
+
hasBackdrop: false,
|
|
95
|
+
});
|
|
96
|
+
const tooltipInjector = Injector.create({
|
|
97
|
+
providers: [
|
|
98
|
+
{
|
|
99
|
+
provide: SC_TOOLTIP_DATA,
|
|
100
|
+
useValue: {
|
|
101
|
+
content: config.content,
|
|
102
|
+
tooltipId,
|
|
103
|
+
},
|
|
104
|
+
},
|
|
105
|
+
],
|
|
106
|
+
parent: this.injector,
|
|
107
|
+
});
|
|
108
|
+
const portal = new ComponentPortal(ScTooltip, null, tooltipInjector);
|
|
109
|
+
this.tooltipRef = this.overlayRef.attach(portal);
|
|
110
|
+
this.overlayRef.keydownEvents().subscribe((event) => {
|
|
111
|
+
if (event.key === 'Escape')
|
|
112
|
+
this.hide();
|
|
113
|
+
});
|
|
114
|
+
// Track actual position (CDK may flip if not enough space)
|
|
115
|
+
this.positionSubscription = positionStrategy.positionChanges.subscribe((change) => {
|
|
116
|
+
const pair = change.connectionPair;
|
|
117
|
+
let side;
|
|
118
|
+
if (pair.overlayX === 'center') {
|
|
119
|
+
side = pair.overlayY === 'bottom' ? 'top' : 'bottom';
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
side = pair.overlayX === 'end' ? 'left' : 'right';
|
|
123
|
+
}
|
|
124
|
+
this.tooltipRef?.instance.side.set(side);
|
|
125
|
+
});
|
|
126
|
+
// Subscribe to animation completion
|
|
127
|
+
this.animationSubscription =
|
|
128
|
+
this.tooltipRef.instance.animationComplete.subscribe(() => {
|
|
129
|
+
this.disposeTooltip();
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
hide() {
|
|
133
|
+
if (!this.tooltipRef) {
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
// Trigger close animation (will dispose via animationComplete)
|
|
137
|
+
this.tooltipRef.instance.close();
|
|
138
|
+
}
|
|
139
|
+
disposeTooltip() {
|
|
140
|
+
if (this.positionSubscription) {
|
|
141
|
+
this.positionSubscription.unsubscribe();
|
|
142
|
+
this.positionSubscription = null;
|
|
143
|
+
}
|
|
144
|
+
if (this.animationSubscription) {
|
|
145
|
+
this.animationSubscription.unsubscribe();
|
|
146
|
+
this.animationSubscription = null;
|
|
147
|
+
}
|
|
148
|
+
if (this.overlayRef) {
|
|
149
|
+
this.overlayRef.dispose();
|
|
150
|
+
this.overlayRef = null;
|
|
151
|
+
}
|
|
152
|
+
this.tooltipRef = null;
|
|
153
|
+
this.currentTooltipId = null;
|
|
154
|
+
}
|
|
155
|
+
isTooltipVisible(tooltipId) {
|
|
156
|
+
return this.currentTooltipId === tooltipId;
|
|
157
|
+
}
|
|
158
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScTooltipManager, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
159
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScTooltipManager, providedIn: 'root' });
|
|
160
|
+
}
|
|
161
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScTooltipManager, decorators: [{
|
|
162
|
+
type: Injectable,
|
|
163
|
+
args: [{ providedIn: 'root' }]
|
|
164
|
+
}] });
|
|
165
|
+
//# sourceMappingURL=tooltip-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tooltip-manager.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/tooltip/tooltip-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport {\n ComponentRef,\n ElementRef,\n inject,\n Injectable,\n Injector,\n OutputRefSubscription,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { ScTooltip, SC_TOOLTIP_DATA } from './tooltip';\n\nexport type ScTooltipPosition = 'top' | 'right' | 'bottom' | 'left';\n\nconst positionMap: Record<ScTooltipPosition, ConnectedPosition[]> = {\n top: [\n {\n originX: 'center',\n originY: 'top',\n overlayX: 'center',\n overlayY: 'bottom',\n offsetY: -8,\n },\n {\n originX: 'center',\n originY: 'bottom',\n overlayX: 'center',\n overlayY: 'top',\n offsetY: 8,\n },\n ],\n bottom: [\n {\n originX: 'center',\n originY: 'bottom',\n overlayX: 'center',\n overlayY: 'top',\n offsetY: 8,\n },\n {\n originX: 'center',\n originY: 'top',\n overlayX: 'center',\n overlayY: 'bottom',\n offsetY: -8,\n },\n ],\n left: [\n {\n originX: 'start',\n originY: 'center',\n overlayX: 'end',\n overlayY: 'center',\n offsetX: -8,\n },\n {\n originX: 'end',\n originY: 'center',\n overlayX: 'start',\n overlayY: 'center',\n offsetX: 8,\n },\n ],\n right: [\n {\n originX: 'end',\n originY: 'center',\n overlayX: 'start',\n overlayY: 'center',\n offsetX: 8,\n },\n {\n originX: 'start',\n originY: 'center',\n overlayX: 'end',\n overlayY: 'center',\n offsetX: -8,\n },\n ],\n};\n\nexport interface ScTooltipConfig {\n content: string;\n position: ScTooltipPosition;\n}\n\n@Injectable({ providedIn: 'root' })\nexport class ScTooltipManager {\n private readonly overlay = inject(Overlay);\n private readonly injector = inject(Injector);\n\n private overlayRef: OverlayRef | null = null;\n private tooltipRef: ComponentRef<ScTooltip> | null = null;\n private currentTooltipId: string | null = null;\n private animationSubscription: OutputRefSubscription | null = null;\n private positionSubscription: Subscription | null = null;\n\n show(\n elementRef: ElementRef,\n config: ScTooltipConfig,\n tooltipId: string,\n ): void {\n // Immediately dispose any existing tooltip (skip close animation to avoid race conditions)\n if (this.overlayRef) {\n this.disposeTooltip();\n }\n\n this.currentTooltipId = tooltipId;\n\n const positionStrategy = this.overlay\n .position()\n .flexibleConnectedTo(elementRef)\n .withPositions(positionMap[config.position])\n .withPush(true);\n\n this.overlayRef = this.overlay.create({\n positionStrategy,\n scrollStrategy: this.overlay.scrollStrategies.reposition(),\n hasBackdrop: false,\n });\n\n const tooltipInjector = Injector.create({\n providers: [\n {\n provide: SC_TOOLTIP_DATA,\n useValue: {\n content: config.content,\n tooltipId,\n },\n },\n ],\n parent: this.injector,\n });\n\n const portal = new ComponentPortal(ScTooltip, null, tooltipInjector);\n\n this.tooltipRef = this.overlayRef.attach(portal);\n\n this.overlayRef.keydownEvents().subscribe((event) => {\n if (event.key === 'Escape') this.hide();\n });\n\n // Track actual position (CDK may flip if not enough space)\n this.positionSubscription = positionStrategy.positionChanges.subscribe(\n (change) => {\n const pair = change.connectionPair;\n let side: ScTooltipPosition;\n\n if (pair.overlayX === 'center') {\n side = pair.overlayY === 'bottom' ? 'top' : 'bottom';\n } else {\n side = pair.overlayX === 'end' ? 'left' : 'right';\n }\n\n this.tooltipRef?.instance.side.set(side);\n },\n );\n\n // Subscribe to animation completion\n this.animationSubscription =\n this.tooltipRef.instance.animationComplete.subscribe(() => {\n this.disposeTooltip();\n });\n }\n\n hide(): void {\n if (!this.tooltipRef) {\n return;\n }\n\n // Trigger close animation (will dispose via animationComplete)\n this.tooltipRef.instance.close();\n }\n\n private disposeTooltip(): void {\n if (this.positionSubscription) {\n this.positionSubscription.unsubscribe();\n this.positionSubscription = null;\n }\n\n if (this.animationSubscription) {\n this.animationSubscription.unsubscribe();\n this.animationSubscription = null;\n }\n\n if (this.overlayRef) {\n this.overlayRef.dispose();\n this.overlayRef = null;\n }\n\n this.tooltipRef = null;\n this.currentTooltipId = null;\n }\n\n isTooltipVisible(tooltipId: string): boolean {\n return this.currentTooltipId === tooltipId;\n }\n}\n"]}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { DestroyRef, Directive, effect, ElementRef, inject, input, signal, } from '@angular/core';
|
|
2
|
+
import { _IdGenerator } from '@angular/cdk/a11y';
|
|
3
|
+
import { ScTooltipManager } from './tooltip-manager';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class ScTooltipTrigger {
|
|
6
|
+
tooltipManager = inject(ScTooltipManager);
|
|
7
|
+
elementRef = inject(ElementRef);
|
|
8
|
+
destroyRef = inject(DestroyRef);
|
|
9
|
+
idGenerator = inject(_IdGenerator);
|
|
10
|
+
/** The tooltip text content */
|
|
11
|
+
content = input.required({ ...(ngDevMode ? { debugName: "content" } : {}), alias: 'scTooltipTrigger' });
|
|
12
|
+
/** Position of the tooltip relative to the trigger element */
|
|
13
|
+
position = input('top', { ...(ngDevMode ? { debugName: "position" } : {}), alias: 'tooltipPosition' });
|
|
14
|
+
/** Delay before showing the tooltip in milliseconds */
|
|
15
|
+
showDelay = input(200, { ...(ngDevMode ? { debugName: "showDelay" } : {}), alias: 'tooltipDelay' });
|
|
16
|
+
/** Delay before hiding the tooltip in milliseconds */
|
|
17
|
+
hideDelay = input(0, { ...(ngDevMode ? { debugName: "hideDelay" } : {}), alias: 'tooltipHideDelay' });
|
|
18
|
+
/** Whether the tooltip is disabled */
|
|
19
|
+
disabled = input(false, { ...(ngDevMode ? { debugName: "disabled" } : {}), alias: 'tooltipDisabled' });
|
|
20
|
+
tooltipId = this.idGenerator.getId('sc-tooltip-');
|
|
21
|
+
showTimeout = null;
|
|
22
|
+
hideTimeout = null;
|
|
23
|
+
isVisible = signal(false, ...(ngDevMode ? [{ debugName: "isVisible" }] : []));
|
|
24
|
+
ariaDescribedBy = () => this.isVisible() ? this.tooltipId : null;
|
|
25
|
+
constructor() {
|
|
26
|
+
// Effect to hide tooltip when content becomes empty
|
|
27
|
+
effect(() => {
|
|
28
|
+
if (!this.content() && this.isVisible()) {
|
|
29
|
+
this.hide();
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
// Cleanup on destroy
|
|
33
|
+
this.destroyRef.onDestroy(() => {
|
|
34
|
+
this.cancelTimers();
|
|
35
|
+
this.hide();
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
onMouseEnter() {
|
|
39
|
+
this.scheduleShow();
|
|
40
|
+
}
|
|
41
|
+
onMouseLeave() {
|
|
42
|
+
this.scheduleHide();
|
|
43
|
+
}
|
|
44
|
+
onFocus() {
|
|
45
|
+
this.scheduleShow();
|
|
46
|
+
}
|
|
47
|
+
onBlur() {
|
|
48
|
+
this.scheduleHide();
|
|
49
|
+
}
|
|
50
|
+
scheduleShow() {
|
|
51
|
+
if (this.disabled() || !this.content()) {
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
this.cancelTimers();
|
|
55
|
+
const delay = this.showDelay();
|
|
56
|
+
if (delay > 0) {
|
|
57
|
+
this.showTimeout = setTimeout(() => this.show(), delay);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
this.show();
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
scheduleHide() {
|
|
64
|
+
this.cancelTimers();
|
|
65
|
+
const delay = this.hideDelay();
|
|
66
|
+
if (delay > 0) {
|
|
67
|
+
this.hideTimeout = setTimeout(() => this.hide(), delay);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
this.hide();
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
show() {
|
|
74
|
+
if (this.disabled() || !this.content()) {
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
this.tooltipManager.show(this.elementRef, {
|
|
78
|
+
content: this.content(),
|
|
79
|
+
position: this.position(),
|
|
80
|
+
}, this.tooltipId);
|
|
81
|
+
this.isVisible.set(true);
|
|
82
|
+
}
|
|
83
|
+
hide() {
|
|
84
|
+
if (this.tooltipManager.isTooltipVisible(this.tooltipId)) {
|
|
85
|
+
this.tooltipManager.hide();
|
|
86
|
+
}
|
|
87
|
+
this.isVisible.set(false);
|
|
88
|
+
}
|
|
89
|
+
cancelTimers() {
|
|
90
|
+
if (this.showTimeout) {
|
|
91
|
+
clearTimeout(this.showTimeout);
|
|
92
|
+
this.showTimeout = null;
|
|
93
|
+
}
|
|
94
|
+
if (this.hideTimeout) {
|
|
95
|
+
clearTimeout(this.hideTimeout);
|
|
96
|
+
this.hideTimeout = null;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScTooltipTrigger, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
100
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "21.1.5", type: ScTooltipTrigger, isStandalone: true, selector: "[scTooltipTrigger]", inputs: { content: { classPropertyName: "content", publicName: "scTooltipTrigger", isSignal: true, isRequired: true, transformFunction: null }, position: { classPropertyName: "position", publicName: "tooltipPosition", isSignal: true, isRequired: false, transformFunction: null }, showDelay: { classPropertyName: "showDelay", publicName: "tooltipDelay", isSignal: true, isRequired: false, transformFunction: null }, hideDelay: { classPropertyName: "hideDelay", publicName: "tooltipHideDelay", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "tooltipDisabled", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "focus": "onFocus()", "blur": "onBlur()" }, properties: { "attr.aria-describedby": "ariaDescribedBy()" } }, ngImport: i0 });
|
|
101
|
+
}
|
|
102
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.5", ngImport: i0, type: ScTooltipTrigger, decorators: [{
|
|
103
|
+
type: Directive,
|
|
104
|
+
args: [{
|
|
105
|
+
selector: '[scTooltipTrigger]',
|
|
106
|
+
host: {
|
|
107
|
+
'(mouseenter)': 'onMouseEnter()',
|
|
108
|
+
'(mouseleave)': 'onMouseLeave()',
|
|
109
|
+
'(focus)': 'onFocus()',
|
|
110
|
+
'(blur)': 'onBlur()',
|
|
111
|
+
'[attr.aria-describedby]': 'ariaDescribedBy()',
|
|
112
|
+
},
|
|
113
|
+
}]
|
|
114
|
+
}], ctorParameters: () => [], propDecorators: { content: [{ type: i0.Input, args: [{ isSignal: true, alias: "scTooltipTrigger", required: true }] }], position: [{ type: i0.Input, args: [{ isSignal: true, alias: "tooltipPosition", required: false }] }], showDelay: [{ type: i0.Input, args: [{ isSignal: true, alias: "tooltipDelay", required: false }] }], hideDelay: [{ type: i0.Input, args: [{ isSignal: true, alias: "tooltipHideDelay", required: false }] }], disabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "tooltipDisabled", required: false }] }] } });
|
|
115
|
+
//# sourceMappingURL=tooltip-trigger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tooltip-trigger.js","sourceRoot":"","sources":["../../../../../../../libs/ui/src/lib/components/tooltip/tooltip-trigger.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n DestroyRef,\n Directive,\n effect,\n ElementRef,\n inject,\n input,\n signal,\n} from '@angular/core';\nimport { _IdGenerator } from '@angular/cdk/a11y';\nimport { ScTooltipManager, ScTooltipPosition } from './tooltip-manager';\n\n@Directive({\n selector: '[scTooltipTrigger]',\n host: {\n '(mouseenter)': 'onMouseEnter()',\n '(mouseleave)': 'onMouseLeave()',\n '(focus)': 'onFocus()',\n '(blur)': 'onBlur()',\n '[attr.aria-describedby]': 'ariaDescribedBy()',\n },\n})\nexport class ScTooltipTrigger {\n private readonly tooltipManager = inject(ScTooltipManager);\n private readonly elementRef = inject(ElementRef);\n private readonly destroyRef = inject(DestroyRef);\n private readonly idGenerator = inject(_IdGenerator);\n\n /** The tooltip text content */\n readonly content = input.required<string>({ alias: 'scTooltipTrigger' });\n\n /** Position of the tooltip relative to the trigger element */\n readonly position = input<ScTooltipPosition>('top', {\n alias: 'tooltipPosition',\n });\n\n /** Delay before showing the tooltip in milliseconds */\n readonly showDelay = input<number>(200, { alias: 'tooltipDelay' });\n\n /** Delay before hiding the tooltip in milliseconds */\n readonly hideDelay = input<number>(0, { alias: 'tooltipHideDelay' });\n\n /** Whether the tooltip is disabled */\n readonly disabled = input<boolean>(false, { alias: 'tooltipDisabled' });\n\n private readonly tooltipId = this.idGenerator.getId('sc-tooltip-');\n private showTimeout: ReturnType<typeof setTimeout> | null = null;\n private hideTimeout: ReturnType<typeof setTimeout> | null = null;\n private readonly isVisible = signal(false);\n\n protected readonly ariaDescribedBy = () =>\n this.isVisible() ? this.tooltipId : null;\n\n constructor() {\n // Effect to hide tooltip when content becomes empty\n effect(() => {\n if (!this.content() && this.isVisible()) {\n this.hide();\n }\n });\n\n // Cleanup on destroy\n this.destroyRef.onDestroy(() => {\n this.cancelTimers();\n this.hide();\n });\n }\n\n protected onMouseEnter(): void {\n this.scheduleShow();\n }\n\n protected onMouseLeave(): void {\n this.scheduleHide();\n }\n\n protected onFocus(): void {\n this.scheduleShow();\n }\n\n protected onBlur(): void {\n this.scheduleHide();\n }\n\n private scheduleShow(): void {\n if (this.disabled() || !this.content()) {\n return;\n }\n\n this.cancelTimers();\n\n const delay = this.showDelay();\n if (delay > 0) {\n this.showTimeout = setTimeout(() => this.show(), delay);\n } else {\n this.show();\n }\n }\n\n private scheduleHide(): void {\n this.cancelTimers();\n\n const delay = this.hideDelay();\n if (delay > 0) {\n this.hideTimeout = setTimeout(() => this.hide(), delay);\n } else {\n this.hide();\n }\n }\n\n private show(): void {\n if (this.disabled() || !this.content()) {\n return;\n }\n\n this.tooltipManager.show(\n this.elementRef,\n {\n content: this.content(),\n position: this.position(),\n },\n this.tooltipId,\n );\n this.isVisible.set(true);\n }\n\n private hide(): void {\n if (this.tooltipManager.isTooltipVisible(this.tooltipId)) {\n this.tooltipManager.hide();\n }\n this.isVisible.set(false);\n }\n\n private cancelTimers(): void {\n if (this.showTimeout) {\n clearTimeout(this.showTimeout);\n this.showTimeout = null;\n }\n if (this.hideTimeout) {\n clearTimeout(this.hideTimeout);\n this.hideTimeout = null;\n }\n }\n}\n"]}
|