|
|
@@ -1,64 +1,208 @@
|
|
|
<template>
|
|
|
<div id="secondStep">
|
|
|
- <el-table
|
|
|
- :data="tableData"
|
|
|
- :span-method="objectSpanMethod"
|
|
|
- border
|
|
|
- style="width: 100%; margin-top: 10px"
|
|
|
- >
|
|
|
- <el-table-column
|
|
|
- align="center"
|
|
|
- v-for="(item, index) in tableSet"
|
|
|
- :key="index"
|
|
|
- :prop="item.prop"
|
|
|
- :label="item.label"
|
|
|
- ><template slot-scope="scope">
|
|
|
- <span>{{ scope.row[item.prop] }}</span>
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- </el-table>
|
|
|
+ <div class="topS">
|
|
|
+ 已选择
|
|
|
+ <strong style="color: red">{{ objCopy.length }}</strong> 人;共<strong
|
|
|
+ style="color: red"
|
|
|
+ >{{ compay(tableData, 6) }}</strong
|
|
|
+ >个商品(<strong style="color: red">{{ compay(tableData, 1) }}</strong
|
|
|
+ >视频、<strong style="color: red">{{ compay(tableData, 2) }}</strong
|
|
|
+ >题库、<strong style="color: red">{{ compay(tableData, 3) }}</strong
|
|
|
+ >补考、<strong style="color: red">{{ compay(tableData, 4) }}</strong
|
|
|
+ >前培);总价<strong style="color: red"
|
|
|
+ >¥{{ compay(tableData, 5).toFixed(2) }}</strong
|
|
|
+ >
|
|
|
+ </div>
|
|
|
+ <div class="bodySy">
|
|
|
+ <el-table
|
|
|
+ :height="heightData"
|
|
|
+ :data="tableData"
|
|
|
+ :span-method="objectSpanMethod"
|
|
|
+ border
|
|
|
+ style="width: 100%"
|
|
|
+ >
|
|
|
+ <el-table-column
|
|
|
+ header-align="center"
|
|
|
+ v-for="(item, index) in compayList(tableSet)"
|
|
|
+ :align="item.noCenter ? 'left' : 'center'"
|
|
|
+ :key="index"
|
|
|
+ :prop="item.prop"
|
|
|
+ :label="item.label"
|
|
|
+ :width="item.width"
|
|
|
+ ><template slot-scope="scope">
|
|
|
+ <span v-if="item.scope === 'subject'">
|
|
|
+ {{ changeSujectName(scope.row[item.prop]) }}
|
|
|
+ </span>
|
|
|
+ <div v-else-if="item.scope === 'goods'" style="white-space: nowrap">
|
|
|
+ <div v-if="!scope.row['subjectId']"></div>
|
|
|
+ <div v-else>
|
|
|
+ <el-checkbox
|
|
|
+ v-if="!scope.row['success']"
|
|
|
+ v-model="scope.row[item.prop1]"
|
|
|
+ style="margin-right: 6px"
|
|
|
+ > </el-checkbox
|
|
|
+ ><span style="color: rgb(132, 0, 255)">{{
|
|
|
+ typeChange(scope.row[item.prop2])
|
|
|
+ }}</span
|
|
|
+ >{{ scope.row[item.prop3] }}
|
|
|
+ <el-button
|
|
|
+ type="text"
|
|
|
+ :style="
|
|
|
+ scope.row[item.prop4] === -1 ? 'color:red!important;' : ''
|
|
|
+ "
|
|
|
+ style="color: green"
|
|
|
+ @click="
|
|
|
+ !scope.row['success']
|
|
|
+ ? getClass(scope.row, scope.$index)
|
|
|
+ : ''
|
|
|
+ "
|
|
|
+ >{{
|
|
|
+ scope.row[item.prop4]
|
|
|
+ ? scope.row[item.prop4] === -1
|
|
|
+ ? "请选择班级"
|
|
|
+ : scope.row[item.prop5]
|
|
|
+ : "自动分班"
|
|
|
+ }}</el-button
|
|
|
+ >
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div v-else-if="item.scope === 'priceInput'">
|
|
|
+ <div v-if="!scope.row['subjectId']"></div>
|
|
|
+ <div v-else>
|
|
|
+ ¥<span v-if="scope.row['success']"
|
|
|
+ >{{ scope.row[item.prop] }}
|
|
|
+ </span>
|
|
|
+ <el-input-number
|
|
|
+ v-else
|
|
|
+ :controls="false"
|
|
|
+ size="mini"
|
|
|
+ :min="0"
|
|
|
+ style="width: 80px"
|
|
|
+ :precision="2"
|
|
|
+ v-model="scope.row[item.prop]"
|
|
|
+ @blur="ChangeData(item.func, scope.row, $event)"
|
|
|
+ ></el-input-number>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <span v-else-if="item.scope === 'setOption'"
|
|
|
+ ><el-button
|
|
|
+ v-if="!scope.row['success']"
|
|
|
+ type="text"
|
|
|
+ @click="setOptionsFun(scope.row)"
|
|
|
+ >设置</el-button
|
|
|
+ ><el-button
|
|
|
+ type="text"
|
|
|
+ v-if="!orderSubmitStatus && !scope.row['success']"
|
|
|
+ @click="submitForm(2, scope.row)"
|
|
|
+ >重新提交</el-button
|
|
|
+ ></span
|
|
|
+ >
|
|
|
+ <span v-else-if="item.scope === 'result'">
|
|
|
+ {{
|
|
|
+ scope.row["success"]
|
|
|
+ ? "提交成功"
|
|
|
+ : scope.row["errmsg"] || "请设置商品"
|
|
|
+ }}
|
|
|
+ </span>
|
|
|
+ <span v-else
|
|
|
+ >{{ scope.row[item.prop] >= 0 ? item.ch : ""
|
|
|
+ }}{{ scope.row[item.prop] }}</span
|
|
|
+ >
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </div>
|
|
|
+ <div class="footS">
|
|
|
+ <el-button size="mini" @click="backToPage">上一步</el-button>
|
|
|
+ <el-button size="mini" @click="backPage">取消</el-button>
|
|
|
+ <el-button
|
|
|
+ size="mini"
|
|
|
+ :loading="disabledBtn"
|
|
|
+ @click="orderSubmitStatus ? submitForm() : submitForm(1)"
|
|
|
+ >{{ orderSubmitStatus ? "提交下单内容" : "继续下一步" }}</el-button
|
|
|
+ >
|
|
|
+ </div>
|
|
|
+ <select-class ref="selectClass" />
|
|
|
+ <set-goods-list ref="setGoodsList" />
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
+import selectClass from "./selectClass.vue";
|
|
|
+import setGoodsList from "./setGoodsList.vue";
|
|
|
export default {
|
|
|
+ components: { selectClass, setGoodsList },
|
|
|
data() {
|
|
|
return {
|
|
|
+ disabledBtn: false,
|
|
|
+ orderSubmitStatus: true, //订单是否可提交
|
|
|
tableSet: [
|
|
|
{
|
|
|
label: "学员姓名",
|
|
|
prop: "realname",
|
|
|
+ width: "100px",
|
|
|
},
|
|
|
{
|
|
|
label: "学员身份证",
|
|
|
prop: "idCard",
|
|
|
+ width: "160px",
|
|
|
},
|
|
|
{
|
|
|
label: "手机号码",
|
|
|
prop: "telphone",
|
|
|
+ width: "140px",
|
|
|
},
|
|
|
{
|
|
|
label: "科目",
|
|
|
- prop: "subjectIds",
|
|
|
+ prop: "subjectId",
|
|
|
+ scope: "subject",
|
|
|
+ width: "120px",
|
|
|
},
|
|
|
{
|
|
|
label: "所选商品",
|
|
|
- prop: "goodsName",
|
|
|
+ prop1: "checked",
|
|
|
+ prop2: "goodsType",
|
|
|
+ prop3: "goodsName",
|
|
|
+ prop4: "gradeId",
|
|
|
+ prop5: "gradeName",
|
|
|
+ scope: "goods",
|
|
|
+ noCenter: true,
|
|
|
},
|
|
|
{
|
|
|
label: "商品标准价格",
|
|
|
prop: "standPrice",
|
|
|
+ width: "120px",
|
|
|
+ ch: "¥",
|
|
|
},
|
|
|
{
|
|
|
label: "商品成交价",
|
|
|
- prop: "subjectIds",
|
|
|
+ prop: "goodsRealPrice",
|
|
|
+ width: "120px",
|
|
|
+ scope: "priceInput",
|
|
|
+ func: 1,
|
|
|
},
|
|
|
{
|
|
|
label: "本次收费金额",
|
|
|
- prop: "subjectIds",
|
|
|
+ prop: "goodsReceived",
|
|
|
+ width: "120px",
|
|
|
+ scope: "priceInput",
|
|
|
+ func: 2,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: "设置",
|
|
|
+ scope: "setOption",
|
|
|
+ width: "100px",
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: "提交结果",
|
|
|
+ scope: "result",
|
|
|
+ width: "200px",
|
|
|
},
|
|
|
],
|
|
|
+ objCopy: [],
|
|
|
+ heightData: 0,
|
|
|
tableData: [],
|
|
|
+ toData: {},
|
|
|
typeNameArr: [], // 第一列进行合并操作时存放的数组变量
|
|
|
typeNamePos: 0, // 上面的数组的下标值
|
|
|
storeArr: [], // 第二列进行合并操作时存放的数组变量
|
|
|
@@ -67,10 +211,213 @@ export default {
|
|
|
feePos: 0, // 上面的数组的下标值
|
|
|
fourArr: [], // 第三列进行合并操作时存放的数组变量
|
|
|
fourPos: 0, // 上面的数组的下标值
|
|
|
+ sujectList: [],
|
|
|
+ SN: "", //总单号
|
|
|
};
|
|
|
},
|
|
|
- mounted() {},
|
|
|
+ mounted() {
|
|
|
+ if (this.$parent.suppleRecord) {
|
|
|
+ this.SN = this.$parent.SN;
|
|
|
+ }
|
|
|
+ this.getHeightData();
|
|
|
+ this.getSujectList();
|
|
|
+ },
|
|
|
+ computed: {
|
|
|
+ compay: function () {
|
|
|
+ return function (data, int) {
|
|
|
+ var num = 0;
|
|
|
+ switch (int) {
|
|
|
+ case 1:
|
|
|
+ case 2:
|
|
|
+ case 3:
|
|
|
+ case 4:
|
|
|
+ data.forEach((item) => {
|
|
|
+ if (item.goodsType === int && item.checked) {
|
|
|
+ num++;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ break;
|
|
|
+ case 5:
|
|
|
+ data.forEach((item) => {
|
|
|
+ if (item.goodsReceived && item.checked) {
|
|
|
+ num += Number(item.goodsReceived);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ break;
|
|
|
+ case 6:
|
|
|
+ data.forEach((item) => {
|
|
|
+ if (
|
|
|
+ item.goodsType &&
|
|
|
+ item.goodsId &&
|
|
|
+ item.goodsName &&
|
|
|
+ item.checked
|
|
|
+ ) {
|
|
|
+ num++;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ break;
|
|
|
+
|
|
|
+ default:
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ return num;
|
|
|
+ };
|
|
|
+ },
|
|
|
+ compayList: function () {
|
|
|
+ return function (list) {
|
|
|
+ var arr = [];
|
|
|
+ if (this.orderSubmitStatus) {
|
|
|
+ arr = this.tableSet.filter((item) => {
|
|
|
+ return item.scope !== "result";
|
|
|
+ });
|
|
|
+ } else {
|
|
|
+ arr = JSON.parse(JSON.stringify(this.tableSet));
|
|
|
+ }
|
|
|
+ return arr;
|
|
|
+ };
|
|
|
+ },
|
|
|
+ },
|
|
|
methods: {
|
|
|
+ /**
|
|
|
+ * 取消
|
|
|
+ */
|
|
|
+ backPage() {
|
|
|
+ this.$store.dispatch("tagsView/delView", this.$route).then((res) => {
|
|
|
+ if (this.$parent.suppleRecord) {
|
|
|
+ this.$router.push({
|
|
|
+ path: "orderDetailsT",
|
|
|
+ query: {
|
|
|
+ inputOrderSn: this.$parent.SN,
|
|
|
+ },
|
|
|
+ });
|
|
|
+ } else {
|
|
|
+ this.$router.push({
|
|
|
+ path: "offlineOrder",
|
|
|
+ });
|
|
|
+ }
|
|
|
+ });
|
|
|
+ },
|
|
|
+ /**
|
|
|
+ * 修改金额
|
|
|
+ */
|
|
|
+ ChangeData(int, row, e) {
|
|
|
+ if (int === 1) {
|
|
|
+ if (!e.target.value) {
|
|
|
+ row.goodsRealPrice = 0;
|
|
|
+ row.goodsReceived = 0;
|
|
|
+ } else {
|
|
|
+ if (row.goodsReceived > e.target.value) {
|
|
|
+ row.goodsReceived = e.target.value;
|
|
|
+ this.$message.warning(
|
|
|
+ "商品成交价小于本次收费金额,已自动修改本次收费金额"
|
|
|
+ );
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (int === 2) {
|
|
|
+ if (!e.target.value) {
|
|
|
+ row.goodsReceived = 0;
|
|
|
+ } else {
|
|
|
+ if (row.goodsRealPrice < e.target.value) {
|
|
|
+ row.goodsReceived = row.goodsRealPrice;
|
|
|
+ this.$message.warning(
|
|
|
+ "本次收费金额大于商品成交价,已自动修改本次收费金额"
|
|
|
+ );
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ },
|
|
|
+ /**
|
|
|
+ * 获取表格初始高度
|
|
|
+ */
|
|
|
+ getHeightData() {
|
|
|
+ this.$nextTick(() => {
|
|
|
+ this.heightData =
|
|
|
+ document.getElementsByClassName("bodySy")[0].clientHeight;
|
|
|
+ });
|
|
|
+ },
|
|
|
+ /**
|
|
|
+ * 设置商品信息
|
|
|
+ */
|
|
|
+ setOptionsFun(row) {
|
|
|
+ let data = this.tableData.filter((item) => {
|
|
|
+ return item.realname === row.realname;
|
|
|
+ });
|
|
|
+ this.$refs.setGoodsList.openBox(this.toData, data);
|
|
|
+ },
|
|
|
+ uploadDatas(list) {
|
|
|
+ if (!list.length) return;
|
|
|
+ const index = this.tableData.findIndex((item) => {
|
|
|
+ return item.realname === list[0].realname;
|
|
|
+ });
|
|
|
+ if (index !== -1) {
|
|
|
+ let arr = this.tableData.filter((item) => {
|
|
|
+ return item.realname !== list[0].realname;
|
|
|
+ });
|
|
|
+ arr.splice(index, 0, ...list);
|
|
|
+ this.tableData = arr;
|
|
|
+ }
|
|
|
+ this.merage();
|
|
|
+ },
|
|
|
+ /**
|
|
|
+ * 选择班级
|
|
|
+ */
|
|
|
+ getClass(row, index) {
|
|
|
+ this.$refs.selectClass.openBox(row, index);
|
|
|
+ },
|
|
|
+ backClassData(obj, index) {
|
|
|
+ this.tableData[index].gradeId = obj.gradeId;
|
|
|
+ this.tableData[index].gradeName = obj.gradeName;
|
|
|
+ },
|
|
|
+ /**
|
|
|
+ * 转换商品类型
|
|
|
+ */
|
|
|
+ typeChange(int) {
|
|
|
+ var str = "";
|
|
|
+ switch (int) {
|
|
|
+ case 1:
|
|
|
+ str = "视:";
|
|
|
+ break;
|
|
|
+ case 2:
|
|
|
+ str = "题:";
|
|
|
+ break;
|
|
|
+ case 3:
|
|
|
+ str = "补:";
|
|
|
+ break;
|
|
|
+ case 4:
|
|
|
+ str = "前:";
|
|
|
+ break;
|
|
|
+
|
|
|
+ default:
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ return str;
|
|
|
+ },
|
|
|
+ /**
|
|
|
+ * 转换科目Id为名称
|
|
|
+ */
|
|
|
+ changeSujectName(id) {
|
|
|
+ var names = "";
|
|
|
+ for (var i = 0; i < this.sujectList.length; i++) {
|
|
|
+ if (this.sujectList[i].id == id) {
|
|
|
+ names = this.sujectList[i].subjectName;
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return names;
|
|
|
+ },
|
|
|
+ /**
|
|
|
+ * 获取科目列表
|
|
|
+ */
|
|
|
+ getSujectList() {
|
|
|
+ this.$api
|
|
|
+ .inquireCourseSubject({
|
|
|
+ status: 1,
|
|
|
+ })
|
|
|
+ .then((res) => {
|
|
|
+ this.sujectList = res.rows;
|
|
|
+ });
|
|
|
+ },
|
|
|
merageInit() {
|
|
|
// 在下文的时候会用到,对数据进行初始化是很有必要的
|
|
|
this.typeNameArr = [];
|
|
|
@@ -85,7 +432,6 @@ export default {
|
|
|
merage() {
|
|
|
this.merageInit(); // 前文的初始化数据函数
|
|
|
for (let i = 0; i < this.tableData.length; i += 1) {
|
|
|
- console.log(this.tableData[i], "aa");
|
|
|
if (i === 0) {
|
|
|
// 第一行必须存在
|
|
|
this.typeNameArr.push(1);
|
|
|
@@ -179,9 +525,18 @@ export default {
|
|
|
rowspan: row4,
|
|
|
colspan: col4,
|
|
|
};
|
|
|
+ } else if (columnIndex >= 8) {
|
|
|
+ // 第一列的合并方法
|
|
|
+ const row8 = this.typeNameArr[rowIndex];
|
|
|
+ const col8 = row8 > 0 ? 1 : 0; // 如果被合并了row = 0; 则他这个列需要取消
|
|
|
+ return {
|
|
|
+ rowspan: row8,
|
|
|
+ colspan: col8,
|
|
|
+ };
|
|
|
}
|
|
|
},
|
|
|
getInitData(obj) {
|
|
|
+ this.toData = JSON.parse(JSON.stringify(obj.topData));
|
|
|
let data = JSON.parse(JSON.stringify(obj.tableData));
|
|
|
this.$api
|
|
|
.inquireorderconfiggoodsList({
|
|
|
@@ -201,6 +556,11 @@ export default {
|
|
|
} else {
|
|
|
items.checked = false;
|
|
|
}
|
|
|
+ items.goodsRealPrice = items.standPrice;
|
|
|
+ items.goodsReceived = items.standPrice;
|
|
|
+ if (!items.gradeId) {
|
|
|
+ items.gradeId = 0;
|
|
|
+ }
|
|
|
return items;
|
|
|
});
|
|
|
item.subjectList.push({
|
|
|
@@ -216,6 +576,7 @@ export default {
|
|
|
});
|
|
|
},
|
|
|
decomposeFunc(obj) {
|
|
|
+ this.objCopy = JSON.parse(JSON.stringify(obj));
|
|
|
var arrays = [];
|
|
|
obj.forEach((item) => {
|
|
|
if (item.subjectList.length == 0) {
|
|
|
@@ -223,19 +584,220 @@ export default {
|
|
|
} else {
|
|
|
item.subjectList.forEach((items) => {
|
|
|
items.goodsList.forEach((itemsxs) => {
|
|
|
- itemsxs.subjectId = items.subjectId;
|
|
|
- var datas = Object.assign({ ...item, ...itemsxs });
|
|
|
- arrays.push(datas);
|
|
|
+ if (this.toData.type.indexOf(itemsxs.goodsType) !== -1) {
|
|
|
+ itemsxs.subjectId = items.subjectId;
|
|
|
+ var datas = Object.assign({ ...item, ...itemsxs });
|
|
|
+ arrays.push(datas);
|
|
|
+ }
|
|
|
});
|
|
|
});
|
|
|
}
|
|
|
+ let arry = arrays.some((items) => {
|
|
|
+ return (
|
|
|
+ items.realname == item.realname && items.telphone == item.telphone
|
|
|
+ );
|
|
|
+ });
|
|
|
+ if (!arry) {
|
|
|
+ arrays.push(item);
|
|
|
+ }
|
|
|
});
|
|
|
this.tableData = arrays;
|
|
|
this.merage();
|
|
|
},
|
|
|
+ backToPage() {
|
|
|
+ this.$alert(
|
|
|
+ "确定返回上一步吗?<br />内容清除后将无法恢复,请慎重考虑",
|
|
|
+ "提示",
|
|
|
+ {
|
|
|
+ dangerouslyUseHTMLString: true,
|
|
|
+ }
|
|
|
+ )
|
|
|
+ .then(() => {
|
|
|
+ this.$parent.activeName = "first";
|
|
|
+ })
|
|
|
+ .catch(() => {});
|
|
|
+ },
|
|
|
+ getOrderSNApi() {
|
|
|
+ return new Promise((resolve, reject) => {
|
|
|
+ this.$api
|
|
|
+ .apporderinput({
|
|
|
+ educationTypeId: this.toData.educationId,
|
|
|
+ projectId: this.toData.projectId,
|
|
|
+ businessId: this.toData.businessId,
|
|
|
+ })
|
|
|
+ .then((res) => {
|
|
|
+ this.SN = res.data;
|
|
|
+ this.$parent.SN = res.data;
|
|
|
+ resolve();
|
|
|
+ });
|
|
|
+ });
|
|
|
+ },
|
|
|
+ async submitForm(int, row) {
|
|
|
+ if (this.orderSubmitStatus) {
|
|
|
+ let py = this.tableData.some((item) => {
|
|
|
+ return item.checked && item.gradeId == -1;
|
|
|
+ });
|
|
|
+ if (py) {
|
|
|
+ this.$message.warning("请选择班级");
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if (int === 2 && row) {
|
|
|
+ let ary = this.tableData.some((item) => {
|
|
|
+ return (
|
|
|
+ item.userId === row.userId && item.checked && item.gradeId == -1
|
|
|
+ );
|
|
|
+ });
|
|
|
+ if (ary) {
|
|
|
+ this.$message.warning("请选择班级");
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ this.disabledBtn = true;
|
|
|
+ if (int === 1 && !this.orderSubmitStatus) {
|
|
|
+ var successList = this.tableData.filter((item) => {
|
|
|
+ return item.checked && item.success;
|
|
|
+ });
|
|
|
+ var errorList = this.tableData.filter((item) => {
|
|
|
+ return item.checked && item.errmsg;
|
|
|
+ });
|
|
|
+ this.$parent.changePage2("third", successList, errorList);
|
|
|
+ this.disabledBtn = false;
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ let submitTable = this.tableData.filter((item) => {
|
|
|
+ if (row && int === 2) {
|
|
|
+ return item.checked && item.userId === row.userId;
|
|
|
+ } else {
|
|
|
+ return item.checked;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ if (!submitTable.length && int === 2) {
|
|
|
+ this.tableData.forEach((items, indexs) => {
|
|
|
+ if (items.userId === row.userId) {
|
|
|
+ this.$set(this.tableData[indexs], "errmsg", "");
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ if (!this.SN) {
|
|
|
+ await this.getOrderSNApi();
|
|
|
+ }
|
|
|
+ let arr = [];
|
|
|
+ submitTable.forEach((item) => {
|
|
|
+ if (!arr.length) {
|
|
|
+ arr.push({
|
|
|
+ inputOrderSn: this.SN,
|
|
|
+ orderFrom: 1,
|
|
|
+ userId: item.userId,
|
|
|
+ goodsList: [
|
|
|
+ {
|
|
|
+ goodsId: item.goodsId,
|
|
|
+ goodsRealPrice: item.goodsRealPrice,
|
|
|
+ goodsReceived: item.goodsReceived,
|
|
|
+ goodsPrice: item.standPrice,
|
|
|
+ goodsInputData: {
|
|
|
+ gradeId: item.gradeId,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ ],
|
|
|
+ });
|
|
|
+ } else {
|
|
|
+ const findIndex = arr.findIndex((items) => {
|
|
|
+ return items.userId === item.userId;
|
|
|
+ });
|
|
|
+ if (findIndex !== -1) {
|
|
|
+ arr[findIndex].goodsList.push({
|
|
|
+ goodsId: item.goodsId,
|
|
|
+ goodsRealPrice: item.goodsRealPrice,
|
|
|
+ goodsReceived: item.goodsReceived,
|
|
|
+ goodsPrice: item.standPrice,
|
|
|
+ goodsInputData: {
|
|
|
+ gradeId: item.gradeId,
|
|
|
+ },
|
|
|
+ });
|
|
|
+ } else {
|
|
|
+ arr.push({
|
|
|
+ inputOrderSn: this.SN,
|
|
|
+ orderFrom: 1,
|
|
|
+ userId: item.userId,
|
|
|
+ goodsList: [
|
|
|
+ {
|
|
|
+ goodsId: item.goodsId,
|
|
|
+ goodsRealPrice: item.goodsRealPrice,
|
|
|
+ goodsReceived: item.goodsReceived,
|
|
|
+ goodsPrice: item.standPrice,
|
|
|
+ goodsInputData: {
|
|
|
+ gradeId: item.gradeId,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ ],
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+ });
|
|
|
+ arr.forEach(async (item, index) => {
|
|
|
+ await this.submitFunApi(item);
|
|
|
+ });
|
|
|
+ if (arr.length) {
|
|
|
+ this.$message("已提交下单内容");
|
|
|
+ }
|
|
|
+ this.disabledBtn = false;
|
|
|
+ this.orderSubmitStatus = false;
|
|
|
+ },
|
|
|
+ submitFunApi(item) {
|
|
|
+ var self = this;
|
|
|
+ return new Promise((resolve, reject) => {
|
|
|
+ self.$api.apporderinputOrder(item).then((res) => {
|
|
|
+ resolve(res);
|
|
|
+ if (res.code === 510 || res.code === 511) {
|
|
|
+ self.tableData.forEach((items, indexs) => {
|
|
|
+ if (items.userId === item.userId) {
|
|
|
+ self.$set(self.tableData[indexs], "errmsg", res.msg);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ } else {
|
|
|
+ self.tableData.forEach((items, indexs) => {
|
|
|
+ if (items.userId === item.userId) {
|
|
|
+ if (items.errmsg) {
|
|
|
+ self.$set(self.tableData[indexs], "errmsg", "");
|
|
|
+ }
|
|
|
+ self.$set(self.tableData[indexs], "success", true);
|
|
|
+ self.$set(self.tableData[indexs], "orderId", res.data.orderId);
|
|
|
+ self.$set(self.tableData[indexs], "orderSn", res.data.orderSn);
|
|
|
+ self.$set(self.tableData[indexs], "sheetId", res.data.sheetId);
|
|
|
+ self.$set(self.tableData[indexs], "sheetSn", res.data.sheetSn);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ });
|
|
|
+ });
|
|
|
+ },
|
|
|
},
|
|
|
};
|
|
|
</script>
|
|
|
|
|
|
<style lang="less" scoped>
|
|
|
+#secondStep {
|
|
|
+ display: flex;
|
|
|
+ flex-direction: column;
|
|
|
+ height: 100%;
|
|
|
+ .topS {
|
|
|
+ flex-shrink: 0;
|
|
|
+ height: 28px;
|
|
|
+ text-align: end;
|
|
|
+ font-size: 14px;
|
|
|
+ line-height: 28px;
|
|
|
+ }
|
|
|
+ .bodySy {
|
|
|
+ flex: 1;
|
|
|
+ margin: 10px 0px;
|
|
|
+ box-shadow: 0px 0px 8px 1px rgba(0, 0, 0, 0.2);
|
|
|
+ }
|
|
|
+ .footS {
|
|
|
+ flex-shrink: 0;
|
|
|
+ height: 34px;
|
|
|
+ text-align: center;
|
|
|
+ }
|
|
|
+}
|
|
|
</style>
|