mirror of
https://github.com/antd-tiny-vue/antd-tiny-vue.git
synced 2025-09-10 16:23:17 +08:00
feat: add theme and style
This commit is contained in:
46
components/theme/themes/default/index.ts
Normal file
46
components/theme/themes/default/index.ts
Normal file
@ -0,0 +1,46 @@
|
||||
import { generate } from '@ant-design/colors'
|
||||
import genControlHeight from '../shared/genControlHeight'
|
||||
import genSizeMapToken from '../shared/genSizeMapToken'
|
||||
import type { ColorPalettes, MapToken, PresetColorType, SeedToken } from '../../interface'
|
||||
import { defaultPresetColors } from '../seed'
|
||||
import genColorMapToken from '../shared/genColorMapToken'
|
||||
import genCommonMapToken from '../shared/genCommonMapToken'
|
||||
import genFontMapToken from '../shared/genFontMapToken'
|
||||
import { generateColorPalettes, generateNeutralColorPalettes } from './colors'
|
||||
|
||||
export default function derivative(token: SeedToken): MapToken {
|
||||
const colorPalettes = Object.keys(defaultPresetColors)
|
||||
.map((colorKey: keyof PresetColorType) => {
|
||||
const colors = generate(token[colorKey])
|
||||
|
||||
return new Array(10).fill(1).reduce((prev, _, i) => {
|
||||
prev[`${colorKey}-${i + 1}`] = colors[i]
|
||||
return prev
|
||||
}, {}) as ColorPalettes
|
||||
})
|
||||
.reduce((prev, cur) => {
|
||||
prev = {
|
||||
...prev,
|
||||
...cur
|
||||
}
|
||||
return prev
|
||||
}, {} as ColorPalettes)
|
||||
|
||||
return {
|
||||
...token,
|
||||
...colorPalettes,
|
||||
// Colors
|
||||
...genColorMapToken(token, {
|
||||
generateColorPalettes,
|
||||
generateNeutralColorPalettes
|
||||
}),
|
||||
// Font
|
||||
...genFontMapToken(token.fontSize),
|
||||
// Size
|
||||
...genSizeMapToken(token),
|
||||
// Height
|
||||
...genControlHeight(token),
|
||||
// Others
|
||||
...genCommonMapToken(token)
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user