2026-01-25 00:29:35 +08:00
|
|
|
<template>
|
|
|
|
|
<el-dialog :title="title" :visible.sync="dialogFormVisible" width="500px" @close="close">
|
|
|
|
|
<el-form ref="form" label-width="80px" :model="form" :rules="rules">
|
|
|
|
|
<el-form-item label="壁纸类型" prop="type">
|
2026-01-25 11:57:10 +08:00
|
|
|
<el-select v-model="form.type" allow-create default-first-option filterable placeholder="请选择壁纸类型" style="width: 100%">
|
|
|
|
|
<el-option v-for="item in typeList" :key="item.id" :label="item.name" :value="item.id" />
|
2026-01-25 00:29:35 +08:00
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="壁纸图片" prop="imageUrl">
|
|
|
|
|
<single-upload
|
|
|
|
|
v-model="form.imageUrl"
|
|
|
|
|
style="width: 100px; height: 100px"
|
|
|
|
|
:upload-url="uploadUrl"
|
|
|
|
|
@upload-success="handleUploadSuccess"
|
|
|
|
|
/>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="是否启用" prop="isEnabled">
|
|
|
|
|
<el-switch v-model="form.isEnabled" active-text="启用" :active-value="true" inactive-text="禁用" :inactive-value="false" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-form>
|
|
|
|
|
|
|
|
|
|
<div slot="footer" class="dialog-footer">
|
|
|
|
|
<el-button @click="close">取 消</el-button>
|
|
|
|
|
<el-button type="primary" @click="save">确 定</el-button>
|
|
|
|
|
</div>
|
|
|
|
|
</el-dialog>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
import { doEdit, doAdd } from '@/api/spring/wallpaper/system'
|
|
|
|
|
import { getAllList } from '@/api/spring/wallpaper/type'
|
|
|
|
|
import SingleUpload from '@/components/SingleUpload'
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
name: 'SystemWallpaperEdit',
|
|
|
|
|
components: { SingleUpload },
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
id: '',
|
|
|
|
|
form: {
|
|
|
|
|
type: '',
|
|
|
|
|
imageUrl: '',
|
|
|
|
|
isEnabled: true,
|
|
|
|
|
},
|
|
|
|
|
rules: {
|
|
|
|
|
type: [{ required: true, trigger: 'change', message: '请选择壁纸类型' }],
|
|
|
|
|
imageUrl: [{ required: true, trigger: 'blur', message: '请上传壁纸图片' }],
|
|
|
|
|
isEnabled: [{ required: true, trigger: 'blur', message: '请选择是否启用' }],
|
|
|
|
|
},
|
|
|
|
|
title: '',
|
|
|
|
|
dialogFormVisible: false,
|
|
|
|
|
typeList: [],
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
computed: {
|
|
|
|
|
uploadUrl() {
|
|
|
|
|
return `${process.env.VUE_APP_API_BASE_URL}/management/api/common/upload`
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
created() {
|
|
|
|
|
this.fetchTypeList()
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
async fetchTypeList() {
|
|
|
|
|
const { data } = await getAllList()
|
|
|
|
|
this.typeList = data || []
|
|
|
|
|
},
|
|
|
|
|
handleUploadSuccess(url) {
|
|
|
|
|
this.form.imageUrl = url
|
|
|
|
|
},
|
|
|
|
|
showEdit(row) {
|
|
|
|
|
this.fetchTypeList()
|
|
|
|
|
if (!row) {
|
|
|
|
|
this.title = '添加'
|
|
|
|
|
} else {
|
|
|
|
|
this.title = '编辑'
|
|
|
|
|
this.form = {
|
|
|
|
|
type: row.type,
|
|
|
|
|
imageUrl: row.imageUrl,
|
|
|
|
|
isEnabled: row.isEnabled,
|
|
|
|
|
}
|
|
|
|
|
this.id = row.id
|
|
|
|
|
}
|
|
|
|
|
this.dialogFormVisible = true
|
|
|
|
|
},
|
|
|
|
|
close() {
|
|
|
|
|
this.$refs['form'].resetFields()
|
|
|
|
|
this.form = this.$options.data().form
|
|
|
|
|
this.id = ''
|
|
|
|
|
this.dialogFormVisible = false
|
|
|
|
|
},
|
|
|
|
|
save() {
|
|
|
|
|
this.$refs['form'].validate(async (valid) => {
|
|
|
|
|
if (valid) {
|
|
|
|
|
if (this.id) {
|
|
|
|
|
const { msg } = await doEdit(this.id, this.form)
|
|
|
|
|
this.$baseMessage(msg, 'success')
|
|
|
|
|
} else {
|
|
|
|
|
const { msg } = await doAdd(this.form)
|
|
|
|
|
this.$baseMessage(msg, 'success')
|
|
|
|
|
}
|
|
|
|
|
this.$emit('fetch-data')
|
|
|
|
|
this.close()
|
|
|
|
|
} else {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
</script>
|