【后台管理】-- 系统设置--->用户设置&登录注册

This commit is contained in:
linjinyuan 2022-09-06 19:02:02 +08:00
parent 116d6d5eff
commit c6a1e5924a
2 changed files with 191 additions and 0 deletions

View File

@ -0,0 +1,133 @@
<!-- 网站信息 -->
<template>
<div class="login-register">
<el-form ref="formRef" :rules="rules" :model="formData" label-width="120px">
<el-card shadow="never" class="!border-none">
<div class="font-medium mb-7">通用设置</div>
<el-form-item label="登录方式" prop="methods">
<div>
<el-checkbox v-model="formData.methods" true-label="1" false-label="2" label="登录" />
<el-checkbox v-model="formData.methods" true-label="1" false-label="2" label="注册" />
<div class="form-tips">系统通用登录方式至少选择一项</div>
</div>
</el-form-item>
<el-form-item label="强制绑定手机" prop="favicon" required>
<div>
<el-switch v-model="formData.isBindMobile" />
<span class="mt-1 ml-2">{{
formData.isBindMobile ? "开启" : "关闭"
}}</span>
<div class="form-tips">
1如果开启则新用户在注册完成之后要强制绑定手机号<br />
2老用户登录时如果检测到没有绑定手机则要重新绑定手机号
</div>
</div>
</el-form-item>
<el-form-item label="政策协议" prop="favicon" required>
<div>
<el-switch v-model="formData.isBindMobile" />
<span class="mt-1 ml-2">{{
formData.isBindMobile ? "开启" : "关闭"
}}</span>
<div class="form-tips">
登录/注册会员时是否显示服务协议和隐私政策
</div>
</div>
</el-form-item>
</el-card>
<el-card shadow="never" class="!border-none mt-4">
<div class="font-medium mb-7">第三方设置</div>
<el-form-item label="第三方登录" prop="methods">
<div>
<el-switch v-model="formData.isBindMobile" />
<span class="mt-1 ml-2">{{
formData.isBindMobile ? "开启" : "关闭"
}}</span>
<div class="form-tips">登录时支持第三方登录新用户授权即自动注册账号</div>
<div>
<el-checkbox v-model="formData.methods" true-label="1" false-label="2" label="登录" />
<el-checkbox v-model="formData.methods" true-label="1" false-label="2" label="注册" />
</div>
</div>
</el-form-item>
<el-form-item label="微信开放平台" prop="favicon" required>
<div>
<a href="https://baidu.com" target="_blank">
<el-button type="primary" link class="underline">前往微信开放平台</el-button>
</a>
<div class="form-tips">
1在各渠道使用微信授权登录时强烈建议配置微信开放平台<br />
2微信开放平台关联公众号小程序和APP后可实现各端用户账号统一识别买家唯一微信身份<br />
3没有配置微信开放平台同一微信号会生成多个用户配置微信开放平台后已生成的用户账号无法合并
</div>
</div>
</el-form-item>
</el-card>
</el-form>
<footer-btns v-perms="['setting:website:save']">
<el-button type="primary" @click="handleSubmit">保存</el-button>
</footer-btns>
</div>
</template>
<script lang="ts" setup>
import { getWebsite, setWebsite } from "@/api/setting/website";
import feedback from "@/utils/feedback";
import type { FormInstance } from "element-plus";
const formRef = ref<FormInstance>();
//
const formData = reactive({
methods: 1, //
isBindMobile: 1, //
favicon: "", //
logo: "", // logo
backdrop: "", // 广
});
//
const rules = {
name: [
{
required: true,
message: "请输入网站名称",
trigger: ["blur"],
},
],
};
//
const getData = async () => {
const data = await getWebsite();
for (const key in formData) {
//@ts-ignore
formData[key] = data[key];
}
};
//
const handleSubmit = async () => {
await formRef.value?.validate();
await setWebsite(formData);
feedback.msgSuccess("操作成功");
getData();
};
getData();
</script>
<style lang="scss" scoped>
</style>

View File

@ -0,0 +1,58 @@
<!-- 网站信息 -->
<template>
<div class="user-setup">
<el-card shadow="never" class="!border-none">
<div class="font-medium mb-7">服务器域名</div>
<el-form ref="formRef" :model="formData" label-width="120px">
<el-form-item label="用户默认头像">
<div>
<material-picker v-model="formData.default_avatar" :limit="1" />
</div>
</el-form-item>
<el-form-item>
<div>
<div class="form-tips">用户注册时给的默认头像建议尺寸400*400像素支持jpgjpegpng格式</div>
</div>
</el-form-item>
</el-form>
</el-card>
<footer-btns v-perms="['setting:website:save']">
<el-button type="primary" @click="handleSubmit">保存</el-button>
</footer-btns>
</div>
</template>
<script lang="ts" setup>
import { getWebsite, setWebsite } from '@/api/setting/website'
import feedback from '@/utils/feedback'
import type { FormInstance } from 'element-plus'
const formRef = ref<FormInstance>()
//
const formData = reactive({
default_avatar: '', //
})
//
const getData = async () => {
const data = await getWebsite()
for (const key in formData) {
//@ts-ignore
formData[key] = data[key]
}
}
//
const handleSubmit = async () => {
await formRef.value?.validate()
await setWebsite(formData)
feedback.msgSuccess('操作成功')
getData()
}
getData()
</script>
<style lang="scss" scoped>
</style>