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像素,支持jpg,jpeg,png格式</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像素,支持jpg,jpeg,png格式</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像素,支持jpg,jpeg,png格式</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">
|
|
|
|
|
|
<div class="text-xl font-medium mb-[20px]">商城设置</div>
|
|
|
|
|
|
<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,支持jpg,jpeg,png格式</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'
|
2022-09-16 08:17:08 +00:00
|
|
|
|
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>()
|
2022-09-16 08:17:08 +00:00
|
|
|
|
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('操作成功')
|
2022-09-16 08:17:08 +00:00
|
|
|
|
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>
|