2022-06-21 17:17:19 +08:00
|
|
|
import { generate } from '@ant-design/colors';
|
|
|
|
import { TinyColor } from '@ctrl/tinycolor';
|
2022-06-24 11:11:42 +08:00
|
|
|
import type { ColorPalettes, DerivativeToken, PresetColorType, SeedToken } from '../../interface';
|
|
|
|
import { defaultPresetColors } from '../seed';
|
|
|
|
import { getFontSizes } from '../shared';
|
|
|
|
import { generateBgPalettes, generateTextAlphaPalettes } from './palettes';
|
2022-06-21 17:17:19 +08:00
|
|
|
|
|
|
|
export default function derivative(token: SeedToken): DerivativeToken {
|
|
|
|
const {
|
|
|
|
colorPrimary,
|
|
|
|
colorSuccess,
|
|
|
|
colorWarning,
|
|
|
|
colorError,
|
|
|
|
colorInfo,
|
|
|
|
motionUnit,
|
|
|
|
motionBase,
|
|
|
|
fontSizeBase,
|
|
|
|
sizeUnit,
|
|
|
|
sizeBaseStep,
|
|
|
|
gridUnit,
|
|
|
|
gridBaseStep,
|
|
|
|
radiusBase,
|
|
|
|
controlHeight,
|
|
|
|
lineWidth,
|
|
|
|
} = token;
|
|
|
|
|
|
|
|
const colorPalettes = Object.keys(defaultPresetColors)
|
|
|
|
.map((colorKey: keyof PresetColorType) => {
|
2022-06-24 11:11:42 +08:00
|
|
|
const colors = generate(token[colorKey], { theme: 'dark' });
|
2022-06-21 17:17:19 +08:00
|
|
|
|
|
|
|
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);
|
|
|
|
|
2022-06-24 11:11:42 +08:00
|
|
|
const primaryColors = generate(colorPrimary, { theme: 'dark' });
|
|
|
|
const successColors = generate(colorSuccess, { theme: 'dark' });
|
|
|
|
const warningColors = generate(colorWarning, { theme: 'dark' });
|
|
|
|
const errorColors = generate(colorError, { theme: 'dark' });
|
|
|
|
const infoColors = generate(colorInfo, { theme: 'dark' });
|
|
|
|
const bgColors = generateBgPalettes('#000');
|
|
|
|
const textColors = generateTextAlphaPalettes('#fff');
|
2022-06-21 17:17:19 +08:00
|
|
|
|
2022-06-24 11:11:42 +08:00
|
|
|
const fontSizes = getFontSizes(fontSizeBase);
|
2022-06-21 17:17:19 +08:00
|
|
|
|
|
|
|
return {
|
|
|
|
...token,
|
|
|
|
...colorPalettes,
|
|
|
|
|
|
|
|
// motion
|
|
|
|
motionDurationFast: `${(motionBase + motionUnit * 1).toFixed(1)}s`,
|
|
|
|
motionDurationMid: `${(motionBase + motionUnit * 2).toFixed(1)}s`,
|
|
|
|
motionDurationSlow: `${(motionBase + motionUnit * 3).toFixed(1)}s`,
|
|
|
|
|
|
|
|
// font
|
|
|
|
fontSizes: fontSizes.map(fs => fs.size),
|
|
|
|
lineHeights: fontSizes.map(fs => fs.lineHeight),
|
|
|
|
|
|
|
|
// size
|
|
|
|
sizeSpaceSM: sizeUnit * (sizeBaseStep - 1),
|
|
|
|
sizeSpace: sizeUnit * sizeBaseStep,
|
|
|
|
sizeSpaceXS: sizeUnit * (sizeBaseStep - 2),
|
|
|
|
sizeSpaceXXS: sizeUnit * (sizeBaseStep - 3),
|
|
|
|
|
|
|
|
// grid
|
|
|
|
gridSpaceSM: gridUnit * (gridBaseStep - 1),
|
|
|
|
gridSpaceBase: gridUnit * gridBaseStep,
|
|
|
|
gridSpaceLG: gridUnit * (gridBaseStep + 1),
|
|
|
|
gridSpaceXL: gridUnit * (gridBaseStep + 2),
|
|
|
|
gridSpaceXXL: gridUnit * (gridBaseStep + 5),
|
|
|
|
|
|
|
|
// line
|
|
|
|
lineWidthBold: lineWidth + 1,
|
|
|
|
|
|
|
|
// radius
|
|
|
|
radiusSM: radiusBase / 2,
|
|
|
|
radiusLG: radiusBase * 2,
|
|
|
|
radiusXL: radiusBase * 4,
|
|
|
|
|
2022-06-24 11:11:42 +08:00
|
|
|
colorDefaultOutline: textColors['4'],
|
2022-06-21 17:17:19 +08:00
|
|
|
|
|
|
|
colorPrimaryActive: primaryColors[6],
|
|
|
|
colorPrimaryHover: primaryColors[4],
|
|
|
|
colorPrimaryOutline: new TinyColor(colorPrimary).setAlpha(0.2).toRgbString(),
|
|
|
|
colorPrimarySecondary: primaryColors[2],
|
|
|
|
colorPrimaryBorderHover: primaryColors[3],
|
|
|
|
|
|
|
|
colorSuccessSecondary: successColors[2],
|
2022-06-24 11:11:42 +08:00
|
|
|
colorSuccessBg: successColors[0],
|
2022-06-21 17:17:19 +08:00
|
|
|
|
|
|
|
colorErrorActive: errorColors[6],
|
|
|
|
colorErrorHover: errorColors[4],
|
|
|
|
colorErrorOutline: new TinyColor(colorError).setAlpha(0.2).toRgbString(),
|
|
|
|
colorErrorSecondary: errorColors[2],
|
2022-06-24 11:11:42 +08:00
|
|
|
colorErrorBg: errorColors[0],
|
2022-06-21 17:17:19 +08:00
|
|
|
|
|
|
|
colorWarningActive: warningColors[6],
|
|
|
|
colorWarningHover: warningColors[4],
|
|
|
|
colorWarningOutline: new TinyColor(colorWarning).setAlpha(0.2).toRgbString(),
|
|
|
|
colorWarningSecondary: warningColors[2],
|
2022-06-24 11:11:42 +08:00
|
|
|
colorWarningBg: warningColors[0],
|
2022-06-21 17:17:19 +08:00
|
|
|
|
|
|
|
colorInfoSecondary: infoColors[2],
|
2022-06-24 11:11:42 +08:00
|
|
|
colorInfoBg: infoColors[0],
|
2022-06-21 17:17:19 +08:00
|
|
|
|
|
|
|
colorHighlight: errorColors[4],
|
|
|
|
|
|
|
|
// control
|
|
|
|
controlHeightSM: controlHeight * 0.75,
|
|
|
|
controlHeightXS: controlHeight * 0.5,
|
|
|
|
controlHeightLG: controlHeight * 1.25,
|
2022-06-24 11:11:42 +08:00
|
|
|
|
|
|
|
// map token
|
|
|
|
bgColors,
|
|
|
|
textColors,
|
2022-06-21 17:17:19 +08:00
|
|
|
};
|
|
|
|
}
|