|
@@ -19,7 +19,7 @@
|
|
></div>
|
|
></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
- <div class="wordBtn">
|
|
|
|
|
|
+ <div class="wordBtn" @click="judgeExport">
|
|
导出Excel
|
|
导出Excel
|
|
</div>
|
|
</div>
|
|
<div class="twoType">
|
|
<div class="twoType">
|
|
@@ -35,7 +35,12 @@
|
|
</div>
|
|
</div>
|
|
<div class="selectSty">
|
|
<div class="selectSty">
|
|
<div style="margin-right: 10px;">时间筛选</div>
|
|
<div style="margin-right: 10px;">时间筛选</div>
|
|
- <el-select v-model="termValue" placeholder="请选择">
|
|
|
|
|
|
+ <el-select v-model="termId" placeholder="请选择">
|
|
|
|
+ <el-option
|
|
|
|
+ label="全部"
|
|
|
|
+ @click.native="changeTerm('')"
|
|
|
|
+ value=""
|
|
|
|
+ ></el-option>
|
|
<el-option
|
|
<el-option
|
|
v-for="item in termList"
|
|
v-for="item in termList"
|
|
:key="item.id"
|
|
:key="item.id"
|
|
@@ -118,7 +123,13 @@
|
|
>
|
|
>
|
|
查看
|
|
查看
|
|
</div>
|
|
</div>
|
|
- <div class="TableBtn" style="color: #3681FC;">修改</div>
|
|
|
|
|
|
+ <div
|
|
|
|
+ class="TableBtn"
|
|
|
|
+ style="color: #3681FC;"
|
|
|
|
+ @click="updateCred(scope.row)"
|
|
|
|
+ >
|
|
|
|
+ 修改
|
|
|
|
+ </div>
|
|
<div
|
|
<div
|
|
class="TableBtn"
|
|
class="TableBtn"
|
|
style="color: #EE3E3E;"
|
|
style="color: #EE3E3E;"
|
|
@@ -146,10 +157,12 @@
|
|
ref="refPop"
|
|
ref="refPop"
|
|
v-if="isPop"
|
|
v-if="isPop"
|
|
:judgeNum="judgeNum"
|
|
:judgeNum="judgeNum"
|
|
- :recordData="recordData"
|
|
|
|
|
|
+ :recordDataCopy="recordData"
|
|
:termList="termList"
|
|
:termList="termList"
|
|
:weiList="weiList"
|
|
:weiList="weiList"
|
|
:studentList="studentList"
|
|
:studentList="studentList"
|
|
|
|
+ @selectData="selectData"
|
|
|
|
+ @closePop="closePop"
|
|
></popbox>
|
|
></popbox>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
</template>
|
|
@@ -187,18 +200,20 @@ export default {
|
|
// 组件信息数据
|
|
// 组件信息数据
|
|
isPop: false,
|
|
isPop: false,
|
|
recordData: {},
|
|
recordData: {},
|
|
- recordDataCopy:{},
|
|
|
|
|
|
+ recordDataCopy: {},
|
|
weiList: [],
|
|
weiList: [],
|
|
studentList: [],
|
|
studentList: [],
|
|
- judgeNum:0
|
|
|
|
|
|
+ judgeNum: 0
|
|
};
|
|
};
|
|
},
|
|
},
|
|
methods: {
|
|
methods: {
|
|
closePop() {
|
|
closePop() {
|
|
this.isPop = false;
|
|
this.isPop = false;
|
|
- this.$refs.refPop.fuClick();
|
|
|
|
|
|
+ // console.log('关了');
|
|
|
|
+ // this.$refs.refPop.fuClick(this.recordData);
|
|
},
|
|
},
|
|
|
|
|
|
|
|
+ // 切换页
|
|
handleCurrentChange(val) {
|
|
handleCurrentChange(val) {
|
|
//当页数发生改变的时候调用获取列表数据请求
|
|
//当页数发生改变的时候调用获取列表数据请求
|
|
// console.log(`当前页: ${val}`);
|
|
// console.log(`当前页: ${val}`);
|
|
@@ -218,46 +233,53 @@ export default {
|
|
.get(this.$store.state.api + "selectSETable", params)
|
|
.get(this.$store.state.api + "selectSETable", params)
|
|
.then(res => {
|
|
.then(res => {
|
|
this.isLoading = false;
|
|
this.isLoading = false;
|
|
- // console.log("获取筛选框数据", res);
|
|
|
|
- // let data = res.data;
|
|
|
|
- let ftype = res.data[1];
|
|
|
|
- ftype.unshift({
|
|
|
|
- id: "df8f3f1c-b34b-11ee-b534-005056b86db5",
|
|
|
|
- name: "艺术",
|
|
|
|
- create_at: "2024-01-15"
|
|
|
|
- });
|
|
|
|
- let stype = res.data[2];
|
|
|
|
|
|
+ var ftype = res.data[1]; //公共父级分类
|
|
|
|
+ var stype = res.data[2]; //公共子级分类
|
|
|
|
+ var sctype = res.data[3]; //该学校子级分类
|
|
|
|
+ var fctype = res.data[4]; //该学校父级分类
|
|
|
|
+ var fotype = res.data[5]; //组织父级分类
|
|
|
|
+ var sotype = res.data[6]; //组织子级分类
|
|
|
|
+ var allfType = [];
|
|
|
|
+ var allsType = [];
|
|
|
|
+ if (fotype.length == 0 && sotype.length == 0) {
|
|
|
|
+ if (fctype.length == 0 && sctype.length == 0) {
|
|
|
|
+ for (var i = 0; i < ftype.length; i++) {
|
|
|
|
+ allfType.push(ftype[i]);
|
|
|
|
+ }
|
|
|
|
+ for (var i = 0; i < stype.length; i++) {
|
|
|
|
+ allsType.push(stype[[i]]);
|
|
|
|
+ }
|
|
|
|
+ } else {
|
|
|
|
+ for (var i = 0; i < fctype.length; i++) {
|
|
|
|
+ allfType.push(fctype[i]);
|
|
|
|
+ }
|
|
|
|
+ for (var i = 0; i < sctype.length; i++) {
|
|
|
|
+ allsType.push(sctype[[i]]);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ } else {
|
|
|
|
+ for (var i = 0; i < fotype.length; i++) {
|
|
|
|
+ allfType.push(fotype[i]);
|
|
|
|
+ }
|
|
|
|
+ for (var i = 0; i < sotype.length; i++) {
|
|
|
|
+ allsType.push(sctysotypepe[[i]]);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
|
|
- ftype.forEach((e, index) => {
|
|
|
|
- ftype[index][e.id] = [];
|
|
|
|
|
|
+ allfType.forEach((e, index) => {
|
|
|
|
+ allfType[index][e.id] = [];
|
|
});
|
|
});
|
|
|
|
|
|
// 大数组套小数组循环,进行push操作,最后手动添加艺术
|
|
// 大数组套小数组循环,进行push操作,最后手动添加艺术
|
|
- ftype.forEach((e, w) => {
|
|
|
|
- stype.forEach((k, index) => {
|
|
|
|
|
|
+ allfType.forEach((e, w) => {
|
|
|
|
+ allsType.forEach((k, index) => {
|
|
if (e.id == k.pid) {
|
|
if (e.id == k.pid) {
|
|
// console.log("e.id", ftype[w][e.id]);
|
|
// console.log("e.id", ftype[w][e.id]);
|
|
- ftype[w][e.id].push(k);
|
|
|
|
|
|
+ allfType[w][e.id].push(k);
|
|
}
|
|
}
|
|
});
|
|
});
|
|
- if (e.id == "df8f3f1c-b34b-11ee-b534-005056b86db5") {
|
|
|
|
- ftype[w][e.id].push(
|
|
|
|
- {
|
|
|
|
- id: "be640459-b34d-11ee-b534-005056b86db5",
|
|
|
|
- name: "感受与欣赏",
|
|
|
|
- pid: "df8f3f1c-b34b-11ee-b534-005056b86db5",
|
|
|
|
- create_at: "2024-01-15"
|
|
|
|
- },
|
|
|
|
- {
|
|
|
|
- id: "c862767f-b34d-11ee-b534-005056b86db5",
|
|
|
|
- name: "艺术与创造",
|
|
|
|
- pid: "df8f3f1c-b34b-11ee-b534-005056b86db5",
|
|
|
|
- create_at: "2024-01-15"
|
|
|
|
- }
|
|
|
|
- );
|
|
|
|
- }
|
|
|
|
});
|
|
});
|
|
- this.VeidooList = ftype.reverse();
|
|
|
|
|
|
+ this.VeidooList = allfType;
|
|
|
|
|
|
// 渲染完数据后立即查询一次默认筛选项
|
|
// 渲染完数据后立即查询一次默认筛选项
|
|
this.changeType(this.VeidooList[0]);
|
|
this.changeType(this.VeidooList[0]);
|
|
@@ -272,7 +294,7 @@ export default {
|
|
this.termList.forEach(e => {
|
|
this.termList.forEach(e => {
|
|
if (e.defaultC == 1) {
|
|
if (e.defaultC == 1) {
|
|
this.termId = e.id;
|
|
this.termId = e.id;
|
|
- this.termValue = e.name;
|
|
|
|
|
|
+ // this.termValue = e.name;
|
|
}
|
|
}
|
|
});
|
|
});
|
|
|
|
|
|
@@ -304,31 +326,17 @@ export default {
|
|
// 获取班学生列表
|
|
// 获取班学生列表
|
|
const data2 = {
|
|
const data2 = {
|
|
cid: this.$route.query.cid,
|
|
cid: this.$route.query.cid,
|
|
- // uid: this.$route.query.suid
|
|
|
|
|
|
+ uid: this.$route.query.suid
|
|
};
|
|
};
|
|
this.ajax
|
|
this.ajax
|
|
- .get(this.$store.state.api + "selectClassStudent", data2)
|
|
|
|
|
|
+ .get(this.$store.state.api + "selectManyClassStudent", data2)
|
|
.then(res => {
|
|
.then(res => {
|
|
// console.log(res);
|
|
// console.log(res);
|
|
this.studentList = res.data[0];
|
|
this.studentList = res.data[0];
|
|
console.log("this.studentList", res);
|
|
console.log("this.studentList", res);
|
|
});
|
|
});
|
|
- // (data2).then(res => {
|
|
|
|
- // // res[0].forEach(e => {
|
|
|
|
- // // if (e.id === this.$route.query.uid) {
|
|
|
|
- // // this.stuName = e
|
|
|
|
- // // } else {
|
|
|
|
- // // this.studentList.push(e)
|
|
|
|
- // // }
|
|
|
|
- // // })
|
|
|
|
-
|
|
|
|
- // console.log("this.studentList", this.studentList);
|
|
|
|
- // });
|
|
|
|
-
|
|
|
|
- // selectVeiDoo(data).then(res => {
|
|
|
|
- // this.weiList = res[0];
|
|
|
|
- // });
|
|
|
|
},
|
|
},
|
|
|
|
+ // 选择导出哪些记录
|
|
handleSelectionChange(val) {
|
|
handleSelectionChange(val) {
|
|
this.multipleSelection = val;
|
|
this.multipleSelection = val;
|
|
console.log(this.multipleSelection);
|
|
console.log(this.multipleSelection);
|
|
@@ -345,6 +353,7 @@ export default {
|
|
},
|
|
},
|
|
// 点击小选项
|
|
// 点击小选项
|
|
changeTypeChild(e) {
|
|
changeTypeChild(e) {
|
|
|
|
+ // 重复点击取消选择
|
|
if (this.VeidooChild == e.id) {
|
|
if (this.VeidooChild == e.id) {
|
|
this.VeidooChild = "";
|
|
this.VeidooChild = "";
|
|
} else {
|
|
} else {
|
|
@@ -379,34 +388,149 @@ export default {
|
|
console.log(" 获取筛选数据", res);
|
|
console.log(" 获取筛选数据", res);
|
|
});
|
|
});
|
|
},
|
|
},
|
|
|
|
+ // 修改记录
|
|
|
|
+ updateCred(e) {
|
|
|
|
+ this.judgeNum = 1;
|
|
|
|
+ this.isPop = true;
|
|
|
|
+ if (!Array.isArray(e.type)) {
|
|
|
|
+ if (!e.type) {
|
|
|
|
+ e.type = [];
|
|
|
|
+ } else {
|
|
|
|
+ e.type = e.type.split(",");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ if (!Array.isArray(e.contact)) {
|
|
|
|
+ if (!e.contact) {
|
|
|
|
+ e.contact = [];
|
|
|
|
+ } else {
|
|
|
|
+ e.contact = e.contact.split(",");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ if (!Array.isArray(e.recordImg)) {
|
|
|
|
+ if (!e.recordImg) {
|
|
|
|
+ e.recordImg = [];
|
|
|
|
+ } else {
|
|
|
|
+ e.recordImg = e.recordImg.split(",");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ this.recordData = e;
|
|
|
|
+ },
|
|
|
|
+ // 判断导出数据
|
|
|
|
+ judgeExport() {
|
|
|
|
+ if (this.multipleSelection.length) {
|
|
|
|
+ this.exportExcel();
|
|
|
|
+ } else {
|
|
|
|
+ console.log(2);
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ // exportExcelTwo() {
|
|
|
|
+ // let data = {
|
|
|
|
+ // uid: this.$route.query.suid,
|
|
|
|
+ // cid: this.$route.query.cid,
|
|
|
|
+ // cu: this.Veidoo,
|
|
|
|
+ // cn: this.VeidooChild,
|
|
|
|
+ // cm: this.termId,
|
|
|
|
+ // page: this.page,
|
|
|
|
+ // lim: 8
|
|
|
|
+ // };
|
|
|
|
+ // // return console.log("selectData", data);
|
|
|
|
+ // this.ajax
|
|
|
|
+ // .get(this.$store.state.api + "selectVeidooType", data)
|
|
|
|
+ // .then(res => {
|
|
|
|
+ // this.isLoading = false;
|
|
|
|
+ // this.tableData = res.data[0];
|
|
|
|
+ // this.total = res.data[0].length > 0 ? res.data[0][0].num : 0;
|
|
|
|
+ // console.log(" 获取筛选数据", res);
|
|
|
|
+ // });
|
|
|
|
+ // },
|
|
|
|
+ exportExcel() {
|
|
|
|
+ // var res = res.data[0];
|
|
|
|
+ var res = this.multipleSelection;
|
|
|
|
+
|
|
|
|
+ //如果value的json字段的key值和想要的headers值不一致时,可做如下更改
|
|
|
|
+ //将和下面的Object.fromEntries结合,将json字段的key值改变为要求的excel的header值
|
|
|
|
+ var array = [];
|
|
|
|
+ for (var i = 0; i < res.length; i++) {
|
|
|
|
+ var _json = {};
|
|
|
|
+ _json["创建时间"] = res[i].create_at;
|
|
|
|
+ _json["班级"] = res[i].className;
|
|
|
|
+ _json["记录时间"] = res[i].recordDate;
|
|
|
|
+ // _json["用户名"] = res[i].studentName;
|
|
|
|
+ // _json["用户名"] = res[i].studentName;
|
|
|
|
+ _json["观察地点"] = res[i].place;
|
|
|
|
+ _json["观察内容"] = res[i].recordTit;
|
|
|
|
+ _json["内容"] = res[i].recordContent;
|
|
|
|
+
|
|
|
|
+ array.push(_json);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ var XLSX = require("xlsx");
|
|
|
|
+ const workbook = XLSX.utils.book_new(); //创建一个新的工作簿对象
|
|
|
|
+ let ws = XLSX.utils.json_to_sheet(array); //将json对象数组转化成工作表
|
|
|
|
+ // ws["!cols"] = [
|
|
|
|
+ // //设置每一列的宽度
|
|
|
|
+ // { wch: 50 },
|
|
|
|
+ // { wch: 50 },
|
|
|
|
+ // { wch: 50 }
|
|
|
|
+ // ];
|
|
|
|
+ XLSX.utils.book_append_sheet(workbook, ws, "sheet1"); //把sheet添加到workbook里,第三个参数是sheet名
|
|
|
|
+ XLSX.writeFile(workbook, "观察日记.xlsx");
|
|
|
|
+ // const wopts = { bookType: "xlsx", bookSST: false, type: "array" };//写入的样式bookType:输出的文件类型,type:输出的数据类型,bookSST: 是否生成Shared String Table,官方解释是,如果开启生成速度会下降,但在低版本IOS设备上有更好的兼容性
|
|
|
|
+ // const wbout = XLSX.write(workbook, wopts);// 浏览器端和node共有的API,实际上node可以直接使用xlsx.writeFile来写入文件,但是浏览器没有该API
|
|
|
|
+ // FileSaver.saveAs(new Blob([wbout], { type: "application/octet-stream" }), `${title} demo.xlsx`);//保存文件
|
|
|
|
+ this.$message({
|
|
|
|
+ message: "导出成功",
|
|
|
|
+ type: "success"
|
|
|
|
+ });
|
|
|
|
+ },
|
|
|
|
+ // 删除记录
|
|
delRecord(e) {
|
|
delRecord(e) {
|
|
- return console.log(e);
|
|
|
|
- this.ajax
|
|
|
|
- .get(this.$store.state.api + "selectSETable", { rid: e.rid })
|
|
|
|
- .then(res => {
|
|
|
|
- this.isLoading = false;
|
|
|
|
|
|
+ this.$confirm("是否删除?", "提示", {
|
|
|
|
+ confirmButtonText: "确定",
|
|
|
|
+ cancelButtonText: "取消"
|
|
|
|
+ })
|
|
|
|
+ .then(() => {
|
|
|
|
+ this.ajax
|
|
|
|
+ .post(this.$store.state.api + "updateRecord", [{ rid: e.rid }])
|
|
|
|
+ .then(res => {
|
|
|
|
+ console.log(res);
|
|
|
|
+ this.selectData();
|
|
|
|
+
|
|
|
|
+ this.$message({
|
|
|
|
+ type: "success",
|
|
|
|
+ message: "已删除"
|
|
|
|
+ });
|
|
|
|
+ // this.isLoading = false; updateRecord
|
|
|
|
+ });
|
|
|
|
+ })
|
|
|
|
+ .catch(() => {
|
|
|
|
+ this.$message({
|
|
|
|
+ type: "info",
|
|
|
|
+ message: "已取消删除"
|
|
|
|
+ });
|
|
});
|
|
});
|
|
|
|
+ // return console.log(e);
|
|
},
|
|
},
|
|
lookRecord(e) {
|
|
lookRecord(e) {
|
|
- this.judgeNum=0
|
|
|
|
|
|
+ this.judgeNum = 0;
|
|
console.log("eeeeeeeeeeeeeeeeeee", e);
|
|
console.log("eeeeeeeeeeeeeeeeeee", e);
|
|
this.isPop = true;
|
|
this.isPop = true;
|
|
if (!Array.isArray(e.type)) {
|
|
if (!Array.isArray(e.type)) {
|
|
- if (e.contact == "") {
|
|
|
|
|
|
+ if (!e.type) {
|
|
e.type = [];
|
|
e.type = [];
|
|
} else {
|
|
} else {
|
|
e.type = e.type.split(",");
|
|
e.type = e.type.split(",");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if (!Array.isArray(e.contact)) {
|
|
if (!Array.isArray(e.contact)) {
|
|
- if (e.contact == "") {
|
|
|
|
|
|
+ if (!e.contact) {
|
|
e.contact = [];
|
|
e.contact = [];
|
|
} else {
|
|
} else {
|
|
e.contact = e.contact.split(",");
|
|
e.contact = e.contact.split(",");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if (!Array.isArray(e.recordImg)) {
|
|
if (!Array.isArray(e.recordImg)) {
|
|
- if (e.contact == "") {
|
|
|
|
|
|
+ if (!e.recordImg) {
|
|
e.recordImg = [];
|
|
e.recordImg = [];
|
|
} else {
|
|
} else {
|
|
e.recordImg = e.recordImg.split(",");
|
|
e.recordImg = e.recordImg.split(",");
|