2df5079280f003dfa0f9dcf39cfa9d9c.json 47 KB

1
  1. {"remainingRequest":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\babel-loader\\lib\\index.js!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\src\\views\\stock\\WarehouseManagement\\AddInventoryInfo.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\src\\views\\stock\\WarehouseManagement\\AddInventoryInfo.vue","mtime":1655374732000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\babel.config.js","mtime":1655374732000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\vue-loader\\lib\\index.js","mtime":1655715099000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import AllocateGoodsList from "@/component/goods/AllocateGoodsList.vue";
import WarehouseModel from "@/component/common/WarehouseModel.vue";
import CallInLocation from "@/component/common/CallInLocation";
import { addPauseSave, getPauseSave, delPauseSave } from "@/api/common";
import { addStocktaking, updateStocktaking, getStocktakingInfo } from "@/api/Stock";
import { mapGetters } from "vuex";
export default {
  name: "PurchaseOrderAdd",
  components: {
    AllocateGoodsList,
    WarehouseModel,
    CallInLocation
  },

  data() {
    const validateWarehouse = (rule, value, callback) => {
      if (!value) {
        callback(new Error("请选择仓库"));
      } else {
        callback();
      }
    };

    return {
      skuId: "",
      materielId: "",
      row_index: "",
      storage_show: false,
      loading: false,
      createTime: "",
      no: "",
      del_goods_id: [],
      form_data: {
        warehouseId: "",
        warehouseName: "",
        operatorName: "",
        remark: "",
        stocktakingTime: "",
        details: []
      },
      fromWarehouse: "",
      rules: {
        warehouseId: [{
          required: true,
          validator: validateWarehouse
        }]
      },
      warehouse_show: false,
      invenrory_id: "",
      // 盘点单id
      show_selgoods: false,
      goods_list: [],
      look_path: "",
      activeName: "one"
    };
  },

  computed: {
    plus_goods() {
      let num = 0;
      this.goods_list.forEach(item => {
        if (item.diffNum > 0) {
          num++;
        }
      });
      return num;
    },

    plus_num() {
      let num = 0;
      this.goods_list.forEach(item => {
        if (item.diffNum > 0) {
          num = num + Number(item.diffNum);
        }
      });
      return num;
    },

    diff_goods() {
      let num = 0;
      this.goods_list.forEach(item => {
        if (item.diffNum < 0) {
          num++;
        }
      });
      return num;
    },

    diff_num() {
      let num = 0;
      this.goods_list.forEach(item => {
        if (item.diffNum < 0) {
          num = num + Number(item.diffNum);
        }
      });
      return num;
    },

    ...mapGetters({
      enableLocationManagement: "MUser/enableLocationManagement"
    })
  },

  created() {
    this.look_path = this.$route.name;

    if (this.$route.params.id) {
      this.invenrory_id = this.$route.params.id;
      this.getStocktakingInfo();
    } else {
      this.form_data.operatorName = this.userName;
      this.form_data.stocktakingTime = new Date().getTime();
      this.createTime = new Date().getTime();
      this.getPauseSave();
    }
  },

  methods: {
    // 选择仓库
    selWarehouse(val) {
      const row = val[0];
      this.fromWarehouse = row.warehouseName;
      this.form_data.warehouseId = row.id;
      this.form_data.warehouseName = row.warehouseName;
      this.goods_list = [];
    },

    // 新增暂存
    async addPauseSave() {
      const details = this.$_common.deepClone(this.goods_list).map(item => {
        return item;
      });
      let params = { ...this.form_data,
        warehouseName: this.fromWarehouse,
        stocktakingTime: parseInt(this.form_data.stocktakingTime / 1000),
        details: details
      };
      let target = {};
      this.loading = true;
      const data = await addPauseSave({
        key: this.look_path,
        data: params
      });
      this.loading = false;
      await this.$message({
        type: "success",
        message: "暂存成功"
      });

      if (this.systemType === 2) {
        await this.$closeCurrentGoEdit("/SingleStore/Inventory/InventoryCheck");
      } else {
        await this.$closeCurrentGoEdit("/stock/WarehouseManagement/inventoryInfo");
      }
    },

    // 获取暂存信息
    async getPauseSave() {
      const {
        data
      } = await getPauseSave({
        key: this.look_path
      });
      if (JSON.stringify(data) === "{}") return;
      this.form_data = {
        warehouseId: data.warehouseId,
        warehouseName: data.warehouseName,
        operatorName: data.operatorName,
        remark: data.remark,
        stocktakingTime: data.stocktakingTime,
        details: data.details
      };
      this.no = data.no;
      this.form_data.stocktakingTime = data.stocktakingTime * 1000; // this.createTime = data.createTime * 1000

      this.fromWarehouse = data.warehouseName;
      this.goods_list = data.details.map(item => {
        return {
          id: item.id,
          materielId: item.materielId,
          materielName: item.materielName,
          materielCode: item.materielCode,
          skuId: item.skuId,
          skuName: item.skuName,
          unitName: item.unitName,
          diffNum: item.diffNum,
          remark: item.remark,
          costUnitPrice: item.costUnitPrice || 0,
          documentInventoryNum: item.documentInventoryNum,
          // 账面库存
          currentInventoryNum: item.currentInventoryNum,
          // 实盘库存
          otherNum: item.otherNum,
          // 其他单位
          areaId: item.areaId,
          areaName: item.areaName,
          areaCode: item.areaCode,
          storageLocationName: item.storageLocationName,
          storageLocationId: item.storageLocationId,
          storageLocationCode: item.storageLocationCode
        };
      });
    },

    // 清除暂存
    async delPauseSave(type) {
      const data = delPauseSave({
        key: this.look_path
      });

      if (type) {
        this.$message({
          type: "success",
          message: "清除暂存成功"
        });
        this.$baseEventBus.$emit("reloadRouterView");
      }
    },

    //  点击保存按钮
    async addPurchaseOrder() {
      this.$refs["form"].validate(async valid => {
        if (valid) {
          if (!this.goods_list.length) {
            this.$message.warning(`请选择盘点商品`);
            return;
          }

          let issub = true;

          for (let i in this.goods_list) {
            let item = this.goods_list[i];

            if (Number(item.documentInventoryNum) === 0) {
              this.$message.warning(`第【${Number(i) + 1}】条数据，账面库存为0,无法保存`);
              issub = false;
              break;
            } // if (
            //   this.enableLocationManagement === 5 &&
            //   !item.storageLocationName
            // ) {
            //   issub = false;
            //   this.$message.warning(
            //     `第【${Number(i) + 1}】条数据，未选择库区库位`
            //   );
            //   break;
            // }

          }

          if (!issub) {
            return;
          }

          const details = this.$_common.deepClone(this.goods_list).map(item => {
            delete item.diffNum;
            return item;
          });
          let params = { ...this.form_data,
            stocktakingTime: parseInt(this.form_data.stocktakingTime / 1000),
            details: details
          };

          try {
            this.loading = true;

            if (!this.invenrory_id) {
              // 添加
              const data = await addStocktaking(params);
            } else {
              // 编辑
              params.deleteArray = this.del_goods_id;
              const data = await updateStocktaking(this.invenrory_id, params);
            }

            this.loading = false;
            await this.$message({
              type: "success",
              message: "提交成功"
            });
            await this.delPauseSave();

            if (this.systemType === 2) {
              await this.$closeCurrentGoEdit("/SingleStore/Inventory/InventoryCheck");
            } else {
              await this.$closeCurrentGoEdit("/stock/WarehouseManagement/inventoryInfo");
            }
          } finally {
            this.loading = false;
          }
        }
      });
    },

    //  获取详情 getStocktakingInfo
    async getStocktakingInfo() {
      const {
        data
      } = await getStocktakingInfo(this.invenrory_id);
      this.form_data = {
        warehouseId: data.warehouseId,
        warehouseName: data.warehouseName,
        operatorName: data.operatorName,
        remark: data.remark,
        stocktakingTime: data.stocktakingTime,
        details: data.details
      };
      this.no = data.no;
      this.form_data.stocktakingTime = data.stocktakingTime * 1000;
      this.createTime = data.createTime * 1000;
      this.fromWarehouse = data.warehouseName;
      this.goods_list = data.details.map(item => {
        return {
          id: item.id,
          materielId: item.materielId,
          materielName: item.materielName,
          materielCode: item.materielCode,
          skuId: item.skuId,
          skuName: item.skuName,
          unitName: item.unitName,
          diffNum: item.differenceStatus === 4 ? 0 - item.differenceNum : item.differenceNum - 0,
          remark: item.remark,
          costUnitPrice: item.costUnitPrice || 0,
          documentInventoryNum: item.documentInventoryNum,
          // 账面库存
          currentInventoryNum: item.currentInventoryNum,
          // 实盘库存
          otherNum: item.otherNum,
          // 其他单位
          areaId: item.areaId,
          areaName: item.areaName,
          areaCode: item.areaCode,
          storageLocationName: item.storageLocationName,
          storageLocationId: item.storageLocationId,
          storageLocationCode: item.storageLocationCode
        };
      });
    },

    //  删除
    delData(index, row) {
      this.$confirm("请确认是否删除该商品?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(() => {
        if (row.id) {
          this.del_goods_id.push(row.id);
        }

        this.goods_list.splice(index, 1);
        this.$message({
          type: "success",
          message: "删除成功!"
        });
      });
    },

    // 改变数量
    editNumChange({
      row,
      rowIndex
    }) {
      this.goods_list[rowIndex].diffNum = this.$NP.minus(row.currentInventoryNum, row.documentInventoryNum);
    },

    //  选择商品goodData的数据
    selMoreGoods(val) {
      const goodsData = val.map(item => {
        return {
          isEq: item.isEq,
          otherNum: item.otherNum,
          materielId: item.materielId,
          materielName: item.materielName,
          materielCode: item.materielCode,
          skuId: item.skuId,
          skuName: item.skuName,
          unitName: item.unitName,
          diffNum: 0,
          remark: "",
          costUnitPrice: item.costPrice,
          documentInventoryNum: item.allNum,
          // 账面库存
          currentInventoryNum: item.inventoryNum,
          // 实盘库存
          areaId: "",
          areaName: "",
          areaCode: "",
          storageLocationName: "",
          storageLocationId: "",
          storageLocationCode: ""
        };
      });

      if (this.goods_list.length) {
        this.goods_list = this.$_common.unique(this.goods_list.concat(goodsData), ["materielId", "skuId"]);
      } else {
        this.goods_list = goodsData;
      }
    },

    // 合计
    getSummaries(param) {
      return this.$_common.getSummaries(param, ["实盘库存", "盈亏数量"]);
    },

    objectSpanMethod({
      columns,
      data
    }) {
      const properties = ["materielName", "materielCode", "skuName", "unitName", "remark", "diffNum", "storageLocationName"];
      return this.$_common.getSummariesVxe(columns, data, properties);
    },

    // 选择库区库位
    selStorage(e) {
      const target = this.$_common.deepClone(this.goods_list);
      target[this.row_index] = { ...target[this.row_index],
        areaId: e[0].areaId,
        areaName: e[0].areaName,
        areaCode: e[0].areaCode,
        storageLocationName: e[0].storageLocationName,
        storageLocationId: e[0].storageLocationId,
        storageLocationCode: e[0].storageLocationCode
      };
      this.goods_list = target;
    },

    storageShow(row, rowIndex) {
      this.row_index = rowIndex;
      this.materielId = row.materielId;
      this.skuId = row.skuId;
      this.storage_show = true;
    }

  }
};"},{"version":3,"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiPA;AACA;AACA;AACA;AACA,SACAA,cADA,EAEAC,iBAFA,EAGAC,kBAHA,QAIA,aAJA;AAKA;AACA;EACAC,wBADA;EAEAC;IACAC,iBADA;IAEAC,cAFA;IAGAC;EAHA,CAFA;;EAOAC;IACA;MACA;QACAC;MACA,CAFA,MAEA;QACAA;MACA;IACA,CANA;;IAOA;MACAC,SADA;MAEAC,cAFA;MAGAC,aAHA;MAIAC,mBAJA;MAKAC,cALA;MAMAC,cANA;MAOAC,MAPA;MAQAC,gBARA;MASAC;QACAC,eADA;QAEAC,iBAFA;QAGAC,gBAHA;QAIAC,UAJA;QAKAC,mBALA;QAMAC;MANA,CATA;MAiBAC,iBAjBA;MAkBAC;QACAP;UAAAQ;UAAAC;QAAA;MADA,CAlBA;MAqBAC,qBArBA;MAsBAC,gBAtBA;MAsBA;MACAC,oBAvBA;MAwBAC,cAxBA;MAyBAC,aAzBA;MA0BAC;IA1BA;EA4BA,CA3CA;;EA4CAC;IACAC;MACA;MACA;QACA;UACAC;QACA;MACA,CAJA;MAKA;IACA,CATA;;IAUAC;MACA;MACA;QACA;UACAD;QACA;MACA,CAJA;MAKA;IACA,CAlBA;;IAmBAE;MACA;MACA;QACA;UACAF;QACA;MACA,CAJA;MAKA;IACA,CA3BA;;IA4BAG;MACA;MACA;QACA;UACAH;QACA;MACA,CAJA;MAKA;IACA,CApCA;;IAqCA;MACAI;IADA;EArCA,CA5CA;;EAqFAC;IACA;;IACA;MACA;MACA;IACA,CAHA,MAGA;MACA;MACA;MACA;MACA;IACA;EACA,CAhGA;;EAiGAC;IACA;IACAC;MACA;MACA;MACA;MACA;MACA;IACA,CARA;;IASA;IACA;MACA;QACA;MACA,CAFA;MAGA,eACA,iBADA;QAEAxB,iCAFA;QAGAG,gEAHA;QAIAC;MAJA;MAMA;MACA;MACA;QACAqB,mBADA;QAEArC;MAFA;MAIA;MAEA;QACAsC,eADA;QAEAC;MAFA;;MAIA;QACA,+BACA,uCADA;MAGA,CAJA,MAIA;QACA,+BACA,0CADA;MAGA;IACA,CAzCA;;IA0CA;IACA;MACA;QAAAvC;MAAA;QACAqC;MADA;MAIA;MACA;QACA1B,6BADA;QAEAC,iCAFA;QAGAC,+BAHA;QAIAC,mBAJA;QAKAC,qCALA;QAMAC;MANA;MAQA;MACA,6DAfA,CAgBA;;MACA;MACA;QACA;UACAwB,WADA;UAEArC,2BAFA;UAGAsC,+BAHA;UAIAC,+BAJA;UAKAxC,iBALA;UAMAyC,qBANA;UAOAC,uBAPA;UAQAC,qBARA;UASA/B,mBATA;UAUAgC,sCAVA;UAWAC,+CAXA;UAWA;UACAC,6CAZA;UAYA;UACAC,uBAbA;UAaA;UACAC,mBAdA;UAeAC,uBAfA;UAgBAC,uBAhBA;UAiBAC,6CAjBA;UAkBAC,yCAlBA;UAmBAC;QAnBA;MAqBA,CAtBA;IAuBA,CApFA;;IAqFA;IACA;MACA;QACAlB;MADA;;MAIA;QACA;UACAC,eADA;UAEAC;QAFA;QAIA;MACA;IACA,CAlGA;;IAmGA;IACA;MACA;QACA;UACA;YACA;YACA;UACA;;UACA;;UACA;YACA;;YACA;cACA,sBACA,oCADA;cAGAiB;cACA;YACA,CARA,CASA;YACA;YACA;YACA;YACA;YACA;YACA;YACA;YACA;YACA;;UACA;;UACA;YACA;UACA;;UACA,8BACAC,SADA,CACA,eADA,EAEAC,GAFA,CAEAC;YACA;YACA;UACA,CALA;UAMA,eACA,iBADA;YAEA5C,gEAFA;YAGAC;UAHA;;UAKA;YACA;;YACA;cACA;cACA;YACA,CAHA,MAGA;cACA;cACA4C;cACA;YACA;;YACA;YACA;cACAtB,eADA;cAEAC;YAFA;YAIA;;YACA;cACA,+BACA,uCADA;YAGA,CAJA,MAIA;cACA,+BACA,0CADA;YAGA;UACA,CAzBA,SAyBA;YACA;UACA;QACA;MACA,CAtEA;IAuEA,CA5KA;;IA6KA;IACA;MACA;QAAAvC;MAAA;MAEA;QACAW,6BADA;QAEAC,iCAFA;QAGAC,+BAHA;QAIAC,mBAJA;QAKAC,qCALA;QAMAC;MANA;MAQA;MACA;MACA;MACA;MACA;QACA;UACAwB,WADA;UAEArC,2BAFA;UAGAsC,+BAHA;UAIAC,+BAJA;UAKAxC,iBALA;UAMAyC,qBANA;UAOAC,uBAPA;UAQAC,SACAc,8BACA,sBADA,GAEAA,sBAXA;UAYA7C,mBAZA;UAaAgC,sCAbA;UAcAC,+CAdA;UAcA;UACAC,6CAfA;UAeA;UACAC,uBAhBA;UAgBA;UACAC,mBAjBA;UAkBAC,uBAlBA;UAmBAC,uBAnBA;UAoBAC,6CApBA;UAqBAC,yCArBA;UAsBAC;QAtBA;MAwBA,CAzBA;IA0BA,CAvNA;;IAwNA;IACAM;MACA;QACAC,uBADA;QAEAC,sBAFA;QAGAzB;MAHA,GAIA0B,IAJA,CAIA;QACA;UACA;QACA;;QACA;QACA;UACA1B,eADA;UAEAC;QAFA;MAIA,CAbA;IAcA,CAxOA;;IAyOA;IACA0B;MAAAC;MAAAC;IAAA;MACA,mDACAD,uBADA,EAEAA,wBAFA;IAIA,CA/OA;;IAgPA;IACAE;MACA;QACA;UACAC,eADA;UAEApB,uBAFA;UAGA9C,2BAHA;UAIAsC,+BAJA;UAKAC,+BALA;UAMAxC,iBANA;UAOAyC,qBAPA;UAQAC,uBARA;UASAC,UATA;UAUA/B,UAVA;UAWAgC,6BAXA;UAYAC,iCAZA;UAYA;UACAC,sCAbA;UAaA;UACAE,UAdA;UAeAC,YAfA;UAgBAC,YAhBA;UAiBAC,uBAjBA;UAkBAC,qBAlBA;UAmBAC;QAnBA;MAqBA,CAtBA;;MAuBA;QACA,uCACA,iCADA,EAEA,uBAFA;MAIA,CALA,MAKA;QACA;MACA;IACA,CAjRA;;IAkRA;IACAe;MACA;IACA,CArRA;;IAsRAC;MAAAC;MAAAxE;IAAA;MACA,oBACA,cADA,EAEA,cAFA,EAGA,SAHA,EAIA,UAJA,EAKA,QALA,EAMA,SANA,EAOA,qBAPA;MASA;IACA,CAjSA;;IAkSA;IACAyE;MACA;MACAC,2BACA,yBADA;QAEAxB,mBAFA;QAGAC,uBAHA;QAIAC,uBAJA;QAKAC,6CALA;QAMAC,yCANA;QAOAC;MAPA;MASA;IACA,CA/SA;;IAgTAoB;MACA;MACA;MACA;MACA;IACA;;EArTA;AAjGA","names":["addStocktaking","updateStocktaking","getStocktakingInfo","name","components","AllocateGoodsList","WarehouseModel","CallInLocation","data","callback","skuId","materielId","row_index","storage_show","loading","createTime","no","del_goods_id","form_data","warehouseId","warehouseName","operatorName","remark","stocktakingTime","details","fromWarehouse","rules","required","validator","warehouse_show","invenrory_id","show_selgoods","goods_list","look_path","activeName","computed","plus_goods","num","plus_num","diff_goods","diff_num","enableLocationManagement","created","methods","selWarehouse","key","type","message","id","materielName","materielCode","skuName","unitName","diffNum","costUnitPrice","documentInventoryNum","currentInventoryNum","otherNum","areaId","areaName","areaCode","storageLocationName","storageLocationId","storageLocationCode","issub","deepClone","map","item","params","delData","confirmButtonText","cancelButtonText","then","editNumChange","row","rowIndex","selMoreGoods","isEq","getSummaries","objectSpanMethod","columns","selStorage","target","storageShow"],"sourceRoot":"src/views/stock/WarehouseManagement","sources":["AddInventoryInfo.vue"],"sourcesContent":["<template>\n <ContainerTit class=\"AddInventoryInfo\">\n <div style=\"position: relative\">\n <div class=\"btn-top-div\">\n <el-button v-if=\"!$route.params.id\" @click=\"delPauseSave(1)\">\n 清除暂存\n </el-button>\n <el-button\n v-if=\"!$route.params.id\"\n :loading=\"loading\"\n @click=\"addPauseSave\"\n >\n 暂存\n </el-button>\n <el-button type=\"primary\" :loading=\"loading\" @click=\"addPurchaseOrder\">\n 保存\n </el-button>\n </div>\n </div>\n <div>\n <el-form ref=\"form\" inline :model=\"form_data\" size=\"small\" :rules=\"rules\">\n <el-tabs v-model=\"activeName\">\n <el-tab-pane label=\"新增盘点单\" name=\"one\">\n <el-row style=\"padding-bottom: 13px\">\n <el-col :span=\"24\">\n <p\n style=\"padding-left: 20px\"\n class=\"order_midden_left_text el-icon-arrow-right\"\n >\n 收盘点信息\n </p>\n </el-col>\n <el-col\n v-if=\"!!no\"\n class=\"form\"\n :span=\"6\"\n style=\"margin-bottom: 0\"\n >\n <el-form-item label=\"单据编号:\">\n {{ no }}\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\" style=\"margin-bottom: 0\">\n <el-form-item label=\"所属仓库:\" prop=\"warehouseId\">\n <el-input\n v-model=\"fromWarehouse\"\n placeholder=\"所属仓库\"\n readonly\n >\n <i\n slot=\"suffix\"\n class=\"el-input__icon el-icon-search\"\n @click=\"warehouse_show = true\"\n ></i>\n </el-input>\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\" style=\"margin-bottom: 0\">\n <el-form-item label=\"盘点日期:\" prop=\"stocktakingTime\">\n <el-date-picker\n v-model=\"form_data.stocktakingTime\"\n type=\"date\"\n placeholder=\"选择日期\"\n value-format=\"timestamp\"\n ></el-date-picker>\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\">\n <el-form-item label=\"制单人员:\">\n {{ form_data.operatorName }}\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\">\n <el-form-item label=\"制单时间:\">\n <span>{{ $_common.formatDate(createTime) }}</span>\n </el-form-item>\n </el-col>\n </el-row>\n </el-tab-pane>\n </el-tabs>\n <div class=\"order_bottom\">\n <p class=\"text\">商品清单</p>\n <el-button\n class=\"order_bottom_btn\"\n type=\"primary\"\n size=\"small\"\n :disabled=\"!fromWarehouse\"\n @click=\"show_selgoods = true\"\n >\n 选择商品\n </el-button>\n <div class=\"Enunciate\">\n <div class=\"Enunciate_cont clearfix\">\n <div class=\"float_left\">\n 有 {{ plus_goods }} 款商品共计\n <span>{{ plus_num }}</span>\n 件盘盈,有 {{ diff_goods }} 款商品共计\n <span>{{ diff_num }}</span>\n 件盘亏\n </div>\n </div>\n </div>\n <vxe-table\n border=\"inner\"\n resizable\n show-footer\n show-overflow\n :data=\"goods_list\"\n :edit-config=\"{ trigger: 'click', mode: 'cell' }\"\n :footer-method=\"objectSpanMethod\"\n @edit-closed=\"editNumChange\"\n >\n <vxe-table-column type=\"seq\" width=\"60\"></vxe-table-column>\n <vxe-table-column\n field=\"materielCode\"\n title=\"商品编码\"\n ></vxe-table-column>\n <vxe-table-column\n field=\"materielName\"\n title=\"商品名称\"\n ></vxe-table-column>\n <vxe-table-column field=\"unitName\" title=\"规格\">\n <template #default=\"{ row }\">\n {{ row.unitName }};{{ row.skuName }}\n </template>\n </vxe-table-column>\n <vxe-table-column field=\"documentInventoryNum\" title=\"账面库存\">\n <template #default=\"{ row }\">\n {{ $_common.formatNub(row.documentInventoryNum) }}\n </template>\n </vxe-table-column>\n <vxe-table-column\n v-if=\"enableLocationManagement === 5\"\n field=\"storageLocationName\"\n title=\"库区库位\"\n >\n <template #default=\"{ row, rowIndex }\">\n <vxe-input\n v-model=\"row.storageLocationName\"\n placeholder=\"库区库位\"\n >\n <template #suffix>\n <i\n class=\"el-input__icon el-icon-search\"\n @click=\"storageShow(row, rowIndex)\"\n ></i>\n </template>\n </vxe-input>\n </template>\n </vxe-table-column>\n <vxe-table-column\n field=\"currentInventoryNum\"\n title=\"实盘库存\"\n :edit-render=\"{\n name: '$input',\n props: { type: 'float', digits: 2, min: 0 },\n }\"\n ></vxe-table-column>\n <vxe-table-column\n field=\"otherNum\"\n title=\"其他单位\"\n :edit-render=\"{\n name: '$input',\n props: { type: 'float', digits: 2, min: 0 },\n }\"\n ></vxe-table-column>\n <vxe-table-column field=\"diffNum\" title=\"盈亏数量\">\n <template #default=\"{ row }\">\n <span\n class=\"diff-num\"\n :class=\"[row.diffNum < 0 ? 'jian-num' : '']\"\n >\n {{ row.diffNum > 0 ? \"+\" : \"\" }}{{ row.diffNum }}\n </span>\n </template>\n </vxe-table-column>\n <vxe-table-column\n field=\"remark\"\n title=\"备注\"\n :edit-render=\"{\n name: 'input',\n placeholder: '说点什么吧',\n attrs: { type: 'text' },\n }\"\n ></vxe-table-column>\n <vxe-table-column width=\"80\" title=\"操作\">\n <template #default=\"{ row, rowIndex }\">\n <el-button\n type=\"text\"\n size=\"mini\"\n @click=\"delData(rowIndex, row)\"\n >\n 删除\n </el-button>\n </template>\n </vxe-table-column>\n </vxe-table>\n <div class=\"clearfix other-price-view\">\n <div class=\"float_left\">\n <el-form-item label=\"备注:\">\n <el-input\n v-model=\"form_data.remark\"\n style=\"width: 360px\"\n placeholder=\"备注\"\n ></el-input>\n </el-form-item>\n </div>\n </div>\n </div>\n </el-form>\n </div>\n <AllocateGoodsList\n v-if=\"show_selgoods\"\n :is-show=\"show_selgoods\"\n :warehouse-id=\"form_data.warehouseId\"\n @cancel=\"show_selgoods = false\"\n @confirm=\"selMoreGoods\"\n ></AllocateGoodsList>\n <!-- 选择仓库-->\n <WarehouseModel\n v-if=\"warehouse_show\"\n :is-check=\"false\"\n :is-show=\"warehouse_show\"\n @confirm=\"selWarehouse\"\n @cancel=\"warehouse_show = false\"\n />\n <!-- 库区库位-->\n <CallInLocation\n v-if=\"storage_show\"\n :is-check=\"false\"\n :is-show=\"storage_show\"\n :warehouse-id=\"form_data.warehouseId\"\n :sku-id=\"skuId\"\n :materiel-id=\"materielId\"\n @confirm=\"selStorage\"\n @cancel=\"storage_show = false\"\n />\n </ContainerTit>\n</template>\n\n<script>\n import AllocateGoodsList from \"@/component/goods/AllocateGoodsList.vue\";\n import WarehouseModel from \"@/component/common/WarehouseModel.vue\";\n import CallInLocation from \"@/component/common/CallInLocation\";\n import { addPauseSave, getPauseSave, delPauseSave } from \"@/api/common\";\n import {\n addStocktaking,\n updateStocktaking,\n getStocktakingInfo,\n } from \"@/api/Stock\";\n import { mapGetters } from \"vuex\";\n export default {\n name: \"PurchaseOrderAdd\",\n components: {\n AllocateGoodsList,\n WarehouseModel,\n CallInLocation,\n },\n data() {\n const validateWarehouse = (rule, value, callback) => {\n if (!value) {\n callback(new Error(\"请选择仓库\"));\n } else {\n callback();\n }\n };\n return {\n skuId: \"\",\n materielId: \"\",\n row_index: \"\",\n storage_show: false,\n loading: false,\n createTime: \"\",\n no: \"\",\n del_goods_id: [],\n form_data: {\n warehouseId: \"\",\n warehouseName: \"\",\n operatorName: \"\",\n remark: \"\",\n stocktakingTime: \"\",\n details: [],\n },\n fromWarehouse: \"\",\n rules: {\n warehouseId: [{ required: true, validator: validateWarehouse }],\n },\n warehouse_show: false,\n invenrory_id: \"\", // 盘点单id\n show_selgoods: false,\n goods_list: [],\n look_path: \"\",\n activeName: \"one\",\n };\n },\n computed: {\n plus_goods() {\n let num = 0;\n this.goods_list.forEach((item) => {\n if (item.diffNum > 0) {\n num++;\n }\n });\n return num;\n },\n plus_num() {\n let num = 0;\n this.goods_list.forEach((item) => {\n if (item.diffNum > 0) {\n num = num + Number(item.diffNum);\n }\n });\n return num;\n },\n diff_goods() {\n let num = 0;\n this.goods_list.forEach((item) => {\n if (item.diffNum < 0) {\n num++;\n }\n });\n return num;\n },\n diff_num() {\n let num = 0;\n this.goods_list.forEach((item) => {\n if (item.diffNum < 0) {\n num = num + Number(item.diffNum);\n }\n });\n return num;\n },\n ...mapGetters({\n enableLocationManagement: \"MUser/enableLocationManagement\",\n }),\n },\n created() {\n this.look_path = this.$route.name;\n if (this.$route.params.id) {\n this.invenrory_id = this.$route.params.id;\n this.getStocktakingInfo();\n } else {\n this.form_data.operatorName = this.userName;\n this.form_data.stocktakingTime = new Date().getTime();\n this.createTime = new Date().getTime();\n this.getPauseSave();\n }\n },\n methods: {\n // 选择仓库\n selWarehouse(val) {\n const row = val[0];\n this.fromWarehouse = row.warehouseName;\n this.form_data.warehouseId = row.id;\n this.form_data.warehouseName = row.warehouseName;\n this.goods_list = [];\n },\n // 新增暂存\n async addPauseSave() {\n const details = this.$_common.deepClone(this.goods_list).map((item) => {\n return item;\n });\n let params = {\n ...this.form_data,\n warehouseName: this.fromWarehouse,\n stocktakingTime: parseInt(this.form_data.stocktakingTime / 1000),\n details: details,\n };\n let target = {};\n this.loading = true;\n const data = await addPauseSave({\n key: this.look_path,\n data: params,\n });\n this.loading = false;\n\n await this.$message({\n type: \"success\",\n message: \"暂存成功\",\n });\n if (this.systemType === 2) {\n await this.$closeCurrentGoEdit(\n \"/SingleStore/Inventory/InventoryCheck\"\n );\n } else {\n await this.$closeCurrentGoEdit(\n \"/stock/WarehouseManagement/inventoryInfo\"\n );\n }\n },\n // 获取暂存信息\n async getPauseSave() {\n const { data } = await getPauseSave({\n key: this.look_path,\n });\n\n if (JSON.stringify(data) === \"{}\") return;\n this.form_data = {\n warehouseId: data.warehouseId,\n warehouseName: data.warehouseName,\n operatorName: data.operatorName,\n remark: data.remark,\n stocktakingTime: data.stocktakingTime,\n details: data.details,\n };\n this.no = data.no;\n this.form_data.stocktakingTime = data.stocktakingTime * 1000;\n // this.createTime = data.createTime * 1000\n this.fromWarehouse = data.warehouseName;\n this.goods_list = data.details.map((item) => {\n return {\n id: item.id,\n materielId: item.materielId,\n materielName: item.materielName,\n materielCode: item.materielCode,\n skuId: item.skuId,\n skuName: item.skuName,\n unitName: item.unitName,\n diffNum: item.diffNum,\n remark: item.remark,\n costUnitPrice: item.costUnitPrice || 0,\n documentInventoryNum: item.documentInventoryNum, // 账面库存\n currentInventoryNum: item.currentInventoryNum, // 实盘库存\n otherNum: item.otherNum, // 其他单位\n areaId: item.areaId,\n areaName: item.areaName,\n areaCode: item.areaCode,\n storageLocationName: item.storageLocationName,\n storageLocationId: item.storageLocationId,\n storageLocationCode: item.storageLocationCode,\n };\n });\n },\n // 清除暂存\n async delPauseSave(type) {\n const data = delPauseSave({\n key: this.look_path,\n });\n\n if (type) {\n this.$message({\n type: \"success\",\n message: \"清除暂存成功\",\n });\n this.$baseEventBus.$emit(\"reloadRouterView\");\n }\n },\n // 点击保存按钮\n async addPurchaseOrder() {\n this.$refs[\"form\"].validate(async (valid) => {\n if (valid) {\n if (!this.goods_list.length) {\n this.$message.warning(`请选择盘点商品`);\n return;\n }\n let issub = true;\n for (let i in this.goods_list) {\n let item = this.goods_list[i];\n if (Number(item.documentInventoryNum) === 0) {\n this.$message.warning(\n `第【${Number(i) + 1}】条数据,账面库存为0,无法保存`\n );\n issub = false;\n break;\n }\n // if (\n // this.enableLocationManagement === 5 &&\n // !item.storageLocationName\n // ) {\n // issub = false;\n // this.$message.warning(\n // `第【${Number(i) + 1}】条数据,未选择库区库位`\n // );\n // break;\n // }\n }\n if (!issub) {\n return;\n }\n const details = this.$_common\n .deepClone(this.goods_list)\n .map((item) => {\n delete item.diffNum;\n return item;\n });\n let params = {\n ...this.form_data,\n stocktakingTime: parseInt(this.form_data.stocktakingTime / 1000),\n details: details,\n };\n try {\n this.loading = true;\n if (!this.invenrory_id) {\n // 添加\n const data = await addStocktaking(params);\n } else {\n // 编辑\n params.deleteArray = this.del_goods_id;\n const data = await updateStocktaking(this.invenrory_id, params);\n }\n this.loading = false;\n await this.$message({\n type: \"success\",\n message: \"提交成功\",\n });\n await this.delPauseSave();\n if (this.systemType === 2) {\n await this.$closeCurrentGoEdit(\n \"/SingleStore/Inventory/InventoryCheck\"\n );\n } else {\n await this.$closeCurrentGoEdit(\n \"/stock/WarehouseManagement/inventoryInfo\"\n );\n }\n } finally {\n this.loading = false;\n }\n }\n });\n },\n // 获取详情 getStocktakingInfo\n async getStocktakingInfo() {\n const { data } = await getStocktakingInfo(this.invenrory_id);\n\n this.form_data = {\n warehouseId: data.warehouseId,\n warehouseName: data.warehouseName,\n operatorName: data.operatorName,\n remark: data.remark,\n stocktakingTime: data.stocktakingTime,\n details: data.details,\n };\n this.no = data.no;\n this.form_data.stocktakingTime = data.stocktakingTime * 1000;\n this.createTime = data.createTime * 1000;\n this.fromWarehouse = data.warehouseName;\n this.goods_list = data.details.map((item) => {\n return {\n id: item.id,\n materielId: item.materielId,\n materielName: item.materielName,\n materielCode: item.materielCode,\n skuId: item.skuId,\n skuName: item.skuName,\n unitName: item.unitName,\n diffNum:\n item.differenceStatus === 4\n ? 0 - item.differenceNum\n : item.differenceNum - 0,\n remark: item.remark,\n costUnitPrice: item.costUnitPrice || 0,\n documentInventoryNum: item.documentInventoryNum, // 账面库存\n currentInventoryNum: item.currentInventoryNum, // 实盘库存\n otherNum: item.otherNum, // 其他单位\n areaId: item.areaId,\n areaName: item.areaName,\n areaCode: item.areaCode,\n storageLocationName: item.storageLocationName,\n storageLocationId: item.storageLocationId,\n storageLocationCode: item.storageLocationCode,\n };\n });\n },\n // 删除\n delData(index, row) {\n this.$confirm(\"请确认是否删除该商品?\", \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n }).then(() => {\n if (row.id) {\n this.del_goods_id.push(row.id);\n }\n this.goods_list.splice(index, 1);\n this.$message({\n type: \"success\",\n message: \"删除成功!\",\n });\n });\n },\n // 改变数量\n editNumChange({ row, rowIndex }) {\n this.goods_list[rowIndex].diffNum = this.$NP.minus(\n row.currentInventoryNum,\n row.documentInventoryNum\n );\n },\n // 选择商品goodData的数据\n selMoreGoods(val) {\n const goodsData = val.map((item) => {\n return {\n isEq: item.isEq,\n otherNum: item.otherNum,\n materielId: item.materielId,\n materielName: item.materielName,\n materielCode: item.materielCode,\n skuId: item.skuId,\n skuName: item.skuName,\n unitName: item.unitName,\n diffNum: 0,\n remark: \"\",\n costUnitPrice: item.costPrice,\n documentInventoryNum: item.allNum, // 账面库存\n currentInventoryNum: item.inventoryNum, // 实盘库存\n areaId: \"\",\n areaName: \"\",\n areaCode: \"\",\n storageLocationName: \"\",\n storageLocationId: \"\",\n storageLocationCode: \"\",\n };\n });\n if (this.goods_list.length) {\n this.goods_list = this.$_common.unique(\n this.goods_list.concat(goodsData),\n [\"materielId\", \"skuId\"]\n );\n } else {\n this.goods_list = goodsData;\n }\n },\n // 合计\n getSummaries(param) {\n return this.$_common.getSummaries(param, [\"实盘库存\", \"盈亏数量\"]);\n },\n objectSpanMethod({ columns, data }) {\n const properties = [\n \"materielName\",\n \"materielCode\",\n \"skuName\",\n \"unitName\",\n \"remark\",\n \"diffNum\",\n \"storageLocationName\",\n ];\n return this.$_common.getSummariesVxe(columns, data, properties);\n },\n // 选择库区库位\n selStorage(e) {\n const target = this.$_common.deepClone(this.goods_list);\n target[this.row_index] = {\n ...target[this.row_index],\n areaId: e[0].areaId,\n areaName: e[0].areaName,\n areaCode: e[0].areaCode,\n storageLocationName: e[0].storageLocationName,\n storageLocationId: e[0].storageLocationId,\n storageLocationCode: e[0].storageLocationCode,\n };\n this.goods_list = target;\n },\n storageShow(row, rowIndex) {\n this.row_index = rowIndex;\n this.materielId = row.materielId;\n this.skuId = row.skuId;\n this.storage_show = true;\n },\n },\n };\n</script>\n\n<style lang=\"scss\" scoped>\n .width240 {\n width: 240px;\n }\n .other-price-view {\n padding: 10px 10px 0;\n border: 1px solid #ecf0f7;\n border-top: 0;\n }\n .diff-num {\n font-weight: bold;\n color: #36c1a0;\n }\n .jian-num {\n color: #e84960;\n }\n .order_bottom {\n position: relative;\n border-top: 16px solid #f6f8f9;\n width: 100%;\n background-color: #ffffff;\n border-radius: 3px;\n .text {\n font-size: 16px;\n font-weight: 600;\n color: #2d405e;\n line-height: 64px;\n padding: 0px 24px;\n }\n .order_bottom_btn {\n position: absolute;\n top: 15px;\n right: 20px;\n }\n }\n .order_midden_left_text {\n font-weight: bold;\n font-size: 16px;\n margin: 0 0 27px 0;\n }\n .form {\n padding-left: 40px;\n font-size: 14px;\n margin-bottom: 19px;\n .form_left {\n margin-right: 32px;\n color: #62738e;\n font-weight: 400;\n }\n .form_right {\n color: #2d405e;\n font-weight: 500;\n }\n }\n .btn-top-div {\n position: absolute;\n right: 20px;\n top: 15px;\n z-index: 999;\n }\n .Enunciate {\n width: 100%;\n height: 72px;\n color: #fff;\n font-size: 16px;\n line-height: 40px;\n padding: 16px 24px;\n border-top: 1px solid #dee2ee;\n .Enunciate_cont {\n background-color: #fa6400;\n border-radius: 3px;\n padding: 0 24px;\n }\n }\n</style>\n<style>\n .AddInventoryInfo {\n background-color: #fff;\n }\n .AddInventoryInfo .el-tabs__item {\n font-size: 16px !important;\n height: 60px !important;\n line-height: 60px !important;\n }\n .AddInventoryInfo .is-active {\n font-weight: 700;\n color: #000;\n }\n .AddInventoryInfo .el-tabs__nav {\n margin-left: 24px;\n }\n</style>\n"]}]}