mirror of
https://github.com/jeecgboot/JeecgBoot.git
synced 2025-12-08 17:12:28 +08:00
80 lines
1.9 KiB
Vue
80 lines
1.9 KiB
Vue
import { generate } from '@ant-design/colors';
|
||
import setting from '/@/settings/projectSetting';
|
||
|
||
// 代码逻辑说明: 【JHHB-579】去掉写死的主题色,根据导航栏模式确定主题色
|
||
export const primaryColor = setting.themeColor;
|
||
export const darkMode = setting.themeMode;
|
||
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, {
|
||
theme,
|
||
});
|
||
}
|
||
|
||
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) {
|
||
const arr = new Array(19).fill(0);
|
||
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();
|
||
});
|
||
|
||
const shortAlphaColors = alphaColors.map((item) => item.replace(/\s/g, '').replace(/0\./g, '.'));
|
||
|
||
const tinycolorLightens = arr
|
||
.map((_t, i) => {
|
||
return tinycolor(color)
|
||
.lighten(i * 5)
|
||
.toHexString();
|
||
})
|
||
.filter((item) => item !== '#ffffff');
|
||
|
||
const tinycolorDarkens = arr
|
||
.map((_t, i) => {
|
||
return tinycolor(color)
|
||
.darken(i * 5)
|
||
.toHexString();
|
||
})
|
||
.filter((item) => item !== '#000000');
|
||
return [
|
||
...lightens,
|
||
...darkens,
|
||
...alphaColors,
|
||
...shortAlphaColors,
|
||
...tinycolorDarkens,
|
||
...tinycolorLightens,
|
||
].filter((item) => !item.includes('-'));
|
||
}
|