mirror of
https://github.com/chansee97/nova-admin.git
synced 2025-04-05 19:41:59 +08:00
feat: support change multiple colors
This commit is contained in:
parent
6af26f2eab
commit
2882409ce2
@ -53,6 +53,7 @@
|
|||||||
"@tinymce/tinymce-vue": "^5.1.1",
|
"@tinymce/tinymce-vue": "^5.1.1",
|
||||||
"@vueuse/core": "^10.9.0",
|
"@vueuse/core": "^10.9.0",
|
||||||
"alova": "^2.17.1",
|
"alova": "^2.17.1",
|
||||||
|
"chroma-js": "^2.4.2",
|
||||||
"echarts": "^5.5.0",
|
"echarts": "^5.5.0",
|
||||||
"md-editor-v3": "^4.11.3",
|
"md-editor-v3": "^4.11.3",
|
||||||
"nprogress": "^0.2.0",
|
"nprogress": "^0.2.0",
|
||||||
@ -67,6 +68,7 @@
|
|||||||
"@antfu/eslint-config": "^2.8.3",
|
"@antfu/eslint-config": "^2.8.3",
|
||||||
"@iconify-json/icon-park-outline": "^1.1.15",
|
"@iconify-json/icon-park-outline": "^1.1.15",
|
||||||
"@iconify/vue": "^4.1.1",
|
"@iconify/vue": "^4.1.1",
|
||||||
|
"@types/chroma-js": "^2.4.4",
|
||||||
"@types/node": "^20.11.28",
|
"@types/node": "^20.11.28",
|
||||||
"@types/nprogress": "^0.2.3",
|
"@types/nprogress": "^0.2.3",
|
||||||
"@types/qs": "^6.9.12",
|
"@types/qs": "^6.9.12",
|
||||||
|
@ -31,7 +31,7 @@ const appStore = useAppStore()
|
|||||||
:collapsed="appStore.collapsed"
|
:collapsed="appStore.collapsed"
|
||||||
:collapsed-width="64"
|
:collapsed-width="64"
|
||||||
collapse-mode="width"
|
collapse-mode="width"
|
||||||
:width="220"
|
:width="240"
|
||||||
:inverted="appStore.invertedSider"
|
:inverted="appStore.invertedSider"
|
||||||
>
|
>
|
||||||
<Logo v-if="appStore.showLogo" />
|
<Logo v-if="appStore.showLogo" />
|
||||||
|
@ -38,6 +38,38 @@ const transitionSelectorOptions = [
|
|||||||
value: 'fade',
|
value: 'fade',
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|
||||||
|
const palette = [
|
||||||
|
'#ffb8b8',
|
||||||
|
'#d03050',
|
||||||
|
'#F0A020',
|
||||||
|
'#fff200',
|
||||||
|
'#ffda79',
|
||||||
|
'#18A058',
|
||||||
|
'#006266',
|
||||||
|
'#22a6b3',
|
||||||
|
'#18dcff',
|
||||||
|
'#2080F0',
|
||||||
|
'#c56cf0',
|
||||||
|
'#be2edd',
|
||||||
|
'#706fd3',
|
||||||
|
'#4834d4',
|
||||||
|
'#130f40',
|
||||||
|
'#4b4b4b',
|
||||||
|
]
|
||||||
|
|
||||||
|
function resetSetting() {
|
||||||
|
window.$dialog.warning({
|
||||||
|
title: '警告',
|
||||||
|
content: '你确定?',
|
||||||
|
positiveText: '确定',
|
||||||
|
negativeText: '不确定',
|
||||||
|
onPositiveClick: () => {
|
||||||
|
appStore.resetAlltheme()
|
||||||
|
window.$message.success('重置成功')
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
@ -48,7 +80,7 @@ const transitionSelectorOptions = [
|
|||||||
<i-icon-park-outline-setting-two />
|
<i-icon-park-outline-setting-two />
|
||||||
<n-drawer v-model:show="drawerActive" :width="300">
|
<n-drawer v-model:show="drawerActive" :width="300">
|
||||||
<n-drawer-content title="系统设置" closable>
|
<n-drawer-content title="系统设置" closable>
|
||||||
<n-space vertical size="large">
|
<n-space vertical>
|
||||||
<n-divider>主题设置</n-divider>
|
<n-divider>主题设置</n-divider>
|
||||||
<n-space justify="space-between">
|
<n-space justify="space-between">
|
||||||
深色模式
|
深色模式
|
||||||
@ -65,12 +97,37 @@ const transitionSelectorOptions = [
|
|||||||
<n-space align="center" justify="space-between">
|
<n-space align="center" justify="space-between">
|
||||||
主题色
|
主题色
|
||||||
<n-color-picker
|
<n-color-picker
|
||||||
v-model:value="appStore.theme.common.primaryColor" class="w-7em" :swatches="[
|
v-model:value="appStore.primaryColor"
|
||||||
'#18A058',
|
class="w-7em" :swatches="palette" :show-alpha="false"
|
||||||
'#2080F0',
|
@complete="appStore.setPrimaryColor"
|
||||||
'#F0A020',
|
/>
|
||||||
'#d03050',
|
</n-space>
|
||||||
]" :show-alpha="false"
|
<n-space align="center" justify="space-between">
|
||||||
|
提示色
|
||||||
|
<n-color-picker
|
||||||
|
v-model:value="appStore.infoColor"
|
||||||
|
class="w-7em" :swatches="palette" :show-alpha="false" @complete="appStore.setInfoColor"
|
||||||
|
/>
|
||||||
|
</n-space>
|
||||||
|
<n-space align="center" justify="space-between">
|
||||||
|
成功色
|
||||||
|
<n-color-picker
|
||||||
|
v-model:value="appStore.successColor"
|
||||||
|
class="w-7em" :swatches="palette" :show-alpha="false" @complete="appStore.setSuccessColor"
|
||||||
|
/>
|
||||||
|
</n-space>
|
||||||
|
<n-space align="center" justify="space-between">
|
||||||
|
警告色
|
||||||
|
<n-color-picker
|
||||||
|
v-model:value="appStore.warningColor"
|
||||||
|
class="w-7em" :swatches="palette" :show-alpha="false" @complete="appStore.setWarningColor"
|
||||||
|
/>
|
||||||
|
</n-space>
|
||||||
|
<n-space align="center" justify="space-between">
|
||||||
|
错误色
|
||||||
|
<n-color-picker
|
||||||
|
v-model:value="appStore.errorColor"
|
||||||
|
class="w-7em" :swatches="palette" :show-alpha="false" @complete="appStore.setErrorColor"
|
||||||
/>
|
/>
|
||||||
</n-space>
|
</n-space>
|
||||||
<n-space align="center" justify="space-between">
|
<n-space align="center" justify="space-between">
|
||||||
@ -114,7 +171,7 @@ const transitionSelectorOptions = [
|
|||||||
</n-space>
|
</n-space>
|
||||||
|
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<n-button type="error" @click="appStore.resetAlltheme">
|
<n-button type="error" @click="resetSetting">
|
||||||
重置设置
|
重置设置
|
||||||
</n-button>
|
</n-button>
|
||||||
</template>
|
</template>
|
||||||
|
@ -1,10 +1,15 @@
|
|||||||
import type { GlobalThemeOverrides } from 'naive-ui'
|
import type { GlobalThemeOverrides } from 'naive-ui'
|
||||||
|
import chroma from 'chroma-js'
|
||||||
import themeConfig from './theme.json'
|
import themeConfig from './theme.json'
|
||||||
|
|
||||||
type TransitionAnimation = '' | 'fade-slide' | 'fade-bottom' | 'fade-scale' | 'zoom-fade' | 'zoom-out'
|
type TransitionAnimation = '' | 'fade-slide' | 'fade-bottom' | 'fade-scale' | 'zoom-fade' | 'zoom-out'
|
||||||
interface AppStatus {
|
interface AppStatus {
|
||||||
readonly footerText: string
|
|
||||||
theme: GlobalThemeOverrides
|
theme: GlobalThemeOverrides
|
||||||
|
primaryColor: string
|
||||||
|
infoColor: string
|
||||||
|
successColor: string
|
||||||
|
warningColor: string
|
||||||
|
errorColor: string
|
||||||
collapsed: boolean
|
collapsed: boolean
|
||||||
fullScreen: boolean
|
fullScreen: boolean
|
||||||
darkMode: boolean
|
darkMode: boolean
|
||||||
@ -33,8 +38,12 @@ const isDark = useDark({
|
|||||||
export const useAppStore = defineStore('app-store', {
|
export const useAppStore = defineStore('app-store', {
|
||||||
state: (): AppStatus => {
|
state: (): AppStatus => {
|
||||||
return {
|
return {
|
||||||
footerText: 'Copyright ©2023 Nova Admin',
|
|
||||||
theme: themeConfig,
|
theme: themeConfig,
|
||||||
|
primaryColor: '#18a058',
|
||||||
|
infoColor: '#2080f0',
|
||||||
|
successColor: '#18a058',
|
||||||
|
warningColor: '#f0a020',
|
||||||
|
errorColor: '#d03050',
|
||||||
collapsed: false,
|
collapsed: false,
|
||||||
fullScreen: false,
|
fullScreen: false,
|
||||||
darkMode: isDark.value,
|
darkMode: isDark.value,
|
||||||
@ -53,8 +62,95 @@ export const useAppStore = defineStore('app-store', {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
actions: {
|
actions: {
|
||||||
|
// 重置所有设置
|
||||||
resetAlltheme() {
|
resetAlltheme() {
|
||||||
this.$reset()
|
this.theme = themeConfig
|
||||||
|
this.primaryColor = '#18a058'
|
||||||
|
this.infoColor = '#2080f0'
|
||||||
|
this.successColor = '#18a058'
|
||||||
|
this.warningColor = '#f0a020'
|
||||||
|
this.errorColor = '#d03050'
|
||||||
|
this.collapsed = false
|
||||||
|
this.fullScreen = false
|
||||||
|
this.darkMode = isDark.value
|
||||||
|
this.grayMode = false
|
||||||
|
this.colorWeak = false
|
||||||
|
this.loadFlag = true
|
||||||
|
this.showLogo = true
|
||||||
|
this.showTabs = true
|
||||||
|
this.showBreadcrumb = true
|
||||||
|
this.showBreadcrumbIcon = true
|
||||||
|
this.fixedHeader = false
|
||||||
|
this.invertedSider = false
|
||||||
|
this.invertedHeader = false
|
||||||
|
this.showWatermark = false
|
||||||
|
this.transitionAnimation = 'fade-slide'
|
||||||
|
|
||||||
|
// 重置所有配色
|
||||||
|
this.setPrimaryColor(this.primaryColor)
|
||||||
|
this.setInfoColor(this.infoColor)
|
||||||
|
this.setSuccessColor(this.successColor)
|
||||||
|
this.setWarningColor(this.warningColor)
|
||||||
|
this.setErrorColor(this.errorColor)
|
||||||
|
},
|
||||||
|
|
||||||
|
/* 设置主题色 */
|
||||||
|
setPrimaryColor(color: string) {
|
||||||
|
const brightenColor = chroma(color).brighten(1).hex()
|
||||||
|
const darkenColor = chroma(color).darken(1).hex()
|
||||||
|
Object.assign(this.theme.common, {
|
||||||
|
primaryColor: color,
|
||||||
|
primaryColorHover: brightenColor,
|
||||||
|
primaryColorPressed: darkenColor,
|
||||||
|
primaryColorSuppl: brightenColor,
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
/* 设置信息色 */
|
||||||
|
setInfoColor(color: string) {
|
||||||
|
const brightenColor = chroma(color).brighten(1).hex()
|
||||||
|
const darkenColor = chroma(color).darken(1).hex()
|
||||||
|
Object.assign(this.theme.common, {
|
||||||
|
infoColor: color,
|
||||||
|
infoColorHover: brightenColor,
|
||||||
|
infoColorPressed: darkenColor,
|
||||||
|
infoColorSuppl: brightenColor,
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
/* 设置成功色 */
|
||||||
|
setSuccessColor(color: string) {
|
||||||
|
const brightenColor = chroma(color).brighten(1).hex()
|
||||||
|
const darkenColor = chroma(color).darken(1).hex()
|
||||||
|
Object.assign(this.theme.common, {
|
||||||
|
successColor: color,
|
||||||
|
successColorHover: brightenColor,
|
||||||
|
successColorPressed: darkenColor,
|
||||||
|
successColorSuppl: brightenColor,
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
/* 设置警告色 */
|
||||||
|
setWarningColor(color: string) {
|
||||||
|
const brightenColor = chroma(color).brighten(1).hex()
|
||||||
|
const darkenColor = chroma(color).darken(1).hex()
|
||||||
|
Object.assign(this.theme.common, {
|
||||||
|
warningColor: color,
|
||||||
|
warningColorHover: brightenColor,
|
||||||
|
warningColorPressed: darkenColor,
|
||||||
|
warningColorSuppl: brightenColor,
|
||||||
|
})
|
||||||
|
},
|
||||||
|
/* 设置错误色 */
|
||||||
|
setErrorColor(color: string) {
|
||||||
|
const brightenColor = chroma(color).brighten(1).hex()
|
||||||
|
const darkenColor = chroma(color).darken(1).hex()
|
||||||
|
Object.assign(this.theme.common, {
|
||||||
|
errorColor: color,
|
||||||
|
errorColorHover: brightenColor,
|
||||||
|
errorColorPressed: darkenColor,
|
||||||
|
errorColorSuppl: brightenColor,
|
||||||
|
})
|
||||||
},
|
},
|
||||||
/* 切换侧边栏收缩 */
|
/* 切换侧边栏收缩 */
|
||||||
toggleCollapse() {
|
toggleCollapse() {
|
||||||
|
@ -1,5 +1,24 @@
|
|||||||
{
|
{
|
||||||
"common": {
|
"common": {
|
||||||
"primaryColor": "#165DFF"
|
"primaryColor": "#18a058",
|
||||||
|
"primaryColorHover": "#36ad6a",
|
||||||
|
"primaryColorPressed": "#0c7a43",
|
||||||
|
"primaryColorSuppl": "#36ad6a",
|
||||||
|
"infoColor": "#2080f0",
|
||||||
|
"infoColorHover": "#4098fc",
|
||||||
|
"infoColorPressed": "#1060c9",
|
||||||
|
"infoColorSuppl": "#4098fc",
|
||||||
|
"successColor": "#18a058",
|
||||||
|
"successColorHover": "#36ad6a",
|
||||||
|
"successColorPressed": "#0c7a43",
|
||||||
|
"successColorSuppl": "#36ad6a",
|
||||||
|
"warningColor": "#f0a020",
|
||||||
|
"warningColorHover": "#fcb040",
|
||||||
|
"warningColorPressed": "#c97c10",
|
||||||
|
"warningColorSuppl": "#fcb040",
|
||||||
|
"errorColor": "#d03050",
|
||||||
|
"errorColorHover": "#de576d",
|
||||||
|
"errorColorPressed": "#ab1f3f",
|
||||||
|
"errorColorSuppl": "#de576d"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -53,7 +53,7 @@ function handleValidateClick() {
|
|||||||
{{ userInfo?.id }}
|
{{ userInfo?.id }}
|
||||||
</n-descriptions-item>
|
</n-descriptions-item>
|
||||||
<n-descriptions-item label="用户名">
|
<n-descriptions-item label="用户名">
|
||||||
{{ userInfo?.userName }}
|
{{ userInfo?.username }}
|
||||||
</n-descriptions-item>
|
</n-descriptions-item>
|
||||||
<n-descriptions-item label="真实名称">
|
<n-descriptions-item label="真实名称">
|
||||||
{{ userInfo?.nickname }}
|
{{ userInfo?.nickname }}
|
||||||
@ -80,7 +80,7 @@ function handleValidateClick() {
|
|||||||
<n-input v-model:value="formValue.phone" placeholder="电话号码" />
|
<n-input v-model:value="formValue.phone" placeholder="电话号码" />
|
||||||
</n-form-item>
|
</n-form-item>
|
||||||
<n-form-item>
|
<n-form-item>
|
||||||
<n-button attr-type="button" block @click="handleValidateClick">
|
<n-button type="primary" attr-type="button" block @click="handleValidateClick">
|
||||||
验证
|
验证
|
||||||
</n-button>
|
</n-button>
|
||||||
</n-form-item>
|
</n-form-item>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user