Commit a4eeea5b authored by zhoutong's avatar zhoutong
parents ee47ae6e c5549bf9
import request from '@/utils/request' import request from '@/utils/request'
import query from "@/views/ecw/customer/query"; import query from "@/views/ecw/customer/query";
import * as url from "url"; import * as url from "url";
import {methods} from "vue2-ace-editor";
// 创建客户 // 创建客户
export function createCustomer(data) { export function createCustomer(data) {
...@@ -26,7 +27,14 @@ export function updateCustomer(data) { ...@@ -26,7 +27,14 @@ export function updateCustomer(data) {
data: data data: data
}) })
} }
// 新建潜在客户
export function createPotential(data){
return request({
url:'/ecw/customer/create-potential',
method:'post',
data
})
}
// 删除客户 // 删除客户
export function deleteCustomer(id) { export function deleteCustomer(id) {
return request({ return request({
...@@ -72,6 +80,14 @@ export function getCustomerSelect(query) { ...@@ -72,6 +80,14 @@ export function getCustomerSelect(query) {
params: query params: query
}) })
} }
// 潜在客户
export function getPotential(query){
return request({
url:'/ecw/customer/get-potential',
method:'get',
params:query
})
}
// 根据客户id集合获得客户详情列表 // 根据客户id集合获得客户详情列表
export function getCustomerList(query) { export function getCustomerList(query) {
...@@ -175,7 +191,20 @@ export function handOverCustomer(data) { ...@@ -175,7 +191,20 @@ export function handOverCustomer(data) {
data: data, data: data,
}) })
} }
export function handoverApproval(data) {
return request({
url: '/ecw/customer/handover/approval',
method: 'post',
data: data,
})
}
export function handoverApprovalDetails(params){
return request({
url:'/ecw/customer/handover/approval',
method:'get',
params
})
}
// 公海池客户 // 公海池客户
export function getPublicList(query) { export function getPublicList(query) {
return request({ return request({
...@@ -381,6 +410,14 @@ export function changeCustomerAir(data){ ...@@ -381,6 +410,14 @@ export function changeCustomerAir(data){
}) })
} }
// 设置整柜
export function setChangeCustomerFcl(data){
return request({
url:'/ecw/customer/change-customer-fcl',
method:'put',
data
})
}
//获得客户日志 //获得客户日志
export function getCustomerOperatelogPage(params){ export function getCustomerOperatelogPage(params){
return request({ return request({
......
...@@ -121,3 +121,21 @@ export function getOrderExcptionResult(query) { ...@@ -121,3 +121,21 @@ export function getOrderExcptionResult(query) {
params: query params: query
}) })
} }
// 根据订单ID,异常ID获取价格
export function getOrderExceptionChannelPriceList(data) {
return request({
url: '/order/exception-channel-price/getOrderExceptionChannelPriceList',
method: 'post',
data: data
})
}
// 根据工作流中传的业务ID,获取不可出渠道异常详细信息
export function getExceptionDetailByBusinessId(query) {
return request({
url: '/ecw/order-exception/getExceptionDetailByBusinessId',
method: 'get',
params: query
})
}
\ No newline at end of file
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
</div> </div>
<el-form label-position="left" label-width="100px"> <el-form label-position="left" label-width="100px">
<el-form-item :label="$t('抄送')"> <el-form-item :label="$t('抄送')">
<el-select v-model="valueSync" multiple :placeholder="$t('请选择抄送人')" style="width:100%" filterable > <el-select v-model="valueSync" multiple :placeholder="$t('请选择抄送人')" style="width:100%" filterable :disabled="disabled" >
<el-option <el-option
v-for="item in users" v-for="item in users"
:key="item.id" :key="item.id"
...@@ -45,7 +45,8 @@ export default { ...@@ -45,7 +45,8 @@ export default {
taskData: { // 任务实例的数据。传递时,可展示 UserTask 审核相关的信息 taskData: { // 任务实例的数据。传递时,可展示 UserTask 审核相关的信息
type: Array, type: Array,
default: () => [], default: () => [],
} },
disabled: Boolean
}, },
data(){ data(){
return { return {
......
...@@ -1142,7 +1142,7 @@ ...@@ -1142,7 +1142,7 @@
"手续费(RMB)": "Handling fee (RMB)", "手续费(RMB)": "Handling fee (RMB)",
"需要": "need", "需要": "need",
"不需要": "unnecessary", "不需要": "unnecessary",
"元": "RMB", "元": "Yuan",
"银行收款明细": "Bank Receipt Details", "银行收款明细": "Bank Receipt Details",
"批量核销": "Batch write-off", "批量核销": "Batch write-off",
"添加收款明细": "Add Receipt Details", "添加收款明细": "Add Receipt Details",
...@@ -1396,7 +1396,6 @@ ...@@ -1396,7 +1396,6 @@
"商品链接": "Product link", "商品链接": "Product link",
"编辑商品链接": "Edit product link", "编辑商品链接": "Edit product link",
"添加商品链接": "Add product link", "添加商品链接": "Add product link",
"元": "Yuan",
"通用": "General", "通用": "General",
"价格有效时间": "Price valid time", "价格有效时间": "Price valid time",
"交货地址": "Delivery Address", "交货地址": "Delivery Address",
...@@ -3897,5 +3896,255 @@ ...@@ -3897,5 +3896,255 @@
"收费方数": "", "收费方数": "",
"可放入重量": "", "可放入重量": "",
"可放入收费重量": "", "可放入收费重量": "",
"确定注销并退出系统吗?": "Are you sure to log out and exit the system?" "确定注销并退出系统吗?": "Are you sure to log out and exit the system?",
"若线路价格为全包价,输入清关费不生效": "If the line price is all-inclusive, the input of clearance fees will not take effect.",
"新增潜在客户": "New potential customers",
"批量加价": "Batch markup",
"运费或全包加价": "Freight or all inclusive markup",
"清关费加价价": "Customs clearance fee markup",
"加价单价": "Markup unit price",
"加价申请审核中": "Price increase application under review",
"运费和清关费不能同时为空": "Freight and customs clearance fees cannot both be empty",
"收费箱数": "Number of toll boxes",
"加价金额": "Amount of markup",
"目的港清关": "Customs clearance at destination port",
"我司": "Our company",
"清关方式不能为空": "Customs clearance method cannot be empty",
"我司清关": "Our company's customs clearance",
"合作方清关": "Partner clearance",
"发货方式": "Shipping method",
"多票": "Multiple tickets",
"单票": "Single ticket",
"请选择提单制作状态": "Please select the bill of lading production status",
"提单状态": "Bill of Lading Status",
"部分完成": "Partially completed",
"查看代理商详情": "View agent details",
"实际二程起飞时间": "Actual Second Trip Takeoff Time",
"Shipper": "Shipper",
"请选择Shipper": "Please select Shipper",
"请选择航空公司": "Please select an airline",
"预计起飞时间": "Estimated departure time",
"航程": "Voyage",
"截止送货时间": "Deadline for delivery",
"到仓时间1": "Arrival time 1",
"美元": "USD",
"剩余货值": "Remaining value",
"放入货值": "Value of goods placed",
"是否需要一起移出?": "Do you need to remove it together?",
"送货地址": "Delivery address",
"请输入送货地址": "Please enter the delivery address",
"自提时间": "Self pickup time",
"自提地址": "Self pickup address",
"请输入自提地址": "Please enter the self pickup address",
"公司名称:": "Company Name",
",地址:": ", Address",
",邮箱:": ", email",
",品名:": "Product name",
",From M No:": "From M No",
",BA No:": ", BA No",
"过机状态": "Over machine state",
"顺利": "Smooth",
"敏感货": "Sensitive goods",
"重量误报": "Weight Misreporting",
"删单退场状态": "Deletion and Exit Status",
"提交删单退场审核": "Submit for deletion and exit review",
"机场误差3%": "Airport error 3%",
"超过误差10KG": "Exceeding the error of 10KG",
"过机放行-未找到重货订单": "Pass through release - no heavy order found",
"过机放行-已找到重货订单": "Pass through release - heavy order found",
"超出机场重量": "Exceeding airport weight",
"KG": "KG",
"请选择处理人": "Please select the handler",
"超重订单": "Overweight orders",
"请选择超重订单": "Please select an overweight order",
"取消删单退场审核": "Cancel deletion and exit review",
"新建合包箱号": "New package number",
"箱号": "Box number",
"订单数": "Number of orders",
"入仓数量(个)": "Number of Warehousing Units",
"装箱": "Packing",
"格式错误": "Format error",
"未装箱列表": "Unpacked List",
"已装箱列表": "Packed List",
"集运封箱标签": "Container sealing label for centralized transportation",
"编辑合包箱号": "Edit package number",
"是否确认删除?": "Are you sure to delete?",
"合包箱号: ": "Package number",
"批量移出合包": "Batch move out of packaging",
"封箱": "Sealing the box",
"封箱确认": "Sealing confirmation",
"请填写体积": "Please fill in the volume",
"体积保留两位小数": "Volume to two decimal places",
"m³": "M ³ ",
"请填写重量": "Please fill in the weight",
"重量保留两位小数": "Weight to two decimal places",
"kg": "Kg",
"请填写数量": "Please fill in the quantity",
"数量保留两位小数": "Quantity to two decimal places",
"移出成功": "Successfully removed",
"箱号:": "Box number",
",请问是否打印封箱标签?": "May I ask if you want to print the sealing label?",
"封箱成功": "Successfully sealed the box",
"立刻打印": "Print Now",
"稍后再试": "Try again later",
"扫码查看产品数量": "Scan code to view product quantity",
"批量装箱": "Bulk packing",
"装箱成功": "Packing successful",
"请选择需要装箱的订单": "Please select the order that needs to be boxed",
"待分拣订单": "Orders to be sorted",
"请输入待分拣订单": "Please enter the order to be sorted",
"已分拣单号": "Sorted order number",
"请输入已分拣单号": "Please enter the sorted order number",
"搜索已分拣订单": "Search for sorted orders",
"搜索待分拣订单": "Search for orders to be sorted",
"可出特性": "Extractable characteristic",
"已分拣订单": "Sorted orders",
"可分拣方数": "Sortable quantity",
"特性": "Characteristics",
"筛选后待分拣数量": "Quantity to be sorted after screening",
"分拣全部": "Sort All",
"分拣": "Sorting",
"分拣审核": "Sort Review",
"确认删除该部分及其已分拣订单?": "Are you sure to delete this section and its sorted orders?",
"是否需要一起分拣?": "Do you need to sort together?",
"请注意,分拣反审后,全部提单需重新制作": "Please note that after sorting and review, all bills of lading need to be remade",
"实际起飞时间": "Actual departure time",
"到仓": "To warehouse",
"过机重量异常": "Abnormal weight passing through the machine",
"机场误差3%以内": "Airport error within 3%",
"我司误差超10kg": "Our company's error exceeds 10kg",
"超过机场重量": "Exceeding airport weight",
"全部到仓": "All arrive at the warehouse",
"到仓箱数": "Number of boxes to warehouse",
"入仓修改 ": "Entry modification",
"完成到仓": "Complete to Warehouse",
"货物到仓数小于实装数,请确认": "The number of goods delivered to the warehouse is less than the actual loaded quantity, please confirm",
"合包列表": "Package List",
"分拣反审": "Sort Reverse Review",
"空运-排单": "Air freight - scheduling",
"空运出货操作": "Air freight shipment operation",
"合包": "Packaging",
"出货": "Shipping",
"出仓": "Out of warehouse",
"起飞": "Takeoff",
"直飞": "Direct flight",
"中转": "Transfer",
"供应商自提": "Supplier self pickup",
"数量(个)": "Quantity (pieces)",
"品名可拆数据": "Product name detachable data",
"可拆入仓记录": "Removable warehouse records",
"已拆完": "Completed dismantling",
"已放入入仓记录": "Placed in warehouse entry record",
"{num}箱": "{num} box",
"长{boxGauge1}cm": "Length {boxGauge1} cm",
"宽{boxGauge2}cm": "Width {boxGauge2} cm",
"高{boxGauge3}cm": "Height {boxGauge3} cm",
"方数{volume}m³": "Square {volume} m ³ ",
"重量{weight}kg": "Weight {weight} kg",
"数量{n}": "Quantity {n}",
"快递{expressNo}": "Express {expressNo}",
"储位{location}": "Storage location",
"请选择入仓记录": "Please select a warehouse entry record",
"暂无入仓记录": "There is currently no record of warehouse entry",
"请至少放入一条数据": "Please place at least one piece of data",
"确定要清空放入数据么?": "Are you sure you want to clear the data?",
"新建潜在客户信息": "Create new lead information",
"请输入客户姓名": "Please enter the customer's name",
"询盘信息": "Inquiry Information",
"创建成功": "Created successfully",
"请输入区号。": "Please enter the area code.",
"请输入电话号码。": "Please enter a phone number.",
"请输入客户类别。": "Please enter a phone number.",
"前请输入客户来源": "Please enter a customer category.",
"设置海运整柜客户": "Please enter the customer source before proceeding",
"设置海运非整柜客户": "Set up sea freight full container customers",
"业绩创建时间": "Set up sea freight non full container customers",
"目标值": "Performance creation time",
"目标单位": "target value",
"请输入目标值": "Target unit",
"请选择目标单位": "Please enter the target value",
"填单特性": "Please select the target unit",
"运费/全包价": "Filling characteristics",
"请求备注": "Freight/All Inclusive Price",
"请求内容": "Request Comment",
"打包人": "Request Content",
"打包时间": "Packer",
"无需打包": "Packaging time",
"打包历史": "No packaging required",
"入仓数据": "Packaging History",
"备货状态": "Warehouse entry data",
"打包前": "Stock status",
"打包后": "Before packaging",
"打包数据": "After packaging",
"打包后箱数": "Packaging data",
"打包后体积": "Number of boxes after packaging",
"打包后重量": "Volume after packaging",
"打包后数量(个)": "Weight after packaging",
"查看打包历史": "Quantity after packaging (pieces)",
"空运专线": "Viewing Packaging History",
"费用来源": "Air freight dedicated line",
"来自{source}": "Source of expenses",
"优惠详情": "From {source}",
"优惠ID": "Offer Details",
"优惠名称": "Offer ID",
"运费优惠": "Offer Name",
"清关费优惠": "Freight discount",
"查看母订单": "Customs clearance fee discount",
"变更出货渠道": "View Parent Order",
"开始备货": "Change shipping channel",
"修改备货": "Start stocking",
"批量可出": "Modify stock preparation",
"批量转异": "Batch available",
"可出": "Batch conversion",
"确认转异": "Can be released",
"修改报价": "Confirm conversion",
"全包价成交单价": "Modify quotation",
"运费成交单价": "All inclusive transaction unit price",
"清关费成交单价": "Freight transaction unit price",
"审核驳回原因": "Customs clearance fee transaction unit price",
"提货方式": "Reason for review rejection",
"申请泡货标准优惠": "Delivery method",
"现订单泡重": "Apply for standard discounts on bubble food",
"新订单泡重": "Current order foam weight",
"重货标准优惠申请": "New order bubble weight",
"泡货标准优惠申请": "Application for Heavy Duty Standard Discount",
"入仓记录放入确认": "Application for Standard Discount of Pickled Goods",
"可拆出入仓记录": "Confirmation of placement of warehouse entry records",
"可拆": "Removable warehouse entry records",
"新入仓记录": "Detachable",
"确定要删除该行入仓记录吗?": "New Entry Record",
"请填写收费方数": "Are you sure you want to delete the warehouse entry record for this row?",
"请填写收费重量": "Please fill in the number of charging parties",
"请放入品名": "Please fill in the chargeable weight",
"放入箱数不能大于可拆箱数": "Please include the product name",
"{field}最少为0.01": "The number of boxes placed cannot be greater than the number of detachable boxes",
"已有拆单数据,是否要重置?": "{field} should be at least 0.01",
"完成打包": "There is already splitting data, do you want to reset it?",
"打包状态": "Complete packaging",
"打包": "Packaging status",
"修改打包": "pack",
"完成备货": "Modify packaging",
"确认并完成打包": "Complete stock preparation",
"导出所选": "Confirm and complete packaging",
"备货": "Export Selected",
"备货订单": "Stock up",
"暂无货物入库信息": "Stock order",
"多了": "There is currently no information on goods entering the warehouse",
"订单重量上限kg": "Too much",
"快捷设置": "Order weight limit kg",
"*针对所有价格加价": "Quick Settings",
"批量减价": "*Add price to all prices",
"是否単询": "Batch price reduction",
"是否单询": "Is it a single inquiry",
"阶梯和价格设置不能留空": "Single inquiry or not",
"新建空运价格": "Ladder and price settings cannot be left blank",
"新建海运价格": "New air freight price",
"批量设置海运价格": "New sea freight price",
"批量设置空运价格": "Batch setting of sea freight prices",
"批量设置商品海运路线": "Set air freight prices in bulk",
"批量设置商品空运路线": "Batch setting of product shipping routes",
"暂无清关费设置": "Batch set up air freight routes for goods",
"查看更多": "There is currently no customs clearance fee setting",
"単询": "View more",
"查看阶梯价": "Single inquiry"
} }
...@@ -403,6 +403,18 @@ export default { ...@@ -403,6 +403,18 @@ export default {
id: this.processInstance.businessKey, id: this.processInstance.businessKey,
path: this.processInstance.processDefinition?.formCustomViewPath path: this.processInstance.processDefinition?.formCustomViewPath
}, },
// 出货批量加价审核
box_batch_markup:{
component: () => import('@/views/ecw/box/components/batchMakeUpDetail.vue'),
processId: this.processInstance.businessKey,
type: this.processInstance.processDefinition?.formCustomViewPath
},
// 可获移交详情
customer_handover_details:{
component: () => import('@/views/ecw/customer/components/customer-handover-details.vue'),
processId: this.processInstance.businessKey,
type: this.processInstance.processDefinition?.formCustomViewPath
}
} }
console.log('formCustomViewPath', this.processInstance.processDefinition.formCustomViewPath.trim()) console.log('formCustomViewPath', this.processInstance.processDefinition.formCustomViewPath.trim())
return map[this.processInstance.processDefinition.formCustomViewPath.trim()] return map[this.processInstance.processDefinition.formCustomViewPath.trim()]
......
<!--批量加价--> <!--批量加价-->
<template> <template>
<div class="app-container"> <div class="app-container">
<div class="page-title">批量加价</div> <div class="page-title">{{$t('批量加价')}}</div>
<div> <div>
运费或全包加价 {{$t('运费或全包加价')}}
<!--货币--> <!--货币-->
<selector v-model="form.reduceCurrencyId" :options="currencyList" label-field="titleZh" value-field="id" defaultable class="w-100 ml-10" /> <selector :disabled="approval" v-model="form.freightCurrencyId" :options="currencyList" :label-field="$l('title')" value-field="id" defaultable class="w-100 ml-10" />
<!--金额--> <!--金额-->
<el-input type="number" v-model="form.cashCondition" @keyup.native="checkPositive(form, 'cashCondition')" class="w-100 ml-10" /> <el-input :disabled="approval" type="number" v-model="form.freightFee" :min="1" @keyup.native="checkPositive(form, 'freightFee')" class="w-100 ml-10" />
<!--单位--> <!--单位-->
<selector v-model="form.prodUnit" :options="unitList" label-field="titleZh" value-field="id" defaultable class="w-100 ml-10" /> <selector :disabled="approval" v-model="form.freightUnitId" :options="unitList" :label-field="$l('title')" value-field="id" defaultable class="w-100 ml-10" />
</div> </div>
<div class="mt-10"> <div class="mt-10">
清关费加价价 {{$t('清关费加价价')}}
<!--货币--> <!--货币-->
<selector v-model="form.reduceCurrencyId" :options="currencyList" label-field="titleZh" value-field="id" defaultable class="w-100 ml-10" /> <selector :disabled="approval" v-model="form.clearanceCurrencyId" :options="currencyList" :label-field="$l('title')" value-field="id" defaultable class="w-100 ml-10" />
<!--金额--> <!--金额-->
<el-input type="number" v-model="form.cashCondition" @keyup.native="checkPositive(form, 'cashCondition')" class="w-100 ml-10" /> <el-input :disabled="approval" type="number" v-model="form.clearanceFee" :min="1" @keyup.native="checkPositive(form, 'clearanceFee')" class="w-100 ml-10" />
<!--单位--> <!--单位-->
<selector v-model="form.prodUnit" :options="unitList" label-field="titleZh" value-field="id" defaultable class="w-100 ml-10" /> <selector :disabled="approval" v-model="form.clearanceUnitId" :options="unitList" :label-field="$l('title')" value-field="id" defaultable class="w-100 ml-10" />
<span>*{{$t('若线路价格为全包价,输入清关费不生效')}}</span>
</div> </div>
<el-card class="mt-20" v-if="shipmentObj"> <el-card class="mt-20" v-if="shipmentObj">
...@@ -55,16 +56,24 @@ ...@@ -55,16 +56,24 @@
<el-card class="mt-20"> <el-card class="mt-20">
<div slot="header"> <div slot="header">
明细 {{$t('明细')}}
</div> </div>
<div> <div class="flex-row" style="display: flex">
当前部分: <div class="flex-1">
{{$t('当前部分')}}
<el-select :placeholder="$t('请选择')" v-model="sectionId" @change="sectionChange"> <el-select :placeholder="$t('请选择')" v-model="sectionId" @change="sectionChange">
<el-option key="0" :label="$t('全部')" value="0"></el-option> <el-option key="0" :label="$t('全部')" :value="0"></el-option>
<el-option v-for="item in sectionList" :key="item.id" :label="item.title" :value="item.id"></el-option> <el-option v-for="item in sectionList" :key="item.id" :label="item.title" :value="item.id"></el-option>
</el-select> </el-select>
</div> </div>
<el-table border :data="orderList" @selection-change="handleSelectionChange" class="mt-10"> <div class="document-status" v-if="sectionObj">
<span>{{$t('单证状态')}}</span>
<template v-for="(item, index) in getDocStatus(sectionObj.sectionOrderList)">
<dict-tag :type="DICT_TYPE.ECW_CUSTOMS_TYPE" :value="item" :key="index" />
</template>
</div>
</div>
<el-table v-if="sectionObj" ref="orderTable" border :data="sectionObj.sectionOrderList || []" @selection-change="handleSelectionChange" class="mt-10">
<el-table-column type="selection" width="50"></el-table-column>> <el-table-column type="selection" width="50"></el-table-column>>
<el-table-column align="center" :label="$t('序号')" width="50" prop="tidanNum" /> <el-table-column align="center" :label="$t('序号')" width="50" prop="tidanNum" />
<el-table-column prop="orderNo" :label="$t('订单号')" align="center"> <el-table-column prop="orderNo" :label="$t('订单号')" align="center">
...@@ -76,7 +85,7 @@ ...@@ -76,7 +85,7 @@
<template v-slot="{row}"> <template v-slot="{row}">
<section> <section>
<div v-for="(item, index) in row.goodsList" :key="index"> <div v-for="(item, index) in row.goodsList" :key="index">
{{index+1}}{{item.prodTitleZh}} <div>{{index+1}}{{$l(item, 'prodTitle')}}</div>
</div> </div>
</section> </section>
</template> </template>
...@@ -96,26 +105,32 @@ ...@@ -96,26 +105,32 @@
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="customsFee" :label="$t('报关费用')" align="center"></el-table-column> <el-table-column prop="customsFee" :label="$t('报关费用')" align="center"></el-table-column>
<el-table-column prop="" :label="$t('当前成交价')" align="center" width="120px"> <el-table-column prop="" :label="$t('加价单价')" align="center" width="200px">
<template slot-scope="scope"> <template slot-scope="scope">
// TODO <div>
</template> {{$t('运费')}}{{form.freightFee || 0}}{{ currencyMap[form.freightCurrencyId]}}/{{unitMap[form.freightUnitId]}}
</el-table-column> </div>
<el-table-column prop="" :label="$t('加价后成交价')" align="center" width="120px"> <div>
<template slot-scope="scope"> {{$t('清关费')}}{{form.clearanceFee || 0}}{{ currencyMap[form.clearanceCurrencyId]}}/{{unitMap[form.clearanceUnitId]}}
// TODO </div>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
</el-card> </el-card>
<el-card class="mt-20"> <el-card class="mt-20">
<work-flow xmlkey="todo"></work-flow> <work-flow xmlkey="shipment_batch_add_price" v-model="form.copyUserId" :disabled="approval"></work-flow>
</el-card> </el-card>
<div class="mt-20"> <div class="mt-20" v-if="shipmentObj">
<el-button type="primary" @click="$alert('TODO')">提交审核</el-button>
<el-button type="primary" @click="$alert('TODO')">审核中</el-button> <template v-if="approval">
<el-button type="default" @click="$alert('TODO')">取消审核</el-button> <el-button type="primary" @click="$router.push('/bpm/process-instance/detail?id=' + shipmentObj.batchAddPriceApprovalInfo.bpmProcessId)">{{$t('加价申请审核中')}}</el-button>
<el-button type="default" @click="cancelAproval">{{$t('取消审核')}}</el-button>
</template>
<template v-else>
<el-button type="primary" @click="submit">{{$t('提交审核')}}</el-button>
</template>
<el-button type="default" @click="$store.dispatch('tagsView/delCurrentView')">{{$t('返回')}}</el-button>
</div> </div>
</div> </div>
</template> </template>
...@@ -128,20 +143,22 @@ import {getChannelList} from "@/api/ecw/channel"; ...@@ -128,20 +143,22 @@ import {getChannelList} from "@/api/ecw/channel";
import {getCabinetPage} from "@/api/ecw/cabinet"; import {getCabinetPage} from "@/api/ecw/cabinet";
import {getWarehouseList} from "@/api/ecw/warehouse"; import {getWarehouseList} from "@/api/ecw/warehouse";
import {getSupplierPage} from "@/api/ecw/supplier"; import {getSupplierPage} from "@/api/ecw/supplier";
import {boxGoodsDetail, getSectionList} from "@/api/ecw/boxSea"; import {approvalCancel, boxGoodsDetail, createApproval, getSectionList, loadSecGoodsList} from "@/api/ecw/boxSea";
import {getAbnormalList, getbox, getLogList} from "@/api/ecw/box"; import {getAbnormalList, getbox, getLogList} from "@/api/ecw/box";
import {getTotlContent} from "@/views/ecw/box/shippingSea/utils"; import {getTotlContent} from "@/views/ecw/box/shippingSea/utils";
import WorkFlow from "@/components/WorkFlow"; import WorkFlow from "@/components/WorkFlow";
import Template from "@/views/cms/template/index.vue";
export default { export default {
name: "batchMarkup", name: "batchMarkup",
components: {selector, WorkFlow}, components: {Template, selector, WorkFlow},
data(){ data(){
return { return {
unitList:[], unitList:[],
currencyList:[], currencyList:[],
form:{}, form:{
orderList:[], copyUserId:[]
},
// 表格多选 // 表格多选
multipleSelection: [], multipleSelection: [],
// 选择的id // 选择的id
...@@ -154,10 +171,25 @@ export default { ...@@ -154,10 +171,25 @@ export default {
shipmentObj: null, shipmentObj: null,
shipmentId: null, shipmentId: null,
// 当前选择的部分 // 当前选择的部分
sectionId: 0 sectionId: 0,
sectionObj: null
} }
}, },
computed:{ computed:{
currencyMap(){
let map = {}
this.currencyList.forEach(item => {
map[item.id] = this.$l(item, 'title')
})
return map
},
unitMap(){
let map = {}
this.unitList.forEach(item => {
map[item.id] = this.$l(item, 'title')
})
return map
},
/* 渠道 */ /* 渠道 */
getShipChannelName() { getShipChannelName() {
return (shippingChannelId) => { return (shippingChannelId) => {
...@@ -182,14 +214,15 @@ export default { ...@@ -182,14 +214,15 @@ export default {
weight: boxStatistics.weight ?? 0, weight: boxStatistics.weight ?? 0,
}); });
} }
return; return 0;
}; };
}, },
/* 获取仓库 */ /* 获取仓库 */
getCityName() { getCityName() {
return (id) => { return (id) => {
let arr = this.warehouseList.filter((item) => item.id == id); if(!this.warehouseList || !this.warehouseList.length) return ''
return arr.length > 0 ? this.$l(arr[0], "title") : this.$t(""); let warehouse = this.warehouseList.find((item) => item.id == id);
return warehouse ? this.$l(warehouse, "title") : this.$t("");
}; };
}, },
// 部分信息 // 部分信息
...@@ -201,28 +234,48 @@ export default { ...@@ -201,28 +234,48 @@ export default {
return getTotlContent(secStatistics); return getTotlContent(secStatistics);
} }
}, },
getDocStatus() {
return (list = []) => {
// 获取类型
let customsTypes = list.map((item) => item.customsType);
// 去重
return Array.from(new Set(customsTypes));
};
},
// 是否审核中
approval(){
return this.shipmentObj?.batchAddPriceApprovalInfo?.approvalStatus === 1
}
}, },
created() { async created() {
getUnitList().then(res => this.unitList = res.data) getUnitList().then(res => this.unitList = res.data)
getCurrencyList().then(res => this.currencyList = res.data) getCurrencyList().then(res => this.currencyList = res.data)
this.shipmentId = this.$route.query.shipmentId this.shipmentId = this.$route.query.shipmentId
if(!this.shipmentId){ if(!this.shipmentId){
return this.$message.error('请求参数错误') return this.$message.error('请求参数错误')
} }
this.initData() await this.getBoxDetail()
this.getSectionList() await this.initData()
this.getBoxDetail() await this.getSectionList()
// 如果是审核中,则默认选中订单
this.$nextTick(() =>{
if(this.approval){
this.sectionObj.sectionOrderList.forEach(order => {
if(this.form.orderIds.indexOf(order.orderId) > -1){
this.$refs.orderTable.toggleRowSelection(order)
}
})
}
})
}, },
methods:{ methods:{
// 检查正数 // 检查正数
checkPositive(object, field){ checkPositive(object, field){
const lastChar = object[field].split('').pop() object[field] = parseInt(object[field])
object[field] = parseFloat(object[field])
if(isNaN(object[field]) || object[field] < 0) object[field] = '' if(isNaN(object[field]) || object[field] < 0) object[field] = ''
else object[field] = object[field].toString() else object[field] = object[field].toString()
// 如果最后一位是.且没有其他点则补上
if(object[field] != '' && object[field].indexOf('.') == -1 && lastChar == '.') object[field] += '.'
}, },
// 表格多选 // 表格多选
handleSelectionChange(selection) { handleSelectionChange(selection) {
...@@ -230,7 +283,7 @@ export default { ...@@ -230,7 +283,7 @@ export default {
this.ids = selection.map(item => item.orderId) this.ids = selection.map(item => item.orderId)
}, },
// 初始化字典数据 // 初始化字典数据
initData() { async initData() {
// 查询渠道 // 查询渠道
getChannelList().then((res) => (this.channelList = res.data)); getChannelList().then((res) => (this.channelList = res.data));
// 查询柜型 // 查询柜型
...@@ -246,19 +299,28 @@ export default { ...@@ -246,19 +299,28 @@ export default {
const { data } = res; const { data } = res;
this.allSupplier = data.list; this.allSupplier = data.list;
});*/ });*/
/*loadSecGoodsList({shipmentId: this.shipmentId}).then(res => {
this.sectionList = res.data
})*/
await this.getBoxGoodsDetail()
}, },
// 出货信息 // 出货信息
getBoxDetail() { getBoxDetail() {
getbox(this.shipmentId).then((res) => { getbox(this.shipmentId).then((res) => {
const { data } = res; const { data } = res;
this.shipmentObj = data ?? {}; this.shipmentObj = data ?? {};
// 如果是审核中则表单给默认值
if(this.shipmentObj.batchAddPriceApprovalInfo && this.approval){
let details = JSON.parse(this.shipmentObj.batchAddPriceApprovalInfo.details)
this.$set(this, 'form', details)
}
}); });
}, },
// 查询详情页所有数据 // 查询详情页所有数据
getSectionList() { getSectionList() {
let param = { shipmentId: this.shipmentId }; let param = { shipmentId: this.shipmentId };
// 部分 // 部分
getSectionList(param).then((res) => { return getSectionList(param).then((res) => {
this.sectionList = res.data.map((item, index) => { this.sectionList = res.data.map((item, index) => {
return { return {
...item, ...item,
...@@ -280,13 +342,50 @@ export default { ...@@ -280,13 +342,50 @@ export default {
}, },
// 获取部分详情以及物品 // 获取部分详情以及物品
getBoxGoodsDetail() { getBoxGoodsDetail() {
boxGoodsDetail({ return boxGoodsDetail({
shipmentId: this.shipmentId, shipmentId: this.shipmentId,
secId: this.sectionId, secId: this.sectionId,
}).then((res) => { }).then((res) => {
this.sectionObj = res.data; this.sectionObj = res.data;
}); });
}, },
// 提交审核
submit(){
if(!this.form.freightFee && !this.form.clearanceFee){
return this.$message.error(this.$t('运费和清关费不能同时为空'))
}
if(!this.ids.length){
return this.$message.error(this.$t('最少选择一个订单'))
}
let form = {...this.form, orderIds: this.ids}
let data = {
approvalType: 18, // 批量加价
copyUserId: this.form.copyUserId,
details: JSON.stringify(form),
shipmentId: this.shipmentId
}
createApproval(data).then(() => {
this.$message.success(this.$t('提交成功'))
this.$store.dispatch('tagsView/delCurrentView')
})
},
// 取消审核
cancelAproval(){
this.$prompt(this.$t('请输入取消原因'), this.$t('取消审核'), {
inputPattern: /\S/,
inputErrorMessage: this.$t('请输入取消原因')
}).then(({value}) => {
console.log('cancelApproval', value)
return approvalCancel({
applyReason: value,
id: this.shipmentObj.batchAddPriceApprovalInfo.id,
shipmentId: this.shipmentId
})
}).then(res => {
this.$message.success('已取消审核')
this.getBoxDetail()
})
}
} }
} }
</script> </script>
......
<template>
<div class="app-approvalShipping">
<h1>{{$t('申请信息')}}{{$t('出货信息')}}</h1>
<el-descriptions :column="6" border>
<el-descriptions-item :label="$t('自编号')">{{boxBackVO.selfNo}}</el-descriptions-item>
<el-descriptions-item :label="$t('运输方式')">
<dict-tag :type="DICT_TYPE.ECW_TRANSPORT_TYPE" :value="boxBackVO.transportType" />
</el-descriptions-item>
<el-descriptions-item :label="$t('出货渠道')">
{{getShipChannelName(boxBackVO.shippingChannelId)}}
</el-descriptions-item>
<el-descriptions-item :label="$t('柜型')">
{{cabinetLabel}}
</el-descriptions-item>
<el-descriptions-item :label="$t('体积/重量')">
{{getVolumeWeight(loadDetail.totalStatistics)}}
</el-descriptions-item>
<el-descriptions-item :label="$t('货柜状态')">
{{boxBackVO.shipmentStatusText}}
</el-descriptions-item>
</el-descriptions>
<div v-if="approvalInfo.applyReason">
<h1>{{$t('申请原因')}}</h1>
<div>
{{approvalInfo.applyReason}}
</div>
</div>
<el-table :data="loadDetail.sectionOrderList" border class="mt-10">
<el-table-column prop="orderNo" :label="$t('订单号')" align="center">
<template v-slot="{row}">
<el-button type="text" @click="jumpOrderDetail(row)">{{row.orderNo}}</el-button>
</template>
</el-table-column>
<el-table-column :label="$t('货物信息')" align="center" width="500px">
<template v-slot="{row}">
<section>
<div v-for="(item, index) in row.goodsList" :key="index">
<div>{{index+1}}{{$l(item, 'prodTitle')}}</div>
</div>
</section>
</template>
</el-table-column>
<el-table-column :label="$t('收费箱数')" align="center" prop="num"></el-table-column>
<el-table-column :label="$t('收费体积')" align="center" prop="chargeVolume"></el-table-column>
<el-table-column :label="$t('收费重量')" align="center" prop="chargeWeight"></el-table-column>
<el-table-column :label="$t('加价金额')" align="center">
<template slot-scope="{row}" v-if="details">
<div>
{{$t('运费')}}{{details.freightFee || 0}}{{ currencyMap[details.freightCurrencyId]}}/{{unitMap[details.freightUnitId]}}
</div>
<div>
{{$t('清关费')}}{{details.clearanceFee || 0}}{{ currencyMap[details.clearanceCurrencyId]}}/{{unitMap[details.clearanceUnitId]}}
</div>
</template>
</el-table-column>
</el-table>
</div>
</template>
<script>
import { approvalDetail } from "@/api/ecw/box";
import { getSeaStatus, getTotlContent } from "../shippingSea/utils";
import { getCabinetPage } from "@/api/ecw/cabinet";
import { getChannelList } from "@/api/ecw/channel";
import Decimal from "decimal.js";
import Template from "@/views/cms/template/index.vue";
import {getUnitList} from "@/api/ecw/unit";
import {getCurrencyList} from "@/api/ecw/currency";
/**
* 批量加价审核详情
*/
export default {
name: "BatchMakeUpDetail",
components: {Template},
props: {
processId: {
type: [Number, String],
},
type: String,
},
data() {
return {
unitList:[],
currencyList:[],
approvalInfo: {},
boxBackVO: {},
loadDetail: {},
// 柜型
cabinetLabel: "",
//渠道
channelList: [],
// 弹出配置
dialogConfig: {
title: "",
visible: false,
},
srcStrs: [],
};
},
created() {
getUnitList().then(res => this.unitList = res.data)
getCurrencyList().then(res => this.currencyList = res.data)
getChannelList().then((res) => (this.channelList = res.data));
},
methods: {
getTotlContent,
/* 获取详情 */
getApprovalDetail(processId) {
approvalDetail({ approvalId: processId }).then((res) => {
this.approvalInfo = res.data.approvalInfo;
this.boxBackVO = res.data.boxBackVO;
this.loadDetail = res.data.loadDetail;
});
},
/* 获取柜型 */
getCabinetLabel(cabinetId) {
getCabinetPage(null).then((response) => {
const cabinetList = response.data.list;
for (const cabinetItem of cabinetList) {
if (cabinetItem.id == cabinetId) {
this.cabinetLabel = cabinetItem.name;
break;
}
}
});
},
/* 合计 */
calcSum(goodsList) {
let sum = 0;
goodsList.forEach((element) => {
sum = Decimal.add(sum, element.num).toNumber();
});
return sum;
},
/* 跳转订单详情 */
jumpOrderDetail(row) {
this.$router.push("/order/detail?orderId=" + row.orderId);
},
},
watch: {
processId: {
immediate: true,
handler(val) {
this.getApprovalDetail(val);
},
},
boxBackVO(val) {
// 柜型
this.getCabinetLabel(val.cabinetId);
},
},
computed: {
/* 渠道 */
getShipChannelName() {
return (shippingChannelId) => {
for (const channelItem of this.channelList) {
if (channelItem.channelId == shippingChannelId) {
return this.$l(channelItem, "name");
}
}
};
},
/* 体积重量 */
getVolumeWeight() {
return (total) => {
return this.getTotlContent(total);
};
},
/* 是否显示卸柜箱数 */
isShowColumn() {
return (shippingVO) => {
return getSeaStatus(shippingVO) >= 182 ? true : false;
};
},
details(){
if(!this.approvalInfo) return null
return JSON.parse(this.approvalInfo?.details)
},
currencyMap(){
let map = {}
this.currencyList.forEach(item => {
map[item.id] = this.$l(item, 'title')
})
return map
},
unitMap(){
let map = {}
this.unitList.forEach(item => {
map[item.id] = this.$l(item, 'title')
})
return map
},
},
};
</script>
<style lang="scss" scoped>
.el-image {
border-radius: 5px;
background-color: #ebeef5;
box-shadow: 0 0 5px 1px #ccc;
::v-deep .el-image__inner {
transition: all 0.3s;
cursor: pointer;
&:hover {
transform: scale(1.2);
}
}
::v-deep .image-slot {
display: flex;
justify-content: center;
align-items: center;
width: 100%;
height: 100%;
color: #909399;
font-size: 30px;
}
}
</style>
...@@ -118,7 +118,7 @@ ...@@ -118,7 +118,7 @@
<el-dropdown-item command="error">{{$t('异常登记')}}</el-dropdown-item> <el-dropdown-item command="error">{{$t('异常登记')}}</el-dropdown-item>
<el-dropdown-item command="cost">{{$t('费用登记')}}</el-dropdown-item> <el-dropdown-item command="cost">{{$t('费用登记')}}</el-dropdown-item>
<el-dropdown-item command="batchMarkup">{{$t('批量加价')}}</el-dropdown-item> <el-dropdown-item command="batchMarkup">{{$t('批量加价')}}</el-dropdown-item>
<el-dropdown-item :disabled="scope.row.ldStatus<46" command="editLadingBill">{{$t('编辑提货单')}}</el-dropdown-item> <el-dropdown-item :disabled="scope.row.prStatus<25" command="editLadingBill">{{$t('编辑提货单')}}</el-dropdown-item>
<!-- <el-dropdown-item command="delete">{{$t('删除')}}</el-dropdown-item>--> <!-- <el-dropdown-item command="delete">{{$t('删除')}}</el-dropdown-item>-->
</el-dropdown-menu> </el-dropdown-menu>
......
...@@ -494,7 +494,7 @@ export default { ...@@ -494,7 +494,7 @@ export default {
break; break;
case "router": case "router":
this.$router.push("/boxSea/shippingSea/" + this.shipmentId); this.$router.push("/boxAir/shippingAir/" + this.shipmentId);
break; break;
case "cost": case "cost":
......
...@@ -70,7 +70,7 @@ ...@@ -70,7 +70,7 @@
{{getCheckExamineStatus}} {{getCheckExamineStatus}}
</el-form-item> </el-form-item>
</el-form-item> </el-form-item>
<el-form-item v-show="cusDeclarationObj.overMachineStatus == 2 && cusDeclarationObj.overMachineAbnormalStatus == 1"> <el-form-item v-show="cusDeclarationObj.overMachineStatus == 2 && cusDeclarationObj.overMachineAbnormalStatus == 1 && shipmentObj.overMachineExamineStatus == 0 && (typeof cusDeclarationObj.id != 'undefined')">
<el-button type="primary" @click="approvalCreate">{{$t('提交删单退场审核')}}</el-button> <el-button type="primary" @click="approvalCreate">{{$t('提交删单退场审核')}}</el-button>
</el-form-item> </el-form-item>
<el-form-item prop="weightMisreport" v-show="cusDeclarationObj.overMachineStatus == 2 && cusDeclarationObj.overMachineAbnormalStatus == 2"> <el-form-item prop="weightMisreport" v-show="cusDeclarationObj.overMachineStatus == 2 && cusDeclarationObj.overMachineAbnormalStatus == 2">
...@@ -106,11 +106,8 @@ ...@@ -106,11 +106,8 @@
</el-form-item> </el-form-item>
</el-form> </el-form>
<el-row class="operate-button" v-if="inReview">
<el-button type="primary" @click="jumpReviewDetail">{{cusDeclarationObj.dcCheckStatus === '1' ? $t('全部退场审核中') : $t('部分退场审核中')}}</el-button>
<el-button type="primary" plain @click="canclAudit">{{cusDeclarationObj.dcCheckStatus === '1' ? $t('取消全部退场审核') : $t('取消部分退场审核')}}</el-button>
</el-row>
<el-row class="operate-button"> <el-row class="operate-button">
<el-button type="primary" v-if="inReview" plain @click="canclAudit">{{$t('取消删单退场审核')}}</el-button>
<el-button type="primary" @click="onSubmit(1)" :disabled="isCheckDeal('submit')">{{$t('保存')}}</el-button> <el-button type="primary" @click="onSubmit(1)" :disabled="isCheckDeal('submit')">{{$t('保存')}}</el-button>
<el-button type="success" v-if="!inReview" @click="onSubmit(2)" :disabled="isCheckDeal('submit')">{{$t('提交')}}</el-button> <el-button type="success" v-if="!inReview" @click="onSubmit(2)" :disabled="isCheckDeal('submit')">{{$t('提交')}}</el-button>
<el-button @click="cancel">{{$t('关闭')}}</el-button> <el-button @click="cancel">{{$t('关闭')}}</el-button>
...@@ -291,11 +288,16 @@ export default { ...@@ -291,11 +288,16 @@ export default {
]); ]);
oldData.overDealUser = this.strToArray(oldData.overDealUser) oldData.overDealUser = this.strToArray(oldData.overDealUser)
oldData.overOrders = this.strToArray(oldData.overOrders) oldData.overOrders = this.strToArray(oldData.overOrders)
this.cusDeclarationObj = oldData; this.cusDeclarationObj = oldData;
if(this.shipmentObj.overMachineExamineStatus == 1){
this.$set(this.cusDeclarationObj, "overMachineStatus", 2)
this.$set(this.cusDeclarationObj, "overMachineAbnormalStatus", 1)
}
}, },
methods: { methods: {
strToArray(str) { strToArray(str) {
if(str == 0) return [] if(!str) return []
let array = str?.split(",") ?? [] let array = str?.split(",") ?? []
return array.map(item=>{return Number(item)}) return array.map(item=>{return Number(item)})
}, },
...@@ -373,10 +375,9 @@ export default { ...@@ -373,10 +375,9 @@ export default {
approvalCreate({ approvalCreate({
shipmentId: this.shipmentObj.id, shipmentId: this.shipmentObj.id,
approvalStatus: 0, approvalStatus: 0,
approvalType: 10 approvalType: 11
}).then((res) => { }).then((res) => {
serviceMsg(res, this).then(() => { serviceMsg(res, this).then(() => {
this.cancel("submit");
}); });
}); });
}, },
...@@ -403,18 +404,18 @@ export default { ...@@ -403,18 +404,18 @@ export default {
} }
// 3.查验状态,查验后放行 直接提交 // 3.查验状态,查验后放行 直接提交
if (dcCheckStatus === "3") { if (dcCheckStatus === "3") {
const { checkExamineStatus } = this.shipmentObj; const { overMachineExamineStatus } = this.shipmentObj;
// 没有退场审核中的状态 // 没有退场审核中的状态
if (checkExamineStatus !== 1) { if (overMachineExamineStatus !== 1) {
this.submitCustomsCreate(operateType); this.submitCustomsCreate(operateType);
return; return;
} }
} }
// 4.查验状态,退场/部分退场 提示 // 4.查验状态,退场/部分退场 提示
if (["1", "2"].includes(dcCheckStatus)) { if (["1", "2"].includes(dcCheckStatus)) {
const { checkExamineStatus } = this.shipmentObj; const { overMachineExamineStatus } = this.shipmentObj;
// 退场审核状态,1-审核中,2-审核成功,3-审核失败,4-取消 // 退场审核状态,1-审核中,2-审核成功,3-审核失败,4-取消
if ([0, 2, 3, 4].includes(checkExamineStatus)) { if ([0, 2, 3, 4].includes(overMachineExamineStatus)) {
this.$modal this.$modal
.confirm(this.$t( .confirm(this.$t(
`您确认提交${ `您确认提交${
...@@ -562,9 +563,10 @@ export default { ...@@ -562,9 +563,10 @@ export default {
}, },
/* 取消审核 */ /* 取消审核 */
canclAudit() { canclAudit() {
console.log(this.shipmentObj)
approvalCancel({ approvalCancel({
applyReason: this.$t("取消审核"), applyReason: this.$t("取消审核"),
id: this.shipmentObj["customsApprovalInfo"].id, id: this.shipmentObj["customsDeleteExitApprovalInfo"].id,
shipmentId: this.shipmentObj.id, shipmentId: this.shipmentObj.id,
}).then((res) => { }).then((res) => {
serviceMsg(res, this).then(() => { serviceMsg(res, this).then(() => {
...@@ -576,11 +578,11 @@ export default { ...@@ -576,11 +578,11 @@ export default {
}, },
/* 判断查验选择是否禁用 */ /* 判断查验选择是否禁用 */
disabledRadio(item) { disabledRadio(item) {
const { checkExamineStatus, checkDealStatus, customsInfo } = const { overMachineExamineStatus, checkDealStatus, customsInfo } =
this.shipmentObj; this.shipmentObj;
const { dcCheckStatus } = customsInfo ?? {}; // 部分退场状态并且审核通过,退场不可选择 const { dcCheckStatus } = customsInfo ?? {}; // 部分退场状态并且审核通过,退场不可选择
if ( if (
checkExamineStatus === 2 && overMachineExamineStatus === 2 &&
dcCheckStatus === 2 && dcCheckStatus === 2 &&
checkDealStatus === 0 && checkDealStatus === 0 &&
item.value === "1" item.value === "1"
...@@ -631,8 +633,8 @@ export default { ...@@ -631,8 +633,8 @@ export default {
immediate: true, immediate: true,
handler: function (val) { handler: function (val) {
// 监听查验状态变化 // 监听查验状态变化
let { checkExamineStatus } = val; let { overMachineExamineStatus } = val;
if (checkExamineStatus === 1) { if (overMachineExamineStatus === 1) {
// 按钮变成审核中 // 按钮变成审核中
this.inReview = true; this.inReview = true;
} }
...@@ -657,15 +659,15 @@ export default { ...@@ -657,15 +659,15 @@ export default {
computed: { computed: {
/* 获取报关审核退场状态文字 */ /* 获取报关审核退场状态文字 */
getCheckExamineStatus() { getCheckExamineStatus() {
const { checkExamineStatus, checkDealStatus, customsInfo } = const { overMachineExamineStatus, checkDealStatus, customsInfo } =
this.shipmentObj; this.shipmentObj;
const { dcCheckStatus } = customsInfo ?? {}; const { dcCheckStatus } = customsInfo ?? {};
if (checkExamineStatus === 1) { if (overMachineExamineStatus === 1) {
return dcCheckStatus === 1 return dcCheckStatus === 1
? this.$t("退场审核中") ? this.$t("退场审核中")
: this.$t("部分退场审核中"); : this.$t("部分退场审核中");
} }
if (checkExamineStatus === 2 && checkDealStatus === 0) { if (overMachineExamineStatus === 2 && checkDealStatus === 0) {
return dcCheckStatus === 1 return dcCheckStatus === 1
? this.$t("审核通过,退场中") ? this.$t("审核通过,退场中")
: this.$t("审核通过,部分退场中"); : this.$t("审核通过,部分退场中");
...@@ -675,7 +677,7 @@ export default { ...@@ -675,7 +677,7 @@ export default {
/* 判断是否已处理 */ /* 判断是否已处理 */
isCheckDeal() { isCheckDeal() {
return (type) => { return (type) => {
const { checkExamineStatus, checkDealStatus, customsInfo } = const { overMachineExamineStatus, checkDealStatus, customsInfo } =
this.shipmentObj; this.shipmentObj;
const { dcCheckStatus } = customsInfo ?? {}; const { dcCheckStatus } = customsInfo ?? {};
...@@ -683,7 +685,7 @@ export default { ...@@ -683,7 +685,7 @@ export default {
if (type === "status") { if (type === "status") {
// 退场/部分退场 审核通过未处理,禁用 // 退场/部分退场 审核通过未处理,禁用
if ( if (
checkExamineStatus === 2 && overMachineExamineStatus === 2 &&
[1, 2].includes(dcCheckStatus) && [1, 2].includes(dcCheckStatus) &&
checkDealStatus === 0 checkDealStatus === 0
) { ) {
...@@ -696,7 +698,7 @@ export default { ...@@ -696,7 +698,7 @@ export default {
// 退场 审核通过未处理,禁用 // 退场 审核通过未处理,禁用
// 部分退场 审核通过未处理,由 disabledRadio 方法判断 // 部分退场 审核通过未处理,由 disabledRadio 方法判断
if ( if (
checkExamineStatus === 2 && overMachineExamineStatus === 2 &&
[1].includes(dcCheckStatus) && [1].includes(dcCheckStatus) &&
checkDealStatus === 0 checkDealStatus === 0
) { ) {
...@@ -708,7 +710,7 @@ export default { ...@@ -708,7 +710,7 @@ export default {
if (type === "submit") { if (type === "submit") {
const { dcCheckStatus: newCheckStatus } = this.cusDeclarationObj; const { dcCheckStatus: newCheckStatus } = this.cusDeclarationObj;
// 退场/部分退场 审核通过未处理 // 退场/部分退场 审核通过未处理
if (checkExamineStatus === 2 && checkDealStatus === 0) { if (overMachineExamineStatus === 2 && checkDealStatus === 0) {
// 退场,禁用 // 退场,禁用
if (dcCheckStatus === 1) return true; if (dcCheckStatus === 1) return true;
// 部分退场 // 部分退场
......
...@@ -122,7 +122,7 @@ ...@@ -122,7 +122,7 @@
</div> </div>
</el-dialog> </el-dialog>
<!-- 打印标签 --> <!-- 打印标签 -->
<el-dialog :title="$t('集运封箱标签')" :visible.sync="printdialogVisible" width="300px" :modal-append-to-body="false" append-to-body> <el-dialog :title="$t('集运封箱标签')" :visible.sync="printdialogVisible" width="350px" :modal-append-to-body="false" append-to-body>
<print-tag v-if="printdialogVisible" :tagData="tagData" /> <print-tag v-if="printdialogVisible" :tagData="tagData" />
</el-dialog> </el-dialog>
</el-row> </el-row>
......
...@@ -64,7 +64,7 @@ ...@@ -64,7 +64,7 @@
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('实装箱数')" align="center" prop="installNum" /> <el-table-column :label="$t('实装箱数')" align="center" prop="installNum" />
<el-table-column :label="$t('卸柜箱数')" align="center" prop="unloadNum" /> <el-table-column :label="$t('到仓箱数')" align="center" prop="unloadNum" />
<el-table-column :label="$t('清关状态')" align="center" prop=""> <el-table-column :label="$t('清关状态')" align="center" prop="">
<template slot-scope="scope">{{clearStatus(scope.row)}}</template> <template slot-scope="scope">{{clearStatus(scope.row)}}</template>
</el-table-column> </el-table-column>
...@@ -106,7 +106,7 @@ ...@@ -106,7 +106,7 @@
</div> </div>
<div class="label-font"> <div class="label-font">
<p> <p>
<span>{{$t('已卸')}}:</span> <span>{{$t('到仓')}}:</span>
<span>{{getUnLoadNumCount}}</span> <span>{{getUnLoadNumCount}}</span>
</p> </p>
</div> </div>
...@@ -263,6 +263,7 @@ export default { ...@@ -263,6 +263,7 @@ export default {
}, },
/** 提交 */ /** 提交 */
onSubmit() { onSubmit() {
if(this.getUnLoadNumCount>0){
approvalCreate({ approvalCreate({
shipmentId: this.$attrs.shipmentObj.id, shipmentId: this.$attrs.shipmentObj.id,
approvalStatus: 0, approvalStatus: 0,
...@@ -273,6 +274,10 @@ export default { ...@@ -273,6 +274,10 @@ export default {
this.cancel(); this.cancel();
}); });
}); });
}else{
this.$message.error(this.$t("货物到仓数小于实装数,请确认"));
}
}, },
/** 取消 */ /** 取消 */
cancel() { cancel() {
......
...@@ -59,7 +59,7 @@ ...@@ -59,7 +59,7 @@
<el-table-column :label="$t('发布人') + '/' + $t('发布时间')" align="center" prop="startTime" width="180"> <el-table-column :label="$t('发布人') + '/' + $t('发布时间')" align="center" prop="startTime" width="180">
<template slot-scope="scope"> <template slot-scope="scope">
<div>{{ scope.row.creatorName }}</div> <div>{{ scope.row.creatorName }}</div>
<div>{{ parseTime(scope.row.createTime, '{y}-{m}-{d}') }}</div> <div>{{ parseTime(scope.row.createTime) }}</div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('开始时间')" align="center" prop="startTime" width="180"> <el-table-column :label="$t('开始时间')" align="center" prop="startTime" width="180">
...@@ -82,7 +82,7 @@ ...@@ -82,7 +82,7 @@
<el-table-column :label="$t('更新人') + '/' + $t('更新时间')" align="center" width="180"> <el-table-column :label="$t('更新人') + '/' + $t('更新时间')" align="center" width="180">
<template slot-scope="scope"> <template slot-scope="scope">
<div>{{ scope.row.updaterName }}</div> <div>{{ scope.row.updaterName }}</div>
<div>{{ parseTime(scope.row.updateTime, '{y}-{m}-{d}') }}</div> <div>{{ parseTime(scope.row.updateTime)}}</div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('状态')" align="center" prop="createTime" width="180"> <el-table-column :label="$t('状态')" align="center" prop="createTime" width="180">
......
<template>
<div>
<el-dialog :title="$t('新建潜在客户信息')" :visible.sync="dialogTableVisible">
<el-form ref="form" :rules="rules" :model="form" label-width="100px" style="padding: 0 20px;">
<el-form-item prop="name" :label="$t('客户姓名')">
<el-input v-model="form.name" :placeholder="$t('请输入客户姓名')"></el-input>
</el-form-item>
<el-form-item required :label="$t('联系方式')" >
<el-row :gutter="20">
<el-col :span="4" >
<el-form-item prop="customerContacts[0].areaCode" >
<area-code-selector v-model="form.customerContacts['0'].areaCode" />
</el-form-item>
</el-col>
<el-col :span="10">
<el-form-item prop="customerContacts[0].phoneNew">
<el-input style="width:100%;" v-model="form.customerContacts[0].phoneNew" maxlength="11" :placeholder="$t('请输入联系方式')" />
</el-form-item>
</el-col>
</el-row>
</el-form-item>
<el-form-item prop="source" :label="$t('客户来源')">
<el-select v-model="form.source" :placeholder="$t('请选择客户来源')">
<el-option v-for="dict in getDictDatas(DICT_TYPE.CUSTOMER_SOURCE)"
:key="dict.value" :label="dict.label" :value="parseInt(dict.value)" />
</el-select>
</el-form-item>
<el-form-item :label="$t('客户类别')" prop="type" >
<dict-selector v-model="form.type" :type="DICT_TYPE.CUSTOMER_TYPE" form-type="checkbox" multiple ></dict-selector>
</el-form-item>
<el-form-item :label="$t('客户经理')" >
<el-select v-model="form.customerService" :placeholder="$t('请选择客户经理')">
<el-option v-for="item in serviceUserList"
:key="item.id" :label="item.nickname" :value="item.id" />
</el-select>
</el-form-item>
<el-form-item :label="$t('公司名称')">
<el-input v-model="form.company" ></el-input>
</el-form-item>
<el-form-item :label="$t('公司英文名称')">
<el-input v-model="form.companyEn" ></el-input>
</el-form-item>
<el-form-item :label="$t('主营类别')" prop="productType">
<el-row :gutter="10">
<el-col :span="11">
<el-select v-model="form.productType" style="width: 100%" @change="getProductListFn" :placeholder="$t('请选择产品类别')" >
<el-option :label="item.titleZh" :value="item.id" v-for="(item) in productTypeList" :key="item.id"/>
</el-select>
</el-col>
<el-col :span="11">
<el-select v-model="form.productId" style="width: 100%" :placeholder="$t('请选择')">
<el-option :label="item.titleZh" :value="parseInt(item.id)" v-for="(item) in productList" :key="item.id"/>
</el-select>
</el-col>
</el-row>
</el-form-item>
<el-form-item :label="$t('询盘信息')" >
<el-input
v-model="form.inquiry"
type="textarea"
:rows="3"
:placeholder="$t('请输入内容')">
</el-input>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button @click="dialogTableVisible = false">{{$t('取 消')}}</el-button>
<el-button type="primary" @click="submit">{{$t('确 定')}}</el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import {DICT_TYPE, getDictDatas} from "@/utils/dict";
import AreaCodeSelector from "@/components/AreaCodeSelector/index.vue";
import {listServiceUser} from "@/api/system/user";
import {getProductTypeList} from "@/api/ecw/productType";
import {getProductList} from "@/api/ecw/product";
import {createPotential} from "@/api/ecw/customer";
export default {
name: "addPotentialCustom",
methods: {
getDictDatas,
getProductListFn(val){
getProductList({typeId:val}).then(r => {
this.productList = r.data
})
},
reset(){
this.form = {
name:undefined,
customerContacts:[{areaCode:undefined,phoneNew:undefined,name:undefined,isDefault: 1}],
source:undefined,
type:[],
customerService:undefined,
company:undefined,
companyEn:undefined,
inquiry:undefined,
productType:undefined,
productId:undefined,
}
},
submit(){
this.$refs.form.validate((valId)=>{
if (valId){
let p = {...this.form}
p.type = p.type.join(',')
p.customerContacts[0].name = p.name + p.customerContacts[0].phoneNew
createPotential(p).then(r => {
if(r.code === 0){
this.$emit('change');
this.dialogTableVisible = false;
this.$message(this.$t('创建成功'));
}
})
}
})
},
},
components: {AreaCodeSelector},
created() {
this.reset()
listServiceUser().then(r => {
this.serviceUserList = r.data
})
getProductTypeList().then(r => {
this.productTypeList = r.data
})
},
computed: {
DICT_TYPE() {
return DICT_TYPE
},
rules(){
return {
name:{ required:true,message:this.$t('请输入名称'),target:'blur' },
customerContacts:[{areaCode:{required:true,message:this.$t('请输入区号。'),target:'blur'},phoneNew:{required:true,message:this.$t('请输入电话号码。'),target:'blur'} },],
type:{ type:'array', message:this.$t('请输入客户类别。'), required:true, target:['blur','change']},
source:{message:this.$t('前请输入客户来源'),required:true,target:'change',type:'number'}
}
}
},
data(){
return {
dialogTableVisible:false,
serviceUserList:[],
productTypeList:[],
productList:[],
form:{}
}
},
}
</script>
<style scoped>
</style>
<template>
<div style="display: inline-block">
<span @click="visible = true"> <slot></slot></span>
<el-dialog title="更多联系人" :visible.sync="visible">
<div v-if="info">
<div style="text-align: center;margin-bottom: 20px;" v-for="(item, index) in info" :key="index">
联系人{{index + 1}}{{$l('name', item)}}联系方式{{index + 1}}:+{{item.areaCode}} {{item.phoneNew}}<br/>
邮箱:{{item.email}}
</div>
</div>
<div v-else>
暂无数据
</div>
</el-dialog>
</div>
</template>
<script>
import {getCustomerContacts, getCustomerContactsListByCustomer} from "@/api/ecw/customerContacts";
export default {
name: "contacts",
props:{
id:[Number]
},
data(){
return {
visible:false,
info:null,
}
},
methods:{
getCustomerContactsFn() {
getCustomerContactsListByCustomer({customerId: this.id}).then(r => {
console.log(r,'rrr')
this.info = r.data
})
}
},
watch:{
visible(val){
if(val){
this.getCustomerContactsFn()
}
}
}
}
</script>
<style scoped>
</style>
<template>
<div>
<div v-for="(item, index) in info.customerHandoverDetailDtoList">
<div style="color: blue"> 客户编号{{index + 1}}{{item.customerNumber}} 客户名称{{index + 1}}{{item.customerName}} </div>
<div>就客户经理{{index + 1}}{{item.oldCustomerServiceName || '-'}} <span v-if="item.oldCustomerServiceDeptName">{{item.oldCustomerServiceDeptName}}</span></div>
</div>
<div style="color: blue">新客户经理:{{info.newCustomerServiceName || '-'}} <span v-if="info.newCustomerServiceDeptName">{{info.newCustomerServiceDeptName}}</span> </div>
<div>
申请理由:{{info.reason}}
</div>
</div>
</template>
<script>
import { handoverApprovalDetails} from "@/api/ecw/customer";
export default {
name: "customer-handover-details",
props: {
processId: {
type: [Number, String],
},
type: String,
},
data(){
return {
info:{
customerHandoverDetailDtoList:[]
}
}
},
mounted() {
this.handoverApprovalFn()
},
methods:{
handoverApprovalFn(){
handoverApprovalDetails({approvalId:this.processId}).then(r =>{
this.info =r.data
})
}
}
}
</script>
<style scoped>
</style>
...@@ -29,7 +29,7 @@ export default { ...@@ -29,7 +29,7 @@ export default {
}, },
computed:{ computed:{
getCustomerList(){ getCustomerList(){
let index = this.customerList.findIndex(item => item.id !== this.recommended[0]) let index = this.customerList.findIndex(item => item.id === this.recommended[0]?.id)
if(index > -1) return this.customerList if(index > -1) return this.customerList
else return [...this.customerList,...this.recommended] else return [...this.customerList,...this.recommended]
} }
...@@ -50,7 +50,6 @@ export default { ...@@ -50,7 +50,6 @@ export default {
}, },
watch:{ watch:{
value(val){ value(val){
console.log(val,'val')
this.customer = val; this.customer = val;
if(!(this.customerList.some(i => i.id === val)) && val !== undefined){ if(!(this.customerList.some(i => i.id === val)) && val !== undefined){
getCustomerList({ids:val}).then(r => { getCustomerList({ids:val}).then(r => {
......
...@@ -45,7 +45,7 @@ ...@@ -45,7 +45,7 @@
<el-form-item :label="$t('出货渠道')" prop="transportType"> <el-form-item :label="$t('出货渠道')" prop="transportType">
<!-- <dict-selector :type="DICT_TYPE.ECW_CUSTOMER_TRANSPORT_TYPE" form-type="checkbox" multiple v-model="form.transportType"></dict-selector>--> <!-- <dict-selector :type="DICT_TYPE.ECW_CUSTOMER_TRANSPORT_TYPE" form-type="checkbox" multiple v-model="form.transportType"></dict-selector>-->
<el-checkbox-group v-model="form.transportType"> <el-checkbox-group v-model="form.transportType">
<el-checkbox v-for="item in getDictDatas(DICT_TYPE.ECW_CUSTOMER_TRANSPORT_TYPE)" :key="item.value" :label="item.value" :disabled="item.value == 4">{{item.label}}</el-checkbox> <el-checkbox v-for="item in getDictDatas(DICT_TYPE.ECW_CUSTOMER_TRANSPORT_TYPE)" :key="item.value" :label="item.value" :disabled="[3,4].includes(+item.value)">{{item.label}}</el-checkbox>
</el-checkbox-group> </el-checkbox-group>
</el-form-item> </el-form-item>
</el-col> </el-col>
...@@ -60,7 +60,7 @@ ...@@ -60,7 +60,7 @@
<!-- </el-form-item>--> <!-- </el-form-item>-->
<el-form-item :label="$t('常用提货网点')" prop="remarks"> <el-form-item :label="$t('常用提货网点')" prop="remarks">
<el-select v-model="form.pickupPoint"> <el-select v-model="form.pickupPoint">
<el-option v-for="item in serviceNetworkList " :value="item.id" :label="isChinese ? item.titleZh : item.titleEn "></el-option> <el-option v-for="item in getNodeLists " :value="item.id" :label="isChinese ? item.titleZh : item.titleEn "></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
...@@ -98,13 +98,13 @@ ...@@ -98,13 +98,13 @@
<el-form-item :label="$t('主营类别')" prop="productType"> <el-form-item :label="$t('主营类别')" prop="productType">
<el-row :gutter="10"> <el-row :gutter="10">
<el-col :span="11"> <el-col :span="11">
<el-select v-model="form.productType" :placeholder="$t('请选择产品类别')" @change="form.productId = ''"> <el-select @change="change" v-model="form.productType" :placeholder="$t('请选择产品类别')">
<el-option :label="item.titleZh" :value="item.id" v-for="(item) in productTypeList" :key="item.id"/> <el-option :label="item.titleZh" :value="item.id" v-for="(item) in productTypeList" :key="item.id"/>
</el-select> </el-select>
</el-col> </el-col>
<el-col :span="11"> <el-col :span="11">
<el-select v-model="form.productId" :placeholder="$t('请选择')"> <el-select v-model="form.productId" :placeholder="$t('请选择')">
<el-option :label="item.titleZh" :value="parseInt(item.id)" v-for="(item) in productListFilter" :key="item.id"/> <el-option :label="item.titleZh" :value="parseInt(item.id)" v-for="(item) in productList" :key="item.id"/>
</el-select> </el-select>
</el-col> </el-col>
</el-row> </el-row>
...@@ -193,7 +193,11 @@ ...@@ -193,7 +193,11 @@
<el-switch v-model="form.isShowTidanPrice"></el-switch> <el-switch v-model="form.isShowTidanPrice"></el-switch>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12">
<el-form-item :label="$t('询盘信息')">
<el-input show-word-limit v-model="form.inquiry" :rows="3" type="textarea" :maxlength="500"></el-input>
</el-form-item>
</el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item :label="$t('到仓确认')" prop="arrivalConfirm"> <el-form-item :label="$t('到仓确认')" prop="arrivalConfirm">
<el-switch v-model="form.arrivalConfirm" :active-value="1" :inactive-value="0" /> <el-switch v-model="form.arrivalConfirm" :active-value="1" :inactive-value="0" />
...@@ -358,12 +362,17 @@ ...@@ -358,12 +362,17 @@
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column
width="260px"
prop="email" prop="email"
:label="$t('邮箱')" :label="$t('邮箱')"
> >
<template v-slot="{row}"> <template v-slot="{row}">
<el-form-item label=""> <el-form-item v-for="(item, index) in row.email" :key="index" label="">
<el-input v-model="row.email" :placeholder="$t('请输入邮箱')" size="mini"/> <div style="display: flex;align-items: center;">
<el-input v-model="row.email[index]" :placeholder="$t('请输入邮箱')" size="mini"/>
<el-button @click="deleteEmail(row.email,index)" v-if="row.email.length !== 1" style="height:25px;margin-left: 5px" type="danger" size="mini">删除</el-button>
<el-button @click="addEmail(row.email)" style="height: 25px;margin-left: 5px" v-if="index === row.email.length -1 && row.email.length < 5" size="mini" type="primary">添加</el-button>
</div>
</el-form-item> </el-form-item>
</template> </template>
</el-table-column> </el-table-column>
...@@ -592,19 +601,19 @@ export default { ...@@ -592,19 +601,19 @@ export default {
this.getCustomer(this.customerId).then(() => { this.getCustomer(this.customerId).then(() => {
getCustomerContactsListByCustomer({customerId: customerId}).then(r => { getCustomerContactsListByCustomer({customerId: customerId}).then(r => {
this.form.customerContacts = r.data this.form.customerContacts = r.data
let list = this.form.customerContacts.map(item => item.userid); this.form.customerContacts.forEach(item => {
if(list.length >0){ if(item.email){
memberUserList({ids:list.join(',')}).then(r=>{ item.email = item.email.split(',')
this.selectMemberList = r.data }else {
}) item.email = [""]
} }
})
})
if(this.form.promoter){ if(this.form.promoter){
getCustomerList({ids:this.form.promoter}).then(r => { getCustomerList({ids:this.form.promoter}).then(r => {
this.recommended = r.data; this.recommended = r.data;
}) })
} }
})
// 打开重泡货开关 // 打开重泡货开关
if(this.form.weightUnit){ if(this.form.weightUnit){
this.showZhong = true this.showZhong = true
...@@ -634,14 +643,12 @@ export default { ...@@ -634,14 +643,12 @@ export default {
} }
getNodeList().then(r => { getNodeList().then(r => {
this.nodeList = r.data this.getNodeLists = r.data
}) })
getProductTypeList().then(r => { getProductTypeList().then(r => {
this.productTypeList = r.data this.productTypeList = r.data
}) })
getProductList().then(r => {
this.productList = r.data
})
getTradeCityList({type: 1}).then(r => { getTradeCityList({type: 1}).then(r => {
this.importCityList = r.data.filter(item => item.type === '1') this.importCityList = r.data.filter(item => item.type === '1')
}) })
...@@ -657,13 +664,10 @@ export default { ...@@ -657,13 +664,10 @@ export default {
getCountryListAll().then(r => { getCountryListAll().then(r => {
this.countryList = r.data this.countryList = r.data
}) })
// 获取服务网点
getServiceNetwork().then(r =>{
this.serviceNetworkList = r.data
})
}, },
data(){ data(){
return { return {
getNodeLists:[],
isCustomerServiceConfirmed:false, isCustomerServiceConfirmed:false,
getDictDatas, getDictDatas,
DICT_TYPE, DICT_TYPE,
...@@ -718,6 +722,21 @@ export default { ...@@ -718,6 +722,21 @@ export default {
}, },
methods: { methods: {
addEmail(row){
row.push('')
},
deleteEmail(row, index){
row.splice(index, 1)
},
change(val){
this.form.productId = '';
this.getProductListFn(val);
},
getProductListFn(val){
getProductList({typeId:val}).then(r => {
this.productList = r.data
})
},
deleteBankData(index){ deleteBankData(index){
this.form.customerBanks.splice(index, 1); this.form.customerBanks.splice(index, 1);
}, },
...@@ -842,7 +861,10 @@ export default { ...@@ -842,7 +861,10 @@ export default {
} }
this.updateCustomerLines() this.updateCustomerLines()
const form = {...this.form, type: this.form.type?.join(','), transportType: (this.form.transportType || [])?.join(','), taxRate: Number(this.form.taxRate)} const form = {...this.form, type: this.form.type?.join(','), transportType: (this.form.transportType || [])?.join(','), taxRate: Number(this.form.taxRate)}
form.customerContacts = JSON.parse(JSON.stringify(this.form.customerContacts))
form.customerContacts.forEach(e =>{
e.email = [...e.email].join(',')
})
// 检查路线是否启用了但是没选择目的仓 // 检查路线是否启用了但是没选择目的仓
let errors = 0 let errors = 0
form.customerLines.forEach(line => { form.customerLines.forEach(line => {
...@@ -896,6 +918,7 @@ export default { ...@@ -896,6 +918,7 @@ export default {
/** 表单重置 */ /** 表单重置 */
reset() { reset() {
this.form = { this.form = {
inquiry:undefined,
id: undefined, id: undefined,
number: undefined, number: undefined,
name: undefined, name: undefined,
...@@ -949,6 +972,11 @@ export default { ...@@ -949,6 +972,11 @@ export default {
return getCustomer(id).then(response => { return getCustomer(id).then(response => {
console.log(response,'response') console.log(response,'response')
this.form = { ...this.form, ...response.data, id: this.customerId,transportType: response.data.transportType && response.data.transportType !== '' ? response.data.transportType.split(',') : [],customerBanks:response.data.customerBankBackVOList }; this.form = { ...this.form, ...response.data, id: this.customerId,transportType: response.data.transportType && response.data.transportType !== '' ? response.data.transportType.split(',') : [],customerBanks:response.data.customerBankBackVOList };
if(this.form.productType){
console.log('1231',this.form.productType)
this.getProductListFn(this.form.productType)
}
this.open = true; this.open = true;
this.title = this.$t('修改客户'); this.title = this.$t('修改客户');
this.getZhongPao() this.getZhongPao()
...@@ -969,7 +997,7 @@ export default { ...@@ -969,7 +997,7 @@ export default {
"areaCode": "", "areaCode": "",
// "customerId": 0,q // "customerId": 0,q
"department": "", "department": "",
"email": "", "email": [''],
"isDefault": this.form.customerContacts.length === 0 ? 1 : 0, "isDefault": this.form.customerContacts.length === 0 ? 1 : 0,
"name": "", "name": "",
"phoneNew": "", "phoneNew": "",
......
...@@ -68,7 +68,8 @@ ...@@ -68,7 +68,8 @@
<!-- 操作工具栏 --> <!-- 操作工具栏 -->
<el-row :gutter="10" class="mb8"> <el-row :gutter="10" class="mb8">
<el-col :span="1.5"> <el-col :span="1.5">
<el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" <el-button v-if="path === '/customer/potential'" type="primary" plain icon="el-icon-plus" size="mini" @click="handleAddPotential">{{$t('新增潜在客户')}}</el-button>
<el-button v-else type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
v-hasPermi="[ selectAuthorityFn('ecw:customer:create')]">{{$t('新增')}}</el-button> v-hasPermi="[ selectAuthorityFn('ecw:customer:create')]">{{$t('新增')}}</el-button>
</el-col> </el-col>
<el-col :span="1.5" > <el-col :span="1.5" >
...@@ -87,6 +88,16 @@ ...@@ -87,6 +88,16 @@
<el-button :disabled="!selectCustomerList.length" @click="setChangeCustomerAir(false)" v-if="$route.path === '/customer/customer'" type="primary" plain size="mini" :loading="exportLoading" <el-button :disabled="!selectCustomerList.length" @click="setChangeCustomerAir(false)" v-if="$route.path === '/customer/customer'" type="primary" plain size="mini" :loading="exportLoading"
v-hasPermi="['ecw:customer:transport']">{{$t('设为非空运客户')}}</el-button> v-hasPermi="['ecw:customer:transport']">{{$t('设为非空运客户')}}</el-button>
</el-col> </el-col>
<el-col :span="1.5">
<el-button v-hasPermi="['ecw:customer:fcl']" :disabled="!selectCustomerList.length" @click="setFullContainerLoad(true)" v-if="$route.path === '/customer/customer'" type="primary" plain size="mini" :loading="exportLoading">{{$t('设置海运整柜客户')}}</el-button>
</el-col>
<el-col :span="1.5">
<el-button v-hasPermi="['ecw:customer:create-potential']" :disabled="!selectCustomerList.length" @click="setFullContainerLoad(false)" v-if="$route.path === '/customer/customer'" type="primary" plain size="mini" :loading="exportLoading"
>{{$t('设置海运非整柜客户')}}</el-button>
</el-col>
<el-col :span="1.5">
<el-button v-has-permi="['ecw:customer:fcl-mistake']" v-if="path === '/customer/customer'" type="primary" plain icon="el-icon-plus" size="mini" @click="handleAddPotential">{{$t('新增潜在客户')}}</el-button>
</el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
</el-row> </el-row>
...@@ -124,7 +135,10 @@ ...@@ -124,7 +135,10 @@
<el-table-column :label="$t('主联系人')" prop="defaultContactName"></el-table-column> <el-table-column :label="$t('主联系人')" prop="defaultContactName"></el-table-column>
<el-table-column :label="$t('主联系方式')" prop="defaultContactPhone"> <el-table-column :label="$t('主联系方式')" prop="defaultContactPhone">
<template v-slot="{row}"> <template v-slot="{row}">
+{{row.defaultContactPhone}} +{{row.defaultContactPhone}} <br/>
<contacts :id="row.id" >
<el-button v-if="$route.path === '/customer/customer'" type="text">更多</el-button>
</contacts>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('创建时间')" align="center" prop="createTime" width="180"> <el-table-column :label="$t('创建时间')" align="center" prop="createTime" width="180">
...@@ -512,13 +526,24 @@ ...@@ -512,13 +526,24 @@
<customer-follow-list :customer-id="customerId" :id="customerId" ref="CustomerFollowList"></customer-follow-list> <customer-follow-list :customer-id="customerId" :id="customerId" ref="CustomerFollowList"></customer-follow-list>
<customer-complaints :customer-id="customerId" ref="customerComplaints"></customer-complaints> <customer-complaints :customer-id="customerId" ref="customerComplaints"></customer-complaints>
<transfer-customer :show.sync="transferShow" :customer-ids.sync="selectCustomerList"></transfer-customer> <transfer-customer :show.sync="transferShow" :customer-ids.sync="selectCustomerList"></transfer-customer>
<add-potential-custom ref="potentialCustom" @change="getList" ></add-potential-custom>
</div> </div>
</template> </template>
<script> <script>
import { import {
createCustomer, updateCustomer, deleteCustomer, getCustomer, createCustomer,
getCustomerPage, exportCustomerExcel, testEnterToOpenSea, getCustomerDeptPage, changeCustomerAir updateCustomer,
deleteCustomer,
getCustomer,
getCustomerPage,
exportCustomerExcel,
testEnterToOpenSea,
getCustomerDeptPage,
changeCustomerAir,
getPotential,
setChangeCustomerFcl
} from "@/api/ecw/customer"; } from "@/api/ecw/customer";
import { getDictDatas, DICT_TYPE } from '@/utils/dict'; import { getDictDatas, DICT_TYPE } from '@/utils/dict';
import {CommonStatusEnum} from '@/utils/constants' import {CommonStatusEnum} from '@/utils/constants'
...@@ -533,10 +558,14 @@ import { getCountryListAll } from '@/api/ecw/country' ...@@ -533,10 +558,14 @@ import { getCountryListAll } from '@/api/ecw/country'
import {getCreditPage} from "@/api/customer/credit"; import {getCreditPage} from "@/api/customer/credit";
import transferCustomer from "@/views/ecw/customer/transferCustomer"; import transferCustomer from "@/views/ecw/customer/transferCustomer";
import Template from "@/views/cms/template/index.vue"; import Template from "@/views/cms/template/index.vue";
import AddPotentialCustom from "@/views/ecw/customer/addPotentialCustom.vue";
import Contacts from "@/views/ecw/customer/components/contacts.vue";
export default { export default {
name: "EcwCustomerIndex", name: "EcwCustomerIndex",
components: { components: {
Contacts,
AddPotentialCustom,
Template, Template,
upload, upload,
CustomerFollowList, CustomerFollowList,
...@@ -604,6 +633,9 @@ export default { ...@@ -604,6 +633,9 @@ export default {
}; };
}, },
computed:{ computed:{
path(){
return this.$route.path
},
channel(){ channel(){
return (val)=>{ return (val)=>{
return !!val ? this.getDictDatas(this.DICT_TYPE.ECW_CUSTOMER_TRANSPORT_TYPE).filter(i => (val.split(',') || []).includes(i.value)).map(i => this.isChinese ? i.label : i.labelEn ).join('') :'' return !!val ? this.getDictDatas(this.DICT_TYPE.ECW_CUSTOMER_TRANSPORT_TYPE).filter(i => (val.split(',') || []).includes(i.value)).map(i => this.isChinese ? i.label : i.labelEn ).join('') :''
...@@ -642,9 +674,6 @@ export default { ...@@ -642,9 +674,6 @@ export default {
this.creditList = r.data.list this.creditList = r.data.list
}) })
this.getList(); this.getList();
// getNodeList().then(r => {
// this.nodeList = r.data
// })
listServiceUser().then(r=>{ listServiceUser().then(r=>{
this.customerServiceList = r.data; this.customerServiceList = r.data;
}) })
...@@ -656,6 +685,19 @@ export default { ...@@ -656,6 +685,19 @@ export default {
this.getList(); this.getList();
}, },
methods: { methods: {
// 设置整柜
setFullContainerLoad(isFcl){
setChangeCustomerFcl({
"customerIdList": this.selectCustomerList,
isFcl
}).then(r =>{
if(r.code === 0){
this.$message.success(isFcl ? '设置客户为海运整柜成功!' : '设置客户为非海运整柜成功!')
this.selectCustomerList = []
this.getList()
}
})
},
// 设置空运客户 // 设置空运客户
setChangeCustomerAir(isAir){ setChangeCustomerAir(isAir){
changeCustomerAir({ changeCustomerAir({
...@@ -709,6 +751,9 @@ export default { ...@@ -709,6 +751,9 @@ export default {
case '/customer/department-customers': case '/customer/department-customers':
getCustomerDeptPage(params).then(this.setData); getCustomerDeptPage(params).then(this.setData);
break; break;
case '/customer/potential':
getPotential(params).then(this.setData)
break;
} }
}, },
...@@ -719,6 +764,10 @@ export default { ...@@ -719,6 +764,10 @@ export default {
// this.open = true; // this.open = true;
// this.title = this.$t("添加客户"); // this.title = this.$t("添加客户");
}, },
// 新增潜在客户
handleAddPotential(){
this.$refs.potentialCustom.dialogTableVisible = true;
},
/** 删除按钮操作 */ /** 删除按钮操作 */
handleDelete(row) { handleDelete(row) {
const id = row.id; const id = row.id;
......
...@@ -7,8 +7,8 @@ ...@@ -7,8 +7,8 @@
<div> <div>
<el-button type="primary" size="small" v-has-permi="['ecw:customer:query-edit']" @click="$router.push('/customer/edit/' + id)">{{$t('编辑')}}</el-button> <el-button type="primary" size="small" v-has-permi="['ecw:customer:query-edit']" @click="$router.push('/customer/edit/' + id)">{{$t('编辑')}}</el-button>
<el-button v-has-permi="['ecw:customer:query-quoted-price']" @click="$router.push('/offer/create')" type="primary" size="small">{{$t('报价')}}</el-button> <el-button v-has-permi="['ecw:customer:query-quoted-price']" @click="$router.push('/offer/create')" type="primary" size="small">{{$t('报价')}}</el-button>
<el-button v-has-permi="['ecw:customer:query-follow-up']" type="primary" size="small" @click="$refs['customerFollow'].customerFollow.dialogVisible = true">{{$t('跟进')}}</el-button> <el-button v-has-permi="['ecw:customer:query-follow-up']" type="primary" size="small" @click="customerFollowFn('follow')">{{$t('跟进')}}</el-button>
<el-button v-has-permi="['ecw:customer:query-customer-complaint']" type="primary" size="small" @click="$refs['customerComplaint'].handleAdd()">{{$t('客诉')}}</el-button> <el-button v-has-permi="['ecw:customer:query-customer-complaint']" type="primary" size="small" @click="customerFollowFn('complain')">{{$t('客诉')}}</el-button>
<el-button v-hasPermi="['ecw:customer:query-delete']" type="danger" size="small" @click="deleteCustomerFn()">{{$t('删除')}}</el-button> <el-button v-hasPermi="['ecw:customer:query-delete']" type="danger" size="small" @click="deleteCustomerFn()">{{$t('删除')}}</el-button>
</div> </div>
</div> </div>
...@@ -29,7 +29,7 @@ ...@@ -29,7 +29,7 @@
<el-descriptions-item :label="$t('客户等级')">{{ getDictDataLabel(DICT_TYPE.CUSTOMER_LEVEL, customer.level) }}</el-descriptions-item> <el-descriptions-item :label="$t('客户等级')">{{ getDictDataLabel(DICT_TYPE.CUSTOMER_LEVEL, customer.level) }}</el-descriptions-item>
<el-descriptions-item :label="$t('信用等级')">{{isChinese ? customer.creditLevelNameZh :customer.creditLevelNameEn }}</el-descriptions-item> <el-descriptions-item :label="$t('信用等级')">{{isChinese ? customer.creditLevelNameZh :customer.creditLevelNameEn }}</el-descriptions-item>
<el-descriptions-item :label="$t('国家')">{{ isChinese ? country.nameZh : country.nameEn }}</el-descriptions-item> <el-descriptions-item :label="$t('国家')">{{$l(customer,'countryName')}}{{customer.countryName}}</el-descriptions-item>
<!-- <el-descriptions-item :label="$t('业务员')">{{ customer }}</el-descriptions-item>--> <!-- <el-descriptions-item :label="$t('业务员')">{{ customer }}</el-descriptions-item>-->
<el-descriptions-item :label="$t('客户来源')">{{ getDictDataLabel(DICT_TYPE.CUSTOMER_SOURCE, customer.source) }}</el-descriptions-item> <el-descriptions-item :label="$t('客户来源')">{{ getDictDataLabel(DICT_TYPE.CUSTOMER_SOURCE, customer.source) }}</el-descriptions-item>
<el-descriptions-item :label="$t('客户类别')"> <el-descriptions-item :label="$t('客户类别')">
...@@ -37,17 +37,19 @@ ...@@ -37,17 +37,19 @@
</el-descriptions-item> </el-descriptions-item>
<!-- <el-descriptions-item :label="$t('联系方式')">{{ customer }}</el-descriptions-item>--> <!-- <el-descriptions-item :label="$t('联系方式')">{{ customer }}</el-descriptions-item>-->
<el-descriptions-item :label="$t('推介人')">{{ customer.promoterName }}</el-descriptions-item> <el-descriptions-item :label="$t('推介人')">{{ customer.promoterName }}</el-descriptions-item>
<el-descriptions-item :label="$t('客户经理')">{{customerService }}</el-descriptions-item> <el-descriptions-item :label="$t('客户经理')">{{customer.customerServiceName }}</el-descriptions-item>
<el-descriptions-item :label="$t('公司名称')">{{ customer.company }}</el-descriptions-item> <el-descriptions-item :label="$t('公司名称')">{{ customer.company }}</el-descriptions-item>
<el-descriptions-item :label="$t('公司英文名称')">{{ customer.companyEn }}</el-descriptions-item> <el-descriptions-item :label="$t('公司英文名称')">{{ customer.companyEn }}</el-descriptions-item>
<el-descriptions-item :label="$t('联系地址')">{{ customer.address }}</el-descriptions-item> <el-descriptions-item :label="$t('联系地址')">{{ customer.address }}</el-descriptions-item>
<el-descriptions-item :label="$t('创建时间')">{{ parseTime(customer.createTime) }}</el-descriptions-item> <el-descriptions-item :label="$t('创建时间')">{{ parseTime(customer.createTime) }}</el-descriptions-item>
<el-descriptions-item :label="$t('创建人')">{{ customer.founderName }}</el-descriptions-item> <el-descriptions-item :label="$t('创建人')">{{ customer.founderName }}</el-descriptions-item>
<el-descriptions-item :label="$t('状态')">{{ getDictDataLabel(DICT_TYPE.CUSTOMER_STATUS, customer.status) }}</el-descriptions-item> <el-descriptions-item :label="$t('状态')">{{ getDictDataLabel(DICT_TYPE.CUSTOMER_STATUS, customer.status)}}</el-descriptions-item>
<el-descriptions-item :label="$t('主营类别')">{{ productType }}</el-descriptions-item> <el-descriptions-item :label="$t('主营类别')">{{ $l(customer,'productTypeName') }}</el-descriptions-item>
<el-descriptions-item :label="$t('常提货网点')">{{ pickupPoint }}</el-descriptions-item> <el-descriptions-item :label="$t('常提货网点')">{{ $l(customer,'pickupPointName') }}</el-descriptions-item>
<el-descriptions-item :label="$t('图片')"> <el-descriptions-item :label="$t('图片')">
<el-image v-show="!!customer.picture" :src="customer.picture" style="width: 100px;height: 100px"></el-image> <el-image v-if="customer.picture" :src="customer.picture" style="width: 100px;height: 100px">
<span slot="error">加载失败</span>
</el-image>
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item :label="$t('备注')">{{ customer.remarks }}</el-descriptions-item> <el-descriptions-item :label="$t('备注')">{{ customer.remarks }}</el-descriptions-item>
<el-descriptions-item :label="$t('业绩类型')">{{ customer.isNew ?$t('新客户') : $t('老客户') }}</el-descriptions-item> <el-descriptions-item :label="$t('业绩类型')">{{ customer.isNew ?$t('新客户') : $t('老客户') }}</el-descriptions-item>
...@@ -92,7 +94,7 @@ ...@@ -92,7 +94,7 @@
:label="$t('联系方式')" :label="$t('联系方式')"
> >
<template v-slot="{row}"> <template v-slot="{row}">
{{ row.areaCode + row.phoneNew }} +{{ row.areaCode}} {{row.phoneNew}}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column
...@@ -303,10 +305,10 @@ ...@@ -303,10 +305,10 @@
<pagination @pagination="getInfoListOfferPage" :page.sync="infoListOfferFrom.pageNo" :limit.sync="infoListOfferFrom.pageSize" :total="infoListOfferTotal" ></pagination> <pagination @pagination="getInfoListOfferPage" :page.sync="infoListOfferFrom.pageNo" :limit.sync="infoListOfferFrom.pageSize" :total="infoListOfferTotal" ></pagination>
</el-tab-pane> </el-tab-pane>
<el-tab-pane name="follow" :label="$t('跟进')"> <el-tab-pane name="follow" :label="$t('跟进')">
<customer-follow customerQuery ref="customerFollow" :id="id" :customer-id="id"></customer-follow> <customer-follow v-if="activeName === 'follow'" customerQuery ref="customerFollow" :id="id" :customer-id="id"></customer-follow>
</el-tab-pane> </el-tab-pane>
<el-tab-pane name="complain" :label="$t('客户投诉')"> <el-tab-pane name="complain" :label="$t('客户投诉')">
<customer-complaint ref="customerComplaint" :customer-id="id" hidden-search></customer-complaint> <customer-complaint v-if="activeName === 'complain'" ref="customerComplaint" :customer-id="id" hidden-search></customer-complaint>
</el-tab-pane> </el-tab-pane>
<el-tab-pane name="bill" :label="$t('账单')"> <el-tab-pane name="bill" :label="$t('账单')">
<el-table style="width: 100%" :data="infoListReceiptList"> <el-table style="width: 100%" :data="infoListReceiptList">
...@@ -529,38 +531,31 @@ export default { ...@@ -529,38 +531,31 @@ export default {
getCreditRulePage({page:1,rows:999,type:2}).then(r => { getCreditRulePage({page:1,rows:999,type:2}).then(r => {
this.creditTypeList = r.data.list this.creditTypeList = r.data.list
}) })
getNodeList().then(r => { // getNodeList().then(r => {
this.nodeList = r.data // this.nodeList = r.data
}) // })
getCustomer(this.id).then(response => { getCustomer(this.id).then(response => {
this.customer = { ...this.customer, ...response.data } this.customer = { ...this.customer, ...response.data }
console.log( this.customer,'this.customer') console.log( this.customer,'this.customer')
getCustomerContactsListByCustomer({customerId: this.id}).then(r => { getCustomerContactsListByCustomer({customerId: this.id}).then(r => {
this.customerContacts = r.data this.customerContacts = r.data
let list = this.customerContacts.map(r => r.userid) let list = this.customerContacts.filter(r => r.userid)
memberUserList({ids:list.join(',')}).then(r => { if(list.length > 0){
memberUserList({ids:list.map(i=>i.userid).join(',')}).then(r => {
this.memberList = r.data this.memberList = r.data
}) })
}
}) })
getCountry(this.customer.country ? this.customer.country : 0 ).then(r => {
this.country = r.data
})
})
getProductTypeList().then(r => {
this.productTypeList = r.data
}) })
getCustomerSelect({pageSize:1000,pageNo:1}).then(r => { // getCustomerSelect({pageSize:1000,pageNo:1}).then(r => {
this.customerSelect = r.data.list // this.customerSelect = r.data.list
}) // })
listServiceUser().then(r => {
this.serviceUserList = r.data
})
// this.getBrankByCustomerList()//品牌授权 // this.getBrankByCustomerList()//品牌授权
this.getCustomerGrade() // this.getCustomerGrade()
// this.creditLogPage()//等级日志 // this.creditLogPage()//等级日志
this.getorderList()//订单 this.getorderList()//订单
// this.getInfoListOfferPage()//报价 // this.getInfoListOfferPage()//报价
...@@ -716,22 +711,16 @@ export default { ...@@ -716,22 +711,16 @@ export default {
isChinese(){ isChinese(){
return this.$i18n.locale === 'zh_CN' return this.$i18n.locale === 'zh_CN'
}, },
productType(){
const productType = this.productTypeList.find(p => p.id === parseInt(this.customer.productType))
return productType ? productType.titleZh : ''
},
pickupPoint(){ pickupPoint(){
const pickupPoint = this.nodeList.find(p => p.id === parseInt(this.customer.pickupPoint)) const pickupPoint = this.nodeList.find(p => p.id === parseInt(this.customer.pickupPoint))
return pickupPoint ? pickupPoint.titleZh : '' return pickupPoint ? pickupPoint.titleZh : ''
}, },
promoter() { // promoter() {
return this.customerSelect.find(e => e.id === this.customer.promoter)?.name || '' // return this.customerSelect.find(e => e.id === this.customer.promoter)?.name || ''
}, // },
customerService() {
return this.serviceUserList.find(e => e.id === this.customer.customerService)?.nickname || ''
},
id() { id() {
return this.customerId ? parseInt(this.customerId) : undefined return parseInt(this.$route.params.customerId)
}, },
creditScoreCalculation(){ creditScoreCalculation(){
return (val)=>{ return (val)=>{
...@@ -745,6 +734,16 @@ export default { ...@@ -745,6 +734,16 @@ export default {
} }
}, },
methods:{ methods:{
customerFollowFn(val){
this.activeName = val
this.$nextTick(()=>{
if(val === 'follow'){
this.$refs['customerFollow'].customerFollow.dialogVisible = true;
}else {
this.$refs['customerComplaint'].handleAdd()
}
})
},
checkPermi, checkPermi,
userIdFormatter(row, column, cellValue){ userIdFormatter(row, column, cellValue){
const member = this.memberList.find(e => e.id === cellValue) const member = this.memberList.find(e => e.id === cellValue)
......
...@@ -6,8 +6,12 @@ ...@@ -6,8 +6,12 @@
width="30%"> width="30%">
<div style="width: 100%;min-height: 200px;text-align: center"> <div style="width: 100%;min-height: 200px;text-align: center">
<el-select filterable v-model="service"> <el-select filterable v-model="service">
<el-option v-for="(item,index) in customerServiceList" :key="index" :label="item.nickname" :value="item.id"></el-option> <el-option v-for="(item,index) in customerServiceList" :key="index" :label="item.deptName ? item.nickname + `(${item.deptName})` : item.nickname " :value="item.id"></el-option>
</el-select> </el-select>
<div style="display: flex;margin-top: 20px;">
<label style="width:100px;" >申请理由</label>
<el-input v-model="textarea" type="textarea"></el-input>
</div>
</div> </div>
<span slot="footer" class="dialog-footer"> <span slot="footer" class="dialog-footer">
<el-button @click="$emit('update:show',false)" >{{$t('取 消')}}</el-button> <el-button @click="$emit('update:show',false)" >{{$t('取 消')}}</el-button>
...@@ -18,7 +22,7 @@ ...@@ -18,7 +22,7 @@
<script> <script>
import {listServiceUser} from "@/api/system/user"; import {listServiceUser} from "@/api/system/user";
import {handOverCustomer} from "@/api/ecw/customer"; import {handoverApproval, handOverCustomer} from "@/api/ecw/customer";
export default { export default {
name: "transferCustomer", name: "transferCustomer",
...@@ -37,6 +41,7 @@ export default { ...@@ -37,6 +41,7 @@ export default {
}, },
computed:{ computed:{
getCustomerIds(){ getCustomerIds(){
console.log(this.customerIds,'this.customerIds')
if(this.customerIds instanceof Array) return this.customerIds if(this.customerIds instanceof Array) return this.customerIds
else return this.customerIds.split(',') else return this.customerIds.split(',')
} }
...@@ -45,6 +50,7 @@ export default { ...@@ -45,6 +50,7 @@ export default {
return { return {
customerServiceList:[], customerServiceList:[],
service:'', service:'',
textarea:''
} }
}, },
methods:{ methods:{
...@@ -52,13 +58,16 @@ export default { ...@@ -52,13 +58,16 @@ export default {
if(!this.service){ if(!this.service){
return this.$message.warning(this.$t('请选择客户经理!')); return this.$message.warning(this.$t('请选择客户经理!'));
} }
handOverCustomer({ handoverApproval({
customerServiceId:this.service, customerServiceId:this.service,
customerIdList:this.getCustomerIds customerIdList:this.getCustomerIds,
reason:this.textarea
}).then(r=>{ }).then(r=>{
if(r.code === 0){ if(r.code === 0){
this.$emit('update:show',false) this.$emit('update:show',false)
this.$emit('update:customerIds',[]) this.$emit('update:customerIds',[])
this. service = '';
this.textarea = '';
this.$message.success(this.$t('用户批量转移成功!')) this.$message.success(this.$t('用户批量转移成功!'))
} }
}) })
......
...@@ -416,9 +416,13 @@ export default { ...@@ -416,9 +416,13 @@ export default {
this.list = response.data.list; this.list = response.data.list;
this.total = response.data.total; this.total = response.data.total;
this.loading = false; this.loading = false;
getCustomerList({ids:this.list.map(i => i.customerId).join(',')}).then(r => { let list = []
list = this.list.filter(i => i.customerId)
if(list.length > 0){
getCustomerList({ids:list.map(i => i.customerId).join(',')}).then(r => {
this.customerSelect = r.data this.customerSelect = r.data
}) })
}
}); });
}, },
/** 取消按钮 */ /** 取消按钮 */
......
...@@ -344,7 +344,7 @@ ...@@ -344,7 +344,7 @@
<el-button @click="cancelHandOver">{{$t('取 消')}}</el-button> <el-button @click="cancelHandOver">{{$t('取 消')}}</el-button>
</div> </div>
</el-dialog> </el-dialog>
<transfer-customer :show.sync="openHandOver" :customer-ids.sync="handOverForm.customerIdList"></transfer-customer>
</div> </div>
</template> </template>
...@@ -363,6 +363,7 @@ import {CommonStatusEnum} from '@/utils/constants' ...@@ -363,6 +363,7 @@ import {CommonStatusEnum} from '@/utils/constants'
import {handOverCustomer} from "../../../api/ecw/customer"; import {handOverCustomer} from "../../../api/ecw/customer";
import {getCountryListAll} from "@/api/ecw/country"; import {getCountryListAll} from "@/api/ecw/country";
import {getCreditPage} from "@/api/customer/credit"; import {getCreditPage} from "@/api/customer/credit";
import transferCustomer from "@/views/ecw/customer/transferCustomer.vue";
...@@ -380,6 +381,7 @@ export default { ...@@ -380,6 +381,7 @@ export default {
}, },
}, },
components: { components: {
transferCustomer
}, },
data() { data() {
return { return {
...@@ -570,8 +572,9 @@ export default { ...@@ -570,8 +572,9 @@ export default {
}, },
/** 修改按钮操作 */ /** 修改按钮操作 */
handOver(row) { handOver(row) {
this.resetHandOverForm(); // this.resetHandOverForm();
this.openHandOver = true; this.openHandOver = true;
this.handOverForm.customerIdList = [row.id]; this.handOverForm.customerIdList = [row.id];
}, },
......
...@@ -411,9 +411,10 @@ export default { ...@@ -411,9 +411,10 @@ export default {
}, },
//分配客服 //分配客服
distribution(row){ distribution(row){
this.service = row.customerService; // this.service = row.customerService;
this.transferData = row; // this.transferData = row;
this.transferShow =true; this.selectCustomerList = [row.id]
this.batchTransferShow =true;
}, },
transferFn(){ transferFn(){
if(!this.service){ if(!this.service){
......
...@@ -102,7 +102,7 @@ import {getUnitList} from "@/api/ecw/unit" ...@@ -102,7 +102,7 @@ import {getUnitList} from "@/api/ecw/unit"
import { getCurrencyList } from '@/api/ecw/currency' import { getCurrencyList } from '@/api/ecw/currency'
import {getProductAttrList} from '@/api/ecw/productAttr' import {getProductAttrList} from '@/api/ecw/productAttr'
import Decimal from 'decimal.js' import Decimal from 'decimal.js'
import {getExceptionById} from '@/api/ecw/orderException' import {getExceptionDetailByBusinessId,getOrderExceptionChannelPriceList} from '@/api/ecw/orderException'
export default { export default {
name: 'NotShipingChannel', name: 'NotShipingChannel',
...@@ -147,6 +147,7 @@ export default { ...@@ -147,6 +147,7 @@ export default {
} }
}, },
async created(){ async created(){
await getUnitList().then(res => this.unitList = res.data)
await getCurrencyList().then(res => this.currencyList = res.data) await getCurrencyList().then(res => this.currencyList = res.data)
this.productAttrList = (await getProductAttrList()).data this.productAttrList = (await getProductAttrList()).data
if(this.id){ if(this.id){
...@@ -156,11 +157,12 @@ export default { ...@@ -156,11 +157,12 @@ export default {
methods:{ methods:{
Decimal, Decimal,
getData(){ getData(){
getExceptionById(this.id).then(res => { getExceptionDetailByBusinessId({businessId:this.id}).then(res => {
this.orderExceptionData = res.data this.orderExceptionData = res.data
if(res.data.orderId){ if(res.data.orderId){
getOrder(res.data.orderId).then(res => { getOrder(res.data.orderId).then(res => {
this.order = res.data this.order = res.data
this.getExceptionPriceList(res.data.orderId)
}) })
} }
}) })
...@@ -182,6 +184,25 @@ export default { ...@@ -182,6 +184,25 @@ export default {
this.channel = res.data this.channel = res.data
}) })
}, },
getExceptionPriceList(orderId){
let that = this
getOrderExceptionChannelPriceList({orderId:orderId,exceptionId:this.orderExceptionData.id,exceptionResultId:parseInt(that.id)}).then(res=>{
if(res.code==0&&res.data.length>0){
that.order.orderItemVOList.map(v=>{
var item = res.data.find(vs=>vs.orderItemId==v.orderItemId)
if(item){
v.oneSeaFreight = item.freightFee
v.seaFreightCurrency = item.freightCurrencyId
v.seaFreightVolume = item.freightUnitId
v.oneClearanceFreight = item.clearanceFee
v.clearanceFreightCurrency = item.clearanceCurrencyId
v.clearanceFreightVolume = item.clearanceUnitId
}
})
}
})
}
} }
} }
</script> </script>
......
...@@ -48,7 +48,7 @@ ...@@ -48,7 +48,7 @@
<label style="font-weight: 600; font-size: 5.5mm">{{item.destTitleEn}} </label> <label style="font-weight: 600; font-size: 5.5mm">{{item.destTitleEn}} </label>
</p> </p>
<p style=" padding: 0px; padding-top: 2.7mm; padding-bottom: 2.7mm; padding-left: 3mm; float: left; width: 29%; border-bottom: 0.2mm solid #333; text-align: center; line-height: 6mm; font-size: 4mm; text-transform: uppercase; margin: 0px; " > <p style=" padding: 0px; padding-top: 2.7mm; padding-bottom: 2.7mm; padding-left: 3mm; float: left; width: 29%; border-bottom: 0.2mm solid #333; text-align: center; line-height: 6mm; font-size: 4mm; text-transform: uppercase; margin: 0px; " >
LCL {{item.transportType}}
</p> </p>
<p style=" padding: 0px; padding-top: 2.7mm; padding-bottom: 2.7mm; padding-left: 4mm; float: left; border-left: 0.2mm solid #333; border-bottom: 0.2mm solid #333; text-align: center; line-height: 6mm; margin: 0px; font-size: 5mm; text-transform: uppercase; font-weight: 500; " > <p style=" padding: 0px; padding-top: 2.7mm; padding-bottom: 2.7mm; padding-left: 4mm; float: left; border-left: 0.2mm solid #333; border-bottom: 0.2mm solid #333; text-align: center; line-height: 6mm; margin: 0px; font-size: 5mm; text-transform: uppercase; font-weight: 500; " >
{{item.inTime|parseTime('{y}-{m}-{d}')}} {{item.inTime|parseTime('{y}-{m}-{d}')}}
...@@ -119,7 +119,7 @@ export default { ...@@ -119,7 +119,7 @@ export default {
this.$set(this, 'tags', res.data) this.$set(this, 'tags', res.data)
// this.form.start = res.data[0].num // this.form.start = res.data[0].num
// 起始标签为入仓数 + 1 // 起始标签为入仓数 + 1
this.form.start = this.warehouseInNum + 1 this.form.start = (this.warehouseInNum || 0) + 1
this.form.end = res.data[res.data.length-1].num this.form.end = res.data[res.data.length-1].num
}) })
}, },
......
...@@ -71,7 +71,9 @@ ...@@ -71,7 +71,9 @@
<el-descriptions-item :label="$t('运输方式')" > <el-descriptions-item :label="$t('运输方式')" >
<dict-tag :type="DICT_TYPE.ECW_TRANSPORT_TYPE" :value="order.transportId" /> <dict-tag :type="DICT_TYPE.ECW_TRANSPORT_TYPE" :value="order.transportId" />
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item v-if="getDictData(DICT_TYPE.ECW_TRANSPORT_TYPE, order.transportId).cssClass == 'channel'":label="$t('出货渠道')" >{{channelName}}</el-descriptions-item> <el-descriptions-item v-if="getDictData(DICT_TYPE.ECW_TRANSPORT_TYPE, order.transportId).cssClass == 'channel'":label="$t('出货渠道')" >
{{order.channelName}}
</el-descriptions-item>
</el-descriptions> </el-descriptions>
</el-card> </el-card>
...@@ -404,7 +406,12 @@ ...@@ -404,7 +406,12 @@
</div> </div>
</el-col> </el-col>
<el-col :span="12" v-if="feeDetail.charging != 1"> <el-col :span="12" v-if="feeDetail.charging != 1">
<div>{{$t('清关费')}}</div> <div>
{{$t('清关费')}}
<template v-if="order.transportId == 3 || order.transportId == 4">
{{$t('来自{source}', {source: feeDetail.airClearanceSource + feeDetail.sourceName})}}
</template>
</div>
<div v-for="item in feeDetail.clearance"> <div v-for="item in feeDetail.clearance">
{{item.label}}: {{item.value}} {{item.label}}: {{item.value}}
<template v-if="item.currency"> <template v-if="item.currency">
...@@ -506,7 +513,7 @@ export default { ...@@ -506,7 +513,7 @@ export default {
currencyList: [], currencyList: [],
unitList:[], unitList:[],
feeList: [], feeList: [],
channelName: '/', channel: null,
region: '', region: '',
orderWarehouseIn: null, // 入仓详情 orderWarehouseIn: null, // 入仓详情
showWarehouseInItemId: null, // 当前显示的入仓 showWarehouseInItemId: null, // 当前显示的入仓
...@@ -564,7 +571,7 @@ export default { ...@@ -564,7 +571,7 @@ export default {
} }
}, },
'order.channelId'(){ 'order.channelId'(){
this.getChannel() // this.getChannel()
}, },
'order.consigneeVO'(val){ 'order.consigneeVO'(val){
if(!val) return '-' if(!val) return '-'
...@@ -687,7 +694,16 @@ export default { ...@@ -687,7 +694,16 @@ export default {
label: this.$t('价格更新时间'), label: this.$t('价格更新时间'),
value: parseTime(row.updateTime) value: parseTime(row.updateTime)
}) })
this.feeDetail = {freight, clearance, charging: row.charging, coupons: row.couponInfoVOList} this.feeDetail = {
freight,
clearance,
charging:
row.charging,
coupons: row.couponInfoVOList,
airClearanceSource: row.airClearanceSource == 1 ? this.$t('商品') : this.$t('渠道'), // 空运清关费来源:1 商品 2 渠道
airClearanceInfo: JSON.parse(row.airClearanceInfo), //空运清关费来源数据详情,
sourceName: row.airClearanceSource == 1 ? this.$l(row, 'prodTitle') : this.channelName
}
}, },
closeFeeDetail(){ closeFeeDetail(){
...@@ -717,12 +733,12 @@ export default { ...@@ -717,12 +733,12 @@ export default {
}) })
}) })
}, */ }, */
getChannel(){ /*getChannel(){
if(!this.order || !this.order.channelId || this.order.transportId == 1 || this.order.transportId == 2) return if(!this.order || !this.order.channelId || this.order.transportId == 1 || this.order.transportId == 2) return
getChannel(this.order.channelId).then(res => { getChannel(this.order.channelId).then(res => {
this.channelName = res.data.nameZh this.channel = res.data
}) })
}, },*/
loadFeeList(){ loadFeeList(){
getReceivableListByOrderId({id: this.orderId}).then(res => { getReceivableListByOrderId({id: this.orderId}).then(res => {
this.feeList = res.data this.feeList = res.data
......
...@@ -832,8 +832,8 @@ export default { ...@@ -832,8 +832,8 @@ export default {
} }
}, },
'form.transportId'(transportId, oldTransportId){ 'form.transportId'(transportId, oldTransportId){
// 海运拼柜给表单默认值 // 空运
if(this.form.transportId == 4){ if(this.form.transportId == 4 || this.form.transportId == 3){
this.$nextTick(() => { this.$nextTick(() => {
this.$set(this, 'form', Object.assign(this.form, { this.$set(this, 'form', Object.assign(this.form, {
doubleClear: 2, doubleClear: 2,
...@@ -854,8 +854,9 @@ export default { ...@@ -854,8 +854,9 @@ export default {
this.$set(this.form, 'channelId', null) this.$set(this.form, 'channelId', null)
} }
// 如果是专线空运默认目的港清关选择我司
if(transportId == 3){ if(transportId == 3){
// 如果是专线空运默认目的港清关选择我司
this.$set(this.form, 'portDestCustomsClear', 1) this.$set(this.form, 'portDestCustomsClear', 1)
} }
......
...@@ -632,9 +632,15 @@ export default { ...@@ -632,9 +632,15 @@ export default {
// 渠道列表,空运需要渠道筛选 // 渠道列表,空运需要渠道筛选
channelList:[], channelList:[],
// 编号搜索条件 // 编号搜索条件
noParam: {}, noParam: {
key: 'numberKey',
value: ''
},
// 商品搜索条件 // 商品搜索条件
prodParam: {} prodParam: {
key: 'prodKey',
value: ''
}
}; };
}, },
watch:{ watch:{
...@@ -877,6 +883,8 @@ export default { ...@@ -877,6 +883,8 @@ export default {
page: 1, page: 1,
rows: 10 rows: 10
} }
this.noParam.value = ''
this.prodParam.value = ''
this.dateFilter = [] this.dateFilter = []
this.handleQuery(); this.handleQuery();
}, },
......
...@@ -530,47 +530,47 @@ ...@@ -530,47 +530,47 @@
<dict-tag :type="DICT_TYPE.ECW_IS_BRAND" :value="scope.row.brandType"></dict-tag> <dict-tag :type="DICT_TYPE.ECW_IS_BRAND" :value="scope.row.brandType"></dict-tag>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('填单箱数')" prop="num" min-width="60" /> <el-table-column :label="$t('填单箱数')" align="center" prop="num" min-width="60" />
<!-- v2.0 入仓特性异常 --> <!-- v2.0 入仓特性异常 -->
<el-table-column :label="$t('填单特性')" prop="prodAttrIds" min-width="60"> <el-table-column :label="$t('填单特性')" align="center" prop="prodAttrIds" min-width="60">
<template slot-scope="scope"> <template slot-scope="scope">
{{getProdAtrr(scope.row.prodAttrIds)}} {{getProdAtrr(scope.row.prodAttrIds)}}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('入仓箱数')" min-width="60"> <el-table-column :label="$t('入仓箱数')" align="center" min-width="60">
<template slot-scope="scope"> <template slot-scope="scope">
{{scope.row.warehouseInInfoVO?scope.row.warehouseInInfoVO.cartonsNum:0}} {{scope.row.warehouseInInfoVO?scope.row.warehouseInInfoVO.cartonsNum:0}}
</template> </template>
</el-table-column> </el-table-column>
<!-- v2.0 入仓特性异常 --> <!-- v2.0 入仓特性异常 -->
<el-table-column :label="$t('入仓特性')" prop="num" min-width="60"> <el-table-column :label="$t('入仓特性')" align="center" prop="num" min-width="60">
<template slot-scope="scope"> <template slot-scope="scope">
{{scope.row.warehouseInInfoVO&&scope.row.warehouseInInfoVO.prodAttrIds?getProdAtrr(scope.row.warehouseInInfoVO.prodAttrIds):''}} {{scope.row.warehouseInInfoVO&&scope.row.warehouseInInfoVO.prodAttrIds?getProdAtrr(scope.row.warehouseInInfoVO.prodAttrIds):''}}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('方数')" prop="volume" min-width="30"> <el-table-column :label="$t('方数')" align="center" prop="volume" min-width="30">
<template slot-scope="scope"> <template slot-scope="scope">
{{scope.row.warehouseInInfoVO?scope.row.warehouseInInfoVO.volume:0}} {{scope.row.warehouseInInfoVO?scope.row.warehouseInInfoVO.volume:0}}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('重量')" prop="weight" min-width="30"> <el-table-column :label="$t('重量')" prop="weight" align="center" min-width="30">
<template slot-scope="scope"> <template slot-scope="scope">
{{scope.row.warehouseInInfoVO?scope.row.warehouseInInfoVO.weight:0}} {{scope.row.warehouseInInfoVO?scope.row.warehouseInInfoVO.weight:0}}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('数量')" prop="quantity" min-width="30"> <el-table-column :label="$t('数量')" prop="quantity" align="center" min-width="30">
<template slot-scope="scope"> <template slot-scope="scope">
{{scope.row.warehouseInInfoVO?scope.row.warehouseInInfoVO.quantityAll:0}} {{scope.row.warehouseInInfoVO?scope.row.warehouseInInfoVO.quantityAll:0}}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('货值')" prop="worth" min-width="30" /> <el-table-column :label="$t('货值')" prop="worth" align="center" min-width="30" />
<el-table-column :label="$t('运费/全包价')" prop="quantity" min-width="260" v-if="handlerParams.orderExceptionHandlerResult=='continue_channel'"> <el-table-column :label="$t('运费/全包价')" prop="quantity" align="center" min-width="260" v-if="handlerParams.orderExceptionHandlerResult=='continue_channel'">
<template slot-scope="scope" > <template slot-scope="scope" >
<div v-if="scope.row.charging ==1" class="channel"> <div v-if="scope.row.charging ==1" class="channel">
<!-- <span v-if="!scope.row.oneSeaFreight">{{$t('全包价')}}:{{$t('未报价')}}</span> --> <!-- <span v-if="!scope.row.oneSeaFreight">{{$t('全包价')}}:{{$t('未报价')}}</span> -->
<div class="channel"> <div class="channel">
<div style="width:80px">{{$t('全包价')}}:</div> <div style="width:80px">{{$t('全包价')}}:</div>
<div style="width:88%" class="channel"> <div style="width:88%" class="channel" v-if="orderExceptionData.orderExceptionStatus==0">
<inputor default2="0" v-model.number="scope.row.oneSeaFreight" type="number" :placeholder="$t('整数或者两位小数')" class="w100" /> <inputor default2="0" v-model.number="scope.row.oneSeaFreight" type="number" :placeholder="$t('整数或者两位小数')" class="w100" />
<selector v-model="scope.row.seaFreightCurrency" :options="currencyList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" /> <selector v-model="scope.row.seaFreightCurrency" :options="currencyList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" />
/ <selector v-model="scope.row.seaFreightVolume" :options="unitList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" /> / <selector v-model="scope.row.seaFreightVolume" :options="unitList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" />
...@@ -579,49 +579,57 @@ ...@@ -579,49 +579,57 @@
</div> </div>
<div v-else> <div v-else>
<!-- <span v-if="!scope.row.oneSeaFreight">{{$t('运费')}}:{{$t('未报价')}}</span> --> <!-- <span v-if="!scope.row.oneSeaFreight">{{$t('运费')}}:{{$t('未报价')}}</span> -->
<div class="channel"> <div class="channel" v-if="orderExceptionData.orderExceptionStatus==0">
<div style="width:80px">{{$t('运费')}}:</div> <div style="width:80px">{{$t('运费')}}:</div>
<div style="width:88%" class="channel"> <div style="width:88%" class="channel" >
<inputor default2="0" v-model.number="scope.row.oneSeaFreight" type="number" :placeholder="$t('整数或者两位小数')" class="w100" /> <inputor default2="0" v-model.number="scope.row.oneSeaFreight" type="number" :placeholder="$t('整数或者两位小数')" class="w100" />
<selector v-model="scope.row.seaFreightCurrency" :options="currencyList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" /> <selector v-model="scope.row.seaFreightCurrency" :options="currencyList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" />
/ <selector v-model="scope.row.seaFreightVolume" :options="unitList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" /> / <selector v-model="scope.row.seaFreightVolume" :options="unitList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" />
</div> </div>
</div> </div>
<div v-else class="channel">
<span v-if="!scope.row.oneSeaFreight">{{$t('运费')}}:{{$t('未报价')}}</span>
<span v-else>{{$t('全包价')}}:{{scope.row.oneSeaFreight}} {{currencyMap[scope.row.seaFreightCurrency]}} / {{unitMap[scope.row.seaFreightVolume]}}</span>
</div>
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('清关费')" prop="quantity" min-width="180" v-if="handlerParams.orderExceptionHandlerResult=='continue_channel'"> <el-table-column :label="$t('清关费')" prop="quantity" align="center" min-width="180" v-if="handlerParams.orderExceptionHandlerResult=='continue_channel'">
<template slot-scope="scope"> <template slot-scope="scope">
<div class="channel"> <div class="channel">
<!-- <span v-if="!scope.row.oneClearanceFreight">{{$t('未报价')}}</span> --> <!-- <span v-if="!scope.row.oneClearanceFreight">{{$t('未报价')}}</span> -->
<div class="channel"> <div class="channel" v-if="orderExceptionData.orderExceptionStatus==0">
<inputor default2="0" v-model.number="scope.row.oneClearanceFreight" type="number" :placeholder="$t('整数或者两位小数')" class="w100" /> <inputor default2="0" v-model.number="scope.row.oneClearanceFreight" type="number" :placeholder="$t('整数或者两位小数')" class="w100" />
<selector v-model="scope.row.clearanceFreightCurrency" :options="currencyList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" /> <selector v-model="scope.row.clearanceFreightCurrency" :options="currencyList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" />
/ <selector v-model="scope.row.clearanceFreightVolume" :options="unitList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" /> / <selector v-model="scope.row.clearanceFreightVolume" :options="unitList" :label-field="$l('title')" value-field="id" defaultable2 class="w100" />
</div> </div>
<div v-else>
<span v-if="!scope.row.oneClearanceFreight">{{$t('未报价')}}</span>
<span v-else>{{scope.row.oneClearanceFreight}} {{currencyMap[scope.row.clearanceFreightCurrency]}} / {{unitMap[scope.row.clearanceFreightVolume]}}</span>
</div>
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('运费/全包价')" prop="quantity" min-width="220" v-if="handlerParams.orderExceptionHandlerResult=='change_channel'"> <el-table-column :label="$t('运费/全包价')" prop="quantity" align="center" min-width="220" v-if="handlerParams.orderExceptionHandlerResult=='change_channel'">
<template slot-scope="scope" > <template slot-scope="scope" >
<div v-if="scope.row.charging ==1" class="channel"> <div v-if="scope.row.charging ==1" class="channel">
<span v-if="!scope.row.oneSeaFreight">{{$t('全包价')}}:{{$t('未报价')}}</span> <span v-if="!scope.row.oneSeaFreight">{{$t('全包价')}}:{{$t('未报价')}}</span>
<span v-else>{{$t('全包价')}}:{{scope.row.oneSeaFreight}} {{currencyMap[scope.row.seaFreightCurrency]}} / {{unitMap[scope.row.seaFreightVolume]}}</span> <span v-else>{{$t('全包价')}}:{{scope.row.oneSeaFreight}} {{currencyMap[scope.row.seaFreightCurrency]}} / {{unitMap[scope.row.seaFreightVolume]}}</span>
<el-button type="primary" plain @click="routeToPrice(scope.row,1)">{{!scope.row.oneSeaFreight?$t('报价'):$t('修改报价')}}</el-button> <el-button v-if="orderExceptionData.orderExceptionStatus==0" type="primary" plain @click="routeToPrice(scope.row,1)">{{!scope.row.oneSeaFreight?$t('报价'):$t('修改报价')}}</el-button>
</div> </div>
<div v-else class="channel"> <div v-else class="channel">
<span v-if="!scope.row.oneSeaFreight">{{$t('运费')}}:{{$t('未报价')}}</span> <span v-if="!scope.row.oneSeaFreight">{{$t('运费')}}:{{$t('未报价')}}</span>
<span v-else>{{$t('运费')}}:{{scope.row.oneSeaFreight}} {{currencyMap[scope.row.seaFreightCurrency]}} / {{unitMap[scope.row.seaFreightVolume]}}</span> <span v-else>{{$t('运费')}}:{{scope.row.oneSeaFreight}} {{currencyMap[scope.row.seaFreightCurrency]}} / {{unitMap[scope.row.seaFreightVolume]}}</span>
<el-button type="primary" plain @click="routeToPrice(scope.row,1)">{{!scope.row.oneSeaFreight?$t('报价'):$t('修改报价')}}</el-button> <el-button v-if="orderExceptionData.orderExceptionStatus==0" type="primary" plain @click="routeToPrice(scope.row,1)">{{!scope.row.oneSeaFreight?$t('报价'):$t('修改报价')}}</el-button>
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('清关费')" prop="quantity" min-width="260" v-if="handlerParams.orderExceptionHandlerResult=='change_channel'"> <el-table-column :label="$t('清关费')" prop="quantity" align="center" min-width="260" v-if="handlerParams.orderExceptionHandlerResult=='change_channel'">
<template slot-scope="scope"> <template slot-scope="scope">
<div class="channel"> <div class="channel">
<span v-if="!scope.row.oneClearanceFreight">{{$t('未报价')}}</span> <span v-if="!scope.row.oneClearanceFreight">{{$t('未报价')}}</span>
<span v-else>{{scope.row.oneClearanceFreight}} {{currencyMap[scope.row.clearanceFreightCurrency]}} / {{unitMap[scope.row.clearanceFreightVolume]}}</span> <span v-else>{{scope.row.oneClearanceFreight}} {{currencyMap[scope.row.clearanceFreightCurrency]}} / {{unitMap[scope.row.clearanceFreightVolume]}}</span>
<el-button type="primary" plain @click="routeToPrice(scope.row,2)">{{!scope.row.oneClearanceFreight?$t('报价'):$t('修改报价')}}</el-button> <el-button v-if="orderExceptionData.orderExceptionStatus==0" type="primary" plain @click="routeToPrice(scope.row,2)">{{!scope.row.oneClearanceFreight?$t('报价'):$t('修改报价')}}</el-button>
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
...@@ -688,7 +696,7 @@ ...@@ -688,7 +696,7 @@
import {getOrder} from '@/api/ecw/order' import {getOrder} from '@/api/ecw/order'
import FilePreview from '@/components/FilePreview' import FilePreview from '@/components/FilePreview'
import { getCurrencyList } from '@/api/ecw/currency' import { getCurrencyList } from '@/api/ecw/currency'
import {getExceptionById,handlerExceptionByExceptionId,getOrderItemById,getOrderFeeById,getOrderExcptionResult} from "@/api/ecw/orderException" import {getExceptionById,handlerExceptionByExceptionId,getOrderItemById,getOrderFeeById,getOrderExcptionResult,getOrderExceptionChannelPriceList} from "@/api/ecw/orderException"
import {getFirstReceivableListByOrderId} from '@/api/ecw/financial' import {getFirstReceivableListByOrderId} from '@/api/ecw/financial'
import WorkFlow from '@/components/WorkFlow' import WorkFlow from '@/components/WorkFlow'
import {listByIds} from '@/api/ecw/region' import {listByIds} from '@/api/ecw/region'
...@@ -750,7 +758,7 @@ ...@@ -750,7 +758,7 @@
channelList: [], // 出货取到 channelList: [], // 出货取到
tradeCityList:[], tradeCityList:[],
unitList: [], unitList: [],
selectLine:null selectLine:null,
}; };
}, },
activated(){ activated(){
...@@ -927,9 +935,7 @@ ...@@ -927,9 +935,7 @@
that.getOrderFeeByIdData() that.getOrderFeeByIdData()
that.getPreExceptionData() that.getPreExceptionData()
} }
if(that.orderExceptionData.orderExceptionStatus==2){ if(that.orderExceptionData.orderExceptionStatus>0){
that.getOrderExcptionResult()
}else if(that.orderExceptionData.orderExceptionType=='not_shipping_channel_exception'&&that.orderExceptionData.orderExceptionStatus==1){
that.getOrderExcptionResult() that.getOrderExcptionResult()
} }
}); });
...@@ -976,6 +982,7 @@ ...@@ -976,6 +982,7 @@
} }
if(this.orderExceptionData.orderExceptionType=='not_shipping_channel_exception'){ if(this.orderExceptionData.orderExceptionType=='not_shipping_channel_exception'){
// this.handlerParams.channelPriceList = [] // this.handlerParams.channelPriceList = []
if(this.orderExceptionData.orderExceptionStatus==0){
this.orderData.orderItemVOList.map(v=>{ this.orderData.orderItemVOList.map(v=>{
if(!v.oneSeaFreight){ if(!v.oneSeaFreight){
v.seaFreightCurrency = this.currencyList[0]['id'] v.seaFreightCurrency = this.currencyList[0]['id']
...@@ -986,6 +993,9 @@ ...@@ -986,6 +993,9 @@
v.clearanceFreightVolume = this.unitList[1]['id'] v.clearanceFreightVolume = this.unitList[1]['id']
} }
}) })
}else{
this.getExceptionPriceList()
}
} }
}); });
}, },
...@@ -1092,22 +1102,22 @@ ...@@ -1092,22 +1102,22 @@
} }
if(this.orderExceptionData.orderExceptionType=='not_shipping_channel_exception'&&this.handlerParams.orderExceptionHandlerResult=='continue_channel'){ if(this.orderExceptionData.orderExceptionType=='not_shipping_channel_exception'&&this.handlerParams.orderExceptionHandlerResult=='continue_channel'){
this.handlerParams.orderItemVOList = this.orderData.orderItemVOList this.handlerParams.orderItemVOList = this.orderData.orderItemVOList
// this.handlerParams.channelPriceList = [] this.handlerParams.channelPriceList = []
// this.orderData.orderItemVOList.map(v=>{ this.orderData.orderItemVOList.map(v=>{
// var listItem = { var listItem = {
// orderId:v.orderId, orderId:v.orderId,
// orderItemId:v.orderItemId, orderItemId:v.orderItemId,
// charging:v.charging, charging:v.charging,
// freightFee:v.oneSeaFreight, freightFee:v.oneSeaFreight,
// isPayAdvance:v.isPayAdvance, isPayAdvance:v.isPayAdvance||0,
// freightCurrencyId:v.seaFreightCurrency, freightCurrencyId:v.seaFreightCurrency,
// freightUnitId:v.seaFreightVolume, freightUnitId:v.seaFreightVolume,
// clearanceFee:v.oneClearanceFreight, clearanceFee:v.oneClearanceFreight,
// clearanceCurrencyId:v.seaFreightCurrency, clearanceCurrencyId:v.clearanceFreightCurrency,
// clearanceUnitId:v.clearanceFreightVolume clearanceUnitId:v.clearanceFreightVolume
// } }
// this.handlerParams.channelPriceList.push(listItem) this.handlerParams.channelPriceList.push(listItem)
// }) })
} }
handlerExceptionByExceptionId(this.handlerParams).then(res=>{ handlerExceptionByExceptionId(this.handlerParams).then(res=>{
this.$modal.msgSuccess(this.$t('提交成功')); this.$modal.msgSuccess(this.$t('提交成功'));
...@@ -1248,6 +1258,26 @@ ...@@ -1248,6 +1258,26 @@
} }
}, },
//获取提交的不可出渠道异常商品清关费
getExceptionPriceList(){
let that = this
getOrderExceptionChannelPriceList({orderId:that.orderId,exceptionId:parseInt(that.orderExceptionId),exceptionResultId:this.handlerParams.id}).then(res=>{
if(res.code==0&&res.data.length>0){
that.orderData.orderItemVOList.map(v=>{
var item = res.data.find(vs=>vs.orderItemId==v.orderItemId)
if(item){
v.oneSeaFreight = item.freightFee
v.seaFreightCurrency = item.freightCurrencyId
v.seaFreightVolume = item.freightUnitId
v.oneClearanceFreight = item.clearanceFee
v.clearanceFreightCurrency = item.clearanceCurrencyId
v.clearanceFreightVolume = item.clearanceUnitId
}
})
}
})
}
} }
}; };
</script> </script>
......
...@@ -26,7 +26,8 @@ ...@@ -26,7 +26,8 @@
remote remote
@change="handleBrandChange" @change="handleBrandChange"
:remote-method="getProductBrandPage" :remote-method="getProductBrandPage"
disabled> disabled
>
<el-option <el-option
v-for="item in brandList" v-for="item in brandList"
:key="item.id" :key="item.id"
...@@ -368,24 +369,6 @@ export default { ...@@ -368,24 +369,6 @@ export default {
feeType: undefined, feeType: undefined,
recordMode: undefined recordMode: undefined
}, },
form1: {
table: [],
brandType: undefined,
orderId: undefined,
orderNo: undefined,
brand: undefined,
inTime: undefined,
material: undefined,
orderItemId: undefined,
prodAttrIds: [],
prodId: undefined,
prodTitleEn: undefined,
prodTitleZh: undefined,
prodType: undefined,
type: 1,
feeType: undefined,
recordMode: undefined
},
brandList: [], brandList: [],
brandList1: [], brandList1: [],
formRules: { formRules: {
...@@ -474,15 +457,15 @@ export default { ...@@ -474,15 +457,15 @@ export default {
}) })
if (!this.edit){ if (!this.edit){
let protectRowCount = 0 /*let protectRowCount = 0
this.protectRowCount = this.form.table.map(e => { this.protectRowCount = this.form.table.map(e => {
if (e.id){ if (e.id){
protectRowCount++ protectRowCount++
} }
}) })
this.protectRowCount = protectRowCount this.protectRowCount = protectRowCount*/
this.handleAdd() this.handleAdd()
this.handleAdd(1) // this.handleAdd(1)
} }
}, },
handleClose() { handleClose() {
...@@ -516,6 +499,7 @@ export default { ...@@ -516,6 +499,7 @@ export default {
} }
// 首次入仓、入仓补充 // 首次入仓、入仓补充
return finishPacked({ return finishPacked({
brand: this.form.brand,
orderId: this.warehousing.orderId, orderId: this.warehousing.orderId,
orderItemId: this.warehousing.orderItemId, orderItemId: this.warehousing.orderItemId,
orderWarehouseInItemDtoList: this.form.table.map(e => { orderWarehouseInItemDtoList: this.form.table.map(e => {
...@@ -608,7 +592,7 @@ export default { ...@@ -608,7 +592,7 @@ export default {
cartonsNum = this.warehousing.num - hasCartonsNum cartonsNum = this.warehousing.num - hasCartonsNum
} }
const form = val === 1 ? this.form1 : this.form const form = {...this.form}
const formLength = form.table.length const formLength = form.table.length
let orderLocationBackVOList = [] let orderLocationBackVOList = []
/* // 不默认使用上一条记录的储位 https://zentao.test.jdshangmen.com/bug-view-3344.html /* // 不默认使用上一条记录的储位 https://zentao.test.jdshangmen.com/bug-view-3344.html
......
...@@ -846,7 +846,8 @@ export default { ...@@ -846,7 +846,8 @@ export default {
this.serviceOpen = true; this.serviceOpen = true;
this.lineform.lineId = row.lineId; this.lineform.lineId = row.lineId;
this.lineform.transportType = row.transportType; this.lineform.transportType = row.transportType;
this.lineform.isClientShow = row.isClientShow; this.lineform.isClientShow = row.isClientShow ? 1 : 0;
this.lineform.makeBillNode = row.makeBillNode; this.lineform.makeBillNode = row.makeBillNode;
}, },
...@@ -863,7 +864,7 @@ export default { ...@@ -863,7 +864,7 @@ export default {
makeBillNode:this.lineform.makeBillNode makeBillNode:this.lineform.makeBillNode
}).then(res => { }).then(res => {
this.$modal.msgSuccess(this.$t("操作成功")); this.$modal.msgSuccess(this.$t("操作成功"));
this.getRouteList()
for(let index in this.routeList) { for(let index in this.routeList) {
let routeItem = this.routeList[index]; let routeItem = this.routeList[index];
if(routeItem.lineId && routeItem.lineId == this.lineform.lineId) { if(routeItem.lineId && routeItem.lineId == this.lineform.lineId) {
...@@ -1060,11 +1061,7 @@ export default { ...@@ -1060,11 +1061,7 @@ export default {
this.changeContinents(response.data.zhou); this.changeContinents(response.data.zhou);
this.changeCountry(response.data.guojia); this.changeCountry(response.data.guojia);
this.changeProvince(response.data.sheng); this.changeProvince(response.data.sheng);
this.isUpdate = true; this.isUpdate = true;
this.open = true; this.open = true;
this.title = this.$t("修改仓库"); this.title = this.$t("修改仓库");
}); });
......
...@@ -96,92 +96,41 @@ const sea = ` ...@@ -96,92 +96,41 @@ const sea = `
` `
const air= ` const air= `
<table style="width:100%;"> <table width="100%">
<tbody> <tbody>
<tr class="firstRow"> <tr class="firstRow">
<td style="text-align:center;"> <td style="text-align: center;">
<img src="${prefix}/logo.png" alt="" style="width:118px;"/> <img src="https://static2.groupage.cn/logo.png" alt="" style="width: 118px;"/>
</td> </td>
<td class="laymain" style="vertical-align:text-top;"> <td class="laymain" style="vertical-align: text-top; word-break: break-all;">
<p style="font-size:36px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;"> <p style="margin-top: 5px; margin-bottom: 5px; font-size: 36px; color: rgb(0, 143, 215); font-family: &quot;Times New Roman&quot;; text-align: center;">
E&C LOGISTICS LIMITED E&C LOGISTICS LIMITED
</p> </p>
<p style="font-size:16px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;"> <p style="margin-top: 5px; margin-bottom: 5px; color: rgb(0, 143, 215); font-family: &quot;Times New Roman&quot;; text-align: center; line-height: 1.75em;">
<span style="font-size: 16px;">China Head Add.:+86 400 9009962(Guangzhou/Yiwu)</span>
China Head Add.: +8618058993570/ 13556084412/13660548225/
</p>
<p style="font-size:16px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;">
Yiwu Branch: +15957997302/ 18058993571/13105572235
</p> </p>
<p style="font-size:16px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;"> <p style="margin-top: 5px; margin-bottom: 5px; color: rgb(0, 143, 215); font-family: &quot;Times New Roman&quot;; text-align: center; line-height: 1.75em;">
<span style="font-size: 16px;">NGR head office: 07011331745/ 08140352000 Onitsha: 07043969197 /09048725208</span>
NGR head office: 07011331745/ 08140352000/
</p> </p>
<p style="font-size:16px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;"> <p style="margin-top: 5px; margin-bottom: 5px; color: rgb(0, 143, 215); font-family: &quot;Times New Roman&quot;; text-align: center; line-height: 1.75em;">
<span style="font-size: 16px;">Complaint Line:+86 400 9009962(CHINA)/+2348140352000(NIGERIA)</span>
Alaba Branch (Air-Cargo) : 07082148641/ 08105496751/ 07011331745
</p> </p>
</td> </td>
<td style="text-align:center;"> <td style="text-align: center;">
<img src="${prefix}/weixin.jpg" alt="" style="width:142px;"/> <img src="https://static2.groupage.cn/weixin.jpg" alt="" style="width: 142px;"/>
<p style="font-size:16px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;"> <p style="margin-top: 5px; margin-bottom: 5px; color: rgb(0, 143, 215); font-family: &quot;Times New Roman&quot;;">
https://person2.groupage.cn
Website: www.groupage.cn
</p> </p>
</td> </td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
<table style="width:100%;"> <p style="margin: 2rem; margin-top:0rem; text-wrap: wrap; font-size: 33px; font-family: &quot;Times New Roman&quot;; text-align: center;">
<tbody>
<tr class="firstRow">
<td style="font-size:16px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;">
Lagos Airport Branch: 07018291182/07082148641
</td>
<td style="font-size:16px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;">
Trade fair Branch: 07013178195/ 09023762194
</td>
</tr>
</tbody>
</table>
<p style="font-size:16px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;">
IDUMOTA/ISLAND : 07010775374/09025168630/09024538636
</p>
<p style="font-size:16px;color:#008fd7;font-family:&#39;Times New Roman&#39;;text-align:center;">
Complaint Line:+86 15920356527(CHINA) / +2349021774695 (NIGERIA)
</p>
<p style="font-size:33px;color:#000;font-family:&#39;Times New Roman&#39;;text-align:center; margin: 2rem;">
AIR WAY BILL AIR WAY BILL
</p> </p>
<p>
<br/>
</p>
` `
const agreementSea = ` const agreementSea = `
...@@ -376,83 +325,134 @@ within 7days of issuance of same,else,it will be taken that i have consented to ...@@ -376,83 +325,134 @@ within 7days of issuance of same,else,it will be taken that i have consented to
</p>` </p>`
const agreementAir = ` const agreementAir = `
<table class="fgh" style="width:96%;"> <table cellpadding="0" cellspacing="0" border="1" width="100%">
<tbody> <tbody>
<tr> <tr>
<th style="vertical-align:middle;text-align:left;font-size:9px;color:#333;font-family:'Times New Roman';white-space:nowrap"> <td valign="top" align="right">
Definition Definition
</th> </td>
<td style="text-align:left;font-size:14px;color:#333;border:1px solid #ccc;font-family:'Times New Roman';"> <td>
<p> <span style="font-size: 10px;">Customer客户指:suppliers/receivers/owner发货人/收货人/货权所有人<br/>company&nbsp;公司指:E&amp;C Logitsics CO., LTD广州市捷道国际货运代理有限公司</span>
Company means E&amp;C LOGISITCS LIMITED
</p >
<p>
Customer means those who gives the goods to the Company and pays for the services provided by the Company.
</p >
</td> </td>
</tr> </tr>
<tr> <tr>
<th style="text-align:right;font-size:16px;color:#333;vertical-align:text-top;font-family:'Times New Roman';"> <td valign="top" align="right">
Note: <span style="font-family:'Times New Roman';">1.</span> Note:1.
</th> </td>
<td style="text-align:left;font-size:14px;color:#333;border:1px solid #ccc;font-family:'Times New Roman';"> <td>
We will not guarantee to ship any famous brand name goods, but we will try our best protect the customers benefit if the above information declared. <span style="font-size: 10px;">Customer shall provide all information required for shipping and make sure all the information is correct yet in accord with actual goods. Any loss due to misinformation, shall be borne by customer (Customer has the duty to confirm the information contained in his packing list is accurate).<br/>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;客户必须提供正确的货物信息并确保与实际货物相符,客户有义务核对我司提供的所有需确认的文件信息并确保信息核对无误,客户需承担因信息错误或者缺乏导致的损失。</span>
</td> </td>
</tr> </tr>
<tr> <tr>
<th style="text-align:right;font-size:16px;color:#333;vertical-align:text-top;font-family:'Times New Roman';"> <td valign="top" align="right">
<span style="font-family:'Times New Roman';">2.</span> 2.
</th> </td>
<td style="text-align:left;font-size:14px;color:#333;border:1px solid #ccc;font-family:'Times New Roman';"> <td>
Customer affirms that all the goods it gives to company, regardless of the source, are legal and are not related to any infringement of intellectual property rights. Furthermore, based on Customer’s representation and Company’s reliance on it, company is not obliged to confirm or scrutinize any infringement of the intellectual property rights. If the company should suffer any losses due to intellectual property issues related to customer’s goods, Company may pursue litigation or arbitration or both to recover its losses. <span style="font-size: 10px;">Customer shall ensure that the consignments comply with existing laws of the importing and exporting countries. The customer shall take responsibility for goods been disposed of by government agencies for not complying with laws such as counterfeit, contraband, fake, or prohibited goods been disposed of. It is also not the responsibility of the company to ascertain the quality or quantity or model of the goods. That is between the customer and the supplier. Company shall ship what was sent to it, provided it does not contravene existing laws of both import and export country.<br/>本公司不对发收货双方所发生的买卖交易的具体细节负责,包括交易货物类型,型号,款式,颜色,数量等一切订单信息。客户需确保托运货物遵守进口国与出口国的法律法规,并承担因货物违反相关国家法律规定,质量认证标准等被相关部门处置产生的损失,如仿冒品、伪劣品和违禁品被没收或征收,本公司不承担在进出口程序中非因公司故意或过失导致的任何损失。</span>
</td> </td>
</tr> </tr>
<tr> <tr>
<th style="text-align:right;font-size:16px;color:#333;vertical-align:text-top;font-family:'Times New Roman';"> <td valign="top" align="right">
<span style="font-family:'Times New Roman';">3.</span> 3.
</th> </td>
<td style="text-align:left;font-size:14px;color:#333;border:1px solid #ccc;font-family:'Times New Roman';"> <td>
Our company does not assume responsibility for any fake product or goods that are prohibited for Import/export. <span style="font-size: 10px;">The company does not accept responsibility for damage to fragile goods during transportation. Sender shall take protective measures.<br/>&nbsp;&nbsp;&nbsp;&nbsp;本公司不承担易碎品在运输途中出现破损的责任,发货人需自行做好货物保护措施。</span>
</td> </td>
</tr> </tr>
<tr> <tr>
<th style="text-align:right;font-size:16px;color:#333;vertical-align:text-top;font-family:'Times New Roman';"> <td valign="top" align="right">
<span style="font-family:'Times New Roman';">4.</span> 4.
</th> </td>
<td style="text-align:left;font-size:14px;color:#333;border:1px solid #ccc;font-family:'Times New Roman';"> <td>
Any shipment, lost, we will not take any responsibility, the shipper shall request insurance. <span style="font-size: 10px;">Customer shall take out appropriate insurance to secure his goods while still in the company’s custody, as the company will bear no responsibility for loss or damages to any uninsured goods. The company shall not be responsible for delay or loss due to force majeure factors during transportation which are not caused by the company.<br/>客户应对货物购买保险,本公司不对在本公司仓库内未投保的货物的损失或损坏不承担任何责任。由于货物运输途中存在不可抗力因素,出现延误及货损等情况,非我司原因造成的,我司不承担责任,客户需要自行做好规避措施。</span>
</td> </td>
</tr> </tr>
<tr> <tr>
<th style="text-align:right;font-size:16px;color:#333;vertical-align:text-top;font-family:'Times New Roman';"> <td valign="top" align="right">
<span style="font-family:'Times New Roman';">5.</span> 5.
</th> </td>
<td style="text-align:left;font-size:14px;color:#333;border:1px solid #ccc;font-family:'Times New Roman';"> <td>
All goods for which the cost of freight and clearing is borne by the agent shall be paid for by the importer and such goods collected on or befor the expiration of fifiteen(15) working days. <span style="font-size: 10px;">It is agreed and the customer irrevocably consents that the company shall at all times maintain a legal right of lien on the goods for any sums due to the company including demurage, and expenses for prolonged warehousing of the goods. The loss/damage/on-hold failure/wrong pick up, caused by not picking up on time will be borne by the customer for goods stayed over 30days.&nbsp; The cargo will regards as abandoned good if overstay 90 days in our warehouse, Our company reserves the right to dispose of goods,recover all reasonable expenses such as freight and storage fees and requires the customer to bear reasonable rights protection fees, including but not limited to attorney fees and transportation fees.<br/>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;双方同意且客户不可单方撤销同意基础上,公司应享有在任何时候对货物持有合法的留置权,以应付公司相关款项的支付,包括滞期费和货物延长仓储费。货物在到达目的港仓超期30个自然日,因客户不提货导致的损失(丢货/破损/控货失败/提错货物)我司概不承担。货物在仓超期90个自然日,视为客户放弃货物,我司有权做废物处理,向客户追偿拖欠运费、仓储费等所有合理费用,并要求客户承担由此产生的合理维权费,包括但不限于律师费、交通费等。</span>
</td> </td>
</tr> </tr>
<tr> <tr>
<th style="text-align:right;font-size:16px;color:#333;vertical-align:text-top;font-family:'Times New Roman';"> <td valign="top" align="right">
<span style="font-family:'Times New Roman';">6.</span> 6.
</th> </td>
<td style="text-align:left;font-size:14px;color:#333;border:1px solid #ccc;font-family:'Times New Roman';"> <td>
In order to ensure that the warehouse and/or space made available for storing clearde goods is not congested, the agent shall have the power to dispose off the cleared goods at the expiration of fifteen(15) days of arrival if the importers fail to pay the said cleared goods and remove same within the stipulated periods. <span style="font-size: 10px;">Overweight /volume weight goods need to be charged following our standard. Please note that price stated on the packing list is subject to review without noticefor reasons of sudden unforeseen changes in freight/clearing, or any other reasons. In such cases, additional costs will be borne by the customer.如果货物属于重货/泡货,需按照我司重货/泡货标准计费。此外,请注意,由于其他突然未预见到的原因导致合理的成本增加,本提货单上的报价将不予重新通知客户进行审查,此额外费用应由客户支付。</span>
</td> </td>
</tr> </tr>
<tr> <tr>
<th style="text-align:right;font-size:16px;color:#333;vertical-align:text-top;font-family:'Times New Roman';"> <td valign="top" align="right">
<span style="font-family:'Times New Roman';">7.</span> 7.
</th> </td>
<td style="text-align:left;font-size:14px;color:#333;border:1px solid #ccc;font-family:'Times New Roman';"> <td>
If however,the amount expended for the shipping as well as clearing ,the importer shall reimburse the agent of the balance. <span style="font-size: 10px;">Once the company sends the parking list to customers through email/E&amp;C platforms/whatsapp/wechat/QQ, the sending date shall be deemed the day that the receiver receives it.<br/>如本公司通过邮件/我司平台客户端/whatsapp/微信/QQ社交软件发送提货单给客户,发送之日视为客户收到之日。</span>
</td> </td>
</tr> </tr>
<tr> <tr>
<th style="text-align:right;font-size:16px;color:#333;vertical-align:text-top;font-family:'Times New Roman';"> <td valign="top" align="right">
<span style="font-family:'Times New Roman';">8.</span> 8
</th> </td>
<td style="text-align:left;font-size:14px;color:#333;border:1px solid #ccc;font-family:'Times New Roman';"> <td>
We offer the "warehouse to warehouse" service, we not take any responsibility of the goods after the goods leave our warehouse. <span style="font-size: 10px;">Where extra cost is incurred in both import and export country., the company has the right to request that customer pays for the changes.<br/>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;在货物的运输期间可能产生额外的费用,包括起运港与目的港产生的费用,我司有权要求客户按货物的比例支付相关费用。</span>
</td>
</tr>
<tr>
<td valign="top" align="right">
9
</td>
<td>
<span style="font-size: 10px;">Company may request the customer to pick up at a new warehouse or request delivery fee where there is a change in the warehouse address<br/>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;我司有权要求客户到指定仓库提货,需要派送至原分点客户需承担派送费。</span>
</td>
</tr>
<tr>
<td valign="top" align="right">
10
</td>
<td>
<span style="font-size: 10px;">Company shall not take responsibility for goods after they leave the warehouse. However, receiver shall inform the company within 24 hours of receiving the goods if he has questions or where there are issues with the goods received. Otherwise, the receiver shall be deemed to have accepted the goods and no further questions/issues can be raised.<br/>货物离开公司仓库后,我司概不对货物承担任何责任,如客户有任何问题或异议,需要收到货物的24小时之内通知公司,否则视为收货人已经接受货物,不得再提出问题或异议。</span>
</td>
</tr>
<tr>
<td valign="top" align="right">
11
</td>
<td>
<span style="font-size: 10px;">The company shall not be responsible for any goods confiscated from her warehouses by customs, standard organization of Nigeria, or any other government agency due to breech of government regulations.对于因违反政府有关法律规定而被海关、尼日利亚标准组织或任何其他政府机构从我方仓库扣押/没收的任何货物,本公司概不负责。</span>
</td>
</tr>
<tr>
<td valign="top" align="right">
12
</td>
<td>
<span style="font-size: 10px;">12. The customer shall pay the freight, clearing, and any other costs which may arise to pick up his goods with 30 days of arrival at the destination warehouse. 1% of freight will be charged as overdue penalty each day if late payment over 30days, and storage fee charged according to following standard shall be applied.Nigerian Warehouse:#150/CBM/Day from the first day to 90 days<br/>客户需在货物到达目的地仓库后30自然日内付清海运费,清关费及其他费用并提走货物,每逾期一日,承担应付金额百分之一的违约金,超期提货的,加收仓储费,超期不提货则从到仓日起收取仓储费,收费标准如下:尼日利亚仓库:超期1-90个自然日,仓储费用自入仓日起收取150奈拉/方/天</span>
</td>
</tr>
<tr>
<td valign="top" align="right">
13
</td>
<td>
<span style="font-size: 10px;">It is understood that supplier/shipper retains the right to endorse a bill of lading/packing list transfer title to a third party where the initial party fails to pay the supplier/shipper for any given shipment and the company shall not be liable for such endorsement of transfer to a third party buyer<br/>&nbsp;据悉,如果收货人未能向其供应商/托运人全额支付任何给定货物的货款,供应商/托运人保留背书提单或将货物所有权转让给第三方的权利,我们对此类背书转让给第三方买方不承担责任。</span>
</td>
</tr>
<tr>
<td valign="top" align="right">
14
</td>
<td>
<span style="font-size: 10px;">The customer agrees with the company that the terms of this packing list shall constitute the contract between the parties herein and agree to be bound by same<br/>客户同意本公司的装箱单条款,本条款将构成双方之间的合同,并同意受其约束。</span>
</td>
</tr>
<tr>
<td valign="top" align="right">
15
</td>
<td>
<span style="font-size: 10px;">Any dispute arising out of this contract between the parties shall be submitted to Guangzhou International Shipping Arbitration Court for arbitration. The law of the People&#39;s Republic of China shall be applied.&nbsp;双方之间因本合同引发的纠纷,提交广州国际航运仲裁院仲裁解决,适用中华人民共和国法。</span>
</td> </td>
</tr> </tr>
</tbody> </tbody>
...@@ -476,16 +476,15 @@ const agreementAir = ` ...@@ -476,16 +476,15 @@ const agreementAir = `
<tbody> <tbody>
<tr> <tr>
<td> <td>
<p class="carry" style="font-size:16px;font-weight:bold;text-align:center;font-family:'Times New Roman';margin-left:302px;"> <p class="carry" style="font-size:16px;font-weight:bold;text-align:center;font-family:'Times New Roman';">
WE HELP YOU CARRY MORE. WE HELP YOU CARRY MORE.
</p> </p>
<p class="bless" style="font-size:16px;text-align:right;font-family:'Times New Roman';">
THANKS FOR YOUR PATRONAGE; GOD BLESS YOU.
</p>
</td> </td>
<td style="font-size:16px;text-align:center;font-family:'Times New Roman';"> </tr>
<p class="sign" style="margin-left:23px;"> <tr>
<img src="${prefix}/qianming.png" style="width:219px;height:98px;"> <td>
<p class="bless" style="font-size:16px;text-align:center;font-family:'Times New Roman';">
THANKS FOR YOUR PATRONAGE; GOD BLESS YOU.
</p> </p>
</td> </td>
</tr> </tr>
...@@ -494,7 +493,7 @@ const agreementAir = ` ...@@ -494,7 +493,7 @@ const agreementAir = `
<table style="width:100%;"> <table style="width:100%;">
<tbody> <tbody>
<tr> <tr>
<td style="vertical-align:bottom;"> <td style="vertical-align:bottom; font-size:10px">
I have read and accepted the terms and conditions above,and shall report my acceptance<br> I have read and accepted the terms and conditions above,and shall report my acceptance<br>
within 7days of issuance of same,else,it will be taken that i have consented to it. within 7days of issuance of same,else,it will be taken that i have consented to it.
</td> </td>
......
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