admin-vben/build/config/themeConfig.ts

70 lines
1.7 KiB
TypeScript
Raw Normal View History

2023-03-18 13:10:54 +00:00
import { generate } from '@ant-design/colors'
export const primaryColor = '#0960bd'
export const darkMode = 'light'
type Fn = (...arg: any) => any
type GenerateTheme = 'default' | 'dark'
export interface GenerateColorsParams {
mixLighten: Fn
mixDarken: Fn
tinycolor: any
color?: string
}
export function generateAntColors(color: string, theme: GenerateTheme = 'default') {
return generate(color, {
2023-07-29 10:46:43 +00:00
theme,
2023-03-18 13:10:54 +00:00
})
}
export function getThemeColors(color?: string) {
const tc = color || primaryColor
const lightColors = generateAntColors(tc)
const primary = lightColors[5]
const modeColors = generateAntColors(primary, 'dark')
return [...lightColors, ...modeColors]
}
export function generateColors({ color = primaryColor, mixLighten, mixDarken, tinycolor }: GenerateColorsParams) {
2023-07-29 10:46:43 +00:00
const arr = Array.from({ length: 19 }).fill(0)
2023-03-18 13:10:54 +00:00
const lightens = arr.map((_t, i) => {
return mixLighten(color, i / 5)
})
const darkens = arr.map((_t, i) => {
return mixDarken(color, i / 5)
})
const alphaColors = arr.map((_t, i) => {
return tinycolor(color)
.setAlpha(i / 20)
.toRgbString()
})
2023-07-29 10:46:43 +00:00
const shortAlphaColors = alphaColors.map(item => item.replace(/\s/g, '').replace(/0\./g, '.'))
2023-03-18 13:10:54 +00:00
const tinycolorLightens = arr
.map((_t, i) => {
return tinycolor(color)
.lighten(i * 5)
.toHexString()
})
2023-07-29 10:46:43 +00:00
.filter(item => item !== '#ffffff')
2023-03-18 13:10:54 +00:00
const tinycolorDarkens = arr
.map((_t, i) => {
return tinycolor(color)
.darken(i * 5)
.toHexString()
})
2023-07-29 10:46:43 +00:00
.filter(item => item !== '#000000')
2023-03-18 13:10:54 +00:00
return [...lightens, ...darkens, ...alphaColors, ...shortAlphaColors, ...tinycolorDarkens, ...tinycolorLightens].filter(
2023-07-29 10:46:43 +00:00
item => !item.includes('-'),
2023-03-18 13:10:54 +00:00
)
}