You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
664 lines
24 KiB
664 lines
24 KiB
<template> |
|
<div style="padding: 0 100px;"> |
|
<el-card shadow="hover" class="m-b-20 head-card"> |
|
<div class="flex-between"> |
|
<el-page-header @back="$router.back()" content="参赛信息与成绩"></el-page-header> |
|
</div> |
|
</el-card> |
|
|
|
<el-card shadow="hover" class="m-b-20" v-loading="loading"> |
|
<div style="display: flex;align-items: center"> |
|
<table v-if="form.completeCompetitionSetup.competitionType" class="table m-b-20 m-r-10"> |
|
<tr> |
|
<th width="150">团队名称:</th> |
|
<td> |
|
<el-input :disabled="!editing" v-model="info.team.teamName"></el-input> |
|
</td> |
|
<th width="150">团队邀请码:</th> |
|
<td> |
|
<el-input :disabled="!editing" maxlength="6" v-model="info.team.invitationCode"></el-input> |
|
</td> |
|
</tr> |
|
</table> |
|
<div v-if="form.completeCompetitionSetup.competitionType && status < 4" class="m-b-20 text-center"> |
|
<el-button type="primary" @click="edit(1)">{{ editing ? '保存' : '编辑' }}</el-button> |
|
</div> |
|
</div> |
|
<table class="table"> |
|
<template v-if="form.completeCompetitionSetup.competitionType === 0"> |
|
<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.realSchool }}</td> |
|
</tr> |
|
</template> |
|
<template v-if="form.completeCompetitionSetup.competitionType"> |
|
<template> |
|
<tr> |
|
<th>队长:</th> |
|
<td>{{ info.caption.userName }}{{ info.caption.realSchool && ',' + info.caption.realSchool }}{{ |
|
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 width="130">指导老师:</th> |
|
<td> |
|
<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" :disabled="!item.edit"></el-input> |
|
<el-input placeholder="请输入职务" maxlength="10" v-model="item.position" clearable size="mini" |
|
:disabled="!item.edit"></el-input> |
|
<el-input placeholder="请输入手机号" maxlength="11" v-model="item.phone" clearable size="mini" |
|
:disabled="!item.edit"></el-input> |
|
<template> |
|
<i v-if="item.edit" class="el-icon-check icon" @click="submitAdvisor(item, i)"></i> |
|
<i v-else class="el-icon-edit icon" @click="editAdvisor(item)"></i> |
|
<i class="el-icon-delete icon" @click="delAdvisor(item, i)"></i> |
|
</template> |
|
</div> |
|
</td> |
|
</tr> |
|
<tr> |
|
<th>竞赛阶段:</th> |
|
<td> |
|
<table class="table tc"> |
|
<tr> |
|
<th width="80">序号</th> |
|
<th>赛项阶段名称</th> |
|
<template v-if="form.completeCompetitionSetup.competitionType"> |
|
<th width="110">参赛人数限制</th> |
|
<th> |
|
允许参赛人员 |
|
<el-tooltip v-if="stageTip" effect="dark" content="阶段参赛人员异常,请尽快按照阶段赛规则调整,否则可能影响比赛成绩!" |
|
placement="bottom"> |
|
<i class="info el-icon-warning" style="margin-right: 10px;color: #ff1650;"></i> |
|
</el-tooltip> |
|
</th> |
|
</template> |
|
<th v-if="form.rule === 0">总分</th> |
|
<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.customNumber || '不限制' }}</td> |
|
<td> |
|
<template v-if="item.participants"> |
|
<el-tag v-for="tag in item.participants" :key="tag.name" class="m-r-5" closable |
|
@close="removePar(tag, item)"> |
|
{{ tag.name }} |
|
</el-tag> |
|
</template> |
|
<span v-else class="m-r-5">无</span> |
|
<i class="el-icon-edit icon" @click="selectPar(item)"></i> |
|
<el-tooltip v-if="stageTip && stageTip[i + 1]" effect="dark" :content="stageTip[i + 1]" |
|
placement="bottom"> |
|
<el-tag type="danger" class="m-l-5">异常</el-tag> |
|
</el-tooltip> |
|
</td> |
|
</template> |
|
<td v-if="form.rule === 0 && !i" :rowspan="info.stages.length">{{ info.totalScore }}</td> |
|
<td> |
|
<span v-if="item.score >= 0" class="m-r-10">分数{{ item.score }}</span> |
|
<el-button |
|
v-if="form.completeCompetitionSetup.competitionType || (!form.completeCompetitionSetup.competitionType && item.reportId)" |
|
type="text" @click="show(item)">查看成绩详情</el-button> |
|
</td> |
|
</tr> |
|
</template> |
|
<tr v-else> |
|
<td colspan="6">暂无数据</td> |
|
</tr> |
|
</table> |
|
<el-alert v-if="form.completeCompetitionSetup.competitionType && form.rule !== 2" style="margin-top: 10px;" |
|
:title="'注:请团长(团队创建人)设置各阶段参赛成员,只有被选择的允许参赛成员可进入对应阶段比赛' + (info.teamLimit ? ',每个团队成员只能参加一个赛项阶段' : '') + '!'" |
|
type="warning" show-icon> |
|
</el-alert> |
|
</td> |
|
</tr> |
|
</table> |
|
|
|
<template v-if="form.completeCompetitionSetup.competitionType"> |
|
<div class="flex a-center m-t-20 m-b-20"> |
|
<div class="l-title" style="margin: 0 20px 0 0">团队成员</div> |
|
<el-tag v-for="(item, i) in teamErrors" :key="i" type="danger" style="margin-right: 5px">{{ item |
|
}}</el-tag> |
|
</div> |
|
<div class="flex-center"> |
|
<p>队长:{{ info.caption.userName }}</p> |
|
<el-button type="primary" @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"></el-table-column> |
|
<el-table-column prop="realSchool" label="学校" min-width="100" align="center"></el-table-column> |
|
<el-table-column prop="workNumber" label="学号" min-width="100" align="center"></el-table-column> |
|
<el-table-column prop="createTime" label="加入时间" width="180" align="center"></el-table-column> |
|
<el-table-column label="操作" align="center" width="160"> |
|
<template slot-scope="scope"> |
|
<el-button v-if="scope.row.captain" type="text" @click="removeLine(scope.row)">踢出团队</el-button> |
|
</template> |
|
</el-table-column> |
|
</el-table> |
|
</template> |
|
</el-card> |
|
|
|
<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">取消</el-button> |
|
</span> |
|
</el-dialog> |
|
<el-dialog title="选择参赛成员" :visible.sync="chooseVisible" :close-on-click-modal="false" width="400px"> |
|
<el-checkbox-group v-model="checkedMembers"> |
|
<el-checkbox v-for="(item, i) in chooses" :key="i" :label="item.accountId">{{ item.userName }}</el-checkbox> |
|
</el-checkbox-group> |
|
<p v-if="info.teamLimit && curRow.customNumber" style="margin-top: 15px;font-size: 12px;">注:当前阶段限制{{ |
|
curRow.customNumber }}人参赛,且此竞赛每个成员只能参加一个阶段赛项。</p> |
|
<span slot="footer" class="dialog-footer"> |
|
<el-button size="small" type="primary" @click="chooseSubmit">确定</el-button> |
|
<el-button size="small" @click="chooseVisible = false">取消</el-button> |
|
</span> |
|
</el-dialog> |
|
<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> |
|
<template v-if="members.length"> |
|
<tr v-for="(item, i) in members" :key="i"> |
|
<td>{{ i + 1 }}</td> |
|
<td>{{ item.userName }}</td> |
|
<td>{{ item.realSchool }}</td> |
|
<td>{{ item.timeSum }}min</td> |
|
<td>{{ item.score }}</td> |
|
<td> |
|
<el-button :disabled="!item.reportId" type="text" @click="toReport(item)">查看</el-button> |
|
</td> |
|
</tr> |
|
</template> |
|
<tr v-else> |
|
<td colspan="6">暂无数据</td> |
|
</tr> |
|
</table> |
|
<div class="pagination"> |
|
<el-pagination background layout="total, prev, pager, next" :total="total" @current-change="handleCurrentChange" |
|
:current-page="page" :page-size="pageSize"> |
|
</el-pagination> |
|
</div> |
|
|
|
<span slot="footer" class="dialog-footer"> |
|
<el-button size="small" type="primary" @click="memberVisible = false">确定</el-button> |
|
</span> |
|
</el-dialog> |
|
</div> |
|
</template> |
|
|
|
<script> |
|
import Util from "@/libs/util"; |
|
export default { |
|
data () { |
|
return { |
|
id: +this.$route.query.id, |
|
accountId: +this.$route.query.accountId, |
|
loading: false, |
|
status: 5, |
|
form: { |
|
competitionStage: [], |
|
completeCompetitionSetup: {}, |
|
competitionRegistration: {} |
|
}, |
|
info: { |
|
isCaption: 0, |
|
person: {}, |
|
caption: {}, |
|
team: { |
|
captain: 1, |
|
invitationCode: '' |
|
}, |
|
stages: [], |
|
teamDetail: [], |
|
teamInstructors: [] |
|
}, |
|
memberVisible: false, |
|
members: [], |
|
page: 1, |
|
pageSize: 10, |
|
total: 0, |
|
curRow: {}, |
|
teamVisible: false, |
|
teams: [], |
|
teamNameRepeat: false, |
|
teamForm: { |
|
accountId: +this.$route.query.accountId, |
|
identification: 1, |
|
competitionId: this.$route.query.id, |
|
registrationInvitationCode: '', |
|
teamName: '', |
|
invitationCode: '', |
|
whetherSignUp: 1 |
|
}, |
|
curStage: null, |
|
originInfo: {}, |
|
originIns: { |
|
id: '', |
|
position: '', |
|
name: '', |
|
phone: '', |
|
}, |
|
checkedPlayer: '', |
|
transferVisible: false, |
|
editing: false, |
|
memberVisible: false, |
|
members: [], |
|
curRow: {}, |
|
chooseVisible: false, |
|
checkedMember: '', |
|
checkedMembers: [], |
|
chooses: [], |
|
timer: null, |
|
teamErrors: [], |
|
stageTip: null, |
|
}; |
|
}, |
|
mounted () { |
|
this.$once('hook:beforeDestroy', function () { |
|
clearInterval(this.timer) |
|
}) |
|
this.getData() |
|
}, |
|
methods: { |
|
getData () { |
|
this.loading = true |
|
this.$post(`${this.api.getCompetition}?competitionId=${this.id}`).then(({ competition }) => { |
|
this.form = competition |
|
this.timer = setInterval(this.handleStatus, 1000) |
|
this.getInfo() |
|
}).catch(err => { }) |
|
}, |
|
// 获取竞赛信息 |
|
getInfo () { |
|
this.$post(`${this.api.entryInformation}?competitionId=${this.id}&accountId=${this.accountId}`).then(res => { |
|
const info = res.entryInformation |
|
// 如果是队长,并且没有指导老师,默认添加一个空的 |
|
if (!info.teamInstructors.length) info.teamInstructors.push(JSON.parse(JSON.stringify(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.originInfo = JSON.parse(JSON.stringify(info)) |
|
// 把参赛人员的名字和accountId处理成一个数组 |
|
info.stages && info.stages.map(e => { |
|
if (e.participantAccountIds && e.teamParticipantIds) { |
|
const accountIds = e.participantAccountIds.split(',').map(n => +n) |
|
const names = e.teamParticipantIds.split(',') |
|
const participants = [] |
|
accountIds.map((n, i) => { |
|
participants.push({ |
|
id: n, |
|
name: names[i] |
|
}) |
|
}) |
|
e.participants = participants |
|
} |
|
}) |
|
this.info = info |
|
this.form.completeCompetitionSetup.competitionType && this.getErrorInfo() |
|
this.loading = false |
|
}).catch(err => { }); |
|
}, |
|
// 获取团队异常信息 |
|
async getErrorInfo () { |
|
const res = await this.$get(this.api.checkTeamStatus, { |
|
competitionId: this.id, |
|
teamId: this.info.teamId |
|
}) |
|
this.teamErrors = res.teamTip.split(';').filter(e => e) |
|
if (Object.keys(res.stageTip).length) { |
|
this.stageTip = res.stageTip |
|
} |
|
}, |
|
// 报名时间、比赛时间、状态处理 |
|
handleStatus () { |
|
let status |
|
const n = this.form |
|
let now = new Date().getTime(); |
|
let signUpStartTime = new Date(Util.dateCompatible(n.signUpStartTime)).getTime(); // 报名开始时间 |
|
let signUpEndTime = new Date(Util.dateCompatible(n.signUpEndTime)).getTime(); // 报名结束时间 |
|
let playStartTime = new Date(Util.dateCompatible(n.playStartTime)).getTime(); // 比赛开始时间 |
|
let playEndTime = new Date(Util.dateCompatible(n.playEndTime)).getTime(); // 比赛结束时间 |
|
if (now < signUpStartTime) { // 报名没开始 |
|
status = 0; |
|
} else if (now > signUpStartTime && now < signUpEndTime) { // 报名进行中 |
|
status = n.competitionRegistration ? 1 : 2 // 1已报名,2立即报名 |
|
} else if (now > signUpEndTime && now < playStartTime) { // 报名结束了,但比赛没开始 |
|
status = 3; |
|
} else if (now > playStartTime && now < playEndTime) { // 比赛进行中 |
|
status = 4 |
|
} else if (now > playEndTime) { // 比赛结束 |
|
status = 5; |
|
} |
|
this.status = status |
|
}, |
|
// 编辑保存 |
|
edit (showMsg) { |
|
if (this.editing || !showMsg) { |
|
const { teamId, teamName, invitationCode } = this.info.team |
|
if (invitationCode.length !== 6) return Util.errorMsg('请输入6位数团队邀请码') |
|
this.$post(this.api.editCompetitionTeam, { |
|
accountId: this.accountId, |
|
identification: 1, |
|
competitionId: this.id, |
|
teamId, |
|
teamName, |
|
invitationCode, |
|
whetherSignUp: 0 |
|
}).then(res => { |
|
this.editing = false |
|
this.getInfo() |
|
showMsg && Util.successMsg('保存成功') |
|
}).catch(res => { }) |
|
} else { |
|
this.editing = !this.editing |
|
} |
|
}, |
|
// 删除指导老师 |
|
delAdvisor (row, i) { |
|
if (row.id) { |
|
this.$confirm('确定要删除吗?', '提示', { |
|
type: 'warning' |
|
}).then(() => { |
|
this.$post(`${this.api.deleteAnAdvisor}?id=${row.id}`).then(res => { |
|
Util.successMsg('删除成功') |
|
this.info.teamInstructors.splice(i, 1) |
|
}).catch(res => { }) |
|
}).catch(() => { }) |
|
} else { |
|
this.info.teamInstructors.splice(i, 1) |
|
} |
|
}, |
|
// 添加指导老师 |
|
addAdvisor () { |
|
if (this.info.teamInstructors.length > 4) return Util.errorMsg('指导老师仅限添加5个!') |
|
const line = JSON.parse(JSON.stringify(this.originIns)) |
|
line.edit = 1 |
|
this.info.teamInstructors.push(line) |
|
}, |
|
// 编辑导老师 |
|
editAdvisor (row) { |
|
this.$set(row, 'edit', 1) |
|
}, |
|
// 提交指导老师 |
|
submitAdvisor (row, i) { |
|
if (!row.name) return Util.errorMsg('请输入姓名') |
|
const { phone } = row |
|
if (phone && !/^1[3456789]\d{9}$/.test(phone)) return Util.errorMsg('请输入正确手机号格式') |
|
this.$post(this.api.addAnAdvisor, { |
|
name: row.name, |
|
competitionId: this.id, |
|
id: row.id, |
|
teamId: this.info.teamId, |
|
phone: row.phone, |
|
position: row.position, |
|
accountId: this.accountId |
|
}).then(({ id }) => { |
|
Util.successMsg((row.id ? '修改' : '新增') + '成功') |
|
if (!row.id) { |
|
this.info.teamInstructors[i].id = id |
|
} |
|
this.info.teamInstructors[i].edit = 0 |
|
}).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 => { |
|
this.checkedPlayer = '' |
|
Util.successMsg('转让成功') |
|
this.transferVisible = false |
|
this.getInfo() |
|
}).catch(res => { }) |
|
}, |
|
// 踢出团队 |
|
removeLine (row) { |
|
// 取每个阶段的开始结束时间,有任何阶段开始了都不能转让队长和踢出队员 |
|
const now = new Date() |
|
let start = 0 |
|
// for (const e of this.form.competitionStage) { |
|
// if (now >= new Date(e.startTime) && now <= new Date(e.endTime)) { |
|
// Util.errorMsg('比赛已经开始,无法踢出成员!') |
|
// start = 1 |
|
// break |
|
// } |
|
// } |
|
if (!start) { |
|
let include |
|
for (const e of this.info.stages) { |
|
if (e.participantAccountIds) { |
|
const ids = e.participantAccountIds.split(',').map(n => +n) |
|
if (ids.includes(row.accountId)) { |
|
include = e.stageName |
|
break |
|
} |
|
} |
|
} |
|
this.$confirm(include ? `该成员已被指定参加${include},踢出后需重新指定成员参加,是否确认踢出团队?` : '确定要踢出该成员吗?', '提示', { |
|
type: 'warning', |
|
closeOnClickModal: false |
|
}).then(() => { |
|
this.$post(`${this.api.removeTheLine}?teamId=${this.info.teamId}&competitionId=${this.id}&accountId=${row.accountId}`).then(res => { |
|
Util.successMsg('移除成功') |
|
this.getInfo() |
|
}).catch(res => { }) |
|
}).catch(() => { }) |
|
} |
|
}, |
|
// 移除参赛人员 |
|
removePar (e, stage) { |
|
this.$confirm('确定要移除该成员吗?', '提示', { |
|
type: 'warning' |
|
}).then(() => { |
|
this.$post(this.api.cancelParticipant, { |
|
accountId: e.id, |
|
competitionId: this.id, |
|
stageId: stage.stageId, |
|
teamId: this.info.teamId |
|
}).then(res => { |
|
Util.successMsg('移除成功') |
|
this.getInfo() |
|
}).catch(res => { }) |
|
}).catch(() => { }) |
|
}, |
|
// 选择参赛人员 |
|
selectPar (row) { |
|
const item = this.form.competitionStage.find(e => e.stageId == row.stageId) |
|
if (item) { |
|
const { teamLimit, stages, teamDetail } = this.info |
|
// teamLimit=true,则每个成员只能参加一个阶段的比赛,要获取stages里返回的所有participantAccountIds(参赛人员的accountId),然后不显示这些参赛人员 |
|
if (teamLimit) { |
|
const chooses = [] |
|
let ids = [] |
|
// 获取已经允许参赛的人员accountId |
|
stages.map(e => { |
|
const id = e.participantAccountIds |
|
if (e.stageId != row.stageId && id) ids.push(...id.split(',').map(n => +n)) |
|
}) |
|
ids = [...new Set(ids)] |
|
teamDetail.map(e => { |
|
ids.includes(e.accountId) || chooses.push(e) // 没有参赛的人员则显示出来 |
|
}) |
|
this.chooses = chooses |
|
} else { |
|
this.chooses = this.info.teamDetail |
|
} |
|
this.curRow = row |
|
this.checkedMembers = row.participants ? row.participants.map(e => e.id) : [] |
|
this.chooseVisible = true |
|
} |
|
}, |
|
// 选择参赛人员提交 |
|
chooseSubmit () { |
|
const accountIds = this.checkedMembers |
|
if (!accountIds.length) return Util.errorMsg('请选择参赛成员!') |
|
const { customNumber, teamNumLimit } = this.curRow // 参赛人数限制 |
|
if (teamNumLimit && accountIds.length > customNumber) return Util.errorMsg(`请选择${this.curRow.customNumber}个以下参赛成员!`) // 选择的参赛人员个数不能大于参赛人数限制 |
|
this.$post(this.api.stageSelectParticipants, { |
|
accountIds, |
|
competitionId: this.id, |
|
stageId: this.curRow.stageId, |
|
teamId: this.info.teamId |
|
}).then(res => { |
|
this.checkedMembers = [] |
|
Util.successMsg('修改成功') |
|
this.getInfo() |
|
this.chooseVisible = false |
|
}).catch(res => { }) |
|
}, |
|
async getMembers () { |
|
try { |
|
const { page } = await this.$post(this.api.stageTeamScoreDetails, { |
|
pageNum: this.page, |
|
pageSize: this.pageSize, |
|
competitionId: this.id, |
|
stageId: this.curRow.stageId, |
|
teamId: this.info.teamId |
|
}) |
|
this.members = page.records |
|
this.total = page.total |
|
} catch (e) { } |
|
}, |
|
// 查看成绩详情 |
|
show (row) { |
|
this.curRow = row |
|
// 团队展示弹框,个人跳转实验报告 |
|
if (this.form.completeCompetitionSetup.competitionType) { // 团队比赛并且是队长,则展示团队成员成绩详情 |
|
this.memberVisible = true |
|
if (this.info.teamId) { |
|
this.getMembers() |
|
} else { |
|
this.members = [] |
|
} |
|
} else if (row.reportId) { // 团员或者个人比赛,并且有reportId,则进入实验报告 |
|
this.toReport(row) |
|
} |
|
}, |
|
handleCurrentChange (val) { |
|
this.page = val; |
|
this.getMembers() |
|
}, |
|
// 跳转实验报告 |
|
toReport (row) { |
|
this.$router.push(`${this.curRow.method === 1 ? 'theoryReport' : 'trialReport'}?reportId=${row.reportId}`) |
|
}, |
|
} |
|
}; |
|
</script> |
|
|
|
<style lang="scss" scoped> |
|
.m-r-5 { |
|
margin-right: 5px; |
|
} |
|
|
|
.l-title { |
|
margin-top: 20px; |
|
font-size: 18px; |
|
} |
|
|
|
.table { |
|
width: 100%; |
|
border-collapse: collapse; |
|
|
|
th, |
|
td { |
|
padding: 12px; |
|
border: 1px solid #ebeef5; |
|
} |
|
|
|
&.tc { |
|
text-align: center; |
|
} |
|
|
|
th { |
|
text-align: center; |
|
background-color: #f8faff; |
|
} |
|
|
|
.icon { |
|
margin-right: 10px; |
|
font-size: 16px; |
|
color: #7a7a7a; |
|
cursor: pointer; |
|
|
|
&:hover { |
|
color: $main-color; |
|
} |
|
} |
|
|
|
.plus { |
|
margin-bottom: 10px; |
|
text-align: right; |
|
} |
|
|
|
.line { |
|
display: flex; |
|
align-items: center; |
|
margin-bottom: 10px; |
|
|
|
.el-input { |
|
margin-right: 15px; |
|
} |
|
} |
|
} |
|
|
|
.flex-center { |
|
display: flex; |
|
justify-content: space-between; |
|
align-items: center; |
|
margin-bottom: 15px; |
|
} |
|
|
|
.text-center { |
|
text-align: center; |
|
} |
|
</style> |