2024-09-11 15:55:28 +08:00
|
|
|
|
<template>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
<view class="content">
|
|
|
|
|
<view class="top-heder">
|
|
|
|
|
<view class="t-left" @click="getback()">
|
|
|
|
|
<uni-icons type="left" size="18"></uni-icons>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="t-title">
|
|
|
|
|
<text>检测详情</text>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="t-you"></view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="x-box">
|
|
|
|
|
<view class="box-dis">
|
|
|
|
|
<view class="shop-img">
|
|
|
|
|
<image :src="baseImageUrl+detailData.goodsImage" mode=""></image>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="ds-right">
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<view class="h-title">{{ detailData.carNum }}</view>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
<view class="dis-hui">
|
|
|
|
|
<text>车型:</text>
|
|
|
|
|
<text>{{ detailData.carType }}</text>
|
|
|
|
|
</view>
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<!-- <view class="dis-hui">-->
|
|
|
|
|
<!-- <text>预约人:</text>-->
|
|
|
|
|
<!-- <text>{{ detailData.buyUserName }}</text>-->
|
|
|
|
|
<!-- </view>-->
|
|
|
|
|
<!-- <view class="dis-hui">-->
|
|
|
|
|
<!-- <text>手机号:</text>-->
|
|
|
|
|
<!-- <text>{{ detailData.buyUserPhone }}</text>-->
|
|
|
|
|
<!-- </view>-->
|
|
|
|
|
<!-- <view class="dis-hui" style="display: flex; justify-content: space-between; align-items: center;">-->
|
|
|
|
|
<!-- <text>引车员:</text>-->
|
|
|
|
|
<!-- <text>{{ detailData.leadManName }}</text>-->
|
|
|
|
|
<!-- <text style="margin-left: auto; color: blue;" @tap="selectLeadMan">更换引车员</text>-->
|
|
|
|
|
<!-- </view>-->
|
|
|
|
|
|
|
|
|
|
|
2024-11-15 17:48:16 +08:00
|
|
|
|
<view class="dis-hui">
|
2024-12-09 11:04:54 +08:00
|
|
|
|
<text>检测类型:</text>
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<text>{{ detailData.goodsName }}</text>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
</view>
|
|
|
|
|
<view class="dis-hui">
|
2024-12-09 11:04:54 +08:00
|
|
|
|
<text>¥:</text>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
<text>{{ detailData.goodsPrice / 100 }}元</text>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<view class="r-two-box">
|
|
|
|
|
<view class="h-two-box"
|
|
|
|
|
style="margin-bottom: 10px;border-bottom: 1px solid #DDDDDD;box-sizing: border-box;padding-bottom: 10px">
|
|
|
|
|
|
|
|
|
|
<view class="h-two-l">
|
|
|
|
|
<view class="h_title"> 引车员</view>
|
|
|
|
|
<view class="h_name">{{ detailData.leadManName }}</view>
|
|
|
|
|
</view>
|
2024-12-11 15:44:14 +08:00
|
|
|
|
<view v-if="isChangeLeadMan" class="h-two-r" @tap="selectLeadMan">
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<image src="../..//static/imgs/t_.png" mode=""></image>
|
|
|
|
|
<text>更换引车员</text>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="h-two-box">
|
|
|
|
|
<view class="h-two-l">
|
|
|
|
|
<view class="h_title"> 客户信息</view>
|
|
|
|
|
<view class="h_name">{{ detailData.buyUserName }} {{ detailData.buyUserPhone }}</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="h-two-r" @click="callUser(detailData.buyUserPhone)">
|
|
|
|
|
<image src="../..//static/imgs/b_.png" mode=""></image>
|
|
|
|
|
<text>拨打电话</text>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
</view>
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<view class="box-top">
|
|
|
|
|
<view style=" width: 100%;">
|
|
|
|
|
<!-- <view class="touxiang" v-if="!detailData.workerAvatar">-->
|
|
|
|
|
<!-- <image src="../../static/detection/touxiang.png" mode=""></image>-->
|
|
|
|
|
<!-- </view>-->
|
|
|
|
|
<!-- <view class="touxiang" v-else>-->
|
|
|
|
|
<!-- <image :src="baseImageUrl+detailData.workerAvatar" mode=""></image>-->
|
|
|
|
|
<!-- </view>-->
|
|
|
|
|
<!-- <view class="sanniu">-->
|
|
|
|
|
<!-- <text>{{ detailData.workerName }}</text>-->
|
|
|
|
|
<!-- </view>-->
|
|
|
|
|
<view class="steps-container">
|
|
|
|
|
<view
|
|
|
|
|
v-for="(item, index) in detailData.workNodes"
|
|
|
|
|
:key="index"
|
|
|
|
|
class="step-item"
|
|
|
|
|
>
|
|
|
|
|
<!-- 圆形图标 -->
|
|
|
|
|
<view
|
|
|
|
|
class="step-circle"
|
|
|
|
|
:class="{'circle-blue': item.type === '1', 'circle-yellow': item.type === '0'}">
|
|
|
|
|
</view>
|
|
|
|
|
<!-- 项目信息 -->
|
|
|
|
|
<view class="step-content">{{ item.projectName }}</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
<!-- <view class="bd-tel" >-->
|
|
|
|
|
<!-- <uni-icons type="phone" color="#0D2E8D" size="16"></uni-icons>-->
|
|
|
|
|
<!-- <text>联系用户</text>-->
|
|
|
|
|
<!-- </view>-->
|
2024-11-15 17:48:16 +08:00
|
|
|
|
</view>
|
|
|
|
|
<view class="x-box" v-if="roleSelect == 'shop'">
|
|
|
|
|
<view class="h-title">订单详情</view>
|
|
|
|
|
<!-- <view class="on-input">-->
|
|
|
|
|
<!-- <view class="o-left">订单编号:</view>-->
|
|
|
|
|
<!-- <view class="o-right">{{ detailData.orderNo }}</view>-->
|
|
|
|
|
<!-- </view>-->
|
|
|
|
|
<view class="on-input">
|
|
|
|
|
<view class="o-left">折扣:</view>
|
|
|
|
|
<view class="o-right">{{ detailData.reduceMoney / 100 }}</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="on-input">
|
|
|
|
|
<view class="o-left">优惠金额:</view>
|
|
|
|
|
<view class="o-right">{{ detailData.couponDiscount / 100 }}</view>
|
|
|
|
|
</view>
|
|
|
|
|
<!-- <view class="on-input">-->
|
|
|
|
|
<!-- <view class="o-left">核销人:</view>-->
|
|
|
|
|
<!-- <view class="o-right">{{ detailData.validationRealName }}</view>-->
|
|
|
|
|
<!-- </view>-->
|
|
|
|
|
<!-- <view class="on-input">-->
|
|
|
|
|
<!-- <view class="o-left">核销时间:</view>-->
|
|
|
|
|
<!-- <view class="o-right">{{ detailData.validationTime }}</view>-->
|
|
|
|
|
<!-- </view>-->
|
|
|
|
|
<view class="bottomxx" v-if="isOnline&&isOnline==0&&orderStatus&&orderStatus==0" @click="xling = true">
|
|
|
|
|
<view class="">结算</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="bottom-input">
|
|
|
|
|
<view class="o-left">实付金额:</view>
|
|
|
|
|
<view class="o-zui">{{ (detailData.payMoney + detailData.balance) / 100 }}元</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<view class="" style="margin-bottom: 10px" v-for="(item,index) in detailData.stepInfos" :key="index">
|
|
|
|
|
|
|
|
|
|
<view class="p_titel" style="display: flex;justify-content: space-between;">
|
|
|
|
|
<view style="margin-right: -15px; display: flex; ">
|
|
|
|
|
<view class="qiu_">{{ index + 1 }}</view>
|
|
|
|
|
<view style="margin-left: 10px">
|
|
|
|
|
<view class="jc_title">
|
|
|
|
|
{{ item.title }}
|
|
|
|
|
</view>
|
|
|
|
|
<view class="jc_name">施工人员:
|
|
|
|
|
{{ item.nickname }}
|
|
|
|
|
</view>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-12-09 13:35:17 +08:00
|
|
|
|
<text class="times" v-if="!item.updateTime">{{ item.createTime }}</text>
|
|
|
|
|
<text class="times" v-else style="text-align: center">{{ item.createTime }}<br/><text>至</text><br/>{{item.updateTime}}</text>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
|
2024-11-25 16:48:58 +08:00
|
|
|
|
</view>
|
|
|
|
|
<view class="p_box" v-if="index+1 <detailData.stepInfos.length || (item.images.length > 0 || item.content)">
|
2024-11-15 17:48:16 +08:00
|
|
|
|
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<view class="g_hui" v-if="item.images.length > 0 || item.content">
|
|
|
|
|
<view style="margin-bottom: 10px; box-sizing: border-box;" v-if="item.content">{{ item.content }}</view>
|
|
|
|
|
<view style="display: flex" v-if="item.images">
|
|
|
|
|
<u-album :urls="item.imageList" :singleSize="70"></u-album>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-11-25 16:48:58 +08:00
|
|
|
|
|
|
|
|
|
|
2024-11-15 17:48:16 +08:00
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
</view>
|
2024-12-11 15:18:36 +08:00
|
|
|
|
<view class="annniu" v-if="detailData.status&&(detailData.status == 0 || detailData.status == 2)&&workNodeStatus == 1"
|
2024-11-15 17:48:16 +08:00
|
|
|
|
@click="hge = true;getProject()">
|
|
|
|
|
<view class="">结束检测</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="annniu"
|
|
|
|
|
v-if="detailData.status&&detailData.status == 1&&detailData.isPass&&detailData.isPass ==1&&detailData.makeCert!=1"
|
|
|
|
|
@click="dialogToggle">
|
|
|
|
|
<view class="">制证完成</view>
|
|
|
|
|
</view>
|
|
|
|
|
<u-picker :show="show" :columns="columns" keyName="label" @close="close" @confirm="confirm" @change="change"
|
|
|
|
|
@cancel="cancel"></u-picker>
|
|
|
|
|
<u-popup :show="hge" @close="closehge" :round="10" @open="openxl">
|
|
|
|
|
<view class="popup-box">
|
|
|
|
|
<view class="on-inputx">
|
2024-12-09 10:40:21 +08:00
|
|
|
|
<text>备注:</text>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
<!-- <input type="text" placeholder="请输入内容"> -->
|
|
|
|
|
</view>
|
|
|
|
|
<u--textarea v-model="remark" placeholder="请输入内容" border="bottom"></u--textarea>
|
|
|
|
|
<view class="on-inputx">
|
|
|
|
|
<text>施工图片:</text>
|
|
|
|
|
<!-- <input type="text" placeholder="请输入内容"> -->
|
|
|
|
|
</view>
|
|
|
|
|
<u-upload :fileList="fileList1" @afterRead="afterRead" @delete="deletePic" name="1" multiple
|
|
|
|
|
:maxCount="10"></u-upload>
|
|
|
|
|
|
|
|
|
|
<view class="t-title">是否合格</view>
|
|
|
|
|
<view class="on-inputx">
|
|
|
|
|
<view class="anniu" :class="{'an':geindex == index}" v-for="(item,index) in sfou" :key="index"
|
|
|
|
|
@click="Nnimamadewen(item.value,index)">
|
|
|
|
|
<text>{{ item.text }}</text>
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
</view>
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<view v-if="isExamine">
|
|
|
|
|
<view class="t-title" v-if="geindex == 1">重审/退办</view>
|
|
|
|
|
<view class="on-inputx" v-if="geindex == 1">
|
|
|
|
|
<view class="anniu" :class="{'an':isRetrial == item.value}" v-for="(item,index) in cstb"
|
|
|
|
|
:key="index" @click="shenmowanyi(item.value,index)">
|
|
|
|
|
<text>{{ item.text }}</text>
|
|
|
|
|
</view>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
</view>
|
2024-11-25 16:48:58 +08:00
|
|
|
|
<view class="t-title" v-if="tbindex == 1 && isRetrial == 1 && isPass != '1'">选择复检的项目</view>
|
|
|
|
|
<view class="box_ on-inputx" v-if="tbindex == 1 && isRetrial == 1 && isPass != '1'">
|
|
|
|
|
<view class="box_button " :class="{ 'box_button_x' :csId.includes(item.id) }"
|
|
|
|
|
v-for="item in selectProject" @click="clickProject(item)">{{ item.projectName }}
|
|
|
|
|
</view>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="bottomx" @click="submit()">
|
|
|
|
|
<uni-icons type="compose" color="#0D2E8D" size="20"></uni-icons>
|
|
|
|
|
<text>提交</text>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</u-popup>
|
|
|
|
|
<u-popup :show="xling" @close="closexl" :round="10" @open="openxl">
|
|
|
|
|
<view class="popup-box">
|
|
|
|
|
<view class="t-title">线下订单</view>
|
|
|
|
|
|
|
|
|
|
<view class="on-inputx">
|
|
|
|
|
<text>商品价格:</text>
|
|
|
|
|
<text>{{ detailData.goodsPrice / 100 }}元</text>
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
<view class="on-inputx">
|
|
|
|
|
<text>优惠金额:</text>
|
|
|
|
|
<input type="number" v-model="reduceMoney" @input="jisuan" placeholder="请输入优惠金额">
|
|
|
|
|
</view>
|
|
|
|
|
<view class="on-inputx">
|
|
|
|
|
|
|
|
|
|
<text>
|
|
|
|
|
<text style="color: red;font-weight: bold;text-align: center;">*</text>
|
|
|
|
|
实付金额:
|
|
|
|
|
</text>
|
|
|
|
|
<input type="number" v-model="payMoney" placeholder="请输入实付金额">
|
|
|
|
|
</view>
|
|
|
|
|
<view class="on-inputx">
|
|
|
|
|
<text>
|
|
|
|
|
<text style="color: red;font-weight: bold;text-align: center;">*</text>
|
|
|
|
|
付款方式:
|
|
|
|
|
</text>
|
|
|
|
|
|
|
|
|
|
</view>
|
|
|
|
|
<view class="warp-box">
|
|
|
|
|
|
|
|
|
|
<view class="lan-box" :class=" {'lantong':payType == item.value } " v-for="(item,index) in shelist"
|
|
|
|
|
:key="index" @click="xuanxiaolan(item)">
|
|
|
|
|
{{ item.label }}
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="on-inputx">
|
|
|
|
|
<text>收款账号:</text>
|
|
|
|
|
<input type="text" @click="bankShow = true" v-model="receivablesAccount" placeholder="请输入收款账号">
|
|
|
|
|
</view>
|
|
|
|
|
<view class="on-inputx">
|
|
|
|
|
<text>备注:</text>
|
|
|
|
|
|
|
|
|
|
</view>
|
|
|
|
|
<u--textarea v-model="payRemark" placeholder="如果存在组合付款方式,请在备注中描述清楚"
|
|
|
|
|
border="bottom"></u--textarea>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<view class="bottomx" @click="tiijiao()" style="margin-top: 10px;">
|
|
|
|
|
<uni-icons type="compose" color="#0D2E8D" size="20"></uni-icons>
|
|
|
|
|
<text>提交</text>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</u-popup>
|
|
|
|
|
<u-picker :show="bankShow" :columns="bankList" @confirm="chooseBank" @cancel="bankShow=false"
|
|
|
|
|
keyName="label"></u-picker>
|
2024-11-18 17:58:28 +08:00
|
|
|
|
<u-picker :show="showLeadMan" :columns="leadManList" :defaultIndex="defaultIndex" @confirm="confirmLeadMan"
|
|
|
|
|
@cancel="cancelLeadMan"
|
|
|
|
|
keyName="nickname"></u-picker>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
|
|
|
|
|
<uni-popup ref="alertDialog" type="dialog">
|
|
|
|
|
<uni-popup-dialog cancelText="关闭" confirmText="确定" title="通知" content="您确定制证完成吗"
|
|
|
|
|
@confirm="dialogConfirm"
|
|
|
|
|
@close="dialogClose"></uni-popup-dialog>
|
|
|
|
|
</uni-popup>
|
|
|
|
|
</view>
|
2024-09-11 15:55:28 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
2024-11-15 17:48:16 +08:00
|
|
|
|
import config from '@/config'
|
|
|
|
|
import request from '../../utils/request';
|
|
|
|
|
import upload from '@/utils/upload.js'
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
baseImageUrl: this.$baseImageUrl,
|
|
|
|
|
reduceMoney: null,
|
|
|
|
|
payMoney: null,
|
|
|
|
|
payType: '',
|
|
|
|
|
receivablesAccount: '',
|
|
|
|
|
orderStatus: null,
|
|
|
|
|
payRemark: '',
|
|
|
|
|
bankList: [],
|
|
|
|
|
bankShow: false,
|
|
|
|
|
isRetrial: 1,
|
2024-11-18 17:58:28 +08:00
|
|
|
|
showLeadMan: false,
|
2024-11-15 17:48:16 +08:00
|
|
|
|
tbindex: 1,
|
|
|
|
|
isOnline: 1,
|
|
|
|
|
hge: false,
|
|
|
|
|
roleSelect: '',
|
|
|
|
|
orImages: false,
|
|
|
|
|
show: false,
|
|
|
|
|
xling: false,
|
2024-11-18 17:58:28 +08:00
|
|
|
|
leadManList: [],
|
2024-11-15 17:48:16 +08:00
|
|
|
|
baseUrl: this.$baseUrl,
|
|
|
|
|
geindex: 0,
|
|
|
|
|
detailData: {},
|
|
|
|
|
inspectionInfoId: '',
|
|
|
|
|
workNodeId: '',
|
|
|
|
|
workNodeStatus: '',
|
|
|
|
|
stepInfo: {
|
|
|
|
|
isPass: "0"
|
|
|
|
|
},
|
|
|
|
|
selectProject: [],
|
|
|
|
|
lei: '请选择车辆类型',
|
2024-11-18 17:58:28 +08:00
|
|
|
|
defaultIndex: [0],
|
2024-11-15 17:48:16 +08:00
|
|
|
|
columns: [],
|
2024-11-25 16:48:58 +08:00
|
|
|
|
isExamine: false,
|
2024-11-15 17:48:16 +08:00
|
|
|
|
cph: '',
|
|
|
|
|
fileList1: [],
|
|
|
|
|
fileList2: [],
|
|
|
|
|
shelist: [],
|
2024-11-25 16:48:58 +08:00
|
|
|
|
type: 1,
|
2024-11-15 17:48:16 +08:00
|
|
|
|
isPass: "1",
|
|
|
|
|
remark: '',
|
|
|
|
|
csId: [],
|
|
|
|
|
sfou: [{
|
|
|
|
|
text: '合格',
|
|
|
|
|
value: "1"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
text: '不合格',
|
|
|
|
|
value: "0"
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
cstb: [{
|
|
|
|
|
text: '重检',
|
|
|
|
|
value: "2"
|
|
|
|
|
}, {
|
|
|
|
|
text: '复检',
|
|
|
|
|
value: "1"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
text: '退办理',
|
|
|
|
|
value: "0"
|
|
|
|
|
},
|
2024-12-11 15:44:14 +08:00
|
|
|
|
],
|
|
|
|
|
isChangeLeadMan: false,
|
2024-11-15 17:48:16 +08:00
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
onLoad(option) {
|
|
|
|
|
this.inspectionInfoId = option.inspectionInfoId
|
|
|
|
|
this.workNodeId = option.workNodeId
|
|
|
|
|
this.workNodeStatus = option.workNodeStatus
|
2024-11-25 16:48:58 +08:00
|
|
|
|
if (this.workNodeStatus == '1') {
|
|
|
|
|
this.isExamines()
|
|
|
|
|
}
|
2024-12-11 15:44:14 +08:00
|
|
|
|
if (this.inspectionInfoId){
|
|
|
|
|
this.judgeUpdateLeadMan()
|
|
|
|
|
}
|
2024-11-15 17:48:16 +08:00
|
|
|
|
},
|
|
|
|
|
onShow() {
|
|
|
|
|
this.getindex()
|
|
|
|
|
uni.getStorage({
|
|
|
|
|
key: 'roleSelect',
|
|
|
|
|
success: (res) => {
|
|
|
|
|
this.roleSelect = res.data
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
2024-12-11 15:44:14 +08:00
|
|
|
|
judgeUpdateLeadMan(){
|
|
|
|
|
request({
|
|
|
|
|
url: '/system/info/judgeUpdateLeadMan?id=' + this.inspectionInfoId,
|
|
|
|
|
method: 'get'
|
|
|
|
|
}).then(res => {
|
|
|
|
|
this.isChangeLeadMan = res.data
|
|
|
|
|
})
|
|
|
|
|
},
|
2024-11-15 17:48:16 +08:00
|
|
|
|
chooseBank(e) {
|
|
|
|
|
this.receivablesAccount = e.value[0]
|
|
|
|
|
this.bankShow = false
|
|
|
|
|
},
|
|
|
|
|
dialogToggle() {
|
|
|
|
|
this.$refs.alertDialog.open()
|
|
|
|
|
},
|
|
|
|
|
async dialogConfirm() {
|
|
|
|
|
let data = {
|
|
|
|
|
inspectionId: this.inspectionId
|
|
|
|
|
}
|
|
|
|
|
let res = await request({
|
|
|
|
|
url: '/partnerOwn/partner/makeCertOk',
|
|
|
|
|
method: 'post',
|
|
|
|
|
params: data
|
|
|
|
|
})
|
|
|
|
|
if (res.code == 200) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: '操作成功'
|
|
|
|
|
})
|
|
|
|
|
this.getindex()
|
|
|
|
|
this.$refs.alertDialog.close()
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
dialogClose() {
|
|
|
|
|
this.$refs.alertDialog.close()
|
|
|
|
|
},
|
2024-11-18 17:58:28 +08:00
|
|
|
|
selectLeadMan() {
|
|
|
|
|
this.getLeadeMan();
|
|
|
|
|
this.showLeadMan = true
|
|
|
|
|
},
|
|
|
|
|
/*获取引车员信息*/
|
|
|
|
|
getLeadeMan() {
|
|
|
|
|
this.leadManList = []
|
|
|
|
|
request({
|
|
|
|
|
url: '/system/role/getUsersByRoleCode',
|
|
|
|
|
method: 'get',
|
|
|
|
|
params: {
|
|
|
|
|
code: "jcycy"
|
|
|
|
|
}
|
|
|
|
|
}).then(res => {
|
|
|
|
|
this.leadManList.push(res.data)
|
|
|
|
|
let result = this.leadManList
|
|
|
|
|
.map((subArray, subArrayIndex) => {
|
|
|
|
|
const index = subArray.findIndex(item => item.id === this.detailData.leadManId);
|
|
|
|
|
if (index !== -1) {
|
|
|
|
|
// 返回的是子数组的索引和匹配项的索引
|
|
|
|
|
return {subArrayIndex, itemIndex: index};
|
|
|
|
|
} else {
|
|
|
|
|
// 没有找到匹配项,返回 null 或 undefined
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.filter(item => item !== null); // 过滤掉没有匹配的项
|
|
|
|
|
let index = result[0].itemIndex
|
|
|
|
|
// let subArrayIndex = result[0].subArrayIndex
|
|
|
|
|
this.defaultIndex = [index]
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
cancelLeadMan() {
|
|
|
|
|
this.showLeadMan = false
|
|
|
|
|
},
|
|
|
|
|
confirmLeadMan(e) {
|
|
|
|
|
this.nickname = e.value[0].nickname
|
|
|
|
|
this.leadManId = e.value[0].id
|
|
|
|
|
this.showLeadMan = false
|
|
|
|
|
let data = {
|
|
|
|
|
partnerId: uni.getStorageSync('partnerId'),
|
|
|
|
|
id: this.inspectionId,
|
|
|
|
|
leadManId: this.leadManId
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
request({
|
|
|
|
|
url: '/system/info/updateLeadMan',
|
|
|
|
|
method: 'post',
|
|
|
|
|
data: data
|
|
|
|
|
}).then(res => {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: '修改成功'
|
|
|
|
|
})
|
|
|
|
|
this.getindex()
|
|
|
|
|
})
|
|
|
|
|
},
|
2024-11-25 16:48:58 +08:00
|
|
|
|
//判断当前登陆人是否有重检重审和退办理的权限
|
|
|
|
|
isExamines() {
|
|
|
|
|
request({
|
|
|
|
|
url: '/system/info/isExamine',
|
|
|
|
|
method: 'get'
|
|
|
|
|
}).then(res => {
|
|
|
|
|
this.isExamine = res.data
|
|
|
|
|
})
|
|
|
|
|
},
|
2024-11-15 17:48:16 +08:00
|
|
|
|
//查询重审可以选择的项目
|
|
|
|
|
getProject() {
|
|
|
|
|
request({
|
|
|
|
|
url: '/system/info/getWeorkNodesById',
|
|
|
|
|
method: 'get',
|
|
|
|
|
params: {
|
|
|
|
|
inspectionId: this.inspectionId
|
|
|
|
|
}
|
|
|
|
|
}).then(res => {
|
|
|
|
|
this.selectProject = res.data
|
|
|
|
|
//查询当前是否是第一个节点或最后一个节点
|
|
|
|
|
// let data = {
|
|
|
|
|
// inspectionId: this.inspectionId,
|
|
|
|
|
// workNodeId: this.workNodeId
|
|
|
|
|
// }
|
|
|
|
|
// request({
|
|
|
|
|
// url: '/system/info/orImages',
|
|
|
|
|
// method: 'get',
|
|
|
|
|
// params: data
|
|
|
|
|
// }).then(res => {
|
|
|
|
|
// this.orImages = res.data
|
|
|
|
|
// })
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
jisuan() {
|
|
|
|
|
if (this.reduceMoney > (this.detailData.goodsPrice / 100)) {
|
|
|
|
|
this.reduceMoney = this.detailData.goodsPrice / 100
|
|
|
|
|
}
|
|
|
|
|
this.payMoney = (this.detailData.goodsPrice / 100) - this.reduceMoney
|
|
|
|
|
},
|
|
|
|
|
async tiijiao() {
|
|
|
|
|
|
|
|
|
|
if (!this.payMoney || !this.payType) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: '实付金额与付款方式不能为空!',
|
|
|
|
|
icon: 'none'
|
|
|
|
|
})
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
let data = {
|
|
|
|
|
reduceMoney: this.reduceMoney ? this.reduceMoney * 100 : 0,
|
|
|
|
|
payMoney: this.payMoney * 100,
|
|
|
|
|
payType: this.payType,
|
|
|
|
|
receivablesAccount: this.receivablesAccount,
|
|
|
|
|
payRemark: this.payRemark,
|
|
|
|
|
inspectionId: this.inspectionId,
|
|
|
|
|
}
|
|
|
|
|
let res = await request({
|
|
|
|
|
url: '/partnerOwn/partner/offlineCharging',
|
|
|
|
|
method: 'post',
|
|
|
|
|
data: data
|
|
|
|
|
})
|
|
|
|
|
if (res.code = 200) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: "提交成功"
|
|
|
|
|
})
|
|
|
|
|
this.getindex()
|
|
|
|
|
this.xling = false
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
callUser(phone) {
|
|
|
|
|
uni.makePhoneCall({
|
|
|
|
|
phoneNumber: phone //仅为示例
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
async submit() {
|
|
|
|
|
let inspectionInfo = {
|
|
|
|
|
inspectionInfoId: this.inspectionInfoId,
|
|
|
|
|
isPass: this.isPass,
|
|
|
|
|
id: this.workNodeId,
|
|
|
|
|
remark: this.remark,
|
|
|
|
|
dealImages: this.fileList2.join(","),
|
2024-11-25 16:48:58 +08:00
|
|
|
|
type: this.type,
|
2024-11-15 17:48:16 +08:00
|
|
|
|
}
|
|
|
|
|
let status = 0
|
|
|
|
|
if (this.isPass == '1') {
|
|
|
|
|
status = 3
|
2024-11-25 16:48:58 +08:00
|
|
|
|
} else if (this.isExamine && this.tbindex == 1 && this.isRetrial == 1) {
|
2024-11-15 17:48:16 +08:00
|
|
|
|
if (this.csId == '' || this.csId == undefined) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: '请选择要复检的项目',
|
|
|
|
|
icon: 'none'
|
|
|
|
|
})
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
const workNodes = []
|
|
|
|
|
this.csId.forEach(item => {
|
|
|
|
|
let a = {
|
2024-12-11 15:18:36 +08:00
|
|
|
|
id: item,
|
|
|
|
|
status: "3"
|
2024-11-11 18:05:03 +08:00
|
|
|
|
}
|
2024-11-15 17:48:16 +08:00
|
|
|
|
workNodes.push(a)
|
|
|
|
|
})
|
|
|
|
|
inspectionInfo.workNodes = workNodes
|
|
|
|
|
await request({
|
|
|
|
|
url: '/system/info/recheck',
|
|
|
|
|
method: 'post',
|
|
|
|
|
data: inspectionInfo
|
|
|
|
|
})
|
2024-11-18 17:58:28 +08:00
|
|
|
|
uni.navigateBack();
|
2024-11-15 17:48:16 +08:00
|
|
|
|
return
|
2024-11-25 16:48:58 +08:00
|
|
|
|
} else if (this.isExamine && this.tbindex == 2 && this.isRetrial == 2) {
|
2024-11-15 17:48:16 +08:00
|
|
|
|
//跳转到修改工单页面
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages/index/Neworder?inspectionInfoId=' + this.inspectionInfoId
|
|
|
|
|
})
|
|
|
|
|
return
|
2024-11-18 17:58:28 +08:00
|
|
|
|
} else if (this.tbindex == 0 && this.isRetrial == 0) {
|
2024-11-15 17:48:16 +08:00
|
|
|
|
status = 1
|
|
|
|
|
}
|
|
|
|
|
inspectionInfo.selectType = status
|
|
|
|
|
|
|
|
|
|
let res = await request({
|
|
|
|
|
// url: '/partnerOwn/partner/stopInspection',
|
|
|
|
|
url: '/system/info/controls',
|
|
|
|
|
method: 'post',
|
|
|
|
|
data: inspectionInfo
|
|
|
|
|
})
|
|
|
|
|
if (res.code == 200) {
|
|
|
|
|
this.getindex()
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: "成功",
|
|
|
|
|
})
|
|
|
|
|
uni.navigateBack();
|
|
|
|
|
}
|
|
|
|
|
if (res.code == 500) {
|
|
|
|
|
uni.navigateBack();
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
closehge() {
|
|
|
|
|
this.hge = false
|
|
|
|
|
},
|
|
|
|
|
async addStepInfo() {
|
|
|
|
|
this.stepInfo.images = this.fileList2.join(",")
|
|
|
|
|
this.stepInfo.inspectionInfoId = this.inspectionInfoId
|
|
|
|
|
let res = await request({
|
|
|
|
|
url: '/partnerOwn/partner/addStepInfo',
|
|
|
|
|
method: 'post',
|
|
|
|
|
data: this.stepInfo
|
|
|
|
|
|
|
|
|
|
})
|
|
|
|
|
if (res.code == 200) {
|
|
|
|
|
this.fileList1 = []
|
|
|
|
|
this.fileList2 = []
|
|
|
|
|
this.stepInfo = {}
|
|
|
|
|
this.xling = false
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: "成功",
|
|
|
|
|
})
|
|
|
|
|
this.getindex()
|
|
|
|
|
|
|
|
|
|
uni.reLaunch({
|
|
|
|
|
url: '/pages/index/ordermanage'
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
if (res.code == 500) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: "已结束",
|
|
|
|
|
})
|
|
|
|
|
uni.reLaunch({
|
|
|
|
|
url: '/pages/index/ordermanage'
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
clickProject(data) {
|
|
|
|
|
//判断当前id是否存在csId数组里面
|
|
|
|
|
let index = this.csId.indexOf(data.id)
|
|
|
|
|
if (index !== -1) {
|
|
|
|
|
// 如果存在,则从数组中删除
|
|
|
|
|
this.csId.splice(index, 1);
|
|
|
|
|
} else {
|
|
|
|
|
// 如果不存在,则添加到数组中
|
|
|
|
|
this.csId.push(data.id);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
async getindex() {
|
|
|
|
|
|
|
|
|
|
let res = await request({
|
|
|
|
|
url: '/partnerOwn/partner/inspectionDetail',
|
|
|
|
|
method: 'get',
|
|
|
|
|
params: {
|
|
|
|
|
inspectionInfoId: this.inspectionInfoId
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
this.detailData = res.data
|
2024-12-09 11:04:54 +08:00
|
|
|
|
|
2024-11-15 17:48:16 +08:00
|
|
|
|
this.detailData.stepInfos.forEach(item => {
|
|
|
|
|
// 检查 item.images 是否为有效的字符串
|
|
|
|
|
if (typeof item.images === 'string' && item.images.trim() !== '') {
|
|
|
|
|
// 将里面的images转为数组
|
|
|
|
|
item.images = item.images.split(',');
|
|
|
|
|
// 使用map方法处理每个图片路径,转换为对象格式
|
|
|
|
|
item.images = item.images.map(image => this.baseImageUrl + "/" + image);
|
|
|
|
|
|
|
|
|
|
// 将处理后的图片列表赋值给imageList
|
|
|
|
|
item.imageList = item.images;
|
|
|
|
|
} else {
|
|
|
|
|
// 如果 item.images 不是有效的字符串,设置为空数组
|
|
|
|
|
item.images = [];
|
|
|
|
|
item.imageList = [];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 输出最终结果
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
this.inspectionId = res.data.inspectionId
|
|
|
|
|
this.isOnline = res.data.isOnline
|
|
|
|
|
this.orderStatus = res.data.orderStatus
|
|
|
|
|
this.payMoney = res.data.goodsPrice / 100
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let she = await request({
|
|
|
|
|
url: '/rescue/dict/data/type/pay_type',
|
|
|
|
|
method: 'get',
|
|
|
|
|
})
|
|
|
|
|
this.shelist = she.data
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let bankRes = await request({
|
|
|
|
|
url: '/partnerOwn/partner/getBankAccountList',
|
|
|
|
|
method: 'get',
|
|
|
|
|
})
|
|
|
|
|
if (bankRes.code == 200) {
|
|
|
|
|
let tempList = []
|
|
|
|
|
if (bankRes.data && bankRes.data.length > 0) {
|
|
|
|
|
bankRes.data.forEach(it => {
|
|
|
|
|
tempList.push((it.remark) + it.label)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
this.bankList.push(tempList)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
xuanxiaolan(item) {
|
|
|
|
|
this.payType = item.value
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
getback() {
|
|
|
|
|
uni.navigateBack()
|
|
|
|
|
},
|
|
|
|
|
Nnimamadewen(value, index) {
|
|
|
|
|
this.isPass = value
|
|
|
|
|
this.geindex = index
|
2024-11-25 16:48:58 +08:00
|
|
|
|
this.type = value
|
2024-11-15 17:48:16 +08:00
|
|
|
|
},
|
|
|
|
|
shenmowanyi(value, index) {
|
|
|
|
|
this.tbindex = value
|
|
|
|
|
this.isRetrial = value
|
|
|
|
|
},
|
|
|
|
|
closexl(e) {
|
|
|
|
|
this.xling = false
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
openxl(e) {
|
|
|
|
|
},
|
|
|
|
|
close(e) {
|
|
|
|
|
},
|
|
|
|
|
confirm(e) {
|
|
|
|
|
this.show = false,
|
|
|
|
|
this.lei = e.value[0].label
|
|
|
|
|
},
|
|
|
|
|
change(e) {
|
|
|
|
|
},
|
|
|
|
|
cancel(e) {
|
|
|
|
|
this.show = false
|
|
|
|
|
},
|
|
|
|
|
// 删除图片
|
|
|
|
|
deletePic(event) {
|
|
|
|
|
this[`fileList${event.name}`].splice(event.index, 1)
|
|
|
|
|
},
|
|
|
|
|
// 新增图片
|
|
|
|
|
async afterRead(event) {
|
|
|
|
|
// 当设置 multiple 为 true 时, file 为数组格式,否则为对象格式
|
|
|
|
|
let lists = [].concat(event.file)
|
|
|
|
|
let fileListLen = this[`fileList${event.name}`].length
|
|
|
|
|
lists.map((item) => {
|
|
|
|
|
this[`fileList${event.name}`].push({
|
|
|
|
|
...item,
|
|
|
|
|
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
for (let i = 0; i < lists.length; i++) {
|
|
|
|
|
const result = await this.uploadFilePromise(lists[i].url)
|
|
|
|
|
let item = this[`fileList${event.name}`][fileListLen]
|
|
|
|
|
this[`fileList${event.name}`].splice(fileListLen, 1, Object.assign(item, {
|
|
|
|
|
status: 'success',
|
|
|
|
|
message: '',
|
|
|
|
|
url: result
|
|
|
|
|
}))
|
|
|
|
|
fileListLen++
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
uploadFilePromise(url) {
|
|
|
|
|
upload({
|
|
|
|
|
url: '/common/upload',
|
|
|
|
|
filePath: url,
|
|
|
|
|
}).then((res) => {
|
|
|
|
|
// this.newsCover = res.fileName
|
|
|
|
|
this.fileList2.push(res.data.url)
|
|
|
|
|
return res.data.url
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
deletePic1(event) {
|
|
|
|
|
this[`fileList${event.name}`].splice(event.index, 1)
|
|
|
|
|
},
|
2024-11-18 17:58:28 +08:00
|
|
|
|
},
|
|
|
|
|
mounted() {
|
|
|
|
|
// 在组件挂载后启动定时器
|
|
|
|
|
this.timer = setInterval(this.getindex, 3000);
|
|
|
|
|
},
|
|
|
|
|
beforeDestroy() {
|
|
|
|
|
// 在组件销毁前清除定时器
|
|
|
|
|
if (this.timer) {
|
|
|
|
|
clearInterval(this.timer);
|
|
|
|
|
}
|
2024-11-15 17:48:16 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2024-09-11 15:55:28 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style scoped lang="scss">
|
2024-11-15 17:48:16 +08:00
|
|
|
|
image {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.lantong {
|
|
|
|
|
background-color: #0D2E8D !important;
|
|
|
|
|
color: white;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.lan-box {
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
margin: 5px 10px;
|
|
|
|
|
padding: 5px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
background-color: #F4F4F4;
|
|
|
|
|
border-radius: 4px;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.warp-box {
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.content {
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
background: #fff;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.top-heder {
|
|
|
|
|
width: 100%;
|
|
|
|
|
// height: 46px;
|
|
|
|
|
background: white;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 5px 15px;
|
|
|
|
|
padding-top: 45px;
|
|
|
|
|
padding-bottom: 15px;
|
|
|
|
|
margin-bottom: 10px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.t-title {
|
|
|
|
|
font-size: 17px;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
color: #333333;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.t-left {
|
|
|
|
|
width: 10%;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.t-you {
|
|
|
|
|
height: 100%;
|
|
|
|
|
width: 10%;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.x-box {
|
|
|
|
|
width: 95%;
|
|
|
|
|
margin: 10px auto;
|
|
|
|
|
background: #FFFFFF;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
background: white;
|
|
|
|
|
padding-bottom: 0px;
|
|
|
|
|
padding-top: 0px;
|
|
|
|
|
margin-top: 0px;
|
|
|
|
|
margin-bottom: 0px;
|
|
|
|
|
|
|
|
|
|
// display: flex;
|
|
|
|
|
// align-items: center;
|
|
|
|
|
// justify-content: center;
|
|
|
|
|
}
|
|
|
|
|
|
2024-11-25 16:48:58 +08:00
|
|
|
|
.p_box {
|
|
|
|
|
position: relative;
|
|
|
|
|
width: 90%;
|
|
|
|
|
margin: 0 auto;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
//border-left: 1px dashed #DEE1EA;
|
|
|
|
|
border-left: 1px dashed #0d2e8d;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.g_hui {
|
|
|
|
|
background: #F4F5F8;
|
|
|
|
|
border-radius: 16rpx 16rpx 16rpx 16rpx;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.p_titel {
|
|
|
|
|
width: 90%;
|
|
|
|
|
margin: 0 auto;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
|
|
|
|
|
position: relative;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2024-11-15 17:48:16 +08:00
|
|
|
|
.bottomx {
|
|
|
|
|
margin: 0 auto;
|
|
|
|
|
width: 225px;
|
|
|
|
|
height: 46px;
|
|
|
|
|
border-radius: 6px 6px 6px 6px;
|
|
|
|
|
opacity: 1;
|
|
|
|
|
border: 1px solid #0D2E8D;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
color: #0D2E8D;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bottomxx {
|
|
|
|
|
position: fixed;
|
|
|
|
|
right: 10px;
|
|
|
|
|
bottom: 150px;
|
|
|
|
|
width: 46px;
|
|
|
|
|
height: 46px;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
opacity: 1;
|
|
|
|
|
border: 1px solid #0D2E8D;
|
|
|
|
|
background: #0D2E8D;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
color: white;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.touxiang {
|
|
|
|
|
width: 50px;
|
|
|
|
|
height: 50px;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
margin: 10px auto;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.sanniu {
|
|
|
|
|
width: 105px;
|
|
|
|
|
height: 35px;
|
|
|
|
|
background: #0D2E8D;
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
color: #FFFFFF;
|
|
|
|
|
line-height: 15px;
|
|
|
|
|
margin: 0 auto;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.xiamxia {
|
|
|
|
|
width: 30%;
|
|
|
|
|
height: 30px;
|
|
|
|
|
background: linear-gradient(180deg, #3F61C0 0%, #0D2E8D 100%);
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
color: #FFFFFF;
|
|
|
|
|
line-height: 15px;
|
|
|
|
|
margin: 15px auto;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.annniu {
|
|
|
|
|
width: 90%;
|
|
|
|
|
height: 45px;
|
|
|
|
|
background: linear-gradient(180deg, #3F61C0 0%, #0D2E8D 100%);
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
color: #FFFFFF;
|
|
|
|
|
line-height: 15px;
|
|
|
|
|
margin: 15px auto;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.banniu {
|
|
|
|
|
width: 20%;
|
|
|
|
|
height: 30px;
|
|
|
|
|
background: linear-gradient(180deg, #3F61C0 0%, #0D2E8D 100%);
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
color: #FFFFFF;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.box {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.box-dis {
|
|
|
|
|
box-sizing: border-box;
|
2024-11-25 16:48:58 +08:00
|
|
|
|
padding: 15px 0px;
|
2024-11-15 17:48:16 +08:00
|
|
|
|
// border-bottom: 1px solid #EEEEEE;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.shop-img {
|
2024-11-25 16:48:58 +08:00
|
|
|
|
width: 150px;
|
|
|
|
|
height: 150px;
|
2024-11-15 17:48:16 +08:00
|
|
|
|
border-radius: 8px;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
margin-right: 10px;
|
|
|
|
|
}
|
|
|
|
|
|
2024-11-25 16:48:58 +08:00
|
|
|
|
.ds-right {
|
|
|
|
|
width: 55%;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2024-11-15 17:48:16 +08:00
|
|
|
|
.dis-hui {
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
color: #999999;
|
|
|
|
|
margin-bottom: 5px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.times {
|
2024-11-25 16:48:58 +08:00
|
|
|
|
|
2024-11-15 17:48:16 +08:00
|
|
|
|
font-size: 14px;
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
color: #999999;
|
|
|
|
|
margin-left: 25px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.h-title {
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
color: #333333;
|
|
|
|
|
margin-bottom: 5px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.box-top {
|
|
|
|
|
box-sizing: border-box;
|
2024-11-25 16:48:58 +08:00
|
|
|
|
//padding: 15px;
|
2024-11-15 17:48:16 +08:00
|
|
|
|
border-bottom: 1px solid #EEEEEE;
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-around;
|
2024-11-25 16:48:58 +08:00
|
|
|
|
margin-bottom: 15px;
|
2024-11-15 17:48:16 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.t-input {
|
|
|
|
|
width: 90%;
|
|
|
|
|
margin: 20px auto;
|
|
|
|
|
border: 1px solid #0D2E8D;
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 2px 5px;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.on-input {
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
align-items: center;
|
|
|
|
|
margin: 15px auto;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.on-inputx {
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
margin: 15px auto;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bottom-input {
|
|
|
|
|
border-top: 1px solid #F4F4F4;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding-top: 20px;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
width: 100%;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.o-left {
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
color: #666666;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.o-right {
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
color: #333333;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.o-zui {
|
|
|
|
|
font-size: 20px;
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
color: #333333;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.popup-box {
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 15px;
|
|
|
|
|
width: 100%;
|
|
|
|
|
background-color: white;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.sousuo {
|
|
|
|
|
width: 95%;
|
|
|
|
|
margin: 0 auto;
|
|
|
|
|
margin-left: 0px;
|
|
|
|
|
height: 30px;
|
|
|
|
|
background: #F0F0F0;
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
color: #999999;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 0 10px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
|
|
|
|
|
input {
|
|
|
|
|
width: 80%;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.list-box {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 300px;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.list_scroll {
|
|
|
|
|
height: 100%; // 需设置高度
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.list-qiu {
|
|
|
|
|
width: 95%;
|
|
|
|
|
border-bottom: 1px solid #EEEEEE;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px 5px;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
align-items: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.tel {
|
|
|
|
|
margin-left: 5px;
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
color: #666666;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bd-tel {
|
|
|
|
|
width: 100%;
|
|
|
|
|
border-top: 1px solid #EEEEEE;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding-top: 10px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
color: #0D2E8D;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.imgs-warp {
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
margin-top: 10px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.imgss {
|
|
|
|
|
width: 32%;
|
|
|
|
|
height: 110px;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
|
|
|
|
|
image {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.anniu {
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 2px 10px;
|
|
|
|
|
margin: 0px 10px;
|
|
|
|
|
// background: linear-gradient(180deg, #3F61C0 0%, #0D2E8D 100%);
|
|
|
|
|
border: 1px solid #0D2E8D;
|
|
|
|
|
border-radius: 23px;
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
color: #0D2E8D;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.an {
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 2px 10px;
|
|
|
|
|
margin: 0px 10px;
|
|
|
|
|
background: linear-gradient(180deg, #3F61C0 0%, #0D2E8D 100%) !important;
|
|
|
|
|
|
|
|
|
|
border-radius: 23px;
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
color: white !important;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.box_ {
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.box_button {
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
border: 1px solid #999;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 5px 10px;
|
|
|
|
|
margin-right: 5px;
|
|
|
|
|
margin-bottom: 5px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.box_button_x {
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
border: 1px solid #0D2E8D;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 5px 10px;
|
|
|
|
|
margin-right: 5px;
|
|
|
|
|
margin-bottom: 5px;
|
|
|
|
|
background: #0D2E8D;
|
|
|
|
|
color: #fff;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.qiu_ {
|
2024-11-25 16:48:58 +08:00
|
|
|
|
width: 25px;
|
|
|
|
|
height: 25px;
|
2024-11-15 17:48:16 +08:00
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
color: #fff;
|
2024-11-25 16:48:58 +08:00
|
|
|
|
background: #0174F6;
|
|
|
|
|
margin-left: -13px;
|
|
|
|
|
margin-top: 5px;
|
|
|
|
|
//position: absolute;
|
|
|
|
|
//left: -10x;
|
|
|
|
|
//top: 0px;
|
2024-11-15 17:48:16 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.xb_ {
|
|
|
|
|
|
|
|
|
|
width: 13%;
|
|
|
|
|
height: 35px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding-left: 6px;
|
|
|
|
|
color: #0D2E8D;
|
|
|
|
|
font-size: 40px;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
}
|
2024-11-25 16:48:58 +08:00
|
|
|
|
|
|
|
|
|
.steps-container {
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-wrap: wrap; /* 自动换行 */
|
|
|
|
|
justify-content: space-between; /* 均匀分布 */
|
|
|
|
|
gap: 10px; /* 控制横向和纵向间距 */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.step-item {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center; /* 图标和文字垂直居中对齐 */
|
|
|
|
|
width: 31%; /* 每行展示三个 */
|
|
|
|
|
text-align: left;
|
|
|
|
|
margin-bottom: 20px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.step-circle {
|
2024-12-11 10:05:22 +08:00
|
|
|
|
width: 18px;
|
|
|
|
|
height: 18px;
|
2024-11-25 16:48:58 +08:00
|
|
|
|
border-radius: 50%;
|
|
|
|
|
background: linear-gradient(to right, #F1F1F1, #858899);
|
|
|
|
|
box-shadow: 0px 0px 0px 2px rgba(0, 0, 0, 0.3);
|
|
|
|
|
flex-shrink: 0;
|
|
|
|
|
margin-right: 5px; /* 圆点和文字的间距 */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.circle-blue {
|
|
|
|
|
background: linear-gradient(to right, #80BCFF, #0174F6) !important;
|
|
|
|
|
box-shadow: 0px 0px 0px 2px rgba(0, 0, 0, 0.3);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.circle-yellow {
|
|
|
|
|
background: linear-gradient(to right, #FFD78C, #FFB323) !important;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.step-content {
|
2024-12-11 10:05:22 +08:00
|
|
|
|
font-size: 16px;
|
|
|
|
|
line-height: 20px; /* 与图标高度对齐 */
|
2024-11-25 16:48:58 +08:00
|
|
|
|
color: #333;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.r-two-box {
|
|
|
|
|
width: 100%;
|
|
|
|
|
background: #F4F5F8;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
margin-bottom: 15px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.h-two-box {
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.h-two-r {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
font-size: 30rpx;
|
|
|
|
|
color: #0174F6;
|
|
|
|
|
|
|
|
|
|
image {
|
|
|
|
|
width: 30rpx;
|
|
|
|
|
height: 30rpx;
|
|
|
|
|
margin-right: 5px;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.h_title {
|
|
|
|
|
font-size: 24rpx;
|
|
|
|
|
color: #999999;
|
|
|
|
|
margin-bottom: 5px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.h_name {
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
color: #333333;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.jc_title {
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
color: #333333;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.jc_name {
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
color: #9AA0B0;
|
|
|
|
|
}
|
2024-11-11 13:18:56 +08:00
|
|
|
|
</style>
|