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
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',
|
||
|
},
|
||
|
},
|
||
|
})
|