修改主题
This commit is contained in:
34
src/api/system/subject/index.ts
Normal file
34
src/api/system/subject/index.ts
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
import createAxios from '@/utils/request'
|
||||||
|
|
||||||
|
//激活主题
|
||||||
|
export function activateTheme(params: String) {
|
||||||
|
return createAxios({
|
||||||
|
url: '/system-boot/theme/activateTheme',
|
||||||
|
method: 'PUT',
|
||||||
|
params: params
|
||||||
|
})
|
||||||
|
}
|
||||||
|
//删除主题
|
||||||
|
export function deleteTheme(params: String) {
|
||||||
|
return createAxios({
|
||||||
|
url: '/system-boot/theme/deleteTheme',
|
||||||
|
method: 'DELETE',
|
||||||
|
params: params
|
||||||
|
})
|
||||||
|
}
|
||||||
|
//新增主题
|
||||||
|
export function addTheme(data: anyObj) {
|
||||||
|
return createAxios({
|
||||||
|
url: '/system-boot/theme/addTheme',
|
||||||
|
method: 'POST',
|
||||||
|
data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
//修改主题
|
||||||
|
export function updateTheme(data: anyObj) {
|
||||||
|
return createAxios({
|
||||||
|
url: '/system-boot/theme/updateTheme',
|
||||||
|
method: 'PUT',
|
||||||
|
data
|
||||||
|
})
|
||||||
|
}
|
||||||
@@ -23,4 +23,9 @@ export function delMenu(id: string) {
|
|||||||
method: 'delete'
|
method: 'delete'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
export function getTheme() {
|
||||||
|
return createAxios({
|
||||||
|
url: '/system-boot/theme/getTheme',
|
||||||
|
method: 'get'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|||||||
@@ -3,22 +3,22 @@
|
|||||||
<el-scrollbar>
|
<el-scrollbar>
|
||||||
<el-form :inline="false" :model="form" label-width="120px">
|
<el-form :inline="false" :model="form" label-width="120px">
|
||||||
<el-form-item label="用户名称:">
|
<el-form-item label="用户名称:">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.name" :disabled="true"></el-input>
|
<el-input v-model="form.name" :disabled="true"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="登录名称:" class="top">
|
<el-form-item label="登录名称:" class="top">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.loginName" :disabled="true"></el-input>
|
<el-input v-model="form.loginName" :disabled="true"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="归属部门名称:" class="top">
|
<el-form-item label="归属部门名称:" class="top">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.deptName" :disabled="true"></el-input>
|
<el-input v-model="form.deptName" :disabled="true"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="拥有的角色:" class="top">
|
<el-form-item label="拥有的角色:" class="top">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.role" :disabled="true"></el-input>
|
<el-input v-model="form.role" :disabled="true"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="电话号码:" class="top">
|
<el-form-item label="电话号码:" class="top">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.phone" :disabled="true"></el-input>
|
<el-input v-model="form.phone" :disabled="true"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="电子邮箱:" class="top">
|
<el-form-item label="电子邮箱:" class="top">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.email" :disabled="true"></el-input>
|
<el-input v-model="form.email" :disabled="true"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
</el-scrollbar>
|
</el-scrollbar>
|
||||||
|
|||||||
@@ -3,15 +3,15 @@
|
|||||||
<el-scrollbar>
|
<el-scrollbar>
|
||||||
<el-form :inline="false" :model="form" label-width="120px" :rules="rules" ref="formRef">
|
<el-form :inline="false" :model="form" label-width="120px" :rules="rules" ref="formRef">
|
||||||
<el-form-item label="校验密码:" prop="password">
|
<el-form-item label="校验密码:" prop="password">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.password" type="password"
|
<el-input v-model="form.password" type="password"
|
||||||
placeholder="请输入校验密码" show-password />
|
placeholder="请输入校验密码" show-password />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="新密码:" prop="newPwd" style="margin-top: 20px">
|
<el-form-item label="新密码:" prop="newPwd" style="margin-top: 20px">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.newPwd" type="password" placeholder="请输入新密码"
|
<el-input v-model="form.newPwd" type="password" placeholder="请输入新密码"
|
||||||
show-password />
|
show-password />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="确认密码:" prop="confirmPwd" style="margin-top: 20px">
|
<el-form-item label="确认密码:" prop="confirmPwd" style="margin-top: 20px">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.confirmPwd" type="password"
|
<el-input v-model="form.confirmPwd" type="password"
|
||||||
placeholder="请输入确认密码" show-password />
|
placeholder="请输入确认密码" show-password />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
|
|||||||
@@ -13,10 +13,10 @@
|
|||||||
<IconSelector v-model="form.icon" placeholder="请选择图标" />
|
<IconSelector v-model="form.icon" placeholder="请选择图标" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="菜单路由">
|
<el-form-item label="菜单路由">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.path" placeholder="请输入菜单名称" />
|
<el-input v-model="form.path" placeholder="请输入菜单名称" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="组件路径">
|
<el-form-item label="组件路径">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.routeName"
|
<el-input v-model="form.routeName"
|
||||||
placeholder="请输入组件路径,如/src/views/dashboard/index.vue" />
|
placeholder="请输入组件路径,如/src/views/dashboard/index.vue" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="排序">
|
<el-form-item label="排序">
|
||||||
|
|||||||
@@ -825,12 +825,12 @@ const getRealDataMqttMsg = async () => {
|
|||||||
...obj,
|
...obj,
|
||||||
// 电压有效值
|
// 电压有效值
|
||||||
vRmsA: ((obj.vRmsA * obj.pt)) / 1000,
|
vRmsA: ((obj.vRmsA * obj.pt)) / 1000,
|
||||||
vRmsB: ((obj.vRmsA * obj.pt)) / 1000,
|
vRmsB: ((obj.vRmsB * obj.pt)) / 1000,
|
||||||
vRmsC: ((obj.vRmsA * obj.pt)) / 1000,
|
vRmsC: ((obj.vRmsC * obj.pt)) / 1000,
|
||||||
// 电流有效值
|
// 电流有效值
|
||||||
iRmsA: (obj.iRmsA * obj.ct),
|
iRmsA: (obj.iRmsA * obj.ct),
|
||||||
iRmsB: (obj.iRmsA * obj.ct),
|
iRmsB: (obj.iRmsB * obj.ct),
|
||||||
iRmsC: (obj.iRmsA * obj.ct),
|
iRmsC: (obj.iRmsC * obj.ct),
|
||||||
//基波电压幅值
|
//基波电压幅值
|
||||||
v1A: ((obj.v1A * obj.pt)) / 1000,
|
v1A: ((obj.v1A * obj.pt)) / 1000,
|
||||||
v1B: ((obj.v1B * obj.pt)) / 1000,
|
v1B: ((obj.v1B * obj.pt)) / 1000,
|
||||||
@@ -862,12 +862,12 @@ const getRealDataMqttMsg = async () => {
|
|||||||
...obj,
|
...obj,
|
||||||
// 电压有效值
|
// 电压有效值
|
||||||
vRmsA: (obj.vRmsA / obj.pt) * 1000,
|
vRmsA: (obj.vRmsA / obj.pt) * 1000,
|
||||||
vRmsB: (obj.vRmsA / obj.pt) * 1000,
|
vRmsB: (obj.vRmsB / obj.pt) * 1000,
|
||||||
vRmsC: (obj.vRmsA / obj.pt) * 1000,
|
vRmsC: (obj.vRmsC / obj.pt) * 1000,
|
||||||
// 电流有效值
|
// 电流有效值
|
||||||
iRmsA: obj.iRmsA / obj.ct,
|
iRmsA: obj.iRmsA / obj.ct,
|
||||||
iRmsB: obj.iRmsA / obj.ct,
|
iRmsB: obj.iRmsB / obj.ct,
|
||||||
iRmsC: obj.iRmsA / obj.ct,
|
iRmsC: obj.iRmsC / obj.ct,
|
||||||
//基波电压幅值
|
//基波电压幅值
|
||||||
v1A: (obj.v1A / obj.pt) * 1000,
|
v1A: (obj.v1A / obj.pt) * 1000,
|
||||||
v1B: (obj.v1B / obj.pt) * 1000,
|
v1B: (obj.v1B / obj.pt) * 1000,
|
||||||
|
|||||||
@@ -33,18 +33,22 @@ const column: any = ref([
|
|||||||
{ field: 'startTime', title: '数据起始时间', width: '140px', sortable: true },
|
{ field: 'startTime', title: '数据起始时间', width: '140px', sortable: true },
|
||||||
{ field: 'endTime', title: '数据结束时间', width: '140px', sortable: true },
|
{ field: 'endTime', title: '数据结束时间', width: '140px', sortable: true },
|
||||||
{ field: 'itemName', title: '数据来源', width: '100px' },
|
{ field: 'itemName', title: '数据来源', width: '100px' },
|
||||||
{ field: 'statisticalInterval', title: '统计间隔', width: '100px', },
|
{ field: 'statisticalInterval', title: '时间间隔(分钟)', width: '120px', },
|
||||||
{ field: '', title: '时间间隔', width: '140px', },
|
|
||||||
{ field: 'voltageLevel', title: '电压等级', width: '100px', sortable: true },
|
{ field: 'voltageLevel', title: '电压等级', width: '100px', sortable: true },
|
||||||
{ field: 'volConType', title: ' 电压接线方式', width: '100px', sortable: true },
|
|
||||||
|
{ field: 'volConType', title: ' 电压接线方式', width: '120px', sortable: true },
|
||||||
|
{
|
||||||
|
field: 'pt', title: 'PT变比', width: '100px',
|
||||||
|
},
|
||||||
|
{ field: 'ct', title: 'CT变比', width: '100px', },
|
||||||
{ field: 'capacitySi', title: '用户协议容量(MVA)', width: '140px', },
|
{ field: 'capacitySi', title: '用户协议容量(MVA)', width: '140px', },
|
||||||
|
{ field: 'capacitySt', title: '供电设备容量(MVA)', width: '140px', },
|
||||||
{ field: 'capacitySscb', title: '基准短路容量(MVA)', width: '140px', },
|
{ field: 'capacitySscb', title: '基准短路容量(MVA)', width: '140px', },
|
||||||
{ field: 'capacitySscmin', title: '最小短路容量(MVA)', width: '140px', },
|
{ field: 'capacitySscmin', title: '最小短路容量(MVA)', width: '140px', },
|
||||||
{ field: 'capacitySt', title: '供电设备容量(MVA)', width: '140px', },
|
|
||||||
{ field: 'location', title: ' 测试位置', width: '100px', },
|
{ field: 'location', title: ' 测试位置', width: '100px', },
|
||||||
|
|
||||||
{ field: 'ct', title: 'CT', width: '70px', },
|
|
||||||
{ field: 'pt', title: 'PT', width: '70px', },
|
|
||||||
|
|
||||||
])
|
])
|
||||||
const setData = (data: any) => {
|
const setData = (data: any) => {
|
||||||
@@ -54,6 +58,10 @@ const setData = (data: any) => {
|
|||||||
const formatter = (row: any) => {
|
const formatter = (row: any) => {
|
||||||
if (row.column.field == 'voltageLevel') {
|
if (row.column.field == 'voltageLevel') {
|
||||||
return row.cellValue == null ? '/' : voltageLevelList.filter((item: any) => item.id == row.cellValue)[0]?.name
|
return row.cellValue == null ? '/' : voltageLevelList.filter((item: any) => item.id == row.cellValue)[0]?.name
|
||||||
|
} else if (row.column.field == 'pt') {
|
||||||
|
return row.row.pt == null ? '/' : (row.row.pt + '/' + row.row.pt1)
|
||||||
|
} else if (row.column.field == 'ct') {
|
||||||
|
return row.row.ct == null ? '/' : (row.row.ct + '/' + row.row.ct1)
|
||||||
} else if (row.column.field == 'volConType') {
|
} else if (row.column.field == 'volConType') {
|
||||||
return row.cellValue == null ? '/' : volConTypeList.filter((item: any) => item.id == row.cellValue)[0]?.name
|
return row.cellValue == null ? '/' : volConTypeList.filter((item: any) => item.id == row.cellValue)[0]?.name
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
236
src/views/system/subject/form/index.vue
Normal file
236
src/views/system/subject/form/index.vue
Normal file
@@ -0,0 +1,236 @@
|
|||||||
|
<template>
|
||||||
|
<el-dialog draggable v-model="dialogVisible" :title="title" :before-close="Cancel">
|
||||||
|
<el-form :inline="false" :model="configStore" label-width="auto">
|
||||||
|
<el-divider border-style="dashed">全局</el-divider>
|
||||||
|
<div class="layout-config-global form-two">
|
||||||
|
<el-form-item label="组件主名称">
|
||||||
|
<el-input v-model="configStore.name" placeholder="请输入主题名称" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="后台页面切换动画">
|
||||||
|
<el-select v-model="configStore.mainAnimation">
|
||||||
|
<el-option label="slide-right" value="slide-right"></el-option>
|
||||||
|
<el-option label="slide-left" value="slide-left"></el-option>
|
||||||
|
<el-option label="el-fade-in-linear" value="el-fade-in-linear"></el-option>
|
||||||
|
<el-option label="el-fade-in" value="el-fade-in"></el-option>
|
||||||
|
<el-option label="el-zoom-in-center" value="el-zoom-in-center"></el-option>
|
||||||
|
<el-option label="el-zoom-in-top" value="el-zoom-in-top"></el-option>
|
||||||
|
<el-option label="el-zoom-in-bottom" value="el-zoom-in-bottom"></el-option>
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="组件主题色">
|
||||||
|
<el-color-picker v-model="configStore.elementUiPrimary[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="表格标题栏背景颜色">
|
||||||
|
<el-color-picker v-model="configStore.tableHeaderBackground[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="表格标题栏文字颜色">
|
||||||
|
<el-color-picker v-model="configStore.tableHeaderColor[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="表格激活栏颜色">
|
||||||
|
<el-color-picker v-model="configStore.tableCurrent[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="组件主描述">
|
||||||
|
<el-input
|
||||||
|
v-model="configStore.remark"
|
||||||
|
:autosize="{ minRows: 2, maxRows: 4 }"
|
||||||
|
type="textarea"
|
||||||
|
placeholder="请输入描述"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
</div>
|
||||||
|
<el-divider border-style="dashed">侧边栏</el-divider>
|
||||||
|
<div class="layout-config-aside form-two">
|
||||||
|
<el-form-item label="侧边菜单栏背景色">
|
||||||
|
<el-color-picker v-model="configStore.menuBackground[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="侧边菜单文字颜色">
|
||||||
|
<el-color-picker v-model="configStore.menuColor[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="侧边菜单激活项背景色">
|
||||||
|
<el-color-picker v-model="configStore.menuActiveBackground[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="侧边菜单激活项文字色">
|
||||||
|
<el-color-picker v-model="configStore.menuActiveColor[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="侧边菜单顶栏背景色">
|
||||||
|
<el-color-picker v-model="configStore.menuTopBarBackground[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<el-divider border-style="dashed">顶栏</el-divider>
|
||||||
|
<div class="layout-config-aside form-two">
|
||||||
|
<el-form-item label="顶栏背景色">
|
||||||
|
<el-color-picker v-model="configStore.headerBarBackground[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="顶栏文字色">
|
||||||
|
<el-color-picker v-model="configStore.headerBarTabColor[0]" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="顶栏logo">
|
||||||
|
<el-image
|
||||||
|
style="height: 50px"
|
||||||
|
:src="logoFile.url"
|
||||||
|
:preview-src-list="[logoFile.url]"
|
||||||
|
v-if="logoFile.url"
|
||||||
|
class="mr10"
|
||||||
|
></el-image>
|
||||||
|
<el-upload
|
||||||
|
action=""
|
||||||
|
:show-file-list="false"
|
||||||
|
:auto-upload="false"
|
||||||
|
accept=".png,.jpg"
|
||||||
|
:on-change="chooseImage"
|
||||||
|
>
|
||||||
|
<el-button type="primary">上传图片</el-button>
|
||||||
|
</el-upload>
|
||||||
|
</el-form-item>
|
||||||
|
</div>
|
||||||
|
</el-form>
|
||||||
|
|
||||||
|
<template #footer>
|
||||||
|
<div class="dialog-footer">
|
||||||
|
<el-button type="primary" @click="onSubmit">确定</el-button>
|
||||||
|
<el-button @click="Cancel">取消</el-button>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-dialog>
|
||||||
|
</template>
|
||||||
|
<script lang="ts" setup>
|
||||||
|
import { ref, inject } from 'vue'
|
||||||
|
import { reactive } from 'vue'
|
||||||
|
|
||||||
|
import { ElMessage } from 'element-plus'
|
||||||
|
const dialogVisible = ref(false)
|
||||||
|
const title = ref('')
|
||||||
|
import { addTheme, updateTheme } from '@/api/system/subject/index'
|
||||||
|
const emit = defineEmits(['Cancels'])
|
||||||
|
const configStore = ref({
|
||||||
|
// 后台主页面切换动画,可选值<slide-right|slide-left|el-fade-in-linear|el-fade-in|el-zoom-in-center|el-zoom-in-top|el-zoom-in-bottom>
|
||||||
|
mainAnimation: 'slide-right',
|
||||||
|
elementUiPrimary: ['#0e8780', '#0e8780'],
|
||||||
|
tableHeaderBackground: ['#F3F6F9', '#F3F6F9'],
|
||||||
|
tableHeaderColor: ['#111', '#fff'],
|
||||||
|
tableCurrent: ['#F3F6F9', '#F3F6F9'],
|
||||||
|
/* 侧边菜单 */
|
||||||
|
// 侧边菜单背景色
|
||||||
|
menuBackground: ['#0e8780', '#1d1e1f'],
|
||||||
|
// 侧边菜单文字颜色
|
||||||
|
menuColor: ['#FFFFFF', '#CFD3DC'],
|
||||||
|
// 侧边菜单激活项背景色
|
||||||
|
menuActiveBackground: ['#0c7973', '#1d1e1f'],
|
||||||
|
// 侧边菜单激活项文字色
|
||||||
|
menuActiveColor: ['#00f5fd', '#3375b9'],
|
||||||
|
// 侧边菜单顶栏背景色
|
||||||
|
menuTopBarBackground: ['#0e8780', '#1d1e1f'],
|
||||||
|
|
||||||
|
// 顶栏文字色
|
||||||
|
headerBarTabColor: ['#FFFFFF', '#CFD3DC'],
|
||||||
|
// 顶栏背景色
|
||||||
|
headerBarBackground: ['#0e8780', '#1d1e1f'],
|
||||||
|
|
||||||
|
logoFile: '',
|
||||||
|
name: '',
|
||||||
|
color: '',
|
||||||
|
faviconFile: '',
|
||||||
|
remark: ''
|
||||||
|
})
|
||||||
|
|
||||||
|
const logoFile = reactive({
|
||||||
|
url: '',
|
||||||
|
raw: ''
|
||||||
|
})
|
||||||
|
|
||||||
|
const open = (e: any) => {
|
||||||
|
title.value = e.text
|
||||||
|
dialogVisible.value = true
|
||||||
|
if (e.text == '修改主题') {
|
||||||
|
let form = JSON.parse(JSON.stringify(e.row))
|
||||||
|
for (let k in form) {
|
||||||
|
if (
|
||||||
|
k == 'elementUiPrimary' ||
|
||||||
|
k == 'tableHeaderBackground' ||
|
||||||
|
k == 'tableHeaderColor' ||
|
||||||
|
k == 'tableCurrent' ||
|
||||||
|
k == 'menuBackground' ||
|
||||||
|
k == 'menuColor' ||
|
||||||
|
k == 'menuActiveBackground' ||
|
||||||
|
k == 'menuActiveColor' ||
|
||||||
|
k == 'menuTopBarBackground' ||
|
||||||
|
k == 'headerBarTabColor' ||
|
||||||
|
k == 'headerBarBackground'
|
||||||
|
) {
|
||||||
|
form[k] = JSON.parse(form[k])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
logoFile.url = form.logoUrl
|
||||||
|
configStore.value = form
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 确定主题
|
||||||
|
const onSubmit = () => {
|
||||||
|
configStore.value.faviconFile = configStore.value.logoFile
|
||||||
|
configStore.value.color = configStore.value.elementUiPrimary[0]
|
||||||
|
let form = new FormData()
|
||||||
|
for (let k in configStore.value) {
|
||||||
|
if (
|
||||||
|
k == 'logoFile' ||
|
||||||
|
k == 'faviconFile' ||
|
||||||
|
k == 'name' ||
|
||||||
|
k == 'color' ||
|
||||||
|
k == 'remark' ||
|
||||||
|
k == 'mainAnimation' ||
|
||||||
|
k == 'id'
|
||||||
|
) {
|
||||||
|
form.append(k, configStore.value[k])
|
||||||
|
} else if (k == 'logoUrl' || k == 'faviconUrl') {
|
||||||
|
if (configStore.value.logoFile == null) {
|
||||||
|
let str = configStore.value[k].match(/base64,([^"]+)/)[1]
|
||||||
|
let bin = atob(str)
|
||||||
|
let arr = new Array(bin.length)
|
||||||
|
for (let i = 0; i < bin.length; i++) {
|
||||||
|
arr[i] = bin.charCodeAt(i)
|
||||||
|
}
|
||||||
|
let b = new Uint8Array(arr)
|
||||||
|
const blob = new Blob([b], { type: 'image/jpeg' })
|
||||||
|
form.append('faviconFile', blob)
|
||||||
|
form.append('logoFile', blob)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
form.append(k, JSON.stringify(configStore.value[k]))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (title.value == '新增主题') {
|
||||||
|
addTheme(form).then(res => {
|
||||||
|
ElMessage.success('新增成功')
|
||||||
|
Cancel()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
if (title.value == '修改主题') {
|
||||||
|
updateTheme(form).then(res => {
|
||||||
|
ElMessage.success('修改成功')
|
||||||
|
Cancel()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 取消
|
||||||
|
const Cancel = () => {
|
||||||
|
// dialogVisible.value = false
|
||||||
|
emit('Cancels')
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 选择图片上传
|
||||||
|
* @param e
|
||||||
|
*/
|
||||||
|
const chooseImage = (e: any) => {
|
||||||
|
console.log('🚀 ~ chooseImage ~ e:', URL.createObjectURL(e.raw!))
|
||||||
|
logoFile.url = URL.createObjectURL(e.raw!)
|
||||||
|
configStore.value.logoFile = e.raw
|
||||||
|
// uploadFile(e.raw, 'sgGovern/').then(res => {
|
||||||
|
// logoFile.name = res.data.name
|
||||||
|
// logoFile.url = res.data.url
|
||||||
|
// configStore.logoFile = res.data.name
|
||||||
|
// ElMessage.success('新增成功')
|
||||||
|
// })
|
||||||
|
}
|
||||||
|
defineExpose({ open })
|
||||||
|
</script>
|
||||||
150
src/views/system/subject/index.vue
Normal file
150
src/views/system/subject/index.vue
Normal file
@@ -0,0 +1,150 @@
|
|||||||
|
<template>
|
||||||
|
<div class="default-main">
|
||||||
|
<TableHeader select ref="TableHeaderRef">
|
||||||
|
<template #operation>
|
||||||
|
<el-button icon="el-icon-Plus" type="primary" @click="add">新增</el-button>
|
||||||
|
</template>
|
||||||
|
</TableHeader>
|
||||||
|
<Table ref="tableRef" />
|
||||||
|
<formTab ref="formTabRef" v-if="show" @Cancels=";(show = false), tableStore.index()" />
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<script setup lang="ts">
|
||||||
|
import { ref, onMounted, provide, nextTick } from 'vue'
|
||||||
|
import TableStore from '@/utils/tableStore'
|
||||||
|
import Table from '@/components/table/index.vue'
|
||||||
|
import TableHeader from '@/components/table/header/index.vue'
|
||||||
|
import { activateTheme, deleteTheme } from '@/api/system/subject/index'
|
||||||
|
import formTab from './form/index.vue'
|
||||||
|
import { ElMessage } from 'element-plus'
|
||||||
|
import { useConfig } from '@/stores/config'
|
||||||
|
import { getTheme } from '@/api/systerm'
|
||||||
|
const configStore = useConfig()
|
||||||
|
defineOptions({
|
||||||
|
name: 'user-boot/function/functionTree'
|
||||||
|
})
|
||||||
|
|
||||||
|
const formTabRef = ref()
|
||||||
|
const TableHeaderRef = ref()
|
||||||
|
const show = ref(false)
|
||||||
|
const tableStore: any = new TableStore({
|
||||||
|
url: '/system-boot/theme/getAllThemes',
|
||||||
|
method: 'GET',
|
||||||
|
column: [
|
||||||
|
{
|
||||||
|
field: 'index',
|
||||||
|
title: '序号',
|
||||||
|
width: '80',
|
||||||
|
formatter: (row: any) => {
|
||||||
|
return (tableStore.table.params.pageNum - 1) * tableStore.table.params.pageSize + row.rowIndex + 1
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ field: 'name', title: '主题名称' },
|
||||||
|
{ field: 'remark', title: '描述' },
|
||||||
|
// { field: 'logoUrl', title: '主题图标', render: 'image' },
|
||||||
|
|
||||||
|
{
|
||||||
|
title: '操作',
|
||||||
|
width: '180',
|
||||||
|
render: 'buttons',
|
||||||
|
buttons: [
|
||||||
|
{
|
||||||
|
name: 'edit',
|
||||||
|
title: '激活 ',
|
||||||
|
type: 'primary',
|
||||||
|
icon: 'el-icon-Plus',
|
||||||
|
render: 'basicButton',
|
||||||
|
disabled: row => {
|
||||||
|
return row.active == 1
|
||||||
|
},
|
||||||
|
click: row => {
|
||||||
|
activateTheme({ id: row.id }).then(res => {
|
||||||
|
ElMessage({
|
||||||
|
message: '激活成功!',
|
||||||
|
type: 'success'
|
||||||
|
})
|
||||||
|
tableStore.index()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'edit',
|
||||||
|
title: '修改 ',
|
||||||
|
type: 'primary',
|
||||||
|
icon: 'el-icon-Plus',
|
||||||
|
render: 'basicButton',
|
||||||
|
click: row => {
|
||||||
|
show.value = true
|
||||||
|
setTimeout(() => {
|
||||||
|
formTabRef.value.open({
|
||||||
|
text: '修改主题',
|
||||||
|
row: row
|
||||||
|
})
|
||||||
|
}, 10)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'edit',
|
||||||
|
title: '删除',
|
||||||
|
type: 'danger',
|
||||||
|
icon: 'el-icon-Delete',
|
||||||
|
render: 'confirmButton',
|
||||||
|
popconfirm: {
|
||||||
|
confirmButtonText: '确认',
|
||||||
|
cancelButtonText: '取消',
|
||||||
|
confirmButtonType: 'danger',
|
||||||
|
title: '确定删除吗?'
|
||||||
|
},
|
||||||
|
click: row => {
|
||||||
|
deleteTheme({ id: row.id }).then(res => {
|
||||||
|
ElMessage({
|
||||||
|
message: '删除成功!',
|
||||||
|
type: 'success'
|
||||||
|
})
|
||||||
|
tableStore.index()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
|
||||||
|
loadCallback: () => {
|
||||||
|
getTheme().then(res => {
|
||||||
|
let list: any = [
|
||||||
|
'elementUiPrimary',
|
||||||
|
'tableHeaderBackground',
|
||||||
|
'tableHeaderColor',
|
||||||
|
'tableCurrent',
|
||||||
|
'menuBackground',
|
||||||
|
'menuColor',
|
||||||
|
'menuTopBarBackground',
|
||||||
|
'menuActiveBackground',
|
||||||
|
'menuActiveColor',
|
||||||
|
'headerBarTabColor',
|
||||||
|
'headerBarBackground'
|
||||||
|
]
|
||||||
|
|
||||||
|
window.localStorage.setItem('getTheme', JSON.stringify(res.data))
|
||||||
|
for (let i = 0; i < list.length; i++) {
|
||||||
|
configStore.setLayout(list[i], JSON.parse(res.data[list[i]]))
|
||||||
|
}
|
||||||
|
configStore.setLayout('elementUiPrimary', JSON.parse(res.data['elementUiPrimary']))
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
provide('tableStore', tableStore)
|
||||||
|
// 新增主题
|
||||||
|
const add = () => {
|
||||||
|
show.value = true
|
||||||
|
setTimeout(() => {
|
||||||
|
formTabRef.value.open({
|
||||||
|
text: '新增主题'
|
||||||
|
})
|
||||||
|
}, 10)
|
||||||
|
}
|
||||||
|
onMounted(() => {
|
||||||
|
tableStore.index()
|
||||||
|
})
|
||||||
|
</script>
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<el-form :rules="rules" ref="formRef" size="large" class="login-form" :model="form">
|
<el-form :rules="rules" ref="formRef" size="large" class="login-form" :model="form">
|
||||||
<el-form-item prop="username">
|
<el-form-item prop="username">
|
||||||
<el-input maxlength="32" show-word-limit ref="usernameRef" v-model="form.username" type="text"
|
<el-input ref="usernameRef" v-model="form.username" type="text"
|
||||||
clearable style="width: 368px" placeholder="用户名" autocomplete="off">
|
clearable style="width: 368px" placeholder="用户名" autocomplete="off">
|
||||||
<template #prefix>
|
<template #prefix>
|
||||||
<span class="iconfont icon-yonghu" style="color: #003078"></span>
|
<span class="iconfont icon-yonghu" style="color: #003078"></span>
|
||||||
@@ -20,7 +20,7 @@
|
|||||||
</el-input>
|
</el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item prop="password">
|
<el-form-item prop="password">
|
||||||
<el-input maxlength="32" show-word-limit ref="passwordRef" v-model="form.password" type="password"
|
<el-input ref="passwordRef" v-model="form.password" type="password"
|
||||||
placeholder="密码" show-password style="width: 368px" autocomplete="off">
|
placeholder="密码" show-password style="width: 368px" autocomplete="off">
|
||||||
<template #prefix>
|
<template #prefix>
|
||||||
<span class="iconfont icon-mima" style="color: #003078"></span>
|
<span class="iconfont icon-mima" style="color: #003078"></span>
|
||||||
|
|||||||
@@ -3,11 +3,11 @@
|
|||||||
<el-scrollbar>
|
<el-scrollbar>
|
||||||
<el-form :inline="false" :model="form" label-width="120px" :rules="rules" ref="formRef">
|
<el-form :inline="false" :model="form" label-width="120px" :rules="rules" ref="formRef">
|
||||||
<el-form-item label="新密码:" prop="newPwd" style="margin-top: 20px">
|
<el-form-item label="新密码:" prop="newPwd" style="margin-top: 20px">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.newPwd" type="password" placeholder="请输入新密码"
|
<el-input v-model="form.newPwd" type="password" placeholder="请输入新密码"
|
||||||
show-password />
|
show-password />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="确认密码:" prop="confirmPwd" style="margin-top: 20px">
|
<el-form-item label="确认密码:" prop="confirmPwd" style="margin-top: 20px">
|
||||||
<el-input maxlength="32" show-word-limit v-model="form.confirmPwd" type="password"
|
<el-input v-model="form.confirmPwd" type="password"
|
||||||
placeholder="请输入确认密码" show-password />
|
placeholder="请输入确认密码" show-password />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
|
|||||||
Reference in New Issue
Block a user