dev_2022-06-14
yujialong 3 years ago
parent 2ef4dc9f36
commit bbb11e67c4
  1. 2
      src/api/index.js
  2. 15
      src/pages/account/login/index.vue
  3. 3
      src/pages/index/list/index.vue
  4. 174
      src/pages/match/details/index.vue
  5. 248
      src/pages/match/list/index.vue
  6. 3
      src/pages/match/noticeDetail/index.vue
  7. 258
      src/pages/touristMatch/list/index.vue
  8. 4
      src/setting.js
  9. 19
      src/store/modules/match.js
  10. 1
      src/store/modules/user.js

@ -73,7 +73,7 @@ export default {
// 线上赛事 // 线上赛事
contestPageConditionQueryByOccupationlabStu: `occupationlab/enterprise/match/contest/contestPageConditionQueryByOccupationlabStu`, contestPageConditionQueryByOccupationlabStu: `occupationlab/enterprise/match/contest/contestPageConditionQueryByOccupationlabStu`,
contestPageConditionQueryByOccupationlab: `occupationlab/enterprise/match/contest/contestPageConditionQueryByOccupationlab`, contestPageConditionQueryByOccupationlab: `occupationlab/enterprise/match/contest/onlineCompetitionByStudent`,
listOfRegisteredEvents: `occupationlab/enterprise/match/contest/listOfRegisteredEvents`, listOfRegisteredEvents: `occupationlab/enterprise/match/contest/listOfRegisteredEvents`,
addApplicant: `occupationlab/enterprise/match/applicant/addApplicant`, // 添加报名人员 addApplicant: `occupationlab/enterprise/match/applicant/addApplicant`, // 添加报名人员
getContestProgress: `occupationlab/enterprise/match/contest-progress/getContestProgress`, // 根据赛事id查询竞赛进展 getContestProgress: `occupationlab/enterprise/match/contest-progress/getContestProgress`, // 根据赛事id查询竞赛进展

@ -144,7 +144,7 @@
<script> <script>
import vFooter from "@/layouts/footer"; import vFooter from "@/layouts/footer";
import { mapMutations, mapActions } from "vuex"; import { mapState, mapMutations, mapActions } from "vuex";
import util from "@/libs/util"; import util from "@/libs/util";
import Setting from "@/setting"; import Setting from "@/setting";
import axios from "axios" import axios from "axios"
@ -206,6 +206,11 @@ export default {
infos: [] infos: []
}; };
}, },
computed: {
...mapState('match', [
'toMatch'
])
},
components: { components: {
vFooter vFooter
}, },
@ -287,11 +292,13 @@ export default {
}, },
// //
toTrial() { toTrial() {
window.open('https://www.wjx.cn/vm/wB0RcMm.aspx') // window.open('https://www.wjx.cn/vm/wB0RcMm.aspx')
}, },
// //
reloadIndex() { reloadIndex() {
window.opener && window.opener.location.reload() try {
window.opener && window.opener.location.reload()
} catch(e) {}
}, },
// //
chooseUser(user) { chooseUser(user) {
@ -322,7 +329,7 @@ export default {
util.cookies.remove('serverLogin') util.cookies.remove('serverLogin')
this.reloadIndex() this.reloadIndex()
util.successMsg('登录成功') util.successMsg('登录成功')
this.$router.replace('/station') this.$router.replace(this.toMatch ? '/touristMatch' : '/station')
}, },
// //
submit() { submit() {

@ -200,7 +200,7 @@
<img class="icon" src="@/assets/img/index/tel-2.png" alt=""> <img class="icon" src="@/assets/img/index/tel-2.png" alt="">
</div> </div>
<div class="text"> <div class="text">
<p class="title">联系销</p> <p class="title">前咨询</p>
<p class="tel-num" style="margin-bottom: 5px">刘兰</p> <p class="tel-num" style="margin-bottom: 5px">刘兰</p>
<p class="tel-num">18019930142</p> <p class="tel-num">18019930142</p>
</div> </div>
@ -811,6 +811,7 @@ export default {
} }
.des { .des {
font-size: 12px; font-size: 12px;
color: #686868;
} }
} }
} }

@ -1,74 +1,76 @@
<template> <template>
<div class="wrap index"> <div class="wrap index">
<div class="banner" :style="{backgroundImage: coverUrlComputed}"></div> <div class="banner" :style="{backgroundImage: 'url(' + (form.carouselUrl || 'https://huoran.oss-cn-shenzhen.aliyuncs.com/20220613/png/1536269450851409920.png') + ')'}"></div>
<div class="center-wrap"> <div class="center">
<breadcrumb ref="breadcrumb" :data="'全部赛事/' + form.name"></breadcrumb> <div class="center-wrap">
<div class="content"> <breadcrumb ref="breadcrumb" :data="'全部赛事/' + form.name"></breadcrumb>
<div class="flex-between"> <div class="content">
<el-tabs v-model="curType" @tab-click="typeChange"> <div class="flex-between">
<el-tab-pane v-for="(item, index) in typeList" :key="index" :label="item.name" :name="item.id"></el-tab-pane> <el-tabs v-model="curType" @tab-click="typeChange">
</el-tabs> <el-tab-pane v-for="(item, index) in typeList" :key="index" :label="item.name" :name="item.id"></el-tab-pane>
<div class="action"> </el-tabs>
<p class="end-text" v-if="status != 5"> <div class="action">
距离{{ endList[status] }}还有<em>{{ end }}</em> <p class="end-text" v-if="status != 5">
</p> 距离{{ endList[status] }}还有<em>{{ end }}</em>
<a class="status" :class="{wait: status == 0 || status == 4,signing: status == 2,signed: status == 1,finish: status == 3 || status == 5}" @click.stop="signup">{{ statusList[status] }}</a> </p>
</div> <a class="status" :class="{wait: status == 0 || status == 4,signing: status == 2,signed: status == 1,finish: status == 3 || status == 5}" @click.stop="signup">{{ statusList[status] }}</a>
</div> </div>
<div class="info"> </div>
<h6 class="title">{{ form.name }}</h6> <div class="info">
<div class="meta">最近编辑时间{{ form.updateTime }}</div> <h6 class="title">{{ form.name }}</h6>
</div> <div class="meta">最近编辑时间{{ form.updateTime }}</div>
</div>
<div class="l-title" id="part1"><img src="@/assets/img/label.png" alt=""> 竞赛信息</div> <div class="l-title" id="part1"><img src="@/assets/img/label.png" alt=""> 竞赛信息</div>
<div v-if="form.description" class="texts ql-editor" v-html="form.description"></div> <div v-if="form.description" class="texts ql-editor" v-html="form.description"></div>
<template v-if="form.contestAnnexList"> <template v-if="form.contestAnnexList">
<h6 class="p-title">附件下载</h6> <h6 class="p-title">附件下载</h6>
<ul class="files"> <ul class="files">
<li v-for="(item, i) in form.contestAnnexList" :key="i"> <li v-for="(item, i) in form.contestAnnexList" :key="i">
<el-link class="m-r-10" type="primary" @click="preview(item)">{{ item.fileName }}</el-link> <el-link class="m-r-10" type="primary" @click="preview(item)">{{ item.fileName }}</el-link>
<el-link type="primary" :underline="false" @click="download(item)">下载</el-link> <el-link type="primary" :underline="false" @click="download(item)">下载</el-link>
</li> </li>
</ul>
</template>
<!-- 进展 -->
<div class="l-title" id="part2"><img src="@/assets/img/label.png" alt=""> 竞赛进展</div>
<ul class="progress" v-if="progress.length">
<li v-for="(item,index) in progress" :key="index" :class="item.status == 0 ? 'not' : (item.status == 1 ? 'ing' : 'done')">
<i class="dot"></i>
<p class="name">{{item.title}}</p>
<p class="desc">{{item.description}}</p>
</li>
<img class="rocket" src="@/assets/img/rocket.png" alt="">
</ul> </ul>
</template> <template v-else>
<div class="empty">
<!-- 进展 --> <div>
<div class="l-title" id="part2"><img src="@/assets/img/label.png" alt=""> 竞赛进展</div> <img src="@/assets/img/none.png" alt="">
<ul class="progress" v-if="progress.length"> <p>暂无数据</p>
<li v-for="(item,index) in progress" :key="index" :class="item.status == 0 ? 'not' : (item.status == 1 ? 'ing' : 'done')"> </div>
<i class="dot"></i> </div>
<p class="name">{{item.title}}</p> </template>
<p class="desc">{{item.description}}</p>
<!-- 公告 -->
<div class="l-title" id="part3"><img src="@/assets/img/label.png" alt=""> 通知公告</div>
<ul class="notice-list" v-if="notices.length">
<li v-for="(item, i) in notices" :key="i" @click="toNotice(item)">
<h6>{{ item.announcementTitle }}</h6>
<p class="meta">{{ item.updateTime }}</p>
<div class="des" v-html="item.announcementText"></div>
</li> </li>
<img class="rocket" src="@/assets/img/rocket.png" alt=""> </ul>
</ul> <template v-else>
<template v-else> <div class="empty">
<div class="empty"> <div>
<div> <img src="@/assets/img/none.png" alt="">
<img src="@/assets/img/none.png" alt=""> <p>暂无通知公告</p>
<p>暂无数据</p> </div>
</div> </div>
</div> </template>
</template> </div>
</div>
<!-- 公告 -->
<div class="l-title" id="part3"><img src="@/assets/img/label.png" alt=""> 通知公告</div>
<ul class="notice-list" v-if="notices.length">
<li v-for="(item, i) in notices" :key="i" @click="toNotice(item)">
<h6>{{ item.announcementTitle }}</h6>
<p class="meta">{{ item.updateTime }}</p>
<div class="des" v-html="item.announcementText"></div>
</li>
</ul>
<template v-else>
<div class="empty">
<div>
<img src="@/assets/img/none.png" alt="">
<p>暂无通知公告</p>
</div>
</div>
</template>
</div>
</div> </div>
</div> </div>
</template> </template>
@ -76,11 +78,12 @@
<script> <script>
import breadcrumb from '@/components/breadcrumb' import breadcrumb from '@/components/breadcrumb'
import util from '@/libs/util' import util from '@/libs/util'
import Setting from "@/setting"
export default { export default {
name: 'matchdetail', name: 'matchdetail',
data() { data() {
return { return {
id: this.$store.state.match.matchId, id: this.$route.query.id,
end: this.$route.query.end, end: this.$route.query.end,
status: this.$route.query.status, status: this.$route.query.status,
statusList: ["等待报名", "已报名", "立即报名", "报名截止", "比赛中", "已结束"], statusList: ["等待报名", "已报名", "立即报名", "报名截止", "比赛中", "已结束"],
@ -188,11 +191,6 @@ export default {
} }
} }
}, },
computed: {
coverUrlComputed() {
return this.form.carouselUrl? 'url(' + this.form.carouselUrl + ')' : "url('../../../assets/img/info-banner.png')"
}
},
mounted() { mounted() {
this.getData() this.getData()
this.getProgress() this.getProgress()
@ -234,18 +232,28 @@ export default {
}, },
// //
toNotice(item) { toNotice(item) {
this.$router.push(`noticeDetail?id=${item.id}&name=${this.form.name}&end=${this.end}&status=${this.status}`) this.$router.push(`noticeDetail?id=${item.id}&matchId=${this.id}&name=${this.form.name}&end=${this.end}&status=${this.status}`)
}, },
signup(){ // //
signup(){
if (util.local.get(Setting.tokenKey)) {
if (this.status == 2) { if (this.status == 2) {
let data = { let data = {
contestId: this.id contestId: this.id
} }
this.$post(this.api.addApplicant,data).then(res => { this.$post(this.api.addApplicant,data).then(res => {
this.$message.success('报名成功') this.$message.success('报名成功')
this.status = 1; this.status = 1;
}).catch(res => {}) }).catch(res => {})
} }
} else {
this.$confirm('请先登录,是否直接前往登录?', "提示", {
type: 'success'
}).then(() => {
this.$router.push('/login')
}).catch(() => {})
}
} }
} }
}; };
@ -268,6 +276,10 @@ export default {
line-height: 30px; line-height: 30px;
} }
} }
.main .center {
background: url(../../../assets/img/match-bg1.png) (0px 95px)/auto auto no-repeat,
url(../../../assets/img/match-bg2.png) (98% 300px)/auto auto no-repeat;
}
.main .center-wrap { .main .center-wrap {
margin-top: 30px; margin-top: 30px;
} }

@ -19,7 +19,7 @@
<template v-if="way === 1 || (way === 2 && form.competitionScope === 2)"> <template v-if="way === 1 || (way === 2 && form.competitionScope === 2)">
<div class="select-wrap"> <div class="select-wrap">
<span class="label">省份</span> <span class="label">省份</span>
<el-select size="small" v-model="form.provinceId" @change="getCity"> <el-select size="small" v-model="form.provinceId" clearable @change="getCity">
<el-option label="不限" value=""></el-option> <el-option label="不限" value=""></el-option>
<el-option <el-option
v-for="(item,index) in provinces" v-for="(item,index) in provinces"
@ -31,7 +31,7 @@
</div> </div>
<div class="select-wrap"> <div class="select-wrap">
<span class="label">城市</span> <span class="label">城市</span>
<el-select size="small" v-model="form.cityId" @change="initData"> <el-select size="small" v-model="form.cityId" clearable @change="initData">
<el-option label="不限" value=""></el-option> <el-option label="不限" value=""></el-option>
<el-option <el-option
v-for="(item,index) in cities" v-for="(item,index) in cities"
@ -63,7 +63,7 @@
<li v-for="(item,index) in listData" :key="index" @click="toDetail(item)"> <li v-for="(item,index) in listData" :key="index" @click="toDetail(item)">
<div class="left"> <div class="left">
<div class="cover"> <div class="cover">
<img :src="item.coverUrl" alt=""> <img :src="item.coverUrl || 'https://huoran.oss-cn-shenzhen.aliyuncs.com/20220623/png/1539857403162943488.png'" alt="">
</div> </div>
<div class="info"> <div class="info">
<div class="title">{{ item.competitionName }}</div> <div class="title">{{ item.competitionName }}</div>
@ -110,8 +110,7 @@
@click.stop="signup(item)">{{ statusList[item.status] }}</p> @click.stop="signup(item)">{{ statusList[item.status] }}</p>
<p class="end-text" v-if="item.status != 5"> <p class="end-text" v-if="item.status != 5">
距离{{ endList[item.status] }}还有 距离{{ endList[item.status] }}还有
<template v-if="item.end > 0"><em>{{ item.end }}</em> </template> <em>{{ item.end }}</em>
<em v-else v-countdown="index">{{ item.end }}</em>
</p> </p>
</div> </div>
</li> </li>
@ -149,6 +148,7 @@ export default {
name: "match", name: "match",
data() { data() {
return { return {
timer: null,
token: util.local.get(Setting.tokenKey), token: util.local.get(Setting.tokenKey),
way: 0, way: 0,
apis: ['contestPageConditionQueryByOccupationlab', 'contestPageConditionQueryByOccupationlabStu', 'listOfRegisteredEvents'], // 3 apis: ['contestPageConditionQueryByOccupationlab', 'contestPageConditionQueryByOccupationlabStu', 'listOfRegisteredEvents'], // 3
@ -174,9 +174,13 @@ export default {
provinceId: '', provinceId: '',
cityId: '', cityId: '',
sequence: '', sequence: '',
competitionScope: 1, // (0: 1: 2.) competitionScope: 0, // (0: 1: 2.)
}, },
scopes: [ scopes: [
{
id: 0,
name: '本校内'
},
{ {
id: 1, id: 1,
name: '全平台' name: '全平台'
@ -207,81 +211,8 @@ export default {
loadIns: null, loadIns: null,
contestIds: [], contestIds: [],
timerList: [], timerList: [],
defaultBanner:'../../../assets/img/info-banner.png',
}; };
}, },
directives: {
countdown: {
bind: function(el, binding, vnode) {
let that = vnode.context;
let item = that.listData[binding.value];
let time = "";
let second = 1000;
let minute = second * 60;
let hour = minute * 60;
let now = new Date().getTime();
let signUpStartTime = new Date(that.core.dateCompatible(item.signUpStartTime)).getTime(); //
let signUpEndTime = new Date(that.core.dateCompatible(item.signUpEndTime)).getTime(); //
let playStartTime = new Date(that.core.dateCompatible(item.playStartTime)).getTime(); //
let playEndTime = new Date(that.core.dateCompatible(item.playEndTime)).getTime(); //
switch (item.status) {
// statusgetData
case 0:
if (now > signUpStartTime) {
item.status = 1;
} else {
time = signUpStartTime - now;
}
break;
case 1:
if (now > signUpEndTime) {
item.status = 3;
} else {
time = signUpEndTime - now;
}
break;
case 2:
if (now > signUpEndTime) {
item.status = 3;
} else {
time = signUpEndTime - now;
}
break;
case 3:
if (now > playStartTime) {
item.status = 4;
} else {
time = playStartTime - now;
}
break;
case 4:
if (now > playEndTime) {
item.status = 5;
} else {
time = playEndTime - now;
}
break;
}
time = `${Math.floor(time / hour)}:${Math.floor(time % hour / minute)}:${Math.floor(time % hour % minute / second)}`;
let timer = setInterval(() => {
let timeList = time.split(":");
let total = Number.parseInt(timeList[0] * 60 * 60) + Number.parseInt(timeList[1] * 60) + Number.parseInt(timeList[2]);
if (total > 0) {
--total;
let hours = Math.floor(total / (60 * 60));
let minutes = Math.floor(total % (60 * 60) / 60);
let seconds = Math.floor(total % (60 * 60) % 60);
time = `${that.core.formateTime(hours)}:${that.core.formateTime(minutes)}:${that.core.formateTime(seconds)}`;
} else {
clearInterval(timer);
}
el.innerHTML = time;
}, 1000);
that.timerList.push(timer);
}
}
},
watch: { watch: {
keyword: function(val) { keyword: function(val) {
clearTimeout(this.searchTimer); clearTimeout(this.searchTimer);
@ -293,74 +224,83 @@ export default {
mounted() { mounted() {
this.getProvince() this.getProvince()
this.getData() this.getData()
this.$once("hook:beforeDestroy", function() { this.$once('hook:beforeDestroy', function() {
this.timerList.forEach((n, k) => { clearInterval(this.timer)
clearInterval(n); })
});
this.timerList = [];
});
}, },
methods: { methods: {
...mapActions("match", [ getList() {
"setMatchId", "setMatchSignupStatus" const { form } = this
]), this.$post(this.api[this.apis[this.way]], {
async getData() { pageNum: this.page,
this.loadIns = Loading.service() pageSize: this.pageSize,
const { form } = this platformSource: 1, // (01)
this.$post(this.api[this.apis[this.way]], { cityId: form.cityId || null,
pageNum: this.page, provinceId: form.provinceId || null,
pageSize: this.pageSize, sequence: form.sequence || null,
platformSource: 1, // (01) competitionScope: this.way === 2 ? form.competitionScope : null,
cityId: form.cityId || null, keyWord: this.keyword
provinceId: form.provinceId || null, }).then(({ data }) => {
sequence: form.sequence || null, this.listData = data.records
competitionScope: this.way === 2 ? form.competitionScope : null, this.totals = data.total
keyWord: this.keyword const second = 1000;
}).then(({ data }) => { const minute = second * 60;
this.listData = data.records const hour = minute * 60;
this.totals = data.total this.listData.forEach((n, k) => {
let time = 60 * 60 * 1000 * 24; //
this.listData.forEach((n, k) => { let now = new Date().getTime();
// let signUpStartTime = new Date(this.core.dateCompatible(n.signUpStartTime)).getTime(); //
let now = new Date().getTime(); let signUpEndTime = new Date(this.core.dateCompatible(n.signUpEndTime)).getTime(); //
let signUpStartTime = new Date(this.core.dateCompatible(n.signUpStartTime)).getTime(); // let playStartTime = new Date(this.core.dateCompatible(n.playStartTime)).getTime(); //
let signUpEndTime = new Date(this.core.dateCompatible(n.signUpEndTime)).getTime(); // let playEndTime = new Date(this.core.dateCompatible(n.playEndTime)).getTime(); //
let playStartTime = new Date(this.core.dateCompatible(n.playStartTime)).getTime(); // let total = 0
let playEndTime = new Date(this.core.dateCompatible(n.playEndTime)).getTime(); // // whetherToSignUp 01
if (now < signUpStartTime) { //
// whetherToSignUp 01 n.status = 0;
if (now < signUpStartTime) { // total = signUpStartTime - now
n.status = 0; } else if (now > signUpStartTime && now < signUpEndTime) { //
n.end = Math.floor((signUpStartTime - now) / time); n.status = n.whetherToSignUp ? 2 : 1 // 12
} else if (now > signUpStartTime && now < signUpEndTime) { // total = signUpEndTime - now
n.status = n.whetherToSignUp ? 2 : 1 // 12 } else if (now > signUpEndTime && now < playStartTime) { // ,
n.end = Math.floor((signUpEndTime - now) / time); n.status = 3;
} else if (now > signUpEndTime && now < playStartTime) { // , total = playStartTime - now
n.status = 3; } else if (now > playStartTime && now < playEndTime) { //
n.end = Math.floor((playStartTime - now) / time); n.status = 4;
} else if (now > playStartTime && now < playEndTime) { // total = playEndTime - now
n.status = 4; } else if (now > playEndTime) { //
n.end = Math.floor((playEndTime - now) / time); n.status = 5;
} else if (now > playEndTime) { // }
n.status = 5;
} if (total > 0) {
const day = Math.floor(total / (60 * 60 * 1000 * 24))
const time = `${this.core.formateTime(Math.floor(total / hour))}:${this.core.formateTime(Math.floor(total % hour / minute))}:${this.core.formateTime(Math.floor(total % hour % minute / second))}`
n.end = day ? day + '天' : time
}
// //
const list = n.contestRangeRespList const list = n.contestRangeRespList
if (list) { if (list) {
const range = [] const range = []
list.map(e => { list.map(e => {
range.push(e.type ? (e.provinceName || e.cityName) : e.schoolName) range.push(e.type ? (e.provinceName || e.cityName) : e.schoolName)
}) })
n.ranges = `${n.range}${range.join(',')}` n.ranges = `${n.range}${range.join(',')}`
} else { } else {
n.ranges = n.range n.ranges = n.range
} }
}); });
this.loadIns.close(); this.loadIns.close();
}).catch(res => { }).catch(res => {
this.loadIns.close() this.loadIns.close()
}) })
},
getData() {
this.loadIns = Loading.service()
this.getList()
if (!Setting.isDev) {
clearInterval(this.timer)
this.timer = setInterval(this.getList, 1000)
}
}, },
initData() { initData() {
this.page = 1 this.page = 1
@ -376,12 +316,14 @@ export default {
getCity() { getCity() {
const { form } = this const { form } = this
form.cityId = '' form.cityId = ''
this.$get(this.api.queryCity, { form.provinceId ?
provinceId: form.provinceId this.$get(this.api.queryCity, {
}).then(({ list }) => { provinceId: form.provinceId
this.cities = list }).then(({ list }) => {
this.cities = list
this.initData()
}).catch(res => {}) :
this.initData() this.initData()
}).catch(res => {})
}, },
changeType(type) { changeType(type) {
this.way = type; this.way = type;
@ -398,10 +340,7 @@ export default {
this.initData() this.initData()
}, },
toDetail(item) { toDetail(item) {
let status = item.status == 1 ? (item.signup ? true : false) : "hide"; this.$router.push(`/match/details?id=${item.id}&status=${item.status}&end=${item.end}`);
this.setMatchId(item.id);
this.setMatchSignupStatus(status);
this.$router.push(`/match/details?status=${item.status}&end=${item.end}`);
}, },
handleCurrentChange(val) { handleCurrentChange(val) {
this.page = val; this.page = val;
@ -492,6 +431,9 @@ export default {
.label { .label {
margin-right: 10px; margin-right: 10px;
} }
.el-select {
width: 130px;
}
} }
.list-inner { .list-inner {
display: flex; display: flex;

@ -11,7 +11,7 @@
</el-breadcrumb-item> </el-breadcrumb-item>
<el-breadcrumb-item <el-breadcrumb-item
v-else-if="breadPath.length > 2 && i === 1" v-else-if="breadPath.length > 2 && i === 1"
:to="{ path: 'details', query: { end, status } }" :to="{ path: 'details', query: { end, status, id } }"
:key="i"> :key="i">
{{item}} {{item}}
</el-breadcrumb-item> </el-breadcrumb-item>
@ -52,6 +52,7 @@ import util from '@/libs/util'
export default { export default {
data() { data() {
return { return {
id: this.$route.query.matchId,
end: this.$route.query.end, end: this.$route.query.end,
status: this.$route.query.status, status: this.$route.query.status,
breadPath: ['全部赛事', this.$route.query.name], breadPath: ['全部赛事', this.$route.query.name],

@ -17,7 +17,7 @@
<template v-if="form.competitionScope === 2"> <template v-if="form.competitionScope === 2">
<div class="select-wrap"> <div class="select-wrap">
<span class="label">省份</span> <span class="label">省份</span>
<el-select size="small" v-model="form.provinceId" @change="getCity"> <el-select size="small" v-model="form.provinceId" clearable @change="getCity">
<el-option label="请选择" value=""></el-option> <el-option label="请选择" value=""></el-option>
<el-option <el-option
v-for="(item,index) in provinces" v-for="(item,index) in provinces"
@ -29,7 +29,7 @@
</div> </div>
<div class="select-wrap"> <div class="select-wrap">
<span class="label">城市</span> <span class="label">城市</span>
<el-select size="small" v-model="form.cityId" @change="initData"> <el-select size="small" v-model="form.cityId" clearable @change="initData">
<el-option label="请选择" value=""></el-option> <el-option label="请选择" value=""></el-option>
<el-option <el-option
v-for="(item,index) in cities" v-for="(item,index) in cities"
@ -57,7 +57,7 @@
<li v-for="(item,index) in listData" :key="index" @click="toDetail(item)"> <li v-for="(item,index) in listData" :key="index" @click="toDetail(item)">
<div class="left"> <div class="left">
<div class="cover"> <div class="cover">
<img :src="item.coverUrl" alt=""> <img :src="item.coverUrl || 'https://huoran.oss-cn-shenzhen.aliyuncs.com/20220623/png/1539857403162943488.png'" alt="">
</div> </div>
<div class="info"> <div class="info">
<div class="title">{{ item.competitionName }}</div> <div class="title">{{ item.competitionName }}</div>
@ -100,8 +100,7 @@
@click.stop="signup(item)">{{ statusList[item.status] }}</p> @click.stop="signup(item)">{{ statusList[item.status] }}</p>
<p class="end-text" v-if="item.status != 5"> <p class="end-text" v-if="item.status != 5">
距离{{ endList[item.status] }}还有 距离{{ endList[item.status] }}还有
<template v-if="item.end > 0"><em>{{ item.end }}</em> </template> <em>{{ item.end }}</em>
<em v-else v-countdown="index">{{ item.end }}</em>
</p> </p>
</div> </div>
</li> </li>
@ -129,9 +128,8 @@
</template> </template>
<script> <script>
import { mapActions } from "vuex"; import { mapMutations } from "vuex";
import { Loading } from "element-ui"; import { Loading } from "element-ui";
import bus from "@/libs/bus";
import Setting from "@/setting" import Setting from "@/setting"
import util from "@/libs/util" import util from "@/libs/util"
@ -139,6 +137,7 @@ export default {
name: "match", name: "match",
data() { data() {
return { return {
timer: null,
token: util.local.get(Setting.tokenKey), token: util.local.get(Setting.tokenKey),
way: 2, way: 2,
statusList: ["等待报名", "已报名", "立即报名", "报名截止", "比赛中", "已结束"], statusList: ["等待报名", "已报名", "立即报名", "报名截止", "比赛中", "已结束"],
@ -163,9 +162,13 @@ export default {
provinceId: '', provinceId: '',
cityId: '', cityId: '',
sequence: '', sequence: '',
competitionScope: 1, // (0: 1: 2.) competitionScope: '', // (0: 1: 2.)
}, },
scopes: [ scopes: [
{
id: '',
name: '不限'
},
{ {
id: 1, id: 1,
name: '全平台' name: '全平台'
@ -197,81 +200,8 @@ export default {
contestIds: [], contestIds: [],
isFirst: true, isFirst: true,
timerList: [], timerList: [],
defaultBanner:'../../../assets/img/info-banner.png',
}; };
}, },
directives: {
countdown: {
bind: function(el, binding, vnode) {
let that = vnode.context;
let item = that.listData[binding.value];
let time = "";
let second = 1000;
let minute = second * 60;
let hour = minute * 60;
let now = new Date().getTime();
let signUpStartTime = new Date(that.core.dateCompatible(item.signUpStartTime)).getTime(); //
let signUpEndTime = new Date(that.core.dateCompatible(item.signUpEndTime)).getTime(); //
let playStartTime = new Date(that.core.dateCompatible(item.playStartTime)).getTime(); //
let playEndTime = new Date(that.core.dateCompatible(item.playEndTime)).getTime(); //
switch (item.status) {
// statusgetData
case 0:
if (now > signUpStartTime) {
item.status = 1;
} else {
time = signUpStartTime - now;
}
break;
case 1:
if (now > signUpEndTime) {
item.status = 3;
} else {
time = signUpEndTime - now;
}
break;
case 2:
if (now > signUpEndTime) {
item.status = 3;
} else {
time = signUpEndTime - now;
}
break;
case 3:
if (now > playStartTime) {
item.status = 4;
} else {
time = playStartTime - now;
}
break;
case 4:
if (now > playEndTime) {
item.status = 5;
} else {
time = playEndTime - now;
}
break;
}
time = `${Math.floor(time / hour)}:${Math.floor(time % hour / minute)}:${Math.floor(time % hour % minute / second)}`;
let timer = setInterval(() => {
let timeList = time.split(":");
let total = Number.parseInt(timeList[0] * 60 * 60) + Number.parseInt(timeList[1] * 60) + Number.parseInt(timeList[2]);
if (total > 0) {
--total;
let hours = Math.floor(total / (60 * 60));
let minutes = Math.floor(total % (60 * 60) / 60);
let seconds = Math.floor(total % (60 * 60) % 60);
time = `${that.core.formateTime(hours)}:${that.core.formateTime(minutes)}:${that.core.formateTime(seconds)}`;
} else {
clearInterval(timer);
}
el.innerHTML = time;
}, 1000);
that.timerList.push(timer);
}
}
},
watch: { watch: {
keyword: function(val) { keyword: function(val) {
clearTimeout(this.searchTimer); clearTimeout(this.searchTimer);
@ -283,75 +213,88 @@ export default {
mounted() { mounted() {
this.getProvince() this.getProvince()
this.getData() this.getData()
this.$once("hook:beforeDestroy", function() { this.$once('hook:beforeDestroy', function() {
this.timerList.forEach((n, k) => { clearInterval(this.timer)
clearInterval(n); })
});
this.timerList = [];
});
}, },
methods: { methods: {
...mapActions("match", [ ...mapMutations('match', [
"setMatchId", "setMatchSignupStatus" 'SET_SOURCE'
]), ]),
async getData() { getList() {
this.loadIns = Loading.service() const { form } = this
const { token, form } = this const scope = form.competitionScope
const scope = form.competitionScope const data = {
this.$post(this.api.contestPageConditionQueryByOccupationlabStu, { pageNum: this.page,
pageNum: this.page, pageSize: this.pageSize,
pageSize: this.pageSize, platformSource: 1, // (01)
platformSource: 1, // (01) cityId: scope === 2 ? (form.cityId || null) : null, // id
competitionScope: scope, provinceId: scope === 2 ? (form.provinceId || null) : null,
cityId: scope === 2 ? (form.cityId || null) : null, // id sequence: form.sequence || null,
provinceId: scope === 2 ? (form.provinceId || null) : null, keyWord: this.keyword
sequence: form.sequence || null, }
keyWord: this.keyword if (scope) data.competitionScope = scope
}).then(({ data }) => { this.$post(this.api.contestPageConditionQueryByOccupationlabStu, data).then(({ data }) => {
this.listData = data.records this.listData = data.records
this.totals = data.total this.totals = data.total
let time = 60 * 60 * 1000 * 24; const second = 1000;
this.listData.forEach((n, k) => { const minute = second * 60;
// const hour = minute * 60;
let now = new Date().getTime(); this.listData.forEach((n, k) => {
let signUpStartTime = new Date(this.core.dateCompatible(n.signUpStartTime)).getTime(); // //
let signUpEndTime = new Date(this.core.dateCompatible(n.signUpEndTime)).getTime(); // let now = new Date().getTime();
let playStartTime = new Date(this.core.dateCompatible(n.playStartTime)).getTime(); // let signUpStartTime = new Date(this.core.dateCompatible(n.signUpStartTime)).getTime(); //
let playEndTime = new Date(this.core.dateCompatible(n.playEndTime)).getTime(); // let signUpEndTime = new Date(this.core.dateCompatible(n.signUpEndTime)).getTime(); //
let playStartTime = new Date(this.core.dateCompatible(n.playStartTime)).getTime(); //
// whetherToSignUp 01 let playEndTime = new Date(this.core.dateCompatible(n.playEndTime)).getTime(); //
if (now < signUpStartTime) { // let total = 0
n.status = 0; // whetherToSignUp 01
n.end = Math.floor((signUpStartTime - now) / time); if (now < signUpStartTime) { //
} else if (now > signUpStartTime && now < signUpEndTime) { // n.status = 0;
n.status = (!token || n.whetherToSignUp) ? 2 : 1 // 12(whetherToSignUp=1) total = signUpStartTime - now
n.end = Math.floor((signUpEndTime - now) / time); } else if (now > signUpStartTime && now < signUpEndTime) { //
} else if (now > signUpEndTime && now < playStartTime) { // , n.status = n.whetherToSignUp ? 2 : 1 // 12
n.status = 3; total = signUpEndTime - now
n.end = Math.floor((playStartTime - now) / time); } else if (now > signUpEndTime && now < playStartTime) { // ,
} else if (now > playStartTime && now < playEndTime) { // n.status = 3;
n.status = 4; total = playStartTime - now
n.end = Math.floor((playEndTime - now) / time); } else if (now > playStartTime && now < playEndTime) { //
} else if (now > playEndTime) { // n.status = 4;
n.status = 5; total = playEndTime - now
} } else if (now > playEndTime) { //
n.status = 5;
}
if (total > 0) {
const day = Math.floor(total / (60 * 60 * 1000 * 24))
const time = `${this.core.formateTime(Math.floor(total / hour))}:${this.core.formateTime(Math.floor(total % hour / minute))}:${this.core.formateTime(Math.floor(total % hour % minute / second))}`
n.end = day ? day + '天' : time
}
// //
const list = n.contestRangeRespList const list = n.contestRangeRespList
if (list) { if (list) {
const range = [] const range = []
list.map(e => { list.map(e => {
range.push(e.type ? (e.provinceName || e.cityName) : e.schoolName) range.push(e.type ? (e.provinceName || e.cityName) : e.schoolName)
}) })
n.ranges = `${n.range}${range.join(',')}` n.ranges = `${n.range}${range.join(',')}`
} else { } else {
n.ranges = n.range n.ranges = n.range
} }
}); });
this.loadIns.close() this.loadIns.close()
}).catch(res => { }).catch(res => {
this.loadIns.close() this.loadIns.close()
}) })
},
getData() {
this.loadIns = Loading.service()
this.getList()
if (!Setting.isDev) {
clearInterval(this.timer)
this.timer = setInterval(this.getList, 1000)
}
}, },
initData() { initData() {
this.page = 1 this.page = 1
@ -367,12 +310,14 @@ export default {
getCity() { getCity() {
const { form } = this const { form } = this
form.cityId = '' form.cityId = ''
this.$get(this.api.queryCity, { form.provinceId ?
provinceId: form.provinceId this.$get(this.api.queryCity, {
}).then(({ list }) => { provinceId: form.provinceId
this.cities = list }).then(({ list }) => {
this.cities = list
this.initData()
}).catch(res => {}) :
this.initData() this.initData()
}).catch(res => {})
}, },
changeType(type) { changeType(type) {
this.way = type; this.way = type;
@ -389,10 +334,7 @@ export default {
this.initData() this.initData()
}, },
toDetail(item) { toDetail(item) {
let status = item.status == 1 ? (item.signup ? true : false) : "hide"; this.$router.push(`/touristMatch/details?id=${item.id}&status=${item.status}&end=${item.end}`);
this.setMatchId(item.id);
this.setMatchSignupStatus(status);
this.$router.push(`/touristMatch/details?status=${item.status}&end=${item.end}`);
}, },
handleCurrentChange(val) { handleCurrentChange(val) {
this.page = val; this.page = val;
@ -401,7 +343,7 @@ export default {
signup(item) { signup(item) {
// //
if (item.status == 2) { if (item.status == 2) {
if (this.token) { if (util.local.get(Setting.tokenKey)) {
this.$post(this.api.addApplicant, { this.$post(this.api.addApplicant, {
contestId: item.id contestId: item.id
}).then(res => { }).then(res => {
@ -412,6 +354,7 @@ export default {
this.$confirm('请先登录,是否直接前往登录?', "提示", { this.$confirm('请先登录,是否直接前往登录?', "提示", {
type: 'success' type: 'success'
}).then(() => { }).then(() => {
this.SET_SOURCE()
this.$router.push('/login') this.$router.push('/login')
}).catch(() => {}) }).catch(() => {})
} }
@ -492,6 +435,9 @@ export default {
.label { .label {
margin-right: 10px; margin-right: 10px;
} }
.el-select {
width: 130px;
}
} }
.list-inner { .list-inner {
display: flex; display: flex;

@ -30,8 +30,8 @@ if (isHh) {
} else if (isDev) { } else if (isDev) {
// 本地 // 本地
systemPath = `http://${location.hostname}:8093/#/` systemPath = `http://${location.hostname}:8093/#/`
// host = "http://121.37.12.51:9000/"; // 中台测试服 host = "http://121.37.12.51:9000/"; // 中台测试服
host = "http://192.168.31.151:9000/"; // 榕 // host = "http://192.168.31.151:9000/"; // 榕
// host = "http://192.168.31.137:9000/"; // 赓 // host = "http://192.168.31.137:9000/"; // 赓
} }

@ -4,23 +4,14 @@
export default { export default {
namespaced: true, namespaced: true,
state: { state: {
matchId: "", toMatch: false
matchSignupStatus: false
}, },
mutations: { mutations: {
SET_MATCH_ID: (state, id) => { SET_SOURCE: state => {
state.matchId = id; state.toMatch = true
}, }
SET_MATCH_SIGNUP_STATUS: (state, value) => {
state.matchSignupStatus = value;
}
}, },
actions: { actions: {
setMatchId({ state, commit }, id) {
commit("SET_MATCH_ID", id);
},
setMatchSignupStatus({ state, commit }, value) {
commit("SET_MATCH_SIGNUP_STATUS", value);
}
} }
}; };

@ -2,7 +2,6 @@ import Setting from "@/setting";
import util from "@/libs/util"; import util from "@/libs/util";
import { post, get, del, put } from "@/plugins/requests/index.js"; import { post, get, del, put } from "@/plugins/requests/index.js";
import api from "@/api"; import api from "@/api";
import addRoutes from "@/libs/route/addRoutes";
/** /**
* 用户信息 * 用户信息
* */ * */

Loading…
Cancel
Save