mirror of
https://codeup.aliyun.com/67c68d4e484ca2f0a13ac3c1/ydc/jsowell-charger-web.git
synced 2026-05-07 11:29:58 +08:00
# Conflicts: # jsowell-ui/.env.development # jsowell-ui/.env.staging # jsowell-ui/bin/build-sit.bat # jsowell-ui/bin/build.bat # jsowell-ui/src/api/adapayMember/adapayMember.js # jsowell-ui/src/api/pile/merchant.js # jsowell-ui/src/router/index.js # jsowell-ui/src/views/financial/financeDetail.vue # jsowell-ui/src/views/financial/merchant.vue # jsowell-ui/src/views/homeIndex/homeIndex.vue # jsowell-ui/src/views/login.vue # jsowell-ui/src/views/pile/basic/detail.vue # jsowell-ui/src/views/pile/station/components/SiteInfo.vue # jsowell-ui/src/views/pile/station/detail.vue # jsowell-ui/src/views/pile/station/orderReport.vue
1 line
31 KiB
JSON
1 line
31 KiB
JSON
{"remainingRequest":"D:\\ideaProjects\\jsowell-charger-web\\jsowell-ui\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\ideaProjects\\jsowell-charger-web\\jsowell-ui\\src\\views\\member\\memberGroup\\detail.vue?vue&type=template&id=2dc2e562&scoped=true","dependencies":[{"path":"D:\\ideaProjects\\jsowell-charger-web\\jsowell-ui\\src\\views\\member\\memberGroup\\detail.vue","mtime":1747098376095},{"path":"D:\\ideaProjects\\jsowell-charger-web\\jsowell-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1748394193395},{"path":"D:\\ideaProjects\\jsowell-charger-web\\jsowell-ui\\node_modules\\vue-loader\\lib\\loaders\\templateLoader.js","mtime":1748394201875},{"path":"D:\\ideaProjects\\jsowell-charger-web\\jsowell-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1748394193395},{"path":"D:\\ideaProjects\\jsowell-charger-web\\jsowell-ui\\node_modules\\vue-loader\\lib\\index.js","mtime":1748394199226}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:
<div class="app-container">
    <el-row type="flex" justify="space-between">
        <!-- 右侧内容 -->
        <el-col :span="24">
            <el-tabs type="border-card">
                <!-- 客户 -->
                <el-tab-pane label="客户">
                    <el-col>
                        <el-button type="primary" size="mini" icon="el-icon-plus" @click="handleAddMember">添加会员
                        </el-button>
                    </el-col>
                    <el-table :data="memberGroupList" stripe style="width: 100%" v-loading="loading">
                        <el-table-column label="会员id" align="center" prop="memberId" />
                        <el-table-column label="昵称" align="center" prop="nickName" />
                        <el-table-column label="状态" align="center" prop="status">
                            <template slot-scope="scope">
                                <dict-tag :options="dict.type.member_status" :value="scope.row.status" />
                            </template>
                        </el-table-column>
                        <el-table-column label="头像" align="center" prop="avatarUrl">

                            <template slot-scope="scope">
                                <el-image style="height: 50px;width: 50px"
                                    :src="scope.row.avatarUrl === null ? defaultImg[0].img : scope.row.avatarUrl"
                                    :preview-src-list='[scope.row.avatarUrl === null ? defaultImg[0].img : scope.row.avatarUrl]' />
                            </template>
                        </el-table-column>
                        <el-table-column label="手机号" align="center" prop="mobileNumber" />
                        <el-table-column label="操作" align="center" width="200">

                            <template slot-scope="scope">
                                <el-button size="mini" type="text" icon="el-icon-delete"
                                    @click="deleteMember(scope.row)">删除
                                </el-button>
                            </template>
                        </el-table-column>
                    </el-table>
                    <!--分页-->
                    <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum"
                        :limit.sync="queryParams.pageSize" @pagination="getMemberList"
                        style="margin-bottom: 20px" />
                </el-tab-pane>

                <!-- 交易明细 -->
                <el-tab-pane label="交易明细">
                    <!--搜索条件-->
                    <el-form :model="from" ref="queryForm" size="small" :inline="true" v-show=true
                        @submit.native.prevent>
                        <el-form-item label="订单编号" prop="orderCode" style="width: 300px">
                            <el-input v-model="from.orderCode" placeholder="请输入订单编号" clearable
                                @keyup.enter.native="handleQuery" />
                        </el-form-item>

                        <el-form-item label="订单状态" prop="orderStatus" style="width: 230px">
                            <el-select v-model="from.orderStatus" placeholder="请选择订单状态" clearable
                                style="width: 140px">
                                <el-option v-for="dict in dict.type.order_status" :key="dict.value"
                                    :label="dict.label" :value="dict.value" />
                            </el-select>
                        </el-form-item>

                        <el-form-item label="手机号码" prop="mobileNumber" style="width: 300px">
                            <el-input v-model="from.mobileNumber" placeholder="请输入手机号码" clearable
                                @keyup.enter.native="handleQuery" />
                        </el-form-item>

                        <el-form-item label="创建时间" style="width: 330px">
                            <el-date-picker v-model="createTimeRange" style="width: 240px"
                                value-format="yyyy-MM-dd HH:mm:ss" :default-time="['00:00:00', '23:59:59']"
                                type="daterange" range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期"
                                :clearable="true" />
                        </el-form-item>

                        <el-form-item label="结算时间" style="width: 330px">
                            <el-date-picker v-model="settleTimeRange" style="width: 240px"
                                value-format="yyyy-MM-dd HH:mm:ss" :default-time="['00:00:00', '23:59:59']"
                                type="daterange" range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期"
                                :clearable="true"></el-date-picker>
                        </el-form-item>
                    </el-form>

                    <el-row :gutter="10" class="mb8">
                        <el-col :span="1.5">
                            <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索
                            </el-button>
                        </el-col>
                        <el-col :span="1.5">
                            <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置
                            </el-button>
                        </el-col>
                        <el-col :span="1.5">
                            <el-button type="warning" plain icon="el-icon-download" size="mini"
                                @click="handleExport" v-hasPermi="['order:order:export']">导出
                            </el-button>
                        </el-col>
                    </el-row>
                    <ul class="uls">
                        <li v-for="totalDate in totalDateList">
                            {{ totalDate.dateDescription }}期间，总用电量{{ totalDate.sumUsedElectricity }}度，总消费金额{{
            totalDate.sumOrderAmount
        }}元，总结算金额{{ totalDate.sumSettleAmount }}元
                        </li>
                    </ul>

                    <!--结果展示-->
                    <el-table :data="orderListResult" stripe style="width: 100%" v-loading="loading">
                        <el-table-column label="订单编号" align="center" prop="orderCode" width="280px">

                            <template slot-scope="scope">
                                <router-link :to="'/order/index/orderDetail/' + scope.row.orderCode"
                                    class="link-type">
                                    <span>{{ scope.row.orderCode }}</span>
                                </router-link>
                            </template>
                        </el-table-column>
                        <el-table-column label="订单状态描述" align="center" prop="orderStatusDescribe" />
                        <el-table-column label="会员昵称" align="center" prop="nickName" width="120px" />
                        <el-table-column label="电话号码" align="center" prop="mobileNumber" width="120px" />
                        <el-table-column label="站点" align="center" prop="stationName" />
                        <el-table-column label="充电桩枪口号" align="center" prop="pileConnectorCode" width="200px" />
                        <el-table-column label="微信商户订单号" align="center" prop="outTradeNo" width="165px" />
                        <el-table-column label="启动方式" align="center" prop="startMode" width="100px">

                            <template slot-scope="scope">
                                <dict-tag :options="dict.type.start_mode" :value="scope.row.startMode" />
                            </template>
                        </el-table-column>
                        <el-table-column label="支付方式" align="center" prop="payMode">

                            <template slot-scope="scope">
                                <dict-tag :options="dict.type.pay_mode" :value="scope.row.payMode" />
                            </template>
                        </el-table-column>
                        <el-table-column label="支付状态" align="center" prop="payStatus">

                            <template slot-scope="scope">
                                <dict-tag :options="dict.type.pay_status" :value="scope.row.payStatus" />
                            </template>
                        </el-table-column>
                        <el-table-column label="支付金额" align="center" prop="payAmount" />
                        <el-table-column label="充电度数" align="center" prop="chargingDegree" width="100px" />
                        <el-table-column label="起始soc" align="center" prop="startSoc" />
                        <el-table-column label="终止soc" align="center" prop="endSoc" />
                        <el-table-column label="开始充电时间" align="center" prop="chargeStartTime" width="180" />
                        <el-table-column label="结束充电时间" align="center" prop="chargeEndTime" width="180" />
                        <el-table-column label="订单总金额" align="center" prop="orderAmount" width="100px" />
                    </el-table>
                    <!--分页-->
                    <pagination v-show="getTotal > 0" :total="getTotal" :page.sync="from.pageNum"
                        :limit.sync="from.pageSize" @pagination="getOrderList" style="margin-bottom: 20px" />
                </el-tab-pane>

                <!-- 站点 -->
                <el-tab-pane label="站点">
                    <el-col>
                        <el-button type="primary" size="mini" icon="el-icon-plus" @click="addasite">添加站点
                        </el-button>
                    </el-col>
                    <el-table :data="sitesList" stripe style="width: 100%" v-loading="loading">
                        <el-table-column label="站点名称" align="center" prop="stationName" width="300" />
                        <el-table-column label="备注" align="center" prop="templateRemark" />
                        <el-table-column label="描述" align="center" prop="templateDesc" />
                        <el-table-column label="操作" align="center" width="200">

                            <template slot-scope="scope">
                                <el-button size="mini" type="text" icon="el-icon-edit"
                                    @click="addasite(scope.row)">修改
                                </el-button>
                                <el-button size="mini" type="text" icon="el-icon-delete"
                                    @click="handleDelete(scope.row)">删除
                                </el-button>
                            </template>
                        </el-table-column>
                    </el-table>
                    <!--分页-->
                    <pagination v-show="stationTotal > 0" :total="stationTotal" :page.sync="queryStation.pageNum"
                        :limit.sync="queryStation.pageSize" @pagination="getStationList"
                        style="margin-bottom: 20px" />
                </el-tab-pane>

                <!-- 车辆列表 -->
                <el-tab-pane label="车辆列表">
                    <el-table :data="carList" stripe style="width: 100%" v-loading="loading">
                        <el-table-column label="车牌号" align="center" prop="licensePlateNumber" />
                        <el-table-column label="VIN码" align="center" prop="vinCode" />
                        <el-table-column label="总消费金额" align="center" prop="totalConsumptionAmount" />
                        <el-table-column label="更新时间" align="center" prop="lastDate" />
                        <el-table-column label="操作" align="center" width="200">

                            <template slot-scope="scope">
                                <el-button size="mini" type="text" @click="details(scope.row)">明细</el-button>
                            </template>
                        </el-table-column>
                    </el-table>
                    <!--分页-->
                    <pagination v-show="consumptionTotal > 0" :total="consumptionTotal"
                        :page.sync="queryCar.pageNum" :limit.sync="queryCar.pageSize"
                        @pagination="getQueryMemberGroupConsumptionList" style="margin-bottom: 20px" />
                </el-tab-pane>

            </el-tabs>
        </el-col>
    </el-row>
    <!--添加会员-->
    <el-dialog title="添加会员" :visible.sync="openAddMember" :before-close="cancel" width="500px" append-to-body>
        <el-input v-model="queryParams.phoneNumber" placeholder="请输入手机号"></el-input>
        <div slot="footer" class="dialog-footer">
            <el-button @click="cancel">取 消</el-button>
            <el-button type="primary" @click="submitForm">确 定</el-button>
        </div>
    </el-dialog>
    <!-- 添加修改站点 -->
    <el-dialog :title="getTitle" :visible.sync="getSite" :before-close="getCancel" width="1000px" append-to-body>
        <el-form ref="exchangeRateB" :model="exchangeRateB" :rules="dialogRules">
            <el-form-item label="请选择站点">
                <el-select v-model="selectSite" placeholder="请选择站点" filterable :disabled="getDisabled"
                    style="width:300px" @change="queryInfo">
                    <el-option v-for="(station, index) in stationList" :key="index" :label="station.stationName"
                        :value="station.id" />
                </el-select>
            </el-form-item>
            <el-row :gutter="20" style="margin-top: 15px;">
                <el-col :span="4">
                    <div class="grid-content bg-purple" style="padding-left: 25px;"> 时段</div>
                </el-col>
                <el-col :span="4">
                    <div style="text-align: center;" class="grid-content bg-purple">原电费(元/度)</div>
                </el-col>
                <el-col :span="4">
                    <div style="text-align: center;" class="grid-content bg-purple">原服务费(元/度)</div>
                </el-col>
                <el-col :span="4">
                    <div style="text-align: center;" class="grid-content bg-purple">电费(元/度)</div>
                </el-col>
                <el-col :span="4">
                    <div style="text-align: center;" class="grid-content bg-purple">服务费(元/度)</div>
                </el-col>
            </el-row>
            <el-row :gutter="20" style="margin-top: 15px;">
                <el-col :span="4">
                    <el-button type="danger">尖时段</el-button>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="electricityPriceA">
                        <el-input v-model="exchangeRate.electricityPriceA" type="number" class="clearInputScore"
                            placeholder="0" clearable disabled />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="servicePriceA">
                        <el-input v-model="exchangeRate.servicePriceA" placeholder="0" clearable type="number"
                            class="clearInputScore" disabled />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="modifyServiceA">
                        <el-input v-model="exchangeRateB.modifyServiceA" type="number" class="clearInputScore"
                            placeholder="0" clearable />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="modifyElectricityA">
                        <el-input v-model="exchangeRateB.modifyElectricityA" placeholder="0" clearable type="number"
                            class="clearInputScore" />
                    </el-form-item>
                </el-col>
            </el-row>
            <!-- 峰 -->
            <el-row :gutter="20">
                <el-col :span="4">
                    <el-button type="warning">峰时段</el-button>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="electricityPriceB">
                        <el-input v-model="exchangeRate.electricityPriceB" type="number" class="clearInputScore"
                            placeholder="0" clearable disabled />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="servicePriceB">
                        <el-input v-model="exchangeRate.servicePriceB" placeholder="0" clearable type="number"
                            class="clearInputScore" disabled />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="modifyServiceB">
                        <el-input v-model="exchangeRateB.modifyServiceB" type="number" class="clearInputScore"
                            placeholder="0" clearable />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="modifyElectricityB">
                        <el-input v-model="exchangeRateB.modifyElectricityB" placeholder="0" clearable type="number"
                            class="clearInputScore" />
                    </el-form-item>
                </el-col>
            </el-row>
            <!-- 平 -->
            <el-row :gutter="20">
                <el-col :span="4">
                    <el-button type="success">平时段</el-button>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="electricityPriceC">
                        <el-input v-model="exchangeRate.electricityPriceC" type="number" class="clearInputScore"
                            placeholder="0" clearable disabled />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="servicePriceC">
                        <el-input v-model="exchangeRate.servicePriceC" placeholder="0" clearable type="number"
                            class="clearInputScore" disabled />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="modifyServiceC">
                        <el-input v-model="exchangeRateB.modifyServiceC" type="number" class="clearInputScore"
                            placeholder="0" clearable />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="modifyElectricityC">
                        <el-input v-model="exchangeRateB.modifyElectricityC" placeholder="0" clearable type="number"
                            class="clearInputScore" />
                    </el-form-item>
                </el-col>
            </el-row>
            <!-- 谷 -->
            <el-row :gutter="20">
                <el-col :span="4">
                    <el-button type="info">谷时段</el-button>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="electricityPriceD">
                        <el-input v-model="exchangeRate.electricityPriceD" type="number" class="clearInputScore"
                            placeholder="0" clearable disabled />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="servicePriceD">
                        <el-input v-model="exchangeRate.servicePriceD" placeholder="0" clearable type="number"
                            class="clearInputScore" disabled />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="modifyServiceD">
                        <el-input v-model="exchangeRateB.modifyServiceD" type="number" class="clearInputScore"
                            placeholder="0" clearable />
                    </el-form-item>
                </el-col>
                <el-col :span="4">
                    <el-form-item prop="modifyElectricityD">
                        <el-input v-model="exchangeRateB.modifyElectricityD" placeholder="0" clearable type="number"
                            class="clearInputScore" />
                    </el-form-item>
                </el-col>
            </el-row>
            <span>24小时尖峰平谷分布设置</span>
            <div>
                <el-tag v-for="item in tagsTime" :key="item.label" :type="item.type"
                    style="margin: 10px 10px 10px 0; width: 160px; height: 30px ;line-height:30px;text-align: center;"
                    effect="dark">
                    {{ item.label }}
                </el-tag>
            </div>
        </el-form>
        <div slot="footer" class="dialog-footer">
            <el-button @click="getCancel">取 消</el-button>
            <el-button type="primary" @click="siteConfirmation">确 定</el-button>
        </div>
    </el-dialog>
    <!-- 车辆列表明细 -->
    <el-dialog title="订单明细" :visible.sync="vehicleDetails" :before-close="closeDetails" width="1800px"
        append-to-body>
        <el-table :data="closeList" stripe style="width: 100%" v-loading="loading">
            <el-table-column label="订单编号" align="center" prop="orderCode" />
            <el-table-column label="站点名称" align="center" prop="stationName" />
            <el-table-column label="昵称" align="center" prop="nickName" />
            <el-table-column label="手机号" align="center" prop="mobileNumber" />
            <el-table-column label="实时充电度数" align="center" prop="realTimeChargingDegree" />
            <el-table-column label="实时消费金额" align="center" prop="realTimeAmount" />
            <el-table-column label="起始SOC" align="center" prop="startSoc" />
            <el-table-column label="终止SOC" align="center" prop="endSoc" />
            <el-table-column label="开始时间" align="center" prop="chargeStartTime" />
            <el-table-column label="结束充电时间" align="center" prop="chargeEndTime" />
        </el-table>
        <!--分页-->
        <pagination v-show="closeTotal > 0" :total="closeTotal" :page.sync="detailParameters.pageNum"
            :limit.sync="detailParameters.pageSize" @pagination="getQueryConsumptionDetailListByVinCode"
            style="margin-bottom: 20px" />
    </el-dialog>
</div>
"},null]} |