|
@@ -9,9 +9,11 @@
|
|
|
<img src="../../../../assets/icon/race/progress.png" alt="" />
|
|
|
</div>
|
|
|
<div class="stepRightNav" @click="jump('first')">
|
|
|
- <div>案例活动信息</div>
|
|
|
- <div>说明</div>
|
|
|
- <div class="isFinishCss" v-if="raceDetail.title != '' && raceDetail.type.length > 0">
|
|
|
+ <div>项目基本信息</div>
|
|
|
+ <div
|
|
|
+ class="isFinishCss"
|
|
|
+ v-if="raceDetail.title != '' && raceDetail.type.length > 0"
|
|
|
+ >
|
|
|
<div class="isFinish">
|
|
|
<img src="../../../../assets/icon/race/finish.png" alt="" />
|
|
|
</div>
|
|
@@ -24,8 +26,7 @@
|
|
|
<img src="../../../../assets/icon/race/progress.png" alt="" />
|
|
|
</div>
|
|
|
<div class="stepRightNav" @click="jump('second')">
|
|
|
- <div>封面</div>
|
|
|
- <div>说明</div>
|
|
|
+ <div>案例封面设置</div>
|
|
|
<div class="isFinishCss" v-if="raceDetail.cover.length > 0">
|
|
|
<div class="isFinish">
|
|
|
<img src="../../../../assets/icon/race/finish.png" alt="" />
|
|
@@ -39,8 +40,7 @@
|
|
|
<img src="../../../../assets/icon/race/progress.png" alt="" />
|
|
|
</div>
|
|
|
<div class="stepRightNav" @click="jump('third')">
|
|
|
- <div>成员信息</div>
|
|
|
- <div>协同人员</div>
|
|
|
+ <div>作者</div>
|
|
|
<div class="isFinishCss" v-if="raceDetail.tableData.length > 0">
|
|
|
<div class="isFinish">
|
|
|
<img src="../../../../assets/icon/race/finish.png" alt="" />
|
|
@@ -54,7 +54,6 @@
|
|
|
<img src="../../../../assets/icon/race/progress.png" alt="" />
|
|
|
</div>
|
|
|
<div class="stepRightNav" @click="jump('fouth')">
|
|
|
- <div>项目说明</div>
|
|
|
<div>项目简介</div>
|
|
|
<div class="isFinishCss" v-if="raceDetail.courseText != ''">
|
|
|
<div class="isFinish">
|
|
@@ -70,7 +69,6 @@
|
|
|
</div>
|
|
|
<div class="stepRightNav" @click="jump('fivth')">
|
|
|
<div>文件上传</div>
|
|
|
- <div>项目资料</div>
|
|
|
<div class="isFinishCss" v-if="raceDetail.data.length > 0">
|
|
|
<div class="isFinish">
|
|
|
<img src="../../../../assets/icon/race/finish.png" alt="" />
|
|
@@ -187,19 +185,19 @@
|
|
|
</div>
|
|
|
<div class="whiteBg" style="border-radius: 0">
|
|
|
<div class="right_first">
|
|
|
- <div class="right_title" id="third">作者</div>
|
|
|
+ <div class="right_title" id="third">联系人</div>
|
|
|
<div
|
|
|
class="addPeople"
|
|
|
- @click="dialogVisibleMember = true"
|
|
|
- v-if="raceDetail.tableData.length < 6"
|
|
|
+ @click="addAutor(0)"
|
|
|
+ v-if="raceDetail.autor.length == 0"
|
|
|
>
|
|
|
- 添加作者
|
|
|
+ 添加联系人
|
|
|
</div>
|
|
|
<div class="raTable">
|
|
|
<el-table
|
|
|
class="tableColor"
|
|
|
ref="table"
|
|
|
- :data="raceDetail.tableData"
|
|
|
+ :data="raceDetail.autor"
|
|
|
:height="tableHeight"
|
|
|
:fit="true"
|
|
|
style="width: 100%"
|
|
@@ -226,7 +224,7 @@
|
|
|
>
|
|
|
{{ scope.row.sn }}
|
|
|
</div>
|
|
|
- <div v-if="scope.$index == 0" class="lxr">联系人</div>
|
|
|
+ <div class="lxr">联系人</div>
|
|
|
</div>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
@@ -265,13 +263,118 @@
|
|
|
<div
|
|
|
class="delete"
|
|
|
style="margin-left: 0"
|
|
|
+ @click="updateStudent(scope.row, scope.$index, 0)"
|
|
|
+ >
|
|
|
+ <img src="../../../../assets/autorUp.png" alt />
|
|
|
+ </div>
|
|
|
+ <div
|
|
|
+ class="delete"
|
|
|
+ @click="deleteStudent(scope.$index, 0)"
|
|
|
+ >
|
|
|
+ <img src="../../../../assets/remove.png" alt />
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </div>
|
|
|
+ <div
|
|
|
+ style="
|
|
|
+ color: #cd0808;
|
|
|
+ width: 97%;
|
|
|
+ margin: 10px auto;
|
|
|
+ font-size: 14px;
|
|
|
+ "
|
|
|
+ >
|
|
|
+ *联系人所有信息都必填
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="whiteBg" style="border-radius: 0">
|
|
|
+ <div class="right_first">
|
|
|
+ <div class="right_title" id="third">协作者</div>
|
|
|
+ <div
|
|
|
+ class="addPeople"
|
|
|
+ @click="addAutor(1)"
|
|
|
+ v-if="raceDetail.tableData.length < 6"
|
|
|
+ >
|
|
|
+ 添加协作者
|
|
|
+ </div>
|
|
|
+ <div class="raTable">
|
|
|
+ <el-table
|
|
|
+ class="tableColor"
|
|
|
+ ref="table"
|
|
|
+ :data="raceDetail.tableData"
|
|
|
+ :height="tableHeight"
|
|
|
+ :fit="true"
|
|
|
+ style="width: 100%"
|
|
|
+ :header-cell-style="{
|
|
|
+ background: '#f1f1f1',
|
|
|
+ fontSize: '17px',
|
|
|
+ }"
|
|
|
+ >
|
|
|
+ <el-table-column label="姓名" min-width="20" align="center">
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <div class="userImg">
|
|
|
+ <div class="tx">
|
|
|
+ <img :src="tx" alt />
|
|
|
+ </div>
|
|
|
+ <div
|
|
|
+ style="
|
|
|
+ width: 50px;
|
|
|
+ text-align: left;
|
|
|
+ white-space: nowrap;
|
|
|
+ overflow: hidden;
|
|
|
+ text-overflow: ellipsis;
|
|
|
+ "
|
|
|
+ >
|
|
|
+ {{ scope.row.sn }}
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="学科" min-width="15" align="center">
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <div>{{ scope.row.su ? scope.row.su : "" }}</div>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="学校" min-width="15" align="center">
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <div>{{ scope.row.sc ? scope.row.sc : "" }}</div>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="邮箱" min-width="15" align="center">
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <div>{{ scope.row.em ? scope.row.em : "" }}</div>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="电话" min-width="15" align="center">
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <div>
|
|
|
+ {{ scope.row.ph ? scope.row.ph : "" }}
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="操作" min-width="20">
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <div class="pb_buttonBox">
|
|
|
+ <!-- <el-button
|
|
|
+ size="mini"
|
|
|
+ type="primary"
|
|
|
+ style="cursor: pointer"
|
|
|
@click="updateStudent(scope.row, scope.$index)"
|
|
|
+ >修改</el-button
|
|
|
+ > -->
|
|
|
+ <div
|
|
|
+ class="delete"
|
|
|
+ style="margin-left: 0"
|
|
|
+ @click="updateStudent(scope.row, scope.$index, 1)"
|
|
|
>
|
|
|
<img src="../../../../assets/autorUp.png" alt />
|
|
|
</div>
|
|
|
<div
|
|
|
class="delete"
|
|
|
- @click="deleteStudent(scope.$index)"
|
|
|
+ @click="deleteStudent(scope.$index, 1)"
|
|
|
>
|
|
|
<img src="../../../../assets/remove.png" alt />
|
|
|
</div>
|
|
@@ -288,7 +391,7 @@
|
|
|
font-size: 14px;
|
|
|
"
|
|
|
>
|
|
|
- *作者不超过6人;默认第一位为主要负责人,联系电话必填,其余人员可以选填
|
|
|
+ *协作者不超过6人;名字必填其余信息非必填
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
@@ -609,6 +712,7 @@ export default {
|
|
|
choosePicVisible: false,
|
|
|
sysPicVisible: false,
|
|
|
isSysPic: false,
|
|
|
+ isAutor: false,
|
|
|
sysPic: [],
|
|
|
upIndex: -1,
|
|
|
sName: "",
|
|
@@ -620,6 +724,7 @@ export default {
|
|
|
title: "",
|
|
|
type: [],
|
|
|
cover: [],
|
|
|
+ autor: [],
|
|
|
tableData: [],
|
|
|
courseText: "",
|
|
|
data: [],
|
|
@@ -678,6 +783,8 @@ export default {
|
|
|
this.$message.error("项目封面仅支持上传一张,请删除后再进行上传");
|
|
|
},
|
|
|
handleClose(done) {
|
|
|
+ this.isAddOrUp = false;
|
|
|
+ this.isAutor = false;
|
|
|
done();
|
|
|
},
|
|
|
jump(t) {
|
|
@@ -925,7 +1032,7 @@ export default {
|
|
|
this.$emit("updateTitle", this.raceDetail);
|
|
|
},
|
|
|
isAddPPTeacher() {
|
|
|
- if (this.raceDetail.tableData.length == 0) {
|
|
|
+ if (this.isAutor == true) {
|
|
|
if (this.sName === "") {
|
|
|
this.$message.error("姓名不能为空");
|
|
|
return;
|
|
@@ -954,93 +1061,86 @@ export default {
|
|
|
return;
|
|
|
}
|
|
|
}
|
|
|
- } else if (this.raceDetail.tableData.length > 0) {
|
|
|
- if (this.upIndex == 0) {
|
|
|
- if (this.sName === "") {
|
|
|
- this.$message.error("姓名不能为空");
|
|
|
- return;
|
|
|
- } else if (this.sSubject === "") {
|
|
|
- this.$message.error("学科不能为空");
|
|
|
- return;
|
|
|
- } else if (this.sSchool === "") {
|
|
|
- this.$message.error("学校不能为空");
|
|
|
- return;
|
|
|
- } else if (this.sPhone == "") {
|
|
|
- this.$message.error("手机号不能为空");
|
|
|
- return;
|
|
|
- } else if (!/^[1][3,4,5,7,8][0-9]{9}$/.test(this.sPhone)) {
|
|
|
+ } else {
|
|
|
+ if (this.sName === "") {
|
|
|
+ this.$message.error("姓名不能为空");
|
|
|
+ return;
|
|
|
+ } else if (this.sPhone != "") {
|
|
|
+ if (!/^[1][3,4,5,7,8][0-9]{9}$/.test(this.sPhone)) {
|
|
|
this.$message.error("手机号格式不正确");
|
|
|
return;
|
|
|
- } else if (this.sEmail == "") {
|
|
|
- this.$message.error("邮箱不能为空");
|
|
|
- return;
|
|
|
- } else if (this.sEmail != "") {
|
|
|
- if (
|
|
|
- !/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/.test(
|
|
|
- this.sEmail
|
|
|
- )
|
|
|
- ) {
|
|
|
- this.$message.error("邮箱格式不正确");
|
|
|
- return;
|
|
|
- }
|
|
|
}
|
|
|
- } else {
|
|
|
- if (this.sName === "") {
|
|
|
- this.$message.error("姓名不能为空");
|
|
|
+ } else if (this.sEmail != "") {
|
|
|
+ if (
|
|
|
+ !/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/.test(
|
|
|
+ this.sEmail
|
|
|
+ )
|
|
|
+ ) {
|
|
|
+ this.$message.error("邮箱格式不正确");
|
|
|
return;
|
|
|
- } else if (this.sPhone != "") {
|
|
|
- if (!/^[1][3,4,5,7,8][0-9]{9}$/.test(this.sPhone)) {
|
|
|
- this.$message.error("手机号格式不正确");
|
|
|
- return;
|
|
|
- }
|
|
|
- } else if (this.sEmail != "") {
|
|
|
- if (
|
|
|
- !/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/.test(
|
|
|
- this.sEmail
|
|
|
- )
|
|
|
- ) {
|
|
|
- this.$message.error("邮箱格式不正确");
|
|
|
- return;
|
|
|
- }
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
- if (this.isAddOrUp == true) {
|
|
|
- this.raceDetail.tableData[this.upIndex].sn = this.sName;
|
|
|
- this.raceDetail.tableData[this.upIndex].su = this.sSubject;
|
|
|
- this.raceDetail.tableData[this.upIndex].sc = this.sSchool;
|
|
|
- this.raceDetail.tableData[this.upIndex].em = this.sEmail;
|
|
|
- this.raceDetail.tableData[this.upIndex].ph = this.sPhone;
|
|
|
+
|
|
|
+ if (this.isAutor == true) {
|
|
|
+ if (this.isAddOrUp == true) {
|
|
|
+ this.raceDetail.autor[0].sn = this.sName;
|
|
|
+ this.raceDetail.autor[0].su = this.sSubject;
|
|
|
+ this.raceDetail.autor[0].sc = this.sSchool;
|
|
|
+ this.raceDetail.autor[0].em = this.sEmail;
|
|
|
+ this.raceDetail.autor[0].ph = this.sPhone;
|
|
|
+ } else {
|
|
|
+ this.raceDetail.autor.push({
|
|
|
+ sn: this.sName,
|
|
|
+ su: this.sSubject,
|
|
|
+ sc: this.sSchool,
|
|
|
+ em: this.sEmail,
|
|
|
+ ph: this.sPhone,
|
|
|
+ });
|
|
|
+ }
|
|
|
} else {
|
|
|
- this.raceDetail.tableData.push({
|
|
|
- sn: this.sName,
|
|
|
- su: this.sSubject,
|
|
|
- sc: this.sSchool,
|
|
|
- em: this.sEmail,
|
|
|
- ph: this.sPhone,
|
|
|
- });
|
|
|
+ if (this.isAddOrUp == true) {
|
|
|
+ this.raceDetail.tableData[this.upIndex].sn = this.sName;
|
|
|
+ this.raceDetail.tableData[this.upIndex].su = this.sSubject;
|
|
|
+ this.raceDetail.tableData[this.upIndex].sc = this.sSchool;
|
|
|
+ this.raceDetail.tableData[this.upIndex].em = this.sEmail;
|
|
|
+ this.raceDetail.tableData[this.upIndex].ph = this.sPhone;
|
|
|
+ } else {
|
|
|
+ this.raceDetail.tableData.push({
|
|
|
+ sn: this.sName,
|
|
|
+ su: this.sSubject,
|
|
|
+ sc: this.sSchool,
|
|
|
+ em: this.sEmail,
|
|
|
+ ph: this.sPhone,
|
|
|
+ });
|
|
|
+ }
|
|
|
}
|
|
|
+
|
|
|
this.sName = "";
|
|
|
this.sSubject = "";
|
|
|
this.sSchool = "";
|
|
|
this.sEmail = "";
|
|
|
this.sPhone = "";
|
|
|
this.isAddOrUp = false;
|
|
|
+ this.isAutor = false;
|
|
|
this.upIndex = -1;
|
|
|
this.dialogVisibleMember = false;
|
|
|
this.$emit("updateTitle", this.raceDetail);
|
|
|
},
|
|
|
- updateStudent(r, i) {
|
|
|
+ updateStudent(r, i, t) {
|
|
|
this.sName = r.sn;
|
|
|
this.sSubject = r.su;
|
|
|
this.sSchool = r.sc;
|
|
|
this.sEmail = r.em;
|
|
|
this.sPhone = r.ph;
|
|
|
this.isAddOrUp = true;
|
|
|
+ if (t == 0) {
|
|
|
+ this.isAutor = true;
|
|
|
+ }
|
|
|
this.upIndex = i;
|
|
|
this.dialogVisibleMember = true;
|
|
|
},
|
|
|
- deleteStudent(i) {
|
|
|
+ deleteStudent(i, t) {
|
|
|
this.$confirm("确定删除此作者吗?", "提示", {
|
|
|
confirmButtonText: "确定",
|
|
|
cancelButtonText: "取消",
|
|
@@ -1051,7 +1151,11 @@ export default {
|
|
|
message: "删除成功",
|
|
|
type: "success",
|
|
|
});
|
|
|
- this.raceDetail.tableData.splice(i, 1);
|
|
|
+ if (t == 0) {
|
|
|
+ this.raceDetail.autor = [];
|
|
|
+ } else {
|
|
|
+ this.raceDetail.tableData.splice(i, 1);
|
|
|
+ }
|
|
|
this.$emit("updateTitle", this.raceDetail);
|
|
|
})
|
|
|
.catch(() => {});
|
|
@@ -1097,12 +1201,19 @@ export default {
|
|
|
this.raceDetail.title = this.raceInfo.title;
|
|
|
this.raceDetail.type = this.raceInfo.type;
|
|
|
this.raceDetail.cover = this.raceInfo.cover;
|
|
|
+ this.raceDetail.autor = this.raceInfo.autor;
|
|
|
this.raceDetail.tableData = this.raceInfo.tableData;
|
|
|
this.raceDetail.courseText = this.raceInfo.courseText;
|
|
|
this.raceDetail.data = this.raceInfo.data;
|
|
|
this.imgChange1(null, null, 1, null);
|
|
|
this.$forceUpdate();
|
|
|
},
|
|
|
+ addAutor(t) {
|
|
|
+ if (t == 0) {
|
|
|
+ this.isAutor = true;
|
|
|
+ }
|
|
|
+ this.dialogVisibleMember = true;
|
|
|
+ },
|
|
|
},
|
|
|
created() {
|
|
|
this.getValue();
|
|
@@ -1211,7 +1322,7 @@ export default {
|
|
|
flex-wrap: nowrap;
|
|
|
justify-content: space-between;
|
|
|
align-items: flex-start;
|
|
|
- margin-left: 10px;
|
|
|
+ margin: 8px 0 0 10px;
|
|
|
height: 40px;
|
|
|
cursor: pointer;
|
|
|
}
|