zxl #15
|
@ -36,3 +36,18 @@ export class toLink {
|
||||||
// 删除链接-缓存
|
// 删除链接-缓存
|
||||||
static delLink = key => ApiService.publicHttp(`/smarttalk/toLink/${key}`, null, 'delete')
|
static delLink = key => ApiService.publicHttp(`/smarttalk/toLink/${key}`, null, 'delete')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// v2.5加入 认证学校
|
||||||
|
export class school {
|
||||||
|
// 学校加入 认证
|
||||||
|
static schoolJoin = data => ApiService.publicHttp(`/smarttalk/register/schoolJoin`,data, 'post')
|
||||||
|
// 获取学校列表
|
||||||
|
static deptTree = data => ApiService.publicHttp(`/smarttalk/register/deptTree`)
|
||||||
|
// 获取当前用户审核详情
|
||||||
|
static registerinfo = data => ApiService.publicHttp(`/smarttalk/register/info`)
|
||||||
|
// 获取学校管理列表
|
||||||
|
static auditlist = data => ApiService.publicHttp(`/smarttalk/audit/list`,data)
|
||||||
|
// 获取学校管理审核
|
||||||
|
static checkSchool = data => ApiService.publicHttp(`/smarttalk/audit/checkSchool`,data,'post')
|
||||||
|
|
||||||
|
}
|
|
@ -105,6 +105,14 @@ export function deptTree(data) {
|
||||||
params:data
|
params:data
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
//获取学校
|
||||||
|
export function getdeptTree(data) {
|
||||||
|
return request({
|
||||||
|
url: '/system/user/deptTree',
|
||||||
|
method: 'get',
|
||||||
|
params:data
|
||||||
|
})
|
||||||
|
}
|
||||||
// 查询部门详细
|
// 查询部门详细
|
||||||
export function getDept(query) {
|
export function getDept(query) {
|
||||||
return request({
|
return request({
|
||||||
|
@ -129,4 +137,21 @@ export function listEvaluation(query) {
|
||||||
method: 'get',
|
method: 'get',
|
||||||
params: query
|
params: query
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
// 发送验证码
|
||||||
|
export function sendcode(data) {
|
||||||
|
return request({
|
||||||
|
url: '/code/send',
|
||||||
|
method: 'post',
|
||||||
|
data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// 教师注册
|
||||||
|
export function instructorregister(data) {
|
||||||
|
return request({
|
||||||
|
url: '/instructor/register',
|
||||||
|
method: 'post',
|
||||||
|
data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 4.9 KiB |
|
@ -10,14 +10,16 @@
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<div class="head-aside">
|
<div class="head-aside">
|
||||||
<ul>
|
<ul >
|
||||||
<li class="auth-li">
|
<li :class="computedregistertype==1 || computedregistertype==3?'auth-li':'auth-li pointer-events'" @click="onUserTo('/schoolCertification')" >
|
||||||
<i class="iconfont icon-renzheng-"></i>
|
<i class="iconfont icon-renzheng-"></i>
|
||||||
<span class="mlr-5">学校认证</span>
|
<span class="mlr-5" v-if="computedregistertype!=4">学校认证</span>
|
||||||
<span class="gray">未认证</span>
|
<span class="mlr-5" v-else>{{ userStore.DeptInfo.register.schoolName }}</span>
|
||||||
|
<span class="gray" v-if="computedregistertype!=4">未认证</span>
|
||||||
</li>
|
</li>
|
||||||
<li>加入学校</li>
|
<li v-if="computedregistertype!=4" :class="computedregistertype==1 || computedregistertype==2 ? '':'pointer-events'" @click="onUserTo('/joinSchool')">加入学校</li>
|
||||||
<li @click="onUserTo('/profile')">个人中心</li>
|
<li @click="onUserTo('/profile')">个人中心</li>
|
||||||
|
<li @click="onUserTo('/schoolManagement')">学校管理</li>
|
||||||
<li @click="onUserTo('/class')">班级中心</li>
|
<li @click="onUserTo('/class')">班级中心</li>
|
||||||
<li @click="logout">退出登录</li>
|
<li @click="logout">退出登录</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
@ -51,13 +53,14 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { ref, watch } from 'vue'
|
import { ref, watch , reactive, onMounted,computed} from 'vue'
|
||||||
import { useRouter } from 'vue-router'
|
import { useRouter } from 'vue-router'
|
||||||
import { ElMessageBox, ElMessage } from 'element-plus'
|
import { ElMessageBox, ElMessage } from 'element-plus'
|
||||||
import useUserStore from '@/store/modules/user'
|
import useUserStore from '@/store/modules/user'
|
||||||
import { sessionStore } from '@/utils/store'
|
import { sessionStore } from '@/utils/store'
|
||||||
import pkc from "../../../../../package.json"
|
import pkc from "../../../../../package.json"
|
||||||
|
|
||||||
|
|
||||||
const { ipcRenderer } = window.electron || {}
|
const { ipcRenderer } = window.electron || {}
|
||||||
const dev_api = ref(import.meta.env.VITE_APP_BASE_API)
|
const dev_api = ref(import.meta.env.VITE_APP_BASE_API)
|
||||||
const userStore = useUserStore()
|
const userStore = useUserStore()
|
||||||
|
@ -66,6 +69,7 @@ const currentRoute = ref('')
|
||||||
const activeId = ref('/home')
|
const activeId = ref('/home')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const version = ref(pkc.version)
|
const version = ref(pkc.version)
|
||||||
|
|
||||||
const popoverRef = ref('')
|
const popoverRef = ref('')
|
||||||
|
@ -106,7 +110,31 @@ const sideBottomMenu = [
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|
||||||
|
const computedregistertype = computed(() => {
|
||||||
|
const type =userStore.DeptInfo?.register?.type ??0
|
||||||
|
console.log(userStore.DeptInfo?.register)
|
||||||
|
if(type==0 || userStore.DeptInfo?.register?.auditStatus!=0 && userStore.DeptInfo?.register?.auditStatus!=1){
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
// 加入成功
|
||||||
|
if(type==3 && userStore.DeptInfo.register.auditStatus==1){
|
||||||
|
console.log(1111)
|
||||||
|
return 4
|
||||||
|
}
|
||||||
|
if(type==4 && userStore.DeptInfo.register.auditStatus==1){
|
||||||
|
return 4
|
||||||
|
}
|
||||||
|
// 加入学校 待审核
|
||||||
|
if(type==3 && userStore.DeptInfo.register.auditStatus==0){
|
||||||
|
return 2
|
||||||
|
}
|
||||||
|
|
||||||
|
// 创建学校 待审核
|
||||||
|
if(type==4 && userStore.DeptInfo.register.auditStatus==0){
|
||||||
|
return 3
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
const clickMenu = ({ id, disabled, path }) => {
|
const clickMenu = ({ id, disabled, path }) => {
|
||||||
if (disabled) return
|
if (disabled) return
|
||||||
activeId.value = id
|
activeId.value = id
|
||||||
|
@ -129,6 +157,7 @@ watch(
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const logout = () => {
|
const logout = () => {
|
||||||
const hasClass = sessionStore.has('activeClass.id')
|
const hasClass = sessionStore.has('activeClass.id')
|
||||||
const hasTool = sessionStore.get('isToolWin')
|
const hasTool = sessionStore.get('isToolWin')
|
||||||
|
@ -153,10 +182,13 @@ const logout = () => {
|
||||||
})
|
})
|
||||||
}).catch(()=>{})
|
}).catch(()=>{})
|
||||||
}
|
}
|
||||||
|
onMounted(() => {
|
||||||
|
userStore.getDeptInfo()
|
||||||
|
// getregisterinfo()
|
||||||
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style>
|
<style lang="scss">
|
||||||
.el-popover.popoverStyle{
|
.el-popover.popoverStyle{
|
||||||
min-width:120px;
|
min-width:120px;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
|
@ -275,4 +307,7 @@ const logout = () => {
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
margin-top: 5px;
|
margin-top: 5px;
|
||||||
}
|
}
|
||||||
|
.pointer-events{
|
||||||
|
pointer-events: none;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
|
@ -160,7 +160,25 @@ export const constantRoutes = [
|
||||||
component: () => import('@/views/setting/index.vue'),
|
component: () => import('@/views/setting/index.vue'),
|
||||||
name: 'setting',
|
name: 'setting',
|
||||||
meta: { title: '设置' }
|
meta: { title: '设置' }
|
||||||
}
|
},
|
||||||
|
{
|
||||||
|
path: '/joinSchool',
|
||||||
|
component: () => import('@/views/joinSchool/index.vue'),
|
||||||
|
name: 'joinSchool',
|
||||||
|
meta: {title: '加入学校'}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: '/schoolCertification',
|
||||||
|
component: () => import('@/views/schoolCertification/index.vue'),
|
||||||
|
name: 'schoolCertification',
|
||||||
|
meta: {title: '学校认证'}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: '/schoolManagement',
|
||||||
|
component: () => import('@/views/schoolManagement/index.vue'),
|
||||||
|
name: 'schoolManagement',
|
||||||
|
meta: {title: '学校管理'}
|
||||||
|
},
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
...toolRouters
|
...toolRouters
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import { defineStore } from 'pinia'
|
import { defineStore } from 'pinia'
|
||||||
import { login, logout, getInfo } from '@/api/login'
|
import { login, logout, getInfo, getdeptTree } from '@/api/login'
|
||||||
|
import {school} from '@/api/apiService'
|
||||||
import { getToken, setToken, removeToken } from '@/utils/auth'
|
import { getToken, setToken, removeToken } from '@/utils/auth'
|
||||||
import defAva from '@/assets/images/user.png'
|
import defAva from '@/assets/images/user.png'
|
||||||
|
|
||||||
|
@ -11,7 +12,8 @@ const useUserStore = defineStore('user', {
|
||||||
avatar: '',
|
avatar: '',
|
||||||
roles: [],
|
roles: [],
|
||||||
permissions: [],
|
permissions: [],
|
||||||
user: {}
|
user: {},
|
||||||
|
DeptInfo:{}
|
||||||
}),
|
}),
|
||||||
actions: {
|
actions: {
|
||||||
// 登录
|
// 登录
|
||||||
|
@ -80,6 +82,12 @@ const useUserStore = defineStore('user', {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
// 注册部门信息
|
||||||
|
getDeptInfo(){
|
||||||
|
school.registerinfo().then(res=>{
|
||||||
|
this.DeptInfo=res.data || {}
|
||||||
|
})
|
||||||
|
},
|
||||||
// 退出系统
|
// 退出系统
|
||||||
logOut() {
|
logOut() {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
|
|
|
@ -0,0 +1,195 @@
|
||||||
|
<template>
|
||||||
|
<div class="joinschool">
|
||||||
|
<div class="titletext"><span style="font-size:30px;margin-right:30px" class="iconfont icon-tianchongxing-"></span>加入学校</div>
|
||||||
|
<div v-if="userregister.value">
|
||||||
|
<div style="border-bottom:1px solid #eee;padding-bottom:10px;margin-bottom:10px" v-if="userregister.value.auditStatus==0">
|
||||||
|
<img style="margin: 0 auto;height:85px" src="@/assets/images/shenhe.png" alt="">
|
||||||
|
<p style="color:#F59A23;font-size:22px">申请审核中</p>
|
||||||
|
<p style="color:#000;font-size:16px;font-weight:600">申请信息已提交,请耐心等待审核通过即可完成申请。</p>
|
||||||
|
</div>
|
||||||
|
<div style="border:1px solid #000;margin-bottom:20px;background:#DFF0D8" v-if="userregister.value.auditStatus==1">
|
||||||
|
<div style="display: flex;align-items: center;justify-content: center;">
|
||||||
|
<el-result style="padding: 17px 35px;" icon="success"></el-result>
|
||||||
|
<p style="font-size:30px;color:#67C23A">审核通过</p>
|
||||||
|
</div>
|
||||||
|
<p style="margin-bottom:10px;color:#439FFE; cursor: pointer" @click='chongxin'>重新认证</p>
|
||||||
|
</div>
|
||||||
|
<div style="border:1px solid #000;margin-bottom:20px;background:#F2DEDE" v-if="userregister.value.auditStatus==2">
|
||||||
|
<div style="display: flex;align-items: center;justify-content: center;">
|
||||||
|
<el-result style="padding: 17px 35px;" icon="error"></el-result>
|
||||||
|
<p style="font-size:30px;color:#E10A07">申请驳回</p>
|
||||||
|
</div>
|
||||||
|
<p style="margin-bottom:10px;font-size:18px;font-weight:600">申请信息已驳回,请重新提交申请信息。</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="box-item" >
|
||||||
|
<el-form ref="ruleFormRef" label-width="auto" :rules="rules" :model="ruleForm" size="large">
|
||||||
|
<!-- <el-form-item label="所属地区" prop="address">
|
||||||
|
<el-cascader
|
||||||
|
style="width:100%"
|
||||||
|
popper-class="aix-regist-address"
|
||||||
|
:options="regionData"
|
||||||
|
v-model="ruleForm.address"
|
||||||
|
/>
|
||||||
|
</el-form-item> -->
|
||||||
|
<el-form-item label="学校名称" prop="school" >
|
||||||
|
<el-cascader :options="optionsSchool" style="width:100%" v-model="ruleForm.school" :disabled="!isshwoBtn" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="申请人" >
|
||||||
|
{{ state.user.nickName }}
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="申请人电话" >
|
||||||
|
{{ state.user.phonenumber }}
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
|
<el-form-item >
|
||||||
|
<div style="width:100%;text-align: right;padding-right:100px">
|
||||||
|
<el-button style="width:150px" type="default" @click="closed">关闭</el-button>
|
||||||
|
<el-button style="width:150px" type="primary" @click="submitForm(ruleFormRef)" v-if="isshwoBtn">确定</el-button>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup >
|
||||||
|
import { ref, reactive, onMounted ,watch} from 'vue'
|
||||||
|
import { regionData, codeToText } from 'element-china-area-data'
|
||||||
|
import { getUserProfile } from '@/api/system/user'
|
||||||
|
import {getDept} from '@/api/login'
|
||||||
|
import {school} from '@/api/apiService'
|
||||||
|
import { ElMessage } from 'element-plus'
|
||||||
|
import useUserStore from '@/store/modules/user'
|
||||||
|
import { useRouter } from 'vue-router'
|
||||||
|
const router = useRouter()
|
||||||
|
const userStore = useUserStore()
|
||||||
|
const ruleFormRef = ref(null)
|
||||||
|
const isshwoBtn = ref(true)
|
||||||
|
const state = reactive({
|
||||||
|
user: {},
|
||||||
|
})
|
||||||
|
const ruleForm = reactive({
|
||||||
|
school:[],
|
||||||
|
// address:[]
|
||||||
|
})
|
||||||
|
const optionsSchool=ref([])
|
||||||
|
|
||||||
|
const rules = reactive({
|
||||||
|
address:[ {
|
||||||
|
required: true,
|
||||||
|
message: '请选择地址',
|
||||||
|
trigger: 'change',
|
||||||
|
},],
|
||||||
|
school:[{
|
||||||
|
required: true,
|
||||||
|
message: '请选择地址',
|
||||||
|
trigger: 'change',
|
||||||
|
},],
|
||||||
|
})
|
||||||
|
watch (() => userStore.DeptInfo, (newValue, oldValue) => {
|
||||||
|
getregisterinfo()
|
||||||
|
})
|
||||||
|
const userregister = reactive({
|
||||||
|
value:null
|
||||||
|
})
|
||||||
|
const chongxin=()=>{
|
||||||
|
isshwoBtn.value=true
|
||||||
|
}
|
||||||
|
async function getUser() {
|
||||||
|
getUserProfile().then((response) => {
|
||||||
|
// response.data.avatar = import.meta.env.VITE_APP_BASE_API + response.data.avatar
|
||||||
|
Object.assign(state.user,response.data)
|
||||||
|
})
|
||||||
|
|
||||||
|
}
|
||||||
|
const getSchoolList = () => {
|
||||||
|
school.deptTree().then(res=>{
|
||||||
|
optionsSchool.value=res.data
|
||||||
|
optionsSchool.value.forEach(item=>{
|
||||||
|
item.value=item.id
|
||||||
|
if(!item.children){
|
||||||
|
item.disabled=true
|
||||||
|
}
|
||||||
|
if(item.children){
|
||||||
|
item.children.forEach(child=>{
|
||||||
|
child.value=child.id
|
||||||
|
if(!child.children){
|
||||||
|
child.disabled=true
|
||||||
|
}
|
||||||
|
if(child.children){
|
||||||
|
child.children.forEach(grandson=>{
|
||||||
|
grandson.value=grandson.id
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// 提交
|
||||||
|
const submitForm = async (formEl) => {
|
||||||
|
if (!formEl) return
|
||||||
|
await formEl.validate((valid, fields) => {
|
||||||
|
if (valid) {
|
||||||
|
// const araname = codeToText[ruleForm.address[0]] + '-' + codeToText[ruleForm.address[1]] + '-' + codeToText[ruleForm.address[2]];
|
||||||
|
const form={
|
||||||
|
schoolId:ruleForm.school[2],
|
||||||
|
// areaIds:ruleForm.address.join(','),
|
||||||
|
// area:araname
|
||||||
|
}
|
||||||
|
school.schoolJoin(form).then(async res=>{
|
||||||
|
if(res.code==200){
|
||||||
|
ElMessage.success('提交成功')
|
||||||
|
await userStore.getDeptInfo()
|
||||||
|
|
||||||
|
}
|
||||||
|
})
|
||||||
|
console.log('submit!')
|
||||||
|
} else {
|
||||||
|
console.log('error submit!', fields)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
const getregisterinfo=()=>{
|
||||||
|
if(!(Object.keys(userStore.DeptInfo).length === 0 && userStore.DeptInfo.constructor === Object)){
|
||||||
|
if(userStore.DeptInfo.register.type==4) return
|
||||||
|
userregister.value=userStore.DeptInfo.register
|
||||||
|
getDept({deptId:userStore.DeptInfo.register.schoolId}).then(res1=>{
|
||||||
|
const arr=(res1?.data?.ancestors || '').split(',')
|
||||||
|
arr.shift()
|
||||||
|
arr.push(userStore.DeptInfo.register.schoolId)
|
||||||
|
ruleForm.school=arr.map(Number)
|
||||||
|
})
|
||||||
|
if(userStore.DeptInfo.register.auditStatus==0 || userStore.DeptInfo.register.auditStatus==1){
|
||||||
|
isshwoBtn.value=false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
// 关闭
|
||||||
|
const closed=()=>{
|
||||||
|
if (ruleFormRef.value) ruleFormRef.value.resetFields()
|
||||||
|
router.push("/home")
|
||||||
|
}
|
||||||
|
onMounted(async () => {
|
||||||
|
getUser()
|
||||||
|
getSchoolList()
|
||||||
|
await userStore.getDeptInfo()
|
||||||
|
getregisterinfo()
|
||||||
|
})
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
.joinschool{
|
||||||
|
padding: 20px;
|
||||||
|
background: #fff;
|
||||||
|
.titletext{
|
||||||
|
text-align: left;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
font-size: 30px;
|
||||||
|
margin-bottom: 30px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -6,7 +6,7 @@
|
||||||
</div>
|
</div>
|
||||||
<img class="welcome-img" :src="leftBg2" />
|
<img class="welcome-img" :src="leftBg2" />
|
||||||
</div>
|
</div>
|
||||||
<div class="box-item login">
|
<div class="box-item login" v-if="isRegister">
|
||||||
<WindowTools :is-has-max="false" />
|
<WindowTools :is-has-max="false" />
|
||||||
<div class="login-title">账号登录</div>
|
<div class="login-title">账号登录</div>
|
||||||
<el-form ref="formRef" class="login-form" :model="loginForm" :rules="rules" size="large">
|
<el-form ref="formRef" class="login-form" :model="loginForm" :rules="rules" size="large">
|
||||||
|
@ -25,9 +25,30 @@
|
||||||
<el-button :loading="btnLoading" class="btn" type="primary" @click="submitForm(formRef)">登录</el-button>
|
<el-button :loading="btnLoading" class="btn" type="primary" @click="submitForm(formRef)">登录</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<div class="flex mb-4" style="display: flex;justify-content: center;color: #ccc;cursor: pointer;">
|
<div class="flex mb-4" style="display: flex;justify-content: center;color: #ccc;cursor: pointer;">
|
||||||
<a class="hover:text-sky-500" style="margin-right: 10px;" @click="RegisterModel(1)">注册账号</a>
|
<a class="hover:text-sky-500" style="margin-right: 10px;" @click="gotoreRegister">注册账号</a>
|
||||||
|
|
</div>
|
||||||
<a class="hover:text-sky-500" style="margin-left: 10px;" @click="RegisterModel(2)">忘记密码</a>
|
</el-form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="box-item login" v-else>
|
||||||
|
<WindowTools :is-has-max="false" />
|
||||||
|
<div class="login-title">账号注册</div>
|
||||||
|
<el-form ref="ruleFormRef" class="login-form" :model="ruleForm" label-width="auto" :rules="rules" size="large">
|
||||||
|
<el-form-item label="手机号" prop="username">
|
||||||
|
<el-input v-model="ruleForm.username" placeholder="请输入手机号" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="验证码" prop="smsCode">
|
||||||
|
<el-input style="width:185px" v-model="ruleForm.smsCode" placeholder="请输入验证码" /><el-button :disabled="codeName!='发送验证码'" type="primary" @click="sendyzm">{{ codeName }}</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="密码" prop="password" >
|
||||||
|
<el-input autocomplete="on" type="password" v-model="ruleForm.password" placeholder="请输入密码" />
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
|
<el-form-item>
|
||||||
|
<el-button class="btn" type="primary" @click="RegisterForm(ruleFormRef)">立即注册</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
<div class="flex mb-4" style="display: flex;justify-content: center;color: #ccc;cursor: pointer;">
|
||||||
|
<a class="hover:text-sky-500" style="margin-right: 10px;" @click="gotoLogin"> 《 返回登录 </a>
|
||||||
</div>
|
</div>
|
||||||
</el-form>
|
</el-form>
|
||||||
</div>
|
</div>
|
||||||
|
@ -52,6 +73,7 @@ import WindowTools from '@/components/window-tools/index.vue'
|
||||||
import SelectSubject from '@/components/select-subject/index.vue'
|
import SelectSubject from '@/components/select-subject/index.vue'
|
||||||
import Register from './components/Register.vue'
|
import Register from './components/Register.vue'
|
||||||
import { sessionStore } from '@/utils/store'
|
import { sessionStore } from '@/utils/store'
|
||||||
|
import {sendcode,instructorregister} from '@/api/login'
|
||||||
|
|
||||||
const { session } = require('@electron/remote')
|
const { session } = require('@electron/remote')
|
||||||
const downloadProp = ref(0)
|
const downloadProp = ref(0)
|
||||||
|
@ -62,17 +84,25 @@ const userStore = useUserStore()
|
||||||
const btnLoading = ref(false)
|
const btnLoading = ref(false)
|
||||||
const isSubject = ref(false)
|
const isSubject = ref(false)
|
||||||
const RegModel = ref(false)
|
const RegModel = ref(false)
|
||||||
|
const isRegister = ref(true)
|
||||||
|
const ruleFormRef = ref(null)
|
||||||
|
const codeName=ref('发送验证码')
|
||||||
|
const timer=ref(null)
|
||||||
//表单
|
//表单
|
||||||
const loginForm = reactive({
|
const loginForm = reactive({
|
||||||
username: '',
|
username: '',
|
||||||
password: '',
|
password: '',
|
||||||
rememberMe: false
|
rememberMe: false
|
||||||
})
|
})
|
||||||
|
// 注册表单
|
||||||
|
const ruleForm = reactive({
|
||||||
|
|
||||||
|
})
|
||||||
//表单规则
|
//表单规则
|
||||||
const rules = reactive({
|
const rules = reactive({
|
||||||
username: [{ required: true, trigger: 'blur', message: '请输入您的账号' }],
|
username: [{ required: true, trigger: 'blur', message: '请输入您的账号' }],
|
||||||
password: [{ required: true, trigger: 'blur', message: '请输入您的密码' }]
|
password: [{ required: true, trigger: 'blur', message: '请输入您的密码' }],
|
||||||
|
smsCode: [{ required: true, trigger: 'blur', message: '请输入您的验证码' }],
|
||||||
})
|
})
|
||||||
|
|
||||||
let curWinUrl = import.meta.env.VITE_APP_BUILD_BASE_PATH
|
let curWinUrl = import.meta.env.VITE_APP_BUILD_BASE_PATH
|
||||||
|
@ -81,6 +111,43 @@ ipcRenderer.on('update-app-progress', (e, prop) => {
|
||||||
downloadProp.value = prop
|
downloadProp.value = prop
|
||||||
showDownLoading.value = prop !== 100
|
showDownLoading.value = prop !== 100
|
||||||
})
|
})
|
||||||
|
const gotoreRegister=()=>{
|
||||||
|
codeName.value='发送验证码'
|
||||||
|
if(timer.value){
|
||||||
|
clearInterval(timer.value);
|
||||||
|
}
|
||||||
|
isRegister.value=false
|
||||||
|
}
|
||||||
|
// 发送验证码
|
||||||
|
const sendyzm=()=>{
|
||||||
|
if(ruleForm.username){
|
||||||
|
const pattern = /^1[3-9]\d{9}$/;
|
||||||
|
if( pattern.test(ruleForm.username) ){
|
||||||
|
sendcode({username:ruleForm.username, source: '4'}).then(res=>{
|
||||||
|
if(res.code==200){
|
||||||
|
ElMessage.success('消息发送成功')
|
||||||
|
codeName.value=60
|
||||||
|
timer.value=setInterval(()=>{
|
||||||
|
codeName.value--
|
||||||
|
if(codeName.value==0){
|
||||||
|
codeName.value='发送验证码'
|
||||||
|
clearInterval(timer.value);
|
||||||
|
}
|
||||||
|
},1000)
|
||||||
|
}else{
|
||||||
|
ElMessage.error(res.msg)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}else{
|
||||||
|
ElMessage.error('请输入正确的手机号码')
|
||||||
|
}
|
||||||
|
// captchaImg({mobile:ruleForm.phoneNumber}).then(res=>{
|
||||||
|
// console.log('res->', res)
|
||||||
|
// })
|
||||||
|
}else{
|
||||||
|
ElMessage.error('请输入手机号码')
|
||||||
|
}
|
||||||
|
}
|
||||||
// 打开弹窗
|
// 打开弹窗
|
||||||
const RegisterModel = type => {
|
const RegisterModel = type => {
|
||||||
RegModel.value.OpenModel(type)
|
RegModel.value.OpenModel(type)
|
||||||
|
@ -148,7 +215,31 @@ const setCookie = (name, value) => {
|
||||||
}
|
}
|
||||||
return session.defaultSession.cookies.set(cookie)
|
return session.defaultSession.cookies.set(cookie)
|
||||||
}
|
}
|
||||||
|
const gotoLogin = () => {
|
||||||
|
codeName.value='发送验证码'
|
||||||
|
if (ruleFormRef.value) ruleFormRef.value.resetFields()
|
||||||
|
isRegister.value = true
|
||||||
|
}
|
||||||
|
// 注册
|
||||||
|
const RegisterForm = async (formEl) => {
|
||||||
|
if (!formEl) return
|
||||||
|
await formEl.validate((valid, fields) => {
|
||||||
|
if (valid) {
|
||||||
|
instructorregister(ruleForm).then(res=>{
|
||||||
|
if(res.code==200){
|
||||||
|
ElMessage.success('您已注册成功')
|
||||||
|
if (ruleFormRef.value) ruleFormRef.value.resetFields()
|
||||||
|
gotoLogin()
|
||||||
|
}else{
|
||||||
|
ElMessage.error(res.msg)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
console.log('submit!')
|
||||||
|
} else {
|
||||||
|
console.log('error submit!', fields)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
localStorage.clear()
|
localStorage.clear()
|
||||||
sessionStore.set('subject', {
|
sessionStore.set('subject', {
|
||||||
|
|
|
@ -0,0 +1,206 @@
|
||||||
|
<template>
|
||||||
|
<div class="joinschool">
|
||||||
|
<div class="titletext"><span style="font-size:30px;margin-right:30px" class="iconfont icon-tianchongxing-"></span>学校认证</div>
|
||||||
|
<div v-if="userregister.value">
|
||||||
|
<div style="border-bottom:1px solid #eee;padding-bottom:10px;margin-bottom:10px" v-if="userregister.value.auditStatus==0">
|
||||||
|
<img style="margin: 0 auto;height:85px" src="@/assets/images/shenhe.png" alt="">
|
||||||
|
<p style="color:#F59A23;font-size:22px">申请审核中</p>
|
||||||
|
<p style="color:#000;font-size:16px;font-weight:600">申请信息已提交,请耐心等待审核通过即可完成申请。</p>
|
||||||
|
</div>
|
||||||
|
<div style="border:1px solid #000;margin-bottom:20px;background:#DFF0D8" v-if="userregister.value.auditStatus==1">
|
||||||
|
<div style="display: flex;align-items: center;justify-content: center;">
|
||||||
|
<el-result style="padding: 17px 35px;" icon="success"></el-result>
|
||||||
|
<p style="font-size:30px;color:#67C23A">审核通过</p>
|
||||||
|
</div>
|
||||||
|
<p style="margin-bottom:10px;color:#439FFE; cursor: pointer">重新认证</p>
|
||||||
|
</div>
|
||||||
|
<div style="border:1px solid #000;margin-bottom:20px;background:#F2DEDE" v-if="userregister.value.auditStatus==2">
|
||||||
|
<div style="display: flex;align-items: center;justify-content: center;">
|
||||||
|
<el-result style="padding: 17px 35px;" icon="error"></el-result>
|
||||||
|
<p style="font-size:30px;color:#E10A07">申请驳回</p>
|
||||||
|
</div>
|
||||||
|
<p style="margin-bottom:10px;font-size:18px;font-weight:600">申请信息已驳回,请重新提交申请信息。</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="box-item" :style="userregister.value?'':'margin-top:30px'" >
|
||||||
|
<el-form ref="ruleFormRef" label-width="auto" :rules="rules" :model="ruleForm" size="large" >
|
||||||
|
<el-form-item label="学校名称" prop="schoolName" >
|
||||||
|
<el-input v-model="ruleForm.schoolName" placeholder="请输入学校名称" :disabled="!isshwoBtn" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="所属地区" prop="address">
|
||||||
|
<el-cascader
|
||||||
|
:disabled="!isshwoBtn"
|
||||||
|
style="width:100%"
|
||||||
|
popper-class="aix-regist-address"
|
||||||
|
:options="regionData"
|
||||||
|
v-model="ruleForm.address"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="事业单位法人证书号" prop="certNum" >
|
||||||
|
<el-input v-model="ruleForm.certNum" placeholder="请输入事业单位法人证书号" :disabled="!isshwoBtn" />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="经办人" >
|
||||||
|
{{ state.user.nickName }}
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="经办人电话" >
|
||||||
|
{{ state.user.phonenumber }}
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
|
<el-form-item >
|
||||||
|
<div style="display:flex;align-items:center;justify-content: space-between;padding-right:100px; width: 100%;">
|
||||||
|
<div style="display:flex;align-items:center;">
|
||||||
|
<el-checkbox style="margin: 0px 10px 0px 55px" v-model="ruleForm.istrue" size="large" :disabled="!isshwoBtn" /> 以上信息真实有效,勾选后提交
|
||||||
|
</div>
|
||||||
|
<div >
|
||||||
|
<el-button style="width:150px" type="default" @click="closed">关闭</el-button>
|
||||||
|
<el-button style="width:150px" type="primary" @click="submitForm(ruleFormRef)" v-if="isshwoBtn">确定</el-button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup >
|
||||||
|
import { ref, reactive, onMounted,watch } from 'vue'
|
||||||
|
import { regionData, codeToText } from 'element-china-area-data'
|
||||||
|
import { getUserProfile } from '@/api/system/user'
|
||||||
|
import {getDept} from '@/api/login'
|
||||||
|
import {school} from '@/api/apiService'
|
||||||
|
import { ElMessage } from 'element-plus'
|
||||||
|
import { useRouter } from 'vue-router'
|
||||||
|
import useUserStore from '@/store/modules/user'
|
||||||
|
const userStore = useUserStore()
|
||||||
|
|
||||||
|
const isshwoBtn=ref(true)
|
||||||
|
const router = useRouter()
|
||||||
|
const state = reactive({
|
||||||
|
user: {},
|
||||||
|
})
|
||||||
|
const userregister = reactive({
|
||||||
|
value:null
|
||||||
|
})
|
||||||
|
const ruleFormRef=ref(null)
|
||||||
|
const ruleForm = reactive({
|
||||||
|
school:[],
|
||||||
|
address:[],
|
||||||
|
schoolName:null,
|
||||||
|
istrue:false
|
||||||
|
})
|
||||||
|
const optionsSchool=ref([])
|
||||||
|
|
||||||
|
const rules = reactive({
|
||||||
|
address:[ {
|
||||||
|
required: true,
|
||||||
|
message: '请选择地址',
|
||||||
|
trigger: 'change',
|
||||||
|
},],
|
||||||
|
certNum:[{ required: true, message: '请输入证书号', trigger: 'blur' }],
|
||||||
|
schoolName:[ { required: true, message: '请输入学校名称', trigger: 'blur' },]
|
||||||
|
})
|
||||||
|
async function getUser() {
|
||||||
|
getUserProfile().then((response) => {
|
||||||
|
// response.data.avatar = import.meta.env.VITE_APP_BASE_API + response.data.avatar
|
||||||
|
Object.assign(state.user,response.data)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
watch (() => userStore.DeptInfo, (newValue, oldValue) => {
|
||||||
|
getregisterinfo()
|
||||||
|
})
|
||||||
|
const getregisterinfo=()=>{
|
||||||
|
if(!(Object.keys(userStore.DeptInfo || {}).length === 0 && userStore.DeptInfo.constructor === Object)){
|
||||||
|
if(userStore.DeptInfo.register.type==3) return
|
||||||
|
userregister.value=userStore.DeptInfo.register
|
||||||
|
ruleForm.schoolName=userStore.DeptInfo.register.schoolName
|
||||||
|
ruleForm.certNum=userStore.DeptInfo.register.certNum
|
||||||
|
ruleForm.istrue=true
|
||||||
|
ruleForm.address=userStore.DeptInfo.register.areaIds.split(",")
|
||||||
|
if(userStore.DeptInfo.register.auditStatus==0 || userStore.DeptInfo.register.auditStatus==1){
|
||||||
|
isshwoBtn.value=false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const getSchoolList = () => {
|
||||||
|
school.deptTree().then(res=>{
|
||||||
|
optionsSchool.value=res.data
|
||||||
|
optionsSchool.value.forEach(item=>{
|
||||||
|
item.value=item.id
|
||||||
|
if(!item.children){
|
||||||
|
item.disabled=true
|
||||||
|
}
|
||||||
|
if(item.children){
|
||||||
|
item.children.forEach(child=>{
|
||||||
|
child.value=child.id
|
||||||
|
if(!child.children){
|
||||||
|
child.disabled=true
|
||||||
|
}
|
||||||
|
if(child.children){
|
||||||
|
child.children.forEach(grandson=>{
|
||||||
|
grandson.value=grandson.id
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// 提交
|
||||||
|
const submitForm = async (formEl) => {
|
||||||
|
if (!formEl) return
|
||||||
|
await formEl.validate((valid, fields) => {
|
||||||
|
if (valid) {
|
||||||
|
if(!ruleForm.istrue) {
|
||||||
|
ElMessage.error('请勾选以上信息真实有效的复选框')
|
||||||
|
return
|
||||||
|
}
|
||||||
|
const araname = codeToText[ruleForm.address[0]] + '-' + codeToText[ruleForm.address[1]] + '-' + codeToText[ruleForm.address[2]];
|
||||||
|
const form={
|
||||||
|
schoolName:ruleForm.schoolName,
|
||||||
|
certNum:ruleForm.certNum,
|
||||||
|
areaIds:ruleForm.address.join(','),
|
||||||
|
area:araname
|
||||||
|
}
|
||||||
|
school.schoolJoin(form).then(async res=>{
|
||||||
|
if(res.code==200){
|
||||||
|
ElMessage.success('提交成功')
|
||||||
|
await userStore.getDeptInfo()
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
})
|
||||||
|
console.log('submit!')
|
||||||
|
} else {
|
||||||
|
console.log('error submit!', fields)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// 关闭
|
||||||
|
const closed=()=>{
|
||||||
|
if (ruleFormRef.value) ruleFormRef.value.resetFields()
|
||||||
|
router.push("/home")
|
||||||
|
}
|
||||||
|
onMounted(() => {
|
||||||
|
getUser()
|
||||||
|
getregisterinfo()
|
||||||
|
getSchoolList()
|
||||||
|
|
||||||
|
|
||||||
|
})
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
.joinschool{
|
||||||
|
padding: 20px;
|
||||||
|
background: #fff;
|
||||||
|
.titletext{
|
||||||
|
text-align: left;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
font-size: 30px;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -0,0 +1,197 @@
|
||||||
|
<template>
|
||||||
|
<div class="schoolManagement">
|
||||||
|
<div class="titletext">学校管理</div>
|
||||||
|
<div class="searchInput">
|
||||||
|
<div class="mr10">学校名称</div>
|
||||||
|
<el-input v-model="searchValue.schoolName" class="mr10" style="width: 240px" placeholder="请输入学校名称" />
|
||||||
|
<div class="mr10">所属区域</div>
|
||||||
|
<el-cascader
|
||||||
|
style="width: 240px;margin-right:10px"
|
||||||
|
:options="regionData"
|
||||||
|
v-model="address"
|
||||||
|
:props="{ checkStrictly: true }"
|
||||||
|
clearable
|
||||||
|
/>
|
||||||
|
<div class="mr10">审核状态</div>
|
||||||
|
<el-radio-group v-model="searchValue.status" class="mr10">
|
||||||
|
<el-radio :value="-1">全部</el-radio>
|
||||||
|
<el-radio :value="0">审核中</el-radio>
|
||||||
|
<el-radio :value="1">已通过</el-radio>
|
||||||
|
<el-radio :value="2">已驳回</el-radio>
|
||||||
|
</el-radio-group>
|
||||||
|
<el-button type="primary" @click="search">搜索</el-button>
|
||||||
|
</div>
|
||||||
|
<el-table :data="tableData" style="width: 100%">
|
||||||
|
<el-table-column prop="schoolName" label="学校名称" width="180" />
|
||||||
|
<el-table-column prop="area" label="所属地区" width="180" />
|
||||||
|
<el-table-column prop="certNum" label="事业单位法人证件号" />
|
||||||
|
<el-table-column prop="name" label="联系人" />
|
||||||
|
<el-table-column prop="mobile" label="联系电话" />
|
||||||
|
<el-table-column prop="status" label="审核状态">
|
||||||
|
<template #default="scope">
|
||||||
|
{{scope.row.status==0?'审核中':scope.row.status==1?'已通过':'已驳回' }}
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column prop="Operations" label="操作">
|
||||||
|
<template #default="scope">
|
||||||
|
<a v-if="scope.row.status==0" style="color:#04A8F0;cursor: pointer;" @click="audit(scope.row)">审核</a>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
|
<el-pagination style="margin-top:10px;float: right;" background layout="prev, pager, next" @size-change="handleSizeChange"
|
||||||
|
@current-change="handleCurrentChange" :default-page-size="searchValue.pageSize" v-model:current-page="searchValue.pageNum" :total="total" />
|
||||||
|
|
||||||
|
<el-dialog
|
||||||
|
v-model="dialogVisible"
|
||||||
|
title="加入学校审核"
|
||||||
|
width="500"
|
||||||
|
style="text-align: left;"
|
||||||
|
:before-close="handleClose"
|
||||||
|
>
|
||||||
|
<div style="margin-left:20px" class="formdialog">
|
||||||
|
审核状态:
|
||||||
|
<el-radio-group v-model="form.status" class="mr10">
|
||||||
|
<el-radio :value="1">通过</el-radio>
|
||||||
|
<el-radio :value="2">拒绝</el-radio>
|
||||||
|
</el-radio-group>
|
||||||
|
</div>
|
||||||
|
<div style="margin-left:20px;margin-top:30px" class="formdialog">
|
||||||
|
审核理由:
|
||||||
|
<el-input
|
||||||
|
v-model="form.auditMsg"
|
||||||
|
style="width: 300px"
|
||||||
|
:rows="3"
|
||||||
|
type="textarea"
|
||||||
|
placeholder="请输入理由"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<template #footer>
|
||||||
|
<div class="dialog-footer">
|
||||||
|
<el-button @click="dialogVisible = false">取消</el-button>
|
||||||
|
<el-button type="primary" @click="sbmitform">
|
||||||
|
确定
|
||||||
|
</el-button>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-dialog>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import { school } from '@/api/apiService';
|
||||||
|
import { ref, reactive, onMounted ,computed} from 'vue'
|
||||||
|
import { regionData, codeToText } from 'element-china-area-data'
|
||||||
|
import { ElMessage } from 'element-plus'
|
||||||
|
import useUserStore from '@/store/modules/user'
|
||||||
|
const userStore = useUserStore()
|
||||||
|
const searchValue = reactive({
|
||||||
|
status:-1,
|
||||||
|
schoolName:null,
|
||||||
|
pageNum:1,
|
||||||
|
pageSize:10,
|
||||||
|
type:3
|
||||||
|
})
|
||||||
|
const id=ref(null)
|
||||||
|
const address=ref([])
|
||||||
|
const total=ref(0)
|
||||||
|
const tableData = ref([])
|
||||||
|
const dialogVisible=ref(false)
|
||||||
|
const form=reactive({
|
||||||
|
status:'1',
|
||||||
|
auditMsg:null,
|
||||||
|
id:null,
|
||||||
|
ex1:null
|
||||||
|
})
|
||||||
|
const sbmitform=()=>{
|
||||||
|
if(!form.auditMsg){
|
||||||
|
return ElMessage.error('请输入理由')
|
||||||
|
}
|
||||||
|
school.checkSchool(form).then(res=>{
|
||||||
|
dialogVisible.value=false
|
||||||
|
form.auditMsg=null
|
||||||
|
form.status=1
|
||||||
|
getList()
|
||||||
|
userStore.getDeptInfo()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
const filterNullProperties=(obj)=> {
|
||||||
|
const newObj = {};
|
||||||
|
for (const key in obj) {
|
||||||
|
if (obj[key] !== null && obj[key] != 'null' && obj[key] !== undefined) {
|
||||||
|
newObj[key] = obj[key];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return newObj;
|
||||||
|
}
|
||||||
|
const search=()=>{
|
||||||
|
searchValue.pageNum=1
|
||||||
|
getList()
|
||||||
|
}
|
||||||
|
const handleCurrentChange=()=>{
|
||||||
|
getList()
|
||||||
|
}
|
||||||
|
const handleSizeChange=()=>{
|
||||||
|
getList()
|
||||||
|
}
|
||||||
|
const handleClose=()=>{
|
||||||
|
form.id=null
|
||||||
|
form.ex1=null
|
||||||
|
form.auditMsg=null
|
||||||
|
form.status=1
|
||||||
|
dialogVisible.value=false
|
||||||
|
}
|
||||||
|
const formattedAddress = () => {
|
||||||
|
if (typeof address.value === 'undefined' || address.value?.length === 0) {
|
||||||
|
return null; // 如果数组为空,则返回空字符串
|
||||||
|
}
|
||||||
|
return address.value.map(code => codeToText[code]).join('-'); // 使用'-'连接数组元素
|
||||||
|
}
|
||||||
|
const getList = () =>{
|
||||||
|
const area=formattedAddress()
|
||||||
|
searchValue.area=area
|
||||||
|
let obj= filterNullProperties(searchValue)
|
||||||
|
|
||||||
|
school.auditlist(obj).then(res=>{
|
||||||
|
tableData.value=res.rows
|
||||||
|
total.value=res.total
|
||||||
|
})
|
||||||
|
}
|
||||||
|
const audit=(row)=>{
|
||||||
|
form.id=row.id
|
||||||
|
form.ex1=row.ex1
|
||||||
|
form.auditMsg=null
|
||||||
|
form.status=1
|
||||||
|
dialogVisible.value=true
|
||||||
|
}
|
||||||
|
onMounted(()=>{
|
||||||
|
console.log(searchValue)
|
||||||
|
getList()
|
||||||
|
})
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped scss>
|
||||||
|
.schoolManagement{
|
||||||
|
padding: 20px;
|
||||||
|
background: #fff;
|
||||||
|
padding-bottom: 50px;
|
||||||
|
}
|
||||||
|
.titletext{
|
||||||
|
text-align: left;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
font-size: 30px;
|
||||||
|
margin-bottom: 30px;
|
||||||
|
}
|
||||||
|
.searchInput{
|
||||||
|
display: flex;
|
||||||
|
align-items:center;
|
||||||
|
margin-bottom: 20px;
|
||||||
|
}
|
||||||
|
.mr10{
|
||||||
|
margin-right: 10px;
|
||||||
|
}
|
||||||
|
.formdialog{
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
</style>
|
Loading…
Reference in New Issue