gaoluyang
2025-07-24 a66da67589e9ec2fbbd6a253e9a9447ba0b29fe2
src/views/salesOutbound/components/formDia.vue
@@ -7,6 +7,7 @@
          <el-col :span="12">
            <el-form-item label="销售日期" prop="saleDate">
              <el-date-picker
                  :disabled="operationType === 'view'"
                  v-model="form.saleDate"
                  type="date"
                  value-format="YYYY-MM-DD"
@@ -19,7 +20,7 @@
          </el-col>
          <el-col :span="12">
            <el-form-item label="客户" prop="customerId">
              <el-select v-model="form.customerId" placeholder="请选择客户">
              <el-select v-model="form.customerId" placeholder="请选择客户" :disabled="operationType === 'view'">
                <el-option
                    v-for="item in customerOptions"
                    :key="item.value"
@@ -33,79 +34,94 @@
        <el-row>
          <el-col :span="12">
            <el-form-item label="煤种" prop="coalId">
              <el-select v-model="form.coalId" placeholder="请选择煤种" @change="setInfo">
              <el-select v-model="form.coalId" placeholder="请选择煤种" @change="setInfo" :disabled="operationType === 'view'">
                <el-option
                    v-for="item in coalOptions"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value"
                    :key="item.coalId"
                    :label="item.coal"
                    :value="item.coalId"
                />
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="单位" prop="unit">
              <el-input v-model="form.unit" placeholder="请输入单位" maxlength="30" />
              <el-input v-model="form.unit" placeholder="请输入单位" maxlength="30" :disabled="operationType === 'view'"/>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="12">
            <el-form-item label="库存数量" prop="inventoryQuantity">
              <el-input v-model="form.inventoryQuantity" placeholder="请输入销售数量" maxlength="30" type="number" />
              <el-input v-model="form.inventoryQuantity" placeholder="请输入销售数量" maxlength="30" type="number" :disabled="operationType === 'view'"/>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="单价(含税)" prop="priceIncludingTax">
              <el-input v-model="form.priceIncludingTax" placeholder="请输入销售单价(含税)" maxlength="30" type="number" />
            <el-form-item label="单价(含税)" prop="priceIncludingTax" @change="mathProfit">
              <el-input v-model="form.priceIncludingTax" placeholder="请输入销售单价(含税)" maxlength="30" type="number" :disabled="operationType === 'view'"/>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="12">
            <el-form-item label="销售数量" prop="saleQuantity">
              <el-input v-model="form.saleQuantity" placeholder="请输入销售数量" maxlength="30" type="number" />
            <el-form-item label="销售数量" prop="saleQuantity" @change="mathProfit">
              <el-input v-model="form.saleQuantity" placeholder="请输入销售数量" maxlength="30" type="number" :disabled="operationType === 'view'"/>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="销售单价(含税)" prop="salePrice" @change="mathProfit">
              <el-input v-model="form.salePrice" placeholder="请输入销售单价(含税)" maxlength="30" type="number" />
              <el-input v-model="form.salePrice" placeholder="请输入销售单价(含税)" maxlength="30" type="number" :disabled="operationType === 'view'"/>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="12">
            <el-form-item label="销售总价(含税)" prop="totalAmount">
              <el-input v-model="form.totalAmount" placeholder="请输入销售总价(含税)" maxlength="30" type="number" />
              <el-input v-model="form.totalAmount" placeholder="请输入销售总价(含税)" maxlength="30" type="number" :disabled="operationType === 'view'"/>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="运费" prop="freight">
              <el-input v-model="form.freight" placeholder="请输入销售总价(含税)" maxlength="30" type="number" />
            <el-form-item label="采购运费" prop="purchasingFreight" @change="mathProfit">
              <el-input v-model="form.purchasingFreight" placeholder="请输入" maxlength="30" type="number" :disabled="operationType === 'view'"/>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
               <el-col :span="12">
                  <el-form-item label="销售运费" prop="salesFreight" @change="mathProfit">
                     <el-input v-model="form.salesFreight" placeholder="请输入" maxlength="30" type="number" :disabled="operationType === 'view'"/>
                  </el-form-item>
               </el-col>
          <el-col :span="12">
            <el-form-item label="购销煤税率(%)" prop="taxCoal">
              <el-input v-model="form.taxCoal" placeholder="请输入销售总价(含税)" maxlength="30" type="number" />
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="运输税率(%)" prop="taxTrans">
              <el-input v-model="form.taxTrans" placeholder="请输入销售总价(含税)" maxlength="30" type="number" />
              <el-input v-model="form.taxCoal" placeholder="请输入" maxlength="30" type="number" :disabled="operationType === 'view'"/>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
               <el-col :span="12">
                  <el-form-item label="运输税率(%)" prop="taxTrans">
                     <el-input v-model="form.taxTrans" placeholder="请输入" maxlength="30" type="number" :disabled="operationType === 'view'"/>
                  </el-form-item>
               </el-col>
          <el-col :span="12">
            <el-form-item label="毛利润" prop="grossProfit">
              <el-input v-model="form.grossProfit" placeholder="毛利润" maxlength="30" type="number" />
              <el-input v-model="form.grossProfit" placeholder="毛利润" maxlength="30" type="number" :disabled="operationType === 'view'"/>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
               <el-col :span="12">
                  <el-form-item label="净利润" prop="netProfit">
                     <el-input v-model="form.netProfit" placeholder="净利润" maxlength="30" type="number" :disabled="operationType === 'view'"/>
                  </el-form-item>
               </el-col>
          <el-col :span="12">
            <el-form-item label="净利润" prop="netProfit">
              <el-input v-model="form.netProfit" placeholder="净利润" maxlength="30" type="number" />
            <el-form-item label="添加至待补库" prop="isPendingRestock">
              <el-select v-model="form.isPendingRestock" placeholder="">
                <el-option label="是" :value="true" />
                <el-option label="否" :value="false" />
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
@@ -122,9 +138,8 @@
<script setup>
import {reactive, ref} from "vue";
import {addOrEditSalesRecord, customerList, officialList} from "../../../api/salesOutbound/index.js";
import {addOrEditSalesRecord, customerList, officialList} from "@/api/salesOutbound/index.js";
import useUserStore from '@/store/modules/user'
import {getCoalInfoList, getSupplyList} from "@/api/procureMent/index.js";
const { proxy } = getCurrentInstance()
const emit = defineEmits()
@@ -142,16 +157,32 @@
    saleQuantity: '',
    salePrice: '',
    totalAmount: '',
    freight: '',
    purchasingFreight: '',
    taxCoal: '',
    taxTrans: '',
    grossProfit: '',
    netProfit: '',
    inventoryQuantity: '',
    priceIncludingTax: '',
      salesFreight: '',
    isPendingRestock: false
  },
  rules: {
    saleDate: [{ required: true, message: "请选择日期", trigger: "change" },],
      customerId: [{ required: true, message: "请选择客户", trigger: "change" },],
      coalId: [{ required: true, message: "请选择煤种", trigger: "change" },],
      unit: [{ required: true, message: "请输入", trigger: "blur" },],
      saleQuantity: [{ required: true, message: "请输入", trigger: "blur" },],
      salePrice: [{ required: true, message: "请输入", trigger: "blur" },],
      totalAmount: [{ required: true, message: "请输入", trigger: "blur" },],
      purchasingFreight: [{ required: false, message: "请输入", trigger: "blur" },],
      taxCoal: [{ required: true, message: "请输入", trigger: "blur" },],
      taxTrans: [{ required: true, message: "请输入", trigger: "blur" },],
      grossProfit: [{ required: true, message: "请输入", trigger: "blur" },],
      netProfit: [{ required: true, message: "请输入", trigger: "blur" },],
      inventoryQuantity: [{ required: true, message: "请输入", trigger: "blur" },],
      priceIncludingTax: [{ required: true, message: "请输入", trigger: "blur" },],
    isPendingRestock: [{ required: true, message: "请选择是否添加至待补库", trigger: "change" },],
  }
})
@@ -159,28 +190,26 @@
// 打开弹框
const openDialog = async (type, row) => {
  operationType.value = type
  dialogVisitable.value = true
  form.value.saleDate = proxy.getCurrentDate()
  const [supplyRes, coalRes] = await Promise.all([
    customerList(),
    getCoalInfoList(),
    officialList(),
  ]);
  let supplyData = supplyRes.data;
  let coalData = coalRes.data;
  coalOptions.value = coalRes.data;
  customerOptions.value = supplyData.map((item) => ({
    value: item.id,
    label: item.customerName,
  }));
  coalOptions.value = coalData.map((item) => ({
    value: item.id,
    label: item.coal,
  }))
  let res = await userStore.getInfo()
  form.value.registrantId = res.user.userId
  form.value.taxCoal = 13
  form.value.taxTrans = 9
  form.value.freight = 20
  if (type === 'edit') {
  form.value.purchasingFreight = 20
  form.value.salesFreight = 0
  if (type !== 'add') {
    form.value = {...row}
  }
}
@@ -205,7 +234,8 @@
  const purchaseTons = form.value.inventoryQuantity;     // 库存数量
  const saleTons = form.value.saleQuantity;          // 销售数量
  const purchasePricePerTon = form.value.priceIncludingTax; // 含税单价
  const transportPricePerTon = form.value.freight; // 运费
  const transportPricePerTon = form.value.purchasingFreight; // 采购运费
  const salesFreight = form.value.salesFreight; // 销售运费
  const salePricePerTon = form.value.salePrice;   // 销售单价(元/吨)
  const coalTaxRate = form.value.taxCoal / 100;      // 购销煤税率(13%)
  const transportTaxRate = form.value.taxTrans / 100; // 运输税率(9%)
@@ -220,13 +250,15 @@
  const D = C * transportTaxRate * purchaseTons;     // 运费进项税额
  const E = salePricePerTon / (1 + coalTaxRate);     // 销售不含税单价
  const F = E * coalTaxRate * saleTons;              // 销项税额
  const R = salesFreight / (1 + transportTaxRate);       // 销售煤运费不含税单价
  const S = R * transportTaxRate * saleTons;              // 销售煤运费进项税额
// 毛利润 = 销售收入 - 成本成本(购煤+运费)的成本部分
  const G = E * saleTons - A * saleTons - C * saleTons;
  const G = E * saleTons - A * saleTons - C * saleTons - R * saleTons;
  form.value.grossProfit = G.toFixed(2);
// 应缴纳增值税 = 销项税 - 可抵扣进项税(按销售量比例计算)
  const H = F - (A * coalTaxRate * saleTons) - (C * transportTaxRate * saleTons);
  const H = F - (A * coalTaxRate * saleTons) - (C * transportTaxRate * saleTons) - (R * transportTaxRate * saleTons);
// 增值税附加税
  const K = H * surchargeRate;