Commit 71e79bbf authored by szh's avatar szh

update

parent adaea545
...@@ -346,7 +346,16 @@ func (courseActionUsersApi *CourseActionUsersApi) WebSignAction(c *gin.Context) ...@@ -346,7 +346,16 @@ func (courseActionUsersApi *CourseActionUsersApi) WebSignAction(c *gin.Context)
response.FailWithMessage(err.Error(), c) response.FailWithMessage(err.Error(), c)
return return
} }
// 检查课程活动 信息
if !*actionInfo.IsShow {
response.FailWithMessage("活动已下线", c)
return
}
if actionInfo.ActionEnd.Unix() < time.Now().Unix() {
response.FailWithMessage("活动已结束", c)
return
}
user,err := courseUsersService.GetCourseUsersByAddr(claims.Username) user,err := courseUsersService.GetCourseUsersByAddr(claims.Username)
if err != nil { if err != nil {
response.FailWithMessage(err.Error(), c) response.FailWithMessage(err.Error(), c)
...@@ -370,25 +379,6 @@ func (courseActionUsersApi *CourseActionUsersApi) WebSignAction(c *gin.Context) ...@@ -370,25 +379,6 @@ func (courseActionUsersApi *CourseActionUsersApi) WebSignAction(c *gin.Context)
return return
} }
// 检查课程活动 信息
courseAction,err := courseActionService.GetCourseAction(uint(*actionInfo.Cid))
if err != nil {
response.FailWithMessage(err.Error(), c)
return
}
if !*courseAction.IsShow {
response.FailWithMessage("活动已下线", c)
return
}
if courseAction.ActionEnd.Unix() < time.Now().Unix() {
response.FailWithMessage("活动已结束", c)
return
}
courseSign,err := courseSignupService.GetCourseSignupByUidAndCid(uint(*actionInfo.Cid),user.ID) courseSign,err := courseSignupService.GetCourseSignupByUidAndCid(uint(*actionInfo.Cid),user.ID)
if err != nil && err != gorm.ErrRecordNotFound { if err != nil && err != gorm.ErrRecordNotFound {
response.FailWithMessage(err.Error(), c) response.FailWithMessage(err.Error(), c)
...@@ -450,6 +440,18 @@ func (courseActionUsersApi *CourseActionUsersApi) WebSignActionSimple(c *gin.Con ...@@ -450,6 +440,18 @@ func (courseActionUsersApi *CourseActionUsersApi) WebSignActionSimple(c *gin.Con
return return
} }
// 检查课程活动 信息
if !*actionInfo.IsShow {
response.FailWithMessage("活动已下线", c)
return
}
if actionInfo.ActionEnd.Unix() < time.Now().Unix() {
response.FailWithMessage("活动已结束", c)
return
}
user,err := courseUsersService.GetCourseUsersByAddr(address) user,err := courseUsersService.GetCourseUsersByAddr(address)
if err != nil { if err != nil {
response.FailWithMessage(err.Error(), c) response.FailWithMessage(err.Error(), c)
...@@ -473,25 +475,6 @@ func (courseActionUsersApi *CourseActionUsersApi) WebSignActionSimple(c *gin.Con ...@@ -473,25 +475,6 @@ func (courseActionUsersApi *CourseActionUsersApi) WebSignActionSimple(c *gin.Con
return return
} }
// 检查课程活动 信息
courseAction,err := courseActionService.GetCourseAction(uint(*actionInfo.Cid))
if err != nil {
response.FailWithMessage(err.Error(), c)
return
}
if !*courseAction.IsShow {
response.FailWithMessage("活动已下线", c)
return
}
if courseAction.ActionEnd.Unix() < time.Now().Unix() {
response.FailWithMessage("活动已结束", c)
return
}
courseSign,err := courseSignupService.GetCourseSignupByUidAndCid(uint(*actionInfo.Cid),user.ID) courseSign,err := courseSignupService.GetCourseSignupByUidAndCid(uint(*actionInfo.Cid),user.ID)
if err != nil && err != gorm.ErrRecordNotFound { if err != nil && err != gorm.ErrRecordNotFound {
response.FailWithMessage(err.Error(), c) response.FailWithMessage(err.Error(), c)
......
...@@ -11,6 +11,9 @@ ...@@ -11,6 +11,9 @@
}, },
"dependencies": { "dependencies": {
"@element-plus/icons-vue": "^0.2.7", "@element-plus/icons-vue": "^0.2.7",
"@vueup/vue-quill": "^1.2.0",
"@wangeditor/editor": "^5.1.23",
"@wangeditor/editor-for-vue": "^5.1.12",
"axios": "^0.19.2", "axios": "^0.19.2",
"core-js": "^3.6.5", "core-js": "^3.6.5",
"echarts": "5.3.2", "echarts": "5.3.2",
...@@ -27,7 +30,8 @@ ...@@ -27,7 +30,8 @@
"spark-md5": "^3.0.1", "spark-md5": "^3.0.1",
"vue": "^3.2.25", "vue": "^3.2.25",
"vue-quill-editor": "^3.0.6", "vue-quill-editor": "^3.0.6",
"vue-router": "^4.0.0-0" "vue-router": "^4.0.0-0",
"vue2-editor": "^2.10.3"
}, },
"devDependencies": { "devDependencies": {
"@vitejs/plugin-legacy": "^2.0.0", "@vitejs/plugin-legacy": "^2.0.0",
...@@ -51,5 +55,10 @@ ...@@ -51,5 +55,10 @@
"vite": "^3.0.1", "vite": "^3.0.1",
"vite-plugin-banner": "^0.1.3", "vite-plugin-banner": "^0.1.3",
"vite-plugin-importer": "^0.2.5" "vite-plugin-importer": "^0.2.5"
},
"eslintConfig": {
"env": {
"vue/setup-compiler-macros": true
}
} }
} }
...@@ -14,9 +14,7 @@ import 'element-plus/es/components/loading/style/css' ...@@ -14,9 +14,7 @@ import 'element-plus/es/components/loading/style/css'
import 'element-plus/es/components/notification/style/css' import 'element-plus/es/components/notification/style/css'
import 'element-plus/es/components/message-box/style/css' import 'element-plus/es/components/message-box/style/css'
import './style/element_visiable.scss' import './style/element_visiable.scss'
//
import VueQuillEditor from 'vue-quill-editor'
import 'quill/dist/quill.snow.css'
initDom() initDom()
/** /**
...@@ -40,7 +38,6 @@ app ...@@ -40,7 +38,6 @@ app
.use(store) .use(store)
.use(auth) .use(auth)
.use(router) .use(router)
.use(VueQuillEditor)
.mount('#app') .mount('#app')
export default app export default app
...@@ -3,9 +3,9 @@ ...@@ -3,9 +3,9 @@
<div class="gva-search-box"> <div class="gva-search-box">
<el-form :inline="true" :model="searchInfo" class="demo-form-inline" @keyup.enter="onSubmit"> <el-form :inline="true" :model="searchInfo" class="demo-form-inline" @keyup.enter="onSubmit">
<el-form-item label="创建时间"> <el-form-item label="创建时间">
<el-date-picker v-model="searchInfo.startCreatedAt" type="datetime" placeholder="开始时间"></el-date-picker> <el-date-picker v-model="searchInfo.startCreatedAt" type="datetime" placeholder="开始时间" />
<el-date-picker v-model="searchInfo.endCreatedAt" type="datetime" placeholder="结束时间"></el-date-picker> <el-date-picker v-model="searchInfo.endCreatedAt" type="datetime" placeholder="结束时间" />
</el-form-item> </el-form-item>
<el-form-item label="课程名称"> <el-form-item label="课程名称">
<el-input v-model="searchInfo.courseName" placeholder="搜索条件" /> <el-input v-model="searchInfo.courseName" placeholder="搜索条件" />
...@@ -16,13 +16,13 @@ ...@@ -16,13 +16,13 @@
<el-option <el-option
key="true" key="true"
label="是" label="是"
value="true"> value="true"
</el-option> />
<el-option <el-option
key="false" key="false"
label="否" label="否"
value="false"> value="false"
</el-option> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
...@@ -58,8 +58,7 @@ ...@@ -58,8 +58,7 @@
<template #default="scope">{{ formatDate(scope.row.CreatedAt) }}</template> <template #default="scope">{{ formatDate(scope.row.CreatedAt) }}</template>
</el-table-column> </el-table-column>
<el-table-column align="left" label="课程名称" prop="courseName" width="120" /> <el-table-column align="left" label="课程名称" prop="courseName" width="120" />
<el-table-column align="left" label="课程描述" prop="courseDesc" width="360" show-overflow-tooltip> <el-table-column align="left" label="课程描述" prop="courseDesc" width="360" show-overflow-tooltip />
</el-table-column>
<el-table-column align="left" label="banner图" prop="courseBanner" width="120" /> <el-table-column align="left" label="banner图" prop="courseBanner" width="120" />
<el-table-column align="left" label="状态 0 不显示 1 显示" prop="isShow" width="120"> <el-table-column align="left" label="状态 0 不显示 1 显示" prop="isShow" width="120">
<template #default="scope">{{ formatBoolean(scope.row.isShow) }}</template> <template #default="scope">{{ formatBoolean(scope.row.isShow) }}</template>
...@@ -68,7 +67,7 @@ ...@@ -68,7 +67,7 @@
<template #default="scope"> <template #default="scope">
<el-button type="primary" link icon="edit" class="table-button" @click="updateCourseListFunc(scope.row)">变更</el-button> <el-button type="primary" link icon="edit" class="table-button" @click="updateCourseListFunc(scope.row)">变更</el-button>
<el-button type="primary" link icon="plus" @click="toCourseAction(scope.row)">活动管理</el-button> <el-button type="primary" link icon="plus" @click="toCourseAction(scope.row)">活动管理</el-button>
<!-- <el-button type="primary" link icon="delete" @click="deleteRow(scope.row)">删除</el-button>--> <!-- <el-button type="primary" link icon="delete" @click="deleteRow(scope.row)">删除</el-button>-->
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
...@@ -84,31 +83,29 @@ ...@@ -84,31 +83,29 @@
/> />
</div> </div>
</div> </div>
<el-dialog v-model="dialogFormVisible" :before-close="closeDialog" title="添加课程" custom-class="user-dialog"> <el-dialog v-model="dialogFormVisible" :before-close="closeDialog" title="添加课程" custom-class="user-dialog">
<el-form :model="formData" label-position="right" ref="elFormRef" :rules="rule" label-width="80px"> <el-form ref="elFormRef" :model="formData" label-position="right" :rules="rule" label-width="80px" content-height="500px">
<el-form-item label="课程名称:" prop="courseName" > <el-form-item label="课程名称:" prop="courseName">
<el-input v-model="formData.courseName" :clearable="true" placeholder="请输入" /> <el-input v-model="formData.courseName" :clearable="true" placeholder="请输入" />
</el-form-item> </el-form-item>
<el-form-item label="课程描述:" prop="courseDesc" > <!-- <el-form-item label="课程描述:" prop="courseDesc" >-->
<!-- <el-input v-model="formData.courseDesc" :clearable="true" type = "textarea" placeholder="请输入" />-->
<!-- </el-form-item>-->
<el-form-item label="课程描述:" prop="courseDesc" style="">
<!-- <div style="display:inline-block"><basic-editor ref="myEditorRef" v-model="formData.courseDesc" /></div>-->
<!-- <vue-editor v-model="formData.courseDesc"></vue-editor>-->
<!-- <div style="display:inline-block"><quill-editor v-model:value="formData.courseDesc"></quill-editor></div>-->
<el-input v-model="formData.courseDesc" :clearable="true" type = "textarea" placeholder="请输入" /> <el-input v-model="formData.courseDesc" :clearable="true" type = "textarea" placeholder="请输入" />
</el-form-item> </el-form-item>
<!-- <el-form-item label="课程描述:" prop="courseDescOne" >-->
<!-- <quill-editor-->
<!-- v-model="formData.courseDesc"-->
<!-- ref="myQuillEditor"-->
<!-- :options="editorOptions"-->
<!-- @blur="onEditorBlur"-->
<!-- @focus="onEditorFocus"-->
<!-- />-->
<!-- </el-form-item>-->
<el-form-item label="展示图" label-width="80px"> <el-form-item label="展示图" label-width="80px">
<div style="display:inline-block" @click="openBannerChange"> <div style="display:inline-block" @click="openBannerChange">
<img v-if="formData.courseBanner" alt="头像" class="header-img-box" :src="(formData.courseBanner && formData.courseBanner.slice(0, 4) !== 'http')?path+formData.courseBanner:formData.courseBanner"> <img v-if="formData.courseBanner" alt="头像" class="header-img-box" :src="(formData.courseBanner && formData.courseBanner.slice(0, 4) !== 'http')?path+formData.courseBanner:formData.courseBanner">
<div v-else class="header-img-box">从媒体库选择</div> <div v-else class="header-img-box">从媒体库选择</div>
</div> </div>
</el-form-item> </el-form-item>
<el-form-item label="状态 0 不显示 1 显示:" prop="isShow" > <el-form-item label="状态 0 不显示 1 显示:" prop="isShow">
<el-switch v-model="formData.isShow" active-color="#13ce66" inactive-color="#ff4949" active-text="是" inactive-text="否" clearable ></el-switch> <el-switch v-model="formData.isShow" active-color="#13ce66" inactive-color="#ff4949" active-text="是" inactive-text="否" clearable />
</el-form-item> </el-form-item>
</el-form> </el-form>
<template #footer> <template #footer>
...@@ -123,9 +120,13 @@ ...@@ -123,9 +120,13 @@
</template> </template>
<script> <script>
import BasicEditor from '@/components/BasicEditor.vue'
export default { export default {
name: 'CourseList' name: 'CourseList',
components: { BasicEditor }
} }
</script> </script>
<script setup> <script setup>
...@@ -147,6 +148,7 @@ import { useRouter } from 'vue-router' ...@@ -147,6 +148,7 @@ import { useRouter } from 'vue-router'
const path = ref(import.meta.env.VITE_BASE_API + '/') const path = ref(import.meta.env.VITE_BASE_API + '/')
const router = useRouter() const router = useRouter()
const myEditorRef = ref()
// 自动化生成的字典(可能为空)以及字段 // 自动化生成的字典(可能为空)以及字段
const formData = ref({ const formData = ref({
...@@ -154,34 +156,34 @@ const formData = ref({ ...@@ -154,34 +156,34 @@ const formData = ref({
courseDesc: '', courseDesc: '',
courseBanner: '', courseBanner: '',
isShow: false, isShow: false,
}) })
// 验证规则 // 验证规则
const rule = reactive({ const rule = reactive({
courseName : [{ courseName: [{
required: true, required: true,
message: '', message: '',
trigger: ['input','blur'], trigger: ['input', 'blur'],
}], }],
courseDesc : [{ courseDesc: [{
required: true, required: true,
message: '', message: '',
trigger: ['input','blur'], trigger: ['input', 'blur'],
}], }],
courseBanner : [{ courseBanner: [{
required: true, required: true,
message: '', message: '',
trigger: ['input','blur'], trigger: ['input', 'blur'],
}], }],
isShow : [{ isShow: [{
required: true, required: true,
message: '', message: '',
trigger: ['input','blur'], trigger: ['input', 'blur'],
}], }],
}) })
const elFormRef = ref()
const elFormRef = ref()
// =========== 表格控制部分 =========== // =========== 表格控制部分 ===========
const page = ref(1) const page = ref(1)
...@@ -200,8 +202,8 @@ const onReset = () => { ...@@ -200,8 +202,8 @@ const onReset = () => {
const onSubmit = () => { const onSubmit = () => {
page.value = 1 page.value = 1
pageSize.value = 10 pageSize.value = 10
if (searchInfo.value.isShow === ""){ if (searchInfo.value.isShow === '') {
searchInfo.value.isShow=null searchInfo.value.isShow = null
} }
getTableData() getTableData()
} }
...@@ -234,13 +236,12 @@ getTableData() ...@@ -234,13 +236,12 @@ getTableData()
// ============== 表格控制部分结束 =============== // ============== 表格控制部分结束 ===============
// 获取需要的字典 可能为空 按需保留 // 获取需要的字典 可能为空 按需保留
const setOptions = async () =>{ const setOptions = async() => {
} }
// 获取需要的字典 可能为空 按需保留 // 获取需要的字典 可能为空 按需保留
setOptions() setOptions()
// 多选数据 // 多选数据
const multipleSelection = ref([]) const multipleSelection = ref([])
// 多选 // 多选
...@@ -257,7 +258,7 @@ const deleteRow = (row) => { ...@@ -257,7 +258,7 @@ const deleteRow = (row) => {
}).then(() => { }).then(() => {
deleteCourseListFunc(row) deleteCourseListFunc(row)
}) })
} }
const toCourseAction = (row) => { const toCourseAction = (row) => {
router.push({ router.push({
...@@ -297,7 +298,7 @@ const onDelete = async() => { ...@@ -297,7 +298,7 @@ const onDelete = async() => {
deleteVisible.value = false deleteVisible.value = false
getTableData() getTableData()
} }
} }
// 行为控制标记(弹窗内部需要增还是改) // 行为控制标记(弹窗内部需要增还是改)
const type = ref('') const type = ref('')
...@@ -312,9 +313,8 @@ const updateCourseListFunc = async(row) => { ...@@ -312,9 +313,8 @@ const updateCourseListFunc = async(row) => {
} }
} }
// 删除行 // 删除行
const deleteCourseListFunc = async (row) => { const deleteCourseListFunc = async(row) => {
const res = await deleteCourseList({ ID: row.ID }) const res = await deleteCourseList({ ID: row.ID })
if (res.code === 0) { if (res.code === 0) {
ElMessage({ ElMessage({
...@@ -328,7 +328,6 @@ const deleteCourseListFunc = async (row) => { ...@@ -328,7 +328,6 @@ const deleteCourseListFunc = async (row) => {
} }
} }
const chooseImg = ref(null) const chooseImg = ref(null)
const openBannerChange = () => { const openBannerChange = () => {
chooseImg.value.open() chooseImg.value.open()
...@@ -353,8 +352,8 @@ const closeDialog = () => { ...@@ -353,8 +352,8 @@ const closeDialog = () => {
} }
} }
// 弹窗确定 // 弹窗确定
const enterDialog = async () => { const enterDialog = async() => {
elFormRef.value?.validate( async (valid) => { elFormRef.value?.validate(async(valid) => {
if (!valid) return if (!valid) return
let res let res
switch (type.value) { switch (type.value) {
......
...@@ -59,8 +59,8 @@ ...@@ -59,8 +59,8 @@
</el-table-column> </el-table-column>
<el-table-column align="left" label="按钮组"> <el-table-column align="left" label="按钮组">
<template #default="scope"> <template #default="scope">
<el-button type="primary" v-if="!scope.row.isPass" link icon="edit" class="table-button" @click="updateCourseSignupFunc(scope.row)">审核</el-button> <el-button type="primary" v-if="!scope.row.isPass && !scope.row.isFrozen" link icon="edit" class="table-button" @click="updateCourseSignupFunc(scope.row)">审核</el-button>
<!-- <el-button type="primary" link icon="delete" @click="deleteRow(scope.row)">删除</el-button>--> <el-button type="primary" v-if="!scope.row.isFrozen" link icon="edit" @click="frozenSign(scope.row)">冻结</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
...@@ -97,7 +97,7 @@ ...@@ -97,7 +97,7 @@
<el-switch v-model="formData.isPass" active-color="#13ce66" inactive-color="#ff4949" active-text="是" inactive-text="否" clearable ></el-switch> <el-switch v-model="formData.isPass" active-color="#13ce66" inactive-color="#ff4949" active-text="是" inactive-text="否" clearable ></el-switch>
</el-form-item> </el-form-item>
<el-form-item label="冻结:" prop="isFrozen" > <el-form-item label="冻结:" prop="isFrozen" >
<el-switch v-model="formData.isFrozen" active-color="#13ce66" inactive-color="#ff4949" active-text="是" inactive-text="否" clearable ></el-switch> <el-switch v-model="formData.isFrozen" active-color="#13ce66" inactive-color="#ff4949" active-text="是" inactive-text="否" clearable disabled></el-switch>
</el-form-item> </el-form-item>
</el-form> </el-form>
<template #footer> <template #footer>
...@@ -107,6 +107,38 @@ ...@@ -107,6 +107,38 @@
</div> </div>
</template> </template>
</el-dialog> </el-dialog>
<el-dialog v-model="dialogFormVisibleTwo" :before-close="closeDialogTwo" title="冻结操作">
<el-form :model="formData" label-position="right" ref="elFormRef" :rules="rule" label-width="80px">
<el-form-item label="用户:" prop="addr" >
<el-input v-model="formData.addr" :clearable="false" placeholder="请输入" disabled/>
</el-form-item>
<el-form-item label="性别 0 女性 1 男性:" prop="sex" >
<el-switch v-model="formData.sex" active-color="#13ce66" inactive-color="#ff4949" active-text="是" inactive-text="否" disabled></el-switch>
</el-form-item>
<el-form-item label="年龄:" prop="age" >
<el-input v-model.number="formData.age" placeholder="请输入" disabled/>
</el-form-item>
<el-form-item label="公司:" prop="company" >
<el-input v-model.number="formData.company" placeholder="请输入" disabled/>
</el-form-item>
<el-form-item label="头像:" prop="photo" >
<img v-if="formData.photo" alt="头像" class="header-img-box" :src="(formData.photo && formData.photo.slice(0, 4) !== 'http')?path+formData.photo:formData.photo">
</el-form-item>
<el-form-item label="通过:" prop="isPass" >
<el-switch v-model="formData.isPass" active-color="#13ce66" inactive-color="#ff4949" active-text="是" inactive-text="否" clearable disabled></el-switch>
</el-form-item>
<el-form-item label="冻结:" prop="isFrozen" >
<el-switch v-model="formData.isFrozen" active-color="#13ce66" inactive-color="#ff4949" active-text="是" inactive-text="否" clearable ></el-switch>
</el-form-item>
</el-form>
<template #footer>
<div class="dialog-footer">
<el-button @click="closeDialogTwo">取 消</el-button>
<el-button type="primary" @click="enterDialogTwo">确 定</el-button>
</div>
</template>
</el-dialog>
</div> </div>
</template> </template>
...@@ -266,6 +298,16 @@ const updateCourseSignupFunc = async(row) => { ...@@ -266,6 +298,16 @@ const updateCourseSignupFunc = async(row) => {
} }
} }
// 更新行
const frozenSign = async(row) => {
const res = await findCourseSignup({ ID: row.ID })
type.value = 'update'
if (res.code === 0) {
formData.value = res.data.recourseSignup
dialogFormVisibleTwo.value = true
}
}
// 删除行 // 删除行
const deleteCourseSignupFunc = async (row) => { const deleteCourseSignupFunc = async (row) => {
...@@ -284,6 +326,7 @@ const deleteCourseSignupFunc = async (row) => { ...@@ -284,6 +326,7 @@ const deleteCourseSignupFunc = async (row) => {
// 弹窗控制标记 // 弹窗控制标记
const dialogFormVisible = ref(false) const dialogFormVisible = ref(false)
const dialogFormVisibleTwo = ref(false)
// 打开弹窗 // 打开弹窗
const openDialog = () => { const openDialog = () => {
...@@ -291,6 +334,12 @@ const openDialog = () => { ...@@ -291,6 +334,12 @@ const openDialog = () => {
dialogFormVisible.value = true dialogFormVisible.value = true
} }
// 打开弹窗
const openDialogTwo = () => {
type.value = 'edit'
dialogFormVisible.value = true
}
// 关闭弹窗 // 关闭弹窗
const closeDialog = () => { const closeDialog = () => {
dialogFormVisible.value = false dialogFormVisible.value = false
...@@ -300,6 +349,15 @@ const closeDialog = () => { ...@@ -300,6 +349,15 @@ const closeDialog = () => {
isPass: false, isPass: false,
} }
} }
const closeDialogTwo = () => {
dialogFormVisibleTwo.value = false
formData.value = {
uid: 0,
cid: 0,
isPass: false,
}
}
// 弹窗确定 // 弹窗确定
const enterDialog = async () => { const enterDialog = async () => {
elFormRef.value?.validate( async (valid) => { elFormRef.value?.validate( async (valid) => {
...@@ -326,6 +384,30 @@ const enterDialog = async () => { ...@@ -326,6 +384,30 @@ const enterDialog = async () => {
} }
}) })
} }
// 弹窗确定
const enterDialogTwo = async () => {
elFormRef.value?.validate( async (valid) => {
if (!valid) return
let res
switch (type.value) {
case 'update':
res = await updateCourseSignup(formData.value)
break
default:
res = await createCourseSignup(formData.value)
break
}
if (res.code === 0) {
ElMessage({
type: 'success',
message: '创建/更改成功'
})
closeDialogTwo()
getTableData()
}
})
}
</script> </script>
<style lang="scss"> <style lang="scss">
......
<template> <template>
<div class="page"> <div class="page">
<img src="@/assets/air.png" alt>
<a
style="color:#409EFF"
target="view_window"
href="https://mainnet.bityuan.com/address/1QBGDgy6CRPJj1mCFE1S2MYNfqDuGq3bJu"
>查询余额</a>
<!-- <div class="gva-card-box">--> <!-- <div class="gva-card-box">-->
<!-- <div class="gva-card gva-top-card">--> <!-- <div class="gva-card gva-top-card">-->
<!-- <div class="gva-top-card-left">--> <!-- <div class="gva-top-card-left">-->
......
...@@ -70,23 +70,23 @@ ...@@ -70,23 +70,23 @@
</div> </div>
<div class="login_panel_right" /> <div class="login_panel_right" />
<div class="login_panel_foot"> <div class="login_panel_foot">
<div class="links"> <!-- <div class="links">-->
<a href="http://doc.henrongyi.top/" target="_blank"> <!-- <a href="http://doc.henrongyi.top/" target="_blank">-->
<img src="@/assets/docs.png" class="link-icon" alt="文档"> <!-- <img src="@/assets/docs.png" class="link-icon" alt="文档">-->
</a> <!-- </a>-->
<a href="https://support.qq.com/product/371961" target="_blank"> <!-- <a href="https://support.qq.com/product/371961" target="_blank">-->
<img src="@/assets/kefu.png" class="link-icon" alt="客服"> <!-- <img src="@/assets/kefu.png" class="link-icon" alt="客服">-->
</a> <!-- </a>-->
<a <!-- <a-->
href="https://reward" <!-- href="https://reward"-->
target="_blank" <!-- target="_blank"-->
> <!-- >-->
<img src="@/assets/github.png" class="link-icon" alt="github"> <!-- <img src="@/assets/github.png" class="link-icon" alt="github">-->
</a> <!-- </a>-->
<a href="https://space.bilibili.com/322210472" target="_blank"> <!-- <a href="https://space.bilibili.com/322210472" target="_blank">-->
<img src="@/assets/video.png" class="link-icon" alt="视频站"> <!-- <img src="@/assets/video.png" class="link-icon" alt="视频站">-->
</a> <!-- </a>-->
</div> <!-- </div>-->
<div class="copyright"> <div class="copyright">
<BottomInfo /> <BottomInfo />
</div> </div>
......
...@@ -52,21 +52,21 @@ ...@@ -52,21 +52,21 @@
<el-tooltip <el-tooltip
class="item" class="item"
effect="light" effect="light"
content="北京反转极光科技有限公司-技术部-前端事业群" content="技术部"
placement="top" placement="top"
> >
<li> <li>
<el-icon> <el-icon>
<data-analysis /> <data-analysis />
</el-icon> </el-icon>
北京反转极光科技有限公司-技术部-前端事业群 技术部-前端
</li> </li>
</el-tooltip> </el-tooltip>
<li> <li>
<el-icon> <el-icon>
<video-camera /> <video-camera />
</el-icon> </el-icon>
中国·北京市·朝阳区 中国
</li> </li>
<el-tooltip <el-tooltip
class="item" class="item"
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment