2021-02-03 23:52:55 +08:00
|
|
|
import { generate } from '@ant-design/colors';
|
2021-02-05 23:27:42 +08:00
|
|
|
|
2021-02-08 23:59:47 +08:00
|
|
|
export const primaryColor = '#0960bd';
|
2021-02-03 23:52:55 +08:00
|
|
|
|
2021-03-28 11:44:09 +08:00
|
|
|
export const borderColorBase = '#d9d9d9';
|
|
|
|
|
2021-02-03 23:52:55 +08:00
|
|
|
export const themeMode = 'light';
|
|
|
|
|
|
|
|
export type ThemeMode = 'dark' | 'light';
|
|
|
|
|
|
|
|
type Fn = (...arg: any) => any;
|
|
|
|
|
|
|
|
export interface GenerateColorsParams {
|
|
|
|
mixLighten: Fn;
|
|
|
|
mixDarken: Fn;
|
|
|
|
tinycolor: any;
|
|
|
|
color?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function generateAntColors(color: string, mode: ThemeMode) {
|
|
|
|
return generate(color, {
|
|
|
|
theme: mode == 'dark' ? 'dark' : 'default',
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getThemeColors(color?: string, theme?: ThemeMode) {
|
|
|
|
const tc = color || primaryColor;
|
|
|
|
const tm = theme || themeMode;
|
|
|
|
const colors = generateAntColors(tc, tm);
|
|
|
|
const primary = colors[5];
|
|
|
|
const modeColors = generateAntColors(primary, tm === 'dark' ? 'light' : 'dark');
|
|
|
|
|
|
|
|
return [...colors, ...modeColors];
|
|
|
|
}
|
|
|
|
|
|
|
|
export function generateColors({
|
|
|
|
color = primaryColor,
|
|
|
|
mixLighten,
|
|
|
|
mixDarken,
|
|
|
|
tinycolor,
|
|
|
|
}: GenerateColorsParams) {
|
2021-02-04 21:46:35 +08:00
|
|
|
const arr = new Array(19).fill(0);
|
2021-03-18 22:38:36 +08:00
|
|
|
const lightens = arr.map((_t, i) => {
|
2021-02-03 23:52:55 +08:00
|
|
|
return mixLighten(color, i / 5);
|
|
|
|
});
|
|
|
|
|
2021-03-18 22:38:36 +08:00
|
|
|
const darkens = arr.map((_t, i) => {
|
2021-02-03 23:52:55 +08:00
|
|
|
return mixDarken(color, i / 5);
|
|
|
|
});
|
|
|
|
|
2021-03-18 22:38:36 +08:00
|
|
|
const alphaColors = arr.map((_t, i) => {
|
2021-02-03 23:52:55 +08:00
|
|
|
return tinycolor(color)
|
|
|
|
.setAlpha(i / 20)
|
|
|
|
.toRgbString();
|
|
|
|
});
|
|
|
|
|
2021-02-04 21:46:35 +08:00
|
|
|
const tinycolorLightens = arr
|
2021-03-18 22:38:36 +08:00
|
|
|
.map((_t, i) => {
|
2021-02-03 23:52:55 +08:00
|
|
|
return tinycolor(color)
|
|
|
|
.lighten(i * 5)
|
|
|
|
.toHexString();
|
|
|
|
})
|
|
|
|
.filter((item) => item !== '#ffffff');
|
|
|
|
|
2021-02-04 21:46:35 +08:00
|
|
|
const tinycolorDarkens = arr
|
2021-03-18 22:38:36 +08:00
|
|
|
.map((_t, i) => {
|
2021-02-03 23:52:55 +08:00
|
|
|
return tinycolor(color)
|
|
|
|
.darken(i * 5)
|
|
|
|
.toHexString();
|
|
|
|
})
|
|
|
|
.filter((item) => item !== '#000000');
|
|
|
|
return [...lightens, ...darkens, ...alphaColors, ...tinycolorDarkens, ...tinycolorLightens];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* less global variable
|
|
|
|
*/
|
|
|
|
export function generateModifyVars() {
|
|
|
|
const palettes = generateAntColors(primaryColor, themeMode);
|
|
|
|
const primary = palettes[5];
|
|
|
|
|
|
|
|
const primaryColorObj: Record<string, string> = {};
|
|
|
|
|
|
|
|
for (let index = 0; index < 10; index++) {
|
2021-02-07 22:38:18 +08:00
|
|
|
primaryColorObj[`primary-${index + 1}`] = palettes[index];
|
2021-02-03 23:52:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
'primary-color': primary,
|
|
|
|
...primaryColorObj,
|
|
|
|
'info-color': primary,
|
|
|
|
'processing-color': primary,
|
|
|
|
'success-color': '#55D187', // Success color
|
|
|
|
'error-color': '#ED6F6F', // False color
|
|
|
|
'warning-color': '#EFBD47', // Warning color
|
|
|
|
'disabled-color': 'rgba(0, 0, 0, 0.25)', // Failure color
|
|
|
|
'heading-color': 'rgba(0, 0, 0, 0.85)', // Title color
|
|
|
|
'text-color': 'rgba(0, 0, 0, 0.85)', // Main text color
|
2021-02-21 17:56:23 +08:00
|
|
|
'text-color-secondary': 'rgba(0, 0, 0, 0.45)', // Subtext color
|
2021-02-03 23:52:55 +08:00
|
|
|
'font-size-base': '14px', // Main font size
|
|
|
|
'box-shadow-base': '0 2px 8px rgba(0, 0, 0, 0.15)', // Floating shadow
|
2021-03-28 11:44:09 +08:00
|
|
|
'border-color-base': borderColorBase, // Border color,
|
2021-02-03 23:52:55 +08:00
|
|
|
'border-radius-base': '2px', // Component/float fillet
|
|
|
|
'link-color': primary, // Link color
|
|
|
|
};
|
|
|
|
}
|