提交 2b95be80 编写于 作者: V vben

fix: fix cssVar hmr error

上级 7692ffb9
...@@ -50,8 +50,11 @@ ...@@ -50,8 +50,11 @@
} }
// collapsed show title end // collapsed show title end
.ant-menu-item,
.ant-menu-submenu-title { .ant-menu-submenu-title {
> .basic-menu__name { > .basic-menu__name {
width: 100%;
.basic-menu__tag { .basic-menu__tag {
float: right; float: right;
margin-top: @app-menu-item-height / 2; margin-top: @app-menu-item-height / 2;
...@@ -62,14 +65,6 @@ ...@@ -62,14 +65,6 @@
.ant-menu-item { .ant-menu-item {
transition: unset; transition: unset;
> .basic-menu__name {
.basic-menu__tag {
float: right;
margin-top: @app-menu-item-height / 2;
transform: translate(0%, -50%);
}
}
} }
&__tag { &__tag {
......
import { ref, Ref, isRef, watch } from '@vue/runtime-dom' // import { ref, Ref, isRef, watch } from '@vue/runtime-dom';
export default function useCssVar( // TODO 打开注释会造成热更新失效,待排查
prop: string, // export default function useCssVar(prop: string, refEl?: Ref<HTMLElement | null>) {
refEl?: Ref<HTMLElement | null> // const refVar = ref('');
) { // let el: HTMLElement = document.documentElement;
const refVar = ref('')
let el: HTMLElement = document.documentElement
if (isRef(refEl)) { // if (isRef(refEl)) {
watch( // watch(
refEl, // refEl,
() => { // () => {
if (refEl.value) { // if (refEl.value) {
el = refEl.value as HTMLElement // el = refEl.value as HTMLElement;
refVar.value = getComputedStyle(el).getPropertyValue(prop) // refVar.value = getComputedStyle(el).getPropertyValue(prop);
} // }
}, // },
{ immediate: true } // { immediate: true }
) // );
} else { // } else {
refVar.value = getComputedStyle(el).getPropertyValue(prop) // refVar.value = getComputedStyle(el).getPropertyValue(prop);
} // }
watch( // watch(
refVar, // refVar,
val => { // (val) => {
el && el.style.setProperty(prop, val) // el && el.style.setProperty(prop, val);
}, // },
{ immediate: true } // { immediate: true }
) // );
return refVar // return refVar;
// }
export function getCssVar(prop: string, dom = document.documentElement) {
return getComputedStyle(dom).getPropertyValue(prop);
}
export function setCssVar(prop: string, val: any, dom = document.documentElement) {
dom.style.setProperty(prop, val);
} }
...@@ -68,7 +68,7 @@ const setting: ProjectConfig = { ...@@ -68,7 +68,7 @@ const setting: ProjectConfig = {
// 是否显示搜索框 // 是否显示搜索框
showSearch: true, showSearch: true,
// 菜单宽度 // 菜单宽度
menuWidth: 200, menuWidth: 210,
// 菜单模式 // 菜单模式
mode: MenuModeEnum.INLINE, mode: MenuModeEnum.INLINE,
// 菜单类型 // 菜单类型
......
import useCssVar from '/@/hooks/web/useCssVar'; import { setCssVar } from '/@/hooks/web/useCssVar';
import { isHexColor, colorIsDark, lighten, darken } from '/@/utils/color'; import { isHexColor, colorIsDark, lighten, darken } from '/@/utils/color';
import { appStore } from '/@/store/modules/app'; import { appStore } from '/@/store/modules/app';
import { MenuThemeEnum } from '/@/enums/menuEnum'; import { MenuThemeEnum } from '/@/enums/menuEnum';
...@@ -29,15 +29,13 @@ export const updateGrayMode = (gray: boolean) => { ...@@ -29,15 +29,13 @@ export const updateGrayMode = (gray: boolean) => {
export function updateHeaderBgColor(color: string) { export function updateHeaderBgColor(color: string) {
if (!isHexColor(color)) return; if (!isHexColor(color)) return;
const bgColorRef = useCssVar(HEADER_BG_COLOR_VAR);
const bgHoverColorRef = useCssVar(HEADER_BG_HOVER_COLOR_VAR);
const topMenuActiveBgColorRef = useCssVar(HEADER_MENU_ACTIVE_BG_COLOR_VAR);
// bg color // bg color
bgColorRef.value = color; setCssVar(HEADER_BG_COLOR_VAR, color);
// hover color // hover color
const hoverColor = lighten(color, 6); const hoverColor = lighten(color, 6);
bgHoverColorRef.value = hoverColor; setCssVar(HEADER_BG_HOVER_COLOR_VAR, hoverColor);
topMenuActiveBgColorRef.value = hoverColor; setCssVar(HEADER_MENU_ACTIVE_BG_COLOR_VAR, hoverColor);
const isDark = colorIsDark(color); const isDark = colorIsDark(color);
...@@ -51,15 +49,11 @@ export function updateHeaderBgColor(color: string) { ...@@ -51,15 +49,11 @@ export function updateHeaderBgColor(color: string) {
export function updateSidebarBgColor(color: string) { export function updateSidebarBgColor(color: string) {
if (!isHexColor(color)) return; if (!isHexColor(color)) return;
const siderBgColor = useCssVar(SIDER_DARK_BG_COLOR); setCssVar(SIDER_DARK_BG_COLOR, color);
const darkenBgColor = useCssVar(SIDER_DARK_DARKEN_BG_COLOR); setCssVar(SIDER_DARK_DARKEN_BG_COLOR, darken(color, 6));
const lighten1Color = useCssVar(SIDER_LIGHTEN_1_BG_COLOR); setCssVar(SIDER_LIGHTEN_1_BG_COLOR, lighten(color, 4));
const lighten2Color = useCssVar(SIDER_LIGHTEN_2_BG_COLOR); setCssVar(SIDER_LIGHTEN_2_BG_COLOR, lighten(color, 8));
siderBgColor.value = color;
darkenBgColor.value = darken(color, 6);
lighten1Color.value = lighten(color, 4);
lighten2Color.value = lighten(color, 8);
// only #ffffff is light // only #ffffff is light
const isLight = ['#fff', '#ffffff'].includes(color.toLowerCase()); const isLight = ['#fff', '#ffffff'].includes(color.toLowerCase());
......
此差异已折叠。
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册