Files
crater/resources/scripts/components/base/BaseSwitch.vue
2023-03-23 13:18:55 +05:30

57 lines
1.3 KiB
Vue

<template>
<SwitchGroup>
<div class="flex flex-row items-start">
<SwitchLabel v-if="labelLeft" class="mr-4 cursor-pointer">{{
labelLeft
}}</SwitchLabel>
<Switch
v-model="enabled"
:class="enabled ? 'bg-primary-500' : 'bg-gray-300 dark:bg-gray-900'"
class="relative inline-flex items-center h-6 transition-colors rounded-full w-11 focus:outline-none focus:ring-primary-500"
v-bind="$attrs"
>
<span
:class="
enabled
? 'translate-x-6 dark:bg-white'
: 'translate-x-1 dark:bg-gray-500'
"
class="inline-block w-4 h-4 transition-transform bg-white rounded-full"
/>
</Switch>
<SwitchLabel v-if="labelRight" class="ml-4 cursor-pointer">{{
labelRight
}}</SwitchLabel>
</div>
</SwitchGroup>
</template>
<script setup>
import { computed } from 'vue'
import { Switch, SwitchGroup, SwitchLabel } from '@headlessui/vue'
const props = defineProps({
labelLeft: {
type: String,
default: '',
},
labelRight: {
type: String,
default: '',
},
modelValue: {
type: Boolean,
default: false,
},
})
const emit = defineEmits(['update:modelValue'])
const enabled = computed({
get: () => props.modelValue,
set: (value) => emit('update:modelValue', value),
})
</script>