primevue-mirror/apps/labs/plex/selectbutton/index.vue

40 lines
1.8 KiB
Vue

<template>
<SelectButton unstyled :pt="theme">
<template v-for="(_, slotName) in $slots" v-slot:[slotName]="slotProps">
<slot :name="slotName" v-bind="slotProps ?? {}" />
</template>
</SelectButton>
</template>
<script setup>
import SelectButton from 'primevue/selectbutton';
import { ref } from 'vue';
const theme = ref({
root: `inline-flex select-none rounded-md
p-invalid:outline p-invalid:outline-offset-0 p-invalid:outline-red-400 dark:p-invalid:outline-red-300`,
pcToggleButton: {
root: `inline-flex items-center justify-center overflow-hidden relative cursor-pointer select-none
border border-surface-100 dark:border-surface-950
rounded-none first:rounded-s-md last:rounded-e-md
bg-surface-100 dark:bg-surface-950
text-surface-500 dark:text-surface-400
p-checked:text-surface-700 dark:p-checked:text-surface-0
text-base font-medium
focus-visible:outline focus-visible:outline-1 focus-visible:outline-offset-2 focus-visible:outline-primary focus-visible:relative focus-visible:z-10
disabled:cursor-default
disabled:bg-surface-200 disabled:border-surface-200 disabled:text-surface-500
disabled:dark:bg-surface-700 disabled:dark:border-surface-700 disabled:dark:text-surface-400
p-invalid:border-red-400 dark:p-invalid:border-red-300
transition-colors duration-200
p-1 p-small:text-sm p-large:text-lg
`,
content: `relative flex-auto inline-flex items-center justify-center gap-2 py-1 px-3
rounded-md transition-colors duration-200
p-checked:bg-surface-0 dark:p-checked:bg-surface-800 p-checked:shadow-[0px_1px_2px_0px_rgba(0,0,0,0.02),0px_1px_2px_0px_rgba(0,0,0,0.04)]`,
icon: ``,
label: ``
}
});
</script>