@dpa-id-components/dpa-shared-components 21.1.1 → 22.0.0-next.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{alert-fill-BHn_Z4vo.js → alert-filled-COSmQYAa.js} +1 -1
- package/dist/{bell-fill-DHRfa4cC.js → bell-filled-7gfK8601.js} +1 -1
- package/dist/{bookmark-outlined-D41PleT8.js → bookmark-D65iW--h.js} +1 -1
- package/dist/{bookmark-DNJYJq0J.js → bookmark-filled-5lCW1BfF.js} +1 -1
- package/dist/{comment-fill-Dc-swkQu.js → comment-filled-Cl_qZ6Fz.js} +1 -1
- package/dist/components/UiBadge/UiBadge.vue.d.ts +3 -16
- package/dist/components/UiButton/UiButton.vue.d.ts +15 -21
- package/dist/components/UiButtonGroup/UiButtonGroup.vue.d.ts +5 -11
- package/dist/components/UiCheckbox/UiCheckbox.vue.d.ts +14 -21
- package/dist/components/UiChip/UiChip.vue.d.ts +11 -12
- package/dist/components/UiColorPicker/UiColorPicker.vue.d.ts +6 -8
- package/dist/components/UiDatePicker/UiDatePicker.vue.d.ts +47 -84
- package/dist/components/UiDialog/UiDialog.vue.d.ts +20 -37
- package/dist/components/UiFilterBadge/UiFilterBadge.vue.d.ts +10 -9
- package/dist/components/UiFilterButton/UiFilterButton.vue.d.ts +26 -10
- package/dist/components/UiIcon/UiIcon.vue.d.ts +11 -6
- package/dist/components/UiIcon/icons.d.ts +14 -39
- package/dist/components/UiIconButton/UiIconButton.vue.d.ts +15 -6
- package/dist/components/UiInfoContent/UiInfoContent.vue.d.ts +17 -10
- package/dist/components/UiInput/UiInput.vue.d.ts +6 -48
- package/dist/components/UiList/UiList.vue.d.ts +5 -11
- package/dist/components/UiListItem/UiListItem.vue.d.ts +12 -24
- package/dist/components/UiMenu/UiMenu.vue.d.ts +30 -35
- package/dist/components/UiMenu/UiMenuItem.vue.d.ts +8 -5
- package/dist/components/UiMenu/UiMenuList.vue.d.ts +13 -11
- package/dist/components/UiPopover/UiPopover.vue.d.ts +45 -0
- package/dist/components/UiRadioButton/UiRadioButton.vue.d.ts +35 -0
- package/dist/components/UiRadioInputGroup/UiRadioInputGroup.vue.d.ts +27 -31
- package/dist/components/UiSearchBar/UiSearchBar.vue.d.ts +16 -39
- package/dist/components/UiSearchInput/UiSearchInput.vue.d.ts +2 -2
- package/dist/components/UiSkeletonBox/UiSkeletonBox.vue.d.ts +1 -5
- package/dist/components/UiSnackbar/UiSnackbar.vue.d.ts +4 -10
- package/dist/components/UiSpinner/UiSpinner.vue.d.ts +5 -8
- package/dist/components/UiTextButton/UiTextButton.vue.d.ts +22 -13
- package/dist/components/UiToggleButton/UiToggleButton.vue.d.ts +10 -24
- package/dist/components/UiTooltip/UiTooltip.vue.d.ts +3 -31
- package/dist/components/index.d.ts +3 -4
- package/dist/dpa-shared-components.js +4263 -4873
- package/dist/{flag-fill-C3XgapYW.js → flag-filled-VmJW-U0p.js} +1 -1
- package/dist/{folder-fill-CnEmPx6c.js → folder-filled-D6pmcH0e.js} +1 -1
- package/dist/{image focus point-D_hUlTWi.js → image-focus-point-BJ7HhehR.js} +1 -1
- package/dist/{info-fill-DlgeXJbI.js → info-filled-PYbvwGmZ.js} +1 -1
- package/dist/{map-outline-uvK8An7m.js → map-FF2zfEGP.js} +1 -1
- package/dist/{map-BMOQGCce.js → map-filled-Y8JaYK4Y.js} +1 -1
- package/dist/{video-rounded-ISWC3gUM.js → play-CArB2O7k.js} +1 -1
- package/dist/{saved-search-fill-CPoyaMRU.js → saved-search-filled-CNz5iwu_.js} +1 -1
- package/dist/{sidebar-fill-CBSJYVQQ.js → sidebar-filled-BnnqCUYl.js} +1 -1
- package/dist/spinner-CrCQ6H6L.js +32 -0
- package/dist/src/assets/icons/{bookmark-fill.vue → bookmark-filled.vue} +1 -1
- package/dist/src/assets/icons/bookmark.vue +4 -7
- package/dist/src/assets/icons/flag-filled.vue +4 -4
- package/dist/src/assets/icons/folder-filled.vue +4 -4
- package/dist/src/assets/icons/info-filled.vue +4 -4
- package/dist/src/assets/icons/map-filled.vue +13 -0
- package/dist/src/assets/icons/map.vue +1 -1
- package/dist/src/assets/icons/play.vue +1 -1
- package/dist/src/assets/icons/spinner.vue +27 -3
- package/dist/src/components/DpaMediaItem/DpaMediaItem.spec.ts +3 -3
- package/dist/src/components/DpaMediaItem/DpaMediaItem.vue +17 -17
- package/dist/src/components/UiBadge/README.md +8 -13
- package/dist/src/components/UiBadge/UiBadge.spec.ts +9 -15
- package/dist/src/components/UiBadge/UiBadge.stories.ts +52 -42
- package/dist/src/components/UiBadge/UiBadge.vue +29 -77
- package/dist/src/components/UiButton/README.md +20 -18
- package/dist/src/components/UiButton/UiButton.spec.ts +12 -41
- package/dist/src/components/UiButton/UiButton.stories.ts +53 -33
- package/dist/src/components/UiButton/UiButton.vue +55 -111
- package/dist/src/components/UiButtonGroup/UiButtonGroup.stories.ts +3 -2
- package/dist/src/components/UiButtonGroup/UiButtonGroup.vue +23 -1
- package/dist/src/components/UiCard/UiCard.vue +3 -3
- package/dist/src/components/UiCheckBoxGroup/UiCheckBoxGroup.spec.ts +4 -2
- package/dist/src/components/UiCheckBoxGroup/UiCheckBoxGroup.stories.ts +1 -1
- package/dist/src/components/UiCheckBoxGroup/UiCheckBoxGroup.vue +2 -3
- package/dist/src/components/UiCheckbox/README.md +4 -16
- package/dist/src/components/UiCheckbox/UiCheckbox.spec.ts +15 -141
- package/dist/src/components/UiCheckbox/UiCheckbox.stories.ts +18 -32
- package/dist/src/components/UiCheckbox/UiCheckbox.vue +48 -84
- package/dist/src/components/UiChip/README.md +10 -5
- package/dist/src/components/UiChip/UiChip.spec.ts +5 -60
- package/dist/src/components/UiChip/UiChip.stories.ts +53 -17
- package/dist/src/components/UiChip/UiChip.vue +31 -33
- package/dist/src/components/UiCollapseNavigation/README.md +3 -3
- package/dist/src/components/UiCollapseNavigation/UiCollapseNavigation.stories.ts +12 -12
- package/dist/src/components/UiCollapseNavigation/UiCollapseNavigation.vue +8 -6
- package/dist/src/components/UiColorPicker/UiColorPicker.spec.ts +12 -24
- package/dist/src/components/UiColorPicker/UiColorPicker.stories.ts +5 -6
- package/dist/src/components/UiColorPicker/UiColorPicker.vue +21 -60
- package/dist/src/components/UiColorPicker/lib/colors.ts +9 -9
- package/dist/src/components/UiDatePicker/README.md +68 -46
- package/dist/src/components/UiDatePicker/UiDatePicker.spec.ts +92 -284
- package/dist/src/components/UiDatePicker/UiDatePicker.stories.ts +210 -196
- package/dist/src/components/UiDatePicker/UiDatePicker.vue +301 -432
- package/dist/src/components/UiDialog/README.md +17 -22
- package/dist/src/components/UiDialog/UiDialog.spec.ts +3 -110
- package/dist/src/components/UiDialog/UiDialog.stories.ts +45 -54
- package/dist/src/components/UiDialog/UiDialog.vue +75 -104
- package/dist/src/components/UiFilterBadge/README.md +7 -7
- package/dist/src/components/UiFilterBadge/UiFilterBadge.spec.ts +47 -3
- package/dist/src/components/UiFilterBadge/UiFilterBadge.stories.ts +3 -18
- package/dist/src/components/UiFilterBadge/UiFilterBadge.vue +31 -26
- package/dist/src/components/UiFilterButton/README.md +2 -0
- package/dist/src/components/UiFilterButton/UiFilterButton.spec.ts +1 -1
- package/dist/src/components/UiFilterButton/UiFilterButton.stories.ts +2 -1
- package/dist/src/components/UiFilterButton/UiFilterButton.vue +31 -23
- package/dist/src/components/UiIcon/UiIcon.spec.ts +3 -3
- package/dist/src/components/UiIcon/UiIcon.stories.ts +1 -1
- package/dist/src/components/UiIcon/UiIcon.vue +24 -25
- package/dist/src/components/UiIcon/icons.ts +113 -141
- package/dist/src/components/UiIconButton/UiIconButton.spec.ts +1 -1
- package/dist/src/components/UiIconButton/UiIconButton.stories.ts +1 -0
- package/dist/src/components/UiIconButton/UiIconButton.vue +28 -10
- package/dist/src/components/UiInfoContent/README.md +7 -8
- package/dist/src/components/UiInfoContent/UiInfoContent.spec.ts +29 -21
- package/dist/src/components/UiInfoContent/UiInfoContent.stories.ts +11 -33
- package/dist/src/components/UiInfoContent/UiInfoContent.vue +34 -33
- package/dist/src/components/UiInput/README.md +15 -32
- package/dist/src/components/UiInput/UiInput.spec.ts +71 -102
- package/dist/src/components/UiInput/UiInput.stories.ts +67 -58
- package/dist/src/components/UiInput/UiInput.vue +87 -286
- package/dist/src/components/UiLabel/README.md +0 -9
- package/dist/src/components/UiLabel/UiLabel.vue +1 -1
- package/dist/src/components/UiList/UiList.stories.ts +1 -0
- package/dist/src/components/UiList/UiList.vue +22 -0
- package/dist/src/components/UiListItem/UiListItem.spec.ts +1 -2
- package/dist/src/components/UiListItem/UiListItem.stories.ts +2 -2
- package/dist/src/components/UiListItem/UiListItem.vue +73 -93
- package/dist/src/components/UiMenu/README.md +64 -7
- package/dist/src/components/UiMenu/UiMenu.spec.ts +87 -99
- package/dist/src/components/UiMenu/UiMenu.stories.ts +166 -411
- package/dist/src/components/UiMenu/UiMenu.vue +228 -408
- package/dist/src/components/UiMenu/UiMenuItem.vue +28 -9
- package/dist/src/components/UiMenu/UiMenuList.vue +22 -0
- package/dist/src/components/UiOverlay/README.md +1 -1
- package/dist/src/components/UiOverlay/UiOverlay.stories.ts +1 -1
- package/dist/src/components/UiOverlay/UiOverlay.vue +2 -2
- package/dist/src/components/UiOverlayMenu/README.md +1 -1
- package/dist/src/components/UiOverlayMenu/UiOverlayMenu.vue +3 -3
- package/dist/src/components/UiPopover/README.md +56 -0
- package/dist/src/components/UiPopover/UiPopover.stories.ts +49 -0
- package/dist/src/components/UiPopover/UiPopover.vue +187 -0
- package/dist/src/components/UiRadioButton/README.md +44 -0
- package/dist/src/components/UiRadioButton/UiRadioButton.stories.ts +85 -0
- package/dist/src/components/UiRadioButton/UiRadioButton.vue +82 -0
- package/dist/src/components/UiRadioInputGroup/UiRadioInputGroup.spec.ts +5 -5
- package/dist/src/components/UiRadioInputGroup/UiRadioInputGroup.stories.ts +5 -30
- package/dist/src/components/UiRadioInputGroup/UiRadioInputGroup.vue +44 -69
- package/dist/src/components/UiSearchBar/README.md +40 -37
- package/dist/src/components/UiSearchBar/UiSearchBar.spec.ts +6 -23
- package/dist/src/components/UiSearchBar/UiSearchBar.stories.ts +25 -127
- package/dist/src/components/UiSearchBar/UiSearchBar.vue +73 -179
- package/dist/src/components/UiSearchInput/UiSearchInput.vue +27 -22
- package/dist/src/components/UiSection/UiSection.vue +4 -4
- package/dist/src/components/UiSectionDivider/UiSectionDivider.vue +3 -3
- package/dist/src/components/UiSelect/UiSelect.stories.ts +1 -1
- package/dist/src/components/UiSelect/UiSelect.vue +17 -76
- package/dist/src/components/UiSkeletonBox/UiSkeletonBox.spec.ts +1 -1
- package/dist/src/components/UiSkeletonBox/UiSkeletonBox.vue +12 -17
- package/dist/src/components/UiSnackbar/UiSnackbar.spec.ts +45 -0
- package/dist/src/components/UiSnackbar/UiSnackbar.stories.ts +19 -22
- package/dist/src/components/UiSnackbar/UiSnackbar.vue +23 -26
- package/dist/src/components/UiSpinner/README.md +6 -4
- package/dist/src/components/UiSpinner/UiSpinner.spec.ts +33 -19
- package/dist/src/components/UiSpinner/UiSpinner.stories.ts +16 -20
- package/dist/src/components/UiSpinner/UiSpinner.vue +55 -87
- package/dist/src/components/UiTextButton/UiTextButton.spec.ts +3 -3
- package/dist/src/components/UiTextButton/UiTextButton.stories.ts +1 -0
- package/dist/src/components/UiTextButton/UiTextButton.vue +28 -9
- package/dist/src/components/UiToggleButton/README.md +16 -15
- package/dist/src/components/UiToggleButton/UiToggleButton.spec.ts +48 -62
- package/dist/src/components/UiToggleButton/UiToggleButton.stories.ts +30 -40
- package/dist/src/components/UiToggleButton/UiToggleButton.vue +54 -129
- package/dist/src/components/UiTooltip/README.md +25 -36
- package/dist/src/components/UiTooltip/UiTooltip.spec.ts +45 -25
- package/dist/src/components/UiTooltip/UiTooltip.stories.ts +21 -64
- package/dist/src/components/UiTooltip/UiTooltip.vue +64 -136
- package/dist/src/components/index.ts +4 -6
- package/dist/src/compositions/useBreakpoints/UseBreakpoints.stories.vue +4 -2
- package/dist/src/tailwindPreset.css +161 -56
- package/dist/src/types/index.ts +1 -0
- package/dist/src/utils/cn.spec.ts +21 -4
- package/dist/src/utils/cn.ts +11 -4
- package/dist/style.css +1 -1
- package/dist/tailwindPreset.css +161 -56
- package/dist/types/index.d.ts +1 -0
- package/dist/utils/cn.d.ts +8 -0
- package/dist/{video overlay-DfhF7VpE.js → video-overlay-D6e61Eo7.js} +1 -1
- package/package.json +1 -2
- package/src/assets/icons/{bookmark-fill.vue → bookmark-filled.vue} +1 -1
- package/src/assets/icons/bookmark.vue +4 -7
- package/src/assets/icons/flag-filled.vue +4 -4
- package/src/assets/icons/folder-filled.vue +4 -4
- package/src/assets/icons/info-filled.vue +4 -4
- package/src/assets/icons/map-filled.vue +13 -0
- package/src/assets/icons/map.vue +1 -1
- package/src/assets/icons/play.vue +1 -1
- package/src/assets/icons/spinner.vue +27 -3
- package/src/components/DpaMediaItem/DpaMediaItem.vue +17 -17
- package/src/components/UiBadge/README.md +8 -13
- package/src/components/UiBadge/UiBadge.vue +29 -77
- package/src/components/UiButton/README.md +20 -18
- package/src/components/UiButton/UiButton.vue +55 -111
- package/src/components/UiButtonGroup/UiButtonGroup.vue +23 -1
- package/src/components/UiCard/UiCard.vue +3 -3
- package/src/components/UiCheckBoxGroup/UiCheckBoxGroup.vue +2 -3
- package/src/components/UiCheckbox/README.md +4 -16
- package/src/components/UiCheckbox/UiCheckbox.vue +48 -84
- package/src/components/UiChip/README.md +10 -5
- package/src/components/UiChip/UiChip.vue +31 -33
- package/src/components/UiCollapseNavigation/README.md +3 -3
- package/src/components/UiCollapseNavigation/UiCollapseNavigation.vue +8 -6
- package/src/components/UiColorPicker/UiColorPicker.vue +21 -60
- package/src/components/UiColorPicker/lib/colors.ts +9 -9
- package/src/components/UiDatePicker/README.md +68 -46
- package/src/components/UiDatePicker/UiDatePicker.vue +301 -432
- package/src/components/UiDialog/README.md +17 -22
- package/src/components/UiDialog/UiDialog.vue +75 -104
- package/src/components/UiFilterBadge/README.md +7 -7
- package/src/components/UiFilterBadge/UiFilterBadge.vue +31 -26
- package/src/components/UiFilterButton/README.md +2 -0
- package/src/components/UiFilterButton/UiFilterButton.vue +31 -23
- package/src/components/UiIcon/UiIcon.vue +24 -25
- package/src/components/UiIcon/icons.ts +113 -141
- package/src/components/UiIconButton/UiIconButton.vue +28 -10
- package/src/components/UiInfoContent/README.md +7 -8
- package/src/components/UiInfoContent/UiInfoContent.vue +34 -33
- package/src/components/UiInput/README.md +15 -32
- package/src/components/UiInput/UiInput.vue +87 -286
- package/src/components/UiLabel/README.md +0 -9
- package/src/components/UiLabel/UiLabel.vue +1 -1
- package/src/components/UiList/UiList.vue +22 -0
- package/src/components/UiListItem/UiListItem.vue +73 -93
- package/src/components/UiMenu/README.md +64 -7
- package/src/components/UiMenu/UiMenu.vue +228 -408
- package/src/components/UiMenu/UiMenuItem.vue +28 -9
- package/src/components/UiMenu/UiMenuList.vue +22 -0
- package/src/components/UiOverlay/README.md +1 -1
- package/src/components/UiOverlay/UiOverlay.vue +2 -2
- package/src/components/UiOverlayMenu/README.md +1 -1
- package/src/components/UiOverlayMenu/UiOverlayMenu.vue +3 -3
- package/src/components/UiPopover/README.md +56 -0
- package/src/components/UiPopover/UiPopover.vue +187 -0
- package/src/components/UiRadioButton/README.md +44 -0
- package/src/components/UiRadioButton/UiRadioButton.vue +82 -0
- package/src/components/UiRadioInputGroup/UiRadioInputGroup.vue +44 -69
- package/src/components/UiSearchBar/README.md +40 -37
- package/src/components/UiSearchBar/UiSearchBar.vue +73 -179
- package/src/components/UiSearchInput/UiSearchInput.vue +27 -22
- package/src/components/UiSection/UiSection.vue +4 -4
- package/src/components/UiSectionDivider/UiSectionDivider.vue +3 -3
- package/src/components/UiSelect/UiSelect.vue +17 -76
- package/src/components/UiSkeletonBox/UiSkeletonBox.vue +12 -17
- package/src/components/UiSnackbar/UiSnackbar.vue +23 -26
- package/src/components/UiSpinner/README.md +6 -4
- package/src/components/UiSpinner/UiSpinner.vue +55 -87
- package/src/components/UiTextButton/UiTextButton.vue +28 -9
- package/src/components/UiToggleButton/README.md +16 -15
- package/src/components/UiToggleButton/UiToggleButton.vue +54 -129
- package/src/components/UiTooltip/README.md +25 -36
- package/src/components/UiTooltip/UiTooltip.vue +64 -136
- package/src/tailwindPreset.css +161 -56
- package/src/types/index.ts +1 -0
- package/src/utils/cn.ts +11 -4
- package/dist/assets/icons/flag-outline.vue.d.ts +0 -3
- package/dist/assets/icons/folder-fill.vue.d.ts +0 -3
- package/dist/assets/icons/graphic-circled.vue.d.ts +0 -3
- package/dist/assets/icons/graphic-filled.vue.d.ts +0 -3
- package/dist/assets/icons/image focus point.vue.d.ts +0 -3
- package/dist/assets/icons/info-fill.vue.d.ts +0 -3
- package/dist/assets/icons/lock-filled.vue.d.ts +0 -3
- package/dist/assets/icons/map-outline.vue.d.ts +0 -3
- package/dist/assets/icons/paperplane.vue.d.ts +0 -3
- package/dist/assets/icons/pause-circle.vue.d.ts +0 -3
- package/dist/assets/icons/picture-circled.vue.d.ts +0 -3
- package/dist/assets/icons/picture-filled.vue.d.ts +0 -3
- package/dist/assets/icons/picture-gallery.vue.d.ts +0 -3
- package/dist/assets/icons/play-circle.vue.d.ts +0 -3
- package/dist/assets/icons/play-fill.vue.d.ts +0 -3
- package/dist/assets/icons/plus-circle.vue.d.ts +0 -3
- package/dist/assets/icons/saved-search-fill.vue.d.ts +0 -3
- package/dist/assets/icons/sidebar-fill.vue.d.ts +0 -3
- package/dist/assets/icons/star-fill.vue.d.ts +0 -3
- package/dist/assets/icons/text-circled.vue.d.ts +0 -3
- package/dist/assets/icons/text-filled.vue.d.ts +0 -3
- package/dist/assets/icons/video overlay.vue.d.ts +0 -3
- package/dist/assets/icons/video-circled.vue.d.ts +0 -3
- package/dist/assets/icons/video-filled.vue.d.ts +0 -3
- package/dist/assets/icons/video-rounded.vue.d.ts +0 -3
- package/dist/audio-circled-amRbTaDb.js +0 -15
- package/dist/audio-filled-C7m_-PTb.js +0 -15
- package/dist/bookmark-fill-DbkrXmPt.js +0 -20
- package/dist/components/UiAutocomplete/UiAutocomplete.vue.d.ts +0 -22
- package/dist/components/UiFilterBadgeButton/UiFilterBadgeButton.vue.d.ts +0 -29
- package/dist/components/UiSimpleInput/UiSimpleInput.vue.d.ts +0 -20
- package/dist/filter-outline-ChWKUbSt.js +0 -16
- package/dist/flag-filled-CdVD_QxY.js +0 -18
- package/dist/flag-outline-ChGgKT6P.js +0 -18
- package/dist/folder-filled-zwvSw3Sd.js +0 -18
- package/dist/graphic-circled-BtuNYmPh.js +0 -15
- package/dist/graphic-filled-DXQvxz4s.js +0 -15
- package/dist/info-filled-Btao1rhT.js +0 -18
- package/dist/lock-filled-C5I60_d0.js +0 -18
- package/dist/paperplane-ed0y9oB6.js +0 -18
- package/dist/pause-circle-ab18LhX3.js +0 -19
- package/dist/picture-circled-DYsNZNYH.js +0 -15
- package/dist/picture-filled-CQYRN3Fa.js +0 -15
- package/dist/picture-gallery-BgWYQrqC.js +0 -16
- package/dist/play-BXy8WcYq.js +0 -18
- package/dist/play-circle-B88YxOh-.js +0 -18
- package/dist/play-fill-nWPoHjD3.js +0 -18
- package/dist/plus-circle-DKWKVMiq.js +0 -18
- package/dist/spinner-dy09pOOm.js +0 -13
- package/dist/src/assets/icons/audio-circled.vue +0 -12
- package/dist/src/assets/icons/audio-filled.vue +0 -12
- package/dist/src/assets/icons/bookmark-outlined.vue +0 -12
- package/dist/src/assets/icons/filter-outline.vue +0 -8
- package/dist/src/assets/icons/flag-fill.vue +0 -13
- package/dist/src/assets/icons/flag-outline.vue +0 -13
- package/dist/src/assets/icons/folder-fill.vue +0 -13
- package/dist/src/assets/icons/graphic-circled.vue +0 -12
- package/dist/src/assets/icons/graphic-filled.vue +0 -12
- package/dist/src/assets/icons/info-fill.vue +0 -13
- package/dist/src/assets/icons/lock-filled.vue +0 -13
- package/dist/src/assets/icons/map-outline.vue +0 -13
- package/dist/src/assets/icons/paperplane.vue +0 -13
- package/dist/src/assets/icons/pause-circle.vue +0 -14
- package/dist/src/assets/icons/picture-circled.vue +0 -12
- package/dist/src/assets/icons/picture-filled.vue +0 -12
- package/dist/src/assets/icons/picture-gallery.vue +0 -13
- package/dist/src/assets/icons/play-circle.vue +0 -13
- package/dist/src/assets/icons/play-fill.vue +0 -13
- package/dist/src/assets/icons/plus-circle.vue +0 -13
- package/dist/src/assets/icons/star-fill.vue +0 -13
- package/dist/src/assets/icons/text-circled.vue +0 -12
- package/dist/src/assets/icons/text-filled.vue +0 -12
- package/dist/src/assets/icons/video-circled.vue +0 -12
- package/dist/src/assets/icons/video-filled.vue +0 -12
- package/dist/src/assets/icons/video-rounded.vue +0 -13
- package/dist/src/components/UiAutocomplete/README.md +0 -44
- package/dist/src/components/UiAutocomplete/UiAutocomplete.spec.ts +0 -39
- package/dist/src/components/UiAutocomplete/UiAutocomplete.stories.ts +0 -46
- package/dist/src/components/UiAutocomplete/UiAutocomplete.vue +0 -159
- package/dist/src/components/UiFilterBadgeButton/README.md +0 -38
- package/dist/src/components/UiFilterBadgeButton/UiFilterBadgeButton.spec.ts +0 -41
- package/dist/src/components/UiFilterBadgeButton/UiFilterBadgeButton.stories.ts +0 -56
- package/dist/src/components/UiFilterBadgeButton/UiFilterBadgeButton.vue +0 -50
- package/dist/src/components/UiSimpleInput/README.md +0 -38
- package/dist/src/components/UiSimpleInput/UiSimpleInput.spec.ts +0 -58
- package/dist/src/components/UiSimpleInput/UiSimpleInput.stories.ts +0 -53
- package/dist/src/components/UiSimpleInput/UiSimpleInput.vue +0 -98
- package/dist/src/utils/index.spec.ts +0 -12
- package/dist/star-fill-DIXwg3gQ.js +0 -18
- package/dist/text-circled-Cykzn5-2.js +0 -15
- package/dist/text-filled-BwOhn26K.js +0 -15
- package/dist/video-circled-Bw9Miyyr.js +0 -15
- package/dist/video-filled-B5Td1M5L.js +0 -15
- package/src/assets/icons/audio-circled.vue +0 -12
- package/src/assets/icons/audio-filled.vue +0 -12
- package/src/assets/icons/bookmark-outlined.vue +0 -12
- package/src/assets/icons/filter-outline.vue +0 -8
- package/src/assets/icons/flag-fill.vue +0 -13
- package/src/assets/icons/flag-outline.vue +0 -13
- package/src/assets/icons/folder-fill.vue +0 -13
- package/src/assets/icons/graphic-circled.vue +0 -12
- package/src/assets/icons/graphic-filled.vue +0 -12
- package/src/assets/icons/info-fill.vue +0 -13
- package/src/assets/icons/lock-filled.vue +0 -13
- package/src/assets/icons/map-outline.vue +0 -13
- package/src/assets/icons/paperplane.vue +0 -13
- package/src/assets/icons/pause-circle.vue +0 -14
- package/src/assets/icons/picture-circled.vue +0 -12
- package/src/assets/icons/picture-filled.vue +0 -12
- package/src/assets/icons/picture-gallery.vue +0 -13
- package/src/assets/icons/play-circle.vue +0 -13
- package/src/assets/icons/play-fill.vue +0 -13
- package/src/assets/icons/plus-circle.vue +0 -13
- package/src/assets/icons/star-fill.vue +0 -13
- package/src/assets/icons/text-circled.vue +0 -12
- package/src/assets/icons/text-filled.vue +0 -12
- package/src/assets/icons/video-circled.vue +0 -12
- package/src/assets/icons/video-filled.vue +0 -12
- package/src/assets/icons/video-rounded.vue +0 -13
- package/src/components/UiAutocomplete/README.md +0 -44
- package/src/components/UiAutocomplete/UiAutocomplete.vue +0 -159
- package/src/components/UiFilterBadgeButton/README.md +0 -38
- package/src/components/UiFilterBadgeButton/UiFilterBadgeButton.vue +0 -50
- package/src/components/UiSimpleInput/README.md +0 -38
- package/src/components/UiSimpleInput/UiSimpleInput.vue +0 -98
- /package/dist/{alert-BMmH4q6y.js → alert-CdAp0ksh.js} +0 -0
- /package/dist/assets/icons/{alert-fill.vue.d.ts → alert-filled.vue.d.ts} +0 -0
- /package/dist/assets/icons/{audio-circled.vue.d.ts → bell-filled.vue.d.ts} +0 -0
- /package/dist/assets/icons/{audio-filled.vue.d.ts → bookmark-filled.vue.d.ts} +0 -0
- /package/dist/assets/icons/{bell-fill.vue.d.ts → comment-filled.vue.d.ts} +0 -0
- /package/dist/assets/icons/{bookmark-fill.vue.d.ts → image-focus-point.vue.d.ts} +0 -0
- /package/dist/assets/icons/{bookmark-outlined.vue.d.ts → map-filled.vue.d.ts} +0 -0
- /package/dist/assets/icons/{comment-fill.vue.d.ts → saved-search-filled.vue.d.ts} +0 -0
- /package/dist/assets/icons/{filter-outline.vue.d.ts → sidebar-filled.vue.d.ts} +0 -0
- /package/dist/assets/icons/{flag-fill.vue.d.ts → video-overlay.vue.d.ts} +0 -0
- /package/dist/{audio-BN2iVbbp.js → audio-Cgg6MUeM.js} +0 -0
- /package/dist/{audio-DLQLFJ3x.js → audio-DS8plcCU.js} +0 -0
- /package/dist/{bag-Br7SrnRJ.js → bag-B28jMR7E.js} +0 -0
- /package/dist/{bell-kOosto6B.js → bell-k_sZgnpL.js} +0 -0
- /package/dist/{book-D0Xsp8As.js → book-CqUJ_JRz.js} +0 -0
- /package/dist/{box-Bw_tD7Nd.js → box-BCDNtaq7.js} +0 -0
- /package/dist/{bulb-tXJKei6j.js → bulb-12wSYpgA.js} +0 -0
- /package/dist/{call-BdzulBfZ.js → call-CW04DyHi.js} +0 -0
- /package/dist/{camera-D8so0Wqg.js → camera-CbeyxVU5.js} +0 -0
- /package/dist/{check-CTBqwPMY.js → check-BpPjjXqx.js} +0 -0
- /package/dist/{checklist-CVBb2iLT.js → checklist-CFCfO7IN.js} +0 -0
- /package/dist/{checkmark-BkBvk5FP.js → checkmark-DhUksPvT.js} +0 -0
- /package/dist/{checkmark-double-9tbcPPxC.js → checkmark-double-BNGXAUiT.js} +0 -0
- /package/dist/{chevron-down-BcjUrqWQ.js → chevron-down-BjZ6BFFp.js} +0 -0
- /package/dist/{chevron-left-DdChgK6Q.js → chevron-left-Z-D_OY2t.js} +0 -0
- /package/dist/{chevron-right-BR3OVahz.js → chevron-right-D1GfZQB6.js} +0 -0
- /package/dist/{chevron-up-R3uiTZDq.js → chevron-up-DWZ1F8w0.js} +0 -0
- /package/dist/{clipboard-BFi2VbBj.js → clipboard-CNCIToKK.js} +0 -0
- /package/dist/{clock-C3D4TRfx.js → clock-CqWSNhFX.js} +0 -0
- /package/dist/{close-CbIMNMG_.js → close-oHIGT_JQ.js} +0 -0
- /package/dist/{cloud-save-CQCTGXxN.js → cloud-save-CWTQ5IHS.js} +0 -0
- /package/dist/{code-ChJ2qMcZ.js → code-BD5nOHqK.js} +0 -0
- /package/dist/{collapse-DISUbIVr.js → collapse-D6QeCZC7.js} +0 -0
- /package/dist/{color-palette-B4pqFFIE.js → color-palette-BpONORjj.js} +0 -0
- /package/dist/{comment-CzF3hkpf.js → comment-D5RZxZWG.js} +0 -0
- /package/dist/{copy-CywrUiK2.js → copy-BDnlScSS.js} +0 -0
- /package/dist/{copy-link-DqcNlpUK.js → copy-link-BSfa58Tb.js} +0 -0
- /package/dist/{delete-Bl6aSpBn.js → delete-dDyi0gau.js} +0 -0
- /package/dist/{download-BdnIOaET.js → download-B-ZTsIBv.js} +0 -0
- /package/dist/{dpa-id-4HKRxUEF.js → dpa-id-DRnjTcHI.js} +0 -0
- /package/dist/{edit-KtC1G-_s.js → edit-BbFkVyRd.js} +0 -0
- /package/dist/{edit-add-DjUq6zXq.js → edit-add-CAPOsjts.js} +0 -0
- /package/dist/{eil-CPA4kVQM.js → eil-CzEP-9Lo.js} +0 -0
- /package/dist/{emoji-C2BmBFxC.js → emoji-BjLqvypC.js} +0 -0
- /package/dist/{emoji-add-NHqne_6m.js → emoji-add-BB4fB4th.js} +0 -0
- /package/dist/{envelope-BDSOA_J7.js → envelope-DftzB5Ol.js} +0 -0
- /package/dist/{event-Bo_sb247.js → event-FR1JMgj6.js} +0 -0
- /package/dist/{expand-BK_uzKmx.js → expand-DaVQ0gpz.js} +0 -0
- /package/dist/{external-link-BPYyKPIa.js → external-link-2Es0qWwd.js} +0 -0
- /package/dist/{file-B97T9C2M.js → file-AHJ00f5M.js} +0 -0
- /package/dist/{file-pdf-lFk-5brY.js → file-pdf-CJDdjKS0.js} +0 -0
- /package/dist/{filter-BIJnBkRa.js → filter-CXjBFUUg.js} +0 -0
- /package/dist/{flag-DNP4L-y-.js → flag-CbX4PUMS.js} +0 -0
- /package/dist/{flags-G-Nbo5ST.js → flags-Buo1j-9g.js} +0 -0
- /package/dist/{flash-9TBwsdOx.js → flash-Dlr5gL01.js} +0 -0
- /package/dist/{folder-s6NWFqjh.js → folder-DQwCjGZC.js} +0 -0
- /package/dist/{folder-add-B-l2wmwY.js → folder-add-zPr2Gmtj.js} +0 -0
- /package/dist/{gallery-B8I5lJ51.js → gallery-CfUbckcB.js} +0 -0
- /package/dist/{gallery-DSmOoCFT.js → gallery-DPl8qZQu.js} +0 -0
- /package/dist/{graphic-BMtcGj5R.js → graphic-BbhCuiiE.js} +0 -0
- /package/dist/{graphic-d-_5qmyr.js → graphic-nXH5ifxc.js} +0 -0
- /package/dist/{graphics-eur3JZ_7.js → graphics-Dp8pQzs-.js} +0 -0
- /package/dist/{grid-1-DOm2nS5Y.js → grid-1-DZUEMbtb.js} +0 -0
- /package/dist/{grid-2-D9XOIyFO.js → grid-2-BQ-9yylY.js} +0 -0
- /package/dist/{grid-3-CR1E0m9u.js → grid-3-BGhZrrCJ.js} +0 -0
- /package/dist/{grid-4-QKKeiUGc.js → grid-4-DY9N435A.js} +0 -0
- /package/dist/{grid-6-C5bCbXur.js → grid-6-B0BR3wbB.js} +0 -0
- /package/dist/{grid-9-FNxsRYRg.js → grid-9-BWhM7qat.js} +0 -0
- /package/dist/{grid-masonry-CuwXzdZ6.js → grid-masonry-1e9tYkSK.js} +0 -0
- /package/dist/{grid-masonry-9-CxLBpKCz.js → grid-masonry-9-DiiX1pQo.js} +0 -0
- /package/dist/{help-DkjfD818.js → help-CLfj4LQM.js} +0 -0
- /package/dist/{home-njHAfgwc.js → home-D6htLjOF.js} +0 -0
- /package/dist/{image-C2RlXeDP.js → image-DnYnaoeu.js} +0 -0
- /package/dist/{impact-high-C0SywXT1.js → impact-high-DuECIU0d.js} +0 -0
- /package/dist/{impact-low-yDd0jU4k.js → impact-low-DMtzvmWi.js} +0 -0
- /package/dist/{impact-medium-Cc_nInN7.js → impact-medium-B5-WfnV2.js} +0 -0
- /package/dist/{impact-very-high-DiOgG_Ji.js → impact-very-high-C1K1nCE9.js} +0 -0
- /package/dist/{impact-very-low-CYW4RgJO.js → impact-very-low-CXbiBK6E.js} +0 -0
- /package/dist/{info-NBFIJ3YI.js → info-Ca-64c_9.js} +0 -0
- /package/dist/{label-CTr8hHIv.js → label-D8X5FrVe.js} +0 -0
- /package/dist/{label-filled-CnTpOqvX.js → label-filled-DjSc-Fk4.js} +0 -0
- /package/dist/{language-UqPESR_Z.js → language-OE6ZfER_.js} +0 -0
- /package/dist/{latest-Cq12zjMs.js → latest-D0dlub5f.js} +0 -0
- /package/dist/{lightbulb-BpK9qU_u.js → lightbulb-DKJrsADi.js} +0 -0
- /package/dist/{list-DKcsNf15.js → list-BviTrZEl.js} +0 -0
- /package/dist/{list-search-BzZuYf_P.js → list-search-Ck6anukf.js} +0 -0
- /package/dist/{lock-BFfHVSog.js → lock-C5vUwbkA.js} +0 -0
- /package/dist/{mail-pagEqHtM.js → mail-CtA-d2d0.js} +0 -0
- /package/dist/{menu-j4cvnLP8.js → menu-DFzmvE6J.js} +0 -0
- /package/dist/{minus-CGsJ-jkT.js → minus-COmVHb9S.js} +0 -0
- /package/dist/{more-horizontal-CDZjG5h8.js → more-horizontal-DzHbd3yn.js} +0 -0
- /package/dist/{more-vertical-YUehtvol.js → more-vertical-CiJm6ZaV.js} +0 -0
- /package/dist/{move-CiU3PwqY.js → move-CUyDTrlz.js} +0 -0
- /package/dist/{move-up-down-H-qHtTwO.js → move-up-down-3AiMDXGu.js} +0 -0
- /package/dist/{navigation-DmqoQINO.js → navigation-BryXzz7G.js} +0 -0
- /package/dist/{note-BZ3q-D4L.js → note-CXIfkCb0.js} +0 -0
- /package/dist/{offline-CLl0pwpv.js → offline-BlqqTvjx.js} +0 -0
- /package/dist/{package-iJOVTpPH.js → package-BEkSqrZt.js} +0 -0
- /package/dist/{package-D_Bh8bgp.js → package-pKbuF39E.js} +0 -0
- /package/dist/{paper-plane-DcYms0cj.js → paper-plane-CwVjTgAB.js} +0 -0
- /package/dist/{pause-COAxeJRm.js → pause-D-nbILiS.js} +0 -0
- /package/dist/{pdf-BweFqxRM.js → pdf-C7o5LP5D.js} +0 -0
- /package/dist/{pen-CmBOMgX_.js → pen-5O6IZM5k.js} +0 -0
- /package/dist/{pen-check-BApB0Zi2.js → pen-check-GQoVyZ_V.js} +0 -0
- /package/dist/{people-D07vIou7.js → people-CFA1u84D.js} +0 -0
- /package/dist/{phone-B9TyVbBj.js → phone-BmL2p-7F.js} +0 -0
- /package/dist/{picture-D7kBYru_.js → picture-BBiWVmta.js} +0 -0
- /package/dist/{picture-DJRwU5Gl.js → picture-jf1PkZfY.js} +0 -0
- /package/dist/{pin-BlBzA8ov.js → pin-CTaBntUQ.js} +0 -0
- /package/dist/{planning-BhE-A4FO.js → planning-s3sRV6ix.js} +0 -0
- /package/dist/{plus-CmEv_iHA.js → plus-Dm-ZxxHJ.js} +0 -0
- /package/dist/{print-ChdLXKHj.js → print-B5fjHJZL.js} +0 -0
- /package/dist/{refresh-C7k19NtO.js → refresh-gU5ZZuG6.js} +0 -0
- /package/dist/{reset-CpXqaOj5.js → reset-CwU1iGF5.js} +0 -0
- /package/dist/{responsive-CKNXzAo1.js → responsive-BHNmDmM6.js} +0 -0
- /package/dist/{rubix-thema-Cmk-5-bm.js → rubix-thema-BZvVEFud.js} +0 -0
- /package/dist/{save-BX3-Z5qP.js → save-mTHDeUnL.js} +0 -0
- /package/dist/{saved-search-Be8D9tJ9.js → saved-search-DJO4_yPH.js} +0 -0
- /package/dist/{search-BeIwOzJl.js → search-B5yHBLf_.js} +0 -0
- /package/dist/{settings-CLChu_zl.js → settings-Hb_Y7Y53.js} +0 -0
- /package/dist/{share-j6ezShBH.js → share-OpdW8ZmZ.js} +0 -0
- /package/dist/{share-alternative-BD-WQYvk.js → share-alternative-C3pSVTYb.js} +0 -0
- /package/dist/{sidebar-CPe20Xae.js → sidebar-DtAUGBof.js} +0 -0
- /package/dist/{slack-BjvLF16S.js → slack-mCoCq7b9.js} +0 -0
- /package/dist/{slider-config-CTzwxojK.js → slider-config-yjKG-9r9.js} +0 -0
- /package/dist/{spellcheck-thqRUMx9.js → spellcheck-bP4DPCKJ.js} +0 -0
- /package/dist/src/assets/icons/{alert-fill.vue → alert-filled.vue} +0 -0
- /package/dist/src/assets/icons/{bell-fill.vue → bell-filled.vue} +0 -0
- /package/dist/src/assets/icons/{comment-fill.vue → comment-filled.vue} +0 -0
- /package/dist/src/assets/icons/{image focus point.vue → image-focus-point.vue} +0 -0
- /package/dist/src/assets/icons/{saved-search-fill.vue → saved-search-filled.vue} +0 -0
- /package/dist/src/assets/icons/{sidebar-fill.vue → sidebar-filled.vue} +0 -0
- /package/dist/src/assets/icons/{video overlay.vue → video-overlay.vue} +0 -0
- /package/dist/{standard-view-dE52BPUm.js → standard-view-CN0ixRE4.js} +0 -0
- /package/dist/{star-uv_o0S9H.js → star-BKWqck4u.js} +0 -0
- /package/dist/{star-filled-BqrpxMqq.js → star-filled-CdXMXBn7.js} +0 -0
- /package/dist/{stop-CrmQCpqp.js → stop-B8l9lmwT.js} +0 -0
- /package/dist/{story-BdUCZQmb.js → story-Cxy8EkgB.js} +0 -0
- /package/dist/{story-DEvV0oQv.js → story-DOxZDwJp.js} +0 -0
- /package/dist/{sync-CPmOdu5b.js → sync-BW_fAqt6.js} +0 -0
- /package/dist/{tasks-TKH8SUBe.js → tasks-DLNuebMi.js} +0 -0
- /package/dist/{text-7i2atLMM.js → text-Bsl2QZz3.js} +0 -0
- /package/dist/{text-BMhu0paW.js → text-CPSps-qh.js} +0 -0
- /package/dist/{thumbs-down-LH8SIeIF.js → thumbs-down-pSf_ND98.js} +0 -0
- /package/dist/{thumbs-up-WZQzpqKr.js → thumbs-up-Braz70N6.js} +0 -0
- /package/dist/{thumbs-up-double-SeGWEXZ_.js → thumbs-up-double-C6foUkOq.js} +0 -0
- /package/dist/{topic-63EhQ_l1.js → topic-BamlhBNV.js} +0 -0
- /package/dist/{union-DKjbjP-9.js → union-CYw04THu.js} +0 -0
- /package/dist/{upload-yjh9wxAA.js → upload-BL_iLqTa.js} +0 -0
- /package/dist/{user-need-divert-me-B_cSVEIY.js → user-need-divert-me-2RaqdMMH.js} +0 -0
- /package/dist/{user-need-educate-me-DOgCmShA.js → user-need-educate-me-CRi42bIc.js} +0 -0
- /package/dist/{user-need-give-me-perspective-2wacZI2F.js → user-need-give-me-perspective-BIF7v9vF.js} +0 -0
- /package/dist/{user-need-help-me-D4VE0IcH.js → user-need-help-me-O0XSLzP-.js} +0 -0
- /package/dist/{user-need-touch-me-u3n8c5IH.js → user-need-touch-me-BueJ3SSh.js} +0 -0
- /package/dist/{user-need-update-me-BcDyXzME.js → user-need-update-me-DP574fsn.js} +0 -0
- /package/dist/{video-BViz7WnQ.js → video-CWHoNlON.js} +0 -0
- /package/dist/{video-hhs4-tLq.js → video-DhS7zpNF.js} +0 -0
- /package/dist/{view-C9Xks5Gy.js → view-Bc5W8beK.js} +0 -0
- /package/dist/{view-off-BuSbQwX0.js → view-off-DquC2i3E.js} +0 -0
- /package/dist/{volume-up-BLQXZI5X.js → volume-up-DEzoW7Bq.js} +0 -0
- /package/src/assets/icons/{alert-fill.vue → alert-filled.vue} +0 -0
- /package/src/assets/icons/{bell-fill.vue → bell-filled.vue} +0 -0
- /package/src/assets/icons/{comment-fill.vue → comment-filled.vue} +0 -0
- /package/src/assets/icons/{image focus point.vue → image-focus-point.vue} +0 -0
- /package/src/assets/icons/{saved-search-fill.vue → saved-search-filled.vue} +0 -0
- /package/src/assets/icons/{sidebar-fill.vue → sidebar-filled.vue} +0 -0
- /package/src/assets/icons/{video overlay.vue → video-overlay.vue} +0 -0
|
@@ -21,8 +21,27 @@
|
|
|
21
21
|
/>
|
|
22
22
|
</component>
|
|
23
23
|
</template>
|
|
24
|
+
<script lang="ts">
|
|
25
|
+
/**
|
|
26
|
+
* @deprecated
|
|
27
|
+
* Please replace with your own component
|
|
28
|
+
*/
|
|
29
|
+
export default {
|
|
30
|
+
name: "UiTextButton",
|
|
31
|
+
setup() {
|
|
32
|
+
onMounted(() => {
|
|
33
|
+
if (window.location.origin.includes("local")) {
|
|
34
|
+
// eslint-disable-next-line no-console
|
|
35
|
+
console.warn(
|
|
36
|
+
"Component is deprecated. It will be removed in a future update.",
|
|
37
|
+
);
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
},
|
|
41
|
+
};
|
|
42
|
+
</script>
|
|
24
43
|
<script setup lang="ts">
|
|
25
|
-
import { computed } from "vue";
|
|
44
|
+
import { computed, onMounted } from "vue";
|
|
26
45
|
|
|
27
46
|
import UiIcon, { type UiIconName } from "../UiIcon/UiIcon.vue";
|
|
28
47
|
|
|
@@ -76,9 +95,9 @@ const weightClassName = computed((): string => {
|
|
|
76
95
|
fontClass = "font-semibold rounded-lg";
|
|
77
96
|
|
|
78
97
|
if (props.placement === "onsurface") {
|
|
79
|
-
hoverClass = "hover:bg-
|
|
98
|
+
hoverClass = "hover:bg-neutral-whisper";
|
|
80
99
|
} else if (props.placement === "oncanvas") {
|
|
81
|
-
hoverClass = "hover:bg-
|
|
100
|
+
hoverClass = "hover:bg-neutral-pale";
|
|
82
101
|
}
|
|
83
102
|
}
|
|
84
103
|
|
|
@@ -108,22 +127,22 @@ const textClassName = computed((): string => {
|
|
|
108
127
|
|
|
109
128
|
const colorClass = computed((): string => {
|
|
110
129
|
if (props.color === "blue") {
|
|
111
|
-
return "text-
|
|
130
|
+
return "text-primary";
|
|
112
131
|
} else if (props.color === "gray") {
|
|
113
132
|
if (props.placement === "onsurface") {
|
|
114
|
-
return "text-
|
|
133
|
+
return "text-neutral-subtle";
|
|
115
134
|
} else if (props.placement === "oncanvas") {
|
|
116
|
-
return "text-
|
|
135
|
+
return "text-neutral-emphasis";
|
|
117
136
|
}
|
|
118
137
|
}
|
|
119
138
|
return "";
|
|
120
139
|
});
|
|
121
140
|
|
|
122
|
-
const iconSize = computed((): "
|
|
141
|
+
const iconSize = computed((): "sm" | "md" => {
|
|
123
142
|
if (props.size === "xsmall") {
|
|
124
|
-
return "
|
|
143
|
+
return "sm";
|
|
125
144
|
} else {
|
|
126
|
-
return "
|
|
145
|
+
return "md";
|
|
127
146
|
}
|
|
128
147
|
});
|
|
129
148
|
|
|
@@ -5,38 +5,39 @@
|
|
|
5
5
|
```html
|
|
6
6
|
<!-- SomeComponent.vue using UiToggleButton -->
|
|
7
7
|
<template>
|
|
8
|
-
<UiToggleButton
|
|
8
|
+
<UiToggleButton v-model="value">Toggle me</UiToggleButton>
|
|
9
9
|
</template>
|
|
10
10
|
|
|
11
|
+
|
|
11
12
|
<script setup lang="ts">
|
|
12
13
|
import { UiToggleButton } from "@dpa-id-components/dpa-shared-components";
|
|
13
14
|
</script>
|
|
14
15
|
```
|
|
15
16
|
|
|
17
|
+
|
|
16
18
|
## API
|
|
17
19
|
|
|
18
20
|
### Props
|
|
19
21
|
|
|
20
|
-
| Name | Type | Default
|
|
21
|
-
|
|
22
|
-
| `
|
|
23
|
-
| `
|
|
24
|
-
| `labelPosition` | `String` | `left`
|
|
25
|
-
| `
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
| `size` | `String` | `small` | Sets the element's `size` to either "small" or "large" |
|
|
22
|
+
| Name | Type | Default | Description |
|
|
23
|
+
|-----------------|-----------|---------|--------------------------------------------------------------|
|
|
24
|
+
| `id` | `String` | | Sets the `id` of the input. Auto-generated if not provided. |
|
|
25
|
+
| `modelValue` | `Boolean` | `false` | The `checked` state of the checkbox |
|
|
26
|
+
| `labelPosition` | `String` | `left` | To place the label to the right side set this to `"right"` |
|
|
27
|
+
| `size` | `String` | `sm` | Sets the element's size to either `"sm"` or `"lg"` |
|
|
28
|
+
|
|
29
|
+
### Attributes
|
|
30
|
+
|
|
31
|
+
HTML attributes like `disabled`, `aria-label`, etc. are forwarded to the underlying `<input>` element via `v-bind="$attrs"`.
|
|
31
32
|
|
|
32
33
|
### Slots
|
|
33
34
|
|
|
34
35
|
| Name | Description |
|
|
35
|
-
|
|
36
|
+
|-----------|---------------|
|
|
36
37
|
| `default` | Label content |
|
|
37
38
|
|
|
38
39
|
### Events
|
|
39
40
|
|
|
40
41
|
| Name | Type | Description |
|
|
41
|
-
|
|
42
|
-
| `update:model-value` | `boolean` |
|
|
42
|
+
|----------------------|-----------|----------------------------------------|
|
|
43
|
+
| `update:model-value` | `boolean` | |
|
|
@@ -3,87 +3,73 @@ import { describe, expect, it } from "vitest";
|
|
|
3
3
|
|
|
4
4
|
import UiToggleButton from "./UiToggleButton.vue";
|
|
5
5
|
|
|
6
|
+
function mountToggle(props = {}, slotContent = "Label") {
|
|
7
|
+
return mount(UiToggleButton, {
|
|
8
|
+
props,
|
|
9
|
+
slots: { default: slotContent },
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
|
|
6
13
|
describe("UiToggleButton", () => {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
+
it("renders with correct defaults when no props are provided", () => {
|
|
15
|
+
const wrapper = mountToggle();
|
|
16
|
+
|
|
17
|
+
const input = wrapper.find("[data-testid='toggleButton']");
|
|
18
|
+
const inputEl = input.element as HTMLInputElement;
|
|
19
|
+
|
|
20
|
+
expect(inputEl.checked).toBe(false);
|
|
21
|
+
expect(inputEl.disabled).toBe(false);
|
|
22
|
+
expect(input.attributes("id")).toBeTruthy();
|
|
14
23
|
});
|
|
15
24
|
|
|
16
|
-
it("
|
|
17
|
-
|
|
25
|
+
it("renders slot content", () => {
|
|
26
|
+
const wrapper = mountToggle({}, "Slot Label");
|
|
27
|
+
|
|
28
|
+
expect(wrapper.text()).toContain("Slot Label");
|
|
18
29
|
});
|
|
19
30
|
|
|
20
|
-
it("emits
|
|
31
|
+
it("emits update:modelValue when clicked", async () => {
|
|
32
|
+
const wrapper = mountToggle({ modelValue: false });
|
|
33
|
+
|
|
21
34
|
const input = wrapper.find("[data-testid='toggleButton']");
|
|
35
|
+
await input.setValue(true);
|
|
22
36
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
expect(wrapper.emitted()["update:modelValue"]).toBeTruthy();
|
|
37
|
+
expect(wrapper.emitted("update:modelValue")).toBeTruthy();
|
|
38
|
+
expect(wrapper.emitted("update:modelValue")?.[0]).toEqual([true]);
|
|
26
39
|
});
|
|
27
40
|
|
|
28
|
-
it("
|
|
29
|
-
|
|
30
|
-
modelValue: true,
|
|
31
|
-
color: "green",
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
const dot = wrapper.find(".dot");
|
|
35
|
-
const line = wrapper.find(".line");
|
|
36
|
-
expect((dot.element as HTMLInputElement).className).toContain(
|
|
37
|
-
"translate-x-full bg-green-primary",
|
|
38
|
-
);
|
|
39
|
-
expect((line.element as HTMLInputElement).className).toContain(
|
|
40
|
-
"opacity-50",
|
|
41
|
-
);
|
|
42
|
-
});
|
|
41
|
+
it("emits update:modelValue false when toggled from true", async () => {
|
|
42
|
+
const wrapper = mountToggle({ modelValue: true });
|
|
43
43
|
|
|
44
|
-
|
|
45
|
-
await
|
|
46
|
-
modelValue: true,
|
|
47
|
-
size: "small",
|
|
48
|
-
});
|
|
44
|
+
const input = wrapper.find("[data-testid='toggleButton']");
|
|
45
|
+
await input.setValue(false);
|
|
49
46
|
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
expect((dot.element as HTMLInputElement).className).toContain("h-4 w-4");
|
|
53
|
-
expect((line.element as HTMLInputElement).className).toContain("h-3 w-6");
|
|
47
|
+
expect(wrapper.emitted("update:modelValue")).toBeTruthy();
|
|
48
|
+
expect(wrapper.emitted("update:modelValue")?.[0]).toEqual([false]);
|
|
54
49
|
});
|
|
55
50
|
|
|
56
|
-
it("
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
});
|
|
51
|
+
it("disables the input when disabled prop is set", () => {
|
|
52
|
+
const wrapper = mountToggle({ disabled: true });
|
|
53
|
+
|
|
54
|
+
const input = wrapper.find("[data-testid='toggleButton']");
|
|
61
55
|
|
|
62
|
-
|
|
63
|
-
const line = wrapper.find(".line");
|
|
64
|
-
expect((dot.element as HTMLInputElement).className).toContain("h-6 w-6");
|
|
65
|
-
expect((line.element as HTMLInputElement).className).toContain("h-4 w-10");
|
|
56
|
+
expect((input.element as HTMLInputElement).disabled).toBe(true);
|
|
66
57
|
});
|
|
67
58
|
|
|
68
|
-
it("
|
|
69
|
-
|
|
70
|
-
disabled: true,
|
|
71
|
-
});
|
|
59
|
+
it("does not emit update:modelValue when disabled", async () => {
|
|
60
|
+
const wrapper = mountToggle({ disabled: true, modelValue: false });
|
|
72
61
|
|
|
73
62
|
const input = wrapper.find("[data-testid='toggleButton']");
|
|
74
|
-
|
|
63
|
+
await input.setValue(true);
|
|
64
|
+
|
|
65
|
+
expect(wrapper.emitted("update:modelValue")).toBeFalsy();
|
|
75
66
|
});
|
|
76
67
|
|
|
77
|
-
it("
|
|
78
|
-
const
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
slots: {
|
|
84
|
-
default: "Slot Label",
|
|
85
|
-
},
|
|
86
|
-
});
|
|
87
|
-
expect(wrapperWithSlotContent.text()).toContain("Slot Label");
|
|
68
|
+
it("uses provided id on the input", () => {
|
|
69
|
+
const wrapper = mountToggle({ id: "custom-id" });
|
|
70
|
+
|
|
71
|
+
const input = wrapper.find("[data-testid='toggleButton']");
|
|
72
|
+
|
|
73
|
+
expect(input.attributes("id")).toBe("custom-id");
|
|
88
74
|
});
|
|
89
75
|
});
|
|
@@ -6,46 +6,24 @@ import UiIcon from "../UiIcon/UiIcon.vue";
|
|
|
6
6
|
import UiToggleButton from "./UiToggleButton.vue";
|
|
7
7
|
|
|
8
8
|
const meta = {
|
|
9
|
-
title: "
|
|
9
|
+
title: "forms/UiToggleButton",
|
|
10
10
|
component: UiToggleButton,
|
|
11
11
|
argTypes: {
|
|
12
|
-
color: {
|
|
13
|
-
control: { type: "select" },
|
|
14
|
-
options: ["blue", "green"],
|
|
15
|
-
},
|
|
16
12
|
size: {
|
|
17
13
|
control: { type: "select" },
|
|
18
|
-
options: ["
|
|
14
|
+
options: ["sm", "lg"],
|
|
19
15
|
},
|
|
20
16
|
modelValue: {
|
|
21
17
|
control: "boolean",
|
|
22
18
|
},
|
|
23
|
-
disabled: {
|
|
24
|
-
control: "boolean",
|
|
25
|
-
},
|
|
26
|
-
labelText: {
|
|
27
|
-
control: "text",
|
|
28
|
-
},
|
|
29
|
-
labelSpace: {
|
|
30
|
-
control: "select",
|
|
31
|
-
options: ["default", "xl"],
|
|
32
|
-
},
|
|
33
19
|
labelPosition: {
|
|
34
20
|
control: "select",
|
|
35
21
|
options: ["left", "right"],
|
|
36
22
|
},
|
|
37
|
-
labelTextSize: {
|
|
38
|
-
control: "select",
|
|
39
|
-
options: ["xs", "sm", "md", "lg"],
|
|
40
|
-
},
|
|
41
23
|
},
|
|
42
24
|
args: {
|
|
43
|
-
|
|
44
|
-
size: "small",
|
|
25
|
+
size: "sm",
|
|
45
26
|
modelValue: false,
|
|
46
|
-
disabled: false,
|
|
47
|
-
labelSpace: "default",
|
|
48
|
-
labelTextSize: "xs",
|
|
49
27
|
labelPosition: "left",
|
|
50
28
|
},
|
|
51
29
|
} satisfies Meta<typeof UiToggleButton>;
|
|
@@ -68,36 +46,48 @@ export const Default: Story = {
|
|
|
68
46
|
}),
|
|
69
47
|
};
|
|
70
48
|
|
|
71
|
-
export const
|
|
49
|
+
export const WithIcon: Story = {
|
|
72
50
|
render: (args) => ({
|
|
73
51
|
setup() {
|
|
74
52
|
const isChecked = ref(args.modelValue);
|
|
75
|
-
|
|
76
|
-
|
|
53
|
+
return { args, isChecked };
|
|
54
|
+
},
|
|
55
|
+
components: { UiToggleButton, UiIcon },
|
|
56
|
+
template: `
|
|
57
|
+
<UiToggleButton v-bind="args" v-model="isChecked">
|
|
58
|
+
<div class="flex items-center">
|
|
59
|
+
<UiIcon size="sm" name="flag" />
|
|
60
|
+
<span class="pl-1.5">Label</span></div>
|
|
61
|
+
</UiToggleButton>`,
|
|
62
|
+
}),
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
export const WithoutLabel: Story = {
|
|
66
|
+
render: (args) => ({
|
|
67
|
+
setup() {
|
|
68
|
+
const isChecked = ref(args.modelValue);
|
|
69
|
+
return { args, isChecked };
|
|
77
70
|
},
|
|
78
71
|
components: { UiToggleButton },
|
|
79
72
|
template: `
|
|
80
|
-
<UiToggleButton
|
|
81
|
-
|
|
73
|
+
<UiToggleButton v-bind="args" v-model="isChecked">
|
|
74
|
+
<span class="sr-only">Accessible label</span>
|
|
75
|
+
</UiToggleButton>
|
|
82
76
|
`,
|
|
83
77
|
}),
|
|
84
78
|
};
|
|
85
79
|
|
|
86
|
-
export const
|
|
87
|
-
args: {
|
|
88
|
-
color: "green",
|
|
89
|
-
},
|
|
80
|
+
export const Disabled: Story = {
|
|
90
81
|
render: (args) => ({
|
|
91
82
|
setup() {
|
|
92
83
|
const isChecked = ref(args.modelValue);
|
|
93
84
|
return { args, isChecked };
|
|
94
85
|
},
|
|
95
|
-
components: { UiToggleButton
|
|
86
|
+
components: { UiToggleButton },
|
|
96
87
|
template: `
|
|
97
|
-
<UiToggleButton v-bind="args" v-model="isChecked">
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
</UiToggleButton>`,
|
|
88
|
+
<UiToggleButton v-bind="args" v-model="isChecked" disabled>
|
|
89
|
+
Label
|
|
90
|
+
</UiToggleButton>
|
|
91
|
+
`,
|
|
102
92
|
}),
|
|
103
93
|
};
|
|
@@ -1,76 +1,57 @@
|
|
|
1
1
|
<template>
|
|
2
|
-
<
|
|
3
|
-
|
|
2
|
+
<UiLabel
|
|
3
|
+
:for="toggleId"
|
|
4
|
+
:class="
|
|
5
|
+
cn(
|
|
6
|
+
'inline-flex cursor-pointer gap-2 align-middle leading-4 font-normal text-neutral-emphasis',
|
|
7
|
+
$attrs.class,
|
|
8
|
+
)
|
|
9
|
+
"
|
|
10
|
+
>
|
|
11
|
+
<slot v-if="labelPosition === 'left'" />
|
|
12
|
+
<div class="relative">
|
|
13
|
+
<input
|
|
14
|
+
:id="toggleId"
|
|
15
|
+
v-model="modelValue"
|
|
16
|
+
type="checkbox"
|
|
17
|
+
data-testid="toggleButton"
|
|
18
|
+
role="switch"
|
|
19
|
+
class="sr-only"
|
|
20
|
+
v-bind="{ ...$attrs, class: null }"
|
|
21
|
+
/>
|
|
4
22
|
<div
|
|
5
|
-
|
|
6
|
-
class="whitespace-nowrap"
|
|
23
|
+
class="line rounded-full shadow-inner transition-opacity duration-200 ease-in-out"
|
|
7
24
|
:class="{
|
|
8
|
-
|
|
9
|
-
'
|
|
10
|
-
'
|
|
25
|
+
'bg-secondary opacity-50': modelValue,
|
|
26
|
+
'bg-neutral-faint': !modelValue,
|
|
27
|
+
'h-3 w-6': size === 'sm',
|
|
28
|
+
'h-4 w-10': size === 'lg',
|
|
11
29
|
}"
|
|
12
|
-
|
|
13
|
-
<slot />
|
|
14
|
-
</div>
|
|
30
|
+
/>
|
|
15
31
|
<div
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
:aria-checked="modelValue"
|
|
29
|
-
tabindex="0"
|
|
30
|
-
class="sr-only"
|
|
31
|
-
:disabled="disabled"
|
|
32
|
-
:aria-label="labelText"
|
|
33
|
-
@click="emit('update:modelValue', !modelValue)"
|
|
34
|
-
/>
|
|
35
|
-
<div
|
|
36
|
-
class="line rounded-full shadow-inner transition-opacity duration-200 ease-in-out"
|
|
37
|
-
:class="{
|
|
38
|
-
'opacity-50': modelValue,
|
|
39
|
-
[colorClass]: modelValue,
|
|
40
|
-
'bg-gray-300': !modelValue,
|
|
41
|
-
[lineSize]: true,
|
|
42
|
-
}"
|
|
43
|
-
/>
|
|
44
|
-
<div
|
|
45
|
-
:class="{
|
|
46
|
-
'translate-x-full': modelValue,
|
|
47
|
-
[colorClass]: modelValue,
|
|
48
|
-
'bg-gray-500': !modelValue,
|
|
49
|
-
[dotSize]: true,
|
|
50
|
-
}"
|
|
51
|
-
class="dot absolute -left-1 rounded-full shadow-sm transition-transform duration-200 ease-in-out"
|
|
52
|
-
/>
|
|
53
|
-
</div>
|
|
54
|
-
<div
|
|
55
|
-
v-if="!isLabelPositionLeft && !$slots.default"
|
|
56
|
-
class="leading-4 font-normal whitespace-nowrap text-gray-800"
|
|
57
|
-
:class="[labelSpaceClass, labelTextSizeClass]"
|
|
58
|
-
>
|
|
59
|
-
{{ labelText }}
|
|
60
|
-
</div>
|
|
61
|
-
</UiLabel>
|
|
62
|
-
</div>
|
|
32
|
+
:class="{
|
|
33
|
+
'translate-x-full bg-secondary': modelValue,
|
|
34
|
+
'bg-neutral-muted': !modelValue,
|
|
35
|
+
'-top-0.5 size-4': size === 'sm',
|
|
36
|
+
'-top-1 size-6': size === 'lg',
|
|
37
|
+
}"
|
|
38
|
+
class="dot absolute -left-1 rounded-full shadow-sm transition-transform duration-200 ease-in-out"
|
|
39
|
+
/>
|
|
40
|
+
</div>
|
|
41
|
+
|
|
42
|
+
<slot v-if="labelPosition === 'right'" />
|
|
43
|
+
</UiLabel>
|
|
63
44
|
</template>
|
|
64
45
|
|
|
65
46
|
<script setup lang="ts">
|
|
66
|
-
import {
|
|
67
|
-
import { computed, ref } from "vue";
|
|
47
|
+
import { computed, useId } from "vue";
|
|
68
48
|
|
|
49
|
+
import { cn } from "../../utils/cn.ts";
|
|
69
50
|
import UiLabel from "../UiLabel/UiLabel.vue";
|
|
70
51
|
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
52
|
+
defineOptions({ inheritAttrs: false });
|
|
53
|
+
|
|
54
|
+
const modelValue = defineModel<boolean>({ default: false });
|
|
74
55
|
|
|
75
56
|
defineSlots<{
|
|
76
57
|
/**
|
|
@@ -79,72 +60,16 @@ defineSlots<{
|
|
|
79
60
|
default?: () => any;
|
|
80
61
|
}>();
|
|
81
62
|
|
|
82
|
-
const
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
labelVisible?: boolean;
|
|
92
|
-
color?: "blue" | "green";
|
|
93
|
-
size?: "small" | "large";
|
|
94
|
-
}>(),
|
|
95
|
-
{
|
|
96
|
-
id: undefined,
|
|
97
|
-
modelValue: false,
|
|
98
|
-
disabled: false,
|
|
99
|
-
labelText: "",
|
|
100
|
-
labelTextSize: "xs",
|
|
101
|
-
labelSpace: "default",
|
|
102
|
-
labelPosition: "left",
|
|
103
|
-
labelVisible: true,
|
|
104
|
-
color: "blue",
|
|
105
|
-
size: "small",
|
|
106
|
-
},
|
|
107
|
-
);
|
|
108
|
-
|
|
109
|
-
const toggleId = ref(props.id ?? `toggle-id-${uuidv4()}`);
|
|
110
|
-
|
|
111
|
-
const labelSpaceClass = computed(() => {
|
|
112
|
-
return props.labelPosition === "left"
|
|
113
|
-
? props.labelSpace === "default"
|
|
114
|
-
? "mr-3"
|
|
115
|
-
: "mr-12"
|
|
116
|
-
: props.labelSpace === "default"
|
|
117
|
-
? "ml-3"
|
|
118
|
-
: "ml-12";
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
const labelTextSizeClass = computed(() => {
|
|
122
|
-
switch (props.labelTextSize) {
|
|
123
|
-
case "xs":
|
|
124
|
-
return "text-xs";
|
|
125
|
-
case "sm":
|
|
126
|
-
return "text-sm";
|
|
127
|
-
case "md":
|
|
128
|
-
return "text-md";
|
|
129
|
-
case "lg":
|
|
130
|
-
return "text-lg";
|
|
131
|
-
default:
|
|
132
|
-
return "text-xs";
|
|
133
|
-
}
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
const isLabelPositionLeft = computed(() => {
|
|
137
|
-
return props.labelPosition === "left";
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
const colorClass = computed(() => {
|
|
141
|
-
return props.color === "blue" ? "bg-blue-default" : "bg-green-primary";
|
|
142
|
-
});
|
|
63
|
+
const {
|
|
64
|
+
id = undefined,
|
|
65
|
+
labelPosition = "left",
|
|
66
|
+
size = "sm",
|
|
67
|
+
} = defineProps<{
|
|
68
|
+
id?: string;
|
|
69
|
+
labelPosition?: "left" | "right";
|
|
70
|
+
size?: "sm" | "lg";
|
|
71
|
+
}>();
|
|
143
72
|
|
|
144
|
-
const
|
|
145
|
-
|
|
146
|
-
});
|
|
147
|
-
const dotSize = computed(() => {
|
|
148
|
-
return props.size === "small" ? "h-4 w-4 top-[-2px]" : "h-6 w-6 top-[-4px]";
|
|
149
|
-
});
|
|
73
|
+
const defaultId = useId();
|
|
74
|
+
const toggleId = computed(() => id ?? `id-${defaultId}`);
|
|
150
75
|
</script>
|
|
@@ -5,16 +5,15 @@
|
|
|
5
5
|
```html
|
|
6
6
|
<!-- SomeComponent.vue using UiTooltip -->
|
|
7
7
|
<template>
|
|
8
|
-
<
|
|
9
|
-
<
|
|
10
|
-
<
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
</UiTooltip>
|
|
15
|
-
</div>
|
|
8
|
+
<UiTooltip>
|
|
9
|
+
<template #activator>
|
|
10
|
+
<button>Target</button>
|
|
11
|
+
</template>
|
|
12
|
+
Tooltip Content
|
|
13
|
+
</UiTooltip>
|
|
16
14
|
</template>
|
|
17
15
|
|
|
16
|
+
|
|
18
17
|
<script lang="ts" setup>
|
|
19
18
|
import UiTooltip from "@dpa-id-components/dpa-shared-components";
|
|
20
19
|
</script>
|
|
@@ -24,34 +23,24 @@
|
|
|
24
23
|
|
|
25
24
|
### Props
|
|
26
25
|
|
|
27
|
-
| Name
|
|
28
|
-
|
|
29
|
-
| `position`
|
|
30
|
-
| `
|
|
31
|
-
| `
|
|
32
|
-
| `
|
|
33
|
-
| `
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
"top-start": "scale-95 opacity-0 -translate-y-2 ",
|
|
46
|
-
top: "scale-95 opacity-0 -translate-y-2 ",
|
|
47
|
-
"top-end": "scale-95 opacity-0 -translate-y-2",
|
|
48
|
-
right: "scale-95 opacity-0 translate-x-2",
|
|
49
|
-
"bottom-end": "scale-95 opacity-0 translate-y-2 ",
|
|
50
|
-
bottom: "scale-95 opacity-0 translate-y-2",
|
|
51
|
-
"bottom-start": "scale-95 opacity-0 translate-y-2",
|
|
52
|
-
left: "scale-95 opacity-0 -translate-x-2",
|
|
53
|
-
}
|
|
54
|
-
```
|
|
26
|
+
| Name | Type | Default | Description |
|
|
27
|
+
|---------------------|-----------------------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
|
28
|
+
| `position` | `Placement` | `bottom` | Position of the tooltip relative to the activator slot |
|
|
29
|
+
| `fixed` | `Boolean` | `true` | Whether the tooltip positioning is fixed instead of absolute |
|
|
30
|
+
| `floatingUiOptions` | `UseFloatingOptions` | `null` | Options for [Floating Ui](https://floating-ui.com/) [Interface](https://github.com/floating-ui/floating-ui/blob/afca34cc59321569ccfca9b41934859809c47a3d/packages/vue/src/types.ts#L60) |
|
|
31
|
+
| `animate` | `Boolean` | `false` | Whether the tooltip should be animated |
|
|
32
|
+
| `hidden` | `Boolean` | `false` | Allows you to turn off the tooltip content, useful for scenarios like mobile devices where tooltips may not be needed. |
|
|
33
|
+
|
|
34
|
+
### Attributes
|
|
35
|
+
|
|
36
|
+
### Attributes
|
|
37
|
+
|
|
38
|
+
The `class` attribute is forwarded to the component's root element, so e.g. `<UiTooltip class="mt-4">` styles the outer wrapper (useful for layout or positioning).
|
|
39
|
+
The root element has `inline-block` and `align-middle` as default classes, which can be overridden via `tailwind-merge`.
|
|
40
|
+
|
|
41
|
+
All other attributes (`aria-*`, `data-*`, event listeners, etc.) are forwarded to the inner tooltip content element via `v-bind="$attrs"`.
|
|
42
|
+
|
|
43
|
+
To style the tooltip content itself, wrap the slot content in your own element with the desired classes.
|
|
55
44
|
|
|
56
45
|
|
|
57
46
|
### Slots
|