edu/admin/src/views/channel/weapp.vue

180 lines
7.9 KiB
Vue
Raw Normal View History

2022-08-29 11:06:52 +00:00
<template>
<div>
<el-card class="!border-none" shadow="never">
<el-alert
type="warning"
title="温馨提示:填写微信小程序开发配置,请前往微信公众平台申请小程序并完成认证"
2022-08-29 11:06:52 +00:00
:closable="false"
show-icon
/>
</el-card>
<el-form ref="formRef" :model="formData" label-width="160px">
2022-08-29 11:06:52 +00:00
<el-card class="!border-none mt-4" shadow="never">
<div class="font-medium mb-7">微信小程序</div>
<el-form-item label="小程序名称" prop="name">
2022-08-29 11:06:52 +00:00
<div class="w-80">
<el-input v-model="formData.name" placeholder="请输入小程序名称" />
2022-08-29 11:06:52 +00:00
</div>
</el-form-item>
<el-form-item label="原始ID" prop="primaryId">
<div class="w-80">
<el-input v-model="formData.primaryId" placeholder="请输入原始ID" />
</div>
</el-form-item>
<el-form-item label="小程序码" prop="qrCode">
2022-08-29 11:06:52 +00:00
<div>
<div>
<material-picker v-model="formData.qrCode" :limit="1" />
</div>
<div class="form-tips">建议尺寸宽400px*高400pxjpgjpegpng格式</div>
</div>
</el-form-item>
</el-card>
<el-card class="!border-none mt-4" shadow="never">
<div class="font-medium mb-7">开发者ID</div>
2022-08-29 11:06:52 +00:00
<el-form-item label="AppID" prop="appId">
<div class="w-80">
<el-input v-model="formData.appId" placeholder="请输入AppID" />
</div>
</el-form-item>
<el-form-item label="AppSecret" prop="appSecret">
<div>
<div class="w-80">
<el-input v-model="formData.appSecret" placeholder="请输入AppSecret" />
</div>
</div>
</el-form-item>
<el-form-item>
2022-08-29 11:06:52 +00:00
<div class="form-tips">
小程序账号登录微信公众平台点击开发>开发设置->开发者ID设置AppID和AppSecret
2022-08-29 11:06:52 +00:00
</div>
</el-form-item>
</el-card>
<el-card class="!border-none mt-4" shadow="never">
<div class="font-medium mb-7">服务器域名</div>
<el-form-item label="request合法域名" prop="appId">
2022-08-29 11:06:52 +00:00
<div>
<div class="flex">
2022-09-06 08:36:15 +00:00
<div class="mr-4 w-80">
<el-input v-model="formData.requestDomain" disabled />
</div>
2022-09-06 08:36:15 +00:00
<el-button @click="copy(formData.requestDomain)">复制</el-button>
2022-08-29 11:06:52 +00:00
</div>
<div class="form-tips">
小程序账号登录微信公众平台点击开发>开发设置->服务器域名填写https协议域名
2022-08-29 11:06:52 +00:00
</div>
</div>
</el-form-item>
2022-09-06 08:36:15 +00:00
<el-form-item label="socket合法域名">
2022-08-29 11:06:52 +00:00
<div>
<div class="flex">
2022-09-06 08:36:15 +00:00
<div class="mr-4 w-80">
<el-input v-model="formData.socketDomain" disabled />
</div>
2022-09-06 08:36:15 +00:00
<el-button @click="copy(formData.socketDomain)">复制</el-button>
2022-08-29 11:06:52 +00:00
</div>
<div class="form-tips">
小程序账号登录微信公众平台点击开发>开发设置->服务器域名填写wss协议域名
2022-08-29 11:06:52 +00:00
</div>
</div>
</el-form-item>
2022-09-06 08:36:15 +00:00
<el-form-item label="uploadFile合法域名">
2022-08-29 11:06:52 +00:00
<div>
<div class="flex">
2022-09-06 08:36:15 +00:00
<div class="mr-4 w-80">
<el-input v-model="formData.uploadFileDomain" disabled />
</div>
2022-09-06 08:36:15 +00:00
<el-button @click="copy(formData.uploadFileDomain)">复制</el-button>
</div>
<div class="form-tips">
小程序账号登录微信公众平台点击开发>开发设置->服务器域名填写https协议域名
</div>
2022-08-29 11:06:52 +00:00
</div>
</el-form-item>
2022-09-06 08:36:15 +00:00
<el-form-item label="downloadFile合法域名">
2022-08-29 11:06:52 +00:00
<div>
<div class="flex">
2022-09-06 08:36:15 +00:00
<div class="mr-4 w-80">
<el-input v-model="formData.downloadFileDomain" disabled />
2022-08-29 11:06:52 +00:00
</div>
2022-09-06 08:36:15 +00:00
<el-button @click="copy(formData.downloadFileDomain)">复制</el-button>
2022-08-29 11:06:52 +00:00
</div>
<div class="form-tips">
小程序账号登录微信公众平台点击开发>开发设置->服务器域名填写https协议域名
2022-08-29 11:06:52 +00:00
</div>
</div>
</el-form-item>
2022-09-06 08:36:15 +00:00
<el-form-item label="udp合法域名">
2022-08-29 11:06:52 +00:00
<div>
<div class="flex">
2022-09-06 08:36:15 +00:00
<div class="mr-4 w-80">
<el-input v-model="formData.udpDomain" disabled />
2022-08-29 11:06:52 +00:00
</div>
2022-09-06 08:36:15 +00:00
<el-button @click="copy(formData.udpDomain)">复制</el-button>
2022-08-29 11:06:52 +00:00
</div>
<div class="form-tips">
小程序账号登录微信公众平台点击开发>开发设置->服务器域名填写udp协议域名
2022-08-29 11:06:52 +00:00
</div>
</div>
</el-form-item>
</el-card>
<el-card class="!border-none mt-4" shadow="never">
<div class="font-medium mb-7">业务域名</div>
2022-09-06 08:36:15 +00:00
<el-form-item label="业务域名">
2022-08-29 11:06:52 +00:00
<div>
<div class="flex">
2022-09-06 08:36:15 +00:00
<div class="mr-4 w-80">
<el-input v-model="formData.businessDomain" disabled />
2022-08-29 11:06:52 +00:00
</div>
2022-09-06 08:36:15 +00:00
<el-button @click="copy(formData.businessDomain)">复制</el-button>
2022-08-29 11:06:52 +00:00
</div>
<div class="form-tips">
小程序账号登录微信公众平台点击开发>开发设置->业务域名填写业务域名
2022-08-29 11:06:52 +00:00
</div>
</div>
</el-form-item>
</el-card>
</el-form>
<footer-btns v-perms="['channel:h5:save']">
<el-button type="primary" @click="handelSave">保存</el-button>
</footer-btns>
</div>
</template>
<script lang="ts" setup>
import { getWeappConfig, setWeappConfig } from '@/api/channel/weapp'
2022-08-29 11:06:52 +00:00
import feedback from '@/utils/feedback'
2022-09-06 08:36:15 +00:00
import { useClipboard } from '@vueuse/core'
2022-08-29 11:06:52 +00:00
const formData = reactive({
name: '',
primaryId: '',
qrCode: '',
appId: '',
2022-09-06 08:36:15 +00:00
appSecret: '',
businessDomain: '',
downloadFileDomain: '',
requestDomain: '',
socketDomain: '',
tcpDomain: '',
udpDomain: '',
uploadFileDomain: ''
2022-08-29 11:06:52 +00:00
})
2022-09-06 08:36:15 +00:00
const { copy } = useClipboard()
2022-08-29 11:06:52 +00:00
const getDetail = async () => {
const data = await getWeappConfig()
2022-08-29 11:06:52 +00:00
for (const key in formData) {
//@ts-ignore
formData[key] = data[key]
}
}
const handelSave = async () => {
await setWeappConfig(formData)
2022-08-29 11:06:52 +00:00
getDetail()
feedback.msgSuccess('操作成功')
}
getDetail()
</script>