1 |
- {"remainingRequest":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\babel-loader\\lib\\index.js!D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\wnmp\\www\\vue\\seaBlueAdmin\\src\\views\\Finance\\Handle\\AddPayment.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\src\\views\\Finance\\Handle\\AddPayment.vue","mtime":1678954023544},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\babel.config.js","mtime":1681371897685},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1681371913603},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\babel-loader\\lib\\index.js","mtime":1681371912860},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1681371913603},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\vue-loader\\lib\\index.js","mtime":1681371925849}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import Handle from "@/component/Finance/Handle.vue";
import SelectSupplier from "@/component/common/SelectSupplier.vue";
import AccountType from "../AccountType";
import { getAllPayment } from "@/api/System";
import { getSupplierInfoById, updatePurchaseStatus } from "@/api/Purchase";
import { addFinanceType, editFinanceType, addPaid, editPaid, getPaidInfo, getAllFinanceTypeNoPage, getTempPaidData, getPayInfo, exportGetAllPay, getAllPay } from "@/api/Finance";
import SelectShop from "@/component/goods/SelectShop.vue";
export default {
  name: "AddPayment",
  components: {
    SelectSupplier,
    AccountType,
    Handle,
    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 validateShop = (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,
      code: "",
      customerName: "",
      customerTypeList: [],
      pay_index: 0,
      pay_type_list: [],
      handle_show: false,
      show_shop: false,
      // 打开店铺选择弹窗
      account_show: false,
      money: "",
      no: "",
      form: {
        supplierId: "",
        supplierName: "",
        sourceNo: "",
        sourceNoMoney: "",
        currentAccountName: "",
        financeType: "",
        financeTypeId: "",
        shopId: "",
        shopName: "",
        receiptTime: "",
        createTime: "",
        tempSave: false,
        accountList: [{
          accountId: "",
          accountNumber: "",
          accountName: "",
          money: "",
          discountMoney: "",
          finalMoney: "",
          payWay: "",
          remark: ""
        }]
      },
      rules: {
        supplierName: [{
          required: true,
          validator: validateName
        }],
        sourceNo: [{
          required: true,
          validator: validateNo
        }],
        currentAccountName: [{
          required: true,
          message: "请输入付款人",
          trigger: "blur"
        }],
        shopName: [{
          required: true,
          message: "请选择商铺",
          trigger: "blur"
        }]
      },
      paid: "",
      createTime: "",
      isLook: false,
      isEdit: false,
      choose_data: [],
      check_money: 0,
      // 勾选后合计
      id: "",
      purchaseId: "",
      createTime1: "",
      activeName: "one"
    };
  },

  computed: {
    // 付款总金额
    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) || 0);
        });
        return sum;
      }
    },

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

  },

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

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

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

      this.form.currentAccountName = this.userName;

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

      this.form.receiptTime = new Date().getTime();
      await this.getAllFinanceType();
      await this.getAllPayment();

      if (this.$route.params.id) {
        // 编辑页面
        this.paid = this.$route.params.id; // 付款单详情

        await this.getPaidInfo();
      } else if (this.$route.query.id) {
        // 应付单 进入 新增付款单
        this.id = this.$route.query.id;
        this.purchaseId = this.$route.query.purchaseId;
        this.createTime1 = this.$route.query.createTime; // 应付详情

        await this.getPayInfo();
      } else {
        // 新增
        await this.getTempPaidData();
      }

      if (this.$route.query.supplierId) {
        await this.getSupplierInfoById(this.$route.query.supplierId);
      }
    },

    // 批量选择
    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 getPayInfo(obj) {
      const {
        data
      } = await getPayInfo({
        id: this.id,
        purchaseId: this.purchaseId,
        createTime: this.createTime1
      });
      this.form.supplierId = data.supplierId;
      this.form.supplierName = data.supplierName;
      this.form.sourceNo = data.no;
      this.form.sourceNoMoney = data.payMoney;
      this.form.shopName = data.shopName;
      this.form.shopId = data.shopId;
      this.form.accountList = [{
        accountId: "",
        accountNumber: "",
        accountName: "",
        money: data.payMoney,
        discountMoney: 0,
        finalMoney: "",
        payWay: "",
        remark: ""
      }];
      this.tableData = [{ ...data,
        offsetMoney: Number(data.notOffsetMoney)
      }]; // 添加调用标识，1表示不是纯新增页面

      await this.getSupplierInfoById(data.supplierId, 1);
    },

    // 获取供应商详情
    async getSupplierInfoById(id, isEdit) {
      const {
        data
      } = await getSupplierInfoById(id);
      this.money = data.money || 0;

      if (!isEdit) {
        this.form.supplierName = data.title;
        this.form.supplierId = data.id;
        await this.getAllPay();
      }
    },

    // async getPayInfo1() {
    //   // let params = {
    //   //   page: 1,
    //   //   pageSize: 999,
    //   //   supplierId: this.form.supplierId,
    //   //   offsetStatus: 4,
    //   // };
    //   const { data, pageTotal } = await getPayInfo({
    //     id: this.id,
    //     purchaseId: this.purchaseId,
    //     createTime: this.createTime1,
    //   });
    //   let arr = [];
    //   arr.push(data);
    //   this.tableData = arr;
    //   this.tableData[0].offsetMoney = data.notOffsetMoney;
    // },
    // 列表
    async getAllPay() {
      let params = {
        page: 1,
        pageSize: 999,
        supplierId: this.form.supplierId,
        offsetStatus: [3, 4]
      };
      const {
        data,
        pageTotal
      } = await getAllPay(params);
      this.tableData = data.map(item => {
        return { ...item,
          offsetMoney: Number(item.notOffsetMoney)
        };
      });
    },

    addType() {
      if (!this.add_form.name.trim()) {
        this.$message.warning("必填项不能为空");
        return;
      }

      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;
        }
      });
    },

    openHandelShow() {
      if (!this.form.supplierId) {
        this.$message.warning("请选择供应商");
        return;
      }

      this.handle_show = true;
    },

    handlesel(val) {
      this.form.sourceNo = val[0].no;
      this.form.sourceNoMoney = val[0].payMoney;
      this.form.shopName = val[0].shopName;
      this.form.shopId = val[0].shopId;
      this.form.accountList[0].money = val[0].payMoney;
    },

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

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

    // 暂存数据
    async temData(tempSave) {
      let receiptOffsetData = this.choose_data.map(item => {
        return {
          payReceiptId: 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 addPaid(params);
      this.loading = false;
      this.$message({
        message: "暂存成功",
        type: "success"
      });
      this.$closeCurrentGoEdit("/Finance/Handle/PaymentList");
    },

    //  保存
    async addData(tempSave) {
      this.$refs["base_form"].validate(async valid => {
        if (valid) {
          if (!tempSave) {
            let isSub = true;

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

              if (!item.accountName) {
                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.moneyTotal) {
              //   isSub = false;
              //   this.$message.warning("核销金额不能大于付款金额");
              //   break;
              // }

            }

            if (!isSub) {
              return;
            }
          }

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

            try {
              if (this.paid) {
                const data = await editPaid(this.paid, params);
              } else {
                const data = await addPaid(params);
              }

              this.loading = false;
              this.$message({
                type: "success",
                message: "操作成功!"
              });
              this.$closeCurrentGoEdit("/Finance/Handle/PaymentList");
            } catch {
              this.loading = false;
            }
          } else {
            const params = { ...this.form,
              receiptTime: parseInt(this.form.receiptTime / 1000),
              tempSave: tempSave,
              financeTypeId: 4,
              financeType: "采购预付"
            };
            this.$confirm("确定要将该单据作为采购预付款？", "提示", {
              confirmButtonText: "确定",
              cancelButtonText: "取消",
              type: "warning"
            }).then(async () => {
              this.loading = true;

              try {
                if (this.paid) {
                  const data = await editPaid(this.paid, params);
                } else {
                  const data = await addPaid(params);
                }

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

    //  详情
    async getPaidInfo() {
      const {
        data
      } = await getPaidInfo({
        id: this.paid,
        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);
      }
    },

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

    //  供应商
    selUnitSupplier(val, list) {
      this.form.supplierName = list[0].title;
      this.money = list[0].money;
      this.getAllPay();
    },

    //  获取财务类型
    async getAllFinanceType() {
      const {
        data
      } = await getAllFinanceTypeNoPage(2);
      this.customerTypeList = data;
      const finance = data.find(item => {
        return item.name === "采购付款";
      });
      this.form.financeTypeId = finance.id;
      this.form.financeType = finance.name;
    },

    delAccount(index) {
      this.form.accountList.splice(index, 1);
    },

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

    openAccount(index) {
      this.account_index = index;

      if (!this.form.supplierId) {
        this.$message.warning("请选择供应商");
        return;
      }

      if (!this.form.shopId) {
        this.$message.warning("请选择商铺");
        return;
      }

      this.account_show = true;
    },

    // 结算账户
    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;
    },

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

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

    // 自动核销
    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.$refs.multipleTable.clearSelection();
      this.tableData = this.tableData.map(item => {
        return { ...item,
          offsetMoney: Number(item.payMoney)
        };
      });
    },

    goDetail(row) {
      this.$router.push(`/Purchase/ManageP/PurchaseOrderLook/${row.purchaseId}`);
    }

  }
};"},{"version":3,"mappings":"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IACA,CAhCA;;IAiCA;IACAC;MACA;MACA;MACA;QACAC;MACA,CAFA;MAGAC;MACA;IACA,CA1CA;;IA2CA;IACA;MACA;QAAArE;MAAA;QACAsD,WADA;QAEAC,2BAFA;QAGAnB;MAHA;MAKA;MACA;MACA;MACA;MACA;MACA;MACA,yBACA;QACAG,aADA;QAEAC,iBAFA;QAGAC,eAHA;QAIAlB,oBAJA;QAKAmB,gBALA;QAMAC,cANA;QAOAC,UAPA;QAQAC;MARA,CADA;MAYA,kBACA;QAAAyB;MAAA,CADA,EAxBA,CA2BA;;MACA;IACA,CAzEA;;IA0EA;IACA;MACA;QAAAtE;MAAA;MACA;;MACA;QACA;QACA;QACA;MACA;IACA,CAnFA;;IAoFA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;MACA;QACAuE,OADA;QAEAC,aAFA;QAGA9C,gCAHA;QAIA+C;MAJA;MAMA;QAAAzE;QAAA0E;MAAA;MACA;QACA;UAAAJ;QAAA;MACA,CAFA;IAGA,CAjHA;;IAkHAK;MACA;QACA;QACA;MACA;;MACA;QACA;UACA;;UACA;YACAC,gCACA;YADA;UAGA,CAJA,MAIA;YACAA,8CACA;YADA;UAGA;;UACA;UAEA;QACA;MACA,CAhBA;IAiBA,CAxIA;;IAyIAC;MACA;QACA;QACA;MACA;;MACA;IACA,CA/IA;;IAgJAC;MACA;MACA;MACA;MACA;MACA;IACA,CAtJA;;IAuJA;IACAC;MACA;IACA,CA1JA;;IA2JAC;MACA;QACAzC,aADA;QAEAC,iBAFA;QAGAC,eAHA;QAIAlB,SAJA;QAKAmB,iBALA;QAMAC,cANA;QAOAC,UAPA;QAQAC;MARA;IAUA,CAtKA;;IAuKA;IACA;MACA;QACA;UACAoC,qBADA;UAEAX;QAFA;MAIA,CALA;MAMA,iBACA,YADA;QAEAnC,mDAFA;QAGAE,kBAHA;QAIA6C;MAJA;MAMA;MACA;MACA;MAEA;QACArE,eADA;QAEAsE;MAFA;MAIA;IACA,CA9LA;;IA+LA;IACA;MACA;QACA;UACA;YACA;;YACA;cACA;;cACA;gBACAC;gBACA;gBACA;cACA;;cACA;gBACAA;gBACA;gBACA;cACA,CAXA,CAYA;cACA;cACA;cACA;cACA;cACA;cACA;cACA;cACA;cACA;;YACA;;YACA;cACA;YACA;UACA;;UACA;YACA;cACA;gBACAH,qBADA;gBAEAX,6BAFA;gBAGAe;cAHA;YAKA,CANA;YAOA,iBACA,YADA;cAEAlD,mDAFA;cAGAE,kBAHA;cAIA6C;YAJA;YAMA;;YACA;cACA;gBACA;cACA,CAFA,MAEA;gBACA;cACA;;cACA;cACA;gBACAC,eADA;gBAEAtE;cAFA;cAIA;YACA,CAZA,CAYA;cACA;YACA;UACA,CA9BA,MA8BA;YACA,iBACA,YADA;cAEAsB,mDAFA;cAGAE,kBAHA;cAIAL,gBAJA;cAKAD;YALA;YAOA;cACAuD,uBADA;cAEAC,sBAFA;cAGAJ;YAHA,GAKAK,IALA,CAKA;cACA;;cACA;gBACA;kBACA;gBACA,CAFA,MAEA;kBACA;gBACA;;gBACA;gBACA;kBACAL,eADA;kBAEAtE;gBAFA;gBAIA;cACA,CAZA,CAYA;gBACA;cACA;YACA,CAtBA,EAuBA4E,KAvBA,CAuBA;cACA;YACA,CAzBA;UA0BA;QACA;MACA,CAjGA;IAkGA,CAnSA;;IAoSA;IACA;MACA;QAAAzF;MAAA;QACAsD,aADA;QAEAlB;MAFA;MAKA,cACA,OADA;QAEAD,oCAFA;QAGAG;MAHA;;MAKA;QACA;QACA;QACAoD;UACA;YACA;cACA;YACA;UACA,CAJA;QAKA,CANA,EAMA,GANA;MAOA;IACA,CA3TA;;IA4TA;IACAC;MACA;QACA;MACA,CAFA;MAGA;IACA,CAlUA;;IAmUA;IACAC;MACA;MACA;MACA;IACA,CAxUA;;IAyUA;IACA;MACA;QAAA5F;MAAA;MAEA;MACA;QACA;MACA,CAFA;MAGA;MACA;IACA,CAnVA;;IAoVA6F;MACA;IACA,CAtVA;;IAuVA;IACA;MACA;QACAtB,OADA;QAEAC;MAFA;MAKA;IACA,CA/VA;;IAgWAsB;MACA;;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;IACA,CA3WA;;IA4WA;IACAC;MACA;MACA,0DACAC,oBADA;MAEA;IACA,CAlXA;;IAmXA;IACA;MACA;QAAAhG;MAAA;MAEA;MACA,cACA,OADA;QAEAmC,8CAFA;QAGAG;UACA;QACA,CAFA;MAHA;;MAOA;QACA;QACA;QACAoD;UACA;YACA;UACA,CAFA;QAGA,CAJA,EAIA,GAJA;MAKA;IACA,CAxYA;;IAyYA;IACAO;MACA;;MACA;QACA,6BADA,CAEA;;QACAC,kCAHA,CAIA;;QACA,kDALA,CAMA;;QACA;UACAC;UACA;QACA;MACA;IACA,CAxZA;;IAyZA;IACAC;MACA;MACA;QACA,SACA,OADA;UAEA9B;QAFA;MAIA,CALA;IAMA,CAlaA;;IAmaA+B;MACA,kBACA,uDADA;IAGA;;EAvaA;AA3KA","names":["addFinanceType","editFinanceType","addPaid","editPaid","getPaidInfo","getAllFinanceTypeNoPage","getTempPaidData","getPayInfo","exportGetAllPay","getAllPay","name","components","SelectSupplier","AccountType","Handle","SelectShop","data","callback","tableData","form_type","label","value","show_model","add_form","link","isDefault","enableStatus","add_rule","required","message","loading","code","customerName","customerTypeList","pay_index","pay_type_list","handle_show","show_shop","account_show","money","no","form","supplierId","supplierName","sourceNo","sourceNoMoney","currentAccountName","financeType","financeTypeId","shopId","shopName","receiptTime","createTime","tempSave","accountList","accountId","accountNumber","accountName","discountMoney","finalMoney","payWay","remark","rules","validator","trigger","paid","isLook","isEdit","choose_data","check_money","id","purchaseId","createTime1","activeName","computed","moneyTotal","Number","sum","offSetTotal","offSetNotTotal","created","activated","methods","selectionChange","num","console","offsetMoney","page","pageSize","offsetStatus","pageTotal","addType","target","openHandelShow","handlesel","selShop","addAccount","payReceiptId","receiptOffsetData","type","isSub","payCreateTime","confirmButtonText","cancelButtonText","then","catch","setTimeout","typeChange","selUnitSupplier","delAccount","openAccount","accountsel","val","offsetGet","total","item","moneyBlur","goDetail"],"sourceRoot":"src/views/Finance/Handle","sources":["AddPayment.vue"],"sourcesContent":["<!--添加基础资料-->\n<template>\n <ContainerTit class=\"AddPayment\">\n <div class=\"page-tip-div\" style=\"margin: 0; position: relative\">\n 温馨提示: 1、退款时在金额输入框输入负数即可!\n 2、付款时,在金额输入框输入正数即可!\n 3、商家预付货款时,在新增选择单据类型为采购预付后不用选择原单据号即可创建!\n <div class=\"btn-top-div\">\n <el-button\n v-if=\"$accessCheck($Access.PaymentListGetTempPaidData)\"\n :loading=\"loading\"\n :disabled=\"isEdit || isLook\"\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 size=\"small\"\n :model=\"form\"\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=\"supplierName\"\n style=\"min-width: 400px\"\n >\n <SelectSupplier\n v-model=\"form.supplierId\"\n :clearable=\"false\"\n width=\"180\"\n @change=\"selUnitSupplier\"\n />\n <el-button\n size=\"mini\"\n type=\"text\"\n @click=\"$router.push('/Purchase/ManageP/SupplierAdd')\"\n >\n 【新建供应商】\n </el-button>\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=\"180\"\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=\"money\"\n disabled\n style=\"width: 180px\"\n placeholder=\"不可编辑\"\n ></el-input>\n </el-form-item>\n </el-col>\n <el-col class=\"form\" :span=\"6\">\n <el-form-item label=\"付款人\" prop=\"currentAccountName\">\n <el-input\n v-model=\"form.currentAccountName\"\n style=\"width: 180px\"\n placeholder=\"当前账户\"\n ></el-input>\n </el-form-item>\n </el-col>\n\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: 180px\"\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=\"12\">\n <el-form-item\n label=\"业务类型\"\n prop=\"financeTypeId\"\n style=\"min-width: 450px\"\n >\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 customerTypeList\"\n :key=\"index\"\n :label=\"item.name\"\n :value=\"item.id\"\n ></el-option>\n </el-select>\n <el-button size=\"mini\" type=\"text\" @click=\"getAllFinanceType\">\n 【刷新】\n </el-button>\n <el-button size=\"mini\" type=\"text\" @click=\"show_model = true\">\n 【新建类型】\n </el-button>\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=\"name\" label=\"结算账户\" min-width=\"160\">\n <template slot-scope=\"scope\">\n <el-input\n v-model=\"scope.row.accountName\"\n readonly\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 @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 size=\"small\"\n style=\"width: 100%\"\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 size=\"small\"\n placeholder=\"备注\"\n ></el-input>\n </template>\n </el-table-column>\n <el-table-column\n prop=\"remark\"\n label=\"操作\"\n width=\"130px\"\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 </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 @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 prop=\"financeType\" label=\"单据类型\" min-width=\"100\">\n <template slot-scope=\"scope\">\n {{ scope.row.receiptTypeId === 2 ? \"采购订单\" : \"采购退货单\" }}\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 prop=\"address\" label=\"金额\" min-width=\"100\">\n <template slot-scope=\"scope\">\n {{ $_common.formattedNumber(scope.row.payMoney) }}\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 prop=\"purchaseNo\" label=\"来源单据\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <span class=\"click-div\" @click=\"goDetail(scope.row)\">\n {{ scope.row.purchaseNo }}\n </span>\n </template>\n </el-table-column>\n <el-table-column\n prop=\"supplierName\"\n label=\"往来单位名称\"\n min-width=\"140\"\n ></el-table-column>\n </el-table>\n </div>\n </el-form>\n <AccountType\n v-if=\"account_show\"\n :is-check=\"false\"\n :is-show=\"account_show\"\n :shop-id=\"form.shopId\"\n @cancel=\"account_show = false\"\n @confirm=\"accountsel\"\n />\n <Handle\n v-if=\"handle_show\"\n :is-check=\"false\"\n :is-show=\"handle_show\"\n :supplier=\"form.supplierId\"\n @cancel=\"handle_show = false\"\n @confirm=\"handlesel\"\n />\n <!-- 新增付款类型-->\n <el-dialog\n name=\"新增财务类型\"\n :visible.sync=\"show_model\"\n width=\"40%\"\n :close-on-press-escape=\"false\"\n :close-on-click-modal=\"false\"\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 Handle from \"@/component/Finance/Handle.vue\";\n import SelectSupplier from \"@/component/common/SelectSupplier.vue\";\n import AccountType from \"../AccountType\";\n\n import { getAllPayment } from \"@/api/System\";\n import { getSupplierInfoById, updatePurchaseStatus } from \"@/api/Purchase\";\n import {\n addFinanceType,\n editFinanceType,\n addPaid,\n editPaid,\n getPaidInfo,\n getAllFinanceTypeNoPage,\n getTempPaidData,\n getPayInfo,\n exportGetAllPay,\n getAllPay,\n } from \"@/api/Finance\";\n import SelectShop from \"@/component/goods/SelectShop.vue\";\n\n export default {\n name: \"AddPayment\",\n components: {\n SelectSupplier,\n AccountType,\n Handle,\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 validateShop = (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 code: \"\",\n customerName: \"\",\n customerTypeList: [],\n pay_index: 0,\n pay_type_list: [],\n handle_show: false,\n show_shop: false, // 打开店铺选择弹窗\n account_show: false,\n money: \"\",\n no: \"\",\n form: {\n supplierId: \"\",\n supplierName: \"\",\n sourceNo: \"\",\n sourceNoMoney: \"\",\n currentAccountName: \"\",\n financeType: \"\",\n financeTypeId: \"\",\n shopId: \"\",\n shopName: \"\",\n receiptTime: \"\",\n createTime: \"\",\n tempSave: false,\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 supplierName: [{ required: true, validator: validateName }],\n sourceNo: [{ required: true, validator: validateNo }],\n currentAccountName: [\n { required: true, message: \"请输入付款人\", trigger: \"blur\" },\n ],\n shopName: [\n { required: true, message: \"请选择商铺\", trigger: \"blur\" },\n ],\n },\n paid: \"\",\n createTime: \"\",\n isLook: false,\n isEdit: false,\n choose_data: [],\n check_money: 0, // 勾选后合计\n id: \"\",\n purchaseId: \"\",\n createTime1: \"\",\n activeName: \"one\",\n };\n },\n computed: {\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) || 0);\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].notOffsetMoney);\n } else {\n let sum = 0;\n this.tableData.forEach((item) => {\n sum = this.$NP.plus(sum, Number(item.notOffsetMoney) || 0);\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 this.isLook = this.$route.path.indexOf(\"LookPayment\") > -1;\n this.isEdit = this.$route.path.indexOf(\"editPayment\") > -1;\n // 收款人默认当前账户\n this.form.currentAccountName = this.userName;\n if (this.$route.params.createTime) {\n this.form.createTime = this.$route.params.createTime;\n }\n this.form.receiptTime = new Date().getTime();\n await this.getAllFinanceType();\n await this.getAllPayment();\n if (this.$route.params.id) {\n // 编辑页面\n this.paid = this.$route.params.id;\n // 付款单详情\n await this.getPaidInfo();\n } else if (this.$route.query.id) {\n // 应付单 进入 新增付款单\n this.id = this.$route.query.id;\n this.purchaseId = this.$route.query.purchaseId;\n this.createTime1 = this.$route.query.createTime;\n // 应付详情\n await this.getPayInfo();\n } else {\n // 新增\n await this.getTempPaidData();\n }\n if (this.$route.query.supplierId) {\n await this.getSupplierInfoById(this.$route.query.supplierId);\n }\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 getPayInfo(obj) {\n const { data } = await getPayInfo({\n id: this.id,\n purchaseId: this.purchaseId,\n createTime: this.createTime1,\n });\n this.form.supplierId = data.supplierId;\n this.form.supplierName = data.supplierName;\n this.form.sourceNo = data.no;\n this.form.sourceNoMoney = data.payMoney;\n this.form.shopName = data.shopName;\n this.form.shopId = data.shopId;\n this.form.accountList = [\n {\n accountId: \"\",\n accountNumber: \"\",\n accountName: \"\",\n money: data.payMoney,\n discountMoney: 0,\n finalMoney: \"\",\n payWay: \"\",\n remark: \"\",\n },\n ];\n this.tableData = [\n { ...data, offsetMoney: Number(data.notOffsetMoney) },\n ];\n // 添加调用标识,1表示不是纯新增页面\n await this.getSupplierInfoById(data.supplierId, 1);\n },\n // 获取供应商详情\n async getSupplierInfoById(id, isEdit) {\n const { data } = await getSupplierInfoById(id);\n this.money = data.money || 0;\n if (!isEdit) {\n this.form.supplierName = data.title;\n this.form.supplierId = data.id;\n await this.getAllPay();\n }\n },\n // async getPayInfo1() {\n // // let params = {\n // // page: 1,\n // // pageSize: 999,\n // // supplierId: this.form.supplierId,\n // // offsetStatus: 4,\n // // };\n // const { data, pageTotal } = await getPayInfo({\n // id: this.id,\n // purchaseId: this.purchaseId,\n // createTime: this.createTime1,\n // });\n // let arr = [];\n // arr.push(data);\n // this.tableData = arr;\n // this.tableData[0].offsetMoney = data.notOffsetMoney;\n // },\n // 列表\n async getAllPay() {\n let params = {\n page: 1,\n pageSize: 999,\n supplierId: this.form.supplierId,\n offsetStatus: [3, 4],\n };\n const { data, pageTotal } = await getAllPay(params);\n this.tableData = data.map((item) => {\n return { ...item, offsetMoney: Number(item.notOffsetMoney) };\n });\n },\n addType() {\n if (!this.add_form.name.trim()) {\n this.$message.warning(\"必填项不能为空\");\n return;\n }\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 openHandelShow() {\n if (!this.form.supplierId) {\n this.$message.warning(\"请选择供应商\");\n return;\n }\n this.handle_show = true;\n },\n handlesel(val) {\n this.form.sourceNo = val[0].no;\n this.form.sourceNoMoney = val[0].payMoney;\n this.form.shopName = val[0].shopName;\n this.form.shopId = val[0].shopId;\n this.form.accountList[0].money = val[0].payMoney;\n },\n // 选择商铺\n selShop(val, row) {\n this.form.shopName = row[0].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 // 暂存数据\n async temData(tempSave) {\n let receiptOffsetData = this.choose_data.map((item) => {\n return {\n payReceiptId: 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 addPaid(params);\n this.loading = false;\n\n this.$message({\n message: \"暂存成功\",\n type: \"success\",\n });\n this.$closeCurrentGoEdit(\"/Finance/Handle/PaymentList\");\n },\n // 保存\n async addData(tempSave) {\n this.$refs[\"base_form\"].validate(async (valid) => {\n if (valid) {\n if (!tempSave) {\n let isSub = true;\n for (let i in this.form.accountList) {\n let item = this.form.accountList[i];\n if (!item.accountName) {\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.moneyTotal) {\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 payReceiptId: item.id,\n offsetMoney: item.offsetMoney,\n payCreateTime: item.createTime,\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 try {\n if (this.paid) {\n const data = await editPaid(this.paid, params);\n } else {\n const data = await addPaid(params);\n }\n this.loading = false;\n this.$message({\n type: \"success\",\n message: \"操作成功!\",\n });\n this.$closeCurrentGoEdit(\"/Finance/Handle/PaymentList\");\n } catch {\n this.loading = false;\n }\n } else {\n const params = {\n ...this.form,\n receiptTime: parseInt(this.form.receiptTime / 1000),\n tempSave: tempSave,\n financeTypeId: 4,\n 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.paid) {\n const data = await editPaid(this.paid, params);\n } else {\n const data = await addPaid(params);\n }\n this.loading = false;\n this.$message({\n type: \"success\",\n message: \"操作成功!\",\n });\n this.$closeCurrentGoEdit(\"/Finance/Handle/PaymentList\");\n } catch {\n this.loading = false;\n }\n })\n .catch(() => {\n this.loading = false;\n });\n }\n }\n });\n },\n // 详情\n async getPaidInfo() {\n const { data } = await getPaidInfo({\n id: this.paid,\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 // 类型AddPromotion\n typeChange(val) {\n const target = this.customerTypeList.find((item) => {\n return item.id === val;\n });\n this.form.financeType = target.name;\n },\n // 供应商\n selUnitSupplier(val, list) {\n this.form.supplierName = list[0].title;\n this.money = list[0].money;\n this.getAllPay();\n },\n // 获取财务类型\n async getAllFinanceType() {\n const { data } = await getAllFinanceTypeNoPage(2);\n\n this.customerTypeList = 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 delAccount(index) {\n this.form.accountList.splice(index, 1);\n },\n // 获取支付方式\n async getAllPayment() {\n const data = await getAllPayment({\n page: 1,\n pageSize: 9,\n });\n\n this.pay_type_list = data.data;\n },\n openAccount(index) {\n this.account_index = index;\n if (!this.form.supplierId) {\n this.$message.warning(\"请选择供应商\");\n return;\n }\n if (!this.form.shopId) {\n this.$message.warning(\"请选择商铺\");\n return;\n }\n this.account_show = true;\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 async getTempPaidData() {\n const { data } = await getTempPaidData();\n\n if (JSON.stringify(data) === \"{}\") return;\n this.form = {\n ...data,\n receiptTime: parseInt(data.receiptTime * 1000),\n accountList: data.accountList.map((item) => {\n return item;\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 // 自动核销\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 this.$refs.multipleTable.clearSelection();\n this.tableData = this.tableData.map((item) => {\n return {\n ...item,\n offsetMoney: Number(item.payMoney),\n };\n });\n },\n goDetail(row) {\n this.$router.push(\n `/Purchase/ManageP/PurchaseOrderLook/${row.purchaseId}`\n );\n },\n },\n };\n</script>\n<style lang=\"scss\" scoped>\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 .AddPayment {\n background-color: #fff;\n }\n .AddPayment .el-tabs__item {\n font-size: 16px !important;\n height: 60px !important;\n line-height: 60px !important;\n }\n .AddPayment .is-active {\n font-weight: 700;\n color: #000;\n }\n .AddPayment .el-tabs__nav {\n margin-left: 24px;\n }\n</style>\n"]}]}
|