import { reactive, watch } from 'vue'; import { preferences } from '@vben/preferences'; /** * 用于适配各个框架的设计系统 */ export function useAntdDesignTokens() { const rootStyles = getComputedStyle(document.documentElement); const tokens = reactive({ borderRadius: '' as any, colorBgBase: '', colorBgContainer: '', colorBgElevated: '', colorBgLayout: '', colorBgMask: '', colorBorder: '', colorError: '', colorInfo: '', colorPrimary: '', colorSuccess: '', colorTextBase: '', colorWarning: '', }); const getCssVariableValue = (variable: string, isColor: boolean = true) => { const value = rootStyles.getPropertyValue(variable); return isColor ? `hsl(${value})` : value; }; watch( () => preferences.theme, () => { tokens.colorPrimary = getCssVariableValue('--primary'); tokens.colorError = getCssVariableValue('--destructive'); tokens.colorWarning = getCssVariableValue('--warning'); tokens.colorSuccess = getCssVariableValue('--success'); tokens.colorTextBase = getCssVariableValue('--foreground'); getCssVariableValue('--primary-foreground'); tokens.colorBorder = getCssVariableValue('--border'); tokens.colorBgElevated = getCssVariableValue('--popover'); tokens.colorBgContainer = getCssVariableValue('--card'); tokens.colorBgBase = getCssVariableValue('--background'); tokens.borderRadius = getCssVariableValue('--radius', false); tokens.colorBgLayout = getCssVariableValue('--background-deep'); tokens.colorBgMask = getCssVariableValue('--overlay'); }, { immediate: true }, ); return { tokens, }; } export function useNaiveDesignTokens() { const rootStyles = getComputedStyle(document.documentElement); const commonTokens = reactive({ baseColor: '', bodyColor: '', borderColor: '', borderRadius: '', cardColor: '', dividerColor: '', errorColor: '', errorColorHover: '', errorColorPressed: '', errorColorSuppl: '', invertedColor: '', modalColor: '', popoverColor: '', primaryColor: '', primaryColorHover: '', primaryColorPressed: '', primaryColorSuppl: '', successColor: '', successColorHover: '', successColorPressed: '', successColorSuppl: '', tableColor: '', textColorBase: '', warningColor: '', warningColorHover: '', warningColorPressed: '', warningColorSuppl: '', }); const getCssVariableValue = (variable: string, isColor: boolean = true) => { const value = rootStyles.getPropertyValue(variable); return isColor ? `hsl(${value})` : value; }; watch( () => preferences.theme, () => { commonTokens.primaryColor = getCssVariableValue('--primary'); commonTokens.primaryColorHover = getCssVariableValue('--primary-600'); commonTokens.primaryColorPressed = getCssVariableValue('--primary-700'); commonTokens.primaryColorSuppl = getCssVariableValue('--primary-800'); commonTokens.errorColor = getCssVariableValue('--destructive'); commonTokens.errorColorHover = getCssVariableValue('--destructive-600'); commonTokens.errorColorPressed = getCssVariableValue('--destructive-700'); commonTokens.errorColorSuppl = getCssVariableValue('--destructive-800'); commonTokens.warningColor = getCssVariableValue('--warning'); commonTokens.warningColorHover = getCssVariableValue('--warning-600'); commonTokens.warningColorPressed = getCssVariableValue('--warning-700'); commonTokens.warningColorSuppl = getCssVariableValue('--warning-800'); commonTokens.successColor = getCssVariableValue('--success'); commonTokens.successColorHover = getCssVariableValue('--success-600'); commonTokens.successColorPressed = getCssVariableValue('--success-700'); commonTokens.successColorSuppl = getCssVariableValue('--success-800'); commonTokens.textColorBase = getCssVariableValue('--foreground'); commonTokens.baseColor = getCssVariableValue('--primary-foreground'); commonTokens.dividerColor = commonTokens.borderColor = getCssVariableValue('--border'); commonTokens.modalColor = commonTokens.popoverColor = getCssVariableValue('--popover'); commonTokens.tableColor = commonTokens.cardColor = getCssVariableValue('--card'); commonTokens.bodyColor = getCssVariableValue('--background'); commonTokens.invertedColor = getCssVariableValue('--background-deep'); commonTokens.borderRadius = getCssVariableValue('--radius', false); // antDesignTokens.colorBgMask = getCssVariableValue('--overlay'); }, { immediate: true }, ); return { commonTokens, }; } export function useElementPlusDesignTokens() { const rootStyles = getComputedStyle(document.documentElement); const getCssVariableValue = (variable: string, isColor: boolean = true) => { const value = rootStyles.getPropertyValue(variable); return isColor ? `hsl(${value})` : value; }; const el = document.documentElement; watch( () => preferences.theme, () => { el.style.setProperty( '--el-color-primary', getCssVariableValue('--primary'), ); el.style.setProperty( '--el-color-success', getCssVariableValue('--success'), ); el.style.setProperty( '--el-color-warning', getCssVariableValue('--warning'), ); el.style.setProperty( '--el-color-danger', getCssVariableValue('--destructive'), ); el.style.setProperty( '--el-fill-color-blank', getCssVariableValue('--background'), ); el.style.setProperty( '--el-text-color-primary', getCssVariableValue('--foreground'), ); }, { immediate: true }, ); }