From 99bc8177d4af2804e455c6e4edb12a0225718f3d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=98=AD?= <81747598+lan-yonghui@users.noreply.github.com> Date: Fri, 10 Jan 2025 12:13:44 +0800 Subject: [PATCH] feat: Save custom theme color scheme (#7690) --- frontend/src/views/setting/panel/index.vue | 10 +++++-- .../views/setting/panel/theme-color/index.vue | 28 ++++++++++++++----- 2 files changed, 29 insertions(+), 9 deletions(-) diff --git a/frontend/src/views/setting/panel/index.vue b/frontend/src/views/setting/panel/index.vue index 2dd729162..ba846bf42 100644 --- a/frontend/src/views/setting/panel/index.vue +++ b/frontend/src/views/setting/panel/index.vue @@ -252,6 +252,10 @@ const mobile = computed(() => { interface ThemeColor { light: string; dark: string; + themePredefineColors: { + light: string[]; + dark: string[]; + }; } const form = reactive({ @@ -366,8 +370,10 @@ const search = async () => { const xpackRes = await getXpackSetting(); if (xpackRes) { form.theme = xpackRes.data.theme || globalStore.themeConfig.theme || 'light'; - form.themeColor = JSON.parse(xpackRes.data.themeColor); - globalStore.themeConfig.themeColor = xpackRes.data.themeColor; + form.themeColor = JSON.parse(xpackRes.data.themeColor || '{"light":"#005eeb","dark":"#F0BE96"}'); + globalStore.themeConfig.themeColor = xpackRes.data.themeColor + ? xpackRes.data.themeColor + : '{"light":"#005eeb","dark":"#F0BE96"}'; globalStore.themeConfig.theme = form.theme; form.proxyDocker = xpackRes.data.proxyDocker; } diff --git a/frontend/src/views/setting/panel/theme-color/index.vue b/frontend/src/views/setting/panel/theme-color/index.vue index 22e2893cc..1da11fa0a 100644 --- a/frontend/src/views/setting/panel/theme-color/index.vue +++ b/frontend/src/views/setting/panel/theme-color/index.vue @@ -94,13 +94,24 @@ const drawerVisible = ref(); const loading = ref(); interface DialogProps { - themeColor: { light: string; dark: string }; + themeColor: { + light: string; + dark: string; + themePredefineColors: { + light: string[]; + dark: string[]; + }; + }; theme: ''; } interface ThemeColor { light: string; dark: string; + themePredefineColors: { + light: string[]; + dark: string[]; + }; } const form = reactive({ @@ -124,6 +135,7 @@ const lightPredefineColors = ref([ '#ff4500', '#ff8c00', '#ffd700', + '#333539', ]); const darkPredefineColors = ref([ '#238636', @@ -135,6 +147,7 @@ const darkPredefineColors = ref([ '#ff4500', '#ff8c00', '#ffd700', + '#333539', ]); const defaultDarkColors = [ @@ -191,9 +204,13 @@ const acceptParams = (params: DialogProps): void => { form.theme = params.theme; form.dark = form.themeColor.dark; form.light = form.themeColor.light; + if (form.themeColor.themePredefineColors) { + localStorage.setItem(STORAGE_KEY, JSON.stringify(form.themeColor.themePredefineColors)); + } initThemeColors(); lightPredefineColors.value = themeColors.value['light']; darkPredefineColors.value = themeColors.value['dark']; + lightColors = defaultLightColors; lightPredefineColors.value.slice(0, 2).forEach((color) => { const exists = lightColors.some((item) => item.color === color); if (!exists) { @@ -203,6 +220,7 @@ const acceptParams = (params: DialogProps): void => { }); } }); + darkColors = defaultDarkColors; darkPredefineColors.value.slice(0, 2).forEach((color) => { const exists = darkColors.some((item) => item.color === color); if (!exists) { @@ -259,7 +277,7 @@ const onSave = async (formEl: FormInstance | undefined) => { }).then(async () => { await formEl.validate(async (valid) => { if (!valid) return; - form.themeColor = { light: form.light, dark: form.dark }; + form.themeColor = { light: form.light, dark: form.dark, themePredefineColors: themeColors.value }; if (globalStore.isProductPro) { await updateXpackSettingByKey('ThemeColor', JSON.stringify(form.themeColor)); MsgSuccess(i18n.global.t('commons.msg.operationSuccess')); @@ -288,12 +306,8 @@ const onReSet = async () => { cancelButtonText: i18n.global.t('commons.button.cancel'), type: 'info', }).then(async () => { - form.themeColor = { light: '#005eeb', dark: '#F0BE96' }; + form.themeColor = { light: '#005eeb', dark: '#F0BE96', themePredefineColors: themeColors.value }; if (globalStore.isProductPro) { - localStorage.setItem(STORAGE_KEY, JSON.stringify(defaultColors)); - themeColors.value = { ...defaultColors }; - darkColors = [...defaultDarkColors]; - lightColors = [...defaultLightColors]; await updateXpackSettingByKey('ThemeColor', JSON.stringify(form.themeColor)); MsgSuccess(i18n.global.t('commons.msg.operationSuccess')); loading.value = false;