534ce87ddd36243e7a87a1e3929a40a1.json 71 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\\Finance\\Receivable\\AddReceipt.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\src\\views\\Finance\\Receivable\\AddReceipt.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 Receivable from "@/component/Finance/Receivable";
import AccountType from "../AccountType";
import { getAllPayment } from "@/api/System";
import { getCustomerInfo } from "@/api/Customer";
import { addFinanceType, editFinanceType, getReceivedInfo, addReceived, editReceived, getTempReceivedData, getAllFinanceTypeNoPage, getReceiveInfo, getAllReceive, editPaid, addPaid } from "@/api/Finance";
import SelectShop from "@/component/goods/SelectShop.vue";
import SelectCustomer from "@/component/common/SelectCustomer.vue";
export default {
  name: "AddReceipt",
  components: {
    Receivable,
    AccountType,
    SelectCustomer,
    SelectShop
  },

  data() {
    const validateName = (rule, value, callback) => {
      if (!value) {
        callback(new Error("请选择收款单位"));
      } else {
        callback();
      }
    };

    const validateNo = (rule, value, callback) => {
      if (!value) {
        callback(new Error("请选择原单据号"));
      } else {
        callback();
      }
    };

    const validateShopName = (rule, value, callback) => {
      if (!value) {
        callback(new Error("请选择店铺"));
      } else {
        callback();
      }
    };

    return {
      tableData: [],
      // 新增财务类型
      form_type: [{
        label: "应收单",
        value: 1
      }, {
        label: "应付单",
        value: 2
      }],
      show_model: false,
      add_form: {
        name: "",
        link: "",
        isDefault: 4,
        enableStatus: 5
      },
      add_rule: {
        name: [{
          required: true,
          message: "请输入类型名称"
        }],
        link: [{
          required: true,
          message: "请选择归属单据"
        }]
      },
      loading: false,
      account_index: 0,
      financeTypeList: [],
      pay_type_list: [],
      code: "",
      account_show: false,
      receivable_show: false,
      no: "",
      form: {
        customerId: "",
        customerName: "",
        sourceNo: "",
        sourceNoMoney: "",
        currentAccountName: "",
        financeType: "",
        financeTypeId: "",
        shopId: "",
        money: "",
        shopName: "",
        receiptTime: "",
        createTime: "",
        accountList: [{
          accountId: "",
          accountNumber: "",
          accountName: "",
          money: "",
          discountMoney: "",
          finalMoney: "",
          payWay: "",
          remark: ""
        }]
      },
      rules: {
        customerName: [{
          required: true,
          validator: validateName
        }],
        sourceNo: [{
          required: true,
          validator: validateNo
        }],
        shopName: [{
          required: true,
          validator: validateShopName
        }]
      },
      account_id: "",
      isLook: false,
      isEdit: false,
      show_shop: false,
      choose_data: [],
      check_money: 0,
      // 勾选后合计
      id: "",
      time: "",
      delAccountList: [],
      flag: false,
      activeName: "one"
    };
  },

  computed: {
    // 核销总金额
    total() {
      if (!this.form.accountList.length) {
        return 0;
      } else if (this.form.accountList.length === 1) {
        return Number(this.form.accountList[0].money);
      } else {
        let sum = 0;
        this.form.accountList.forEach(item => {
          sum = this.$NP.plus(sum, Number(item.money));
        });
        return sum;
      }
    },

    // 收款总金额
    moneyTotal() {
      if (!this.form.accountList.length) {
        return 0;
      } else if (this.form.accountList.length === 1) {
        return this.$NP.minus(Number(this.form.accountList[0].money), Number(this.form.accountList[0].discountMoney));
      } else {
        let sum = 0;
        this.form.accountList.forEach(item => {
          const money = this.$NP.minus(Number(item.money), Number(item.discountMoney));
          sum = this.$NP.plus(sum, money);
        });
        return sum;
      }
    },

    // 核销总金额
    offSetTotal() {
      if (!this.choose_data.length) {
        return 0;
      } else if (this.choose_data.length === 1) {
        return Number(this.choose_data[0].offsetMoney);
      } else {
        let sum = 0;
        this.choose_data.forEach(item => {
          sum = this.$NP.plus(sum, Number(item.offsetMoney));
        });
        return sum;
      }
    },

    // 未核销总金额
    offSetNotTotal() {
      if (!this.tableData.length) {
        return 0;
      } else if (this.tableData.length === 1) {
        return Number(this.tableData[0].offsetMoney);
      } else {
        let sum = 0;
        this.tableData.forEach(item => {
          sum = this.$NP.plus(sum, Number(item.offsetMoney));
        });
        return sum;
      }
    }

  },

  created() {
    this.initial();
  },

  activated() {
    if (this.$_isInit()) return;
    this.initial();
  },

  methods: {
    // 初始化
    async initial() {
      await this.getAllFinanceType();
      await this.getAllPayment();
      this.isLook = this.$route.path.indexOf("LookReceipt") > -1;
      this.isEdit = this.$route.path.indexOf("editReceipt") > -1; // 收款人默认当前账户

      this.form.currentAccountName = this.userName;

      if (this.$route.params.createTime) {
        this.form.createTime = this.$route.params.createTime;
      }

      if (this.$route.params.id) {
        // 编辑收款单
        this.account_id = this.$route.params.id; //  获取详情 收款单详情

        await this.getReceivedInfo();
      } else if (this.$route.query.id) {
        // 从应收单点击收款按钮进来 新增收款单
        //  获取应收单详情
        this.id = this.$route.query.id;
        this.time = this.$route.query.createTime;
        await this.getReceiveInfo();
      } else {
        // 新增收款单
        await this.getTempReceivedData(); // 获取暂存数据
      }

      if (this.$route.query.customerId) {
        await this.getCustomerInfo(this.$route.query.customerId);
      }

      this.form.receiptTime = new Date().getTime();
    },

    goOtherDetail(orderId) {
      this.$router.push("/order/manageO/OrderDetails/1/" + orderId);
    },

    // 批量选择
    selectionChange(val) {
      this.choose_data = val;
      let num = 0;
      this.choose_data.forEach(item => {
        num += Number(item.offsetMoney);
      }); // console.log("勾选余额", num);

      this.check_money = num;
    },

    // 获取应收单详情
    async getReceiveInfo(obj) {
      const {
        data
      } = await getReceiveInfo({
        id: this.id,
        createTime: this.time
      });
      this.id = data.id;
      this.form.customerId = data.customerId;
      this.form.customerName = data.customerName;
      this.form.sourceNo = data.no;
      this.form.sourceNoMoney = data.receiveMoney;
      this.form.shopName = data.shopName;
      this.form.shopId = data.shopId;

      if (data.receiptTypeId === 6) {
        const finance = this.financeTypeList.find(item => {
          return item.name === "销售退货退款";
        });
        this.form.financeTypeId = finance.id;
        this.form.financeType = finance.name;
      }

      this.form.accountList = [{
        accountId: 0,
        accountNumber: "",
        accountName: "",
        money: data.receiveMoney,
        discountMoney: "",
        finalMoney: "",
        payWay: "",
        remark: ""
      }];
      this.tableData = [{ ...data,
        offsetMoney: Number(data.notOffsetMoney)
      }]; // 在应收单列表点击收款按钮打开的新增收款单页面，核销明细自动核销。

      setTimeout(() => {
        this.offsetGet();
      }, 200); // await this.getCustomerInfo(data.customerId);
    },

    // 获取客户详情
    async getCustomerInfo(id) {
      const {
        data
      } = await getCustomerInfo(id);
      this.form.money = data.money || 0;
      this.form.customerId = data.id;
      this.form.customerName = data.name;
      await this.getAllReceive();
    },

    //  应收单列表
    async getAllReceive() {
      let params = {
        page: 1,
        pageSize: 999,
        customerId: this.form.customerId,
        offsetStatus: [3, 4],
        moneyType: 1 // auditStatus: 2,
        // financeTypeId: this.form.financeTypeId,

      };
      const {
        data
      } = await getAllReceive(params);
      this.tableData = data.map(item => {
        return { ...item,
          offsetMoney: Number(item.notOffsetMoney)
        };
      });
    },

    // 新增财务类型
    async addType() {
      this.$refs["form"].validate(async valid => {
        if (valid) {
          let target = {};

          if (!this.is_edit) {
            target = await addFinanceType({ ...this.add_form
            });
          } else {
            target = await editFinanceType(this.pay_id, { ...this.add_form
            });
          }

          const data = target;
          this.show_model = false;
        }
      });
    },

    // 选择商铺
    selShop(val, row) {
      this.form.shopName = row[0].name; // this.form.shopId = row[0].id
    },

    receivablesel(val) {
      this.form.sourceNo = val[0].no;
      this.form.sourceNoMoney = val[0].receiveMoney;
      this.form.shopName = val[0].shopName;
      this.form.shopId = val[0].shopId;
    },

    //  收款单详情
    async getReceivedInfo() {
      const {
        data
      } = await getReceivedInfo({
        id: this.account_id,
        createTime: this.form.createTime
      });
      this.form = { ...data,
        receiptTime: data.receiptTime * 1000,
        accountList: data.accountList
      };

      if (data.offsetDate) {
        this.tableData = data.offsetDate;
        this.choose_data = data.offsetDate;
        setTimeout(() => {
          this.tableData.forEach(item => {
            if (item.offsetMoney > 0) {
              this.$refs.multipleTable.toggleRowSelection(item);
            }
          });
        }, 200);
      }
    },

    // 暂存数据
    async temData(tempSave) {
      let receiptOffsetData = this.choose_data.map(item => {
        return {
          receiveReceiptId: item.id,
          offsetMoney: item.offsetMoney
        };
      });
      const params = { ...this.form,
        receiptTime: parseInt(this.form.receiptTime / 1000),
        tempSave: tempSave,
        receiptOffsetData: receiptOffsetData
      };
      this.loading = true;
      const data = await addReceived(params);
      this.loading = false;
      this.$message({
        message: "暂存成功",
        type: "success"
      });
      this.$closeCurrentGoEdit("/Finance/Receivable/ReceiptList");
    },

    //  添加
    async addData(tempSave) {
      this.$refs["base_form"].validate(async valid => {
        if (valid) {
          if (!tempSave) {
            if (this.flag) {
              this.form.accountList = [...this.form.accountList, ...this.delAccountList];
            }

            let isSub = true;

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

              if (!item.accountId) {
                isSub = false;
                this.$message.warning("请选择结算账户");
                break;
              }

              if (!item.money) {
                isSub = false;
                this.$message.warning("请输入收款金额");
                break;
              }
              /* if (!item.payWay) {
                isSub = false;
                this.$message.warning("请选择结算方式");
                break;
              }*/


              if (this.offSetTotal > this.total) {
                isSub = false;
                this.$message.warning("核销金额不能大于收款金额");
                break;
              }
            }

            if (!isSub) {
              return;
            }
          }

          if (this.choose_data.length) {
            let receiptOffsetData = this.choose_data.map(item => {
              return {
                receiveReceiptId: item.id,
                offsetMoney: item.offsetMoney,
                receiveCreateTime: item.createTime
              };
            });
            const params = { ...this.form,
              receiptTime: parseInt(this.form.receiptTime / 1000),
              tempSave: tempSave,
              receiptOffsetData: receiptOffsetData,
              sourceId: this.id
            };
            this.loading = true;

            try {
              if (this.account_id) {
                const data = await editReceived(this.account_id, params);
              } else {
                const data = await addReceived(params);
              }

              this.loading = false;
              this.$message({
                type: "success",
                message: "操作成功!"
              });
              this.$closeCurrentGoEdit("/Finance/Receivable/ReceiptList");
            } catch {
              this.loading = false;
            }
          } else {
            if (this.form.financeTypeId === 1) {
              this.form.financeType = "销售退货退款";
            }

            if (this.form.financeTypeId === 2) {
              this.form.financeType = "销售收款";
            }

            if (this.form.financeTypeId === 3) {
              this.form.financeType = "预存收款";
            }

            const form = this.$_common.deepClone(this.form);
            delete form.sourceNo;
            const params = { ...form,
              receiptTime: parseInt(this.form.receiptTime / 1000),
              tempSave: tempSave,
              financeTypeId: this.form.financeTypeId,
              financeType: this.form.financeType
            };
            this.$confirm("确定要将该单据作为预收款吗？", "提示", {
              confirmButtonText: "确定",
              cancelButtonText: "取消",
              type: "warning"
            }).then(async () => {
              this.loading = true;

              try {
                if (this.account_id) {
                  const data = await editReceived(this.account_id, params);
                } else {
                  const data = await addReceived(params);
                }

                this.loading = false;
                this.$message({
                  type: "success",
                  message: "操作成功!"
                });
                this.$closeCurrentGoEdit("/Finance/Receivable/ReceiptList");
              } catch {
                this.loading = false;
              }
            }).catch(() => {
              this.loading = false;
            });
          }
        }
      });
    },

    //  获取暂存数据
    async getTempReceivedData() {
      const {
        data
      } = await getTempReceivedData();
      if (JSON.stringify(data) === "{}") return;
      this.form = { ...data,
        receiptTime: data.receiptTime * 1000,
        accountList: data.accountList.map(item => {
          return { ...item,
            payWay: parseInt(item.payWay)
          };
        })
      };

      if (data.offsetDate) {
        this.tableData = data.offsetDate;
        this.choose_data = data.offsetDate;
        setTimeout(() => {
          this.tableData.forEach(item => {
            this.$refs.multipleTable.toggleRowSelection(item);
          });
        }, 200);
      }
    },

    openAccount(index) {
      this.account_index = index;

      if (this.form.shopId) {
        this.account_show = true;
      } else {
        this.$message.warning("请选择所属店铺");
      }
    },

    // 结算账户
    accountsel(val) {
      this.form.accountList[this.account_index].accountId = val[0].id;
      this.form.accountList[this.account_index].accountNumber = val[0].accountNumber;
      this.form.accountList[this.account_index].accountName = val[0].name;
    },

    // 类型
    typeChange(val) {
      const target = this.financeTypeList.find(item => {
        return item.id === val;
      });
      this.form.financeType = target.name;
    },

    //  获取财务类型
    async getAllFinanceType() {
      const {
        data
      } = await getAllFinanceTypeNoPage(1);
      this.financeTypeList = data;
      const finance = data.find(item => {
        return item.name === "销售收款";
      });
      this.form.financeTypeId = finance.id;
      this.form.financeType = finance.name;
    },

    addAccount() {
      this.form.accountList.push({
        accountId: "",
        accountNumber: "",
        accountName: "",
        money: "",
        discountMoney: "",
        finalMoney: "",
        payWay: "",
        remark: ""
      });
    },

    delAccount(index) {
      if (this.account_id) {
        this.flag = true;

        if (this.form.accountList[index].accountId && this.form.accountList[index].money) {
          this.form.accountList[index].deleteStatus = 4;
          this.delAccountList.push(this.form.accountList[index]);
        }
      }

      console.log(this.delAccountList);
      this.form.accountList.splice(index, 1);
    },

    // 获取支付方式
    async getAllPayment() {
      const data = await getAllPayment({
        page: 1,
        pageSize: 99
      });
      this.pay_type_list = data.data;
    },

    //  客户选择
    customerSel(val, row) {
      this.form.customerId = row[0].id;
      this.form.money = row[0].money;
      this.form.sourceNo = "";
      this.form.shopName = row[0].shopName;
      this.form.shopId = row[0].shopId || "";
      this.getAllReceive();
    },

    // 自动核销
    offsetGet() {
      let total = 0;

      for (let i = 0; i < this.tableData.length; i++) {
        let item = this.tableData[i]; // 把本次核销金额相加

        total += Number(item.offsetMoney); // 勾选可以核销的数据

        this.$refs.multipleTable.toggleRowSelection(item); // 如果合计核销金额大于收款总金额，停止循环，并把停止循环前的一条核销数据修改为差值

        if (total > this.moneyTotal || total === this.moneyTotal) {
          item.offsetMoney = this.moneyTotal - (total - item.offsetMoney);
          break;
        }
      }
    },

    // 收款金额失去焦点
    moneyBlur() {
      // 收款金额失去焦点后自动核销
      this.offsetGet(); // 收款金额失去焦点后重新核销
      // this.$refs.multipleTable.clearSelection();
    }

  }
};"},{"version":3,"mappings":"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QACA,iCAFA,CAEA;MACA;;MAEA;QACA;MACA;;MACA;IACA,CAhCA;;IAiCAC;MACA;IACA,CAnCA;;IAoCA;IACAC;MACA;MACA;MACA;QACAC;MACA,CAFA,EAHA,CAMA;;MACA;IACA,CA7CA;;IA8CA;IACA;MACA;QAAApE;MAAA;QACAmD,WADA;QAEAjB;MAFA;MAIA;MACA;MACA;MAEA;MACA;MAEA;MACA;;MACA;QACA;UACA;QACA,CAFA;QAGA;QACA;MACA;;MACA,yBACA;QACAE,YADA;QAEAC,iBAFA;QAGAC,eAHA;QAIAP,wBAJA;QAKAQ,iBALA;QAMAC,cANA;QAOAC,UAPA;QAQAC;MARA,CADA;MAYA,kBACA,EACA,OADA;QAEA2B;MAFA,CADA,EAjCA,CAuCA;;MACAC;QACA;MACA,CAFA,EAEA,GAFA,EAxCA,CA2CA;IACA,CA3FA;;IA4FA;IACA;MACA;QAAAtE;MAAA;MACA;MACA;MAEA;MACA;IACA,CApGA;;IAqGA;IACA;MACA;QACAuE,OADA;QAEAC,aAFA;QAGAjD,gCAHA;QAIAkD,oBAJA;QAKAC,YALA,CAMA;QACA;;MAPA;MASA;QAAA1E;MAAA;MACA;QACA;UAAAqE;QAAA;MACA,CAFA;IAGA,CApHA;;IAqHA;IACA;MACA;QACA;UACA;;UACA;YACAM,gCACA;YADA;UAGA,CAJA,MAIA;YACAA,8CACA;YADA;UAGA;;UACA;UAEA;QACA;MACA,CAhBA;IAiBA,CAxIA;;IAyIA;IACAC;MACA,iCADA,CAEA;IACA,CA7IA;;IA8IAC;MACA;MACA;MACA;MACA;IACA,CAnJA;;IAoJA;IACA;MACA;QAAA7E;MAAA;QACAmD,mBADA;QAEAjB;MAFA;MAKA,cACA,OADA;QAEAD,oCAFA;QAGAE;MAHA;;MAKA;QACA;QACA;QACAmC;UACA;YACA;cACA;YACA;UACA,CAJA;QAKA,CANA,EAMA,GANA;MAOA;IACA,CA3KA;;IA4KA;IACA;MACA;QACA;UACAQ,yBADA;UAEAT;QAFA;MAIA,CALA;MAMA,iBACA,YADA;QAEApC,mDAFA;QAGA8C,kBAHA;QAIAC;MAJA;MAMA;MACA;MACA;MAEA;QACAnE,eADA;QAEAoE;MAFA;MAIA;IACA,CAnMA;;IAoMA;IACA;MACA;QACA;UACA;YACA;cACA,yBACA,wBADA,EAEA,sBAFA;YAIA;;YACA;;YACA;cACA;;cACA;gBACAC;gBACA;gBACA;cACA;;cACA;gBACAA;gBACA;gBACA;cACA;cACA;AACA;AACA;AACA;AACA;;;cACA;gBACAA;gBACA;gBACA;cACA;YACA;;YACA;cACA;YACA;UACA;;UACA;YACA;cACA;gBACAJ,yBADA;gBAEAT,6BAFA;gBAGAc;cAHA;YAKA,CANA;YAOA,iBACA,YADA;cAEAlD,mDAFA;cAGA8C,kBAHA;cAIAC,oCAJA;cAKAI;YALA;YAOA;;YACA;cACA;gBACA;cACA,CAFA,MAEA;gBACA;cACA;;cACA;cACA;gBACAH,eADA;gBAEApE;cAFA;cAIA;YACA,CAZA,CAYA;cACA;YACA;UACA,CA/BA,MA+BA;YACA;cACA;YACA;;YACA;cACA;YACA;;YACA;cACA;YACA;;YACA;YACA;YACA,iBACA,OADA;cAEAoB,mDAFA;cAGA8C,kBAHA;cAIAlD,sCAJA;cAKAD;YALA;YAOA;cACAyD,uBADA;cAEAC,sBAFA;cAGAL;YAHA,GAKAM,IALA,CAKA;cACA;;cACA;gBACA;kBACA;gBACA,CAFA,MAEA;kBACA;gBACA;;gBACA;gBACA;kBACAN,eADA;kBAEApE;gBAFA;gBAIA;cACA,CAZA,CAYA;gBACA;cACA;YACA,CAtBA,EAuBA2E,KAvBA,CAuBA;cACA;YACA,CAzBA;UA0BA;QACA;MACA,CAnHA;IAoHA,CA1TA;;IA2TA;IACA;MACA;QAAAxF;MAAA;MAEA;MACA,cACA,OADA;QAEAiC,oCAFA;QAGAE;UACA,SACA,OADA;YAEAM;UAFA;QAIA,CALA;MAHA;;MAUA;QACA;QACA;QACA6B;UACA;YACA;UACA,CAFA;QAGA,CAJA,EAIA,GAJA;MAKA;IACA,CAnVA;;IAoVAmB;MACA;;MACA;QACA;MACA,CAFA,MAEA;QACA;MACA;IACA,CA3VA;;IA4VA;IACAC;MACA;MACA,0DACAC,oBADA;MAEA;IACA,CAlWA;;IAmWA;IACAC;MACA;QACA;MACA,CAFA;MAGA;IACA,CAzWA;;IA0WA;IACA;MACA;QAAA5F;MAAA;MAEA;MACA;QACA;MACA,CAFA;MAGA;MACA;IACA,CApXA;;IAqXA6F;MACA;QACAzD,aADA;QAEAC,iBAFA;QAGAC,eAHA;QAIAP,SAJA;QAKAQ,iBALA;QAMAC,cANA;QAOAC,UAPA;QAQAC;MARA;IAUA,CAhYA;;IAiYAoD;MACA;QACA;;QACA,IACA,0CACA,kCAFA,EAGA;UACA;UACA;QACA;MACA;;MACAC;MACA;IACA,CA9YA;;IA+YA;IACA;MACA;QACAxB,OADA;QAEAC;MAFA;MAKA;IACA,CAvZA;;IAwZA;IACAwB;MACA;MACA;MACA;MACA;MACA;MACA;IACA,CAhaA;;IAiaA;IACAC;MACA;;MACA;QACA,6BADA,CAEA;;QACAxC,kCAHA,CAIA;;QACA,kDALA,CAMA;;QACA;UACAyC;UACA;QACA;MACA;IACA,CAhbA;;IAibA;IACAC;MACA;MACA,iBAFA,CAGA;MACA;IACA;;EAvbA;AAlLA","names":["addFinanceType","editFinanceType","getReceivedInfo","addReceived","editReceived","getTempReceivedData","getAllFinanceTypeNoPage","getReceiveInfo","getAllReceive","editPaid","addPaid","name","components","Receivable","AccountType","SelectCustomer","SelectShop","data","callback","tableData","form_type","label","value","show_model","add_form","link","isDefault","enableStatus","add_rule","required","message","loading","account_index","financeTypeList","pay_type_list","code","account_show","receivable_show","no","form","customerId","customerName","sourceNo","sourceNoMoney","currentAccountName","financeType","financeTypeId","shopId","money","shopName","receiptTime","createTime","accountList","accountId","accountNumber","accountName","discountMoney","finalMoney","payWay","remark","rules","validator","account_id","isLook","isEdit","show_shop","choose_data","check_money","id","time","delAccountList","flag","activeName","computed","total","sum","moneyTotal","Number","offSetTotal","offSetNotTotal","created","activated","methods","goOtherDetail","selectionChange","num","offsetMoney","setTimeout","page","pageSize","offsetStatus","moneyType","target","selShop","receivablesel","receiveReceiptId","tempSave","receiptOffsetData","type","isSub","receiveCreateTime","sourceId","confirmButtonText","cancelButtonText","then","catch","openAccount","accountsel","val","typeChange","addAccount","delAccount","console","customerSel","offsetGet","item","moneyBlur"],"sourceRoot":"src/views/Finance/Receivable","sources":["AddReceipt.vue"],"sourcesContent":["<!--新增收款单-->\n<template>\n <ContainerTit class=\"AddReceipt\">\n <div class=\"page-tip-div\" style=\"margin: 0; position: relative\">\n 温馨提示:1、退款时在金额输入框输入负数即可!2、收款时,在金额输入框输入正数即可!3、客户给商家预付货款时,在新增选择单据类型为预存收款后不用选择原单据号即可创建!\n <div class=\"btn-top-div\">\n <el-button\n v-if=\"$accessCheck($Access.ReceiptListGetTempReceivedData)\"\n :loading=\"loading\"\n :disabled=\"isLook || isEdit\"\n @click=\"temData(true)\"\n >\n 暂存\n </el-button>\n <el-button\n v-if=\"!isLook\"\n type=\"primary\"\n :loading=\"loading\"\n @click=\"addData(false)\"\n >\n 保存并提交\n </el-button>\n </div>\n </div>\n <el-form\n ref=\"base_form\"\n label-width=\"120px\"\n :model=\"form\"\n size=\"small\"\n :rules=\"rules\"\n :disabled=\"isLook\"\n >\n <el-tabs v-model=\"activeName\">\n <el-tab-pane label=\"基础信息\" name=\"one\" style=\"position: relative\">\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 class=\"form\" :span=\"6\">\n <el-form-item\n label=\"收款单位\"\n prop=\"customerName\"\n style=\"min-width: 400px\"\n >\n <SelectCustomer\n v-model=\"form.customerName\"\n :clearable=\"false\"\n width=\"150\"\n @change=\"customerSel\"\n />\n <el-button\n size=\"mini\"\n type=\"text\"\n @click=\"$router.push('/Customer/CustomerAdmin/AddCustomer')\"\n >\n 【新建客户】\n </el-button>\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\">\n <el-form-item label=\"单据日期\" prop=\"brandId\">\n <template>\n <div class=\"block\">\n <el-date-picker\n v-model=\"form.receiptTime\"\n style=\"width: 210px\"\n type=\"date\"\n placeholder=\"选择日期\"\n value-format=\"timestamp\"\n ></el-date-picker>\n </div>\n </template>\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\">\n <el-form-item\n label=\"所属店铺\"\n prop=\"shopName\"\n style=\"min-width: 400px\"\n >\n <SelectShop\n v-model=\"form.shopId\"\n width=\"160\"\n :clearable=\"false\"\n placeholder=\"选择商铺\"\n @change=\"selShop\"\n />\n <el-button\n size=\"mini\"\n type=\"text\"\n @click=\"$router.push('/SystemSettings/liansuoguanli/AddShop')\"\n >\n 【新建商铺】\n </el-button>\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\">\n <el-form-item label=\"当前应收\" prop=\"money\">\n <el-input\n v-model=\"form.money\"\n disabled\n style=\"width: 210px\"\n placeholder=\"不可编辑\"\n ></el-input>\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\">\n <el-form-item label=\"业务类型\">\n <el-select\n v-model=\"form.financeTypeId\"\n style=\"width: 180px\"\n clearable\n placeholder=\"选择类型\"\n @change=\"typeChange\"\n >\n <el-option\n v-for=\"(item, index) in financeTypeList\"\n :key=\"index\"\n :label=\"item.name\"\n :value=\"item.id\"\n ></el-option>\n </el-select>\n <el-button\n v-if=\"financeTypeList.length === 0\"\n size=\"mini\"\n type=\"text\"\n @click=\"getAllFinanceType\"\n >\n 【刷新】\n </el-button>\n <el-button\n v-if=\"financeTypeList.length === 0\"\n size=\"mini\"\n type=\"text\"\n @click=\"show_model = true\"\n >\n 【新建类型】\n </el-button>\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\">\n <el-form-item label=\"收款人\">\n {{ form.currentAccountName }}\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-table :data=\"form.accountList\">\n <el-table-column prop=\"accountId\" label=\"结算账户\" min-width=\"160\">\n <template slot-scope=\"scope\">\n <el-input\n v-model=\"scope.row.accountName\"\n readonly\n style=\"width: 100%\"\n size=\"small\"\n placeholder=\"结算账户\"\n >\n <i\n slot=\"suffix\"\n class=\"el-input__icon el-icon-search\"\n @click=\"openAccount(scope.$index)\"\n ></i>\n </el-input>\n </template>\n </el-table-column>\n <el-table-column prop=\"money\" label=\"收款金额\" min-width=\"120\">\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.money\"\n :controls=\"false\"\n placeholder=\"收款金额\"\n size=\"small\"\n style=\"width: 100%\"\n :min=\"0\"\n @blur=\"moneyBlur\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"优惠金额\" min-width=\"120\">\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.discountMoney\"\n :controls=\"false\"\n placeholder=\"优惠金额\"\n style=\"width: 100%\"\n size=\"small\"\n :max=\"Number(scope.row.money)\"\n :min=\"0\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"实际收款金额\" min-width=\"120\" align=\"center\">\n <template slot-scope=\"scope\">\n {{\n $NP.minus(scope.row.money || 0, scope.row.discountMoney || 0)\n }}\n </template>\n </el-table-column>\n <el-table-column label=\"备注\" min-width=\"200\">\n <template slot-scope=\"scope\">\n <el-input\n v-model=\"scope.row.remark\"\n style=\"width: 100%\"\n size=\"small\"\n placeholder=\"备注\"\n ></el-input>\n </template>\n </el-table-column>\n <el-table-column\n prop=\"remark\"\n label=\"操作\"\n width=\"140\"\n align=\"center\"\n >\n <template slot-scope=\"scope\">\n <el-button\n :disabled=\"form.accountList.length === 1\"\n size=\"mini\"\n type=\"text\"\n @click=\"delAccount(scope.$index)\"\n >\n 删除\n </el-button>\n <!-- <el-button size=\"mini\" type=\"text\" @click=\"addAccount\">-->\n <!-- 新增-->\n <!-- </el-button>-->\n </template>\n </el-table-column>\n </el-table>\n <div class=\"table-b-div\">\n <div class=\"table-b-div-cont\" @click=\"addAccount\">\n <el-button type=\"text\" size=\"mini\" @click=\"addAccount\">\n <i class=\"el-icon-plus\"></i>\n 新增\n </el-button>\n </div>\n </div>\n </div>\n <div class=\"order_bottom\">\n <p class=\"text\">核销明细</p>\n <div class=\"Enunciate\">\n <div class=\"Enunciate_cont clearfix\">\n <div class=\"float_left\">\n <span>\n 未核销金额:{{ $_common.formattedNumber(offSetNotTotal) }}\n </span>\n <span style=\"margin: 0 20px\">\n 本次核销金额:{{ $_common.formattedNumber(offSetTotal) }}\n </span>\n <span>\n 核销差额:{{\n $_common.formattedNumber(offSetTotal - moneyTotal)\n }}\n </span>\n </div>\n <div class=\"float_right\">\n <el-button size=\"mini\" @click=\"offsetGet\">自动核销</el-button>\n </div>\n </div>\n </div>\n <el-table\n ref=\"multipleTable\"\n :data=\"tableData\"\n style=\"width: 100%\"\n @selection-change=\"selectionChange\"\n >\n <el-table-column\n type=\"selection\"\n width=\"55\"\n align=\"center\"\n fixed=\"left\"\n ></el-table-column>\n <el-table-column\n prop=\"receiptTypeId\"\n label=\"单据类型\"\n min-width=\"100\"\n >\n <template slot-scope=\"scope\">\n {{\n scope.row.receiptTypeId === 6\n ? \"销售退货单\"\n : scope.row.receiptTypeId === 1\n ? \"销售订单\"\n : \"\"\n }}\n </template>\n </el-table-column>\n <el-table-column\n prop=\"no\"\n label=\"单据编号\"\n min-width=\"140\"\n ></el-table-column>\n <el-table-column prop=\"address\" label=\"单据日期\" min-width=\"120\">\n <template slot-scope=\"scope\">\n {{ $_common.formatDate(scope.row.createTime) }}\n </template>\n </el-table-column>\n <el-table-column label=\"金额\" min-width=\"100\">\n <template slot-scope=\"scope\">\n {{ $_common.formattedNumber(scope.row.receiveMoney) }}\n </template>\n </el-table-column>\n <el-table-column prop=\"address\" label=\"未核销金额\" min-width=\"100\">\n <template slot-scope=\"scope\">\n {{ $_common.formattedNumber(scope.row.notOffsetMoney) }}\n </template>\n </el-table-column>\n <el-table-column prop=\"address\" label=\"本次核销金额\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.offsetMoney\"\n :controls=\"false\"\n placeholder=\"本次核销金额\"\n :max=\"Number(scope.row.notOffsetMoney)\"\n style=\"width: 100%\"\n size=\"small\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column\n show-overflow-tooltip\n prop=\"originNo\"\n label=\"销售订单号\"\n min-width=\"100\"\n >\n <template slot-scope=\"scope\">\n <span\n class=\"click-div\"\n @click=\"goOtherDetail(scope.row.originId)\"\n >\n {{ scope.row.originNo }}\n </span>\n </template>\n </el-table-column>\n <el-table-column\n prop=\"customerName\"\n label=\"往来单位名称\"\n min-width=\"100\"\n ></el-table-column>\n </el-table>\n </div>\n </el-form>\n <AccountType\n v-if=\"account_show\"\n :shop-id=\"form.shopId\"\n :is-check=\"false\"\n :is-show=\"account_show\"\n @cancel=\"account_show = false\"\n @confirm=\"accountsel\"\n />\n <Receivable\n v-if=\"receivable_show\"\n :id=\"form.customerId\"\n :is-check=\"false\"\n :is-show=\"receivable_show\"\n @cancel=\"receivable_show = false\"\n @confirm=\"receivablesel\"\n />\n <!-- 新增财务类型-->\n <el-dialog\n :close-on-press-escape=\"false\"\n :close-on-click-modal=\"false\"\n name=\"新增财务类型\"\n :visible.sync=\"show_model\"\n width=\"40%\"\n @close=\"show_model = false\"\n >\n <el-form\n ref=\"form\"\n :model=\"add_form\"\n :rules=\"add_rule\"\n size=\"small\"\n label-width=\"100px\"\n >\n <el-form-item label=\"类型\" prop=\"name\">\n <el-input\n v-model=\"add_form.name\"\n placeholder=\"请输入类型名称\"\n ></el-input>\n </el-form-item>\n <el-form-item label=\"归属单据\" prop=\"link\">\n <el-select v-model=\"add_form.link\" placeholder=\"请选择\">\n <el-option\n v-for=\"item in form_type\"\n :key=\"item.value\"\n :label=\"item.label\"\n :value=\"item.value\"\n ></el-option>\n </el-select>\n </el-form-item>\n <el-form-item label=\"是否默认\" prop=\"defaultStatus\">\n <el-switch\n v-model=\"add_form.isDefault\"\n :active-value=\"5\"\n :inactive-value=\"4\"\n ></el-switch>\n </el-form-item>\n <el-form-item label=\"是否禁用\" prop=\"enableStatus\">\n <el-radio-group v-model=\"add_form.enableStatus\">\n <el-radio :label=\"4\">是</el-radio>\n <el-radio :label=\"5\">否</el-radio>\n </el-radio-group>\n </el-form-item>\n </el-form>\n <span slot=\"footer\" class=\"dialog-footer\">\n <el-button size=\"small\" @click=\"show_model = false\">取 消</el-button>\n <el-button type=\"primary\" size=\"small\" @click=\"addType\">\n 确 定\n </el-button>\n </span>\n </el-dialog>\n </ContainerTit>\n</template>\n\n<script>\n import Receivable from \"@/component/Finance/Receivable\";\n import AccountType from \"../AccountType\";\n\n import { getAllPayment } from \"@/api/System\";\n import { getCustomerInfo } from \"@/api/Customer\";\n\n import {\n addFinanceType,\n editFinanceType,\n getReceivedInfo,\n addReceived,\n editReceived,\n getTempReceivedData,\n getAllFinanceTypeNoPage,\n getReceiveInfo,\n getAllReceive,\n editPaid,\n addPaid,\n } from \"@/api/Finance\";\n import SelectShop from \"@/component/goods/SelectShop.vue\";\n import SelectCustomer from \"@/component/common/SelectCustomer.vue\";\n export default {\n name: \"AddReceipt\",\n components: {\n Receivable,\n AccountType,\n SelectCustomer,\n SelectShop,\n },\n data() {\n const validateName = (rule, value, callback) => {\n if (!value) {\n callback(new Error(\"请选择收款单位\"));\n } else {\n callback();\n }\n };\n const validateNo = (rule, value, callback) => {\n if (!value) {\n callback(new Error(\"请选择原单据号\"));\n } else {\n callback();\n }\n };\n const validateShopName = (rule, value, callback) => {\n if (!value) {\n callback(new Error(\"请选择店铺\"));\n } else {\n callback();\n }\n };\n return {\n tableData: [],\n // 新增财务类型\n form_type: [\n {\n label: \"应收单\",\n value: 1,\n },\n {\n label: \"应付单\",\n value: 2,\n },\n ],\n show_model: false,\n add_form: {\n name: \"\",\n link: \"\",\n isDefault: 4,\n enableStatus: 5,\n },\n add_rule: {\n name: [{ required: true, message: \"请输入类型名称\" }],\n link: [{ required: true, message: \"请选择归属单据\" }],\n },\n loading: false,\n account_index: 0,\n financeTypeList: [],\n pay_type_list: [],\n code: \"\",\n account_show: false,\n receivable_show: false,\n no: \"\",\n form: {\n customerId: \"\",\n customerName: \"\",\n sourceNo: \"\",\n sourceNoMoney: \"\",\n currentAccountName: \"\",\n financeType: \"\",\n financeTypeId: \"\",\n shopId: \"\",\n money: \"\",\n shopName: \"\",\n receiptTime: \"\",\n createTime: \"\",\n accountList: [\n {\n accountId: \"\",\n accountNumber: \"\",\n accountName: \"\",\n money: \"\",\n discountMoney: \"\",\n finalMoney: \"\",\n payWay: \"\",\n remark: \"\",\n },\n ],\n },\n rules: {\n customerName: [{ required: true, validator: validateName }],\n sourceNo: [{ required: true, validator: validateNo }],\n shopName: [{ required: true, validator: validateShopName }],\n },\n account_id: \"\",\n isLook: false,\n isEdit: false,\n show_shop: false,\n choose_data: [],\n check_money: 0, // 勾选后合计\n id: \"\",\n time: \"\",\n delAccountList: [],\n flag: false,\n activeName: \"one\",\n };\n },\n computed: {\n // 核销总金额\n total() {\n if (!this.form.accountList.length) {\n return 0;\n } else if (this.form.accountList.length === 1) {\n return Number(this.form.accountList[0].money);\n } else {\n let sum = 0;\n this.form.accountList.forEach((item) => {\n sum = this.$NP.plus(sum, Number(item.money));\n });\n return sum;\n }\n },\n // 收款总金额\n moneyTotal() {\n if (!this.form.accountList.length) {\n return 0;\n } else if (this.form.accountList.length === 1) {\n return this.$NP.minus(\n Number(this.form.accountList[0].money),\n Number(this.form.accountList[0].discountMoney)\n );\n } else {\n let sum = 0;\n this.form.accountList.forEach((item) => {\n const money = this.$NP.minus(\n Number(item.money),\n Number(item.discountMoney)\n );\n sum = this.$NP.plus(sum, money);\n });\n return sum;\n }\n },\n // 核销总金额\n offSetTotal() {\n if (!this.choose_data.length) {\n return 0;\n } else if (this.choose_data.length === 1) {\n return Number(this.choose_data[0].offsetMoney);\n } else {\n let sum = 0;\n this.choose_data.forEach((item) => {\n sum = this.$NP.plus(sum, Number(item.offsetMoney));\n });\n return sum;\n }\n },\n // 未核销总金额\n offSetNotTotal() {\n if (!this.tableData.length) {\n return 0;\n } else if (this.tableData.length === 1) {\n return Number(this.tableData[0].offsetMoney);\n } else {\n let sum = 0;\n this.tableData.forEach((item) => {\n sum = this.$NP.plus(sum, Number(item.offsetMoney));\n });\n return sum;\n }\n },\n },\n created() {\n this.initial();\n },\n activated() {\n if (this.$_isInit()) return;\n this.initial();\n },\n methods: {\n // 初始化\n async initial() {\n await this.getAllFinanceType();\n await this.getAllPayment();\n this.isLook = this.$route.path.indexOf(\"LookReceipt\") > -1;\n this.isEdit = this.$route.path.indexOf(\"editReceipt\") > -1;\n // 收款人默认当前账户\n this.form.currentAccountName = this.userName;\n if (this.$route.params.createTime) {\n this.form.createTime = this.$route.params.createTime;\n }\n if (this.$route.params.id) {\n // 编辑收款单\n this.account_id = this.$route.params.id;\n // 获取详情 收款单详情\n await this.getReceivedInfo();\n } else if (this.$route.query.id) {\n // 从应收单点击收款按钮进来 新增收款单\n // 获取应收单详情\n this.id = this.$route.query.id;\n this.time = this.$route.query.createTime;\n await this.getReceiveInfo();\n } else {\n // 新增收款单\n await this.getTempReceivedData(); // 获取暂存数据\n }\n\n if (this.$route.query.customerId) {\n await this.getCustomerInfo(this.$route.query.customerId);\n }\n this.form.receiptTime = new Date().getTime();\n },\n goOtherDetail(orderId) {\n this.$router.push(\"/order/manageO/OrderDetails/1/\" + orderId);\n },\n // 批量选择\n selectionChange(val) {\n this.choose_data = val;\n let num = 0;\n this.choose_data.forEach((item) => {\n num += Number(item.offsetMoney);\n });\n // console.log(\"勾选余额\", num);\n this.check_money = num;\n },\n // 获取应收单详情\n async getReceiveInfo(obj) {\n const { data } = await getReceiveInfo({\n id: this.id,\n createTime: this.time,\n });\n this.id = data.id;\n this.form.customerId = data.customerId;\n this.form.customerName = data.customerName;\n\n this.form.sourceNo = data.no;\n this.form.sourceNoMoney = data.receiveMoney;\n\n this.form.shopName = data.shopName;\n this.form.shopId = data.shopId;\n if (data.receiptTypeId === 6) {\n const finance = this.financeTypeList.find((item) => {\n return item.name === \"销售退货退款\";\n });\n this.form.financeTypeId = finance.id;\n this.form.financeType = finance.name;\n }\n this.form.accountList = [\n {\n accountId: 0,\n accountNumber: \"\",\n accountName: \"\",\n money: data.receiveMoney,\n discountMoney: \"\",\n finalMoney: \"\",\n payWay: \"\",\n remark: \"\",\n },\n ];\n this.tableData = [\n {\n ...data,\n offsetMoney: Number(data.notOffsetMoney),\n },\n ];\n // 在应收单列表点击收款按钮打开的新增收款单页面,核销明细自动核销。\n setTimeout(() => {\n this.offsetGet();\n }, 200);\n // await this.getCustomerInfo(data.customerId);\n },\n // 获取客户详情\n async getCustomerInfo(id) {\n const { data } = await getCustomerInfo(id);\n this.form.money = data.money || 0;\n this.form.customerId = data.id;\n\n this.form.customerName = data.name;\n await this.getAllReceive();\n },\n // 应收单列表\n async getAllReceive() {\n let params = {\n page: 1,\n pageSize: 999,\n customerId: this.form.customerId,\n offsetStatus: [3, 4],\n moneyType: 1,\n // auditStatus: 2,\n // financeTypeId: this.form.financeTypeId,\n };\n const { data } = await getAllReceive(params);\n this.tableData = data.map((item) => {\n return { ...item, offsetMoney: Number(item.notOffsetMoney) };\n });\n },\n // 新增财务类型\n async addType() {\n this.$refs[\"form\"].validate(async (valid) => {\n if (valid) {\n let target = {};\n if (!this.is_edit) {\n target = await addFinanceType({\n ...this.add_form,\n });\n } else {\n target = await editFinanceType(this.pay_id, {\n ...this.add_form,\n });\n }\n const data = target;\n\n this.show_model = false;\n }\n });\n },\n // 选择商铺\n selShop(val, row) {\n this.form.shopName = row[0].name;\n // this.form.shopId = row[0].id\n },\n receivablesel(val) {\n this.form.sourceNo = val[0].no;\n this.form.sourceNoMoney = val[0].receiveMoney;\n this.form.shopName = val[0].shopName;\n this.form.shopId = val[0].shopId;\n },\n // 收款单详情\n async getReceivedInfo() {\n const { data } = await getReceivedInfo({\n id: this.account_id,\n createTime: this.form.createTime,\n });\n\n this.form = {\n ...data,\n receiptTime: data.receiptTime * 1000,\n accountList: data.accountList,\n };\n if (data.offsetDate) {\n this.tableData = data.offsetDate;\n this.choose_data = data.offsetDate;\n setTimeout(() => {\n this.tableData.forEach((item) => {\n if (item.offsetMoney > 0) {\n this.$refs.multipleTable.toggleRowSelection(item);\n }\n });\n }, 200);\n }\n },\n // 暂存数据\n async temData(tempSave) {\n let receiptOffsetData = this.choose_data.map((item) => {\n return {\n receiveReceiptId: item.id,\n offsetMoney: item.offsetMoney,\n };\n });\n const params = {\n ...this.form,\n receiptTime: parseInt(this.form.receiptTime / 1000),\n tempSave: tempSave,\n receiptOffsetData: receiptOffsetData,\n };\n this.loading = true;\n const data = await addReceived(params);\n this.loading = false;\n\n this.$message({\n message: \"暂存成功\",\n type: \"success\",\n });\n this.$closeCurrentGoEdit(\"/Finance/Receivable/ReceiptList\");\n },\n // 添加\n async addData(tempSave) {\n this.$refs[\"base_form\"].validate(async (valid) => {\n if (valid) {\n if (!tempSave) {\n if (this.flag) {\n this.form.accountList = [\n ...this.form.accountList,\n ...this.delAccountList,\n ];\n }\n let isSub = true;\n for (let i in this.form.accountList) {\n let item = this.form.accountList[i];\n if (!item.accountId) {\n isSub = false;\n this.$message.warning(\"请选择结算账户\");\n break;\n }\n if (!item.money) {\n isSub = false;\n this.$message.warning(\"请输入收款金额\");\n break;\n }\n /* if (!item.payWay) {\n isSub = false;\n this.$message.warning(\"请选择结算方式\");\n break;\n }*/\n if (this.offSetTotal > this.total) {\n isSub = false;\n this.$message.warning(\"核销金额不能大于收款金额\");\n break;\n }\n }\n if (!isSub) {\n return;\n }\n }\n if (this.choose_data.length) {\n let receiptOffsetData = this.choose_data.map((item) => {\n return {\n receiveReceiptId: item.id,\n offsetMoney: item.offsetMoney,\n receiveCreateTime: item.createTime,\n };\n });\n const params = {\n ...this.form,\n receiptTime: parseInt(this.form.receiptTime / 1000),\n tempSave: tempSave,\n receiptOffsetData: receiptOffsetData,\n sourceId: this.id,\n };\n this.loading = true;\n try {\n if (this.account_id) {\n const data = await editReceived(this.account_id, params);\n } else {\n const data = await addReceived(params);\n }\n this.loading = false;\n this.$message({\n type: \"success\",\n message: \"操作成功!\",\n });\n this.$closeCurrentGoEdit(\"/Finance/Receivable/ReceiptList\");\n } catch {\n this.loading = false;\n }\n } else {\n if (this.form.financeTypeId === 1) {\n this.form.financeType = \"销售退货退款\";\n }\n if (this.form.financeTypeId === 2) {\n this.form.financeType = \"销售收款\";\n }\n if (this.form.financeTypeId === 3) {\n this.form.financeType = \"预存收款\";\n }\n const form = this.$_common.deepClone(this.form);\n delete form.sourceNo;\n const params = {\n ...form,\n receiptTime: parseInt(this.form.receiptTime / 1000),\n tempSave: tempSave,\n financeTypeId: this.form.financeTypeId,\n financeType: this.form.financeType,\n };\n this.$confirm(\"确定要将该单据作为预收款吗?\", \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n })\n .then(async () => {\n this.loading = true;\n try {\n if (this.account_id) {\n const data = await editReceived(this.account_id, params);\n } else {\n const data = await addReceived(params);\n }\n this.loading = false;\n this.$message({\n type: \"success\",\n message: \"操作成功!\",\n });\n this.$closeCurrentGoEdit(\"/Finance/Receivable/ReceiptList\");\n } catch {\n this.loading = false;\n }\n })\n .catch(() => {\n this.loading = false;\n });\n }\n }\n });\n },\n // 获取暂存数据\n async getTempReceivedData() {\n const { data } = await getTempReceivedData();\n\n if (JSON.stringify(data) === \"{}\") return;\n this.form = {\n ...data,\n receiptTime: data.receiptTime * 1000,\n accountList: data.accountList.map((item) => {\n return {\n ...item,\n payWay: parseInt(item.payWay),\n };\n }),\n };\n if (data.offsetDate) {\n this.tableData = data.offsetDate;\n this.choose_data = data.offsetDate;\n setTimeout(() => {\n this.tableData.forEach((item) => {\n this.$refs.multipleTable.toggleRowSelection(item);\n });\n }, 200);\n }\n },\n openAccount(index) {\n this.account_index = index;\n if (this.form.shopId) {\n this.account_show = true;\n } else {\n this.$message.warning(\"请选择所属店铺\");\n }\n },\n // 结算账户\n accountsel(val) {\n this.form.accountList[this.account_index].accountId = val[0].id;\n this.form.accountList[this.account_index].accountNumber =\n val[0].accountNumber;\n this.form.accountList[this.account_index].accountName = val[0].name;\n },\n // 类型\n typeChange(val) {\n const target = this.financeTypeList.find((item) => {\n return item.id === val;\n });\n this.form.financeType = target.name;\n },\n // 获取财务类型\n async getAllFinanceType() {\n const { data } = await getAllFinanceTypeNoPage(1);\n\n this.financeTypeList = data;\n const finance = data.find((item) => {\n return item.name === \"销售收款\";\n });\n this.form.financeTypeId = finance.id;\n this.form.financeType = finance.name;\n },\n addAccount() {\n this.form.accountList.push({\n accountId: \"\",\n accountNumber: \"\",\n accountName: \"\",\n money: \"\",\n discountMoney: \"\",\n finalMoney: \"\",\n payWay: \"\",\n remark: \"\",\n });\n },\n delAccount(index) {\n if (this.account_id) {\n this.flag = true;\n if (\n this.form.accountList[index].accountId &&\n this.form.accountList[index].money\n ) {\n this.form.accountList[index].deleteStatus = 4;\n this.delAccountList.push(this.form.accountList[index]);\n }\n }\n console.log(this.delAccountList);\n this.form.accountList.splice(index, 1);\n },\n // 获取支付方式\n async getAllPayment() {\n const data = await getAllPayment({\n page: 1,\n pageSize: 99,\n });\n\n this.pay_type_list = data.data;\n },\n // 客户选择\n customerSel(val, row) {\n this.form.customerId = row[0].id;\n this.form.money = row[0].money;\n this.form.sourceNo = \"\";\n this.form.shopName = row[0].shopName;\n this.form.shopId = row[0].shopId || \"\";\n this.getAllReceive();\n },\n // 自动核销\n offsetGet() {\n let total = 0;\n for (let i = 0; i < this.tableData.length; i++) {\n let item = this.tableData[i];\n // 把本次核销金额相加\n total += Number(item.offsetMoney);\n // 勾选可以核销的数据\n this.$refs.multipleTable.toggleRowSelection(item);\n // 如果合计核销金额大于收款总金额,停止循环,并把停止循环前的一条核销数据修改为差值\n if (total > this.moneyTotal || total === this.moneyTotal) {\n item.offsetMoney = this.moneyTotal - (total - item.offsetMoney);\n break;\n }\n }\n },\n // 收款金额失去焦点\n moneyBlur() {\n // 收款金额失去焦点后自动核销\n this.offsetGet();\n // 收款金额失去焦点后重新核销\n // this.$refs.multipleTable.clearSelection();\n },\n },\n };\n</script>\n<style lang=\"scss\" scoped>\n .creat-custorm {\n color: #1890ff;\n font-size: 12px;\n }\n .order_bottom {\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 }\n .table-b-div {\n height: 80px;\n width: 100%;\n padding: 16px 24px 32px 25px;\n border: 1px solid #ebeef5;\n text-align: center;\n line-height: 40px;\n border-top: 0 none;\n cursor: pointer;\n .table-b-div-cont {\n border: 1px dashed #2153d4;\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 .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 .btn-top-div {\n position: absolute;\n right: 20px;\n top: 45px;\n z-index: 999;\n }\n</style>\n<style>\n .AddReceipt {\n background-color: #fff;\n }\n .AddReceipt .el-tabs__item {\n font-size: 16px !important;\n height: 60px !important;\n line-height: 60px !important;\n }\n .AddReceipt .is-active {\n font-weight: 700;\n color: #000;\n }\n .AddReceipt .el-tabs__nav {\n margin-left: 24px;\n }\n</style>\n"]}]}