sigma-ui
Version:
CLI for SIGMA-UI components.
16 lines • 1.44 kB
JSON
{
"name": "slider",
"dependencies": [],
"registryDependencies": [],
"files": [
{
"name": "Slider.vue",
"content": "<script setup lang=\"ts\">\nimport type { SliderRootEmits, SliderRootProps } from 'reka-ui';\nimport { SliderRange, SliderRoot, SliderThumb, SliderTrack, useForwardPropsEmits } from 'reka-ui';\nimport { cn } from '@ui/utils';\n\nconst props = defineProps<SliderRootProps>();\nconst emits = defineEmits<SliderRootEmits>();\n\nconst forwarded = useForwardPropsEmits(props, emits);\n</script>\n\n<template>\n <SliderRoot\n v-bind=\"forwarded\"\n :class=\"cn(\n 'relative flex w-full min-w-[50px] touch-none select-none items-center',\n $attrs.class ?? '',\n )\"\n >\n <SliderTrack class=\"relative h-2 w-full grow overflow-hidden rounded-full bg-secondary\">\n <SliderRange class=\"absolute h-full bg-primary\" />\n </SliderTrack>\n <SliderThumb\n v-for=\"(_, key) in modelValue\"\n :key=\"key\"\n class=\"block h-5 w-5 rounded-full border-2 border-primary bg-background ring-offset-background transition-colors focus-visible:outline-hidden focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50\"\n />\n </SliderRoot>\n</template>\n"
},
{
"name": "index.ts",
"content": "export { default as Slider } from './Slider.vue';\n"
}
],
"type": "components:ui"
}