From de90b07b6faf422b3da5af6e774dce86efe6f4ca Mon Sep 17 00:00:00 2001 From: Li Kui <90845831+likui628@users.noreply.github.com> Date: Fri, 9 Aug 2024 10:52:47 +0800 Subject: [PATCH] fix: menu-badge color not correct (#4089) --- .../base/shared/src/color/convert.test.ts | 19 +++++++++++++++++- .../@core/base/shared/src/color/convert.ts | 20 ++++++++++++++++++- .../src/components/menu-badge/menu-badge.vue | 12 +++++------ 3 files changed, 43 insertions(+), 8 deletions(-) diff --git a/packages/@core/base/shared/src/color/convert.test.ts b/packages/@core/base/shared/src/color/convert.test.ts index f7251888..ee174439 100644 --- a/packages/@core/base/shared/src/color/convert.test.ts +++ b/packages/@core/base/shared/src/color/convert.test.ts @@ -1,6 +1,11 @@ import { describe, expect, it } from 'vitest'; -import { convertToHsl, convertToHslCssVar, convertToRgb } from './convert'; +import { + convertToHsl, + convertToHslCssVar, + convertToRgb, + isValidColor, +} from './convert'; describe('color conversion functions', () => { it('should correctly convert color to HSL format', () => { @@ -39,3 +44,15 @@ describe('color conversion functions', () => { expect(convertToRgb(color)).toEqual(expectedRgba); }); }); + +describe('isValidColor', () => { + it('isValidColor function', () => { + // 测试有效颜色 + expect(isValidColor('blue')).toBe(true); + expect(isValidColor('#000000')).toBe(true); + + // 测试无效颜色 + expect(isValidColor('invalid color')).toBe(false); + expect(isValidColor()).toBe(false); + }); +}); diff --git a/packages/@core/base/shared/src/color/convert.ts b/packages/@core/base/shared/src/color/convert.ts index 5303a6b6..dd7dff20 100644 --- a/packages/@core/base/shared/src/color/convert.ts +++ b/packages/@core/base/shared/src/color/convert.ts @@ -41,4 +41,22 @@ function convertToRgb(str: string): string { return new TinyColor(str.replaceAll(/deg|grad|rad|turn/g, '')).toRgbString(); } -export { convertToHsl, convertToHslCssVar, convertToRgb, TinyColor }; +/** + * 检查颜色是否有效 + * @param {string} color - 待检查的颜色 + * 如果颜色有效返回true,否则返回false + */ +function isValidColor(color?: string) { + if (!color) { + return false; + } + return new TinyColor(color).isValid; +} + +export { + convertToHsl, + convertToHslCssVar, + convertToRgb, + isValidColor, + TinyColor, +}; diff --git a/packages/@core/ui-kit/shadcn-ui/src/components/menu-badge/menu-badge.vue b/packages/@core/ui-kit/shadcn-ui/src/components/menu-badge/menu-badge.vue index fa1e2953..92bac67c 100644 --- a/packages/@core/ui-kit/shadcn-ui/src/components/menu-badge/menu-badge.vue +++ b/packages/@core/ui-kit/shadcn-ui/src/components/menu-badge/menu-badge.vue @@ -3,7 +3,7 @@ import type { MenuRecordBadgeRaw } from '@vben-core/typings'; import { computed } from 'vue'; -import { convertToRgb } from '@vben-core/shared'; +import { isValidColor } from '@vben-core/shared'; import BadgeDot from './menu-badge-dot.vue'; @@ -15,10 +15,10 @@ const props = withDefaults(defineProps(), {}); const variantsMap: Record = { default: 'bg-green-500', - destructive: ' bg-destructive', + destructive: 'bg-destructive', primary: 'bg-primary', - success: ' bg-green-500', - warning: ' bg-yellow-500', + success: 'bg-green-500', + warning: 'bg-yellow-500', }; const isDot = computed(() => props.badgeType === 'dot'); @@ -34,9 +34,9 @@ const badgeClass = computed(() => { }); const badgeStyle = computed(() => { - if (badgeClass.value) { + if (badgeClass.value && isValidColor(badgeClass.value)) { return { - backgroundColor: convertToRgb(badgeClass.value), + backgroundColor: badgeClass.value, }; } return {};