@ -11,9 +11,11 @@
< / e l - t a b s >
< div class = "action" >
< p class = "end-text" v-if ="status != 5" >
距离 { { endList [ status ] } } 还有 < em > { { end } } < / em >
距离 { { endList [ status ] } } 还有
< template v-if ="end > 0" > < em > { { end } } < / em > 天 < / template >
< em v -else -if = " end " v-countdown > {{ end }} < / em >
< / p >
< 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 >
< a v-if ="status != 4 || (status == 4 && curStage)" 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" >
@ -33,6 +35,21 @@
< / li >
< / ul >
< / template >
< div class = "l-title" id = "part1" > < img src = "@/assets/img/label.png" alt = "" > 赛程 、 规则与内容 < / div >
< h6 class = "rule-title" > 共3个竞赛阶段 , 同一个团队每个成员只能参加一个阶段赛项 < / h6 >
< div v-for ="(rule, i) in form.competitionStage" :key="i" class="rule" >
< p > { { rule . stageName } } < / p >
< p > 比赛时间 : { { rule . startTime + ' ~ ' + rule . endTime } } < / p >
< p > 比赛方式 : { { methods . find ( e => e . id == rule . method ) && methods . find ( e => e . id == rule . method ) . name } } < / p >
< p > 课程系统 : { { rule . systemName } } < / p >
< template v-if ="form.completeCompetitionSetup.competitionType" >
< p > 团队参赛人数限制 : { { rule . teamNumLimit } } < / p >
< p > 团队成绩计算方式 : { { teamCalculationMethods . find ( e => e . id == rule . teamCalculationMethod ) && teamCalculationMethods . find ( e => e . id == rule . teamCalculationMethod ) . name } } < / p >
< / template >
< p > ( 阶段 ) 比赛结束后 { { rule . resultAnnouncementTime } } 小时 , 公布 ( 阶段 ) 比赛成绩 。 < / p >
< / div >
<!-- 进展 -- >
< div class = "l-title" id = "part2" > < img src = "@/assets/img/label.png" alt = "" > 竞赛进展 < / div >
@ -70,6 +87,157 @@
< / div >
< / div >
< / template >
<!-- 竞赛排名 -- >
< template v-if ="form.competitionRegistration && form.competitionRegistration.teamId" >
< div class = "l-title" id = "part4" > < img src = "@/assets/img/label.png" alt = "" > 竞赛排名 < / div >
< el -tabs v-model ="curArch" @tab-click="getRank" >
< el -tab -pane v-for ="(item, index) in arches" :key="index" :label="item.stageName + '排名'" :name="item.stageId" > < / el -tab -pane >
< / e l - t a b s >
< el -table ref = "table" :data ="ranks" stripe header -align = " center " >
< el -table -column type = "index" width = "60" label = "排名" align = "center" > < / e l - t a b l e - c o l u m n >
< el -table -column prop = "teamName" label = "团队名称" > < / e l - t a b l e - c o l u m n >
< el -table -column prop = "leaderName" label = "队长" > < / e l - t a b l e - c o l u m n >
< el -table -column prop = "schoolName" label = "学校" > < / e l - t a b l e - c o l u m n >
< el -table -column prop = "school" label = "用时" >
< template slot -scope = " scope " >
{ { scope . row . timeSum } } min
< / template >
< / e l - t a b l e - c o l u m n >
< el -table -column prop = "score" label = "分数" > < / e l - t a b l e - c o l u m n >
< / e l - t a b l e >
< / template >
< div class = "l-title m-t-20" id = "part4" > < img src = "@/assets/img/label.png" alt = "" > 参赛信息 < / div >
< table class = "table" >
< template v-if ="!form.completeCompetitionSetup.competitionType || info.team.captain" >
< tr >
< th width = "150" > 姓名 : < / th >
< td > { { info . person . userName } } < / td >
< / tr >
< tr >
< th > 学号 : < / th >
< td > { { info . person . workNumber } } < / td >
< / tr >
< tr >
< th > 学校 : < / th >
< td > { { info . person . schoolName } } < / td >
< / tr >
< / template >
< template v-if ="form.completeCompetitionSetup.competitionType" >
< tr >
< th > 团队名称 : < / th >
< td >
< el -input v-if ="info.team.captain === 0" :disabled="!editing" v-model="info.team.teamName" > < / el -input >
< span v-else > {{ info.team.teamName }} < / span >
< / td >
< / tr >
< template v-if ="info.team.captain" >
< tr >
< th > 队长 : < / th >
< td > { { info . caption . userName } } { { info . caption . schoolName && ',' + info . caption . schoolName } } { { info . caption . workNumber && ',' + info . caption . workNumber } } < / td >
< / tr >
< tr >
< th > 团队成员 : < / th >
< td >
< el -tag v-for ="(item, i) in info.teamDetail" :key="i" style="margin-right: 5px" > {{ item.userName }} < / el -tag >
< / td >
< / tr >
< / template >
< / template >
< tr >
< th > 指导老师 : < / th >
< td v-if ="info.team.captain === 0 || !form.completeCompetitionSetup.competitionType" >
< div class = "plus" >
< i class = "el-icon-circle-plus-outline icon" @click ="addAdvisor" > < / i >
< / div >
< div v-for ="(item, i) in info.teamInstructors" :key="i" class="line" >
< el -input placeholder = "请输入姓名" v-model ="item.name" clearable size="mini" > < / el -input >
< el -input placeholder = "请输入职务" maxlength = "10" v-model ="item.position" clearable size="mini" > < / el -input >
< el -input placeholder = "请输入联系方式" maxlength = "11" v-model ="item.phone" clearable size="mini" > < / el -input >
< i class = "el-icon-check icon" @click ="submitAdvisor(item)" > < / i >
< i class = "el-icon-delete icon" @ click = "delAdvisor(item, i)" > < / i >
< / div >
< / td >
< td v-else >
{ { info . teamInstructors . map ( e => e . name ) . join ( ',' ) } }
< / td >
< / tr >
< tr v-if ="form.completeCompetitionSetup.competitionType" >
< th > 团队邀请码 : < / th >
< td >
< el -input v-if ="info.team.captain === 0" :disabled="!editing" v-model="info.team.invitationCode" > < / el -input >
< span v-else > {{ info.team.invitationCode }} < / span >
< / td >
< / tr >
< tr >
< th > 竞赛阶段 : < / th >
< td >
< table class = "table tc" >
< tr >
< th width = "80" > 序号 < / th >
< th > 赛项阶段名称 < / th >
< template v-if ="form.completeCompetitionSetup.competitionType" >
< th > 参赛人数限制 < / th >
< th > 允许参赛人员 < / th >
< th v-if ="info.team.captain === 0 && form.rule === 0" > 总分 < / th >
< / template >
< th > 竞赛成绩 < / th >
< / tr >
< template v-if ="info.stages.length" >
< tr v-for ="(item, i) in info.stages" :key ="i" >
< td > { { i + 1 } } < / td >
< td > { { item . stageName } } < / td >
< template v-if ="form.completeCompetitionSetup.competitionType" >
< td > { { item . peopleLimit } } < / td >
< td >
< el -button :disabled ="!editing" type = "danger" size = "mini" @click ="selectPar(item)" > 修改 < / el -button >
< span class = "m-l-5" > { { item . teamParticipantIds } } < / span >
< / td >
< td v-if ="info.team.captain === 0 && form.rule === 0" > < / td >
< / template >
< td >
< span v-if ="item.score" class="m-r-10" > 分数 {{ item.score }} < / span >
< el -button type = "text" : disabled = "item.resultsDetails === 1" @click ="show(item)" > 查看成绩详情 < / el -button >
< / td >
< / tr >
< / template >
< tr v-else >
< td colspan = "6" > 暂无数据 < / td >
< / tr >
< / table >
< el -alert
v - if = "form.completeCompetitionSetup.competitionType && info.team.captain === 0"
style = "margin-top: 10px;"
title = "注:请团长(团队创建人)设置各阶段参赛成员,只有被选择的允许参赛成员可进入对应阶段比赛,每个团队成员只能参加一个赛项阶段!"
type = "warning"
show - icon >
< / e l - a l e r t >
< / td >
< / tr >
< / table >
< div v-if ="form.completeCompetitionSetup.competitionType && info.team.captain === 0" class="m-t-20 text-center" >
< el -button type = "primary" @click ="edit" > {{ editing ? ' 保存 ' : ' 编辑 ' }} < / el -button >
< / div >
< template v-if ="form.completeCompetitionSetup.competitionType && info.team.captain === 0" >
< div class = "l-title m-t-20" > 团队成员 < / div >
< div class = "flex-center" >
< p > 队长 : { { info . caption . userName } } < / p >
< el -button type = "primary" : disabled = "status > 3" @click ="transfer" > 转让队长 < / el -button >
< / div >
< el -table :data ="info.teamDetail" stripe header -align = " center " >
< el -table -column prop = "userName" label = "成员姓名" min -width = " 100 " align = "center" > < / e l - t a b l e - c o l u m n >
< el -table -column prop = "schoolName" label = "学校" min -width = " 100 " align = "center" > < / e l - t a b l e - c o l u m n >
< el -table -column prop = "workNumber" label = "学号" min -width = " 100 " align = "center" > < / e l - t a b l e - c o l u m n >
< el -table -column prop = "createTime" label = "加入时间" width = "180" align = "center" > < / e l - t a b l e - c o l u m n >
< el -table -column label = "操作" align = "center" width = "160" >
< template slot -scope = " scope " >
< el -button v-if ="scope.row.captain" type="text" :disabled="status > 3" @click="removeLine(scope.row)" > 踢出团队 < / el -button >
< / template >
< / e l - t a b l e - c o l u m n >
< / e l - t a b l e >
< / template >
< / div >
< / div >
< / div >
@ -115,6 +283,56 @@
< el -button size = "small" @ click = "teamVisible = false" > 取消 < / e l - b u t t o n >
< / span >
< / e l - d i a l o g >
< el -dialog title = "选择参赛成员" :visible.sync ="transferVisible" :close-on-click-modal ="false" width = "400px" >
< template v-for ="(item, i) in info.teamDetail" >
< el -radio v-if ="item.captain" :key="i" v-model="checkedPlayer" :label="item.teamId" > {{ item.userName }} < / el -radio >
< / template >
< span slot = "footer" class = "dialog-footer" >
< el -button size = "small" type = "primary" @click ="transferSubmit" > 确定 < / el -button >
< el -button size = "small" @ click = "transferVisible = false" > 取消 < / e l - b u t t o n >
< / span >
< / e l - d i a l o g >
< el -dialog title = "选择参赛成员" :visible.sync ="chooseVisible" :close-on-click-modal ="false" width = "400px" >
< template v-if ="info.teamLimit" >
< el -radio v-for ="(item, i) in info.teamDetail" :key="i" v-model="checkedMember" :label="item.accountId" > {{ item.userName }} < / el -radio >
< / template >
< el -checkbox -group v -else v-model ="checkedMembers" >
< el -checkbox v-for ="(item, i) in info.teamDetail" :key="i" :label="item.accountId" > {{ item.userName }} < / el -checkbox >
< / e l - c h e c k b o x - g r o u p >
< p v-if ="info.teamLimit" style="margin-top: 15px;font-size: 12px;" > 注 : 当前阶段限制1人参赛 , 且此竞赛每个成员只能参加一个阶段赛项 。 < / p >
< span slot = "footer" class = "dialog-footer" >
< el -button size = "small" type = "primary" @click ="chooseSubmit" > 确定 < / el -button >
< el -button size = "small" @ click = "chooseVisible = false" > 取消 < / e l - b u t t o n >
< / span >
< / e l - d i a l o g >
< el -dialog title = "团队得分详情" :visible.sync ="memberVisible" width = "900px" :close-on-click-modal ="false" >
< h6 v-if ="members.length" style="margin-bottom: 10px;font-size: 16px;" > 团队名称 : {{ members [ 0 ] .teamName }} 阶段名称 : {{ curRow.stageName }} < / h6 >
< table class = "table tc" >
< tr >
< th width = "60" > 序号 < / th >
< th width = "100" > 姓名 < / th >
< th width = "100" > 学校 < / th >
< th width = "100" > 用时 < / th >
< th width = "100" > 分数 < / th >
< th width = "100" > 得分详情 < / th >
< / tr >
< tr v-for ="(item, i) in members" :key ="i" >
< td > { { i + 1 } } < / td >
< td > { { item . userName } } < / td >
< td > { { item . schoolName } } < / td >
< td > { { item . timeSum } } min < / td >
< td > { { item . score } } < / td >
< td >
< el -button type = "text" @click ="toReport(item)" > 查看 < / el -button >
< / td >
< / tr >
< / table >
< span slot = "footer" class = "dialog-footer" >
< el -button size = "small" type = "primary" @ click = "memberVisible = false" > 确定 < / e l - b u t t o n >
< / span >
< / e l - d i a l o g >
< / div >
< / template >
@ -123,15 +341,19 @@ import { mapMutations } from "vuex";
import breadcrumb from '@/components/breadcrumb'
import util from '@/libs/util'
import Setting from "@/setting"
import Const from '@/const/match'
export default {
name : 'matchdetail' ,
data ( ) {
return {
id : this . $route . query . id ,
id : + this . $route . query . id ,
end : '' ,
status : '' ,
statusList : [ "等待报名" , "已 报名" , "立即报名" , "报名截止" , "进入初赛" , "已结束" ] ,
statusList : [ "等待报名" , "取消 报名" , "立即报名" , "报名截止" , "进入初赛" , "已结束" ] ,
endList : [ "报名开始" , "报名截止" , "报名截止" , "竞赛开始" , "竞赛结束" , "" ] ,
rules : Const . rules ,
methods : Const . methods ,
teamCalculationMethods : Const . teamCalculationMethods ,
form : {
name : '' ,
coverUrl : '' ,
@ -140,7 +362,8 @@ export default {
signUpEndTime : '' ,
playStartTime : '' ,
playEndTime : '' ,
completeCompetitionSetup : { }
completeCompetitionSetup : { } ,
competitionRegistration : { }
} ,
curType : '1' ,
typeList : [
@ -161,13 +384,17 @@ export default {
timer : null ,
notices : [ ] ,
noticeDetail : { } ,
curArch : '0' ,
arches : [ ] ,
ranks : [ ] ,
enterVisible : false ,
enterForm : {
competitionId : this . $route . query . id ,
teamId : '' ,
invitationCode : '' ,
registrationInvitationCode : ''
registrationInvitationCode : '' ,
whetherSignUp : 1
} ,
teamVisible : false ,
@ -178,8 +405,35 @@ export default {
registrationInvitationCode : '' ,
teamName : '' ,
invitationCode : '' ,
whetherSignUp : 1
} ,
curStage : null ,
info : {
isCaption : 0 ,
person : { } ,
caption : { } ,
team : {
captain : 1 ,
invitationCode : ''
} ,
stages : [ ] ,
teamDetail : [ ] ,
teamInstructors : [ ]
} ,
curStage : null
originIns : {
position : '' ,
name : '' ,
phone : '' ,
} ,
checkedPlayer : '' ,
transferVisible : false ,
editing : false ,
memberVisible : false ,
members : [ ] ,
curRow : { } ,
chooseVisible : false ,
checkedMember : '' ,
checkedMembers : [ ]
} ;
} ,
components : {
@ -188,16 +442,17 @@ export default {
directives : {
countdown : {
bind : function ( el , binding , vnode ) {
let that = vnode . context ;
let that = vnode . context
const { form } = that
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 ( that . signUpStartTime ) ) . getTime ( ) ; / / 报 名 开 始 时 间
let signUpEndTime = new Date ( that . core . dateCompatible ( that . signUpEndTime ) ) . getTime ( ) ; / / 报 名 结 束 时 间
let playStartTime = new Date ( that . core . dateCompatible ( that . playStartTime ) ) . getTime ( ) ; / / 比 赛 开 始 时 间
let playEndTime = new Date ( that . core . dateCompatible ( that . playEndTime ) ) . getTime ( ) ; / / 比 赛 结 束 时 间
let signUpStartTime = new Date ( that . core . dateCompatible ( form . signUpStartTime ) ) . getTime ( ) ; / / 报 名 开 始 时 间
let signUpEndTime = new Date ( that . core . dateCompatible ( form . signUpEndTime ) ) . getTime ( ) ; / / 报 名 结 束 时 间
let playStartTime = new Date ( that . core . dateCompatible ( form . playStartTime ) ) . getTime ( ) ; / / 比 赛 开 始 时 间
let playEndTime = new Date ( that . core . dateCompatible ( form . playEndTime ) ) . getTime ( ) ; / / 比 赛 结 束 时 间
switch ( that . status ) {
/ / s t a t u s 每 个 值 的 解 释 请 看 g e t D a t a 方 法
case 0 :
@ -258,7 +513,6 @@ export default {
this . getData ( )
this . getProgress ( )
this . getNotice ( )
this . getTeam ( )
} ,
methods : {
@ -268,7 +522,6 @@ export default {
getData ( ) { / / 获 取 竞 赛 信 息
this . $post ( ` ${ this . api . getCompetition } ?competitionId= ${ this . id } ` ) . then ( ( { competition } ) => {
this . handleStatus ( competition )
console . log ( "🚀 ~ file: index.vue:273 ~ this.$post ~ competition" , competition )
const list = competition . competitionAnnexList
/ / 附 件
if ( list ) {
@ -277,7 +530,20 @@ export default {
e . canPreview = util . canPreview ( filePath . substr ( filePath . lastIndexOf ( '.' ) + 1 ) )
} )
}
const arches = [ ]
/ / 积 分 赛 才 有 总 分 排 名
competition . rule === 0 && arches . push ( {
stageId : '0' ,
stageName : '总分'
} )
arches . push ( ... competition . competitionStage )
arches . map ( e => e . stageId = e . stageId + '' )
this . arches = arches
this . form = competition
const type = competition . completeCompetitionSetup . competitionType
const reg = competition . competitionRegistration
if ( ! type || ( type && reg ) ) this . getInfo ( )
reg && reg . teamId && this . getRank ( )
this . $refs . breadcrumb . update ( '全部赛事/' + competition . name )
} ) . catch ( err => { } )
} ,
@ -305,9 +571,9 @@ export default {
total = playStartTime - now
} else if ( now > playStartTime && now < playEndTime ) { / / 比 赛 进 行 中
/ / 赛 事 阶 段
if ( n . competitionStage ) {
if ( n . competitionStage && n . competitionRegistration ) {
for ( const e of n . competitionStage ) {
if ( now > new Date ( e . startTime ) && now < new Date ( e . endTime ) && ! e . count ) {
if ( now > new Date ( e . startTime ) && now < new Date ( e . endTime ) && ! e . count && e . method !== 2 ) {
this . curStage = e
this . statusList [ 4 ] = '进入' + e . stageName
break
@ -326,6 +592,41 @@ export default {
this . end = day ? day + '天' : time
}
} ,
/ / 获 取 竞 赛 信 息
getInfo ( ) {
this . $post ( ` ${ this . api . entryInformation } ?competitionId= ${ this . id } ` ) . then ( res => {
const info = res . entryInformation
if ( ! info . teamInstructors . length ) info . teamInstructors . push ( this . originIns )
if ( info . personalDetail ) {
info . team = { }
info . teamDetail = [ ]
} else {
info . isCaption = info . team . caption
}
const caption = info . teamDetail . find ( e => ! e . caption )
info . caption = caption ? caption : { }
info . person = info . personalDetail || info . teamDetail . find ( e => e . accountId == info . team . accountId )
this . info = info
} ) . catch ( err => { } ) ;
} ,
/ / 编 辑 保 存
edit ( ) {
if ( this . editing ) {
const { teamId , teamName , invitationCode } = this . info . team
this . $post ( this . api . addCompetitionTeam , {
competitionId : this . id ,
teamId ,
teamName ,
invitationCode ,
whetherSignUp : 0
} ) . then ( res => {
this . getInfo ( )
util . successMsg ( '保存成功' )
} ) . catch ( res => { } )
} else {
this . editing = ! this . editing
}
} ,
getProgress ( ) { / / 获 取 竞 赛 进 展
this . $get ( this . api . getCompetitionProgress , {
competitionId : this . id
@ -361,6 +662,139 @@ export default {
toNotice ( item ) {
this . $router . push ( ` noticeDetail?id= ${ item . id } &matchId= ${ this . id } &name= ${ this . form . name } &end= ${ this . end } &status= ${ this . status } ` )
} ,
/ / 获 取 排 名
getRank ( ) {
const cur = + this . curArch
const data = {
pageNum : 1 ,
pageSize : 1000 ,
competitionId : this . id ,
isOverallRanking : cur ? 0 : 1
}
/ / i f ( c u r ) { / / 阶 段
/ / d a t a . s t a g e I d s = c u r ? c u r : t h i s . f o r m . c o m p e t i t i o n S t a g e . m a p ( e = > + e . s t a g e I d ) . j o i n ( )
data . stageIds = cur ? cur : ''
this . $post ( this . api . frontOfficeCompetitionRanking , data ) . then ( ( { list } ) => {
this . ranks = list
} ) . catch ( res => { } )
/ / } e l s e { / / 总 分
/ / d a t a . s t a g e I d s = t h i s . f o r m . c o m p e t i t i o n S t a g e . m a p ( e = > + e . s t a g e I d ) . j o i n ( )
/ / d a t a . i s O v e r a l l R a n k i n g = 1
/ / t h i s . $ p o s t ( t h i s . a p i . f r o n t D e s k O v e r a l l R a n k i n g , d a t a ) . t h e n ( ( { p a g e } ) = > {
/ / t h i s . r a n k s = p a g e
/ / } ) . c a t c h ( r e s = > { } )
/ / }
} ,
/ / 删 除 指 导 老 师
delAdvisor ( row , i ) {
if ( row . id ) {
this . $confirm ( '确定要删除吗?' , '提示' , {
type : 'warning'
} ) . then ( ( ) => {
this . $post ( ` ${ this . api . deleteAnAdvisor } ?id= ${ row . id } ` ) . then ( res => {
util . successMsg ( '删除成功' )
/ / t h i s . g e t C l a s s i f i c a t i o n ( )
} ) . catch ( res => { } )
} ) . catch ( ( ) => { } )
} else {
this . classifications . splice ( i , 1 )
}
} ,
/ / 添 加 指 导 老 师
addAdvisor ( ) {
if ( this . info . teamInstructors . length > 5 )
this . info . teamInstructors . push ( JSON . parse ( JSON . stringify ( this . originIns ) ) )
} ,
/ / 提 交 指 导 老 师
submitAdvisor ( row ) {
if ( ! row . name ) return util . errorMsg ( '请输入姓名' )
this . $post ( this . api . addAnAdvisor , {
name : row . name ,
competitionId : this . id ,
id : row . id ,
teamId : this . form . competitionRegistration ? this . form . competitionRegistration . teamId : '' ,
phone : row . phone ,
position : row . position ,
} ) . then ( res => {
util . successMsg ( ( row . id ? '修改' : '新增' ) + '成功' )
this . getInfo ( )
} ) . catch ( res => { } )
} ,
/ / 显 示 转 让 队 长
transfer ( ) {
this . transferVisible = true
} ,
/ / 转 让 队 长 提 交
transferSubmit ( ) {
if ( ! this . checkedPlayer ) return util . errorMsg ( '请选择成员' )
this . $post ( this . api . captainOfTransfer , {
captainId : this . info . caption . teamId ,
playerId : this . checkedPlayer
} ) . then ( res => {
util . successMsg ( '转让成功' )
this . transferVisible = false
this . getInfo ( )
} ) . catch ( res => { } )
} ,
/ / 踢 出 团 队
removeLine ( row ) {
this . $post ( ` ${ this . api . removeTheLine } ?teamId= ${ row . teamId } ` ) . then ( res => {
util . successMsg ( '移除成功' )
this . getInfo ( )
} ) . catch ( res => { } )
} ,
/ / 选 择 参 赛 人 员
selectPar ( row ) {
const item = this . form . competitionStage . find ( e => e . stageId == row . stageId )
if ( item ) {
/ / 该 阶 段 已 经 开 始 比 赛 则 不 能 修 改
const now = new Date ( )
if ( now >= new Date ( item . startTime ) && now <= new Date ( item . endTime ) ) {
return util . errorMsg ( '该阶段比赛已经开始,无法修改允许参赛人员!' )
} else {
this . curRow = row
this . chooseVisible = true
}
}
} ,
/ / 选 择 参 赛 人 员 提 交
chooseSubmit ( ) {
this . $post ( this . api . stageSelectParticipants , {
accountIds : this . info . teamLimit ? [ this . checkedMember ] : this . checkedMembers ,
competitionId : this . id ,
stageId : this . curRow . stageId ,
teamId : this . form . competitionRegistration . teamId
} ) . then ( res => {
util . successMsg ( '修改成功' )
this . getInfo ( )
this . chooseVisible = false
} ) . catch ( res => { } )
} ,
/ / 查 看 成 绩 详 情
show ( row ) {
/ / 团 队 展 示 弹 框 , 个 人 跳 转 实 验 报 告
if ( this . form . completeCompetitionSetup . competitionType && this . info . team . captain === 0 ) { / / 团 队 比 赛 并 且 是 团 队 , 则 展 示 团 队 成 员 成 绩 详 情
this . curRow = row
this . memberVisible = true
const teamId = this . form . competitionRegistration . teamId
if ( teamId ) {
this . $post ( this . api . stageGradeManagementList , {
pageNum : 1 ,
pageSize : 1000 ,
competitionId : this . id ,
stageId : row . stageId ,
isNakadai : 0
} ) . then ( ( { page } ) => {
this . members = page . records . filter ( e => e . teamId === teamId )
} ) . catch ( res => { } )
} else {
this . members = [ ]
}
} else if ( row . reportId ) { / / 团 员 或 者 个 人 比 赛 , 并 且 有 r e p o r t I d , 则 进 入 实 验 报 告
this . $router . push ( ` /record/show?reportId= ${ row . reportId } ` )
}
} ,
/ / 报 名 提 交
enterSubmit ( ) {
@ -380,7 +814,8 @@ export default {
competitionId : this . id ,
teamId : '' ,
registrationInvitationCode : '' ,
invitationCode : ''
invitationCode : '' ,
whetherSignUp : 1
}
} ,
@ -418,20 +853,35 @@ export default {
competitionId : this . id ,
teamName : '' ,
invitationCode : '' ,
registrationInvitationCode : ''
registrationInvitationCode : '' ,
whetherSignUp : 1
}
} ,
/ / 立 即 报 名
signup ( ) {
const { status } = this
const { status , form } = this
/ / 如 果 登 录 了
if ( util . local . get ( Setting . tokenKey ) ) {
if ( status == 4 ) { / / 进 入 比 赛
if ( form . isDisable === 1 ) return util . errorMsg ( '当前用户已被禁赛,如有疑问,请联系平台管理员。' ) / / 被 禁 用 的 用 户 不 能 进 入 大 赛
/ / 是 否 允 许 参 加 赛 事 ( 淘 汰 赛 制 )
if ( form . rule === 1 ) {
this . $post ( this . api . allowedParticipateCompetition , {
competitionId : this . id ,
number : this . curStage . number ,
stageId : this . curStage . stageId ,
teamId : form . competitionRegistration . teamId ,
} ) . then ( res => {
/ / t h i s . t o S u b ( )
} ) . catch ( res => { } )
} else {
this . toSub ( )
}
this . toSub ( )
} else if ( status == 2 ) { / / 报 名
/ / 团 队 赛 报 名
if ( this . form . completeCompetitionSetup . competitionType ) {
if ( form . completeCompetitionSetup . competitionType ) {
this . enterVisible = true
} else { / / 个 人 赛 报 名
this . $post ( this . api . addCompetitionRegistration , {
@ -471,7 +921,7 @@ export default {
util . cookies . set ( 'projectId' , form . projectId )
util . cookies . set ( 'token' , token )
util . cookies . set ( 'courseId' , form . cid )
/ / u t i l . c o o k i e s . s e t ( ' c u r r i c u l u m N a m e ' , e s c a p e ( t h i s . c u r r i c u l u m N a m e ) )
util . cookies . set ( 'curriculumName' , escape ( form . systemName ) )
util . cookies . set ( 'systemId' , form . systemId )
util . cookies . set ( 'competitionId' , this . form . id )
util . cookies . set ( 'stageId' , form . stageId )
@ -487,14 +937,13 @@ export default {
/ / 进 入 子 系 统
toSub ( ) {
const { form } = this
const { systemId , projectId , cid } = this . curStage
const { systemId , projectId , cid , stageId } = this . curStage
const competitionId = form . id
const { stageId } = form
const teamId = form . competitionRegistration . teamId
let token = util . local . get ( Setting . tokenKey ) ;
if ( systemId == 11 ) {
/ / 银 行 系 统
location . href = ` ${ Setting . systemPath } /#/index/list?curriculumName= ${ this . curriculumName } &token= ${ token } &cid= ${ this . courseI d} &systemId= ${ systemId } &projectId= ${ projectId } &competitionId= ${ competitionId } &stageId= ${ stageId } &teamId= ${ teamId } &assessmentId=&classId=&stopTime=&test=true `
location . href = ` ${ Setting . systemPath } /#/index/list?curriculumName= ${ this . curriculumName } &token= ${ token } &cid= ${ ci d} &systemId= ${ systemId } &projectId= ${ projectId } &competitionId= ${ competitionId } &stageId= ${ stageId } &teamId= ${ teamId } &assessmentId=&classId=&stopTime=&test=true `
} else if ( systemId == 12 ) {
/ / 众 筹 系 统
window . open ( ` http://120.78.139.126:8879?systemId= ${ systemId } &courseId= ${ cid } &projectId= ${ projectId } &token= ${ token } &userId= ${ this . userId } &classId=1&competitionId= ${ competitionId } &stageId= ${ stageId } &teamId= ${ teamId } ` ) ;
@ -526,6 +975,19 @@ export default {
. main . center - wrap {
margin - top : 30 px ;
}
. rule - title {
margin - bottom : 10 px ;
font - size : 16 px ;
}
. rule {
padding : 15 px ;
margin - bottom : 15 px ;
border : 1 px solid # dfdfdf ;
p {
font - size : 14 px ;
line - height : 30 px ;
}
}
. content {
position : relative ;
padding : 20 px 40 px ;
@ -804,6 +1266,44 @@ export default {
text - overflow : ellipsis ;
}
}
. table {
width : 100 % ;
border - collapse : collapse ;
th , td {
padding : 12 px ;
border : 1 px solid # ebeef5 ;
}
& . tc {
text - align : center ;
}
th {
text - align : center ;
background - color : # f8faff ;
}
. icon {
margin - right : 10 px ;
font - size : 16 px ;
color : # 7 a7a7a ;
cursor : pointer ;
}
. plus {
margin - bottom : 10 px ;
text - align : right ;
}
. line {
display : flex ;
align - items : center ;
. el - input {
margin - right : 15 px ;
}
}
}
. flex - center {
display : flex ;
justify - content : space - between ;
align - items : center ;
margin - bottom : 15 px ;
}
/deep/ . dia - form {
. w - 100 {
width : 100 % ;