Files
ruoyi-plus-vben5/packages/effects/layouts/src/widgets/preferences/blocks/toggle-item.vue

47 lines
1.1 KiB
Vue
Raw Normal View History

2024-05-19 21:20:42 +08:00
<script setup lang="ts">
import type { SelectOption } from '@vben/types';
2024-05-19 21:20:42 +08:00
import { ToggleGroup, ToggleGroupItem } from '@vben-core/shadcn-ui';
defineOptions({
name: 'PreferenceToggleItem',
});
withDefaults(defineProps<{ disabled?: boolean; items: SelectOption[] }>(), {
2024-05-19 21:20:42 +08:00
disabled: false,
items: () => [],
});
const modelValue = defineModel<string>();
</script>
<template>
<div
:class="{
'pointer-events-none opacity-50': disabled,
}"
2024-06-09 13:31:43 +08:00
class="hover:bg-accent flex w-full items-center justify-between rounded-md px-2 py-2"
disabled
2024-05-19 21:20:42 +08:00
>
<span class="text-sm">
<slot></slot>
</span>
2024-05-19 21:20:42 +08:00
<ToggleGroup
v-model="modelValue"
2024-06-09 13:31:43 +08:00
class="gap-2"
size="sm"
2024-05-19 21:20:42 +08:00
type="single"
variant="outline"
>
<template v-for="item in items" :key="item.value">
<ToggleGroupItem
:value="item.value"
class="data-[state=on]:bg-primary data-[state=on]:text-primary-foreground h-7 rounded-sm"
>
{{ item.label }}
</ToggleGroupItem>
</template>
</ToggleGroup>
</div>
</template>