20 lines
1.2 KiB
Vue
20 lines
1.2 KiB
Vue
<template>
|
|
<Label class="flex justify-center items-center my-2">{{ label }}
|
|
<SwitchRoot v-model:checked="model" :disabled="disabled"
|
|
class="mx-3 w-12 h-6 select-none transition-colors border border-light-35 dark:border-dark-35 bg-light-20 dark:bg-dark-20 outline-none
|
|
data-[state=checked]:bg-light-35 dark:data-[state=checked]:bg-dark-35 hover:border-light-50 dark:hover:border-dark-50 focus:shadow-raw transition-[box-shadow] focus:shadow-light-40 dark:focus:shadow-dark-40
|
|
data-[disabled]:bg-light-20 dark:data-[disabled]:bg-dark-20 data-[disabled]:border-light-20 dark:data-[disabled]:border-dark-20">
|
|
<SwitchThumb
|
|
class="block w-[18px] h-[18px] translate-x-[2px] will-change-transform transition-transform bg-light-50 dark:bg-dark-50 data-[state=checked]:translate-x-[26px]
|
|
data-[disabled]:bg-light-30 dark:data-[disabled]:bg-dark-30 data-[disabled]:border-light-30 dark:data-[disabled]:border-dark-30" />
|
|
</SwitchRoot>
|
|
</Label>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
const { label, disabled } = defineProps<{
|
|
label?: string
|
|
disabled?: boolean
|
|
}>();
|
|
const model = defineModel<boolean>();
|
|
</script> |