Files
ruoyi-plus-vben5/packages/business/universal-ui/src/preferences/blocks/toggle-item.vue

45 lines
1.1 KiB
Vue
Raw Normal View History

2024-05-19 21:20:42 +08:00
<script setup lang="ts">
2024-05-21 22:14:25 +08:00
import type { SelectListItem } from '@vben/types';
2024-05-19 21:20:42 +08:00
import { ToggleGroup, ToggleGroupItem } from '@vben-core/shadcn-ui';
defineOptions({
name: 'PreferenceToggleItem',
});
2024-05-21 23:23:48 +08:00
withDefaults(defineProps<{ disabled?: boolean; items: SelectListItem[] }>(), {
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>
<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>