@indielayer/ui
Version:
Indielayer UI Components with Tailwind CSS build for Vue 3
59 lines (41 loc) • 1.9 kB
text/typescript
import { type SelectTheme } from '../Select.vue'
const theme: SelectTheme = {
classes: {
wrapper: '',
box: ({ props, data }) => {
const classes = ['w-full border-b text-sm px-4 border-secondary-300 dark:border-secondary-700 pr-8 outline-transparent outline outline-2 outline-offset-[-1px] transition-all duration-150 ease-in-out']
if (!data.errorInternal && !props.disabled) classes.push('hover:border-secondary-400 dark:hover:border-secondary-500')
if (props.size === 'xs' || props.size === 'sm') classes.push('py-1.5')
else if (props.size === 'lg' || props.size === 'xl') classes.push('py-3.5')
else classes.push('py-2.5')
if (props.disabled) {
classes.push('bg-secondary-100 dark:bg-secondary-900 text-secondary-300 cursor-not-allowed')
} else if (props.readonly) {
classes.push('bg-white dark:bg-secondary-900 text-secondary-700')
} else {
classes.push('bg-secondary-50 dark:bg-secondary-800 text-secondary-700 dark:text-secondary-200')
}
if (data.errorInternal) {
classes.push('border-error-500 dark:border-error-400 group-focus:outline-error-500')
} else if (!props.disabled) {
classes.push('group-focus:outline-[color:var(--x-select-border)]')
}
return classes
},
content: 'p-1',
search: 'p-1 mb-0.5',
contentBody: 'overflow-y-auto max-h-64',
iconWrapper: 'pointer-events-none absolute inset-y-0 right-0 flex items-center px-2',
icon: ({ props }) => {
const classes = ['h-5 w-5']
if (props.disabled) classes.push('text-secondary-300 dark:text-secondary-500')
else classes.push('text-secondary-500 dark:text-secondary-400')
return classes
},
},
styles: ({ colors, css }) => {
const color = colors.getPalette('primary')
return css.get('border', color[500])
},
}
export default theme