edu/admin/src/views/setting/website/information.vue

147 lines
4.7 KiB
Vue
Raw Normal View History

2022-04-08 02:42:44 +00:00
<!-- 网站信息 -->
<template>
<div class="website-information">
2022-09-08 11:09:53 +00:00
<el-form ref="formRef" :rules="rules" :model="formData" label-width="120px">
<el-card shadow="never" class="!border-none">
<div class="text-xl font-medium mb-[20px]">后台设置</div>
2022-04-08 02:42:44 +00:00
<el-form-item label="网站名称" prop="name">
2022-08-12 10:44:09 +00:00
<div class="w-80">
<el-input
v-model="formData.name"
placeholder="请输入网站名称"
maxlength="30"
show-word-limit
></el-input>
</div>
2022-04-08 02:42:44 +00:00
</el-form-item>
2022-09-08 11:09:53 +00:00
<el-form-item label="网站图标" prop="favicon">
2022-08-12 10:44:09 +00:00
<div>
<material-picker v-model="formData.favicon" :limit="1" />
<div class="form-tips">建议尺寸100*100像素支持jpgjpegpng格式</div>
2022-04-08 02:42:44 +00:00
</div>
</el-form-item>
2022-09-08 11:09:53 +00:00
<el-form-item label="网站logo" prop="logo">
2022-08-12 10:44:09 +00:00
<div>
<material-picker v-model="formData.logo" :limit="1" />
<div class="form-tips">建议尺寸200*200像素支持jpgjpegpng格式</div>
2022-04-08 02:42:44 +00:00
</div>
</el-form-item>
2022-09-08 11:09:53 +00:00
<el-form-item label="登录页广告图" prop="backdrop">
2022-08-12 10:44:09 +00:00
<div>
<material-picker v-model="formData.backdrop" :limit="1" />
<div class="form-tips">建议尺寸400*400像素支持jpgjpegpng格式</div>
2022-04-08 02:42:44 +00:00
</div>
</el-form-item>
2022-09-08 11:09:53 +00:00
</el-card>
<el-card shadow="never" class="!border-none mt-4">
2022-10-13 08:08:31 +00:00
<div class="text-xl font-medium mb-[20px]">前台设置</div>
2022-09-08 11:09:53 +00:00
<el-form-item label="商城名称" prop="shopName">
<div class="w-80">
<el-input
v-model="formData.shopName"
placeholder="请输入店铺/商城名称"
maxlength="30"
show-word-limit
></el-input>
</div>
</el-form-item>
<el-form-item label="商城LOGO" prop="shopLogo">
<div>
<material-picker v-model="formData.shopLogo" :limit="1" />
<div class="form-tips">建议尺寸100*100px支持jpgjpegpng格式</div>
</div>
</el-form-item>
</el-card>
</el-form>
2022-08-15 03:46:57 +00:00
<footer-btns v-perms="['setting:website:save']">
2022-08-12 10:44:09 +00:00
<el-button type="primary" @click="handleSubmit">保存</el-button>
2022-04-08 02:42:44 +00:00
</footer-btns>
</div>
</template>
2022-09-20 02:58:38 +00:00
<script lang="ts" setup name="webInformation">
2022-08-12 10:44:09 +00:00
import { getWebsite, setWebsite } from '@/api/setting/website'
import useAppStore from '@/stores/modules/app'
2022-08-29 11:06:22 +00:00
import feedback from '@/utils/feedback'
2022-08-12 10:44:09 +00:00
import type { FormInstance } from 'element-plus'
const formRef = ref<FormInstance>()
const { getConfig } = useAppStore()
2022-08-12 10:44:09 +00:00
// 表单数据
const formData = reactive({
name: '', // 网站名称
favicon: '', // 网站图标
logo: '', // 网站logo
2022-09-08 11:09:53 +00:00
backdrop: '', // 登录页广告图
shopName: '',
shopLogo: ''
2022-08-12 10:44:09 +00:00
})
2022-04-08 02:42:44 +00:00
2022-08-12 10:44:09 +00:00
// 表单验证
const rules = {
name: [
{
required: true,
message: '请输入网站名称',
trigger: ['blur']
2022-04-08 02:42:44 +00:00
}
2022-09-08 11:09:53 +00:00
],
favicon: [
{
required: true,
message: '请选择网站图标',
trigger: ['change']
}
],
logo: [
{
required: true,
message: '请选择网站logo',
trigger: ['change']
}
],
backdrop: [
{
required: true,
message: '请选择登录页广告图',
trigger: ['change']
}
],
shopName: [
{
required: true,
message: '请输入店铺/商城名称',
trigger: ['blur']
}
],
shopLogo: [
{
required: true,
message: '请选择商城LOGO',
trigger: ['change']
}
2022-08-12 10:44:09 +00:00
]
}
2022-04-08 02:42:44 +00:00
2022-08-12 10:44:09 +00:00
// 获取备案信息
const getData = async () => {
const data = await getWebsite()
for (const key in formData) {
//@ts-ignore
formData[key] = data[key]
}
}
2022-04-08 02:42:44 +00:00
2022-08-12 10:44:09 +00:00
// 设置备案信息
const handleSubmit = async () => {
await formRef.value?.validate()
await setWebsite(formData)
2022-08-29 11:06:22 +00:00
feedback.msgSuccess('操作成功')
getConfig()
2022-08-12 10:44:09 +00:00
getData()
}
2022-04-08 02:42:44 +00:00
2022-08-12 10:44:09 +00:00
getData()
2022-04-08 02:42:44 +00:00
</script>
<style lang="scss" scoped></style>