index.vue 6.58 KB
<template>
  <div class="app-container">
    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button :class="{'el-button':true, 'el-button--primary':this.queryParams.pageStatus==0}" size="mini"
          @click="getList(0);">车辆激活</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button :class="{'el-button':true,'el-button--primary':this.queryParams.pageStatus==1}" size="mini"
          @click="getList(1);">车辆激活历史</el-button>
      </el-col>
    </el-row>


    <el-form :model="queryParams" ref="queryForm" :inline="true" label-width="68px">
      <el-form-item label="工地名称" prop="construction">
        <el-input
          v-model="queryParams.construction"
          placeholder="请输入工地名称"
          size="small" />
      </el-form-item>
      <el-form-item label="车牌号" prop="licensePlate">
        <el-input
          v-model="queryParams.licensePlate"
          placeholder="请输入车牌号"
          size="small" />
      </el-form-item>
      <el-form-item label="所属企业" prop="company">
        <el-input v-model="queryParams.company" />
      </el-form-item>
      <el-form-item label="激活状态" prop="activateStatus">
        <el-select v-model="queryParams.activateStatus" placeholder="请选择激活状态" size="small">
          <el-option label="未激活" value="0"/>
          <el-option label="已激活" value="1"/>
        </el-select>
      </el-form-item>
      <el-form-item label="激活时间" prop="createTime" v-if="openActivateTime">
        <el-date-picker v-model="queryParams.createTime" type="datetimerange"
           start-placeholder="开始日期"
           value-format="yyyy-MM-dd HH:mm:ss"
           end-placeholder="结束日期">
        </el-date-picker>
      </el-form-item>
      <el-form-item>
        <el-button type="cyan" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button
          v-if="this.queryParams.status==0 && checkPer(['business.supervision.truckActivate.active'])"
          type="primary"
          size="mini"
          @click="handleAdd"
          v-hasPermi="['business:truckActivate:add']"
        >手动激活</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="warning"
          size="mini"
          @click="handleExport"
          v-hasPermi="['business:truckActivate:export']"
        >导出</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="warning"
          size="mini"
          @click="handleInfoExport"
          v-hasPermi="['business:truckActivate:export']"
        >导出详情</el-button>
      </el-col>


    </el-row>

    <el-table v-loading="loading" :data="truckActivateList" @selection-change="handleSelectionChange">
      <el-table-column label="序号" align="center" type="index" />
      <el-table-column label="工地名称" align="center" prop="construction" />
      <el-table-column label="车牌号" align="center" prop="licensePlate" />
      <el-table-column label="运输企业" align="center" prop="company" />
      <el-table-column label="处理场所" align="center" prop="earthName" />
      <el-table-column label="激活时间" align="center" prop="activateTime" width="180">
        <template slot-scope="scope">
          <span>{{ parseTime(scope.row.activateTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
        </template>
      </el-table-column>
      <el-table-column label="激活状态" prop="objectId">
        <template slot-scope="scope">
          {{ scope.row.activateTime != null ? '已激活' : '未激活' }}
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
        <template slot-scope="scope">
         <el-button size="mini" type="text" icon="el-icon-edit" @click="getInfo(scope.row)">查看详情</el-button>
        </template>
      </el-table-column>
    </el-table>

    <el-dialog title="车辆激活信息详情" width="800px" append-to-body :visible.sync="info">
      <truckActivateInfo :truckObj="truckObj" v-if="info"/>
    </el-dialog>

    <pagination
      v-show="total>0"
      :total="total"
      :page.sync="queryParams.pageNum"
      :limit.sync="queryParams.pageSize"
      @pagination="getList"
    />

    <!-- 添加或修改车辆激活对话框 -->
    <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
      <el-form ref="form" :model="form" :rules="rules" label-width="80px">
        <el-form-item label="所属工地" prop="construction">
          <el-select v-model="form.construction" placeholder="请选择所属工地" filterable reserve-keyword @change="getCompany">
            <el-option v-for="item in constList" :label="item.name" :value="item.name" :title="item.name"></el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="所属企业" prop="company">
            <el-select v-model="form.company" filterable reserve-keyword @change="clearTruck">
              <el-option v-for="item in companyList"
              :disabled="item.creditStatus != 0"
              :label="item.name"
              :value="item.name"
              :title="item.name"
              />
            </el-select>
        </el-form-item>
        <el-form-item label="车牌号" prop="licensePlate">
          <el-input v-model="truckName" />
          <el-checkbox-group v-model="form.licensePlate" v-if="truckList.length > 0">
            <el-checkbox @change="selectAll">全选</el-checkbox>

             <el-checkbox v-if="(!truckName || item.licenseplateNo.indexOf(truckName) > -1) && (form.company && form.company == item.companyName)"
                      :disabled="item.creditStatus != 0 || item.createCount == 2"
                       v-for="item in truckList"
                       :label="item.licenseplateNo"
                       :value="item.id">{{item.licenseplateNo}}<span style="color: red;">({{item.createCount}})</span></el-checkbox>
           </el-checkbox-group>
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="submitForm">确 定</el-button>
        <el-button @click="cancel">取 消</el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script src="../../../api/truck_active.js" />