Commit 438a2af2 authored by Smile's avatar Smile

Merge remote-tracking branch 'origin/jd_cons' into jd_cons

parents efcdb92a 8c8af6ed
<template>
<el-dialog
:visible.sync="dialogVisible"
width="80%"
:before-close="
() => {
$emit('update:dialogVisible', false);
}
"
>
<div class="fee-application">
<h1>{{ $t("费用申请") }}-{{ orderDetails.orderNo }}</h1>
<el-divider></el-divider>
<el-form label-width="100px" inline>
<el-form-item :label="$t('订单号') + ':'"
>
<div class="content">
{{ orderDetails.orderNo }}
</div>
</el-form-item
>
<el-form-item :label="$t('发货人') + ':'"
>
<div class="content">
{{ orderDetails.consignorVO ? orderDetails.consignorVO.name : "" }}
</div>
</el-form-item
>
<el-form-item :label="$t('唛头')"
>
<div class="content">{{ orderDetails.marks }}</div>
</el-form-item
>
<el-form-item>
<el-button
:disabled="!!processInstanceId "
@click="addCost"
>{{ $t("添加申请") }}
</el-button
>
</el-form-item
>
</el-form>
<el-table :data="list">
<el-table-column :label="$t('序号')" type="index"></el-table-column>
<el-table-column :label="$t('费用类型')">
<template v-slot:default="scope">
<dict-selector
:disabled="!scope.row.editMode && !!scope.row.status"
:type="DICT_TYPE.FEE_TYPE"
v-model="scope.row.feeType"
/>
</template>
</el-table-column>
<el-table-column :label="$t('金额')">
<template v-slot:default="scope">
<el-input
:disabled="!scope.row.editMode && !!scope.row.status"
v-model.number="scope.row.applicationFee"
></el-input>
</template>
</el-table-column>
<el-table-column :label="$t('货币类型')">
<template v-slot:default="scope">
<el-select
:disabled="!scope.row.editMode && !!scope.row.status"
v-model="scope.row.applicationFeeCurrency"
>
<el-option
v-for="item in JSON.parse(currencys)"
:key="item.id"
:label="isChinese ? item.titleZh : item.titleEn"
:value="item.id"
/>
</el-select>
</template>
</el-table-column>
<el-table-column :label="$t('付款类型')">
<template v-slot="{ row }">
<dict-selector
:disabled="!row.editMode && !!row.status"
:type="DICT_TYPE.PAYMENT_TYPE"
v-model="row.payType"
/>
</template>
</el-table-column>
<el-table-column :label="$t('备注')">
<template v-slot:default="scope">
<el-input
:disabled="!scope.row.editMode && !!scope.row.status"
v-model="scope.row.remarks"
type="textarea"
></el-input>
</template>
</el-table-column>
<el-table-column :label="$t('确认收款')">
<template v-slot:default="scope">
<dict-tag
:type="DICT_TYPE.ECW_RECEIVABLE_STATE"
:value="scope.row.receiveFlag"
/>
</template>
</el-table-column>
<el-table-column :label="$t('申请人')">
<template v-slot:default="scope">
{{
scope.row.status === 0
? $t("未提交")
: scope.row.applicationAuthor
}}
</template>
</el-table-column>
<el-table-column :label="$t('操作')">
<template v-slot:default="scope">
<el-tag v-if="scope.row.status !== 0 && !scope.row.editMode">{{
STATUS[scope.row.status]
}}
</el-tag>
<!--el-button type="text" v-if="scope.row.status == 1" @click="examineFn">{{$t('审核中')}}</el-button-->
<el-button
type="text"
v-if="scope.row.id && modifable(scope.row)"
@click="modify(scope.row)"
>{{ $t("修改") }}
</el-button
>
<el-button
type="text"
v-if="scope.row.status === 0"
@click="del(scope.$index)"
>删除
</el-button
>
<el-button
type="text"
v-if="scope.row.id && scope.row.applicationFee === 0 && scope.row.status === 2 && !scope.row.editMode"
@click="deleteByFeeIsZero(scope.row.id)"
>删除
</el-button
>
</template>
</el-table-column>
</el-table>
<div style="padding: 20px">
<work-flow xmlkey="free_apply" v-model="selectedUsers"/>
</div>
<div style="text-align: center; margin-top: 20px">
<el-button
type="primary"
v-if="!processInstanceId"
style="margin-right: 30px"
:disabled="!feeList.length && !editMode"
@click="submit"
>{{ $t("提交") }}
</el-button
>
<el-button
type="primary"
v-if="processInstanceId"
style="margin-right: 30px"
@click="goProcessDetail"
>{{ $t("审核中") }}
</el-button
>
<el-button
type="primary"
v-if="processInstanceId"
style="margin-right: 30px"
@click="cancel"
>{{ $t("取消审核") }}
</el-button
>
<el-button @click="$emit('update:dialogVisible', false)">{{
$t("返回")
}}
</el-button>
</div>
</div>
</el-dialog>
</template>
<script>
import {
getOrder,
feeApplicationCreateBatch,
ApplicationListByOrderId,
applicationUpdate,
feeApplicationListByOrderId,
feeApplicationCancel,
getFeeApplicationApproveByOrderId,
getBatchFeeByProcessId,
qetBatchFeeByBusinessId,
getBatchFeeByBusinessId, feeApplicationDelete,
} from "@/api/ecw/order";
import {getDictDatas, DICT_TYPE} from "@/utils/dict";
import workFlow from "@/components/WorkFlow";
export default {
name: "feeApplication",
components: {workFlow},
props: {
orderId: [Number, String],
dialogVisible: {
type: Boolean,
default: false,
},
currencys: String,
},
data() {
return {
orderDetails: {},
// 费用列表
list: [],
// 审核ID,没有则表示不在审核中
processInstanceId: null,
DICT_TYPE,
getDictDatas,
STATUS: {},
selectedUsers: [],
};
},
computed: {
isChinese() {
return this.$i18n.locale === "zh_CN";
},
feeList() {
// return this.list.filter((item) => item.status === 0);
return this.list;
},
// 正在编辑的费用申请
currentItem() {
return this.list.find((item) => item.editMode);
},
// 是否修改模式
editMode() {
return !!this.currentItem;
},
modifable() {
return (item) => {
// 审核中不允许修改
if (this.processInstanceId) return false;
// 有未提交的不允许修改
// if (this.feeList.length) return false;
// 修改中的不允许修改
if (item.editMode) return false;
return true;
}
}
},
created() {
this.getDictDatas(this.DICT_TYPE.AUDIT_STATUS).forEach((e) => {
this.STATUS[e.value] = e.label;
});
getOrder(this.orderId).then((res) => {
this.orderDetails = res.data;
});
// 查询历史申请
feeApplicationListByOrderId({orderId: this.orderId}).then((res) => {
this.list = res.data;
});
// 查询是否有审核中的费用申请
getFeeApplicationApproveByOrderId(this.orderId).then((res) => {
if (res.data) {
this.processInstanceId = res.data.formId;
/*getBatchFeeByBusinessId(res.data.orderApprovalId).then(res => {
this.list = res.data
})*/
}
});
},
methods: {
del(index) {
this.$confirm(this.$t("确定要删除此条费用申请么?")).then(() => {
this.list.splice(index, 1);
});
},
// 修改
modify(item) {
this.$set(item, "editMode", true);
},
addCost() {
this.list.push({
orderId: this.orderId,
feeType: undefined, //费用申请类型
applicationFee: undefined, //金额
applicationFeeCurrency: undefined, // 费用申请货币类型
remarks: undefined,
receiveFlag: 0,
applicationAuthor: undefined,
status: 0,
});
},
deleteByFeeIsZero(id) {
this.$confirm(this.$t("确定要删除此条费用申请么?")).then(() => {
feeApplicationDelete(id).then((r) => {
this.$message({
type: "success",
message: this.$t("删除成功"),
});
this.$emit("update:dialogVisible", false);
});
});
},
submit() {
// 判断费用申请是否有未填项
// console.log("提交的费用信息列表", this.feeList)
const errList = this.feeList.filter((item) => {
return (
!item["feeType"] ||
item.applicationFee == null || item.applicationFee == undefined ||
!item["applicationFeeCurrency"] ||
!item["payType"]
);
});
if (errList.length) {
return this.$message.error("请填写完整费用申请信息");
}
// if (this.editMode) {
// // 要提交status=1,否则保持原状态
// const data = {
// ...this.currentItem,
// status: 1,
// copyUserId: this.selectedUsers,
// };
// return applicationUpdate(data).then((r) => {
// this.$message.success(this.$t("修改成功"));
// this.$emit("update:dialogVisible", false);
// });
// }
feeApplicationCreateBatch({
orderFeeApplicationCreateReqVOList: this.feeList,
copyUserId: this.selectedUsers,
orderId: this.orderId,
}).then((r) => {
if (r.code === 0) {
this.$emit("update:dialogVisible", false);
this.$message.success(this.$t("添加成功"));
this.selectedUsers = [];
this.$emit("refresh")
}
});
},
goProcessDetail() {
this.$emit("update:dialogVisible", false);
this.$router.push(
"/bpm/process-instance/detail?id=" + this.processInstanceId
);
},
cancel() {
this.$prompt(this.$t("请输入取消原因"), this.$t("提示"), {
confirmButtonText: this.$t("确定"),
cancelButtonText: this.$t("取消"),
})
.then(({value}) => {
let item = this.list.find((e) => e.status === 1);
feeApplicationCancel({
huifu: value,
bpmProcessId: this.processInstanceId,
}).then((r) => {
this.$message({
type: "success",
message: this.$t("取消成功"),
});
this.$emit("update:dialogVisible", false);
});
})
.catch(() => {
});
},
},
watch: {
dialogVisible(val) {
if (val) {
this.getOrderList();
getOrder(this.orderId).then((r) => {
if (r.code === 0) {
this.orderDetails = r.data;
}
});
}
},
},
};
</script>
<style scoped lang="scss">
.fee-application {
padding: 0 20px;
h1 {
font-weight: 600;
font-size: 20px;
}
.content {
width: 200px;
}
}
.my-process-designer {
height: calc(100vh - 200px);
}
.box-card {
width: 100%;
margin-bottom: 20px;
}
</style>
......@@ -170,6 +170,7 @@
<el-button size="mini" type="text" icon="el-icon-edit" @click="transmutation(scope.row)">{{$t('转异')}}</el-button>
<el-button size="mini" type="text" icon="el-icon-edit" @click="specialNeedsCons(scope.row)">{{$t('特需')}}</el-button>
<el-button size="mini" type="text" icon="el-icon-edit" @click="specialNeedsConsLook(scope.row)">{{$t('特需查看')}}</el-button>
<el-button size="mini" type="text" icon="el-icon-edit" @click="feeApplication(scope.row)">{{$t('费用申请')}}</el-button>
</template>
</el-table-column>
</el-table>
......@@ -253,6 +254,7 @@
<Transmutation :showException.sync="showException" :id="id" @determine="getList"></Transmutation>
<SpecialNeedsCons :showSpecialNeedsCons.sync="showSpecialNeedsCons" :currency="JSON.stringify(currencyList)" :consId="id" :consNum="consNum" @determine="getList"></SpecialNeedsCons>
<SpecialNeedsConsLook :showSpecialNeedsConsLook.sync="showSpecialNeedsConsLook" :consNum="consNum" :consId="id"></SpecialNeedsConsLook>
<fee-application-cons v-if="feeApplicationBol" :order-id="id" :currencys="JSON.stringify(currencyList)" :dialog-visible.sync="feeApplicationBol "@refresh="getList"></fee-application-cons>
</div>
</template>
......@@ -263,12 +265,13 @@ import Transmutation from "@/views/ecw/cons/components/Transmutation.vue"
import Template from "@/views/cms/template/index.vue";
import UserSelector from "@/components/UserSelector/index.vue";
import { getWarehouseList } from "@/api/ecw/warehouse";
import {getTradeCountryList} from "@/api/ecw/region";
import {getRegionList} from "@/api/ecw/order";
import SpecialNeedsCons from "@/views/ecw/cons/components/SpecialNeedsCons.vue"
import SpecialNeedsConsLook from "@/views/ecw/cons/components/SpecialNeedsConsLook.vue"
import { getCurrencyList } from "@/api/ecw/currency"
import FeeApplicationCons from "@/views/ecw/cons/components/FeeApplicationCons.vue"
import FeeApplication from "@/views/ecw/order/feeApplication.vue"
export default {
name: "Cons",
......@@ -276,6 +279,7 @@ export default {
UserSelector,
Transmutation,
Template,
FeeApplicationCons,
SpecialNeedsConsLook,
SpecialNeedsCons
},
......@@ -343,6 +347,7 @@ export default {
id: null,
currencyList: [],
consNum: null,
feeApplicationBol: false
};
},
created() {
......@@ -566,6 +571,12 @@ export default {
this.id = row.id
this.consNum = row.consNum
this.showSpecialNeedsConsLook = true
},
//费用申请
feeApplication(row) {
this.id = row.id
this.consNum = row.consNum
this.feeApplicationBol = true
}
}
};
......
<template>
<div>
<!-- 搜索工作栏 -->
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" label-width="68px">
<el-form-item :label="$t('编号')">
<el-input
v-model.trim="noParam.value"
:placeholder="$t('请输入快递号、包裹号、订单号')"
clearable
class="w-200"
@input="replaceSpace(noParam, 'value')"
@keyup.enter.native="handleQuery">
<template slot="prepend">
<dict-selector :type="DICT_TYPE.ORDER_QUERY_NO_FIELD" defaultable v-model="noParam.key" />
</template>
</el-input>
</el-form-item>
<el-form-item label="签收时间" prop="signedTime">
<el-date-picker clearable v-model="queryParams.signedTime" type="date" value-format="yyyy-MM-dd" :placeholder="$t('选择签收时间')" />
</el-form-item>
<el-form-item :label="$t('客户经理')">
<user-selector manage v-model="queryParams.salesmanIds" multiple clearable @change="handleQuery" :prepend="{ id: 0, nickname: $t('未分配客户经理') }" class="w-200" />
</el-form-item>
<el-form-item :label="$t('集运仓')">
<el-select v-model="queryParams.wareId" :placeholder="$t('请选择仓库')" filterable>
<el-option v-for="warehouse in this.warehouseList" :key="warehouse.id" :label="$l(warehouse,'title')" :value="warehouse.id" v-if="warehouse.isConsService"></el-option>
</el-select>
</el-form-item>
<el-form-item :label="$t('运输方式')" prop="transportId">
<dict-selector :type="DICT_TYPE.ECW_TRANSPORT_TYPE" v-model="queryParams.transportId" class="w-200" />
</el-form-item>
<el-form-item :label="$t('目的国')" prop="consigneeCountryId">
<el-select v-model="queryParams.consigneeCountryId" :label="queryParams.consigneeCountryId" :placeholder="$t('请选择目的国')" clearable @change="handleQuery" class="w-200">
<el-option v-for="item in AddressProvince" :key="item.guojia" :label="item.guojiaName" :value="item.guojia"></el-option>
</el-select>
</el-form-item>
<el-form-item :label="$t('目的城市')" prop="consigneeCityId">
<el-select v-model="queryParams.consigneeCityId" :placeholder="$t('请选择目的城市')" style="width: 200px" clearable @change="handleQuery" class="w-200">
<el-option v-for="item in AddressCity" :key="item.shi" :label="item.shiName" :value="item.shi"></el-option>
</el-select>
</el-form-item>
<el-form-item :label="$t('出货渠道')" prop="shippingChannelIdList">
<el-select v-model="queryParams.shippingChannelIdList" multiple :placeholder="$t('请选择出货渠道')" clearable>
<el-option v-for="item in channelList" :label="$l(item, 'name')" :value="item.channelId" :key="item.channelId"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<!-- 合计列 -->
<el-row :gutter="10" class="mb8">
<el-col :span="15">
<!-- 订单列表显示搜索条件对应箱数、仓库实测、收款方数、重量 -->
{{ $t("合计:{totalNum}箱,{totalVolume}m³(测) {totalChargeVolume}m³(重) {totalWeight}KG(测), {totalChargeWeight}kg(收费)", statisticsOrder) }}
</el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getOrderList"></right-toolbar>
</el-row>
<!-- 操作工具栏 -->
<!-- 表格内容 -->
<el-table v-loading="loading" :data="list" border ref="dataTable">
<el-table-column :label="$t('快递单号')" align="center" prop="expressNo"></el-table-column>
<el-table-column :label="$t('签收时间')" align="center" prop="signedTime">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.signedTime) }}</span>
</template>
</el-table-column>
<el-table-column :label="$t('运输方式-渠道')+'/'+$t('目的仓')" align="center" prop="code" width="150">
<template slot-scope="scope">
/{{isChinese?scope.row.destTitleZh:scope.row.destTitleEn}}
</template>
</el-table-column>
<el-table-column :label="$t('包裹状态')" align="center" prop="code">
<template slot-scope="scope">
<dict-tag :type="DICT_TYPE.CONS_STATUS" :value="scope.row.status" />
</template>
</el-table-column>
<!-- 转运时间取订单创建时间 -->
<el-table-column :label="$t('转运时间')" align="center" prop="code">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.signedTime) }}</span>
</template>
</el-table-column>
<el-table-column :label="$t('转运单号')" align="center" prop="code">
</el-table-column>
<el-table-column :label="$t('订单状态')" align="center" prop="code">
<template slot-scope="scope">
<dict-tag :type="DICT_TYPE.ORDER_STATUS" :value="scope.row.orderStatus" />
</template>
</el-table-column>
<el-table-column :label="$t('填单数据')" align="center" prop="code">
<template slot-scope="scope">
<span v-html="getGoodsName(scope.row.consItemList)"></span>
</template>
</el-table-column>
<el-table-column :label="$t('验货数据')" align="center" prop="code">
<template slot-scope="scope">
{{getInspectionInfo(scope.row.consItemList)}}
</template>
</el-table-column>
<el-table-column :label="$t('包裹号')" align="center" prop="consNum"></el-table-column>
</el-table>
<!-- 分页组件 -->
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" @pagination="getList"/>
</div>
</template>
<script>
import { getConsPage } from '@/api/ecw/cons'
import Template from '@/views/cms/template/index.vue'
import UserSelector from '@/components/UserSelector/index.vue'
import { getWarehouseList } from '@/api/ecw/warehouse'
import { getRegionList } from '@/api/ecw/order'
export default {
name: "CustomerConsOrder",
components: { UserSelector, Template },
/**
* 可以单独作为页面,也可以作为组件被被客户详情页调用。
* 作为组件时要传入 customerId,用于限制范围和隐藏搜索筛选,可以通过this.customer直接使用
*/
props: {
customerId: Number,
},
data(){
return{
// 遮罩层
loading: true,
// 表格内容
list: [],
// 总条数
total: 0,
dateRangeWatEtime: [],
dateRangeWatTime: [],
dateRangeSignedTime: [],
dateRangeCreateTime: [],
// 进口仓库列表
warehouseList: [],
// 目的国家列表
AddressProvince:[],
// 目的城市列表
AddressCity:[],
// 查询参数
queryParams: {
pageNo: 1,
pageSize: 10,
customerId: this.customerId, // 通过上一个页面传过来的值,默认只获取当前客户的数据
consigneeCountryId: null,
consigneeCityId: null,
shippingChannelIdList: null,
//查询字段...
},
// 编号查询条件
noParam: {
key: "numberKey",
value: ""
},
}
},
// 数据的值有变动时执行
computed:{
// 判断国际化语言
isChinese() {
return this.$i18n.locale === "zh_CN";
},
// 监听查询参数
combinedQueryParams(){
let queryParams = {...this.queryParams}
// 处理编号查询参数
if (this.noParam.value) {
queryParams[this.noParam.key] = this.noParam.value
}
return queryParams
},
},
// 第一次进入页面时执行(只执行一次)
created() {
// 获取表格内容
this.getList();
// 获取进口类型的仓库列表
getWarehouseList({tradeType : 2}).then((r) => {
this.warehouseList = r.data;
});
// 获取国家列表
this.getAddressProvince()
// 获取城市列表
this.getAddressCity()
},
methods:{
/**
* 获取表格内容
*/
getList() {
// 处理查询参数
let params = { ...this.combinedQueryParams };
// 处理时间查询参数
this.addBeginAndEndTime(params, this.dateRangeWatEtime, 'watEtime');
this.addBeginAndEndTime(params, this.dateRangeWatTime, 'watTime');
this.addBeginAndEndTime(params, this.dateRangeSignedTime, 'signedTime');
this.addBeginAndEndTime(params, this.dateRangeCreateTime, 'createTime');
// 执行查询
getConsPage(params).then(response => {
this.list = response.data.list;
this.total = response.data.total;
this.loading = false;
});
},
/**
* 搜索按钮
*/
handleQuery() {
this.queryParams.pageNo = 1;
this.getList();
},
/**
* 重置按钮
*/
resetQuery() {
this.dateRangeWatEtime = [];
this.dateRangeWatTime = [];
this.dateRangeSignedTime = [];
this.dateRangeCreateTime = [];
this.noParam.value = ""
this.resetForm("queryForm");
this.handleQuery();
},
/**
* 获取国家地区列表
*/
getAddressProvince() {
getRegionList(1, 1).then(({ data }) => {
this.AddressProvince = data
})
},
/**
* 获取城市列表
*/
getAddressCity() {
getRegionList(4, 4).then(({ data }) => {
this.AddressCity = data
})
},
/**
* 获取填单数据
*/
getGoodsName(val){
return val.map((item, index) => `${index + 1}.${item.prodName}*${item.quantity}`).join('<br>');
},
/**
* 获取验货数据
*/
getInspectionInfo(val){
let inspectionNums = 0;
let inspectionUnit;
let inspectionQuantitys=0;
let inspectionVolumes=0;
let inspectionWeights=0;
val.forEach(item => {
inspectionUnit = item.inspectionUnit;
inspectionNums += item.inspectionNum;
inspectionQuantitys += item.inspectionQuantity;
inspectionVolumes += item.inspectionVolume;
inspectionWeights += item.inspectionWeight;
});
return `${inspectionQuantitys}${inspectionUnit} ${inspectionVolumes}${inspectionWeights}kg ${inspectionNums}件`;
},
/**
* 去除空格
*/
replaceSpace(obj, field) {
obj[field] = obj[field].replace(/\s+/g, "")
},
}
}
</script>
......@@ -426,6 +426,10 @@
<el-tab-pane name="follow" :label="$t('跟进')">
<log-list-customer-common ref="logListCustomerCommon" :customerService="customer.customerService" :customerNumber="customer.number" v-if="activeName === 'follow'" :customerId="id" />
</el-tab-pane>
<!-- 客户集运订单 -->
<el-tab-pane name="consOrder" :label="$t('集运')">
<customer-cons-order v-if="activeName === 'consOrder'" ref="CustomerConsOrder" :customerId="id"></customer-cons-order>
</el-tab-pane>
<el-tab-pane name="special" :label="$t('特殊设置')">
<el-descriptions :column="2">
<el-descriptions-item :label="$t('是否显示提单价格')">
......@@ -723,6 +727,7 @@ import { getNodeList } from "@/api/ecw/node"
import CustomerFollow from "./components/customerFollow"
import { parseTime } from "@/utils/ruoyi"
import CustomerComplaint from "@/views/ecw/customerComplaint"
import CustomerConsOrder from "@/views/ecw/customer/components/customerConsOrder"
import { listServiceUser, getUserProfile } from "@/api/system/user"
import { getCustomerContactsListByCustomer } from "@/api/ecw/customerContacts"
import { getOrderPage, getRegionList } from "@/api/ecw/order"
......@@ -749,7 +754,8 @@ export default {
Template,
CustomerFollow,
CustomerComplaint,
customerLog
customerLog,
CustomerConsOrder,
},
created() {
// 获取币种
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment