You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

120 lines
4.6 KiB

6 months ago
import { defineConfig } from '@unocss/vite'
import presetUno from '@unocss/preset-uno'
import transformerDirectives from '@unocss/transformer-directives'
const directions = ['m', 'ml', 'mr', 'mt', 'mb', 'p', 'pl', 'pr', 'pt', 'pb']
const properties = [
'margin',
'margin-left',
'margin-right',
'margin-top',
'margin-bottom',
'padding',
'padding-left',
'padding-right',
'padding-top',
'padding-bottom',
]
const pmRules = directions.map((direction, index) => {
const regex = new RegExp(`^${direction}-(\\d+)$`)
return [regex, ([, d]) => ({ [properties[index]]: `${parseInt(d)}rpx` })]
})
export default defineConfig({
presets: [presetUno({ dark: 'class' })],
transformers: [transformerDirectives()],
shortcuts: {
'wh-full': 'w-full h-full',
'flex-center': 'flex justify-center items-center',
'flex-between-center': 'flex flex-justify-between items-center',
'flex-between-baseline': 'flex flex-justify-between items-baseline',
'flex-col-center': 'flex-center flex-col',
'flex-x-center': 'flex justify-center',
'flex-y-center': 'flex items-center',
'i-flex-center': 'inline-flex justify-center items-center',
'i-flex-x-center': 'inline-flex justify-center',
'i-flex-y-center': 'inline-flex items-center',
'flex-col': 'flex flex-col',
'flex-col-stretch': 'flex-col items-stretch',
'i-flex-col': 'inline-flex flex-col',
'i-flex-col-stretch': 'i-flex-col items-stretch',
'flex-1-hidden': 'flex-1 overflow-hidden',
'absolute-lt': 'absolute left-0 top-0',
'absolute-lb': 'absolute left-0 bottom-0',
'absolute-rt': 'absolute right-0 top-0',
'absolute-rb': 'absolute right-0 bottom-0',
'absolute-tl': 'absolute-lt',
'absolute-tr': 'absolute-rt',
'absolute-bl': 'absolute-lb',
'absolute-br': 'absolute-rb',
'absolute-center': 'absolute-lt flex-center wh-full',
'fixed-lt': 'fixed left-0 top-0',
'fixed-lb': 'fixed left-0 bottom-0',
'fixed-rt': 'fixed right-0 top-0',
'fixed-rb': 'fixed right-0 bottom-0',
'fixed-tl': 'fixed-lt',
'fixed-tr': 'fixed-rt',
'fixed-bl': 'fixed-lb',
'fixed-br': 'fixed-rb',
'fixed-center': 'fixed-lt flex-center wh-full',
'nowrap-hidden': 'whitespace-nowrap overflow-hidden',
'ellipsis-text': 'nowrap-hidden text-ellipsis',
'transition-base': 'transition-all duration-300 ease-in-out',
'border-d': 'b b-solid b-#ddd',
pointer: 'cursor-pointer',
},
rules: [
...pmRules,
[/^mx-(\d+)$/, ([, d]) => ({ margin: `0 ${parseInt(d)}px` })],
[/^my-(\d+)$/, ([, d]) => ({ margin: `${parseInt(d)}px 0` })],
[/^px-(\d+)$/, ([, d]) => ({ padding: `0 ${parseInt(d)}px` })],
[/^py-(\d+)$/, ([, d]) => ({ padding: `${parseInt(d)}px 0` })],
[/^fs-(\d+)$/, ([, d]) => ({ 'font-size': `${parseInt(d)}px` })],
],
shortcuts: [
{
/*** flex布局 ****/
'flex-center': 'flex items-center justify-center',
'flex-between-center': 'flex items-center justify-between',
'flex-around-center': 'flex items-center justify-around',
'flex-col': 'flex flex-col',
'flex-col-center': 'flex-center flex-col',
'flex-x-center': 'flex justify-center',
'flex-y-center': 'flex items-center',
/***** grid布局 *****/
'grid-column-2': 'grid grid-cols-2 grid-rows-none',
'grid-column-3': 'grid grid-cols-3 grid-rows-none',
'grid-column-4': 'grid grid-cols-4 grid-rows-none',
'grid-column-5': 'grid grid-cols-5 grid-rows-none',
/**** 固定定位 ****/
'abs-lt': 'absolute left-0 top-0',
'abs-lb': 'absolute left-0 bottom-0',
'abs-rt': 'absolute right-0 top-0',
'abs-rb': 'absolute right-0 bottom-0',
'abs-center': 'absolute top-1/2 left-1/2 transform -translate-y-1/2 -translate-x-1/2', //水平垂直都居中的定位
'abs-x-center': 'absolute left-1/2 transform -translate-x-1/2', //水平居中定位
'abs-y-center': 'absolute top-1/2 transform -translate-y-1/2', //垂直居中定位
/*** 固定定位 ****/
'fixed-lt': 'fixed left-0 top-0',
'fixed-lb': 'fixed left-0 bottom-0',
'fixed-rt': 'fixed right-0 top-0',
'fixed-rb': 'fixed right-0 bottom-0',
'transition-base': 'transition-all duration-300 ease-in-out',
/**** 边框 ****/
'base-border': 'b b-solid b-light',
'base-border-b': 'b-b b-b-solid b-b-light',
/****** 渐变色 ******/
'primary-gradient': 'bg-gradient-to-br from-gradient-start to-gradient-end',
/**** 基础背景图 *****/
'base-bg-img': 'bg-cover bg-no-repeat',
},
],
theme: {
colors: {
primary: '#1890FF',
light: '#ffffff',
dark: '#18181c',
},
},
})