You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

1944 lines
56 KiB

<template>
<el-card class="box-card" v-loading="Pageloading" element-loading-text="正在处理中...">
<el-tabs type="border-card" class="PackageInformation">
<el-tab-pane label="包件信息">
<div class="ResponsibilityBoxS">
<div class="el_btbox" v-for="(item, index) in PackageInfo" :key="index">
<div class="leftbox">
<div class="maxBox">
<span class="title">包条码:</span>
<el-input
disabled
v-model="item.packageCode"
placeholder="请输入包条码"
clearable
:rows="2"
@change="ChangePackageInfo(item.packageCode, index)"
/>
</div>
<div class="maxBox">
<span class="title">订单自编码:</span>
<el-input
disabled
v-model="item.orderCode"
placeholder="请输入订单自编号"
clearable
/>
</div>
<div class="maxBox">
<span class="title">运单号:</span>
<el-input
disabled
v-model="item.waybillNumber"
placeholder="请输入运单号"
clearable
/>
</div>
<div class="maxBox">
<span class="title">品牌:</span>
<el-input disabled v-model="item.brandName" placeholder="请输入品牌" clearable />
</div>
</div>
</div>
<div class="NumTotal">
<span>总件数:{{ PackageInfo.length }}</span>
</div>
</div>
</el-tab-pane>
</el-tabs>
<el-form disabled :model="Indexform" label-width="100px" class="IndexFrom" ref="IndexForm">
<el-form-item label="异常类型">
<el-select
v-model="Indexform.workOrderType"
clearable
placeholder="选择工单异常类型"
@change="abnormalChange"
>
<el-option
v-for="item in IndexException"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="发现节点">
<el-select
v-model="Indexform.discoveryNode"
clearable
placeholder="选择发现节点"
@change="DiscoveringNodesChange"
>
<el-option
v-for="item in DiscoveringNodes"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="异常工单号">
<el-input v-model="Indexform.workOrderNumber" disabled placeholder="异常工单号" clearable />
</el-form-item>
<el-form-item
label="车次号"
v-if="
groundlineSet ||
groundlineType == 1 ||
groundlineType == 3 ||
groundlineType == 4 ||
groundlineType == 8 ||
groundlineType == 5 ||
groundlineType == 7 ||
groundlineType == 8
"
>
<el-input
v-model="Indexform.trainNumber"
placeholder="请输入车次号(干线卸车环节)"
clearable
/>
</el-form-item>
<!-- 必填 -->
<el-form-item label="一级品">
<el-input v-model="Indexform.first" placeholder="请输入一级品类" clearable />
</el-form-item>
<!-- 必填 -->
<el-form-item label="二级品">
<el-input v-model="Indexform.secondary" placeholder="请输入二级品类" clearable />
</el-form-item>
<el-form-item label="车辆路线" v-if="groundlineSet || groundlineType == 3">
<el-input v-model="Indexform.vehicleRoute" placeholder="请输入车辆路线车次号" clearable />
</el-form-item>
<el-form-item label="发货时间">
<el-date-picker
v-model="Indexform.deliverGoodsTime"
type="datetime"
format="YYYY-MM-DD HH:mm:ss"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择发货时间"
/>
</el-form-item>
<el-form-item
label="发现时间"
v-if="
groundlineSet ||
groundlineType == 2 ||
groundlineType == 3 ||
groundlineType == 4 ||
groundlineType == 8 ||
groundlineType == 5 ||
groundlineType == 7 ||
groundlineType == 8
"
>
<el-date-picker
v-model="Indexform.discoveryTime"
type="datetime"
format="YYYY-MM-DD HH:mm:ss"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择发现时间"
/>
</el-form-item>
<el-form-item
label="配送时间"
v-if="
groundlineSet ||
groundlineType == 3 ||
groundlineType == 4 ||
groundlineType == 8 ||
groundlineType == 5 ||
groundlineType == 7 ||
groundlineType == 8
"
>
<el-date-picker
v-model="Indexform.deliveryTime"
type="datetime"
format="YYYY-MM-DD HH:mm:ss"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择配送时间"
/>
</el-form-item>
<el-form-item
label="入库时间"
v-if="groundlineSet || groundlineType == 2 || groundlineType == 4"
>
<el-date-picker
v-model="Indexform.warehousingTime"
type="datetime"
format="YYYY-MM-DD HH:mm:ss"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择入库"
/>
</el-form-item>
<!-- 必填 -->
<el-form-item label="运单商场">
<el-input v-model="Indexform.waybillMall" placeholder="请输入运单商场" clearable />
</el-form-item>
<el-form-item label="钉钉流程号">
<el-input v-model="Indexform.processNumber" placeholder="请输入钉钉流程号" />
</el-form-item>
<el-form-item
label="配送司机"
v-if="
groundlineSet ||
groundlineType == 3 ||
groundlineType == 4 ||
groundlineType == 8 ||
groundlineType == 5 ||
groundlineType == 7 ||
groundlineType == 8
"
>
<el-select
v-model="Indexform.deliveryDriver"
filterable
default-first-option
:reserve-keyword="false"
placeholder="请输入配送司机"
>
<el-option
v-for="item in DeliveryDriver"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<!-- 必填 -->
<!-- <el-form-item label="异常问题描述">
<el-input v-model="Indexform.problemDescription" placeholder="请输入异常问题" clearable />
</el-form-item> -->
<!-- 必填 -->
<el-form-item label="调查经过">
<el-input
disabled
v-model="Indexform.investigationProcess"
placeholder="请输入调查经过"
clearable
:rows="2"
type="textarea"
/>
</el-form-item>
<el-form-item label="处理方">
<el-select
v-model="Indexform.processor"
clearable
filterable
multiple
placeholder="请选择处理方"
disabled
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="处理结果">
<el-select
v-model="Indexform.result"
multiple
filterable
default-first-option
:reserve-keyword="false"
placeholder="请选择处理结果"
@change="changeProcessingResults"
disabled
>
<el-option
v-for="item in ProcessingResults"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item> </el-form-item>
</el-form>
<div class="ProcessingResults" v-if="ProcessingList.length">
<div class="title">处理结果-理赔金额</div>
<div class="Listadmiration">
<div class="name" v-for="(item, index) in ProcessingList" :key="index">
<span>{{ item.name }}:</span>
<el-tooltip :content="item.input" placement="top">
<el-input-number
v-model="item.input"
:min="item.min"
:max="item.max"
@change="TotalChange"
disabled
/>
</el-tooltip>
<div class="Paymentname">
{{ item.payment ? item.text : '支付方式' }}
</div>
<div class="el_PaymentUnit">
<span>支付单位:</span>
<el-input v-model="item.paymentUnit" disabled placeholder="暂无支付单位" />
</div>
<el-date-picker
disabled
v-model="item.compensationTime"
type="datetime"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="理赔支付时间"
/>
</div>
</div>
<div class="el_tool">
<span>总金额:{{ TotalClaimAmount }}</span>
</div>
</div>
<!-- 处理结果说明 -->
<el-form-item label="处理结果说明" class="el_resj">
<el-input
v-model="Indexform.resultDescription"
placeholder="请输入处理结果说明"
clearable
:autosize="{ minRows: 3, maxRows: 4 }"
type="textarea"
disabled
/>
</el-form-item>
<el-tabs type="border-card">
<el-tab-pane label="内部责任划分">
<div class="ResponsibilityBox">
<div class="el_btbox" v-for="(item, index) in FangAddList" :key="index">
<div class="leftbox">
<div class="maxBox">
<span class="title">责任方:</span>
<!-- 提货环节 -->
<el-select
v-model="item.businessName"
clearable
placeholder="请选提货择责任方"
v-if="groundlineType == 1"
disabled
>
<el-option
v-for="item in responsible"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<el-select
v-else
v-model="item.businessName"
filterable
placeholder="请选择责任方"
@change="ResponsiblePartychange(item.businessName, index)"
disabled
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
<div class="maxBox">
<span class="title">责任人:</span>
<el-select
v-model="item.personResponsibleName"
clearable
filterable
placeholder="请选责任人"
disabled
>
<el-option
v-for="item in personResponsibleList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</div>
<div class="maxBox">
<span class="title">占比:</span>
<el-input
v-model="item.responsibilityRatio"
placeholder="请输入占比 "
:rows="2"
disabled
/>
</div>
<div class="maxBox">
<span class="title">三方责任人:</span>
<el-input v-model="item.tripartite" placeholder="请输入三方责任人" disabled />
</div>
<div class="maxBox">
<span class="title">说明:</span>
<el-input
disabled
v-model="item.description"
placeholder="请输入说明 "
clearable
:rows="2"
/>
</div>
</div>
</div>
<div class="Proportion">
<span class="title">公司占比:{{ companyProportion }}%</span>
</div>
</div>
</el-tab-pane>
</el-tabs>
<!-- 完结信息 -->
<el-tabs type="border-card" class="demo-tabs el-endtabs" v-if="UserPermissions != '仓库客服'">
<el-tab-pane>
<template #label>
<span class="custom-tabs-label">
<el-icon><calendar /></el-icon>
<span>完结信息</span>
</span>
</template>
<div class="payanindemnity" v-for="(item, index) in CompensationParty" :key="index">
<div class="el_pklab">
<span class="title" :style="{ color: item.state != 0 ? '#000' : '#F56C6C' }"
>{{ item.state == 0 ? '赔款方' : '受款方' }}{{ item.cld }}</span
>
</div>
<div class="el_pkLi">
<div class="sk_input">
<el-input
v-model="item.name"
:placeholder="item.state == 0 ? '暂无赔款方' : '暂无受款方'"
disabled
/>
</div>
<div class="sk_input">
<el-input v-model="item.reason" placeholder="暂无原因" disabled />
</div>
<div class="sk_input">
<el-input
@input="amountMoney"
:min="0"
v-model="item.num"
placeholder="金额"
disabled
/>
</div>
<!-- 赔款方是那个仓库的 -->
<div class="sk_input" v-if="item.state == 0">
<el-select v-model="item.warehouseId" disabled filterable placeholder="暂无仓库">
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
<div class="sk_input" v-if="item.state == 1"></div>
<!-- 责任人 -->
<div class="sk_input" v-if="item.state == 0">
<el-input
v-model="item.personResponsibleList"
placeholder="暂无责任人"
clearable
:rows="2"
disabled
/>
</div>
<div class="sk_input" v-if="item.state == 1"></div>
</div>
</div>
<div class="paySum">
<span>
<el-icon><Coin /></el-icon>赔款金额总和:<b>{{ TotalamountCompensation }}</b></span
>
<span>
<el-icon><Coin /></el-icon>受款金额总和:<b>{{ TotalamountReceived }}</b></span
>
</div>
</el-tab-pane>
</el-tabs>
<!-- 照片 -->
<div class="Transport_damage_photos" v-if="SelectType == 1 || SelectType == 3 || StateType">
<span class="title">{{
SelectType == 1 ? '运损照片' : SelectType == 3 ? '窜货照片' : '照片'
}}</span>
<el-upload
disabled
v-model:file-list="Indexform.packList"
list-type="picture-card"
:on-preview="pictureList"
:on-remove="ImgListRemove"
:action="doubledCount"
:on-success="ImgSuccess"
:before-upload="beforeAvatarUpload"
:headers="headers"
multiple
drag
>
<el-icon><Plus /></el-icon>
</el-upload>
<el-dialog v-model="dialogImgList" width="30%">
<el-image
:src="amplifyurl"
:zoom-rate="1.2"
:max-scale="7"
:min-scale="0.2"
:preview-src-list="amplifysrcList"
:initial-index="4"
fit="cover"
/>
</el-dialog>
</div>
<!-- appeal为真表示正常进入为假表示从申诉列表进入 -->
<div class="foot_btn" v-if="!appeal">
<!-- v-if="PermissionButton.reply"
v-if="PermissionButton.processing_completed"
v-if="PermissionButton.work_order_completion"
v-if="PermissionButton.repulse"
v-if="PermissionButton.arbitration_completed"
v-if="PermissionButton.information_editing" -->
<el-button type="primary" @click="addireply">回复</el-button>
<el-button type="primary" @click="addingRecord" v-if="$route.query.workOrderStatus != '21'"
>处理结果</el-button
>
<el-button type="primary" @click="EndJump">完结 </el-button>
<el-button type="primary" @click="BatchReturn">打回 </el-button>
<el-button type="primary" @click="CustomerServiceCompleted">客服仲裁完结 </el-button>
<el-button @click="EditInformation">信息编辑</el-button>
</div>
<!-- <div class="foot_btn" v-if="appeal && AppealReview"> -->
<el-button type="primary" @click="AppealEstablished">申诉成立 </el-button>
<el-button type="primary" @click="AppealRejection">申诉驳回 </el-button>
<!-- </div> -->
</el-card>
<!-- 批量打回弹窗 -->
<el-dialog v-model="dialogReturn" title="批量打回" width="40%" draggable class="plAllret">
<el-form
v-loading="repulse"
element-loading-text="正在打回中..."
label-position="top"
label-width="100px"
:model="BatchFrom"
>
<el-form-item label="打回原因">
<el-input v-model="BatchFrom.txt" type="textarea" :rows="4" />
</el-form-item>
<el-form-item label="流转营业部">
<el-select
v-model="BatchFrom.businessDepartment"
multiple
filterable
default-first-option
:reserve-keyword="false"
placeholder="请选择活动区域"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-form>
<template #footer>
<span class="dialog-footer">
<el-button @click="dialogReturn = false">取消</el-button>
<el-button type="primary" @click="ConfirmReturn" :disabled="repulse"> 确定 </el-button>
</span>
</template>
</el-dialog>
</template>
<script setup>
import { ElMessage } from 'element-plus';
import { ElMessageBox } from 'element-plus';
import { useRouter, useRoute } from 'vue-router';
import { getDictionaryBiz } from '@/api/system/dict'; //字典
import { getDetailWarehouse, getDeptWarehouse } from '@/api/basicdata/basicdataWarehouse'; //处理方
import { AddressClosed } from '@/utils/util';
import { useStore } from 'vuex';
import {
$_getList,
$_submit,
$_getDetail,
$_remove,
$_getBusinessDepartmentUser,
$_getAbnormalPackage,
$_getInfo,
$_batchReturn,
$_Cancelappeal,
} from '@/api/aftersales/aftersalesWorkOrder';
import { ref, reactive, toRefs, computed, onMounted, nextTick } from 'vue';
import { compressImageBlob } from '@/components/IMGcompressor/imgcompressor.js';
import { getToken } from '@/utils/auth';
const $router = useRouter();
const $route = useRoute();
const Indexform = ref({
packList: [],
decreaseImageEntityList: [], //处理好的图片数据
}); //首页新增表单
const dialogImgList = ref(false);
const IndexException = ref([]); //异常类型下拉选择
const DiscoveringNodes = ref([]); //发现节点下拉选择
const ProcessingResults = ref([]); //处理结果列表选项
const warehouseData = ref([]); //处理方
const SelectType = ref(null); //类型
const BatchFrom = ref({}); //打回内容
const StateType = ref(true); //类型
const HistoricalPackageinput = ref(''); //历史包件选择
const dialogImageUrl = ref(null); //图片
const TotalamountCompensation = ref(0); //赔款总金额
const TotalamountReceived = ref(0); //受款总金额
const dialogVisible = ref(null); //图片
const ProcessingList = ref([]); //处理结果已经选择的列表
const groundlineSet = ref(true); //干线条件都满足
const groundlineType = ref(null); //干线状态
const ShortageState = ref(false); //少货件数弹窗状态
const Pageloading = ref(false); //申诉列表
const fleeingState = ref(false); //窜货件数弹窗
const ShortageList = ref([]); //少货件数
const fleeingList = ref([]); //窜货件数
const valueStrictly = ref();
const routerID = ref(null); //路由参数ID
const routerState = ref(''); //路由状态
const personResponsibleList = ref([]); //责任人列表
const companyProportion = ref(0); //公司占比
const identifying = ref(1); //订单,零担状态
const dialogHistoricalPackage = ref(false); //历史包件弹窗
const HistoricalPackageList = ref([]); //历史包件数组
const HistorIndex = ref(0); //历史包件索引
const TotalClaimAmount = ref(0); //总金额
const dialogReturn = ref(false); //打回弹窗
const ProcessingRecords = ref([]); //处理放记录用于匹配按钮
const ProcessingRecordsName = ref([]); //匹配的处理方中文名字
const repulse = ref(false); //加载效果
const amplifyurl = ref(''); //当前点击的图片
const amplifysrcList = ref([]); //图片循环列表
const RouteIndexs = ref(''); //进入前的页面索引
const UserPermissions = ref(''); //当前状态
const warehouseInfo = ref(''); //仓库信息
const warehouseState = ref(false); //仓库权限
const $useStore = useStore();
const appeal = ref(false); //工单申诉状态
const AppealReview = ref(false); //申诉状态只能查看
const accessControl = $useStore.getters.permission;
const CompensationParty = ref([
{
name: '',
state: 0,
num: null,
reason: '',
cld: 1,
warehouseId: null,
personResponsibleList: '',
}, //赔款方
// explains: ''
{
name: '',
state: 1,
num: null,
reason: '',
cld: 1,
warehouseId: null,
personResponsibleList: '',
}, //受款方
// explains: ''
]); //收/赔
const PackageInfo = ref([
//包件信息
{ packageCode: '', orderCode: '', waybillNumber: '', brandName: '' },
]);
// 责任方列表
const FangAddList = ref([
{
businessName: '',
personResponsibleName: '',
responsibilityRatio: '',
description: '',
tripartite: '',
},
]);
// 提货责任方
const responsible = ref([
{
value: 1,
label: '工厂',
},
{
value: 2,
label: '外包搬运',
},
{
value: 3,
label: '物流',
},
]);
// 图片列表
const fileList = ref([]);
// 字典公共函数
function updateDictionary(targetArray, dictionaryType) {
getDictionaryBiz(dictionaryType).then(res => {
console.log(res, '字典');
res.data.data.forEach(item => {
targetArray.push({
value: item.dictKey,
label: item.dictValue,
});
});
});
}
// 获取角色权限
getDictionaryBiz('after_sales_visits').then(res => {
console.log(res, '角色字典');
const matchingItem = res.data.data.find(
item => item.dictValue == JSON.parse(localStorage.getItem('TWMS-userInfo')).content.role_name
);
if (matchingItem) {
UserPermissions.value = matchingItem.dictValue;
} else {
UserPermissions.value = '仓库客服';
}
console.log(UserPermissions.value, '当前角色权限');
});
warehouseInfo.value = localStorage.getItem('WarehouseName');
// 图片上传必须携带TOKEN
const headers = computed(() => {
return { 'Blade-Auth': 'Bearer ' + getToken() };
});
// 图片上传接口
const doubledCount = computed(() => {
return '/api/blade-resource/oss/endpoint/put-file';
});
// 图片上传接口
// 图片上传成功回调函数
const ImgSuccess = (response, uploadFile) => {
if (response.success === true) {
console.log(response);
Indexform.value['packList'].push({
name: response.data.originalName,
url: response.data.link,
});
console.log(Indexform.value['packList'], '图片列表');
}
};
// 后台控制权限按钮
const PermissionButton = computed(() => {
return {
workAdd: accessControl.workAdd, //新增
batch_return: accessControl.batch_return, //批量打回
assign: accessControl.assign, //工单指派
apply_arbitration: accessControl.apply_arbitration, //申请仲裁
batch_completion: accessControl.batch_completion, //批量完结
representations: accessControl.representations, //申诉
reply: accessControl.reply, //回复
processing_completed: accessControl.processing_completed, //处理完结
work_order_completion: accessControl.work_order_completion, //完结
repulse: accessControl.repulse, //打回
arbitration_completed: accessControl.arbitration_completed, //仲裁完结
information_editing: accessControl.information_editing, //信息编辑
};
});
// const PermissionButtonS = computed(() => {
// return {
// workAdd:accessControl.workAdd,//新增
// batch_return:accessControl.batch_return,//批量打回
// assign:accessControl.assign, //工单指派
// apply_arbitration:accessControl.apply_arbitration,//申请仲裁
// batch_completion:accessControl.batch_completion,//批量完结
// representations:accessControl.representations,//申诉
// reply:accessControl.reply,//回复
// processing_completed:accessControl.processing_completed,//处理完结
// work_order_completion:accessControl.work_order_completion,//完结
// repulse:accessControl.repulse,//打回
// arbitration_completed:accessControl.arbitration_completed,//仲裁完结
// information_editing:accessControl.information_editing,//信息编辑
// }
// });
// 详情按钮权限
const ButtonPermissions = computed(() => {
// 根据 TabPermissions 的状态,决定每个按钮的显示隐藏逻辑
switch (RouteIndexs.value != 'null') {
case RouteIndexs.value == 0: //全部
return {
reply: false, //回复按钮(都可以查看)
ProcessingResults: false, //处理结果按钮
end: false, //完结按钮
repulse: false, //打回按钮
ArbitrationCompleted: false, //客服仲裁完结
edit: false, //编辑
};
case RouteIndexs.value == 1: //处理中
return {
reply: false, //回复按钮
ProcessingResults: false, //处理结果按钮
end: false, //完结按钮
repulse: false, //打回按钮
ArbitrationCompleted: false, //客服仲裁完结
edit: false, //编辑
};
case RouteIndexs.value == 2: //处理完毕
return {
reply: false, //回复按钮
ProcessingResults: false, //处理结果按钮
end: UserPermissions.value == '职能客服', //完结按钮
repulse: UserPermissions.value == '客服经理', //打回按钮
ArbitrationCompleted: false, //客服仲裁完结
edit: false, //编辑
};
case RouteIndexs.value == 3: //待处理
return {
reply: UserPermissions.value == '仓库客服', //回复按钮
ProcessingResults: UserPermissions.value == '仓库客服', //处理结果按钮
end: UserPermissions.value != '仓库客服', //完结按钮
repulse: UserPermissions.value != '仓库客服', //打回按钮
ArbitrationCompleted: false, //客服仲裁完结
edit: UserPermissions.value == '仓库客服', //编辑
};
case RouteIndexs.value == 4: //理赔金额未出
return {
reply: false, //回复按钮
ProcessingResults: false, //处理结果按钮
end: false, //完结按钮
repulse: false, //打回按钮
ArbitrationCompleted: false, //客服仲裁完结
edit: false, //编辑
};
case RouteIndexs.value == 5: //仲裁中
return {
reply: UserPermissions.value == '职能客服', //回复按钮
ProcessingResults: false, //处理结果按钮
end: false, //完结按钮
repulse: false, //打回按钮
ArbitrationCompleted: UserPermissions.value == '职能客服', //客服仲裁完结
edit: false, //编辑
};
case RouteIndexs.value == 6: //完结
return {
reply: false, //回复按钮
ProcessingResults: false, //处理结果按钮
end: false, //完结按钮
repulse: false, //打回按钮
ArbitrationCompleted: false, //客服仲裁完结
edit: false, //编辑
};
case RouteIndexs.value == 7: //超时未处理
return {
reply: false, //回复按钮
ProcessingResults: false, //处理结果按钮
end: false, //完结按钮
repulse: false, //打回按钮
ArbitrationCompleted: false, //客服仲裁完结
edit: false, //编辑
};
case RouteIndexs.value == 8: //待回复
return {
reply: UserPermissions.value == '仓库客服', //回复按钮
ProcessingResults: UserPermissions.value == '仓库客服', //处理结果按钮
end: UserPermissions.value != '仓库客服', //完结按钮
repulse: UserPermissions.value != '仓库客服', //打回按钮
ArbitrationCompleted: false, //客服仲裁完结
edit: UserPermissions.value == '仓库客服', //编辑
};
// 其他任何情况下的默认情况
default:
return {
reply: false, //回复按钮
ProcessingResults: false, //处理结果按钮
end: false, //完结按钮
repulse: false, //打回按钮
ArbitrationCompleted: false, //客服仲裁完结
edit: false, //编辑
};
}
});
// 上传图片规则
const beforeAvatarUpload = async rawFile => {
const _nameArr = rawFile.name.split('.');
if (_nameArr.length === 0) {
ElMessage.warning('异常类型文件');
return false;
}
const _name = _nameArr[_nameArr.length - 1];
const _whiteArr = ['png', 'jpg', 'jpeg'];
if (!_whiteArr.includes(_name.toLocaleLowerCase())) {
ElMessage.warning('请上传png、jpg、jpeg的类型图片');
return false;
}
const res = await compressImageBlob(rawFile);
return res;
};
// 点击图片列表回调
const pictureList = val => {
dialogImgList.value = true;
console.log(val, '图片列表');
amplifyurl.value = val.url;
};
// 点击图片移除
const ImgListRemove = val => {
console.log(val, '移除图片');
};
// 处理方和责任方获取数据
const handle = () => {
getDeptWarehouse().then(res => {
res.data.data.forEach(item => {
warehouseData.value.push({
value: item.id,
label: item.name,
});
});
});
};
const changeProcessingResults = val => {
// 首先删除取消的项目
ProcessingList.value = ProcessingList.value.filter(item => val.includes(item.state - 1));
// 然后添加或保持新的项目
val.forEach(num => {
let newItem = {
input: 0,
min: 0,
max: 9999999999999,
state: num + 1,
payment: '',
text: '',
compensationTime: '',
};
// 根据num为newItem的name字段赋值
switch (num) {
case '1':
newItem.name = '下补单';
break;
case '2':
newItem.name = '维修/补漆';
break;
case '3':
newItem.name = '客户未要求理赔';
break;
case '4':
newItem.name = '用库存';
break;
case '5':
newItem.name = '赔商家';
break;
case '6':
newItem.name = '赔付运费';
break;
case '7':
newItem.name = '工厂考核';
break;
default:
return;
}
// 如果列表中不存在则加入新项目
if (!ProcessingList.value.some(item => item.state === newItem.state)) {
ProcessingList.value.push(newItem);
console.log(`添加:${newItem.name}`);
}
});
};
// 获取当前责任方的责任人
const ResponsiblePartychange = (val, index) => {
FangAddList.value[index].personResponsibleName = null; //清空当前选择的责任人
$_getBusinessDepartmentUser({
warehouseId: val,
}).then(res => {
console.log(res, '获取责任人列表');
personResponsibleList.value = res.data.data;
});
};
const onLoad = () => {
if ($route.query.RouteIndexs != 'null') {
RouteIndexs.value = $route.query.RouteIndexs; //记录当前状态
}
console.log($route.query.id, '页面初始化');
routerState.value = $route.query.routerState;
updateDictionary(IndexException.value, 'pc_work_order'); //异常类型
updateDictionary(DiscoveringNodes.value, 'pc_discovery_node'); //发现环节
updateDictionary(DiscoveringNodes.value, 'pc_discovery_node'); //发现环节
handle(); //处理方和责任方信息
if ($route.query.Routstate) {
appeal.value = true;
}
// 只能查看申诉信息
if ($route.query.AppealReview) {
if ($route.query.AppealReview == 'false') {
console.log($route.query.AppealReview, '申诉状态');
AppealReview.value = false;
} else {
AppealReview.value = true;
console.log(AppealReview.value, '当前申诉状态');
}
}
console.log(appeal.value);
$_getInfo({ id: $route.query.id }).then(res => {
console.log(res, '回显返回值参数');
Indexform.value = res.data.data;
Indexform.value['result'] = [];
Indexform.value['processor'] = [];
//图片处理回显
Indexform.value.packList = res.data.data.decreaseImageVOList.map(res => {
amplifysrcList.value.push(res.imagePath);
return {
name: res.imageName,
url: res.imagePath,
};
});
// 包件回显
PackageInfo.value = res.data.data.abnormalPackageVOList;
console.log(res.data.data.abnormalPackageVOList, '包件信息');
// 责任方回显
FangAddList.value = res.data.data.processorVOList
.filter(item => item && item.typesOf && item.typesOf == '1')
.map(item => {
return { businessName: item.businessId };
});
console.log(FangAddList.value, '责任方回显问题');
// 公司占比回显计算
let sum = 0;
res.data.data.personResponsibleVOS.forEach(item => {
sum = Number(item.responsibilityRatio) + sum;
});
if (res.data.data.discoveryNode == '1') {
groundlineType.value = '1';
} else {
groundlineType.value = 'null';
}
FangAddList.value = res.data.data.personResponsibleVOS.map(res => {
return {
businessName: res.businessId, //责任人ID
personResponsibleName: res.personResponsibleName, //责任人名称
responsibilityRatio: res.responsibilityRatio + '%', //占比
description: res.description, //说明
tripartite: res.tripartite, //三方责任人
};
});
console.log(FangAddList.value, '责任方回显问题');
res.data.data.processorVOList.forEach(item => {
if (item) {
if (item.typesOf == 2) {
// 处理方
Indexform.value.processor.push(item.businessId);
}
}
});
companyProportion.value = 100 - sum;
ProcessingRecordsName.value = ProcessingRecords.value.filter(item =>
warehouseData.value.includes(item.value)
).label;
console.log(ProcessingRecordsName.value, '匹配到的中文处理方');
// updateDictionary(columnList[2].checkarr, 'pc_work_order'); //异常类型
// updateDictionary(columnList[3].checkarr, 'pc_discovery_node'); //发现环节
getDictionaryBiz('result_handling').then(res => {
console.log(res, '发现环节');
ProcessingResults.value = res.data.data;
});
// 处理结果回显
if (res.data.data.processingResultsVO.processingMoneyEntityList) {
ProcessingList.value = res.data.data.processingResultsVO.processingMoneyEntityList.map(
item => {
Indexform.value.result.push(item.resultType);
return {
input: item.money,
min: 0,
max: 9999999999999999999999999999,
state: item.resultType,
payment: item.compensationMethod,
name: item.resultTypeName,
text: item.compensationMethodName,
compensationTime: item.compensationTime, //支付时间
paymentUnit: item.paymentUnit, //支付单位
};
}
);
}
// 总金额回显
TotalClaimAmount.value = res.data.data.processingResultsVO.money;
// 理赔支付时间
Indexform.value.compensationTime = res.data.data.processingResultsVO.compensationTime;
// 处理结果说明回显
Indexform.value.resultDescription = res.data.data.processingResultsVO.resultDescription;
if (res.data.data.completionRecipientEntityList.length > 0) {
CompensationParty.value = [];
res.data.data.completionRecipientEntityList.forEach((item, index) => {
TotalamountReceived.value += Number(item.money);
CompensationParty.value.push({
state: 1, //状态
num: item.money, //金额
name: item.recipient, //受款方名字
reason: item.reasonReceivingPayment, //受款方原因
// explains: item.explains, //受款方说明
cld: index + 1,
id: item.id,
});
});
}
// 赔款方
if (res.data.data.completionRecordEntities.length) {
res.data.data.completionRecordEntities.forEach((item, index) => {
TotalamountCompensation.value += Number(item.money);
CompensationParty.value.push({
state: 0, //状态
num: item.money, //金额
name: item.indemnitor, //受款方名字
reason: item.reason, //受款方原因
// explains: item.explains, //受款方说明
cld: index + 1,
id: item.id,
accounting: item.accounting ? item.accounting : '',
warehouseId: item.warehouseId, //仓库
personResponsibleList: item.compensationPersonnel, //责任人
});
});
}
});
};
onLoad(); //初始化程序
// 异常类型事件
const abnormalChange = val => {
console.log(val, '异常事件类型');
console.log(StateType.value);
StateType.value = false;
if (val == 1 || val == 2 || val == 3) {
SelectType.value = val;
} else {
StateType.value = true;
}
// 运损无数据默认0
if (val == 1) {
Indexform.value.packageCode = 0;
} else {
Indexform.value.packageCode = null;
}
};
// 发现节点事件
const DiscoveringNodesChange = val => {
groundlineSet.value = false; //干线条件都不满足
if (val == 1 || val == 2 || val == 3 || val == 4 || val == 5 || val == 8 || val == 7) {
groundlineType.value = val; //干线状态
console.log(val);
} else {
groundlineSet.value = true; //展示所有搜索框
}
};
// 照片
const handleRemove = (uploadFile, uploadFiles) => {
console.log(uploadFile, uploadFiles);
};
const handlePictureCardPreview = uploadFile => {
dialogImageUrl.value = uploadFile.url;
dialogVisible.value = true;
};
// 添加包件
const AddPackage = () => {
PackageInfo.value.push({ packageCode: '', orderCode: '', waybillNumber: '' });
};
// 包件移除
const PackagRemoval = val => {
PackageInfo.value.splice(val, 1); //移除当前点击的按钮
};
// 责任方添加
const responsibleParty = () => {
FangAddList.value.push({
businessName: '',
personResponsibleName: '',
responsibilityRatio: '',
description: '',
});
};
// 责任移除
const ResponsibilityRemoval = val => {
FangAddList.value.splice(val, 1); //移除当前点击的按钮
};
// 顶部标签切换
const TopChange = val => {
console.log(val);
if (val == 0) {
identifying.value = 1;
} else {
identifying.value = 2;
}
};
// 批量打回
const BatchReturn = () => {
BatchFrom.value.businessDepartment = [];
BatchFrom.value.txt = null;
dialogReturn.value = true;
};
// 打回按钮
const ConfirmReturn = () => {
repulse.value = true; //开启加载并关闭按钮
let data = {
processorList: [],
};
// 过滤满足条件的对象
let foundObjs = warehouseData.value.filter(obj =>
BatchFrom.value.businessDepartment.includes(obj.value)
);
data['businessId'] = foundObjs.map(item => item.value).join(',');
data['businessName'] = foundObjs.map(item => item.label).join(',');
// 营业部处理
foundObjs.forEach(item => {
data['processorList'].push({ id: item.value, name: item.label });
});
data.reasonReturn = BatchFrom.value.txt; //打回原因
data.workOrderIds = [$route.query.id]; //异常工单ID
console.log(data, '处理好的值');
$_batchReturn(data)
.then(res => {
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
$router.push('/aftersales/aftersalesWorkOrder'); //打回成功跳转到列表
}
})
.catch(error => {
console.log(error, '错误信息');
})
.finally(() => {
repulse.value = false; //关闭加载并关闭按钮
dialogReturn.value = false; //关闭打回弹窗
});
};
// 少货件数对应事件
const ShortageTtems = val => {
ShortageList.value = []; //进入之前重置参数
const pattern = /\s+/g;
const result = val.replace(pattern, '');
console.log(result); // 输出 "33"
Indexform.value.number = result;
if (Indexform.value.number > 1) {
ShortageState.value = true; //数量大于1,开启弹窗输入
}
for (let i = 0; i < val; i++) {
ShortageList.value.push({
number: i + 1, //件数
packageCode: null, //输入框
});
}
};
// 少货关闭回调
const ShortageStateFun = () => {
ShortageList.value.forEach(item => {
if (item.packageCode == null) {
Indexform.value.number = null;
}
});
};
// 少货按钮取消
const ShortageCancellation = () => {
Indexform.value.number = null; //少货件数
ShortageList.value = []; //进入之前重置参数
ShortageState.value = false; //关闭弹窗
};
// 窜货关闭回调
const fleeingFun = () => {
fleeingList.value.forEach(item => {
if (item.packageCode == null) {
Indexform.value.number = null;
}
});
};
// 窜货取消事件
const fleeingCancellation = () => {
Indexform.value.number = null; //少货件数
fleeingList.value = []; //进入之前重置参数
fleeingState.value = false; //关闭弹窗
};
// 窜货输入框
const fleeingTtems = val => {
fleeingList.value = []; //进入之前重置参数
const pattern = /\s+/g;
const result = val.replace(pattern, '');
console.log(result); // 输出 "33"
Indexform.value.number = result;
if (Indexform.value.number > 1) {
fleeingState.value = true; //数量大于1,开启弹窗输入
}
for (let i = 0; i < val; i++) {
fleeingList.value.push({
number: i + 1, //件数
packageCode: null, //输入框
});
}
};
// 少货编辑
const moneyBtnA = () => {
if (!Indexform.value.number) {
ElMessage({
message: '请输入少货数量',
type: 'warning',
});
return;
}
ShortageState.value = true; //开启弹窗输入
};
// 窜货编辑
const moneyBtnB = () => {
if (!Indexform.value.number) {
ElMessage({
message: '请输入窜货数量',
type: 'warning',
});
return;
}
fleeingState.value = true; //开启弹窗输入
};
// 查询包件信息自动回显
const ChangePackageInfo = (val, index) => {
let data = {
packageCode: val,
};
$_getAbnormalPackage(data).then(res => {
console.log(res, '包件信息');
console.log(res.data.data, '包件信息');
if (res.data.data.length) {
const packageData = res.data.data[0];
PackageInfo.value[index].orderCode = packageData.orderCode; //订单自编码
PackageInfo.value[index].waybillNumber = packageData.waybillNumber; //运单号
PackageInfo.value[index].orderId = packageData.orderId; //运单号
PackageInfo.value[index].brandName = packageData.brandName; //品牌
PackageInfo.value[index].state = false; //状态
if (res.data.data.length > 1) {
HistoricalPackageList.value = res.data.data;
PackageInfo.value[index].state = true; //状态
}
}
// packageCode; //包件码
// //订单自编码
// orderCode: orderId; //运单号
// workOrderId; //工单id
// workOrderNumber; //工单名称
console.log(PackageInfo.value, '处理好的参数');
});
};
// 查看历史包件
const historicalPackages = val => {
dialogHistoricalPackage.value = true; //打开历史包件弹窗
HistorIndex.value = val;
console.log(val);
};
// 历史包件确定选择
const HistoricalPackage = val => {
let info = HistoricalPackageList.value.find(obj => obj.workOrderId == val);
PackageInfo.value[HistorIndex.value].orderCode = info.orderCode; //订单自编码
PackageInfo.value[HistorIndex.value].waybillNumber = info.waybillNumber; //运单号
PackageInfo.value[HistorIndex.value].orderId = info.orderId; //运单号
PackageInfo.value[HistorIndex.value].brandName = packageData.brandName; //品牌
dialogHistoricalPackage.value = false; //关闭历史包件弹窗
PackageInfo.value[HistorIndex.value].relatedWorkOrdersId = info.workOrderId;
console.log(PackageInfo.value, '处理好的参数');
};
// 历史包件里面的查看
const ViewPackageDetails = val => {
if (!val) {
ElMessage({
message: '请选择要查看的数据',
type: 'warning',
});
return;
}
console.log(val);
let info = HistoricalPackageList.value.find(obj => obj.workOrderId == val);
console.log(info, '筛选的值');
$router.push({
path: '/aftersales/aftersalesWorkOrderInfo',
query: {
id: info.workOrderId,
name: info.workOrderId + '-信息查看',
routerState: 'view',
},
});
dialogHistoricalPackage.value = false; //打开历史包件弹窗
};
// 回复
const addireply = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrderend',
query: {
id: $route.query.id,
name: $route.query.workOrderNumber + '-回复',
businessId: $route.query.workOrderNumber,
RouterState: 'determine',
index: '0',
},
});
};
// 新增记录跳转
const addingRecord = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrderend',
query: {
id: $route.query.id,
name: $route.query.workOrderNumber + '-添加异常记录',
businessId: $route.query.workOrderNumber,
RouterState: 'record',
index: '1',
},
});
};
// 客服仲裁完结
const CustomerServiceCompleted = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrdermodify',
query: {
id: $route.query.id,
name: $route.query.workOrderNumber + '-客服仲裁完结',
businessId: $route.query.businessId,
warehouseId: $route.query.warehouseId,
workOrderNumber: $route.query.workOrderNumber,
RouterState: 'Kfend',
CompletedEditing: 'true', //可以编辑完结信息编辑
index: '1',
},
});
};
// 编辑信息
const EditInformation = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrdermodify',
query: {
id: $route.query.id,
name: $route.query.workOrderNumber + '-编辑',
businessId: $route.query.businessId,
warehouseId: $route.query.warehouseId,
workOrderNumber: $route.query.workOrderNumber,
RouterState: 'Infoedit',
ProcessType: $route.query.ProcessType, //类型 1 待处理 2 已处理
},
});
};
const EndJump = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrderend',
query: {
id: $route.query.id,
name: $route.query.workOrderNumber + '-完结填写',
RouterState: 'end',
index: '2',
workOrderStatus: $route.query.workOrderStatus, //当前单子状态
},
});
};
// 申诉驳回
const AppealRejection = () => {
let data = {
id: $route.query.appeal, //取消申诉ID
typesOf: '2', //申诉状态
workOrderId: $route.query.id, //异常工单ID
};
$_Cancelappeal(data)
.then(res => {
console.log(res, '申诉驳回返回值');
if (res.data.code == 200) {
ElMessage({
showClose: true,
message: '申诉驳回成功',
type: 'success',
});
$useStore.commit('DEL_TAG_CURRENT'); //关闭当前页面
$router.push({
path: '/aftersales/aftersalesWorkOrder',
});
}
})
.catch(res => {
ElMessage({
showClose: true,
message: '操作失败',
type: 'success',
});
})
.finally(() => {
Pageloading.value = false; //关闭加载效果
});
};
// 申诉成立
const AppealEstablished = () => {
// 编辑信息
$router.push({
path: '/aftersales/aftersalesWorkOrdermodify',
query: {
id: $route.query.id, //这里的id是workOrderId是有申诉列表带入的
name: $route.query.workOrderNumber + '-申诉编辑',
businessId: $route.query.businessId,
warehouseId: $route.query.warehouseId,
workOrderNumber: $route.query.workOrderNumber,
RouterState: 'Kfend',
Appealeditor: 'appeal', //申诉编辑
appealID: $route.query.appealID, //申诉ID
},
});
};
</script>
<style scoped lang="scss">
.IndexFrom {
display: flex;
flex-wrap: wrap;
justify-content: flex-start;
border: 1px solid #dcdfe6;
.el-form-item {
height: 46px;
display: flex;
align-items: center;
margin: 0;
margin-bottom: 18px;
flex: 1 0 30%;
:deep(.el-form-item__label) {
width: 100px !important;
justify-content: flex-start;
}
}
:deep(.el-form-item__content) {
height: 100%;
width: 70% !important;
flex: none;
.el-input {
height: 100% !important;
display: flex;
align-items: center;
}
}
.el-input__wrapper {
height: 32px !important;
}
:deep(.el-input) {
width: 100% !important;
}
:deep(.el-input__wrapper) {
height: 30px !important;
}
:deep(.el-select) {
width: 100%;
}
:deep(.el-form-item__label) {
margin-left: 20px;
}
}
.el_clzr {
margin-top: 40px;
:deep(.el-select) {
width: 100%;
}
:deep(.el-input) {
height: 38px;
}
:deep(.el-form-item__label) {
margin-left: 20px;
font-size: 14px;
width: 100px !important;
justify-content: flex-start;
}
.el-form-item {
margin: 0;
margin-bottom: 34px;
}
:deep(.el-input__wrapper) {
height: 35px !important;
}
:deep(.el-form-item__content) {
height: 100%;
width: 90% !important;
flex: none;
.el-input {
height: 100% !important;
display: flex;
align-items: center;
}
}
}
.Transport_damage_photos {
display: flex;
padding: 0 15px;
margin-top: 20px;
.title {
width: 100px;
display: block;
margin-bottom: 10px;
font-size: 14px;
}
:deep(.el-upload-dragger) {
display: flex;
justify-content: center;
align-items: center;
}
}
.dialog-footer {
width: 100%;
display: flex;
justify-content: flex-end;
padding: 0 10px;
box-sizing: border-box;
padding-right: 36px;
}
.investigate {
:deep(.el-form-item__content) {
width: 90% !important;
box-sizing: border-box;
}
}
.ShortageStatenum {
display: flex;
align-items: center;
margin-bottom: 10px;
.title {
width: 80px;
}
.remove {
width: 47px;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
color: #ff0000;
}
}
.moneyNum {
display: flex;
flex: 1;
.el_btn {
width: 50px;
display: flex;
align-items: center;
justify-content: center;
border: 1px solid #ccc;
margin-left: 3px;
border-radius: 4px;
cursor: pointer;
}
}
.ResponsibilityBox {
width: 100%;
display: flex;
flex-direction: column;
.leftbox {
width: 80%;
display: flex;
justify-content: space-between;
}
.maxBox {
display: flex;
align-items: center;
width: 30%;
margin-right: 16px;
.title {
width: 130px;
font-size: 14px;
color: #606266;
}
.el-select {
width: 100%;
}
}
.el-btn {
margin-left: 5%;
border: none;
}
.el_btbox {
display: flex;
margin-top: 10px;
}
}
.ResponsibilityBoxS {
width: 100%;
display: flex;
flex-direction: column;
margin-bottom: 10px;
.leftbox {
width: 80%;
display: flex;
justify-content: space-between;
}
.maxBox {
display: flex;
align-items: center;
width: 30%;
margin-right: 20px;
.title {
width: 140px;
color: #606266;
font-size: 14px;
}
.el-select {
width: 100%;
}
}
.el-btn {
margin-left: 5%;
border: none;
}
.el_btbox {
display: flex;
margin-top: 10px;
}
}
.PackageInformation {
margin-bottom: 10px;
}
.NumTotal {
width: 30%;
margin-top: 16px;
display: flex;
align-items: center;
span {
width: 120px;
font-size: 14px;
}
}
.Proportion {
margin-top: 16px;
.title {
font-size: 14px;
color: #606266;
}
}
:deep(.is-active) {
border-bottom: 1px solid #e4e7ed !important;
}
.topClass {
:deep(.el-tabs__content) {
padding: 0;
}
}
.foot_btn {
width: 100%;
position: fixed;
bottom: 0;
left: 50%;
height: 40px;
display: flex;
align-items: center;
}
:deep(.el-card__body) {
margin-bottom: 50px;
}
.ProcessingResults {
width: 100%;
min-height: 260px;
border: 1px solid #ccc;
position: relative;
padding: 26px;
box-sizing: border-box;
margin-top: 20px;
color: #606266;
display: flex;
flex-direction: column;
justify-content: space-between;
margin-bottom: 16px;
.title {
position: absolute;
top: -20px;
left: 20px;
font-size: 26px;
background-color: #fff;
}
.Listadmiration {
display: flex;
flex-wrap: wrap;
margin-top: 26px;
justify-content: space-between;
.name {
display: flex;
margin-bottom: 20px;
height: 30px;
width: 46%;
margin-right: 38px;
:deep(.el-input-number) {
width: 220px;
}
span {
display: block;
width: 30%;
color: #606266;
font-size: 16px;
display: flex;
align-items: center;
justify-content: center;
}
}
}
.lptime,
.ZFlptime {
display: flex;
.name {
width: 10%;
color: #606266;
:deep(.el-input--prefix) {
width: 200px;
}
}
:deep(.el-input) {
width: auto;
}
}
.ZFlptime {
margin: 10px 0;
}
}
.Paymentname {
display: flex;
justify-content: center;
align-items: center;
border: 1px solid #bfbfbf;
margin-left: 2px;
border-radius: 4px;
font-size: 14px;
padding: 10px;
cursor: pointer;
width: 200px;
margin: 0 10px;
}
.Paymentname:hover {
border: 1px solid #172e60;
}
.el_resj {
margin-top: 20px !important;
:deep(.el-form-item__label) {
justify-content: flex-start;
margin-left: 20px;
font-size: 14px;
width: 100px !important;
}
}
.lptime {
height: 30px !important;
}
:deep(.el-image) {
width: 100% !important;
height: 300px !important;
}
:deep(.el-input) {
height: 100% !important;
}
.el_PaymentUnit {
display: flex;
align-items: center;
margin-right: 6px;
span {
display: flex;
width: 80px !important;
align-items: center;
}
:deep(.el-input) {
width: 150px;
}
}
.el-endtabs {
margin-top: 26px;
}
.payanindemnity {
display: flex;
align-items: center;
margin-top: 20px;
justify-content: space-between;
.title {
width: 126px;
height: 100%;
display: flex;
display: block;
align-items: center;
}
.sk_input {
margin: 0 5px;
margin-left: 20px;
width: 20%;
}
.el-button {
border: none;
}
.el_pkLi {
display: flex;
width: 100%;
}
}
:deep(.custom-tabs-label) {
display: flex;
align-items: center;
}
.paySum {
margin-top: 36px;
font-size: 14px;
display: flex;
span {
margin-right: 30px;
display: flex;
align-items: center;
}
}
</style>