mirror of
https://github.com/antd-tiny-vue/antd-tiny-vue.git
synced 2025-01-26 16:09:08 +08:00
95 lines
3.4 KiB
TypeScript
95 lines
3.4 KiB
TypeScript
/* eslint-disable import/prefer-default-export, prefer-destructuring */
|
|
|
|
import { generate } from '@ant-design/colors'
|
|
import { TinyColor } from '@ctrl/tinycolor'
|
|
import { canUseDom, updateCSS, warning } from '@v-c/utils'
|
|
import type { Theme } from './context'
|
|
|
|
const dynamicStyleMark = `-ant-${Date.now()}-${Math.random()}`
|
|
|
|
export function getStyle(globalPrefixCls: string, theme: Theme) {
|
|
const variables: Record<string, string> = {}
|
|
|
|
const formatColor = (color: TinyColor, updater?: (cloneColor: TinyColor) => TinyColor) => {
|
|
let clone = color.clone()
|
|
clone = updater?.(clone) || clone
|
|
return clone.toRgbString()
|
|
}
|
|
|
|
const fillColor = (colorVal: string, type: string) => {
|
|
const baseColor = new TinyColor(colorVal)
|
|
const colorPalettes = generate(baseColor.toRgbString())
|
|
|
|
variables[`${type}-color`] = formatColor(baseColor)
|
|
variables[`${type}-color-disabled`] = colorPalettes[1]
|
|
variables[`${type}-color-hover`] = colorPalettes[4]
|
|
variables[`${type}-color-active`] = colorPalettes[6]
|
|
variables[`${type}-color-outline`] = baseColor.clone().setAlpha(0.2).toRgbString()
|
|
variables[`${type}-color-deprecated-bg`] = colorPalettes[0]
|
|
variables[`${type}-color-deprecated-border`] = colorPalettes[2]
|
|
}
|
|
|
|
// ================ Primary Color ================
|
|
if (theme.primaryColor) {
|
|
fillColor(theme.primaryColor, 'primary')
|
|
|
|
const primaryColor = new TinyColor(theme.primaryColor)
|
|
const primaryColors = generate(primaryColor.toRgbString())
|
|
|
|
// Legacy - We should use semantic naming standard
|
|
primaryColors.forEach((color, index) => {
|
|
variables[`primary-${index + 1}`] = color
|
|
})
|
|
// Deprecated
|
|
variables['primary-color-deprecated-l-35'] = formatColor(primaryColor, c => c.lighten(35))
|
|
variables['primary-color-deprecated-l-20'] = formatColor(primaryColor, c => c.lighten(20))
|
|
variables['primary-color-deprecated-t-20'] = formatColor(primaryColor, c => c.tint(20))
|
|
variables['primary-color-deprecated-t-50'] = formatColor(primaryColor, c => c.tint(50))
|
|
variables['primary-color-deprecated-f-12'] = formatColor(primaryColor, c => c.setAlpha(c.getAlpha() * 0.12))
|
|
|
|
const primaryActiveColor = new TinyColor(primaryColors[0])
|
|
variables['primary-color-active-deprecated-f-30'] = formatColor(primaryActiveColor, c => c.setAlpha(c.getAlpha() * 0.3))
|
|
variables['primary-color-active-deprecated-d-02'] = formatColor(primaryActiveColor, c => c.darken(2))
|
|
}
|
|
|
|
// ================ Success Color ================
|
|
if (theme.successColor) {
|
|
fillColor(theme.successColor, 'success')
|
|
}
|
|
|
|
// ================ Warning Color ================
|
|
if (theme.warningColor) {
|
|
fillColor(theme.warningColor, 'warning')
|
|
}
|
|
|
|
// ================= Error Color =================
|
|
if (theme.errorColor) {
|
|
fillColor(theme.errorColor, 'error')
|
|
}
|
|
|
|
// ================= Info Color ==================
|
|
if (theme.infoColor) {
|
|
fillColor(theme.infoColor, 'info')
|
|
}
|
|
|
|
// Convert to css variables
|
|
const cssList = Object.keys(variables).map(key => `--${globalPrefixCls}-${key}: ${variables[key]};`)
|
|
|
|
return `
|
|
:root {
|
|
${cssList.join('\n')}
|
|
}
|
|
`.trim()
|
|
}
|
|
|
|
export function registerTheme(globalPrefixCls: string, theme: Theme) {
|
|
const style = getStyle(globalPrefixCls, theme)
|
|
|
|
if (canUseDom()) {
|
|
updateCSS(style, `${dynamicStyleMark}-dynamic-theme`)
|
|
} else {
|
|
// @ts-expect-error this is ssr
|
|
warning(false, 'ConfigProvider', 'SSR do not support dynamic theme with css variables.')
|
|
}
|
|
}
|