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.
119 lines
4.6 KiB
119 lines
4.6 KiB
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', |
|
}, |
|
}, |
|
});
|
|
|