Browse Source

Merge branch 'dev' of http://47.108.105.48:3000/java_project/logpm_page into dev

pre-production
马远东 1 year ago
parent
commit
7db4cca20a
  1. 23
      src/api/distribution/WarehousingByTrainNumber.js
  2. 51
      src/api/distribution/createTask.js
  3. 10
      src/option/distribution/BookingNote.js
  4. 11
      src/option/supervise/supervise.js
  5. 2
      src/option/waybill/TemporaryStorageList.js
  6. 2
      src/option/waybill/WarehousingByTrainNumber.js
  7. BIN
      src/static/icon_box.png
  8. BIN
      src/static/icon_box_file.png
  9. BIN
      src/static/icon_box_green.png
  10. BIN
      src/static/icon_box_green1.png
  11. BIN
      src/static/icon_box_red.png
  12. BIN
      src/static/icon_box_yellow.png
  13. BIN
      src/static/icon_car.png
  14. BIN
      src/static/icon_car_blue.png
  15. BIN
      src/static/icon_car_green.png
  16. BIN
      src/static/icon_city.png
  17. BIN
      src/static/icon_data.png
  18. BIN
      src/static/icon_day.png
  19. BIN
      src/static/icon_head.png
  20. BIN
      src/static/icon_home.png
  21. BIN
      src/static/icon_home1.png
  22. BIN
      src/static/icon_home2.png
  23. BIN
      src/static/icon_home_data.png
  24. BIN
      src/static/icon_home_storage.png
  25. BIN
      src/static/icon_message.png
  26. BIN
      src/static/icon_message_red.png
  27. BIN
      src/static/icon_money.png
  28. BIN
      src/static/icon_money1.png
  29. BIN
      src/static/icon_money_day.png
  30. BIN
      src/static/icon_money_month.png
  31. BIN
      src/static/icon_month.png
  32. BIN
      src/static/icon_storage.png
  33. 1247
      src/static/listOfLoadedWagons.html
  34. 654
      src/views/basicdata/brand/basicClient.vue
  35. 103
      src/views/distribution/checkInventoryTask/createTask.vue
  36. 2697
      src/views/distribution/checkInventoryTask/createTask2.vue
  37. 64
      src/views/distribution/deliverylist/distributionDeliveryListedt.vue
  38. 1
      src/views/distribution/inventory/distrilbutionBillLading.vue
  39. 47
      src/views/supervise/IndicatorList.vue
  40. 22
      src/views/waybill/CreateZeroOrder.vue
  41. 113
      src/views/waybill/TemporaryStorageList.vue
  42. 308
      src/views/waybill/WarehousingByTrainNumber.vue
  43. 381
      src/views/wel/index.vue
  44. 369
      src/views/wel/index2.vue

23
src/api/distribution/WarehousingByTrainNumber.js

@ -0,0 +1,23 @@
import request from '@/axios';
/**
* 根据类型获取需要入库的暂存单
*/
export const postFindIncomingOrderList = (data = {}) => {
return request({
url: '/api/logpm-trunkline/incoming/findIncomingOrderList',
method: 'post',
data,
});
};
/**
* 入库
*/
export const postIncomingBatchOrder = (data = {}) => {
return request({
url: '/api/logpm-trunkline/incoming/incomingBatchOrder',
method: 'post',
data,
});
};

51
src/api/distribution/createTask.js

@ -63,32 +63,32 @@ export const $_postBatchDelete = params => {
});
};
// 新增盘点任务
export const $_submit = (data) => {
export const $_submit = data => {
return request({
url: '/api/logpm-basic/material/submit',
method: 'post',
data
})
}
data,
});
};
/**
* 盘点详情
*/
export const $_getDetailInfo = params => {
return request({
url: '/api/logpm-warehouse/blade-taskQuest/taskQuest/getDetailInfo',
method:'get',
method: 'get',
params,
});
};
// 查询货位信息
export const $_getList = ( params) => {
export const $_getList = params => {
return request({
url: '/api/logpm-basicdata/goodsAllocation/list',
method: 'get',
params
})
}
params,
});
};
/**
* 盘点状态修改
@ -96,7 +96,7 @@ export const $_getList = ( params) => {
export const $_updateQuestChildInfo = data => {
return request({
url: '/api/logpm-warehouse/blade-taskQuest/taskQuest/updateQuestChildInfo',
method:'put',
method: 'put',
data,
});
};
@ -107,42 +107,33 @@ export const $_updateQuestChildInfo = data => {
export const $_getQuestChildInfo = params => {
return request({
url: '/api/logpm-warehouse/blade-taskQuest/taskQuest/getQuestChildInfo',
method:'get',
method: 'get',
params,
});
};
/**
* 盘点查询
*/
export const $_materialList = params => {
return request({
url: '/api/logpm-basic/material/list',
method:'get',
method: 'get',
params,
});
};
/**
* 删除盘点数据接口
*/
export const $_deleteQuestChild = params => {
return request({
url: '/api/logpm-warehouse/blade-taskQuest/taskQuest/deleteQuestChild',
method:'get',
method: 'get',
params,
});
};
/**
* 盘点详情保存
*/
@ -154,8 +145,6 @@ export const $_updateDetailInfo = data => {
});
};
/**
* 盘点日期延期
*/
@ -167,7 +156,6 @@ export const $_updateDate = data => {
});
};
/**
* 盘点对比数据
*/
@ -205,7 +193,6 @@ export const $_exportGetContrastInfo = params => {
});
};
// 盘点任务库存品
export const $_QuestSelectInventory = params => {
return request({
@ -216,7 +203,6 @@ export const $_QuestSelectInventory = params => {
};
// 盘点任务零担
export const $_taskQuestSelectZreo = params => {
return request({
url: '/api/logpm-warehouse/blade-taskQuest/taskQuest/SelectZreo',
@ -224,3 +210,14 @@ export const $_taskQuestSelectZreo = params => {
params,
});
};
/**
* 未盘点数据导出
*/
export const postExportContrastStockInfo = params => {
return request({
url: '/api/logpm-warehouse/blade-taskQuest/taskQuest/exportContrastStockInfo',
method: 'get',
params,
});
};

10
src/option/distribution/BookingNote.js

@ -136,7 +136,7 @@ export const ChangeOrderColumnList = [
head: false,
},
{
prop: 'unloadNumber',
prop: 'operationRemark',
label: '修改内容',
type: 1,
values: '',
@ -146,7 +146,7 @@ export const ChangeOrderColumnList = [
sortable: true,
},
{
prop: 'NumberOfPiecesInTheCar',
prop: 'createTime',
label: '申请时间',
type: 1,
values: '',
@ -156,7 +156,7 @@ export const ChangeOrderColumnList = [
sortable: true,
},
{
prop: 'unloadNumber',
prop: 'warehouseName',
label: '申请网点',
type: 1,
values: '',
@ -166,7 +166,7 @@ export const ChangeOrderColumnList = [
sortable: true,
},
{
prop: 'NumberOfPiecesInTheCar',
prop: 'createUserName',
label: '申请人',
type: 1,
values: '',
@ -176,7 +176,7 @@ export const ChangeOrderColumnList = [
sortable: true,
},
{
prop: 'unloadNumber',
prop: 'aaa',
label: '修改原因',
type: 1,
values: '',

11
src/option/supervise/supervise.js

@ -155,8 +155,6 @@ export const managementColumnList = [
head: false,
},
{
prop: 'createTime',
label: '创建时间',
@ -242,7 +240,7 @@ export const IndicatorColumnList = [
head: false,
},
{
prop: 'examineDeptName',
prop: 'rangeDeptName',
label: '考核范围',
type: 1,
values: '',
@ -253,7 +251,6 @@ export const IndicatorColumnList = [
head: false,
},
{
prop: 'point',
label: '考核分数',
@ -267,8 +264,8 @@ export const IndicatorColumnList = [
isshowSummary: true,
},
{
prop: 'createDeptName',
label: '考核归属部门',
prop: 'examineDeptName',
label: '指标归属部门',
type: 1,
values: '',
width: '130',
@ -335,7 +332,7 @@ export const IndicatorColumnList = [
// {
// prop: 'isObjection',
// label: '是否存在异议',
// label: '是否存在异议',
// type: 1,
// values: '',
// width: '130',

2
src/option/waybill/TemporaryStorageList.js

@ -28,7 +28,7 @@ export const columnList = [
{
prop: 'htMallName',
label: '汇通商场',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],

2
src/option/waybill/WarehousingByTrainNumber.js

@ -16,7 +16,7 @@ export const columnList = [
fixed: true,
},
{
prop: 'billladingCode',
prop: 'orderCode',
label: '订单自编号',
type: 1,
values: '',

BIN
src/static/icon_box.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 323 B

BIN
src/static/icon_box_file.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 348 B

BIN
src/static/icon_box_green.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 569 B

BIN
src/static/icon_box_green1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 513 B

BIN
src/static/icon_box_red.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 571 B

BIN
src/static/icon_box_yellow.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 233 B

BIN
src/static/icon_car.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 460 B

BIN
src/static/icon_car_blue.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 563 B

BIN
src/static/icon_car_green.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 425 B

BIN
src/static/icon_city.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 513 B

BIN
src/static/icon_data.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 580 B

BIN
src/static/icon_day.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 832 B

BIN
src/static/icon_head.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 564 B

BIN
src/static/icon_home.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 495 B

BIN
src/static/icon_home1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 620 B

BIN
src/static/icon_home2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 442 B

BIN
src/static/icon_home_data.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 498 B

BIN
src/static/icon_home_storage.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 649 B

BIN
src/static/icon_message.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 697 B

BIN
src/static/icon_message_red.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 639 B

BIN
src/static/icon_money.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 516 B

BIN
src/static/icon_money1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.0 KiB

BIN
src/static/icon_money_day.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
src/static/icon_money_month.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
src/static/icon_month.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 726 B

BIN
src/static/icon_storage.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

1247
src/static/listOfLoadedWagons.html

File diff suppressed because it is too large Load Diff

654
src/views/basicdata/brand/basicClient.vue

@ -60,7 +60,7 @@
<el-button type="danger" icon="el-icon-delete" @click="handleDelete" plain
> </el-button
>
<el-button type="danger" icon="el-icon-delete" @click="handleImport"> </el-button>
<el-button type="danger" icon="Upload" @click="handleImport"> </el-button>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
@ -184,195 +184,201 @@
:close-on-click-modal="false"
append-to-body
>
<el-form :disabled="view" ref="form" :model="form" :rules="rules" label-width="120px">
<!-- 表单字段 -->
<el-form-item label="客户编码" prop="clientCode">
<el-input
v-model="form.clientCode"
:validate-method="validateInput"
placeholder="请输入客户编码"
style="width: 100%"
:disabled="viewClientEntd"
/>
</el-form-item>
<el-form-item label="客户名称" prop="clientName">
<el-input v-model="form.clientName" :validate-method="CustomerName" :disabled="CustomerEntd" placeholder="请输入客户名称" style="width: 100%" />
</el-form-item>
<el-form-item label="客户类型" prop="clientType">
<!-- <el-input v-model="form.clientName" placeholder="请输入客户名称" style="width: 100%"/>-->
<!-- <el-select v-model="form.clientType" class="m-2" placeholder="请选择客户类型" style="width: 100%">-->
<!-- <el-option label="发货方" value="1"/>-->
<!-- <el-option label="收货方" value="2"/>-->
<!-- </el-select>-->
<el-select
v-model="form.clientType"
class="m-2"
placeholder="请选择客户端类型"
style="width: 100%"
>
<el-option
v-for="item in clientType"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
<div v-loading="loadingObj.submitLoading">
<el-form :disabled="view" ref="form" :model="form" :rules="rules" label-width="120px">
<!-- 表单字段 -->
<el-form-item label="客户编码" prop="clientCode">
<el-input
v-model="form.clientCode"
:validate-method="validateInput"
placeholder="请输入客户编码"
style="width: 100%"
:disabled="viewClientEntd"
/>
</el-select>
</el-form-item>
<el-form-item label="服务类型" prop="typeServiceList">
<el-select
v-model="form.typeServiceList"
multiple
placeholder="请选择"
style="width: 100%"
@change="coverCharge"
>
<el-option
v-for="item in freightType"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
</el-form-item>
<el-form-item label="客户名称" prop="clientName">
<el-input
v-model="form.clientName"
placeholder="请输入客户名称"
style="width: 100%"
/>
</el-form-item>
<el-form-item label="客户类型" prop="clientType">
<!-- <el-input v-model="form.clientName" placeholder="请输入客户名称" style="width: 100%"/>-->
<!-- <el-select v-model="form.clientType" class="m-2" placeholder="请选择客户类型" style="width: 100%">-->
<!-- <el-option label="发货方" value="1"/>-->
<!-- <el-option label="收货方" value="2"/>-->
<!-- </el-select>-->
<el-select
v-model="form.clientType"
class="m-2"
placeholder="请选择客户端类型"
style="width: 100%"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="配送类型" prop="businessType" v-if="distriType">
<el-radio-group
v-model="form.businessType"
class="ml-4"
v-for="item in distributionType"
>
<el-radio :label="item.dictKey" size="large" style="margin-right: 25px">{{
item.dictValue
}}</el-radio>
<!-- <el-radio label="2" size="large">Option 2</el-radio>-->
</el-radio-group>
<!-- </div>-->
</el-form-item>
<!-- <el-form-item label="客户端类型" prop="typeService">
&lt;!&ndash; <el-input v-model="form.typeService" placeholder="请输入客户类型"/>&ndash;&gt;
&lt;!&ndash; <el-input v-model="form.typeService" placeholder="请输入客户类型;1 C端 2 B端"/>&ndash;&gt;
<el-select v-model="form.typeService" class="m-2" placeholder="请选择客户端类型" style="width: 100%">
<el-option
v-for="item in clientType"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>-->
<el-form-item label="联系人" prop="linkman" v-if="viewEntd">
<el-input v-model="form.linkman" placeholder="请输入联系人" style="width: 100%" />
</el-form-item>
<el-form-item label="联系电话" prop="phone" v-if="viewEntd">
<el-input v-model="form.phone" placeholder="请输入联系电话" style="width: 100%" />
</el-form-item>
<el-form-item label="地址" prop="bladeRegionProvinceId">
<!-- <el-input v-model="form.bladeRegionProvinceId" placeholder="请输入省份"/>-->
<el-cascader
:options="optioner"
style="width: 100%"
v-model="form.bladeRegionProvinceId"
:props="{
checkStrictly: false,
}"
filterable
>
<template #default="{ node, data }">
<span>{{ data.label }}</span>
<span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
</template>
</el-cascader>
</el-form-item>
<el-form-item label="详细地址" prop="detailedly">
<el-input v-model="form.detailedly" placeholder="请填写详细地址" style="width: 100%" />
</el-form-item>
<!-- <el-form-item label="三方商城" prop="tripartiteMall">-->
<!-- <el-input v-model="form.tripartiteMall" placeholder="请填写三方商城" style="width: 100%" />-->
<!-- </el-form-item>-->
<!-- <el-form-item label="开票信息" prop="billingInformation">-->
<!-- <el-input v-model="form.billingInformation" placeholder="请填写开票信息" style="width: 100%" />-->
<!-- </el-form-item>-->
<!-- <el-form-item label="市" prop="bladeRegionCityId">-->
<!-- <el-input v-model="form.bladeRegionCityId" placeholder="请输入市"/>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="区/县" prop="bladeRegionAreaId">-->
<!-- <el-input v-model="form.bladeRegionAreaId" placeholder="请输入区/县"/>-->
<!-- </el-form-item>-->
<el-form-item label="合同附件" prop="leaseAccessories" style="width: 100%">
<!-- <el-input v-model="form.leaseAccessories" placeholder="请输入合同附件"/>-->
<el-upload
v-model:file-list="fileList"
class="upload-demo"
:action="action"
:headers="headers"
multiple
:on-preview="handlePreview"
:on-success="
(response, file, fileList) => {
uploadSuccess(fileList);
}
"
:on-remove="handleRemove"
:before-remove="beforeRemove"
:before-upload="beforeUploadFn"
:limit="3"
:on-exceed="handleExceed"
>
<el-button>上传</el-button>
<template #tip>
<div class="el-upload__tip">大小不超过500KB的jpg/png文件</div>
</template>
</el-upload>
<el-image-viewer
v-if="showImgViewer"
:url-list="imgPreviewUrl"
@close="handleCo"
:z-index="300"
fit="cover"
/>
</el-form-item>
<el-form-item label="合同开始时间" prop="contractStartTime" label-width="120px">
<!-- <el-input v-model="form.contractStartTime" placeholder="请输入合同开始时间"/>-->
<div class="demo-date-picker" style="width: 60%">
<div class="block">
<!-- <span class="demonstration">Default</span>-->
<el-date-picker
v-model="form.contractStartTime"
type="date"
placeholder="选择时间"
format="YYYY/MM/DD HH:mm:ss"
value-format="YYYY-MM-DD HH:mm:ss"
<el-option
v-for="item in clientType"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</div>
</div>
</el-form-item>
<el-form-item label="合同结束时间" prop="contractEntTime" label-width="120px">
<!-- <el-input v-model="form.contractEntTime" placeholder="请输入合同结束时间"/>-->
<div class="demo-date-picker">
<div class="block">
<!-- <span class="demonstration">Default</span>-->
<el-date-picker
v-model="form.contractEntTime"
type="date"
placeholder="选择时间"
format="YYYY/MM/DD HH:mm:ss"
value-format="YYYY-MM-DD HH:mm:ss"
</el-select>
</el-form-item>
<el-form-item label="服务类型" prop="typeServiceList">
<el-select
v-model="form.typeServiceList"
multiple
placeholder="请选择"
style="width: 100%"
@change="coverCharge"
>
<el-option
v-for="item in freightType"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="配送类型" prop="businessType" v-if="distriType">
<el-radio-group
v-model="form.businessType"
class="ml-4"
v-for="item in distributionType"
>
<el-radio :label="item.dictKey" size="large" style="margin-right: 25px">{{
item.dictValue
}}</el-radio>
<!-- <el-radio label="2" size="large">Option 2</el-radio>-->
</el-radio-group>
<!-- </div>-->
</el-form-item>
<!-- <el-form-item label="客户端类型" prop="typeService">
&lt;!&ndash; <el-input v-model="form.typeService" placeholder="请输入客户类型"/>&ndash;&gt;
&lt;!&ndash; <el-input v-model="form.typeService" placeholder="请输入客户类型;1 C端 2 B端"/>&ndash;&gt;
<el-select v-model="form.typeService" class="m-2" placeholder="请选择客户端类型" style="width: 100%">
<el-option
v-for="item in clientType"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>-->
<el-form-item label="联系人" prop="linkman" v-if="viewEntd">
<el-input v-model="form.linkman" placeholder="请输入联系人" style="width: 100%" />
</el-form-item>
<el-form-item label="联系电话" prop="phone" v-if="viewEntd">
<el-input v-model="form.phone" placeholder="请输入联系电话" style="width: 100%" />
</el-form-item>
<el-form-item label="地址" prop="bladeRegionProvinceId">
<!-- <el-input v-model="form.bladeRegionProvinceId" placeholder="请输入省份"/>-->
<el-cascader
:options="optioner"
style="width: 100%"
v-model="form.bladeRegionProvinceId"
:props="{
checkStrictly: false,
}"
filterable
>
<template #default="{ node, data }">
<span>{{ data.label }}</span>
<span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
</template>
</el-cascader>
</el-form-item>
<el-form-item label="详细地址" prop="detailedly">
<el-input
v-model="form.detailedly"
placeholder="请填写详细地址"
style="width: 100%"
/>
</el-form-item>
<el-form-item label="默认付款方式" prop="defaultPaymentMethods">
<el-select v-model="form.defaultPaymentMethods" placeholder="请选择默认付款方式">
<el-option
v-for="item in defaultPaymentMethodsOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</div>
</div>
</el-form-item>
</el-form>
<!-- 表单按钮 -->
<template #footer>
<span v-if="!view" class="dialog-footer">
</el-select>
</el-form-item>
<!-- <el-form-item label="三方商城" prop="tripartiteMall">-->
<!-- <el-input v-model="form.tripartiteMall" placeholder="请填写三方商城" style="width: 100%" />-->
<!-- </el-form-item>-->
<!-- <el-form-item label="开票信息" prop="billingInformation">-->
<!-- <el-input v-model="form.billingInformation" placeholder="请填写开票信息" style="width: 100%" />-->
<!-- </el-form-item>-->
<!-- <el-form-item label="市" prop="bladeRegionCityId">-->
<!-- <el-input v-model="form.bladeRegionCityId" placeholder="请输入市"/>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="区/县" prop="bladeRegionAreaId">-->
<!-- <el-input v-model="form.bladeRegionAreaId" placeholder="请输入区/县"/>-->
<!-- </el-form-item>-->
<el-form-item label="合同附件" prop="leaseAccessories" style="width: 100%">
<!-- <el-input v-model="form.leaseAccessories" placeholder="请输入合同附件"/>-->
<el-upload
v-model:file-list="fileList"
class="upload-demo"
:action="action"
:headers="headers"
multiple
:on-preview="handlePreview"
:on-success="
(response, file, fileList) => {
uploadSuccess(fileList);
}
"
:on-remove="handleRemove"
:before-remove="beforeRemove"
:before-upload="beforeUploadFn"
:limit="3"
:on-exceed="handleExceed"
>
<el-button type="Primary" icon="Position">上传</el-button>
<template #tip>
<div class="el-upload__tip">大小不超过500KB的jpg/png文件</div>
</template>
</el-upload>
<el-image-viewer
v-if="showImgViewer"
:url-list="imgPreviewUrl"
@close="handleCo"
:z-index="300"
fit="cover"
/>
</el-form-item>
<el-form-item label="合同开始时间" prop="contractStartTime" label-width="120px">
<el-date-picker
v-model="form.contractStartTime"
type="date"
placeholder="选择时间"
format="YYYY/MM/DD HH:mm:ss"
value-format="YYYY-MM-DD HH:mm:ss"
/>
</el-form-item>
<el-form-item label="合同结束时间" prop="contractEntTime" label-width="120px">
<el-date-picker
v-model="form.contractEntTime"
type="date"
placeholder="选择时间"
format="YYYY/MM/DD HH:mm:ss"
value-format="YYYY-MM-DD HH:mm:ss"
/>
</el-form-item>
</el-form>
<!-- 表单按钮 -->
<div v-if="!view" class="flex-c-c">
<el-button type="primary" icon="el-icon-circle-check" @click="handleSubmit('form')"
> </el-button
>
<el-button icon="el-icon-circle-close" @click="box = false"> </el-button>
</span>
</template>
</div>
</div>
</el-dialog>
<!-- 账号绑定弹出框页面
@ -759,24 +765,26 @@ export default {
// { min: 3, max: 5, message: ' 3 5 ', trigger: 'blur' }
{ validator: this.CustomerName, trigger: 'blur' },
],
typeService: [{ required: true, message: '请选择客户端类型', trigger: 'blur' }],
typeService: [{ required: true, message: '请选择客户端类型', trigger: ['blur', 'change'] }],
businessType: [
{ required: true, message: '请选择配送业务类型', trigger: 'change' },
// { min: 3, max: 5, message: ' 3 5 ', trigger: 'blur' }
// { min: 3, max: 5, message: ' 3 5 ', trigger: ['blur', 'change'] }
],
clientType: [{ required: true, message: '请选择客户类型', trigger: 'change' }],
typeServiceList: [{ required: true, message: '请选择服务类型', trigger: 'change' }],
linkman: [{ required: true, message: '请填写联系人', trigger: 'blur' }],
detailedly: [{ required: true, message: '请填写详细地址', trigger: 'blur' }],
phone: [{ required: true, message: '请填写联系电话', trigger: 'blur' }],
contractEntTime: [
{ type: 'date', required: true, message: '请选择合同结束时间', trigger: 'change' },
],
contractStartTime: [
{ type: 'date', required: true, message: '请选择合同开始时间', trigger: 'change' },
],
linkman: [{ required: true, message: '请填写联系人', trigger: ['blur', 'change'] }],
detailedly: [{ required: true, message: '请填写详细地址', trigger: ['blur', 'change'] }],
phone: [{ required: true, message: '请填写联系电话', trigger: ['blur', 'change'] }],
// contractEntTime: [
// { type: 'date', required: true, message: '', trigger: 'change' },
// ],
// contractStartTime: [
// { type: 'date', required: true, message: '', trigger: 'change' },
// ],
bladeRegionProvinceId: [{ required: true, message: '请选择地址', trigger: 'change' }],
// leaseAccessories: [{ required: true, message: '', trigger: 'blur' }],
defaultPaymentMethods: [
{ required: true, message: '请选择默认付款方式', trigger: 'change' },
],
},
bianji: false,
@ -785,6 +793,32 @@ export default {
name: '',
phone: '',
},
/** 付款方式 */
defaultPaymentMethodsOptions: [
{
value: '1',
label: '现付',
},
{
value: '2',
label: '到付',
},
{
value: '3',
label: '月结',
},
{
value: '4',
label: '回付',
},
{
value: '5',
label: '内部结算',
},
],
loadingObj: {
submitLoading: false,
},
};
},
created() {},
@ -1194,42 +1228,56 @@ export default {
if (!this.form.id) {
console.log('添加提交的数据:', this.form);
this.$refs[from].validate(valid => {
this.$refs[from].validate(async valid => {
if (valid) {
// this.form.typeService = !!this.form.typeService ? parseInt(this.form.typeService) : undefined;
this.form.bladeRegionCityId = this.form.bladeRegionProvinceId[1];
this.form.bladeRegionAreaId = this.form.bladeRegionProvinceId[2];
this.form.bladeRegionProvinceId = this.form.bladeRegionProvinceId[0];
console.log('上传llll>>>', this.form);
add(this.form).then(() => {
try {
this.loadingObj.submitLoading = true;
// this.form.typeService = !!this.form.typeService ? parseInt(this.form.typeService) : undefined;
this.form.bladeRegionCityId = this.form.bladeRegionProvinceId[1];
this.form.bladeRegionAreaId = this.form.bladeRegionProvinceId[2];
this.form.bladeRegionProvinceId = this.form.bladeRegionProvinceId[0];
console.log('上传llll>>>', this.form);
await add(this.form);
this.box = false;
this.onLoad(this.page);
this.$message({
type: 'success',
message: '操作成功!',
});
});
} catch (error) {
console.log('error :>> ', error);
} finally {
this.loadingObj.submitLoading = false;
}
} else {
console.log('error submit!!');
return false;
}
});
} else {
this.$refs[from].validate(valid => {
this.$refs[from].validate(async valid => {
if (valid) {
console.log('修改提交的数据:', this.form);
// this.form.typeService = !!this.form.typeService ? parseInt(this.form.typeService) : undefined;
this.form.bladeRegionCityId = this.form.bladeRegionProvinceId[1];
this.form.bladeRegionAreaId = this.form.bladeRegionProvinceId[2];
this.form.bladeRegionProvinceId = this.form.bladeRegionProvinceId[0];
update(this.form).then(() => {
try {
this.loadingObj.submitLoading = true;
console.log('修改提交的数据:', this.form);
// this.form.typeService = !!this.form.typeService ? parseInt(this.form.typeService) : undefined;
this.form.bladeRegionCityId = this.form.bladeRegionProvinceId[1];
this.form.bladeRegionAreaId = this.form.bladeRegionProvinceId[2];
this.form.bladeRegionProvinceId = this.form.bladeRegionProvinceId[0];
await update(this.form);
this.box = false;
this.onLoad(this.page);
this.$message({
type: 'success',
message: '操作成功!',
});
});
} catch (error) {
console.log('error :>> ', error);
} finally {
this.loadingObj.submitLoading = false;
}
} else {
console.log('error submit!!');
return false;
@ -1244,7 +1292,10 @@ export default {
this.box = true;
this.distriType = false;
this.viewClientEntd = false;
this.CustomerEntd=false;
this.$nextTick(() => {
this.$refs.form.resetFields();
this.form.defaultPaymentMethods = '1';
});
},
handleAddSon(row) {
console.log(row);
@ -1483,102 +1534,104 @@ export default {
this.query.bladeRegionAreaId = this.query.bladeRegionProvinceId[2];
this.query.bladeRegionProvinceId = this.query.bladeRegionProvinceId[0];
}
getList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
const data = res.data.data;
console.log(data);
getList(page.currentPage, page.pageSize, Object.assign(params, this.query))
.then(res => {
const data = res.data.data;
console.log(data);
data.records.forEach(i => {
let ke = this.clientType.find(kh => parseInt(kh.dictKey) == parseInt(i.clientType));
// console.log("<><><>",ke);
if (!!ke) {
i.clientTypeName = ke.dictValue;
// console.log('==-=-=', i.clientType, ke.dictKey, ke.dictValue);
}
if (!i.clientType) {
i.clientTypeName = '无';
}
let typeServiceName = [];
if (!i.typeServiceBusiness) {
i.typeServiceName = '无';
} else {
i.typeServiceBusiness.forEach(ty => {
let fuw = this.freightType.find(
fw => parseInt(fw.dictKey) == parseInt(ty.typeService)
);
if (!!fuw) {
// console.log("fuw",fuw);
typeServiceName.push(fuw.dictValue);
// console.log('==-=-=', i.typeService, fuw.dictKey, fuw.dictValue);
}
});
i.typeServiceNameFy = typeServiceName.join(',');
}
});
//
// let dz = '';
// data.records.forEach(it => {
// let arrsheng = this.optioner.filter(i => {
// return it.bladeRegionProvinceId == i.value;
// });
// if (arrsheng.length == 0) return;
// // console.log("========",JSON.parse(JSON.stringify(arrsheng)) );
// let arrshi = arrsheng[0].children.filter(i => {
// return it.bladeRegionCityId == i.value;
// });
// // console.log("========",JSON.parse(JSON.stringify(arrsheng)) );
// let arrqu = arrshi[0].children.filter(i => {
// return it.bladeRegionAreaId == i.value;
// });
data.records.forEach(i => {
let ke = this.clientType.find(kh => parseInt(kh.dictKey) == parseInt(i.clientType));
// console.log("<><><>",ke);
if (!!ke) {
i.clientTypeName = ke.dictValue;
// console.log('==-=-=', i.clientType, ke.dictKey, ke.dictValue);
}
if (!i.clientType) {
i.clientTypeName = '无';
}
let typeServiceName = [];
// // console.log("========",JSON.parse(JSON.stringify(arrsheng)) );
// dz =
// arrsheng[0].label +
// (arrshi[0].label ? `/${arrshi[0].label}` : ``) +
// (arrqu[0]?.label ? `/${arrqu[0]?.label}` : '');
// it.bladeRegionProvinceId = dz;
// });
//
let dz = '';
data.records.forEach(it => {
let arrsheng = this.optioner.filter(i => {
return it.bladeRegionProvinceId == i.value;
if (!i.typeServiceBusiness) {
i.typeServiceName = '无';
} else {
i.typeServiceBusiness.forEach(ty => {
let fuw = this.freightType.find(
fw => parseInt(fw.dictKey) == parseInt(ty.typeService)
);
if (!!fuw) {
// console.log("fuw",fuw);
typeServiceName.push(fuw.dictValue);
// console.log('==-=-=', i.typeService, fuw.dictKey, fuw.dictValue);
}
});
i.typeServiceNameFy = typeServiceName.join(',');
}
});
let shengLabel = arrsheng.length > 0 ? arrsheng[0].label : ''; //
//
// let dz = '';
// data.records.forEach(it => {
// let arrsheng = this.optioner.filter(i => {
// return it.bladeRegionProvinceId == i.value;
// });
// if (arrsheng.length == 0) return;
// // console.log("========",JSON.parse(JSON.stringify(arrsheng)) );
// let arrshi = arrsheng[0].children.filter(i => {
// return it.bladeRegionCityId == i.value;
// });
// // console.log("========",JSON.parse(JSON.stringify(arrsheng)) );
// let arrqu = arrshi[0].children.filter(i => {
// return it.bladeRegionAreaId == i.value;
// });
if (arrsheng.length === 0) {
it.bladeRegionProvinceId = shengLabel; //
return;
}
// // console.log("========",JSON.parse(JSON.stringify(arrsheng)) );
// dz =
// arrsheng[0].label +
// (arrshi[0].label ? `/${arrshi[0].label}` : ``) +
// (arrqu[0]?.label ? `/${arrqu[0]?.label}` : '');
// it.bladeRegionProvinceId = dz;
// });
//
let dz = '';
data.records.forEach(it => {
let arrsheng = this.optioner.filter(i => {
return it.bladeRegionProvinceId == i.value;
});
let shengLabel = arrsheng.length > 0 ? arrsheng[0].label : ''; //
let arrshi = arrsheng[0].children.filter(i => {
return it.bladeRegionCityId == i.value;
});
let shiLabel = arrshi.length > 0 ? arrshi[0].label : ''; //
if (arrsheng.length === 0) {
it.bladeRegionProvinceId = shengLabel; //
return;
}
if (arrshi.length === 0) {
dz = shengLabel; //
} else {
let arrqu = arrshi[0].children.filter(i => {
return it.bladeRegionAreaId == i.value;
let arrshi = arrsheng[0].children.filter(i => {
return it.bladeRegionCityId == i.value;
});
let shiLabel = arrshi.length > 0 ? arrshi[0].label : ''; //
let quLabel = arrqu.length > 0 ? arrqu[0].label : ''; //
if (arrshi.length === 0) {
dz = shengLabel; //
} else {
let arrqu = arrshi[0].children.filter(i => {
return it.bladeRegionAreaId == i.value;
});
dz = shengLabel + (shiLabel ? `/${shiLabel}` : '') + (quLabel ? `/${quLabel}` : '');
}
let quLabel = arrqu.length > 0 ? arrqu[0].label : ''; //
it.bladeRegionProvinceId = dz;
dz = shengLabel + (shiLabel ? `/${shiLabel}` : '') + (quLabel ? `/${quLabel}` : '');
}
it.bladeRegionProvinceId = dz;
});
this.page.total = data.total;
this.data = data.records;
this.data = this.$functions.newdatas(this.columnList, this.data);
this.loading = false;
this.selectionClear();
})
.catch(() => {
this.data = [];
this.loading = false;
});
this.page.total = data.total;
this.data = data.records;
this.data = this.$functions.newdatas(this.columnList, this.data);
this.loading = false;
this.selectionClear();
}).catch(()=>{
this.data =[]
this.loading = false;
});
},
},
};
@ -1605,4 +1658,13 @@ export default {
:deep(.el-cascader) {
width: 100%;
}
:deep(.el-date-editor.el-input) {
height: 100% !important;
width: 100% !important;
}
:deep(.el-select) {
width: 100% !important;
}
</style>

103
src/views/distribution/checkInventoryTask/createTask.vue

@ -1,5 +1,5 @@
<template>
<div class="maxContent">
<div class="maxContent" v-loading="loadingObj.pageLoading">
<!-- 搜索功能 -->
<div>
<!-- <div class="SoInput" v-show="searchSo">
@ -158,6 +158,14 @@
<el-button type="primary" @click="TcAddData" v-if="Statusjudgment"> </el-button>
<el-button type="primary" @click="InventoryModification">提交修改</el-button>
<el-button type="primary" @click="ModifyingStatus">修改状态</el-button>
<el-button
icon="Download"
v-if="InventoryState"
type="primary"
@click="handleUncountedExport"
>
导出
</el-button>
</div>
<div style="margin-left: 10px">
<!-- v-if="NotCounted" -->
@ -211,7 +219,7 @@
>
<template #header>
<el-input
@change="InputSo(item)"
@change="() => InputSo(item)"
clearable
v-if="item.type == 5 || item.prop == 'categoryName' || item.prop == 'materialCode'"
v-model="item.values"
@ -668,12 +676,13 @@ import {
$_exportGetContrastInfo,
$_getList,
$_postBatchDelete,
postExportContrastStockInfo,
} from '@/api/distribution/createTask';
import { ElMessageBox } from 'element-plus';
import { ElMessage } from 'element-plus';
import { downloadXls } from '@/utils/util';
import { getDictionaryBiz } from '@/api/system/dict';
import { ref } from 'vue';
import { ref, reactive } from 'vue';
import { off } from 'dom7';
const wLinput = ref(null); //
const wLinputState = ref(false); //
@ -730,6 +739,13 @@ const Statusjudgment = ref(false); //新增按钮
const DbEx = ref(null); //
const fullScreen = ref(false); //
const BatchAbandonment = ref([]); //
/** loading */
const loadingObj = reactive({
/** 页面loading */
pageLoading: false,
});
/** 未盘点query */
const uncountedQuery = reactive({});
const radioList = ref([
{ label: 0, txt: '在库', input: 'stockNum', disabled: true },
{ label: 1, txt: '破损', input: 'wornNum', disabled: true },
@ -1450,57 +1466,7 @@ const InputSo = val => {
console.log(row.value, 'row.value');
data.current = TccurrentPage.value;
data.size = TcpageSize.value;
// if (val.prop == 'categoryName') {
// //
// data.name = val.values;
// $_materialList(data).then(res => {
// console.log(res, '');
// if (res.data.data.records.length) {
// Tctotal.value = res.data.data.total;
// res.data.data.records.forEach(item => {
// item.Checkbox = true;
// });
// TcPdloading.value = false;
// console.log(res, '');
// TcPD.value = res.data.data.records;
// } else {
// Statusjudgment.value = true; //
// TcPD.value = res.data.data.records;
// ElMessage({
// message: '',
// type: 'warning',
// });
// }
// });
// return;
// }
// if (val.prop == 'materialCode') {
// //
// data.sku = val.values;
// $_materialList(data).then(res => {
// console.log(res, '');
// if (res.data.data.records.length) {
// Tctotal.value = res.data.data.total;
// res.data.data.records.forEach(item => {
// item.Checkbox = true;
// });
// TcPdloading.value = false;
// console.log(res, '');
// TcPD.value = res.data.data.records;
// } else {
// Statusjudgment.value = true; //
// TcPD.value = res.data.data.records;
// ElMessage({
// message: '',
// type: 'warning',
// });
// }
// });
// return;
// }
// if (val.prop != 'categoryName' || val.prop != 'materialCode') {
let dataS = {
questNum: UncountedDetails.value.questNum,
questId: UncountedDetails.value.id,
@ -2463,7 +2429,6 @@ const InventorySubmit = () => {
loading.value = true; //
console.log(SubData, '处理好的数据');
postAddtaskQuest(SubData).then(res => {
if ((res.data.code = 200)) {
ElMessage({
message: res.data.msg,
@ -2498,14 +2463,13 @@ const InventorySubmit = () => {
loading.value = true; //
postAddtaskQuest(SubData).then(res => {
if ((res.data.code = 200)) {
ElMessage({
message: res.data.msg,
type: 'success',
});
onLoad(); //
}
ElMessage({
message: res.data.msg,
type: 'success',
});
onLoad(); //
}
console.log(res, '盘点计划提交成功');
});
};
//
@ -2555,6 +2519,23 @@ const DelayButton = () => {
console.log('延期');
dialogTabData.value = true;
};
/** 未盘点数据导出 */
const handleUncountedExport = () => {
ElMessageBox.confirm('是否导出未盘点数据?').then(async () => {
try {
TcPdloading.value = true;
const res = await postExportContrastStockInfo({ questNum: UncountedDetails.value.questNum });
if (res.status !== 200) return;
downloadXls(res.data, '未盘点数据.xlsx');
} catch (error) {
console.log('error :>> ', error);
} finally {
TcPdloading.value = false;
}
});
};
</script>
<style lang="scss" scoped>

2697
src/views/distribution/checkInventoryTask/createTask2.vue

File diff suppressed because it is too large Load Diff

64
src/views/distribution/deliverylist/distributionDeliveryListedt.vue

@ -4339,9 +4339,8 @@ export default {
this.getReservationInventoryPackageListInfo(this.page);
}
})
.catch(res => {
}).finally(()=>{
.catch(res => {})
.finally(() => {
this.loading = false;
});
})
@ -4467,40 +4466,27 @@ export default {
//
LdBatchcancellation() {
return;
if (!this.selectionList.length) {
ElMessage({
message: '请勾选需要计划取消的数据',
type: 'warning',
});
return;
}
this.$confirm('是否进行批量计划取消?')
.then(() => {
this.loading = true; //
if (res.data.code == 200) {
this.truckload(this.page);
}
})
.catch(() => {});
},
//
PackBatchcancellation(){
if (!this.selectionList.length) {
//
PackBatchcancellation() {
if (!this.selectionList.length) {
ElMessage({
message: '请勾选需要计划取消的数据',
type: 'warning',
});
return;
}
let result = this.selectionList.every(item => item.orderPackageStatus == !70 || item.orderPackageLoadingStatus !=20);
console.log(result,'result');
if(!result){
let result = this.selectionList.every(
item => item.orderPackageStatus == !70 || item.orderPackageLoadingStatus != 20
);
console.log(result, 'result');
if (!result) {
ElMessage({
message: '有已经存在签收的订单或已装车,不满足批量签收条件',
type: 'warning',
});
return
return;
}
this.$confirm('是否进行批量计划取消?')
.then(() => {
@ -4521,15 +4507,13 @@ PackBatchcancellation(){
this.selectionList = []; //
this.loading = false;
})
.catch(res => {
}).finally(()=>{
.catch(res => {})
.finally(() => {
this.loading = false;
});
})
.catch(() => {});
},
},
//
Batchsigning() {
@ -4565,13 +4549,15 @@ PackBatchcancellation(){
});
return;
}
let result = this.selectionList.every(item => item.stockSignfoStatus == 10 && item.stockLockingStatus==10);
if(!result){
let result = this.selectionList.every(
item => item.stockSignfoStatus == 10 && item.stockLockingStatus == 10
);
if (!result) {
ElMessage({
message: '有已经存在签收的订单,不满足批量签收条件',
type: 'warning',
});
return
return;
}
this.$confirm('是否进行批量计划取消?')
.then(() => {
@ -4598,10 +4584,6 @@ PackBatchcancellation(){
});
})
.catch(() => {});
},
/**printTemplate
* 打印
@ -5355,7 +5337,7 @@ PackBatchcancellation(){
this.deliverydata = data;
// this.deliverydata.outboundDate = data.stockupInfo.outboundDate;
if (data.stockupInfo.forkliftName) {
if (data.stockupInfo && data.stockupInfo.forkliftName) {
this.deliverydata.forkliftName = data.stockupInfo.forkliftName;
}
@ -5464,9 +5446,9 @@ PackBatchcancellation(){
height: 500px !important;
}
}
:deep(.el-upload-dragger){
:deep(.el-upload-dragger) {
display: flex;
align-items: center;
justify-content: center;
align-items: center;
justify-content: center;
}
</style>

1
src/views/distribution/inventory/distrilbutionBillLading.vue

@ -2966,7 +2966,6 @@ export default {
}
params.genre = 1;
params.typeService = 3;
params.reservation = '30';
params.isAll = 0;
$_getListOne(page.currentPage, page.pageSize, Object.assign(params, this.queryOrder)).then(
res => {

47
src/views/supervise/IndicatorList.vue

@ -112,10 +112,15 @@
<el-button text @click="ClassificationIndicatorView(slotProps.scope)"
>查看</el-button
>
<el-button v-if="slotProps.scope.row.isEdit != '0'" text @click="ClassificationDditing(slotProps.scope)">编辑</el-button>
<el-button
v-if="slotProps.scope.row.isEdit != '0'"
text
@click="ClassificationDditing(slotProps.scope)"
>编辑</el-button
>
<el-button
v-if="slotProps.scope.row.isEdit == '1'"
text
type="primary"
@click="CategoryDeletion(slotProps.scope)"
>删除</el-button
@ -157,11 +162,7 @@
</el-form-item>
<el-form-item label="指标分类">
<el-input
v-model="lassificationform.parentClassifyName"
placeholder="暂无"
/>
<el-input v-model="lassificationform.parentClassifyName" placeholder="暂无" />
</el-form-item>
<el-form-item label="考核部门">
@ -173,8 +174,12 @@
</el-form-item>
<el-form-item label="整改结果">
<el-input :rows="2"
type="textarea" v-model="lassificationform.objectionRemark" placeholder="暂无" />
<el-input
:rows="2"
type="textarea"
v-model="lassificationform.objectionRemark"
placeholder="暂无"
/>
</el-form-item>
<el-form-item label="考核人">
@ -200,13 +205,11 @@
暂无
"
/>
</el-form-item>
<el-form-item label="意见反馈">
<el-input
:rows="2"
type="textarea"
:rows="2"
type="textarea"
v-model="lassificationform.appealReason"
placeholder="暂无"
/>
@ -439,7 +442,7 @@ const pageSize = ref(50);
const lassificationform = ref({}); //
const lassificationformedit = ref({}); //
const title = ref(true); //
const EditEnable = ref(true);//
const EditEnable = ref(true); //
const EditID = ref(true); //ID
const currentPage = ref(1);
const newlyAdded = ref(false); //
@ -815,10 +818,10 @@ const selectionChange = list => {
console.log(selectionList.value, '已经选中的数据');
};
function ProhibitSelection(val, index) {
if (val.isEdit == '0') {
return false;
} else {
if (val.isEdit == '1') {
return true;
} else {
return false;
}
}
const searchHide = () => {
@ -888,9 +891,9 @@ const ClassificationIndicatorView = val => {
}
// 0 1
if (res.data.data.isObjection=='0') {
if (res.data.data.isObjection == '0') {
lassificationform.value.isObjection = '没有';
} else if(res.data.data.isObjection=='1') {
} else if (res.data.data.isObjection == '1') {
lassificationform.value.isObjection = '存在';
}
console.log(res.data.data.pictures, '图片列表');
@ -953,10 +956,10 @@ const ClassificationIndicatorView = val => {
//
const ClassificationDditing = async val => {
console.log(val, '编辑弹窗展开');
if(val.row.isEdit ==1){
EditEnable.value=false;
}else if(val.row.isEdit == 2){
EditEnable.value=true;
if (val.row.isEdit == 1) {
EditEnable.value = false;
} else if (val.row.isEdit == 2) {
EditEnable.value = true;
}
srcList.value = [];
fileList.value = [];

22
src/views/waybill/CreateZeroOrder.vue

@ -1764,22 +1764,22 @@ let _ant1 = null;
const remoteMethod = val => {
if (_ant1) clearTimeout(_ant1);
_ant1 = setTimeout(async () => {
if (val) {
try {
details.loadingObj.loading = true;
const res = await getOpenOrderAdvanceFindWarehouseList({ warehouseName: val });
const { data, code } = res.data;
if (code !== 200) return;
details.options = data || [];
} catch (error) {
} finally {
details.loadingObj.loading = false;
}
try {
details.loadingObj.loading = true;
const res = await getOpenOrderAdvanceFindWarehouseList({ warehouseName: val });
const { data, code } = res.data;
if (code !== 200) return;
details.options = data || [];
} catch (error) {
} finally {
details.loadingObj.loading = false;
}
clearTimeout(_ant1);
}, 1000);
};
remoteMethod('');
/** 目的仓选择时给目的仓名称赋值 */
const destinationWarehouseNameChange = val => {
details.query.destinationWarehouseName = details.options.find(

113
src/views/waybill/TemporaryStorageList.vue

@ -311,27 +311,25 @@
</el-form>
</div>
<template #footer>
<div class="flex-c-c dialog-footer">
<el-button
icon="Position"
type="primary"
:loading="details.loadingObj.addTagLoading"
@click="handleSubmitAddTag(ruleFormRef)"
>
</el-button>
<el-button
icon="Refresh"
type="primary"
:loading="details.loadingObj.addTagLoading"
@click="handleRefreshAddTag(ruleFormRef)"
>
</el-button>
<el-button icon="Close" @click="details.popUpShow.addTagVisited = false"> </el-button>
</div>
</template>
<div class="flex-c-c dialog-footer">
<el-button icon="Close" @click="details.popUpShow.addTagVisited = false"> </el-button>
<el-button
icon="Refresh"
type="primary"
:loading="details.loadingObj.addTagLoading"
@click="() => handleRefreshAddTag(ruleFormRef)"
>
</el-button>
<el-button
icon="Position"
type="primary"
:loading="details.loadingObj.addTagLoading"
@click="() => handleSubmitAddTag(ruleFormRef)"
>
</el-button>
</div>
</el-dialog>
<!-- 导入 -- 批量开标签 -->
@ -1237,50 +1235,63 @@ const handleClose = res => {
};
/** 开标签提交 */
const handleSubmitAddTag = async (formEl: FormInstance | undefined) => {
const handleSubmitAddTag = (formEl: FormInstance | undefined) => {
if (!formEl) return;
await formEl.validate(async (valid, fields) => {
if (valid) {
console.log('submit!');
console.log('details.addTagForm :>> ', details.addTagForm);
try {
if (details.addTagForm.area.length < 2) return ElMessage.warning('区域最少选择到市');
details.loadingObj.addTagLoading = true;
const res = await postOpenLabel({
...details.addTagForm,
area: details.addTagForm.area.join(','),
});
const { code } = res.data;
if (code !== 200) return;
ElMessage.success('添加成功');
details.popUpShow.addTagVisited = false;
initOnLoad({}, true);
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.addTagLoading = false;
formEl.validate((valid, fields) => {
ElMessageBox.confirm('确认提交吗?', '提示', {
confirmButtonText: '确认',
cancelButtonText: '取消',
type: 'warning',
}).then(async () => {
if (valid) {
console.log('submit!');
console.log('details.addTagForm :>> ', details.addTagForm);
try {
if (details.addTagForm.area.length < 2) return ElMessage.warning('区域最少选择到市');
details.loadingObj.addTagLoading = true;
const res = await postOpenLabel({
...details.addTagForm,
area: details.addTagForm.area.join(','),
});
const { code } = res.data;
if (code !== 200) return;
ElMessage.success('添加成功');
details.popUpShow.addTagVisited = false;
initOnLoad({}, true);
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.addTagLoading = false;
}
} else {
console.log('error submit!', fields);
}
} else {
console.log('error submit!', fields);
}
});
});
};
/** 开标签重置 */
const handleRefreshAddTag = (formEl: FormInstance | undefined) => {
console.log('123123 :>> ', 123123);
if (!formEl) return;
formEl.resetFields();
ElMessageBox.confirm('确认重置吗?', '提示', {
confirmButtonText: '确认',
cancelButtonText: '取消',
type: 'warning',
}).then(() => {
formEl.resetFields();
});
};
/** 开启开标签弹窗 */
const handleOpenAddTagDlog = () => {
details.popUpShow.addTagVisited = true;
handleRefreshAddTag(ruleFormRef.value);
ruleFormRef.value.resetFields();
};
onActivated(() => {

308
src/views/waybill/WarehousingByTrainNumber.vue

@ -1,12 +1,23 @@
<template>
<basic-container>
<div class="avue-crud">
<div class="avue-crud" v-loading="details.loadingObj.pageLoading">
<!-- 搜索模块 -->
<div v-h5uShow="!search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="header_search">
<el-form-item label="车次号">
<el-input v-model="query.trainNumber" placeholder="请输入车次号" clearable></el-input>
<el-form-item label="搜索模式">
<el-radio-group v-model="details.searchType" class="ml-4">
<el-radio label="orderCode">订单号</el-radio>
<el-radio label="carsNo">车次号</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item :label="details.searchType === 'orderCode' ? '订单号' : '车次号'">
<el-input
v-model="query.incomingCode"
:placeholder="'请输入' + details.searchType === 'orderCode' ? '订单号' : '车次号'"
clearable
></el-input>
</el-form-item>
<!-- 查询按钮 -->
<el-form-item class="el-btn">
@ -21,7 +32,9 @@
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" icon="Van" @click="handlePutInStorage">批量入库</el-button>
<el-button type="primary" icon="Van" @click="handleBatchPutInStorage"
>批量入库</el-button
>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
@ -36,17 +49,27 @@
<el-row>
<!-- 列表模块 -->
<tablecmt
ref="tableNodeRef"
:columnList="details.columnList"
:tableData="details.data"
:loading="loadingObj.packageListLoading"
:loading="loadingObj.list"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@selection="selectionChange"
:isselectfun="handleIsSelect"
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'"> </template>
<template v-if="slotProps.scope.column.label === '操作'">
<el-text
v-if="Number(slotProps.scope.row.isIncoming) === 1"
@click="handlePutInStorage(slotProps.scope)"
>
入库
</el-text>
<el-text @click="handleGoDetails(slotProps.scope)">包明细</el-text>
</template>
</template>
</tablecmt>
</el-row>
@ -55,19 +78,6 @@
<el-row class="el-fy">
<div class="avue-crud__pagination flex-c-sb" style="width: 100%">
<div style="font-size: 14px">勾选数量: {{ selectionList.length }}</div>
<!-- 分页模块 -->
<el-pagination
align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total"
>
</el-pagination>
</div>
</el-row>
</div>
@ -89,18 +99,26 @@ import dayjs from 'dayjs';
import { mapGetters } from 'vuex';
/** 获取字典 */
import { getDictionaryBiz } from '@/api/system/dict';
import { getopenOrderAdvancePageList } from '@/api/waybill/TemporaryStorageList';
import { showOrderPackgeCode } from '@/api/distribution/distributionStockArticle';
import {
postFindIncomingOrderList,
postIncomingBatchOrder,
} from '@/api/distribution/WarehousingByTrainNumber';
import { downloadXls, setNodeHeight, getHtmls } from '@/utils/util';
import { columnList } from '@/option/waybill/WarehousingByTrainNumber';
import { useRouter } from 'vue-router';
import print from '@/utils/print';
import { ElMessage, ElMessageBox } from 'element-plus';
import { submit } from '@/api/base/region';
//
const $router = useRouter();
//
const tableNodeRef = ref();
const details = reactive<any>({
/** 搜索模式 */
searchType: 'orderCode',
/** 是否开启搜索 */
search: false,
/** 表格搜索条件 */
@ -140,12 +158,12 @@ const details = reactive<any>({
/** 包明细表头 */
columnList,
/** 包明细数据 */
data: [{}],
data: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
list: false,
packageListLoading: false,
pageLoading: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
@ -172,52 +190,53 @@ const details = reactive<any>({
form: {},
});
const {
search,
query,
shortcuts,
stockupDate,
data,
loadingObj,
selectionList,
drawerShow,
page,
popUpShow,
} = toRefs(details);
const { search, query, loadingObj, selectionList, drawerShow } = toRefs(details);
/** vuex */
const permission = computed(() => mapGetters(['permission', 'tagWel', 'tagList']));
console.log('permission :>> ', permission);
onMounted(() => {
const timer = setTimeout(() => {
details.listNode = document.querySelector('.maboxhi');
console.log('details.listNode :>> ', details.listNode);
details.listNode.style.transition = 'all .5s ease-out';
console.log('details.listNode :>> ', details.listNode);
clearTimeout(timer);
}, 100);
});
/** 请求页面数据 */
const onLoad = async (page: any, params = {}) => {
//
details.data = await getopenOrderAdvancePageList(page, { ...details.query, ...params });
const onLoad = async (params = {}) => {
try {
details.loadingObj.list = true;
//
const submitData = {
...details.query,
...params,
};
// 5, 4
submitData.incomingType = details.searchType === 'orderCode' ? 5 : 4;
const res = await postFindIncomingOrderList(submitData);
const { code, data } = res.data;
if (code !== 200) return;
details.data = data;
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.list = false;
}
};
onLoad(details.page);
/** 搜索 */
const searchChange = () => {
onLoad(details.page);
if (!details.searchType) return ElMessage.error('请选择搜索模式');
if (!details.query.incomingCode) return ElMessage.error('请输入搜索内容');
onLoad();
};
/** 清空表单 */
const searchReset = () => {
details.query = {};
details.stockupDate = [];
details.page.currentPage = 1;
onLoad(details.page);
details.data = [];
for (let i = 0; i < details.columnList.length; i++) {
details.columnList[i].values = '';
}
};
/** 展开列表控件 */
@ -229,13 +248,14 @@ const showdrawer = (_flag?: boolean) => {
const searchHide = () => {
details.search = !details.search;
setNodeHeight(details.listNode, '', true);
setNodeHeight(tableNodeRef.value.$el, '', true);
};
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
details.query[row.prop] = index;
onLoad(details.page);
if (!index) delete details.query[row.prop];
onLoad();
};
/** 表格表头时间选择 */
@ -248,7 +268,7 @@ const timesc = (index, row) => {
if (!index) {
delete details.query[row.prop];
}
onLoad(details.page);
onLoad();
};
/** 表格表头输入框搜索 */
@ -256,13 +276,12 @@ const btnsc = () => {};
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
details.query[row.prop] = index;
if (!index) delete details.query[row.prop];
if (row.prop === 'certificateTypeName') {
details.query['certificateType'] = index;
if (!index) delete details.query['certificateType'];
}
onLoad(details.page);
const _prop = row.prop.replace('Name', '');
details.query[_prop] = index;
if (!index) delete details.query[_prop];
onLoad();
};
/** 表格表头复选框选择 */
@ -270,15 +289,6 @@ const selectionChange = (list: any) => {
details.selectionList = list;
};
/** 每页数量改变执行的回调 */
const sizeChange = (pageSize: number) => {
details.page.pageSize = pageSize;
onLoad(details.page);
};
/** 页码改变执行的回调 */
const currentChange = () => {};
/**
* 设置列表 -- 固定函数
* 弹窗的勾选回调用于更改头部数组
@ -297,61 +307,84 @@ const setnewcolum = (newarr, headarr, type) => {
}
};
/** 弹出层开启前清除数据 */
const beforeClose = done => {
done();
details.form = {};
details.selectionList = [];
details.view = false;
};
/**
* 是否开启全屏
* @params(_type) 开启或关闭
*/
const handleFullScrean = (_type: 'open' | 'close', _name: string) => {
let _node = '';
if (_name) _node = document.querySelector(`.${_name} .maboxhi`);
switch (_name) {
//
case 'packageDetailColumnListVisited':
details.fullscreenObj.packageDetailColumnListVisited =
!details.fullscreenObj.packageDetailColumnListVisited;
if (_type === 'close') {
if (_node) setNodeHeight(_node, '500px');
} else {
if (_node) setNodeHeight(_node);
}
break;
default:
details.fullscreenObj[_name] = !details.fullscreenObj[_name];
if (_type === 'close') {
if (_node) setNodeHeight(_node, '500px');
} else {
if (_node) setNodeHeight(_node);
/** 入库 */
const handlePutInStorage = ({ row }) => {
ElMessageBox.confirm('确认批量入库吗?', '警告', {
confirmButtonText: '确认',
cancelButtonText: '取消',
type: 'warning',
})
.then(async () => {
try {
details.loadingObj.pageLoading = true;
const res = await postIncomingBatchOrder({
advanceIds: [row.id],
incomingType: details.searchType === 'orderCode' ? 5 : 4,
});
const { code, msg } = res.data;
if (code !== 200) return;
ElMessage.success(msg);
onLoad();
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.pageLoading = false;
}
break;
}
})
.catch(() => {});
};
/** 入库 */
const handlePutInStorage = row => {
/** 批量入库 */
const handleBatchPutInStorage = () => {
if (!details.selectionList.length) return ElMessage.error('请选择需要入库的数据');
ElMessageBox.confirm('确认批量入库吗?', '警告', {
confirmButtonText: '确认',
cancelButtonText: '取消',
type: 'warning',
})
.then(() => {
ElMessage({
type: 'success',
message: '入库成功',
});
.then(async () => {
try {
details.loadingObj.pageLoading = true;
const res = await postIncomingBatchOrder({
advanceIds: details.selectionList.map(val => val.id),
incomingType: details.searchType === 'orderCode' ? 5 : 4,
});
const { code, msg } = res.data;
if (code !== 200) return;
ElMessage.success(msg);
onLoad();
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.pageLoading = false;
}
})
.catch(() => {});
};
/** 详情 */
const handleGoDetails = ({ row }) => {
$router.push({
path: '/waybill/orderPackageListDetails?name=包明细',
query: {
id: row.id,
name: `订单 -- ${row.orderCode} 包明细`,
},
});
};
const handleIsSelect = val => {
if (Number(val.isIncoming) === 1) {
return true;
} else {
return false;
}
};
</script>
<style scoped lang="scss">
@ -371,19 +404,6 @@ const handlePutInStorage = row => {
height: 100% !important;
}
//
.add_row {
display: flex;
justify-content: space-between;
}
.add_row_title {
text-align: center;
margin-bottom: 10px;
font-size: 18px;
font-weight: bold;
}
//
.statistics_row {
margin: 10px 0;
@ -395,32 +415,4 @@ const handlePutInStorage = row => {
margin-right: 20px;
}
}
//
.crad_container {
display: flex;
.card_container_item {
flex: 1;
// padding: 10px;
border-radius: 5px;
box-shadow: 0 0 5px #ccc;
&:first-child {
margin-right: 20px;
}
.card_container_item_title {
padding: 10px;
border-bottom: 1px solid #ccc;
display: flex;
justify-content: space-between;
align-items: center;
}
.card_container_item_box {
padding: 10px;
}
}
}
</style>

381
src/views/wel/index.vue

@ -134,53 +134,49 @@
<div class="info">
<div class="name">{{ name }}</div>
<div class="slogan">您好欢迎使用货无忧</div>
<div class="title"> 成都数联物科信息技术有限公司</div>
<div class="time">{{currentTime}}</div>
<div class="title">成都数联物科信息技术有限公司</div>
<div class="time">{{ currentTime }}</div>
</div>
</div>
</div>
</template>
<script setup>
import { ref ,onMounted } from 'vue';
import { ref, onMounted } from 'vue';
const indexState = ref(false);
const currentTime = ref('0000年00月00日00时00分00秒');
const name = ref('');
name.value = JSON.parse(localStorage.getItem('TWMS-userInfo')).content.real_name;
setInterval(() => {
const now = new Date();
const year = now.getFullYear();
const month = String(now.getMonth() + 1).padStart(2, '0');
const day = String(now.getDate()).padStart(2, '0');
const hours = String(now.getHours()).padStart(2, '0');
const minutes = String(now.getMinutes()).padStart(2, '0');
const seconds = String(now.getSeconds()).padStart(2, '0');
currentTime.value = `${year}${month}${day}${hours}${minutes}${seconds}`;
}, 1000);
setInterval(() => {
const now = new Date();
const year = now.getFullYear();
const month = String(now.getMonth() + 1).padStart(2, '0');
const day = String(now.getDate()).padStart(2, '0');
const hours = String(now.getHours()).padStart(2, '0');
const minutes = String(now.getMinutes()).padStart(2, '0');
const seconds = String(now.getSeconds()).padStart(2, '0');
currentTime.value = `${year}${month}${day}${hours}${minutes}${seconds}`;
}, 1000);
</script>
<style scoped lang="scss">
.info {
display: flex;
display: flex;
flex-direction: column;
justify-content: center;
.name{
.name {
font-size: 40px;
color: #d3832a;
font-weight: bold;
}
.slogan{
.slogan {
font-size: 3em;
}
.time{
.time {
display: flex;
margin-top: 10px;
justify-content: flex-end;
}
.title{
.title {
display: flex;
margin-top: 10px;
justify-content: flex-end;
@ -190,8 +186,8 @@ name.value = JSON.parse(localStorage.getItem('TWMS-userInfo')).content.real_name
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
align-items: center;
justify-content: center;
span {
color: #d3832a;
}
@ -226,345 +222,6 @@ name.value = JSON.parse(localStorage.getItem('TWMS-userInfo')).content.real_name
<style lang="scss" scope>
@import '../../styles/flowStyle.scss';
// .bx {
// position: relative;
// .ztjk {
// display: flex;
// flex-direction: column;
// align-items: center;
// position: absolute;
// font-size: 14px;
// font-size: #747474;
// top: 235px;
// left: 680px;
// > img {
// width: 62px;
// height: 62px;
// }
// }
// .left {
// width: 640px !important;
// height: 500px;
// background: #ffffff;
// box-shadow: 0px 0px 16px 0px rgba(211, 131, 42, 0.1);
// border-radius: 32px;
// opacity: 1;
// box-sizing: border-box;
// position: absolute;
// left: 20px;
// top: 10px;
// padding: 30px 44px;
// .tptitl {
// display: flex;
// align-items: center;
// > img {
// width: 32px;
// height: 22px;
// margin-right: 8px;
// }
// }
// .onebx1 {
// width: 100%;
// height: 100%;
// position: relative;
// margin-top: 30px;
// > div {
// display: flex;
// flex-direction: column;
// align-items: center;
// position: absolute;
// font-size: 14px;
// font-size: #747474;
// > img {
// width: 62px;
// height: 62px;
// }
// }
// .item1 {
// top: 10px;
// left: 0px;
// }
// .item2 {
// top: 140px;
// left: 0px;
// }
// .item3 {
// top: 10px;
// left: 140px;
// }
// .item4 {
// top: 140px;
// left: 140px;
// }
// .item5 {
// top: 270px;
// left: 140px;
// }
// .item6 {
// top: 10px;
// left: 330px;
// }
// .item7 {
// top: 140px;
// left: 330px;
// }
// .item8 {
// top: 140px;
// left: 450px;
// }
// .upimg {
// width: 15px;
// height: 40px;
// position: absolute;
// left: 355px;
// top: 100px;
// }
// .rigth1 {
// width: 40px;
// height: 15px;
// position: absolute;
// left: 80px;
// top: 40px;
// }
// .rigth2 {
// width: 40px;
// height: 15px;
// position: absolute;
// left: 80px;
// top: 180px;
// }
// .rigth3 {
// width: 40px;
// height: 15px;
// position: absolute;
// left: 400px;
// top: 180px;
// }
// .rigth4 {
// width: 40px;
// height: 15px;
// position: absolute;
// left: 530px;
// top: 180px;
// }
// .rigthall {
// width: 40px;
// height: 270px;
// position: absolute;
// left: 250px;
// top: 50px;
// }
// }
// }
// .rigth {
// width: 640px;
// height: 500px;
// background: #ffffff;
// box-shadow: 0px 0px 16px 0px rgba(58, 216, 188, 0.102);
// border-radius: 32px;
// opacity: 1;
// box-sizing: border-box;
// position: absolute;
// left: 760px;
// top: 10px;
// padding: 30px 44px;
// .tptitl {
// display: flex;
// align-items: center;
// > img {
// width: 32px;
// height: 22px;
// margin-right: 8px;
// }
// }
// .onebx1 {
// width: 100%;
// height: 100%;
// position: relative;
// margin-top: 30px;
// > div {
// display: flex;
// flex-direction: column;
// align-items: center;
// position: absolute;
// font-size: 14px;
// font-size: #747474;
// > img {
// width: 62px;
// height: 62px;
// }
// }
// .item1 {
// top: 140px;
// left: 50px;
// }
// .item2 {
// top: 140px;
// left: 170px;
// }
// .item3 {
// top: 270px;
// left: 170px;
// }
// .item4 {
// top: 10px;
// left: 300px;
// }
// .item5 {
// top: 140px;
// left: 300px;
// }
// .item6 {
// top: 10px;
// left: 430px;
// }
// .item7 {
// top: 140px;
// left: 430px;
// }
// .item8 {
// top: 270px;
// left: 430px;
// }
// .upimg {
// width: 15px;
// height: 40px;
// position: absolute;
// left: 190px;
// top: 230px;
// }
// .rigth1 {
// width: 40px;
// height: 15px;
// position: absolute;
// left: 0px;
// top: 180px;
// }
// .rigth2 {
// width: 40px;
// height: 15px;
// position: absolute;
// left: 120px;
// top: 180px;
// }
// .rigth3 {
// width: 40px;
// height: 15px;
// position: absolute;
// left: 375px;
// top: 180px;
// }
// .rigth4 {
// width: 40px;
// height: 15px;
// position: absolute;
// left: 375px;
// top: 50px;
// }
// .leftall {
// width: 182px;
// height: 540px;
// position: absolute;
// left: 350px;
// top: 50px;
// z-index: 99;
// }
// .rigthall {
// width: 165px;
// height: 270px;
// position: absolute;
// left: 250px;
// top: 50px;
// }
// }
// }
// .buts {
// width: 1380px;
// height: 234px;
// background: #ffffff;
// box-shadow: 0 0 16px 0 rgba(0, 134, 241, 0.102);
// border-radius: 32px;
// opacity: 1;
// position: absolute;
// box-sizing: border-box;
// left: 20px;
// top: 540px;
// padding: 30px 44px;
// .tptitl {
// display: flex;
// align-items: center;
// > img {
// width: 32px;
// height: 22px;
// margin-right: 8px;
// }
// }
// .onebx1{
// width: 100%;
// height: 100%;
// position: relative;
// margin-top: 30px;
// > div {
// display: flex;
// flex-direction: column;
// align-items: center;
// position: absolute;
// font-size: 14px;
// font-size: #747474;
// > img {
// width: 62px;
// height: 62px;
// }
// }
// .item1{
// left: 1000px;
// top:10px;
// }
// .item2{
// left: 800px;
// top:10px;
// }
// .item3{
// left: 600px;
// top:10px;
// }
// .item4{
// left: 400px;
// top:10px;
// }
// .left1{
// width: 60px;
// height: 15px;
// position: absolute;
// left: 900px;
// top: 50px;
// transform: rotate(180deg);
// }
// .left2{
// width: 60px;
// height: 15px;
// position: absolute;
// left: 700px;
// top: 50px;
// transform: rotate(180deg);
// }
// .left3{
// width: 60px;
// height: 15px;
// position: absolute;
// left: 500px;
// top: 50px;
// transform: rotate(180deg);
// }
// }
// }
// }
// .tptitl{
// color: #172E60;
// }
// .bx{
// user-select: none;
// }
#avue-view {
background-color: #fff;
}

369
src/views/wel/index2.vue

@ -0,0 +1,369 @@
<template>
<div class="bx" v-if="indexState">
<div class="left">
<div class="tptitl">
<img src="./static/topicon.png" />
<span>发货操作</span>
</div>
<div class="onebx1">
<div class="item1">
<img src="./static/1.png" />
<span>提货</span>
</div>
<div class="item2">
<img src="./static/2.png" />
<span>预开单</span>
</div>
<div class="item3">
<img src="./static/3.png" />
<span>创建运单</span>
</div>
<div class="item4">
<img src="./static/4.png" />
<span>补录运单</span>
</div>
<div class="item5">
<img src="./static/5.png" />
<span>短驳发车</span>
</div>
<div class="item6">
<img src="./static/6.png" />
<span>外部中转</span>
</div>
<div class="item7">
<img src="./static/7.png" />
<span>库存管理</span>
</div>
<div class="item8">
<img src="./static/8.png" />
<span>车辆配载</span>
</div>
<img class="upimg" src="./static/up.png" />
<img class="rigth1" src="./static/rigth.png" />
<img class="rigth2" src="./static/rigth.png" />
<img class="rigth3" src="./static/rigth.png" />
<img class="rigth4" src="./static/rigth.png" />
<img class="rigthall" src="./static/rigthall.png" />
</div>
</div>
<div class="ztjk">
<img src="./static/9.png" />
<span>到货操作</span>
</div>
<div class="rigth">
<div class="tptitl">
<img src="./static/topicon.png" />
<span>到货操作</span>
</div>
<div class="onebx1">
<div class="item1">
<img src="./static/10.png" />
<span>到站卸车</span>
</div>
<div class="item2">
<img src="./static/11.png" />
<span>库存管理</span>
</div>
<div class="item3">
<img src="./static/12.png" />
<span>短驳接收</span>
</div>
<div class="item4">
<img src="./static/13.png" />
<span>外部中转</span>
</div>
<div class="item5">
<img src="./static/14.png" />
<span>送货</span>
</div>
<div class="item6">
<img src="./static/15.png" />
<span>中转签收</span>
</div>
<div class="item7">
<img src="./static/16.png" />
<span>送货签收</span>
</div>
<div class="item8">
<img src="./static/17.png" />
<span>自提签收</span>
</div>
<img class="upimg" src="./static/down.png" />
<img class="rigth1" src="./static/rigth.png" />
<img class="rigth2" src="./static/rigth.png" />
<img class="rigth3" src="./static/rigth.png" />
<img class="rigth4" src="./static/rigth.png" />
<img class="rigthall" src="./static/rigthall2.png" />
<img class="leftall" src="./static/leftall.png" />
</div>
</div>
<div class="buts">
<div class="tptitl">
<img src="./static/topicon.png" />
<span>回单管理</span>
</div>
<div class="onebx1">
<div class="item1">
<img src="./static/18.png" />
<span>回单回收</span>
</div>
<div class="item2">
<img src="./static/19.png" />
<span>回单寄出</span>
</div>
<div class="item3">
<img src="./static/20.png" />
<span>回单接收</span>
</div>
<div class="item4">
<img src="./static/21.png" />
<span>回单发放</span>
</div>
<img class="left1" src="./static/rigth.png" />
<img class="left2" src="./static/rigth.png" />
<img class="left3" src="./static/rigth.png" />
</div>
</div>
<div class="el-gl">
<div>公告栏</div>
</div>
</div>
<div class="main_container">
<!-- 开单数据 && 开单收入 -->
<div class="flex mb5pt row_first">
<!-- 开单数据 -->
<div class="mr5pt box1 view_box">
<!-- 标题 -->
<div class="align_center mb10pt">
<img class="mr5pt img_13pt" src="@/static/icon_data.png" alt="" />
<div class="title">开单数据</div>
</div>
<!-- 数据 -->
<div class="border padding5pt">
<div class="height40pt flex-c-sb border-bottom">
<div class="align_center">
<img class="mr5pt img_16pt" src="@/static/icon_storage.png" alt="" />
<div>总计</div>
</div>
<div class="align_center">
<span class="data mr5pt">123</span>
<span></span>
</div>
</div>
<div class="height40pt flex-c-sb border-bottom">
<div class="align_center">
<img class="mr5pt img_16pt" src="@/static/icon_month.png" alt="" />
<div>当月</div>
</div>
<div class="align_center">
<span class="data mr5pt">123</span>
<span></span>
</div>
</div>
<div class="height40pt flex-c-sb">
<div class="align_center">
<img class="mr5pt img_16pt" src="@/static/icon_day.png" alt="" />
<div>当日</div>
</div>
<div class="align_center">
<span class="data mr5pt">123</span>
<span></span>
</div>
</div>
</div>
</div>
<!-- 开单收入 -->
<div class="flex1 box2 view_box">
<!-- 标题 -->
<div class="align_center mb10pt">
<img class="mr5pt img_13pt" src="@/static/icon_money.png" alt="" />
<div class="title">开单收入</div>
</div>
<div class="border padding5pt">
<div class="height40pt flex-c-sb border-bottom">
<div class="align_center">
<img class="mr5pt img_16pt" src="@/static/icon_storage.png" alt="" />
<div>总计</div>
</div>
<div class="align_center">
<span class="data mr5pt">123</span>
<span></span>
</div>
</div>
<div class="height40pt flex-c-sb border-bottom">
<div class="align_center">
<img class="mr5pt img_16pt" src="@/static/icon_month.png" alt="" />
<div>当月</div>
</div>
<div class="align_center">
<span class="data mr5pt">123</span>
<span></span>
</div>
</div>
</div>
</div>
</div>
</div>
</template>
<script setup>
import { ref, onMounted } from 'vue';
const indexState = ref(false);
</script>
<style scoped lang="scss">
.info {
display: flex;
display: flex;
flex-direction: column;
justify-content: center;
.name {
font-size: 40px;
color: #d3832a;
font-weight: bold;
}
.slogan {
font-size: 3em;
}
.time {
display: flex;
margin-top: 10px;
justify-content: flex-end;
}
.title {
display: flex;
margin-top: 10px;
justify-content: flex-end;
}
}
.el-gl {
font-weight: 500;
text-align: center;
position: absolute;
right: 10px;
top: 10px;
width: 15%;
background-color: #fff;
border-radius: 32px;
padding: 5px;
box-sizing: border-box;
border: 1px solid #f1eeee69;
box-shadow: 4px 6px 0 #d3dff6, 1px 1px 9px #d3dff6;
height: 762px;
}
.main_container {
background: #f5f5f6;
padding: 0 5pt;
}
.view_box {
padding: 10pt;
padding-top: 8pt;
background: #fff;
border-radius: 2.5pt;
.title {
font-weight: bold;
font-size: 12pt;
line-height: 12pt;
}
.img_10pt {
width: 12pt;
height: 12pt;
}
.img_16pt {
width: 16pt;
height: 16pt;
}
}
.mb10pt {
margin-bottom: 10pt;
}
.mb5pt {
margin-bottom: 5pt;
}
.mr5pt {
margin-right: 5pt;
}
.padding5pt {
padding: 0 5pt;
}
.align_center {
display: flex;
align-items: center;
}
//
.height40pt {
height: 40pt;
font-size: 12pt;
}
//
.data {
font-weight: bold;
color: #000;
font-family: DIN-Bold;
font-size: 15pt;
}
.border {
border: 1pt solid #f5f5f6;
border-radius: 2.5pt;
box-sizing: border-box;
}
.border-bottom {
border-bottom: 1pt solid #f5f5f6;
}
//
.row_first {
height: 160pt;
.box1 {
height: 100%;
width: 170pt;
box-sizing: border-box;
flex: none;
}
.box2 {
height: 100%;
}
}
</style>
<style lang="scss" scope>
@import '../../styles/flowStyle.scss';
#avue-view {
background-color: #fff;
}
</style>
Loading…
Cancel
Save