|
|
|
@ -1,5 +1,5 @@
|
|
|
|
|
<template> |
|
|
|
|
<div> |
|
|
|
|
<div v-loading="details.loadingObj.submitLoadingBtn"> |
|
|
|
|
<basic-container> |
|
|
|
|
<el-divider style="font-size: 28px">货物托运单</el-divider> |
|
|
|
|
<el-form |
|
|
|
@ -41,6 +41,7 @@
|
|
|
|
|
</div> |
|
|
|
|
<el-date-picker |
|
|
|
|
v-model="query.openOrderDate" |
|
|
|
|
:readonly="$route.query.type !== 'add'" |
|
|
|
|
prefix-icon="Calendar" |
|
|
|
|
type="datetime" |
|
|
|
|
placeholder="创建时间" |
|
|
|
@ -51,7 +52,11 @@
|
|
|
|
|
<!-- 第一排 --> |
|
|
|
|
<div class="table-row mt15 border-top"> |
|
|
|
|
<el-form-item label="发站仓:" prop="departureWarehouseName" class="el-times"> |
|
|
|
|
<el-input disabled v-model="query.departureWarehouseName" placeholder="货号"></el-input> |
|
|
|
|
<el-input |
|
|
|
|
disabled |
|
|
|
|
v-model="query['departureWarehouseName']" |
|
|
|
|
placeholder="发站仓" |
|
|
|
|
></el-input> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="到站:" prop="destination"> |
|
|
|
@ -75,10 +80,10 @@
|
|
|
|
|
</div> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="目的仓:" class="el-times" prop="destinationWarehouseName"> |
|
|
|
|
<el-form-item label="目的仓:" class="el-times" prop="queryDestinationWarehouseName"> |
|
|
|
|
<el-select |
|
|
|
|
class="w100" |
|
|
|
|
v-model="query.destinationWarehouseId" |
|
|
|
|
v-model="query.queryDestinationWarehouseName" |
|
|
|
|
filterable |
|
|
|
|
remote |
|
|
|
|
reserve-keyword |
|
|
|
@ -97,7 +102,7 @@
|
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="货号:" prop="goodsCode"> |
|
|
|
|
<el-input v-model="query.goodsCode" placeholder="货号"></el-input> |
|
|
|
|
<el-input v-model="query.goodsCode" readonly placeholder="货号"></el-input> |
|
|
|
|
</el-form-item> |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
@ -130,7 +135,7 @@
|
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label="发货单位:" prop="shipper"> |
|
|
|
|
<SelectBox |
|
|
|
|
:input="handleFindClientInfo('shipper')" |
|
|
|
|
:input="() => handleFindClientInfo('shipper', 1)" |
|
|
|
|
v-model="query.shipper" |
|
|
|
|
placeholder="发货单位" |
|
|
|
|
ref="shipper" |
|
|
|
@ -151,7 +156,7 @@
|
|
|
|
|
|
|
|
|
|
<el-form-item label="发货人:" prop="shipperName"> |
|
|
|
|
<SelectBox |
|
|
|
|
:input="handleFindClientInfo('shipper')" |
|
|
|
|
:input="() => handleFindClientInfo('shipper')" |
|
|
|
|
v-model="query.shipperName" |
|
|
|
|
placeholder="发货人" |
|
|
|
|
ref="shipperName" |
|
|
|
@ -174,7 +179,7 @@
|
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label="联系电话:" prop="shipperMobile"> |
|
|
|
|
<SelectBox |
|
|
|
|
:input="handleFindClientInfo('shipper')" |
|
|
|
|
:input="() => handleFindClientInfo('shipper')" |
|
|
|
|
v-model="query.shipperMobile" |
|
|
|
|
placeholder="联系电话" |
|
|
|
|
ref="shipperMobile" |
|
|
|
@ -207,7 +212,7 @@
|
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label="发货单位:" prop="consignee"> |
|
|
|
|
<SelectBox |
|
|
|
|
:input="handleFindClientInfo('consignee')" |
|
|
|
|
:input="() => handleFindClientInfo('consignee', 1)" |
|
|
|
|
v-model="query.consignee" |
|
|
|
|
placeholder="收货人" |
|
|
|
|
ref="consignee" |
|
|
|
@ -228,7 +233,7 @@
|
|
|
|
|
|
|
|
|
|
<el-form-item label="收货人:" prop="consigneeName"> |
|
|
|
|
<SelectBox |
|
|
|
|
:input="handleFindClientInfo('consignee')" |
|
|
|
|
:input="() => handleFindClientInfo('consignee')" |
|
|
|
|
v-model="query.consigneeName" |
|
|
|
|
placeholder="收货人" |
|
|
|
|
ref="consigneeName" |
|
|
|
@ -251,7 +256,7 @@
|
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label="联系电话:" prop="consigneeMobile"> |
|
|
|
|
<SelectBox |
|
|
|
|
:input="handleFindClientInfo('consignee')" |
|
|
|
|
:input="() => handleFindClientInfo('consignee')" |
|
|
|
|
v-model="query.consigneeMobile" |
|
|
|
|
placeholder="联系电话" |
|
|
|
|
ref="consigneeMobile" |
|
|
|
@ -390,6 +395,7 @@
|
|
|
|
|
<el-form-item label="运费小计:" label-width="fit-content" class="el-times"> |
|
|
|
|
<el-input-number |
|
|
|
|
:controls="false" |
|
|
|
|
@change="handlePayWay" |
|
|
|
|
v-model="item.subtotalFreight" |
|
|
|
|
controls-position="right" |
|
|
|
|
:precision="2" |
|
|
|
@ -529,85 +535,16 @@
|
|
|
|
|
></el-input-number> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-row> |
|
|
|
|
</el-form> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
<!-- 付款方式 --> |
|
|
|
|
<div class="border-left"> |
|
|
|
|
<div style="flex: 1"> |
|
|
|
|
<div class="table-row-title" style="margin-bottom: 10px"> |
|
|
|
|
<div class="table-row-title-item">付款方式</div> |
|
|
|
|
</div> |
|
|
|
|
<div> |
|
|
|
|
<el-form label-width="fit-content" :rules="details.rules"> |
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label="支付方式:"> |
|
|
|
|
<el-select v-model="query.payType" class="m-2" placeholder="支付方式"> |
|
|
|
|
<el-option |
|
|
|
|
v-for="item in query.payTypeList || []" |
|
|
|
|
:key="item.dictValue" |
|
|
|
|
:label="item.dictValue" |
|
|
|
|
:value="item.dictKey" |
|
|
|
|
/> |
|
|
|
|
</el-select> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="付款方式:" prop="payWay"> |
|
|
|
|
<el-select v-model="query.payWay" class="m-2" placeholder="付款方式"> |
|
|
|
|
<el-option |
|
|
|
|
v-for="item in query.payWayList || []" |
|
|
|
|
:key="item.dictValue" |
|
|
|
|
:label="item.dictValue" |
|
|
|
|
:value="item.dictKey" |
|
|
|
|
/> |
|
|
|
|
</el-select> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="现付:"> |
|
|
|
|
<el-input-number |
|
|
|
|
:controls="false" |
|
|
|
|
controls-position="right" |
|
|
|
|
:precision="2" |
|
|
|
|
:min="0" |
|
|
|
|
:step="0.1" |
|
|
|
|
v-model="query.xianPay" |
|
|
|
|
></el-input-number> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-row> |
|
|
|
|
|
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label="到付:"> |
|
|
|
|
<el-input-number |
|
|
|
|
:controls="false" |
|
|
|
|
controls-position="right" |
|
|
|
|
:precision="2" |
|
|
|
|
:min="0" |
|
|
|
|
:step="0.1" |
|
|
|
|
v-model="query.daoPay" |
|
|
|
|
></el-input-number> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="月结:"> |
|
|
|
|
<el-form-item label="安装费:"> |
|
|
|
|
<el-input-number |
|
|
|
|
:controls="false" |
|
|
|
|
controls-position="right" |
|
|
|
|
:precision="2" |
|
|
|
|
:min="0" |
|
|
|
|
:step="0.1" |
|
|
|
|
v-model="query.yuePay" |
|
|
|
|
></el-input-number> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="回付:"> |
|
|
|
|
<el-input-number |
|
|
|
|
:controls="false" |
|
|
|
|
controls-position="right" |
|
|
|
|
:precision="2" |
|
|
|
|
:min="0" |
|
|
|
|
:step="0.1" |
|
|
|
|
v-model="query.huiPay" |
|
|
|
|
v-model="query.installFee" |
|
|
|
|
></el-input-number> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-row> |
|
|
|
@ -615,6 +552,91 @@
|
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
<!-- 付款方式 --> |
|
|
|
|
<div class="border-left"> |
|
|
|
|
<div style="flex: 1"> |
|
|
|
|
<div class="table-row-title" style="margin-bottom: 10px"> |
|
|
|
|
<div class="table-row-title-item">付款方式</div> |
|
|
|
|
</div> |
|
|
|
|
<div> |
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label-width="fit-content" label="支付方式:"> |
|
|
|
|
<el-select v-model="query.payType" class="m-2" placeholder="支付方式"> |
|
|
|
|
<el-option |
|
|
|
|
v-for="item in query.payTypeList || []" |
|
|
|
|
:key="item.dictValue" |
|
|
|
|
:label="item.dictValue" |
|
|
|
|
:value="item.dictKey" |
|
|
|
|
/> |
|
|
|
|
</el-select> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label-width="fit-content" label="付款方式:" prop="payWay"> |
|
|
|
|
<el-select |
|
|
|
|
v-model="query.payWay" |
|
|
|
|
class="m-2" |
|
|
|
|
@change="handlePayWay" |
|
|
|
|
placeholder="付款方式" |
|
|
|
|
> |
|
|
|
|
<el-option |
|
|
|
|
v-for="item in query.payWayList || []" |
|
|
|
|
:key="item.dictValue" |
|
|
|
|
:label="item.dictValue" |
|
|
|
|
:value="item.dictKey" |
|
|
|
|
/> |
|
|
|
|
</el-select> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label-width="fit-content" label="现付:"> |
|
|
|
|
<el-input-number |
|
|
|
|
:controls="false" |
|
|
|
|
controls-position="right" |
|
|
|
|
:precision="2" |
|
|
|
|
:min="0" |
|
|
|
|
:step="0.1" |
|
|
|
|
v-model="query.xianPay" |
|
|
|
|
></el-input-number> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-row> |
|
|
|
|
|
|
|
|
|
<el-row> |
|
|
|
|
<el-form-item label-width="fit-content" label="到付:"> |
|
|
|
|
<el-input-number |
|
|
|
|
:controls="false" |
|
|
|
|
controls-position="right" |
|
|
|
|
:precision="2" |
|
|
|
|
:min="0" |
|
|
|
|
:step="0.1" |
|
|
|
|
v-model="query.daoPay" |
|
|
|
|
></el-input-number> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label-width="fit-content" label="月结:"> |
|
|
|
|
<el-input-number |
|
|
|
|
:controls="false" |
|
|
|
|
controls-position="right" |
|
|
|
|
:precision="2" |
|
|
|
|
:min="0" |
|
|
|
|
:step="0.1" |
|
|
|
|
v-model="query.yuePay" |
|
|
|
|
></el-input-number> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label-width="fit-content" label="回付:"> |
|
|
|
|
<el-input-number |
|
|
|
|
:controls="false" |
|
|
|
|
controls-position="right" |
|
|
|
|
:precision="2" |
|
|
|
|
:min="0" |
|
|
|
|
:step="0.1" |
|
|
|
|
v-model="query.huiPay" |
|
|
|
|
></el-input-number> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-row> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
<!-- 计价方式行 --> |
|
|
|
@ -732,29 +754,64 @@
|
|
|
|
|
width="80%" |
|
|
|
|
v-model="details.popUpShow.columnListVisited" |
|
|
|
|
> |
|
|
|
|
<!-- 列表模块 --> |
|
|
|
|
<tablecmt |
|
|
|
|
:columnList="details.columnList" |
|
|
|
|
:tableData="data" |
|
|
|
|
:loading="loadingObj.list" |
|
|
|
|
@inputTxt="inputsc" |
|
|
|
|
@timeCheck="timesc" |
|
|
|
|
@btnCheck="btnsc" |
|
|
|
|
@selectCheck="selectsc" |
|
|
|
|
@selection="selectionChange" |
|
|
|
|
> |
|
|
|
|
<template #default="slotProps"> |
|
|
|
|
<template v-if="slotProps.scope.column.label === '操作'"> |
|
|
|
|
<el-button type="text" @click="handleShowPackageOrderList(slotProps.scope)"> |
|
|
|
|
包明细 |
|
|
|
|
</el-button> |
|
|
|
|
</template> |
|
|
|
|
</template> |
|
|
|
|
</tablecmt> |
|
|
|
|
<div style="display: flex"> |
|
|
|
|
<el-tabs |
|
|
|
|
v-model="details.orderStatus" |
|
|
|
|
tab-position="left" |
|
|
|
|
style="height: 100%; width: fit-content; flex: none" |
|
|
|
|
class="demo-tabs" |
|
|
|
|
@tab-click="handleClickAll" |
|
|
|
|
> |
|
|
|
|
<el-tab-pane name="haveData" label="有数据"></el-tab-pane> |
|
|
|
|
<el-tab-pane name="notHaveData" label="无数据"></el-tab-pane> |
|
|
|
|
</el-tabs> |
|
|
|
|
|
|
|
|
|
<div class="overflow"> |
|
|
|
|
<el-row> |
|
|
|
|
<div class="avue-crud__header"> |
|
|
|
|
<!-- 头部左侧按钮模块 --> |
|
|
|
|
<div class="avue-crud__left"></div> |
|
|
|
|
<!-- 头部右侧按钮模块 --> |
|
|
|
|
<div class="avue-crud__right"> |
|
|
|
|
<el-button icon="el-icon-refresh" @click="init" circle></el-button> |
|
|
|
|
<el-button icon="Operation" @click="showdrawer(true)" circle></el-button> |
|
|
|
|
<el-button icon="Search" @click="searchHide" circle></el-button> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
</el-row> |
|
|
|
|
<!-- 表格 --> |
|
|
|
|
<!-- 列表模块 --> |
|
|
|
|
<tablecmt |
|
|
|
|
:columnList="details.columnList" |
|
|
|
|
:tableData=" |
|
|
|
|
details.orderStatus === 'haveData' ? details.haveDataData : details.notHaveDataData |
|
|
|
|
" |
|
|
|
|
:loading=" |
|
|
|
|
details.orderStatus === 'haveData' |
|
|
|
|
? details.loadingObj.haveDataList |
|
|
|
|
: details.loadingObj.notHaveDataList |
|
|
|
|
" |
|
|
|
|
@inputTxt="inputsc" |
|
|
|
|
@timeCheck="timesc" |
|
|
|
|
@btnCheck="btnsc" |
|
|
|
|
@selectCheck="selectsc" |
|
|
|
|
@selection="selectionChange" |
|
|
|
|
> |
|
|
|
|
<template #default="slotProps"> |
|
|
|
|
<template v-if="slotProps.scope.column.label === '操作'"> |
|
|
|
|
<el-button type="text" @click="handleShowPackageOrderList(slotProps.scope)"> |
|
|
|
|
包明细 |
|
|
|
|
</el-button> |
|
|
|
|
</template> |
|
|
|
|
</template> |
|
|
|
|
</tablecmt> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
<!-- 分页模块 --> |
|
|
|
|
<el-pagination |
|
|
|
|
align="right" |
|
|
|
|
class="mt10" |
|
|
|
|
background |
|
|
|
|
@size-change="sizeChange" |
|
|
|
|
@current-change="currentChange" |
|
|
|
@ -765,11 +822,31 @@
|
|
|
|
|
:total="page.total" |
|
|
|
|
> |
|
|
|
|
</el-pagination> |
|
|
|
|
<span slot="footer" class="dialog-footer"> |
|
|
|
|
<!-- <el-button type="primary" @click="ddd">导 出</el-button>--> |
|
|
|
|
<el-button type="primary" @click="handleChoose">确 认</el-button> |
|
|
|
|
|
|
|
|
|
<div class="flex-c-c mt10"> |
|
|
|
|
<el-button @click="details.popUpShow.columnListVisited = false">取 消</el-button> |
|
|
|
|
</span> |
|
|
|
|
<el-button type="primary" @click="handleChoose">确 认</el-button> |
|
|
|
|
</div> |
|
|
|
|
</el-dialog> |
|
|
|
|
|
|
|
|
|
<!-- 选取订单 --> |
|
|
|
|
<el-dialog |
|
|
|
|
title="提示" |
|
|
|
|
:center="true" |
|
|
|
|
:align-center="true" |
|
|
|
|
:close-on-click-modal="false" |
|
|
|
|
:close-on-press-escape="false" |
|
|
|
|
:show-close="false" |
|
|
|
|
:visible.sync="details.popUpShow.titleVisited" |
|
|
|
|
width="30%" |
|
|
|
|
v-model="details.popUpShow.titleVisited" |
|
|
|
|
> |
|
|
|
|
<div style="text-align: center">是否继续开单</div> |
|
|
|
|
<div class="flex-c-c mt20"> |
|
|
|
|
<el-button icon="CircleClose" @click="back">取 消</el-button> |
|
|
|
|
<el-button type="primary" icon="CircleCheck" @click="handleRepetition">确 认</el-button> |
|
|
|
|
<el-button type="primary" icon="Printer" @click="handlePrint">打 印</el-button> |
|
|
|
|
</div> |
|
|
|
|
</el-dialog> |
|
|
|
|
</div> |
|
|
|
|
</template> |
|
|
|
@ -794,14 +871,16 @@ import {
|
|
|
|
|
downloadXls, |
|
|
|
|
computeNumber, |
|
|
|
|
deepClone, |
|
|
|
|
isNumer, |
|
|
|
|
isNumber, |
|
|
|
|
setNodeHeight, |
|
|
|
|
getWinHeight, |
|
|
|
|
debounce, |
|
|
|
|
getObjType, |
|
|
|
|
} from '@/utils/util'; |
|
|
|
|
import { columnList, packageListColumnList } from '@/option/waybill/TemporaryStorageList'; |
|
|
|
|
import { getopenOrderAdvancePageList } from '@/api/waybill/TemporaryStorageList'; |
|
|
|
|
import { getLazyTreeAll } from '@/api/base/region'; |
|
|
|
|
import { ElMessage } from 'element-plus'; |
|
|
|
|
import { ElMessage, ElMessageBox } from 'element-plus'; |
|
|
|
|
import type { FormInstance, FormRules } from 'element-plus'; |
|
|
|
|
import { useRouter, useRoute } from 'vue-router'; |
|
|
|
|
import { |
|
|
|
@ -845,13 +924,16 @@ const details = reactive<any>({
|
|
|
|
|
/** 发站仓名称 */ |
|
|
|
|
departureWarehouseName: '', |
|
|
|
|
/** 到站 */ |
|
|
|
|
destination: '', |
|
|
|
|
destination: [], |
|
|
|
|
/** 货号 */ |
|
|
|
|
'-totalNum': 0, |
|
|
|
|
/** 订单自编号 */ |
|
|
|
|
orderCode: '', |
|
|
|
|
/** 目的站名称 */ |
|
|
|
|
destinationWarehouseName: '', |
|
|
|
|
/** 目的仓Id */ |
|
|
|
|
destinationWarehouseId: '', |
|
|
|
|
queryDestinationWarehouseName: '', |
|
|
|
|
/** 货物号 */ |
|
|
|
|
goodsCode: '', |
|
|
|
|
/** 发货单位id */ |
|
|
|
@ -890,6 +972,8 @@ const details = reactive<any>({
|
|
|
|
|
otherFee: 0, |
|
|
|
|
/** 保价费 */ |
|
|
|
|
insuranceFee: 0, |
|
|
|
|
/** 安装费 */ |
|
|
|
|
installFee: 0, |
|
|
|
|
/** 申明价值 */ |
|
|
|
|
claimingValue: 0, |
|
|
|
|
/** 支付方式 */ |
|
|
|
@ -1175,7 +1259,7 @@ const details = reactive<any>({
|
|
|
|
|
}, |
|
|
|
|
], |
|
|
|
|
/** 目的站名称 */ |
|
|
|
|
destinationWarehouseName: [ |
|
|
|
|
queryDestinationWarehouseName: [ |
|
|
|
|
{ |
|
|
|
|
required: true, |
|
|
|
|
message: '请选择目的仓', |
|
|
|
@ -1235,7 +1319,7 @@ const details = reactive<any>({
|
|
|
|
|
{ |
|
|
|
|
required: true, |
|
|
|
|
message: '请选择付款方式', |
|
|
|
|
trigger: ['change', 'blur'], |
|
|
|
|
trigger: ['change'], |
|
|
|
|
}, |
|
|
|
|
], |
|
|
|
|
/** 送货方式 */ |
|
|
|
@ -1258,10 +1342,14 @@ const details = reactive<any>({
|
|
|
|
|
/** 列表 */ |
|
|
|
|
columnList, |
|
|
|
|
/** 列表数据 */ |
|
|
|
|
data: [], |
|
|
|
|
haveDataData: [], |
|
|
|
|
notHaveDataData: [], |
|
|
|
|
/** 页面loading */ |
|
|
|
|
loadingObj: { |
|
|
|
|
loading: false, |
|
|
|
|
/** 列表加载loading */ |
|
|
|
|
haveDataList: false, |
|
|
|
|
notHaveDataList: false, |
|
|
|
|
/** 配载信息loading */ |
|
|
|
|
stowageLoading: false, |
|
|
|
|
/** 收货方 */ |
|
|
|
@ -1281,8 +1369,9 @@ const details = reactive<any>({
|
|
|
|
|
}, |
|
|
|
|
/** 弹出层显示 */ |
|
|
|
|
popUpShow: { |
|
|
|
|
/** 包明细 */ |
|
|
|
|
/** 订单选择 */ |
|
|
|
|
columnListVisited: false, |
|
|
|
|
titleVisited: false, |
|
|
|
|
}, |
|
|
|
|
/** 列表Dom节点 */ |
|
|
|
|
listNode: '', |
|
|
|
@ -1292,6 +1381,8 @@ const details = reactive<any>({
|
|
|
|
|
deepCloneGoodsList: [], |
|
|
|
|
/** 提交数据 */ |
|
|
|
|
submitData: {}, |
|
|
|
|
/** tab标签有无数据 */ |
|
|
|
|
orderStatus: 'haveData', |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
const info = ref<any>({}); |
|
|
|
@ -1332,10 +1423,53 @@ console.log('permission :>> ', permission);
|
|
|
|
|
|
|
|
|
|
onMounted(() => {}); |
|
|
|
|
|
|
|
|
|
// 改单时, 对数据库内到站值进行转译 |
|
|
|
|
const handleTranslationLocation = () => { |
|
|
|
|
// 获取数据库中地址值 |
|
|
|
|
const _location = details.query.destination; |
|
|
|
|
|
|
|
|
|
console.log('_location :>> ', _location); |
|
|
|
|
|
|
|
|
|
let _arr = []; |
|
|
|
|
|
|
|
|
|
// 循环查找匹配的到站地址 |
|
|
|
|
for (const iterator of details.regionOptione) { |
|
|
|
|
let isBreak = false; |
|
|
|
|
|
|
|
|
|
if (iterator.label === _location) { |
|
|
|
|
_arr = [iterator.value]; |
|
|
|
|
isBreak = true; |
|
|
|
|
} else if (getObjType(iterator.children) === 'array') { |
|
|
|
|
for (const item of iterator.children) { |
|
|
|
|
if (item.label === _location) { |
|
|
|
|
_arr = [iterator.value, item.value]; |
|
|
|
|
isBreak = true; |
|
|
|
|
break; |
|
|
|
|
} else if (getObjType(item.children) === 'array') { |
|
|
|
|
for (const value of item.children) { |
|
|
|
|
if (value.label === _location) { |
|
|
|
|
_arr = [iterator.value, item.value, value.value]; |
|
|
|
|
isBreak = true; |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
if (isBreak) break; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (isBreak) break; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
details.query.destination = _arr; |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
// 获取省市区信息 |
|
|
|
|
getLazyTreeAll().then(res => { |
|
|
|
|
if (res.data.success) { |
|
|
|
|
details.regionOptione = res.data.data; |
|
|
|
|
|
|
|
|
|
if (details.query.destination) handleTranslationLocation(); |
|
|
|
|
} |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
@ -1362,7 +1496,7 @@ const onLoad = async (idsArr = []) => {
|
|
|
|
|
console.log('val[valKey] :>> ', val[valKey]); |
|
|
|
|
const _item = Number(val[valKey]); |
|
|
|
|
// 判断是否为数字并将字符串的数字转为数字 |
|
|
|
|
if (isNumer(_item)) { |
|
|
|
|
if (isNumber(_item)) { |
|
|
|
|
val[valKey] = _item; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
@ -1384,6 +1518,7 @@ const onLoad = async (idsArr = []) => {
|
|
|
|
|
} else { |
|
|
|
|
details.query.payWay = data.payWayList.find(val => val.dictValue === '到付').dictKey || '2'; |
|
|
|
|
} |
|
|
|
|
details.query.transportType = '1'; |
|
|
|
|
// instance.proxy.$forceUpdate(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
@ -1399,7 +1534,32 @@ const initPageInfo = async () => {
|
|
|
|
|
|
|
|
|
|
details.query = { ...data, ...data.warehouseWaybill }; |
|
|
|
|
delete details.query.warehouseWaybill; |
|
|
|
|
details.query.queryDestinationWarehouseName = details.query.destinationWarehouseName; |
|
|
|
|
console.log('data :>> ', data); |
|
|
|
|
details.query.openOrderDate = data.warehouseWaybill.createTime; |
|
|
|
|
details.query.orderCode = data.warehouseWaybill.orderNo; |
|
|
|
|
details.query.transportType = '1'; |
|
|
|
|
details.query.receipt = data.warehouseWaybill.receipt |
|
|
|
|
? data.warehouseWaybill.receipt.split(',') |
|
|
|
|
: []; |
|
|
|
|
|
|
|
|
|
details.query.xianPay = isNumber(data.warehouseWaybill.xpay) |
|
|
|
|
? Number(data.warehouseWaybill.xpay) |
|
|
|
|
: data.warehouseWaybill.xpay; |
|
|
|
|
details.query.huiPay = isNumber(data.warehouseWaybill.hpay) |
|
|
|
|
? Number(data.warehouseWaybill.hpay) |
|
|
|
|
: data.warehouseWaybill.hpay; |
|
|
|
|
details.query.yuePay = isNumber(data.warehouseWaybill.ypay) |
|
|
|
|
? Number(data.warehouseWaybill.ypay) |
|
|
|
|
: data.warehouseWaybill.ypay; |
|
|
|
|
details.query.daoPay = isNumber(data.warehouseWaybill.dpay) |
|
|
|
|
? Number(data.warehouseWaybill.dpay) |
|
|
|
|
: data.warehouseWaybill.dpay; |
|
|
|
|
// 转译到站 |
|
|
|
|
if (details.regionOptione.length !== 0) handleTranslationLocation(); |
|
|
|
|
console.log('details.query :>> ', details.query); |
|
|
|
|
|
|
|
|
|
// 初始化goodsList |
|
|
|
|
if (data.warehouseWaybill.detailList.length === 0) |
|
|
|
|
details.goodsList = [ |
|
|
|
|
{ |
|
|
|
@ -1423,7 +1583,6 @@ const initPageInfo = async () => {
|
|
|
|
|
}, |
|
|
|
|
]; |
|
|
|
|
else { |
|
|
|
|
console.log('111 :>> ', 111); |
|
|
|
|
info.value.maxNum = 0; |
|
|
|
|
details.deepCloneGoodsList = []; |
|
|
|
|
details.goodsList = data.warehouseWaybill.detailList.map(val => { |
|
|
|
@ -1440,11 +1599,9 @@ const initPageInfo = async () => {
|
|
|
|
|
|
|
|
|
|
// 计算件数最大值 |
|
|
|
|
info.value.maxNum += val.num; |
|
|
|
|
console.log('val :>> ', val); |
|
|
|
|
details.deepCloneGoodsList.push({ ...val }); |
|
|
|
|
return val; |
|
|
|
|
}); |
|
|
|
|
console.log('details.deepCloneGoodsList :>> ', details.deepCloneGoodsList); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
@ -1511,21 +1668,42 @@ const handleAdd = () => {
|
|
|
|
|
|
|
|
|
|
/** 请求订单数据 */ |
|
|
|
|
const initOrderList = async (params = {}) => { |
|
|
|
|
const status = details.orderStatus; |
|
|
|
|
|
|
|
|
|
try { |
|
|
|
|
if (status === 'haveData') details.loadingObj.haveDataList = true; |
|
|
|
|
else details.loadingObj.notHaveDataList = true; |
|
|
|
|
|
|
|
|
|
details.form.freezeStatus = '0'; |
|
|
|
|
|
|
|
|
|
params.hasPackage = status === 'haveData' ? 1 : 0; |
|
|
|
|
|
|
|
|
|
const res = await getopenOrderAdvancePageList(details.page, { ...details.form, ...params }); |
|
|
|
|
// 获取暂存单列表 |
|
|
|
|
console.log('res :>> ', res); |
|
|
|
|
const { code, data } = res.data; |
|
|
|
|
if (code !== 200) return; |
|
|
|
|
|
|
|
|
|
if (status === 'haveData') details.haveDataData = data.records; |
|
|
|
|
else details.notHaveDataData = data.records; |
|
|
|
|
details.data = data.records; |
|
|
|
|
details.page.total = data.total; |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log('error :>> ', error); |
|
|
|
|
} finally { |
|
|
|
|
// 开启列表loading动画 |
|
|
|
|
if (status === 'haveData') details.loadingObj.haveDataList = false; |
|
|
|
|
else details.loadingObj.notHaveDataList = false; |
|
|
|
|
return null; |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
const init = (params = {}) => { |
|
|
|
|
details.page.pageNum = 1; |
|
|
|
|
details.page.total = 0; |
|
|
|
|
initOrderList(params); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 开启订单列表 */ |
|
|
|
|
const handleChooseOrder = async () => { |
|
|
|
|
try { |
|
|
|
@ -1533,11 +1711,11 @@ const handleChooseOrder = async () => {
|
|
|
|
|
// 开启列表loading动画 |
|
|
|
|
details.loadingObj.loading = true; |
|
|
|
|
|
|
|
|
|
await initOrderList(); |
|
|
|
|
await init(); |
|
|
|
|
|
|
|
|
|
nextTick(() => { |
|
|
|
|
const _node = document.querySelector('.el-dialog-columnList .maboxhi'); |
|
|
|
|
setNodeHeight(_node, '600px'); |
|
|
|
|
setNodeHeight(_node, '60vh'); |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
// return res.data; |
|
|
|
@ -1572,6 +1750,7 @@ const handleChoose = () => {
|
|
|
|
|
// 请求页面数据 |
|
|
|
|
onLoad(ids); |
|
|
|
|
details.popUpShow.columnListVisited = false; |
|
|
|
|
details.popUpShow.titleVisited = false; |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log('error :>> ', error); |
|
|
|
|
} finally { |
|
|
|
@ -1581,7 +1760,7 @@ const handleChoose = () => {
|
|
|
|
|
/** 表格表头输入框搜索 */ |
|
|
|
|
const inputsc = (index, row) => { |
|
|
|
|
details.query[row.prop] = index; |
|
|
|
|
initOrderList(details.page); |
|
|
|
|
init(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 表格表头时间选择 */ |
|
|
|
@ -1593,7 +1772,7 @@ const timesc = (index, row) => {
|
|
|
|
|
if (!index) { |
|
|
|
|
delete details.query[row.prop]; |
|
|
|
|
} |
|
|
|
|
initOrderList(details.page); |
|
|
|
|
init(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 表格表头输入框搜索 */ |
|
|
|
@ -1607,7 +1786,7 @@ const selectsc = (index, row) => {
|
|
|
|
|
details.query['certificateType'] = index; |
|
|
|
|
if (!index) delete details.query['certificateType']; |
|
|
|
|
} |
|
|
|
|
initOrderList(details.page); |
|
|
|
|
init(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 表格表头复选框选择 */ |
|
|
|
@ -1618,13 +1797,13 @@ const selectionChange = (list: any) => {
|
|
|
|
|
/** 每页数量改变执行的回调 */ |
|
|
|
|
const sizeChange = (pageSize: number) => { |
|
|
|
|
details.page.pageSize = pageSize; |
|
|
|
|
initOrderList(details.page); |
|
|
|
|
init(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 页码改变执行的回调 */ |
|
|
|
|
const currentChange = current => { |
|
|
|
|
details.page.pageNum = current; |
|
|
|
|
initOrderList(details.page); |
|
|
|
|
init(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 查看包明细 */ |
|
|
|
@ -1644,10 +1823,8 @@ const handleRemove = (index: number) => {
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 查询目的仓 */ |
|
|
|
|
let _ant1 = null; |
|
|
|
|
const remoteMethod = val => { |
|
|
|
|
if (_ant1) clearTimeout(_ant1); |
|
|
|
|
_ant1 = setTimeout(async () => { |
|
|
|
|
debounce(async () => { |
|
|
|
|
if (val) { |
|
|
|
|
try { |
|
|
|
|
details.loadingObj.loading = true; |
|
|
|
@ -1660,15 +1837,16 @@ const remoteMethod = val => {
|
|
|
|
|
details.loadingObj.loading = false; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
clearTimeout(_ant1); |
|
|
|
|
}, 1000); |
|
|
|
|
}, 500)(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 目的仓选择时给目的仓名称赋值 */ |
|
|
|
|
const destinationWarehouseNameChange = val => { |
|
|
|
|
details.query.destinationWarehouseName = details.options.find( |
|
|
|
|
value => value.warehouseId === val |
|
|
|
|
).warehouseName; |
|
|
|
|
console.log('val :>> ', val); |
|
|
|
|
const _item = details.options.find(value => value.warehouseId === val); |
|
|
|
|
details.query.destinationWarehouseName = _item.warehouseName; |
|
|
|
|
details.query.destinationWarehouseId = _item.warehouseId; |
|
|
|
|
details.query.queryDestinationWarehouseName = details.query.destinationWarehouseName; |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 计算行合计 */ |
|
|
|
@ -1680,47 +1858,47 @@ const handleComputed = (row: any) => {
|
|
|
|
|
else if (row.chargeType === 3) |
|
|
|
|
row.subtotalFreight = computeNumber(row.weight, '*', row.price).result; |
|
|
|
|
// row.subtotalFreight = 1; |
|
|
|
|
handlePayWay(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
let _ant = null; |
|
|
|
|
/** 查询客户信息 */ |
|
|
|
|
const handleFindClientInfo = type => { |
|
|
|
|
if (_ant) clearTimeout(_ant); |
|
|
|
|
_ant = setTimeout(async () => { |
|
|
|
|
try { |
|
|
|
|
details.loadingObj.consignerLoading = true; |
|
|
|
|
|
|
|
|
|
console.log('details.query :>> ', details.query); |
|
|
|
|
|
|
|
|
|
/** 发货人搜索信息 */ |
|
|
|
|
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 submitData = type === 'consignee' ? consignerQuery : shipperQuery; |
|
|
|
|
|
|
|
|
|
const res = await postOpenOrderFindClientInfo(submitData); |
|
|
|
|
const { code, data } = res.data; |
|
|
|
|
if (code !== 200) return; |
|
|
|
|
if (type === 'consignee') { |
|
|
|
|
details.consignerOptions = data || []; |
|
|
|
|
} else { |
|
|
|
|
details.shipperOptions = data || []; |
|
|
|
|
} |
|
|
|
|
} catch (error) { |
|
|
|
|
} finally { |
|
|
|
|
details.loadingObj.consignerLoading = false; |
|
|
|
|
const handleFindClientInfo = async (type, isClearId) => { |
|
|
|
|
try { |
|
|
|
|
// 是否清除id |
|
|
|
|
if (isClearId) { |
|
|
|
|
type === 'consignee' ? (details.query.consigneeId = '') : (details.query.shipperId = ''); |
|
|
|
|
} |
|
|
|
|
clearTimeout(_ant); |
|
|
|
|
}, 1000); |
|
|
|
|
|
|
|
|
|
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 submitData = type === 'consignee' ? consignerQuery : shipperQuery; |
|
|
|
|
|
|
|
|
|
const res = await postOpenOrderFindClientInfo(submitData); |
|
|
|
|
const { code, data } = res.data; |
|
|
|
|
if (code !== 200) return; |
|
|
|
|
if (type === 'consignee') { |
|
|
|
|
details.consignerOptions = data || []; |
|
|
|
|
} else { |
|
|
|
|
details.shipperOptions = data || []; |
|
|
|
|
} |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log('error :>> ', error); |
|
|
|
|
} finally { |
|
|
|
|
details.loadingObj.consignerLoading = false; |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 客户选择 */ |
|
|
|
@ -1745,6 +1923,14 @@ const handleChooseConsigner = (column, prop, order) => {
|
|
|
|
|
consigneeNodeList.forEach(val => val.value.handleClose()); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 切换tabBar */ |
|
|
|
|
const handleClickAll = e => { |
|
|
|
|
console.log('e :>> ', e); |
|
|
|
|
const _name = e.props.name; |
|
|
|
|
details.orderStatus = _name; |
|
|
|
|
initOnLoad(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 返回上一个页面 */ |
|
|
|
|
function back() { |
|
|
|
|
useStores.commit('DEL_TAG_CURRENT'); |
|
|
|
@ -1812,6 +1998,28 @@ const handleDetectionPayWay = () => {
|
|
|
|
|
return content; |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
const handlePayWay = () => { |
|
|
|
|
const payType = Number(details.query.payWay); |
|
|
|
|
const enumPayType = { |
|
|
|
|
1: 'xianPay', |
|
|
|
|
2: 'daoPay', |
|
|
|
|
3: 'yuePay', |
|
|
|
|
4: 'huiPay', |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
for (const key in enumPayType) { |
|
|
|
|
const value = enumPayType[key]; |
|
|
|
|
details.query[value] = 0; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
console.log('Object.keys(enumPayType) :>> ', Object.keys(enumPayType)); |
|
|
|
|
const _item = enumPayType[payType]; |
|
|
|
|
|
|
|
|
|
if (_item) { |
|
|
|
|
details.query[_item] = details.totalObj.totalFreight; |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 提交 */ |
|
|
|
|
const handleSubmit = (formEl: FormInstance | undefined) => { |
|
|
|
|
if (!formEl) return; |
|
|
|
@ -1824,7 +2032,7 @@ const handleSubmit = (formEl: FormInstance | undefined) => {
|
|
|
|
|
// 检测货物名称和件数是否正确填写 |
|
|
|
|
const _flag = details.goodsList.every(val => { |
|
|
|
|
console.log('val :>> ', val); |
|
|
|
|
if (!val.goodsName || !isNumer(val.num) || val.num === 0) return false; |
|
|
|
|
if (!val.goodsName || !isNumber(val.num) || val.num === 0) return false; |
|
|
|
|
return true; |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
@ -1846,11 +2054,15 @@ const handleSubmit = (formEl: FormInstance | undefined) => {
|
|
|
|
|
removeList: [], |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
submitData.customerTrain = details.query.trainNumber; |
|
|
|
|
|
|
|
|
|
const { destination } = submitData; |
|
|
|
|
|
|
|
|
|
console.log('destination :>> ', destination); |
|
|
|
|
if (destination.length === 1) { |
|
|
|
|
return ElMessage({ message: '请选择正确到站地址', type: 'warning' }); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// 筛选到站 |
|
|
|
|
const _findeLocation = details.regionOptione |
|
|
|
|
.find(val => val.value === destination[0]) |
|
|
|
@ -1937,12 +2149,45 @@ const handleSubmit = (formEl: FormInstance | undefined) => {
|
|
|
|
|
|
|
|
|
|
// 记录提交参数 |
|
|
|
|
details.submitData = submitData; |
|
|
|
|
res = await postUpdateWaybill(submitData); |
|
|
|
|
const response = await postUpdateWaybillVerify(submitData); |
|
|
|
|
if (response.data.code !== 200) return; |
|
|
|
|
|
|
|
|
|
if (!response.data.data) return ElMessage.warning('没有更改的数据'); |
|
|
|
|
|
|
|
|
|
// console.log( |
|
|
|
|
// 'response.data.data.replaceAll :>> ', |
|
|
|
|
// response.data.data.replaceAll(';', '</ br>') |
|
|
|
|
// ); |
|
|
|
|
|
|
|
|
|
ElMessageBox.alert(response.data.data.replaceAll(';', ' <br /> '), '被更改数据', { |
|
|
|
|
// if you want to disable its autofocus |
|
|
|
|
// autofocus: false, |
|
|
|
|
dangerouslyUseHTMLString: true, |
|
|
|
|
confirmButtonText: '确认', |
|
|
|
|
callback: async (action: Action) => { |
|
|
|
|
try { |
|
|
|
|
details.loadingObj.submitLoadingBtn = true; |
|
|
|
|
|
|
|
|
|
const res = await postUpdateWaybill(submitData); |
|
|
|
|
const { code, msg } = res.data; |
|
|
|
|
if (code !== 200) return; |
|
|
|
|
if (msg) ElMessage.success(msg); |
|
|
|
|
|
|
|
|
|
back(); |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log('error :>> ', error); |
|
|
|
|
} finally { |
|
|
|
|
details.loadingObj.submitLoadingBtn = false; |
|
|
|
|
} |
|
|
|
|
}, |
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
const { code, msg } = res.data; |
|
|
|
|
if (code !== 200) return; |
|
|
|
|
if (msg) ElMessage.success(msg); |
|
|
|
|
back(); |
|
|
|
|
|
|
|
|
|
// 开启提示框, 是否继续开单 |
|
|
|
|
if (details.pageInfo.type === 'add') details.popUpShow.titleVisited = true; |
|
|
|
|
console.log('res :>> ', res); |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log('error :>> ', error); |
|
|
|
@ -1956,6 +2201,11 @@ const handleSubmit = (formEl: FormInstance | undefined) => {
|
|
|
|
|
}); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 重复开单 */ |
|
|
|
|
const handleRepetition = () => { |
|
|
|
|
handleChooseOrder(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
watch( |
|
|
|
|
$route, |
|
|
|
|
() => { |
|
|
|
@ -2146,6 +2396,11 @@ $borderColor: #172e60;
|
|
|
|
|
margin-top: 15px; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
.mt20 { |
|
|
|
|
margin-top: 20px; |
|
|
|
|
color: var(--el-color-primary); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
.red { |
|
|
|
|
color: var(--token-simulation-red-base-62); |
|
|
|
|
} |
|
|
|
@ -2153,4 +2408,13 @@ $borderColor: #172e60;
|
|
|
|
|
:deep(.el-divider__text.is-center) { |
|
|
|
|
font-size: 28px; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
.overflow { |
|
|
|
|
overflow: hidden; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
:deep(.el-form-item__label) { |
|
|
|
|
color: var(--el-color-primary); |
|
|
|
|
font-weight: bold; |
|
|
|
|
} |
|
|
|
|
</style> |
|
|
|
|