mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-08 20:38:39 +08:00
f3f1dbf1b1
* chore: move in * wip: refactor the structure of design token * refactor: merge override * chore: mv in * chore: fix ts * chore: tmp all * chore: comment * chore: comment * chore: use variables * fix: compile error Co-authored-by: arvinxx <arvinx@foxmail.com>
163 lines
4.3 KiB
TypeScript
163 lines
4.3 KiB
TypeScript
/* eslint-disable import/prefer-default-export */
|
|
|
|
import { generate } from '@ant-design/colors';
|
|
import { TinyColor } from '@ctrl/tinycolor';
|
|
import type { PresetColorType, SeedToken, DerivativeToken, ColorPalettes } from '../interface';
|
|
|
|
const defaultPresetColors: PresetColorType = {
|
|
blue: '#1890FF',
|
|
purple: '#722ED1',
|
|
cyan: '#13C2C2',
|
|
green: '#52C41A',
|
|
magenta: '#EB2F96',
|
|
pink: '#eb2f96',
|
|
red: '#F5222D',
|
|
orange: '#FA8C16',
|
|
yellow: '#FADB14',
|
|
volcano: '#FA541C',
|
|
geekblue: '#2F54EB',
|
|
gold: '#FAAD14',
|
|
lime: '#A0D911',
|
|
};
|
|
|
|
export function derivative(token: SeedToken): DerivativeToken {
|
|
const {
|
|
colorPrimary,
|
|
colorWarning,
|
|
colorError,
|
|
motionUnit,
|
|
motionBaseStep,
|
|
fontSizeBase,
|
|
sizeUnit,
|
|
sizeBaseStep,
|
|
gridUnit,
|
|
gridBaseStep,
|
|
radiusBase,
|
|
} = token;
|
|
|
|
const primaryColors = generate(colorPrimary);
|
|
const warningColors = generate(colorWarning);
|
|
const errorColors = generate(colorError);
|
|
|
|
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,
|
|
|
|
// motion
|
|
motionDurationBase: `${motionUnit * motionBaseStep}s`,
|
|
motionDurationMd: `${motionUnit * (motionBaseStep - 1)}s`,
|
|
motionDurationFast: `${motionUnit * (motionBaseStep - 2)}s`,
|
|
motionDurationSlow: `${motionUnit * (motionBaseStep + 1)}s`,
|
|
|
|
// font
|
|
fontSize: fontSizeBase,
|
|
fontSizeSM: fontSizeBase - 2,
|
|
fontSizeLG: fontSizeBase + 2,
|
|
fontSizeXL: fontSizeBase + 4,
|
|
|
|
// 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),
|
|
|
|
// radius
|
|
radiusSM: radiusBase / 2,
|
|
radiusLG: radiusBase * 2,
|
|
radiusXL: radiusBase * 4,
|
|
|
|
// color //
|
|
|
|
colorBgBelow: new TinyColor({ h: 0, s: 0, v: 98 }).toHexString(),
|
|
colorBgBelow2: new TinyColor({ h: 0, s: 0, v: 96 }).toHexString(),
|
|
|
|
colorErrorActive: errorColors[6],
|
|
colorErrorHover: errorColors[4],
|
|
colorPrimaryActive: primaryColors[6],
|
|
colorPrimaryHover: primaryColors[4],
|
|
colorWarningActive: warningColors[6],
|
|
colorWarningHover: warningColors[4],
|
|
|
|
// text color
|
|
colorText2: new TinyColor('#000').setAlpha(0.85).toRgbString(),
|
|
|
|
colorTextBelow: new TinyColor('#000').setAlpha(0.45).toRgbString(),
|
|
colorTextBelow2: new TinyColor('#000').setAlpha(0.25).toRgbString(),
|
|
colorTextBelow3: new TinyColor({ h: 0, s: 0, v: 75 }).setAlpha(0.5).toRgbString(),
|
|
|
|
// FIXME: should be currentFontSize + 8
|
|
fontHeight: fontSizeBase + 8,
|
|
};
|
|
}
|
|
|
|
const seedToken: SeedToken = {
|
|
// preset color palettes
|
|
...defaultPresetColors,
|
|
|
|
// Color
|
|
colorPrimary: '#1890ff',
|
|
colorSuccess: '#52c41a',
|
|
colorWarning: '#faad14',
|
|
colorError: '#ff4d4f',
|
|
colorInfo: '#1890ff',
|
|
colorText: new TinyColor('#000').setAlpha(0.85).toRgbString(),
|
|
colorTextLightSolid: '#fff',
|
|
|
|
colorBg: new TinyColor({ h: 0, s: 0, v: 100 }).toHexString(),
|
|
|
|
// Font
|
|
fontFamily: `-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial,
|
|
'Noto Sans', sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol',
|
|
'Noto Color Emoji'`,
|
|
fontSizeBase: 14,
|
|
|
|
// Grid
|
|
gridUnit: 4,
|
|
gridBaseStep: 2,
|
|
|
|
// Line
|
|
lineWidth: 1,
|
|
|
|
// Motion
|
|
motionUnit: 0.1,
|
|
motionBaseStep: 3,
|
|
motionEaseInOutCirc: `cubic-bezier(0.78, 0.14, 0.15, 0.86)`,
|
|
motionEaseInOut: `cubic-bezier(0.645, 0.045, 0.355, 1)`,
|
|
motionEaseOutBack: `cubic-bezier(0.12, 0.4, 0.29, 1.46)`,
|
|
motionEaseInQuint: `cubic-bezier(0.645, 0.045, 0.355, 1)`,
|
|
motionEaseOutQuint: `cubic-bezier(0.23, 1, 0.32, 1)`,
|
|
|
|
// Radius
|
|
radiusBase: 2,
|
|
|
|
// Size
|
|
sizeUnit: 4,
|
|
sizeBaseStep: 4,
|
|
};
|
|
|
|
export default seedToken;
|