|
|
|
@ -43,6 +43,7 @@
|
|
|
|
|
:props="{ |
|
|
|
|
checkStrictly: true, |
|
|
|
|
}" |
|
|
|
|
@change="() => handleFindPrice()" |
|
|
|
|
filterable |
|
|
|
|
clearable |
|
|
|
|
> |
|
|
|
@ -62,7 +63,12 @@
|
|
|
|
|
remote |
|
|
|
|
reserve-keyword |
|
|
|
|
placeholder="目的仓" |
|
|
|
|
@change="destinationWarehouseNameChange" |
|
|
|
|
@change=" |
|
|
|
|
val => { |
|
|
|
|
destinationWarehouseNameChange(val); |
|
|
|
|
handleFindPrice(); |
|
|
|
|
} |
|
|
|
|
" |
|
|
|
|
:remote-method="remoteMethod" |
|
|
|
|
:loading="details.loadingObj.loading" |
|
|
|
|
> |
|
|
|
@ -86,13 +92,18 @@
|
|
|
|
|
<div class="flex-c table-row-title">发货方</div> |
|
|
|
|
<div> |
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label="发货单位:" prop="shipper"> |
|
|
|
|
<el-form-item |
|
|
|
|
label="发货单位:" |
|
|
|
|
prop="shipper" |
|
|
|
|
:class="!query.shipperId ? 'is-error' : ''" |
|
|
|
|
> |
|
|
|
|
<SelectBox |
|
|
|
|
:focus="handleCloseSelcet" |
|
|
|
|
:input="() => handleFindClientInfo('shipper', 1)" |
|
|
|
|
v-model="query.shipper" |
|
|
|
|
placeholder="发货单位" |
|
|
|
|
ref="shipper" |
|
|
|
|
:minWidth="true" |
|
|
|
|
> |
|
|
|
|
<el-table |
|
|
|
|
:data="details.shipperOptions" |
|
|
|
@ -111,13 +122,14 @@
|
|
|
|
|
<el-form-item label="发货人:" prop="shipperName"> |
|
|
|
|
<SelectBox |
|
|
|
|
:focus="handleCloseSelcet" |
|
|
|
|
:input="() => handleFindClientInfo('shipper')" |
|
|
|
|
:input="() => handleFindClientInfo('shipperName')" |
|
|
|
|
v-model="query.shipperName" |
|
|
|
|
placeholder="发货人" |
|
|
|
|
ref="shipperName" |
|
|
|
|
:minWidth="true" |
|
|
|
|
> |
|
|
|
|
<el-table |
|
|
|
|
:data="details.shipperOptions" |
|
|
|
|
:data="details.shipperNameOptions" |
|
|
|
|
style="width: 100%" |
|
|
|
|
@row-click="handleChooseShipper" |
|
|
|
|
v-loading="details.loadingObj.consignerLoading" |
|
|
|
@ -135,13 +147,14 @@
|
|
|
|
|
<el-form-item label="联系电话:" prop="shipperMobile"> |
|
|
|
|
<SelectBox |
|
|
|
|
:focus="handleCloseSelcet" |
|
|
|
|
:input="() => handleFindClientInfo('shipper')" |
|
|
|
|
:input="() => handleFindClientInfo('shipperMobile')" |
|
|
|
|
v-model="query.shipperMobile" |
|
|
|
|
placeholder="联系电话" |
|
|
|
|
ref="shipperMobile" |
|
|
|
|
:minWidth="true" |
|
|
|
|
> |
|
|
|
|
<el-table |
|
|
|
|
:data="details.shipperOptions" |
|
|
|
|
:data="details.shipperMobileOptions" |
|
|
|
|
style="width: 100%" |
|
|
|
|
@row-click="handleChooseShipper" |
|
|
|
|
v-loading="details.loadingObj.consignerLoading" |
|
|
|
@ -166,18 +179,28 @@
|
|
|
|
|
<div class="flex-c table-row-title">收货方</div> |
|
|
|
|
<div> |
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label="发货单位:" prop="consignee"> |
|
|
|
|
<el-form-item |
|
|
|
|
label="收货单位:" |
|
|
|
|
prop="consignee" |
|
|
|
|
:class="!query.consigneeId ? 'is-error' : ''" |
|
|
|
|
> |
|
|
|
|
<SelectBox |
|
|
|
|
:focus="handleCloseSelcet" |
|
|
|
|
:input="() => handleFindClientInfo('consignee', 1)" |
|
|
|
|
v-model="query.consignee" |
|
|
|
|
placeholder="收货人" |
|
|
|
|
placeholder="收货单位" |
|
|
|
|
ref="consignee" |
|
|
|
|
:minWidth="true" |
|
|
|
|
> |
|
|
|
|
<el-table |
|
|
|
|
:data="details.consignerOptions" |
|
|
|
|
:data="details.consigneeOptions" |
|
|
|
|
style="width: 100%" |
|
|
|
|
@row-click="handleChooseConsigner" |
|
|
|
|
@row-click=" |
|
|
|
|
(column, prop, order) => { |
|
|
|
|
handleChooseConsigner(column, prop, order); |
|
|
|
|
handleFindPrice(); |
|
|
|
|
} |
|
|
|
|
" |
|
|
|
|
v-loading="details.loadingObj.consignerLoading" |
|
|
|
|
> |
|
|
|
|
<el-table-column prop="clientName" label="发货单位" width="130" /> |
|
|
|
@ -191,15 +214,21 @@
|
|
|
|
|
<el-form-item label="收货人:" prop="consigneeName"> |
|
|
|
|
<SelectBox |
|
|
|
|
:focus="handleCloseSelcet" |
|
|
|
|
:input="() => handleFindClientInfo('consignee')" |
|
|
|
|
:input="() => handleFindClientInfo('consigneeName')" |
|
|
|
|
v-model="query.consigneeName" |
|
|
|
|
placeholder="收货人" |
|
|
|
|
ref="consigneeName" |
|
|
|
|
:minWidth="true" |
|
|
|
|
> |
|
|
|
|
<el-table |
|
|
|
|
:data="details.consignerOptions" |
|
|
|
|
:data="details.consigneeNameOptions" |
|
|
|
|
style="width: 100%" |
|
|
|
|
@row-click="handleChooseConsigner" |
|
|
|
|
@@row-click=" |
|
|
|
|
(column, prop, order) => { |
|
|
|
|
handleChooseConsigner(column, prop, order); |
|
|
|
|
handleFindPrice(); |
|
|
|
|
} |
|
|
|
|
" |
|
|
|
|
v-loading="details.loadingObj.consignerLoading" |
|
|
|
|
> |
|
|
|
|
<el-table-column prop="clientName" label="发货单位" width="130" /> |
|
|
|
@ -215,15 +244,21 @@
|
|
|
|
|
<el-form-item label="联系电话:" prop="consigneeMobile"> |
|
|
|
|
<SelectBox |
|
|
|
|
:focus="handleCloseSelcet" |
|
|
|
|
:input="() => handleFindClientInfo('consignee')" |
|
|
|
|
:input="() => handleFindClientInfo('consigneeMobile')" |
|
|
|
|
v-model="query.consigneeMobile" |
|
|
|
|
placeholder="联系电话" |
|
|
|
|
ref="consigneeMobile" |
|
|
|
|
:minWidth="true" |
|
|
|
|
> |
|
|
|
|
<el-table |
|
|
|
|
:data="details.consignerOptions" |
|
|
|
|
:data="details.consigneeMobileOptions" |
|
|
|
|
style="width: 100%" |
|
|
|
|
@row-click="handleChooseConsigner" |
|
|
|
|
@row-click=" |
|
|
|
|
(column, prop, order) => { |
|
|
|
|
handleChooseConsigner(column, prop, order); |
|
|
|
|
handleFindPrice(); |
|
|
|
|
} |
|
|
|
|
" |
|
|
|
|
v-loading="details.loadingObj.consignerLoading" |
|
|
|
|
> |
|
|
|
|
<el-table-column prop="clientName" label="发货单位" width="130" /> |
|
|
|
@ -291,6 +326,7 @@
|
|
|
|
|
</el-form-item> |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
<!-- 货物名称 --> |
|
|
|
|
<el-form-item |
|
|
|
|
label="货物名称:" |
|
|
|
|
label-width="fit-content" |
|
|
|
@ -300,7 +336,7 @@
|
|
|
|
|
<SelectBox |
|
|
|
|
ref="goodsNameRef" |
|
|
|
|
className="goodsName" |
|
|
|
|
:input="() => debounce(handleFindGoods(item.goodsName, item), 1000)" |
|
|
|
|
:input="() => debounce(handleFindGoods(item.goodsName, item, 1), 1000)" |
|
|
|
|
:focus="handleCloseSelcet" |
|
|
|
|
v-model="item.goodsName" |
|
|
|
|
placeholder="货物名称" |
|
|
|
@ -315,6 +351,7 @@
|
|
|
|
|
() => { |
|
|
|
|
item.goodsName = val.goodsName; |
|
|
|
|
item.goodsId = val.goodsId; |
|
|
|
|
handleFindPrice(item); |
|
|
|
|
handleCloseSelcet(); |
|
|
|
|
} |
|
|
|
|
" |
|
|
|
@ -825,7 +862,7 @@ import dayjs from 'dayjs';
|
|
|
|
|
import { mapGetters } from 'vuex'; |
|
|
|
|
/** 获取字典 */ |
|
|
|
|
import { getDictionaryBiz } from '@/api/system/dict'; |
|
|
|
|
import { downloadXls, computeNumber } from '@/utils/util'; |
|
|
|
|
import { downloadXls, computeNumber, debounce } from '@/utils/util'; |
|
|
|
|
import { getLazyTreeAll } from '@/api/base/region'; |
|
|
|
|
import { ElMessage, ElMessageBox } from 'element-plus'; |
|
|
|
|
import type { FormInstance, FormRules } from 'element-plus'; |
|
|
|
@ -842,6 +879,7 @@ import {
|
|
|
|
|
postUpdateWaybillVerify, |
|
|
|
|
postUpdateWaybill, |
|
|
|
|
postFindCategoryInfo, |
|
|
|
|
postFindArrPrice, |
|
|
|
|
} from '@/api/distribution/CreateOrder.js'; |
|
|
|
|
import { isNumber, getObjType } from '@/utils/util.js'; |
|
|
|
|
import { deepClone } from 'avue-plugin-ueditor/packages/ueditor/src/upload/util'; |
|
|
|
@ -967,6 +1005,36 @@ const details = reactive<any>({
|
|
|
|
|
totalObj: { |
|
|
|
|
/** 总件数 */ |
|
|
|
|
totalCount: computed(() => { |
|
|
|
|
let _deliveryFee = 0; |
|
|
|
|
let _warehouseManagementFee = 0; |
|
|
|
|
let _storageFee = 0; |
|
|
|
|
|
|
|
|
|
for (let index = 0; index < details.goodsList.length; index++) { |
|
|
|
|
const element = details.goodsList[index]; |
|
|
|
|
|
|
|
|
|
_deliveryFee = computeNumber( |
|
|
|
|
_deliveryFee, |
|
|
|
|
'+', |
|
|
|
|
computeNumber(element.deliveryFee || 0, '*', element.num || 0).result |
|
|
|
|
).result; |
|
|
|
|
|
|
|
|
|
_warehouseManagementFee = computeNumber( |
|
|
|
|
_warehouseManagementFee, |
|
|
|
|
'+', |
|
|
|
|
computeNumber(element.warehouseManagementFee || 0, '*', element.num || 0).result |
|
|
|
|
).result; |
|
|
|
|
|
|
|
|
|
_storageFee = computeNumber( |
|
|
|
|
_storageFee, |
|
|
|
|
'+', |
|
|
|
|
computeNumber(element.storageFee || 0, '*', element.num || 0).result |
|
|
|
|
).result; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
details.query.deliveryFee = _deliveryFee; |
|
|
|
|
details.query.warehouseManagementFee = _warehouseManagementFee; |
|
|
|
|
details.query.storageFee = _storageFee; |
|
|
|
|
|
|
|
|
|
return details.goodsList.reduce((curr, item) => { |
|
|
|
|
if (item.num) return curr + item.num; |
|
|
|
|
return curr; |
|
|
|
@ -1193,10 +1261,18 @@ const details = reactive<any>({
|
|
|
|
|
value: 6, |
|
|
|
|
}, |
|
|
|
|
], |
|
|
|
|
/** 收货方 */ |
|
|
|
|
consignerOptions: [], |
|
|
|
|
/** 发货方 */ |
|
|
|
|
/** 收货方 -- 收货单位 */ |
|
|
|
|
consigneeOptions: [], |
|
|
|
|
/** 收货方 -- 收货人 */ |
|
|
|
|
consigneeNameOptions: [], |
|
|
|
|
/** 收货方 -- 收货电话 */ |
|
|
|
|
consigneeMobileOptions: [], |
|
|
|
|
/** 发货方 -- 收货单位 */ |
|
|
|
|
shipperOptions: [], |
|
|
|
|
/** 收货方 -- 收货人 */ |
|
|
|
|
shipperNameOptions: [], |
|
|
|
|
/** 收货方 -- 收货电话 */ |
|
|
|
|
shipperMobileOptions: [], |
|
|
|
|
/** 必填 */ |
|
|
|
|
rules: { |
|
|
|
|
/** 发站仓名称 */ |
|
|
|
@ -1347,6 +1423,19 @@ const details = reactive<any>({
|
|
|
|
|
deepCloneGoodsList: [], |
|
|
|
|
/** 提交数据 */ |
|
|
|
|
submitData: {}, |
|
|
|
|
priceArr: [ |
|
|
|
|
/** 单价 */ |
|
|
|
|
{ name: '运费', key: 'price' }, |
|
|
|
|
/** 送货费 */ |
|
|
|
|
{ name: '配送费', key: 'deliveryFee' }, |
|
|
|
|
// { name: '提货费', key: 'pickupFee' }, |
|
|
|
|
/** 仓库管理费 */ |
|
|
|
|
{ name: '仓库管理费', key: 'warehouseManagementFee' }, |
|
|
|
|
/** 仓储费 */ |
|
|
|
|
{ name: '仓库存储费', key: 'storageFee' }, |
|
|
|
|
/** 装卸费 */ |
|
|
|
|
// { name: '仓库存储费', key: 'storageFee' }, |
|
|
|
|
], |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
const { query, data, drawerShow, loadingObj } = toRefs(details); |
|
|
|
@ -1529,6 +1618,35 @@ const initPageInfo = async () => {
|
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
for (let index = 0; index < details.goodsList.length; index++) { |
|
|
|
|
const element = details.goodsList[index]; |
|
|
|
|
|
|
|
|
|
const { arrPrice } = element; |
|
|
|
|
if (arrPrice && arrPrice.length > 0) { |
|
|
|
|
// 价格赋值 |
|
|
|
|
for (let i = 0; i < details.priceArr.length; i++) { |
|
|
|
|
const value = details.priceArr[i]; |
|
|
|
|
element[value.key] = 0; |
|
|
|
|
|
|
|
|
|
for (let index = 0; index < arrPrice.length; index++) { |
|
|
|
|
const item = arrPrice[index]; |
|
|
|
|
|
|
|
|
|
if (item.itemName === value.name) |
|
|
|
|
element[value.key] = isNumber(item.cost) ? Number(item.cost) : 0; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
handleFindGoods(element.goodsName, element); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (shipper) handleFindClientInfo('shipper'); |
|
|
|
|
if (shipperName) handleFindClientInfo('shipperName'); |
|
|
|
|
if (shipperMobile) handleFindClientInfo('shipperMobile'); |
|
|
|
|
if (consignee) handleFindClientInfo('consignee'); |
|
|
|
|
if (consigneeName) handleFindClientInfo('consigneeName'); |
|
|
|
|
if (consigneeMobile) handleFindClientInfo('consigneeMobile'); |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log('error :>> ', error); |
|
|
|
|
} finally { |
|
|
|
@ -1670,12 +1788,10 @@ const destinationWarehouseNameChange = val => {
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 查询货物 */ |
|
|
|
|
const handleFindGoods = async (goodsName, item) => { |
|
|
|
|
console.log('goodsNameRef :>> ', goodsNameRef); |
|
|
|
|
console.log('item :>> ', item); |
|
|
|
|
item.goodsId = ''; |
|
|
|
|
const handleFindGoods = async (goodsName, item, isClearId = 0) => { |
|
|
|
|
if (isClearId) item.goodsId = ''; |
|
|
|
|
|
|
|
|
|
if (!goodsName) return; |
|
|
|
|
if (!goodsName) return (item.goodsListOptions = []); |
|
|
|
|
|
|
|
|
|
try { |
|
|
|
|
item.loading = true; |
|
|
|
@ -1694,8 +1810,6 @@ const handleFindGoods = async (goodsName, item) => {
|
|
|
|
|
/** 计算行合计 */ |
|
|
|
|
const handleComputed = (row: any) => { |
|
|
|
|
details.query.goodsCode = '-' + details.totalObj.totalCount; |
|
|
|
|
console.log('details.totalObj.totalCount :>> ', details.totalObj.totalCount); |
|
|
|
|
if (!row.price) return; |
|
|
|
|
if (row.chargeType === 1) row.subtotalFreight = computeNumber(row.num, '*', row.price).result; |
|
|
|
|
else if (row.chargeType === 2) |
|
|
|
|
row.subtotalFreight = computeNumber(row.volume, '*', row.price).result; |
|
|
|
@ -1711,31 +1825,22 @@ const handleFindClientInfo = async (type, isClearId = 0) => {
|
|
|
|
|
type === 'consignee' ? (details.query.consigneeId = '') : (details.query.shipperId = ''); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (!details.query[type]) return (details[type + 'Options'] = []); |
|
|
|
|
|
|
|
|
|
details.loadingObj.consignerLoading = true; |
|
|
|
|
|
|
|
|
|
/** 发货人搜索信息 */ |
|
|
|
|
let shipperQuery = { |
|
|
|
|
clientName: details.query.shipper, |
|
|
|
|
linkMan: details.query.shipperName, |
|
|
|
|
linkPhone: details.query.shipperMobile, |
|
|
|
|
}; |
|
|
|
|
/** 寄货人搜索信息 */ |
|
|
|
|
let consignerQuery = { |
|
|
|
|
clientName: details.query.consignee, |
|
|
|
|
linkMan: details.query.consigneeName, |
|
|
|
|
linkPhone: details.query.consigneeMobile, |
|
|
|
|
}; |
|
|
|
|
const nameReg = new RegExp('Name'); |
|
|
|
|
const MobileReg = new RegExp('Mobile'); |
|
|
|
|
|
|
|
|
|
const submitData = type === 'consignee' ? consignerQuery : shipperQuery; |
|
|
|
|
const submitData: any = {}; |
|
|
|
|
if (nameReg.test(type)) submitData.linkMan = details.query[type]; |
|
|
|
|
else if (MobileReg.test(type)) submitData.linkPhone = details.query[type]; |
|
|
|
|
else submitData.clientName = details.query[type]; |
|
|
|
|
|
|
|
|
|
const res = await postOpenOrderFindClientInfo(submitData); |
|
|
|
|
const { code, data } = res.data; |
|
|
|
|
if (code !== 200) return; |
|
|
|
|
if (type === 'consignee') { |
|
|
|
|
details.consignerOptions = data || []; |
|
|
|
|
} else { |
|
|
|
|
details.shipperOptions = data || []; |
|
|
|
|
} |
|
|
|
|
details[type + 'Options'] = data || []; |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log('error :>> ', error); |
|
|
|
|
} finally { |
|
|
|
@ -1751,6 +1856,10 @@ const handleChooseShipper = (column, prop, order) => {
|
|
|
|
|
details.query.shipperAddress = column.linkAddress; |
|
|
|
|
details.query.shipperName = column.linkMan; |
|
|
|
|
details.query.shipperMobile = column.linkPhone; |
|
|
|
|
|
|
|
|
|
handleFindClientInfo('shipper'); |
|
|
|
|
handleFindClientInfo('shipperName'); |
|
|
|
|
handleFindClientInfo('shipperMobile'); |
|
|
|
|
handleCloseSelcet(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
@ -1762,6 +1871,10 @@ const handleChooseConsigner = (column, prop, order) => {
|
|
|
|
|
details.query.consigneeAddress = column.linkAddress; |
|
|
|
|
details.query.consigneeName = column.linkMan; |
|
|
|
|
details.query.consigneeMobile = column.linkPhone; |
|
|
|
|
|
|
|
|
|
handleFindClientInfo('consignee'); |
|
|
|
|
handleFindClientInfo('consigneeName'); |
|
|
|
|
handleFindClientInfo('consigneeMobile'); |
|
|
|
|
handleCloseSelcet(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
@ -2026,6 +2139,125 @@ const handleRepetition = () => {
|
|
|
|
|
resetForm(ruleFormRef.value); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 获取价格 */ |
|
|
|
|
const handleFindPrice = async (condition?: any) => { |
|
|
|
|
try { |
|
|
|
|
// item.loading = true; |
|
|
|
|
|
|
|
|
|
const { destination } = details.query; |
|
|
|
|
|
|
|
|
|
if (destination.length <= 1) return; |
|
|
|
|
if (!details.query.consigneeId) return; |
|
|
|
|
if (!details.query.departureWarehouseId) return; |
|
|
|
|
if (!details.query.destinationWarehouseId) return; |
|
|
|
|
|
|
|
|
|
const submitData = { |
|
|
|
|
consigneeId: details.query.consigneeId, |
|
|
|
|
departureWarehouseId: details.query.departureWarehouseId, |
|
|
|
|
destinationWarehouseId: details.query.destinationWarehouseId, |
|
|
|
|
destinationCode: '', |
|
|
|
|
goodsIds: [] as any[], |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
console.log(submitData); |
|
|
|
|
|
|
|
|
|
// 货物id |
|
|
|
|
if (condition) { |
|
|
|
|
const { goodsId } = condition; |
|
|
|
|
if (!goodsId) return; |
|
|
|
|
submitData.goodsIds = [goodsId]; |
|
|
|
|
} else { |
|
|
|
|
const _goodsIdsArr = []; |
|
|
|
|
|
|
|
|
|
console.log('details.goodsList', details.goodsList); |
|
|
|
|
|
|
|
|
|
// 筛选有goodsId的货物信息 |
|
|
|
|
for (let index = 0; index < details.goodsList.length; index++) { |
|
|
|
|
const { goodsId } = details.goodsList[index]; |
|
|
|
|
if (goodsId) _goodsIdsArr.push(goodsId); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
console.log('_goodsIdsArr', _goodsIdsArr); |
|
|
|
|
|
|
|
|
|
if (_goodsIdsArr.length === 0) return; |
|
|
|
|
submitData.goodsIds = _goodsIdsArr; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// 筛选到站 |
|
|
|
|
const _findeLocation = details.regionOptione |
|
|
|
|
.find(val => val.value === destination[0]) |
|
|
|
|
.children.find(val => val.value === destination[1]); |
|
|
|
|
|
|
|
|
|
let _item: any = {}; |
|
|
|
|
if (destination.length === 2) { |
|
|
|
|
_item = _findeLocation; |
|
|
|
|
} else { |
|
|
|
|
_item = _findeLocation.children.find(val => val.value === destination[2]); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
submitData.destinationCode = _item.value; |
|
|
|
|
|
|
|
|
|
const res = await postFindArrPrice(submitData); |
|
|
|
|
// const { code, data } = res.data; |
|
|
|
|
const { code, data } = res.data; |
|
|
|
|
console.log('data :>> ', data); |
|
|
|
|
|
|
|
|
|
if (code !== 200 || data.length === 0) return; |
|
|
|
|
|
|
|
|
|
if (condition) { |
|
|
|
|
// 循环赋值 |
|
|
|
|
for (let i = 0; i < details.priceArr.length; i++) { |
|
|
|
|
const value = details.priceArr[i]; |
|
|
|
|
condition[value.key] = 0; |
|
|
|
|
|
|
|
|
|
for (let index = 0; index < data[0].arrPrice.length; index++) { |
|
|
|
|
const element = data[0].arrPrice[index]; |
|
|
|
|
|
|
|
|
|
if (element.itemName === value.name) |
|
|
|
|
condition[value.key] = isNumber(element.cost) ? Number(element.cost) : 0; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
console.log('condition :>> ', condition); |
|
|
|
|
handleComputed(condition); |
|
|
|
|
} else { |
|
|
|
|
for (let idx = 0; idx < details.goodsList.length; idx++) { |
|
|
|
|
const val = details.goodsList[idx]; |
|
|
|
|
|
|
|
|
|
if (!val.goodsId) continue; |
|
|
|
|
|
|
|
|
|
let _data = null; |
|
|
|
|
|
|
|
|
|
for (let index = 0; index < data.length; index++) { |
|
|
|
|
const element = data[index]; |
|
|
|
|
if (element.goodsId === val.goodsId) { |
|
|
|
|
_data = element; |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// 循环赋值 |
|
|
|
|
for (let i = 0; i < details.priceArr.length; i++) { |
|
|
|
|
const value = details.priceArr[i]; |
|
|
|
|
val[value.key] = 0; |
|
|
|
|
|
|
|
|
|
for (let index = 0; index < _data.arrPrice.length; index++) { |
|
|
|
|
const element = _data.arrPrice[index]; |
|
|
|
|
|
|
|
|
|
if (element.itemName === value.name) |
|
|
|
|
val[value.key] = isNumber(element.cost) ? Number(element.cost) : 0; |
|
|
|
|
} |
|
|
|
|
console.log('val :>> ', val); |
|
|
|
|
} |
|
|
|
|
handleComputed(val); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log('error :>> ', error); |
|
|
|
|
} finally { |
|
|
|
|
// item.loading = false; |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
watch( |
|
|
|
|
() => $route.query, |
|
|
|
|
() => { |
|
|
|
@ -2268,4 +2500,14 @@ $borderColor: #172e60;
|
|
|
|
|
background: #f5f7fa; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
.is-error { |
|
|
|
|
:deep(.el-input__wrapper) { |
|
|
|
|
border-color: #f00 !important; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
:deep(.el-input__inner) { |
|
|
|
|
color: #f00 !important; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
</style> |
|
|
|
|