@ -8,18 +8,24 @@
< el -tabs v-model ="curType" >
< el -tab -pane v-for ="(item, index) in typeList" :key="index" :label="item.name" :name="item.id" > < / el -tab -pane >
< / e l - t a b s >
< 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 class = "action" >
< p class = "end-text" v-if ="status != 5" >
距离 { { endList [ status ] } } 还有 < em > { { 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 >
< / div >
< / div >
< h6 class = "title" > { { title } } < / h6 >
< div class = "meta" > 最近编辑时间 : { { gmtModified } } < / div >
< div class = "texts ql-editor" v-html ="description" v-if="curType == 1" > < / div >
< div v-else >
< ul class = "progress" v-if ="progress.length" >
< li v-for ="(item,index) in progress" :key ="index ">
< i class = "dot" : class = "[item.status == 0 ? 'not' : (item.status == 1 ? 'ing' : 'done el-icon-circle-check')]" > < / i >
< 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 >
< / div >
< / div >
@ -35,6 +41,9 @@ export default {
return {
id : this . $store . state . match . matchId ,
showSignup : this . $store . state . match . matchSignupStatus ,
end : this . $route . query . end ,
statusList : [ "等待报名" , "已报名" , "立即报名" , "报名截止" , "比赛中" , "已结束" ] ,
endList : [ "报名开始" , "报名截止" , "报名截止" , "竞赛开始" , "竞赛结束" , "" ] ,
coverUrl : '' ,
title : '' ,
curType : '1' ,
@ -52,14 +61,88 @@ export default {
] ,
description : '' ,
gmtModified : '' ,
signUpStartTime : '' ,
signUpEndTime : '' ,
playStartTime : '' ,
playEndTime : '' ,
progress : [ ] ,
status : this . $route . query . status ,
statusList : [ "等待报名" , "已报名" , "立即报名" , "报名截止" , "比赛中" , "已结束" ] ,
timer : null
} ;
} ,
components : {
breadcrumb
} ,
directives : {
countdown : {
bind : function ( el , binding , vnode ) {
let that = vnode . context ;
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 ( ) ; / / 比 赛 结 束 时 间
switch ( that . status ) {
/ / s t a t u s 每 个 值 的 解 释 请 看 g e t D a t a 方 法
case 0 :
if ( now > signUpStartTime ) {
that . status = 1 ;
} else {
time = signUpStartTime - now ;
}
break ;
case 1 :
if ( now > signUpEndTime ) {
that . status = 3 ;
} else {
time = signUpEndTime - now ;
}
break ;
case 2 :
if ( now > signUpEndTime ) {
that . status = 3 ;
} else {
time = signUpEndTime - now ;
}
break ;
case 3 :
if ( now > playStartTime ) {
that . status = 4 ;
} else {
time = playStartTime - now ;
}
break ;
case 4 :
if ( now > playEndTime ) {
that . status = 5 ;
} else {
time = playEndTime - now ;
}
break ;
}
time = ` ${ Math . floor ( time / hour ) } : ${ Math . floor ( time % hour / minute ) } : ${ Math . floor ( time % hour % minute / second ) } ` ;
that . 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 ( that . timer ) ;
}
el . innerHTML = time ;
} , 1000 )
}
}
} ,
computed : {
coverUrlComputed ( ) {
return this . coverUrl ? 'url(' + this . coverUrl + ')' : "url('../../../assets/img/info-banner.png')"
@ -77,6 +160,11 @@ export default {
this . description = data . description
this . title = data . name
this . gmtModified = data . gmtModified
this . signUpStartTime = data . signUpStartTime
this . signUpEndTime = data . signUpEndTime
this . playStartTime = data . playStartTime
this . playEndTime = data . playEndTime
this . $forceUpdate ( )
this . $refs . breadcrumb . update ( '全部赛事/' + data . name )
} ) . catch ( err => { } )
} ,
@ -128,8 +216,13 @@ export default {
color : # 999 ;
text - align : center ;
}
. action {
display : inline - flex ;
align - items : center ;
}
. status {
padding : 0 23 px ;
padding : 0 16 px ;
margin - left : 20 px ;
line - height : 34 px ;
font - size : 14 px ;
color : # fff ;
@ -140,7 +233,7 @@ export default {
background - color : # FAAD14 ;
}
& . signing {
background - color : # 9076 FF ;
background - color : $main - color ;
}
& . signed {
background - color : # 52 C41A ;
@ -149,6 +242,14 @@ export default {
background - color : # ccc ;
}
}
. end - text {
font - size : 12 px ;
color : # 666 ;
em {
font - style : normal ;
color : # cb221c ;
}
}
. texts {
margin : 20 px 0 50 px ;
font - size : 16 px ;
@ -161,120 +262,157 @@ export default {
}
. progress {
position : relative ;
display : flex ;
justify - content : center ;
align - items : center ;
flex - direction : column ;
width : 95 % ;
padding : 50 px 0 ;
margin : 40 px 0 20 px ;
margin : 40 px auto 60 px ;
text - align : left ;
& : before {
content : '' ;
position : absolute ;
left : 413 px ;
width : 1 px ;
top : 0 ;
left : 50 % ;
width : 2 px ;
height : 100 % ;
background - color : # E6E6E6 ;
background - color : # E1E6F2 ;
@ media ( max - width : 1300 px ) {
left : 289 px ;
}
}
& : after {
content : '' ;
position : absolute ;
top : - 10 px ;
left : 430 px ;
border : 8 px solid transparent ;
border - bottom - color : # E1E6F2 ;
}
. rocket {
position : absolute ;
bottom : - 50 px ;
left : 425 px ;
}
li {
position : relative ;
display : inline - flex ;
align - items : center ;
width : 90 % ;
margin - bottom : 40 px ;
width : 400 px ;
margin - bottom : 42 px ;
. dot {
position : absolute ;
left : 366 px ;
width : 13 px ;
height : 13 px ;
background - color : # fff ;
& . not {
border - radius : 50 % ;
background - color : # fff ;
border : 1 px solid # cb221c ;
}
& . ing {
width : 13 px ;
height : 13 px ;
padding : 1 px ;
border : 1 px solid # cb221c ;
border - radius : 50 % ;
background - color : # cb221c ;
background - clip : content - box ;
}
& . done {
left : 365 px ;
color : # cb221c ;
font - size : 16 px ;
}
@ media ( max - width : 1300 px ) {
left : 254 px ;
& . done {
left : 253 px ;
}
}
top : 12 px ;
left : 431 px ;
width : 15 px ;
height : 15 px ;
background - color : # DCDCDC ;
border - radius : 50 % ;
}
. name {
width : 43 % ;
font - size : 24 px ;
color : rgba ( 0 , 0 , 0 , 0.85 ) ;
display : inline - block ;
padding : 0 19 px ;
margin - bottom : 16 px ;
line - height : 40 px ;
text - align : center ;
font - size : 16 px ;
color : # fff ;
border - radius : 20 px ;
background - color : # C4C4C4 ;
}
. desc {
position : relative ;
padding : 24 px 30 px ;
text - align : center ;
color : rgba ( 0 , 0 , 0 , 0.85 ) ;
font - size : 16 px ;
background - color : # fff ;
border : 1 px solid # E6E6E6 ;
border - radius : 8 px ;
& : before {
content : '' ;
z - index : 2 ;
position : absolute ;
top : 28 px ;
left : - 16 px ;
border : 8 px solid transparent ;
border - right - color : # fff ;
color : # 333 ;
font - size : 14 px ;
}
& . ing , & . done {
. dot {
top : 8 px ;
background - color : # 007 EFF ;
}
. name {
background - color : # 007 EFF ;
}
& : after {
content : '' ;
z - index : 1 ;
position : absolute ;
top : 27 px ;
left : - 18 px ;
border : 9 px solid transparent ;
border - right - color : # E6E6E6 ;
}
& . ing {
. dot {
width : 27 px ;
height : 27 px ;
border : 6 px solid # E2F1FB ;
}
}
& : nth - child ( even ) {
flex - direction : row - reverse ;
. name {
margin - left : 16 % ;
& : nth - child ( odd ) {
text - align : right ;
& . ing {
. dot {
left : auto ;
right : - 51 px ;
}
}
. name {
& : before {
content : '' ;
z - index : 2 ;
position : absolute ;
top : 14 px ;
right : - 35 px ;
border : 18 px solid transparent ;
border - top - width : 6 px ;
border - bottom - width : 6 px ;
border - left - color : # C4C4C4 ;
}
}
. desc {
text - align : right ;
}
& . ing , & . done {
. name {
& : before {
border - left - color : # 007 EFF ;
}
}
}
}
& : nth - child ( even ) {
margin - left : 482 px ;
. dot {
left : - 51 px ;
}
& . ing {
. dot {
left : - 57 px ;
}
}
. name {
text - align : left ;
& : after {
content : '' ;
z - index : 2 ;
position : absolute ;
top : 14 px ;
left : - 35 px ;
border : 18 px solid transparent ;
border - top - width : 6 px ;
border - bottom - width : 6 px ;
border - right - color : # C4C4C4 ;
}
}
. desc {
& : before {
. desc {
& : before {
left : auto ;
right : - 16 px ;
border : 8 px solid transparent ;
border - left - color : # fff ;
}
& : after {
& : after {
left : auto ;
right : - 18 px ;
border : 9 px solid transparent ;
border - left - color : # E6E6E6 ;
}
}
}
& : nth - child ( odd ) {
. name {
margin - right : 16 % ;
text - align : right ;
& . ing , & . done {
. name {
& : after {
border - right - color : # 007 EFF ;
}
}
}
}
& : last - child {