<template>
  <div style="width: 100%; padding: 0px 15px">
    <byForm
      :formConfig="formConfig"
      :formOption="formOption"
      v-model="formData.data"
      :rules="rules"
      ref="submit"
    >
      <template #seller>
        <div style="width: 100%">
          <el-form-item prop="sellCorporationId">
            <el-select
              v-model="formData.data.sellCorporationId"
              style="width: 100%"
              disabled
            >
              <el-option
                v-for="item in corporationList"
                :key="item.value"
                :label="item.label"
                :value="item.value"
              />
            </el-select>
          </el-form-item>
          <el-row style="margin-top: 20px; width: 100%">
            <el-col :span="8">
              <el-form-item label="地址" prop="sellCountryName">
                <el-input
                  v-model="formData.data.sellCountryName"
                  placeholder="请输入国家"
                />
              </el-form-item>
            </el-col>
            <el-col :span="1"></el-col>
            <el-col :span="7">
              <el-form-item label=" " prop="sellProvinceName">
                <el-input
                  v-model="formData.data.sellProvinceName"
                  placeholder="请输入省/州"
                />
              </el-form-item>
            </el-col>
            <el-col :span="1"></el-col>
            <el-col :span="7">
              <el-form-item label=" " prop="sellCityName">
                <el-input
                  v-model="formData.data.sellCityName"
                  placeholder="请输入城市"
                />
              </el-form-item>
            </el-col>
          </el-row>
          <el-row style="margin-top: 20px; width: 100%">
            <el-col :span="24">
              <el-form-item prop="sellAddress">
                <el-input v-model="formData.data.sellAddress" type="textarea">
                </el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row style="margin-top: 20px; width: 100%">
            <el-col :span="8">
              <el-form-item label="联系人" prop="sellContactName">
                <el-input
                  v-model="formData.data.sellContactName"
                  placeholder="请输入联系人"
                />
              </el-form-item>
            </el-col>
            <el-col :span="1"></el-col>
            <el-col :span="15">
              <el-form-item label=" " prop="sellContactNumber">
                <el-input
                  v-model="formData.data.sellContactNumber"
                  placeholder="请输入联系人电话"
                />
              </el-form-item>
            </el-col>
          </el-row>
        </div>
      </template>
      <template #buyer>
        <div style="width: 100%">
          <div style="width: 100%">
            <el-form-item prop="buyCorporationId">
              <el-select
                v-model="formData.data.buyCorporationId"
                filterable
                style="width: 100%"
                @change="changeCustomer"
              >
                <el-option
                  v-for="item in customerList"
                  :key="item.value"
                  :label="item.label"
                  :value="item.value"
                />
              </el-select>
            </el-form-item>
            <el-row style="margin-top: 20px; width: 100%">
              <el-col :span="6">
                <el-form-item label="地址" prop="countryId">
                  <el-select
                    v-model="formData.data.countryId"
                    placeholder="国家"
                    filterable
                    @change="(val) => getCityData(val, '20', true)"
                  >
                    <el-option
                      v-for="item in countryData"
                      :label="
                        formData.data.contractType == '2'
                          ? item.chineseName
                          : item.name
                      "
                      :value="item.id"
                    >
                    </el-option>
                  </el-select>
                </el-form-item>
              </el-col>
              <el-col :span="1"></el-col>
              <el-col :span="5">
                <el-form-item label=" " prop="provinceName">
                  <selectCity
                    placeholder="省/洲"
                    @change="(val) => getCityData(val, '30', true)"
                    addressId="provinceId"
                    addressName="provinceName"
                    v-model="formData.data"
                    :data="provinceData"
                  >
                  </selectCity>
                </el-form-item>
              </el-col>
              <el-col :span="1"></el-col>
              <el-col :span="5">
                <el-form-item label=" " prop="cityName">
                  <selectCity
                    placeholder="城市"
                    addressId="cityId"
                    addressName="cityName"
                    v-model="formData.data"
                    :data="cityData"
                  >
                  </selectCity>
                </el-form-item>
              </el-col>
              <el-col :span="1"></el-col>
              <el-col :span="5">
                <el-form-item label=" " prop="buyPostalCode">
                  <el-input
                    v-model="formData.data.buyPostalCode"
                    placeholder="请输入邮编"
                  />
                </el-form-item>
              </el-col>
            </el-row>
            <el-row style="margin-top: 20px; width: 100%">
              <el-col :span="24">
                <el-form-item prop="buyAddress">
                  <el-input v-model="formData.data.buyAddress" type="textarea">
                  </el-input>
                </el-form-item>
              </el-col>
            </el-row>
            <el-row style="margin-top: 20px; width: 100%">
              <el-col :span="8">
                <el-form-item label="联系人" prop="buyContactName">
                  <el-autocomplete
                    v-model="formData.data.buyContactName"
                    :fetch-suggestions="querySearchPerson"
                    clearable
                    class="inline-input w-50"
                    placeholder="请输入联系人"
                    @select="handlePerson"
                  >
                  </el-autocomplete>
                </el-form-item>
              </el-col>
              <el-col :span="1"></el-col>
              <el-col :span="15">
                <el-form-item label=" " prop="buyContactNumber">
                  <el-input
                    v-model="formData.data.buyContactNumber"
                    placeholder="请输入联系人电话"
                  />
                </el-form-item>
              </el-col>
            </el-row>
          </div>
        </div>
      </template>
      <template #commodity>
        <div style="width: 100%">
          <el-button @click="openProduct = true">添加商品</el-button>
          <el-table
            :data="formData.data.contractProductList"
            style="width: 100%; margin-top: 16px"
          >
            <el-table-column label="商品图片" width="80">
              <template #default="{ row }">
                <div v-if="row.fileUrl">
                  <img
                    :src="row.fileUrl"
                    class="pic"
                    @click="onPicture(row.fileUrl)"
                  />
                </div>
                <div v-else></div>
              </template>
            </el-table-column>
            <el-table-column prop="code" label="商品编码" width="120" />
            <el-table-column prop="name" label="商品中文名" width="160" />
            <el-table-column label="商品英文名" min-width="200">
              <template #default="{ row, $index }">
                <div style="width: 100%">
                  <el-form-item
                    :prop="'contractProductList.' + $index + '.productName'"
                    :rules="rules.productName"
                    :inline-message="true"
                  >
                    <el-input
                      v-model="row.productName"
                      placeholder="请输入商品英文名"
                    />
                  </el-form-item>
                </div>
              </template>
            </el-table-column>
            <el-table-column label="规格型号" width="180">
              <template #default="{ row, $index }">
                <div style="width: 100%">
                  <el-form-item
                    :prop="'contractProductList.' + $index + '.productModel'"
                    :inline-message="true"
                  >
                    <el-input
                      v-model="row.productModel"
                      placeholder="请输入规格型号"
                    />
                  </el-form-item>
                </div>
              </template>
            </el-table-column>
            <el-table-column
              prop="unit"
              label="单位"
              width="100"
              :formatter="(row) => dictValueLabel(row.unit, productUnit)"
            />
            <el-table-column label="数量" width="160">
              <template #default="{ row, $index }">
                <div style="width: 100%">
                  <el-form-item
                    :prop="'contractProductList.' + $index + '.quantity'"
                    :rules="rules.quantity"
                    :inline-message="true"
                  >
                    <el-input-number
                      onmousewheel="return false;"
                      v-model="row.quantity"
                      placeholder="请输入数量"
                      style="width: 100%"
                      :controls="false"
                      :min="0"
                      @change="
                        () => {
                          return calculationAmount(
                            'contractProductList',
                            $index,
                            'quantity'
                          );
                        }
                      "
                    />
                  </el-form-item>
                </div>
              </template>
            </el-table-column>
            <el-table-column label="单价" width="160">
              <template #default="{ row, $index }">
                <div style="width: 100%">
                  <el-form-item
                    :prop="'contractProductList.' + $index + '.price'"
                    :rules="rules.price"
                    :inline-message="true"
                  >
                    <el-input-number
                      onmousewheel="return false;"
                      v-model="row.price"
                      placeholder="请输入单价"
                      style="width: 100%"
                      :controls="false"
                      :min="0"
                      @change="
                        () => {
                          return calculationAmount(
                            'contractProductList',
                            $index,
                            'price'
                          );
                        }
                      "
                    />
                  </el-form-item>
                </div>
              </template>
            </el-table-column>
            <el-table-column prop="amount" label="金额" width="100" />
            <el-table-column
              align="center"
              label="操作"
              width="120"
              fixed="right"
            >
              <template #default="{ row, $index }">
                <el-button
                  type="primary"
                  link
                  @click="handleHandover(row, $index)"
                  >交接单</el-button
                >
                <el-button
                  type="primary"
                  link
                  @click="handleRemove($index, row)"
                  >删除</el-button
                >
              </template>
            </el-table-column>
          </el-table>
        </div>
      </template>
      <template #otherCharge>
        <div style="width: 100%">
          <el-button type="primary" @click="clickAdd()">添加行</el-button>
          <el-table
            :data="formData.data.contractProjectList"
            style="width: 100%; margin-top: 16px"
          >
            <el-table-column label="收费项目" width="220">
              <template #default="{ row, $index }">
                <div style="width: 100%">
                  <el-form-item
                    :prop="'contractProjectList.' + $index + '.payName'"
                    :rules="rules.payName"
                    :inline-message="true"
                  >
                    <el-autocomplete
                      v-model="row.payName"
                      :fetch-suggestions="querySearch"
                      clearable
                      class="inline-input w-50"
                      placeholder="请输入收费项目"
                    />
                  </el-form-item>
                </div>
              </template>
            </el-table-column>
            <el-table-column label="金额" width="180">
              <template #default="{ row, $index }">
                <div style="width: 100%">
                  <el-form-item
                    :prop="'contractProjectList.' + $index + '.amount'"
                    :rules="rules.amount"
                    :inline-message="true"
                  >
                    <el-input-number
                      onmousewheel="return false;"
                      v-model="row.amount"
                      placeholder="请输入金额"
                      style="width: 100%"
                      :controls="false"
                      :min="0"
                      @change="
                        () => {
                          return totalAmount(
                            'contractProjectList',
                            $index,
                            'amount'
                          );
                        }
                      "
                    />
                  </el-form-item>
                </div>
              </template>
            </el-table-column>
            <el-table-column label="备注">
              <template #default="{ row, $index }">
                <div style="width: 100%">
                  <el-form-item
                    :prop="'contractProjectList.' + $index + '.remark'"
                  >
                    <el-input v-model="row.remark" placeholder="请输入备注" />
                  </el-form-item>
                </div>
              </template>
            </el-table-column>
            <el-table-column
              align="center"
              label="操作"
              width="80"
              fixed="right"
            >
              <template #default="{ row, $index }">
                <el-button type="primary" link @click="handleDelete($index)"
                  >删除</el-button
                >
              </template>
            </el-table-column>
          </el-table>
        </div>
      </template>
      <template #offerMoney>
        <div style="width: 100%">
          <el-row style="margin-top: 20px; width: 100%">
            <el-col :span="4">
              <el-form-item label="币种" prop="currency">
                <el-select
                  v-model="formData.data.currency"
                  placeholder="请选择币种"
                  style="width: 100%"
                >
                  <el-option
                    v-for="item in accountCurrency"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value"
                  />
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="1"></el-col>
            <el-col :span="6">
              <el-form-item label="合同总金额" prop="amount">
                <el-input
                  v-model="formData.data.amount"
                  placeholder="合同总金额"
                  disabled
                />
              </el-form-item>
            </el-col>
          </el-row>
          <el-row style="margin-top: 20px; width: 100%">
            <el-col :span="6">
              <el-form-item label="付款方式" prop="paymentMethod">
                <el-select
                  v-model="formData.data.paymentMethod"
                  placeholder="请选择付款方式"
                  style="width: 100%"
                >
                  <el-option
                    v-for="item in fundsPaymentMethod"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value"
                  />
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="1"></el-col>
            <el-col :span="6">
              <el-form-item label="预付比例 (%)" prop="advanceRatio">
                <el-input-number
                  onmousewheel="return false;"
                  v-model="formData.data.advanceRatio"
                  placeholder="请输入预付比例"
                  style="width: 100%"
                  :precision="2"
                  :controls="false"
                  :min="0"
                  :max="100"
                />
              </el-form-item>
            </el-col>
            <el-col :span="1"></el-col>
            <el-col :span="6">
              <el-form-item label="收款账号" prop="shroffAccountId">
                <el-select
                  v-model="formData.data.shroffAccountId"
                  placeholder="请选择收款账号"
                  style="width: 100%"
                  @change="changeShroffAccount"
                >
                  <el-option
                    v-for="item in accountList"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value"
                  />
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="1"></el-col>
            <el-col :span="3">
              <el-form-item label="  ">
                <el-button type="primary" @click="changeActiveName" text>
                  <span v-if="activeName == '1'">收起</span>
                  <span v-else>展开</span>
                </el-button>
              </el-form-item>
            </el-col>
          </el-row>
          <div style="width: 100%; margin-top: 34px">
            <el-collapse v-model="activeName" class="hideCollapse" accordion>
              <el-collapse-item title="" name="1">
                <el-row style="width: 100%">
                  <el-col :span="9">
                    <el-form-item
                      label="Beneficiary Name"
                      prop="beneficiaryName"
                    >
                      <el-input
                        v-model="formData.data.beneficiaryName"
                        placeholder="请输入Beneficiary Name"
                      />
                    </el-form-item>
                    <div style="height: 20px"></div>
                    <el-form-item
                      label="Beneficiary Bank"
                      prop="beneficiaryBank"
                    >
                      <el-input
                        v-model="formData.data.beneficiaryBank"
                        placeholder="请输入Beneficiary Bank"
                      />
                    </el-form-item>
                    <div style="height: 20px"></div>
                    <el-form-item
                      label="Beneficiary Bank Address"
                      prop="beneficiaryBankAddress"
                    >
                      <el-input
                        v-model="formData.data.beneficiaryBankAddress"
                        placeholder="请输入Beneficiary Bank Address"
                      />
                    </el-form-item>
                  </el-col>
                  <el-col :span="9">
                    <el-form-item
                      label="Beneficiary Account Number"
                      prop="beneficiaryAccountNumber"
                    >
                      <el-input
                        v-model="formData.data.beneficiaryAccountNumber"
                        placeholder="请输入Beneficiary Account Number"
                      />
                    </el-form-item>
                    <div style="height: 20px"></div>
                    <el-form-item label="Swift Code" prop="swiftCode">
                      <el-input
                        v-model="formData.data.swiftCode"
                        placeholder="请输入Swift Code"
                      />
                    </el-form-item>
                    <div style="height: 20px"></div>
                    <el-form-item
                      label="Beneficiary Address"
                      prop="beneficiaryAddress"
                    >
                      <el-input
                        v-model="formData.data.beneficiaryAddress"
                        placeholder="请输入Beneficiary Address"
                      />
                    </el-form-item>
                  </el-col>
                </el-row>
              </el-collapse-item>
            </el-collapse>
          </div>
        </div>
      </template>
      <template #delivery>
        <div style="width: 100%">
          <el-row style="margin-top: 20px; width: 100%">
            <el-col :span="7">
              <el-form-item label="贸易方式" prop="tradeMethods">
                <el-select
                  v-model="formData.data.tradeMethods"
                  placeholder="请选择贸易方式"
                  style="width: 100%"
                >
                  <el-option
                    v-for="item in tradeMethods"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value"
                  />
                </el-select>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row style="margin-top: 20px; width: 100%">
            <el-col :span="7">
              <el-form-item label="运输方式" prop="transportMethod">
                <el-select
                  v-model="formData.data.transportMethod"
                  placeholder="请选择运输方式"
                  style="width: 100%"
                >
                  <el-option
                    v-for="item in shippingMethod"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value"
                  />
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="1"></el-col>
            <el-col :span="7">
              <el-form-item label="运输说明" prop="transportRemark">
                <el-input
                  v-model="formData.data.transportRemark"
                  placeholder="请输入运输说明"
                />
              </el-form-item>
            </el-col>
          </el-row>
          <el-row style="margin-top: 20px; width: 100%">
            <el-col :span="15">
              <el-form-item label="付款条件" prop="remark">
                <el-input
                  v-model="formData.data.remark"
                  :rows="2"
                  type="textarea"
                  placeholder="请输入付款条件"
                />
              </el-form-item>
            </el-col>
          </el-row>
          <el-row style="margin-top: 20px; width: 100%">
            <el-col :span="7">
              <el-form-item label="交货期限 (天)" prop="deliveryTime">
                <el-input-number
                  onmousewheel="return false;"
                  v-model="formData.data.deliveryTime"
                  placeholder="请输入交货期限"
                  style="width: 100%"
                  :precision="0"
                  :controls="false"
                  :min="0"
                />
              </el-form-item>
            </el-col>
            <el-col :span="1"></el-col>
            <el-col :span="7">
              <el-form-item label="质保期 (天)" prop="warranty">
                <el-input-number
                  onmousewheel="return false;"
                  v-model="formData.data.warranty"
                  placeholder="请输入质保期"
                  style="width: 100%"
                  :precision="0"
                  :controls="false"
                  :min="0"
                />
              </el-form-item>
            </el-col>
          </el-row>
        </div>
      </template>
      <template #shipment>
        <div style="width: 100%">
          <el-table
            :data="formData.data.contractShipmentList"
            style="width: 100%; margin-top: 16px"
          >
            <el-table-column prop="code" label="商品编码" width="120" />
            <el-table-column prop="productName" label="商品名称" />
            <el-table-column label="出货日期" width="220">
              <template #default="{ row, $index }">
                <div style="width: 100%">
                  <el-form-item
                    :prop="'contractShipmentList.' + $index + '.shipmentTime'"
                    :rules="rules.shipmentTime"
                    :inline-message="true"
                  >
                    <el-date-picker
                      v-model="row.shipmentTime"
                      type="date"
                      placeholder="请选择出货日期"
                      value-format="YYYY-MM-DD HH:mm:ss"
                    />
                  </el-form-item>
                </div>
              </template>
            </el-table-column>
            <el-table-column label="数量" width="160">
              <template #default="{ row, $index }">
                <div style="width: 100%">
                  <el-form-item
                    :prop="'contractShipmentList.' + $index + '.quantity'"
                    :inline-message="true"
                  >
                    <el-input-number
                      onmousewheel="return false;"
                      v-model="row.quantity"
                      placeholder="请输入数量"
                      style="width: 100%"
                      :controls="false"
                      :min="0"
                      @change="
                        () => {
                          return calculationAmount(
                            'contractShipmentList',
                            $index,
                            'quantity'
                          );
                        }
                      "
                    />
                  </el-form-item>
                </div>
              </template>
            </el-table-column>
            <el-table-column
              align="center"
              label="操作"
              width="120"
              fixed="right"
            >
              <template #default="{ row, $index }">
                <el-button type="primary" link @click="clickSplit(row)"
                  >拆分</el-button
                >
                <el-button type="primary" link @click="clickDelete($index)"
                  >删除</el-button
                >
              </template>
            </el-table-column>
          </el-table>
        </div>
      </template>
    </byForm>

    <el-dialog
      v-if="openProduct"
      v-model="openProduct"
      title="选择商品"
      width="70%"
      append-to-body
    >
      <SelectGoods
        :selectList="acquireSelectList()"
        @cancel="openProduct = false"
        @pushGoods="pushGoods"
      ></SelectGoods>
    </el-dialog>

    <el-dialog
      title="交接单"
      v-if="openHandover"
      v-model="openHandover"
      width="800"
    >
      <byForm
        :formConfig="formHandoverConfig"
        :formOption="formOption"
        v-model="productRow.data"
      >
        <template #remark>
          <div style="width: 100%">
            <Editor
              :value="productRow.data.remark"
              @updateValue="updateContent"
            />
          </div>
        </template>
        <template #file>
          <div style="width: 100%">
            <el-upload
              v-model:fileList="fileList"
              action="https://winfaster.obs.cn-south-1.myhuaweicloud.com"
              :data="uploadData"
              multiple
              :before-upload="uploadFile"
              :on-success="handleSuccess"
              :on-preview="onPreviewFile"
            >
              <el-button>选择</el-button>
            </el-upload>
          </div>
        </template>
      </byForm>
      <template #footer>
        <el-button @click="openHandover = false" size="large">取 消</el-button>
        <el-button type="primary" @click="submitHandoverForm()" size="large"
          >确 定</el-button
        >
      </template>
    </el-dialog>
  </div>
</template>

<script setup>
import byForm from "@/components/byForm/index";
import SelectGoods from "@/components/product/SelectGoods";
import { ElMessage } from "element-plus";
import Editor from "@/components/Editor/index.vue";
import selectCity from "@/components/selectCity/index.vue";
import { useRoute } from "vue-router";

const route = useRoute();
// 接收父组件的传值
const props = defineProps({
  queryData: String,
});
const { proxy } = getCurrentInstance();
const contractType = ref([]);
const accountCurrency = ref([]);
const fundsPaymentMethod = ref([]);
const tradeMethods = ref([]);
const shippingMethod = ref([]);
const templateList = ref([]);
const corporationList = ref([]);
const customerList = ref([]);
const countryData = ref([]);
const provinceData = ref([]);
const cityData = ref([]);
const customerUserList = ref([]);
const accountList = ref([]);
const productUnit = ref([]);
const openProduct = ref(false);
const activeName = ref("1");
const formData = reactive({
  data: {
    contractType: "1",
    amount: undefined,
    contractProductList: [],
    contractProjectList: [],
    contractShipmentList: [],
  },
});
const submit = ref(null);
const judgeStatus = () => {
  if (route.query.processType == 20 || route.query.processType == 10) {
    return true;
  }
  if (props.queryData.recordList && props.queryData.recordList.length > 0) {
    let data = props.queryData.recordList.filter(
      (item) => item.status === 2 && item.nodeType !== 1
    );
    if (data && data.length > 0) {
      return true;
    }
  }
  return false;
};
const formOption = reactive({
  inline: true,
  labelWidth: 100,
  itemWidth: 100,
  rules: [],
  disabled: false,
});
const formConfig = computed(() => {
  return [
    {
      type: "title",
      title: "合同模板",
      label: "",
    },
    {
      type: "select",
      label: "合同类型",
      prop: "contractType",
      data: contractType.value,
      itemWidth: 25,
    },
    {
      type: "select",
      label: "选择合同模板",
      prop: "contractTemplateId",
      data: templateList.value,
      fn: (val) => {
        changeTemplate(val);
      },
      itemWidth: 26,
    },
    {
      type: "slot",
      slotName: "seller",
      label: "卖方信息",
      itemWidth: 50,
    },
    {
      type: "slot",
      slotName: "buyer",
      label: "买方信息",
      itemWidth: 50,
    },
    {
      type: "slot",
      slotName: "commodity",
      label: "商品信息",
    },
    {
      type: "slot",
      slotName: "otherCharge",
      label: "其他收费项目",
    },
    {
      type: "slot",
      slotName: "offerMoney",
      label: "收款信息",
    },
    {
      type: "slot",
      slotName: "delivery",
      label: "交付信息",
    },
    {
      type: "slot",
      slotName: "shipment",
      label: "出货计划",
    },
  ];
});
const rules = ref({
  contractType: [
    { required: true, message: "请选择合同类型", trigger: "change" },
  ],
  contractTemplateId: [
    { required: true, message: "请选择合同模板", trigger: "change" },
  ],
  buyCorporationId: [
    { required: true, message: "请选择公司", trigger: "change" },
  ],
  countryId: [{ required: true, message: "请选择国家", trigger: "change" }],
  sellAddress: [{ required: true, message: "请输入详细地址", trigger: "blur" }],
  buyAddress: [{ required: true, message: "请输入详细地址", trigger: "blur" }],
  buyContactName: [
    { required: true, message: "请输入联系人", trigger: ["change", "blur"] },
  ],
  buyContactNumber: [
    { required: true, message: "请输入联系电话", trigger: "blur" },
  ],
  productName: [
    { required: true, message: "请输入商品英文名", trigger: "blur" },
  ],
  productModel: [
    { required: true, message: "请输入规格型号", trigger: "blur" },
  ],
  quantity: [{ required: true, message: "请输入数量", trigger: "blur" }],
  price: [{ required: true, message: "请输入单价", trigger: "blur" }],
  amount: [{ required: true, message: "请输入金额", trigger: "blur" }],
  payName: [
    { required: true, message: "请输入收费项目", trigger: ["change", "blur"] },
  ],
  currency: [{ required: true, message: "请选择币种", trigger: "change" }],
  effective: [{ required: true, message: "请输入报价有效期", trigger: "blur" }],
  deliveryTime: [
    { required: true, message: "请选择交货期限", trigger: "blur" },
  ],
  paymentMethod: [
    { required: true, message: "请选择付款方式", trigger: "change" },
  ],
  advanceRatio: [
    { required: true, message: "请输入预付比例", trigger: "blur" },
  ],
  shroffAccountId: [
    { required: true, message: "请选择收款账号", trigger: "change" },
  ],
  tradeMethods: [
    { required: true, message: "请选择贸易方式", trigger: "change" },
  ],
  transportMethod: [
    { required: true, message: "请选择运输方式", trigger: "change" },
  ],
  transportRemark: [
    { required: true, message: "请输入运输说明", trigger: "blur" },
  ],
  remark: [{ required: true, message: "请输入付款条件", trigger: "blur" }],
});
const getDict = () => {
  proxy
    .getDictOne([
      "account_currency",
      "funds_payment_method",
      "trade_mode",
      "shipping_method",
      "contract_type",
      "unit",
    ])
    .then((res) => {
      accountCurrency.value = res["account_currency"].map((x) => ({
        label: x.dictValue,
        value: x.dictKey,
      }));
      fundsPaymentMethod.value = res["funds_payment_method"].map((x) => ({
        label: x.dictValue,
        value: x.dictKey,
      }));
      tradeMethods.value = res["trade_mode"].map((x) => ({
        label: x.dictValue,
        value: x.dictKey,
      }));
      shippingMethod.value = res["shipping_method"].map((x) => ({
        label: x.dictValue,
        value: x.dictKey,
      }));
      contractType.value = res["contract_type"].map((x) => ({
        label: x.dictValue,
        value: x.dictKey,
      }));
      productUnit.value = res["unit"].map((x) => ({
        label: x.dictValue,
        value: x.dictKey,
      }));
    });

  proxy
    .post("/contractTemplate/page", { pageNum: 1, pageSize: 999 })
    .then((res) => {
      templateList.value = res.rows.map((item) => {
        return {
          ...item,
          label: item.templateName,
          value: item.id,
        };
      });
    });
  proxy.post("/corporation/page", { pageNum: 1, pageSize: 999 }).then((res) => {
    corporationList.value = res.rows.map((item) => {
      return {
        ...item,
        label: item.name,
        value: item.id,
      };
    });
  });
  proxy
    .post("/accountManagement/page", { pageNum: 1, pageSize: 999 })
    .then((res) => {
      accountList.value = res.rows.map((item) => {
        return {
          ...item,
          label: item.alias,
          value: item.id,
        };
      });
    });
};
getDict();
const changeTemplate = (val) => {
  formData.data.sellCorporationId = "";
  formData.data.sellContactName = "";
  formData.data.sellContactNumber = "";
  formData.data.sellCountryName = "";
  formData.data.sellProvinceName = "";
  formData.data.sellCityName = "";
  formData.data.sellAddress = "";
  if (val) {
    proxy.post("/contractTemplate/detail", { id: val }).then((res) => {
      formData.data.sellCorporationId = res.corporationId;
      if (res.corporationId) {
        proxy
          .post("/corporation/detail", { id: res.corporationId })
          .then((detailCorporation) => {
            if (detailCorporation.countryEnStr) {
              formData.data.sellCountryName = detailCorporation.countryEnStr;
            }
            if (detailCorporation.provinceEnStr) {
              formData.data.sellProvinceName = detailCorporation.provinceEnStr;
            }
            if (detailCorporation.cityEnStr) {
              formData.data.sellCityName = detailCorporation.cityEnStr;
            }
            if (detailCorporation.addressEn) {
              formData.data.sellAddress = detailCorporation.addressEn;
            }
            // proxy.post("/customizeArea/list", { parentId: "0" }).then((resCountry) => {
            //   let sellCountryData = resCountry.filter((item) => item.id === detailCorporation.countryId);
            //   if (sellCountryData && sellCountryData.length > 0) {
            //     formData.data.sellCountryName = sellCountryData[0].chineseName;
            //   } else {
            //     formData.data.sellCountryName = "";
            //   }
            // });
            // if (detailCorporation.countryId) {
            //   proxy
            //     .post("/customizeArea/list", {
            //       parentId: detailCorporation.countryId,
            //     })
            //     .then((resProvince) => {
            //       let sellProvinceData = resProvince.filter((item) => item.id === detailCorporation.provinceId);
            //       if (sellProvinceData && sellProvinceData.length > 0) {
            //         formData.data.sellProvinceName = sellProvinceData[0].name;
            //       } else {
            //         formData.data.sellProvinceName = "";
            //       }
            //     });
            // } else {
            //   formData.data.sellProvinceName = "";
            // }
            // if (detailCorporation.provinceId) {
            //   proxy
            //     .post("/customizeArea/list", {
            //       parentId: detailCorporation.provinceId,
            //     })
            //     .then((resCity) => {
            //       let sellCityData = resCity.filter((item) => item.id === detailCorporation.cityId);
            //       if (sellCityData && sellCityData.length > 0) {
            //         formData.data.sellCityName = sellCityData[0].name;
            //       } else {
            //         formData.data.sellCityName = "";
            //       }
            //     });
            // } else {
            //   formData.data.sellCityName = "";
            // }
            // formData.data.sellAddress = detailCorporation.address;
          });
      }
      formData.data.sellContactName = res.contactName;
      formData.data.sellContactNumber = res.contactNumber;
    });
  }
};
const getCityData = (id, type, isChange) => {
  proxy.post("/customizeArea/list", { parentId: id }).then((res) => {
    if (type === "20") {
      provinceData.value = res;
      if (isChange) {
        formData.data.provinceId = "";
        formData.data.provinceName = "";
        formData.data.cityId = "";
        formData.data.cityName = "";
      }
    } else if (type === "30") {
      cityData.value = res;
      if (isChange) {
        formData.data.cityId = "";
        formData.data.cityName = "";
      }
    } else {
      countryData.value = res;
    }
  });
};
getCityData("0");
const changeCustomer = (val) => {
  formData.data.buyContactName = "";
  formData.data.buyContactNumber = "";
  if (val) {
    proxy.post("/customer/detail", { id: val }).then(
      (res) => {
        if (res.customerUserList && res.customerUserList.length > 0) {
          formData.data.buyContactName = res.customerUserList[0].name;
          if (res.customerUserList[0].contactJson) {
            let contactJson = JSON.parse(res.customerUserList[0].contactJson);
            if (contactJson && contactJson.length > 0) {
              formData.data.buyContactNumber = contactJson[0].contactNo;
            }
          }
          customerUserList.value = res.customerUserList.map((item) => {
            return {
              ...item,
              value: item.name,
            };
          });
        }
        formData.data.countryId = res.countryId;
        formData.data.provinceId = res.provinceId;
        formData.data.cityId = res.cityId;
        formData.data.buyPostalCode = res.zipCode;
        formData.data.buyAddress = res.address;
        getCityData(formData.data.countryId, "20");
        if (formData.data.provinceId) {
          getCityData(formData.data.provinceId, "30");
        }
      },
      (err) => {
        console.log(err);
        formData.data.countryId = "";
        formData.data.provinceId = "";
        formData.data.cityId = "";
        formData.data.buyPostalCode = "";
        formData.data.buyAddress = "";
      }
    );
  } else {
    formData.data.countryId = "";
    formData.data.provinceId = "";
    formData.data.cityId = "";
    formData.data.buyPostalCode = "";
    formData.data.buyAddress = "";
  }
  getDecisionAids();
};
let auxiliaryData = ref([
  {
    label: "最近合同",
    data: [],
  },
  {
    label: "产品价格",
    data: [],
  },
]);
const emit = defineEmits(["auxiliaryChange"]);
const getDecisionAids = () => {
  let data = {
    buyCorporationId: formData.data.buyCorporationId,
    productIdList: [],
  };
  if (
    formData.data.contractProductList &&
    formData.data.contractProductList.length > 0
  ) {
    data.productIdList = formData.data.contractProductList.map(
      (item) => item.productId
    );
  }
  proxy.post("/contract/decisionAid", data).then((res) => {
    if (res.lastContractList && res.lastContractList.length > 0) {
      auxiliaryData.value[0].data = res.lastContractList.map((item) => {
        return [
          {
            label: "合同编号",
            value: item.code,
            style: {
              color: "#0084FF",
            },
            id: item.id,
            num: 1,
            // fn: () => {},
          },
          {
            label: "下单日期",
            value: item.createTime,
            id: item.id,
            num: 1,
          },
          {
            label: "合同金额",
            value: item.currency + item.amount,
            id: item.id,
            num: 1,
          },
        ];
      });
    } else {
      auxiliaryData.value[0].data = [];
    }
    if (res.productPriceList && res.productPriceList.length > 0) {
      auxiliaryData.value[1].data = res.productPriceList.map((item) => {
        return [
          {
            label: "产品名称",
            value: item.name,
            id: item.id,
            num: 1,
          },
          {
            label: "最近价格",
            value: item.lastPrice,
            id: item.id,
            num: 1,
          },
          {
            label: "历史最高",
            value: item.maxPrice,
            id: item.id,
            num: 1,
          },
          {
            label: "历史最低",
            value: item.minPrice,
            id: item.id,
            num: 1,
          },
        ];
      });
    } else {
      auxiliaryData.value[1].data = [];
    }
    emit("auxiliaryChange", auxiliaryData.value);
  });
};
const createFilter = (queryString) => {
  return (restaurant) => {
    return (
      restaurant.value.toLowerCase().indexOf(queryString.toLowerCase()) === 0
    );
  };
};
const querySearchPerson = (queryString, callback) => {
  const results = queryString
    ? customerUserList.value.filter(createFilter(queryString))
    : customerUserList.value;
  callback(results);
};
const handlePerson = (item) => {
  if (item.contactJson) {
    let contactJson = JSON.parse(item.contactJson);
    if (contactJson && contactJson.length > 0) {
      formData.data.buyContactNumber = contactJson[0].contactNo;
    } else {
      formData.data.buyContactNumber = "";
    }
  }
};
const pushGoods = (goods) => {
  if (goods && goods.length > 0) {
    let afterFiltering = [];
    if (
      formData.data.contractProductList &&
      formData.data.contractProductList.length > 0
    ) {
      afterFiltering = goods.filter((item) => {
        let data = formData.data.contractProductList.filter(
          (itemProduct) => itemProduct.productId === item.id
        );
        if (data && data.length > 0) {
          return false;
        }
        return true;
      });
    } else {
      afterFiltering = goods;
    }
    formData.data.contractProductList =
      formData.data.contractProductList.concat(
        afterFiltering.map((item) => {
          let fileUrl = "";
          if (item.fileList && item.fileList.length > 0) {
            fileUrl = item.fileList[0].fileUrl;
          }
          let name = item.name;
          if (item.standardJson) {
            let standardJson = JSON.parse(item.standardJson);
            if (standardJson && standardJson.englishName) {
              name = standardJson.englishName;
            }
          }
          return {
            fileUrl: fileUrl,
            code: item.code,
            productId: item.id,
            name: item.name,
            productName: name,
            productModel: item.spec,
            unit: item.unit,
            quantity: undefined,
            price: undefined,
            amount: "",
            remark: "",
            fileList: [],
          };
        })
      );
    formData.data.contractShipmentList =
      formData.data.contractShipmentList.concat(
        afterFiltering.map((item) => {
          return {
            code: item.code,
            productId: item.id,
            productName: item.name,
            shipmentTime: "",
            quantity: undefined,
          };
        })
      );
    ElMessage({
      message: "添加成功!",
      type: "success",
    });
    openProduct.value = false;
    getDecisionAids();
  } else {
    ElMessage("请选择至少一件商品");
  }
};
const onPicture = (path) => {
  window.open(path, "_blank");
};
const productRow = reactive({
  data: {
    productName: "",
    productModel: "",
    remark: "",
  },
});
const productIndex = ref(0);
const openHandover = ref(false);
const fileList = ref([]);
const uploadData = ref({});
const formHandoverConfig = computed(() => {
  return [
    {
      type: "title",
      title: "产品信息",
      label: "",
    },
    {
      type: "input",
      prop: "productName",
      label: "产品名称",
      itemType: "text",
      disabled: true,
    },
    {
      type: "input",
      prop: "productModel",
      label: "规格型号",
      itemType: "text",
      disabled: true,
    },
    {
      type: "slot",
      slotName: "remark",
      label: "交接单",
    },
    {
      type: "slot",
      prop: "file",
      slotName: "file",
      label: "上传附件",
    },
  ];
});
const handleHandover = (row, index) => {
  productRow.data = {
    productName: row.productName,
    productModel: row.productModel,
    remark: row.remark,
  };
  if (row.fileList && row.fileList.length > 0) {
    fileList.value = row.fileList.map((item) => {
      return {
        raw: item,
        name: item.fileName,
        url: item.fileUrl,
      };
    });
  } else {
    fileList.value = [];
  }
  productIndex.value = index;
  openHandover.value = true;
};
const updateContent = (val) => {
  productRow.data.remark = val;
};
const changeActiveName = () => {
  if (activeName.value) {
    activeName.value = "";
  } else {
    activeName.value = "1";
  }
};
const uploadFile = async (file) => {
  const res = await proxy.post("/fileInfo/getSing", { fileName: file.name });
  uploadData.value = res.uploadBody;
  file.id = res.id;
  file.fileName = res.fileName;
  file.fileUrl = res.fileUrl;
  file.uploadState = true;
  return true;
};
const handleSuccess = (any, UploadFile) => {
  UploadFile.raw.uploadState = false;
};
const onPreviewFile = (file) => {
  window.open(file.raw.fileUrl, "_blank");
};
const submitHandoverForm = () => {
  if (fileList.value && fileList.value.length > 0) {
    for (let i = 0; i < fileList.value.length; i++) {
      if (fileList.value[i].raw.uploadState) {
        ElMessage("文件上传中,请稍后提交");
        return;
      }
    }
    formData.data.contractProductList[productIndex.value].fileList =
      fileList.value.map((item) => {
        return {
          id: item.raw.id,
          fileName: item.raw.fileName,
          fileUrl: item.raw.fileUrl,
          uploadState: item.raw.uploadState,
        };
      });
  } else {
    formData.data.contractProductList[productIndex.value].fileList = [];
  }
  formData.data.contractProductList[productIndex.value].remark =
    productRow.data.remark;
  openHandover.value = false;
};
const handleRemove = async (index, row) => {
  formData.data.contractShipmentList =
    formData.data.contractShipmentList.filter(
      (item) => item.productId !== row.productId
    );
  await formData.data.contractProductList.splice(index, 1);
  totalAmount();
  getDecisionAids();
};
const calculationAmount = (listLabel, index, label) => {
  if (formData.data[listLabel][index][label]) {
    formData.data[listLabel][index][label] = Number(
      Math.round(Number(formData.data[listLabel][index][label]) * 10000) / 10000
    );
  }
  nextTick(() => {
    if (
      formData.data.contractProductList &&
      formData.data.contractProductList.length > 0
    ) {
      for (let i = 0; i < formData.data.contractProductList.length; i++) {
        let money = 0;
        if (
          formData.data.contractProductList[i].quantity &&
          formData.data.contractProductList[i].price
        ) {
          money = Number(
            Math.round(
              Number(formData.data.contractProductList[i].quantity) *
                Number(formData.data.contractProductList[i].price) *
                10000
            ) / 10000
          );
        }
        formData.data.contractProductList[i].amount = money;
      }
    }
    nextTick(() => {
      totalAmount();
    });
  });
};
const totalAmount = (listLabel, index, label) => {
  if (listLabel && formData.data[listLabel][index][label]) {
    formData.data[listLabel][index][label] = Number(
      Math.round(Number(formData.data[listLabel][index][label]) * 10000) / 10000
    );
  }
  let money = 0;
  if (
    formData.data.contractProductList &&
    formData.data.contractProductList.length > 0
  ) {
    for (let i = 0; i < formData.data.contractProductList.length; i++) {
      if (formData.data.contractProductList[i].amount) {
        money = Number(
          Math.round(
            (Number(money) +
              Number(formData.data.contractProductList[i].amount)) *
              10000
          ) / 10000
        );
      }
    }
  }
  if (
    formData.data.contractProjectList &&
    formData.data.contractProjectList.length > 0
  ) {
    for (let i = 0; i < formData.data.contractProjectList.length; i++) {
      if (formData.data.contractProjectList[i].amount) {
        money = Number(
          Math.round(
            (Number(money) +
              Number(formData.data.contractProjectList[i].amount)) *
              10000
          ) / 10000
        );
      }
    }
  }
  formData.data.amount = money;
};
const clickAdd = () => {
  if (
    formData.data.contractProjectList &&
    formData.data.contractProjectList.length > 0
  ) {
    formData.data.contractProjectList.push({
      payName: "",
      amount: undefined,
      remark: "",
    });
  } else {
    formData.data.contractProjectList = [
      { payName: "", amount: undefined, remark: "" },
    ];
  }
};
const handleDelete = async (index) => {
  await formData.data.contractProjectList.splice(index, 1);
  totalAmount();
};
const querySearch = (queryString, callback) => {
  proxy.post("/quotationPay/page", { payName: queryString }).then((res) => {
    if (res.rows && res.rows.length > 0) {
      res.rows = res.rows.map((item) => {
        return {
          ...item,
          value: item.payName,
        };
      });
      callback(res.rows);
    } else {
      callback([]);
    }
  });
};
const clickSplit = (item) => {
  formData.data.contractShipmentList.push({
    code: item.code,
    productId: item.productId,
    productName: item.productName,
    shipmentTime: "",
    quantity: undefined,
  });
};
const clickDelete = (index) => {
  formData.data.contractShipmentList.splice(index, 1);
};

const handleSubmit = async () => {
  let status = await submit.value.handleSubmit(() => {});
  if (status) {
    if (
      !(
        formData.data.contractProductList &&
        formData.data.contractProductList.length > 0
      )
    ) {
      ElMessage("请添加至少一件商品");
      return false;
    }
    if (
      formData.data.contractShipmentList &&
      formData.data.contractShipmentList.length > 0
    ) {
      for (let i = 0; i < formData.data.contractProductList.length; i++) {
        let data = formData.data.contractShipmentList.filter(
          (item) =>
            item.productId === formData.data.contractProductList[i].productId
        );
        if (data && data.length > 0) {
          let quantity = 0;
          for (let j = 0; j < data.length; j++) {
            quantity = parseFloat(Number(quantity) + Number(data[j].quantity));
          }
          if (quantity > formData.data.contractProductList[i].quantity) {
            ElMessage("出货数量不能大于商品数量");
            return false;
          }
        }
      }
    }
    return true;
  } else {
    setTimeout(() => {
      const errorDiv = document.getElementsByClassName("is-error");
      errorDiv[0].scrollIntoView();
    }, 0);
  }
  return false;
};
const getFormData = () => {
  return proxy.deepClone(formData.data);
};
// 向父组件暴露
defineExpose({
  getFormData,
  handleSubmit,
});
const changeShroffAccount = (val) => {
  if (val) {
    let data = accountList.value.filter((item) => item.value === val);
    if (data && data.length > 0) {
      formData.data.beneficiaryName = data[0].beneficiaryName;
      formData.data.beneficiaryBank = data[0].beneficiaryBank;
      formData.data.beneficiaryBankAddress = data[0].beneficiaryBankAddress;
      formData.data.beneficiaryAccountNumber = data[0].beneficiaryAccountNumber;
      formData.data.swiftCode = data[0].swiftCode;
      formData.data.beneficiaryAddress = data[0].beneficiaryAddress;
    }
  }
};
watch(
  props.queryData,
  () => {
    formOption.disabled = judgeStatus();
    if (
      props.queryData &&
      ["10", "20", "30"].includes(route.query.processType)
    ) {
      for (var text in props.queryData) {
        formData.data[text] = props.queryData[text];
      }
      if (formData.data.countryId) {
        getCityData(formData.data.countryId, "20");
      }
      if (formData.data.provinceId) {
        getCityData(formData.data.provinceId, "30");
      }
      getDecisionAids();
    }
  },
  {
    deep: true,
  }
);
const acquireSelectList = () => {
  let data = [];
  if (
    formData.data.contractProductList &&
    formData.data.contractProductList.length > 0
  ) {
    data = formData.data.contractProductList.map((item) => {
      return {
        id: item.productId,
        name: item.name,
      };
    });
  }
  return data;
};
onMounted(() => {
  if (!route.query.processType || route.query.processType == 30) {
    proxy
      .post("/customer/privateSeaPage", { pageNum: 1, pageSize: 999 })
      .then((res) => {
        customerList.value = res.rows.map((item) => {
          return {
            ...item,
            label: item.name,
            value: item.id,
          };
        });
      });
  } else {
    proxy.post("/customer/page", { pageNum: 1, pageSize: 999 }).then((res) => {
      customerList.value = res.rows.map((item) => {
        return {
          ...item,
          label: item.name,
          value: item.id,
        };
      });
    });
  }
  // 报价单生成合同
  if (props.queryData.priceSheetId) {
    proxy
      .post("/saleQuotation/detail", { id: props.queryData.priceSheetId })
      .then((res) => {
        res.countryId = res.buyCountryId;
        res.provinceId = res.buyProvinceId;
        res.cityId = res.buyCityId;
        for (var text in res) {
          formData.data[text] = res[text];
        }
        if (
          formData.data.quotationProductList &&
          formData.data.quotationProductList.length > 0
        ) {
          formData.data.contractProductList =
            formData.data.quotationProductList.map((item) => {
              delete item.id;
              return {
                ...item,
              };
            });
          formData.data.contractShipmentList = proxy.deepClone(
            formData.data.contractProductList.map((item) => {
              return {
                ...item,
                quantity: undefined,
              };
            })
          );
          for (let i = 0; i < formData.data.contractProductList.length; i++) {
            proxy
              .post("/productInfo/detail", {
                id: formData.data.contractProductList[i].productId,
              })
              .then((resProduct) => {
                let name = resProduct.name;
                if (resProduct.standardJson) {
                  let standardJson = JSON.parse(resProduct.standardJson);
                  if (standardJson && standardJson.englishName) {
                    name = standardJson.englishName;
                  }
                }
                formData.data.contractProductList[i].name = resProduct.name;
                formData.data.contractProductList[i].productName = name;
                formData.data.contractProductList[i].code = resProduct.code;
                formData.data.contractProductList[i].unit = resProduct.unit;
                formData.data.contractShipmentList[i].code = resProduct.code;
              });
          }
        }
        delete formData.data.id;
        delete formData.data.code;
        getCityData(formData.data.countryId, "20");
        if (formData.data.provinceId) {
          getCityData(formData.data.provinceId, "30");
        }
        if (
          formData.data.quotationPayList &&
          formData.data.quotationPayList.length > 0
        ) {
          formData.data.contractProjectList =
            formData.data.quotationPayList.map((item) => {
              delete item.id;
              return {
                ...item,
              };
            });
        }
      });
  }
  if (route.query && route.query.businessId) {
    proxy
      .post("/contract/detail", { id: route.query.businessId })
      .then((res) => {
        setTimeout(() => {
          formData.data.id = res.id;
          for (let i = 0; i < formData.data.contractProductList.length; i++) {
            formData.data.contractProductList[i].id =
              res.contractProductList[i].id;
          }
          for (let i = 0; i < formData.data.contractProjectList.length; i++) {
            formData.data.contractProjectList[i].id =
              res.contractProjectList[i].id;
          }
          for (let i = 0; i < formData.data.contractShipmentList.length; i++) {
            formData.data.contractShipmentList[i].id =
              res.contractShipmentList[i].id;
          }
        }, 2000);
      });
  }
  // 暂存修改
  if (!route.query.processType && route.query.contractId) {
    proxy
      .post("/contract/detail", { id: route.query.contractId })
      .then((res) => {
        if (res && res.dataJson) {
          res = { ...res, ...JSON.parse(res.dataJson) };
        }
        res.countryId = res.buyCountryId;
        res.provinceId = res.buyProvinceId;
        res.cityId = res.buyCityId;
        for (var text in res) {
          if (text === "contractType") {
            formData.data[text] = res[text] + "";
          } else {
            formData.data[text] = res[text];
          }
        }
        getCityData(formData.data.countryId, "20");
        if (formData.data.provinceId) {
          getCityData(formData.data.provinceId, "30");
        }
        if (
          formData.data.contractProductList &&
          formData.data.contractProductList.length > 0
        ) {
          let productIds = formData.data.contractProductList.map(
            (item) => item.productId
          );
          proxy
            .post("/fileInfo/getList", { businessIdList: productIds })
            .then((resFile) => {
              for (
                let i = 0;
                i < formData.data.contractProductList.length;
                i++
              ) {
                if (
                  resFile[formData.data.contractProductList[i].productId] &&
                  resFile[formData.data.contractProductList[i].productId]
                    .length > 0
                ) {
                  formData.data.contractProductList[i].fileUrl =
                    resFile[
                      formData.data.contractProductList[i].productId
                    ][0].fileUrl;
                }
              }
            });
          let ids = formData.data.contractProductList.map((item) => item.id);
          proxy
            .post("/fileInfo/getList", { businessIdList: ids })
            .then((resFile) => {
              for (
                let i = 0;
                i < formData.data.contractProductList.length;
                i++
              ) {
                if (
                  resFile[formData.data.contractProductList[i].id] &&
                  resFile[formData.data.contractProductList[i].id].length > 0
                ) {
                  formData.data.contractProductList[i].fileList =
                    resFile[formData.data.contractProductList[i].id];
                }
              }
            });
        }
      });
  }
});
</script>

<style lang="scss" scoped>
::v-deep(.el-input-number .el-input__inner) {
  text-align: left;
}
.pic {
  object-fit: contain;
  width: 50px;
  height: 50px;
  cursor: pointer;
  vertical-align: middle;
}
.shrinkPadding {
  padding-right: 0 !important;
}
.hideCollapse {
  margin-top: -62px;
  border: 0 !important;
}
::v-deep(.el-collapse-item__arrow) {
  display: none !important;
}
::v-deep(.el-collapse-item__wrap) {
  border: 0 !important;
}
::v-deep(.el-collapse-item__header) {
  border: 0 !important;
}
</style>