index.vue 7.05 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.status==0}"  size="mini" @click="getData(1);" >失信驾驶员</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button  :class="{'el-button':true,'el-button--primary':this.queryParams.status==1}" size="mini" @click="getHistoryData(1);">历史驾驶员</el-button>
      </el-col>
    </el-row>

    <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch">
      <el-row type="flex" justify="center">
        <el-col>
          <el-form-item label="驾驶员姓名" prop="name">
            <el-select v-model="queryParams.name"
                       filterable

                       reserve-keyword
                       placeholder="驾驶员姓名"
                       size="small"
                       :loading="loading">
              <el-option
                v-for="item in dictNames"
                :label="item"
                :value="item">
              </el-option>
            </el-select>
          </el-form-item>
        </el-col>
        <el-col>
          <el-form-item label="车牌号" prop="licenseplateNo">
            <el-select v-model="queryParams.licenseplateNo"
                       filterable

                       reserve-keyword
                       placeholder="车牌号"
                       size="small"
                       :loading="loading">
              <el-option
                v-for="item in dictLicenseplateNo"
                :label="item"
                :value="item">
              </el-option>
            </el-select>
          </el-form-item>

          </el-col>
        <el-col>
        <el-form-item label="失信日期" prop="time" v-show="queryParams.status==0">
          <el-date-picker  size="small" style="width: 200px" v-model="queryParams.time" type="date"
                          value-format="yyyy-MM-dd" placeholder="失信日期">
          </el-date-picker>
        </el-form-item>
      </el-col>
      </el-row>

    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button type="primary"  size="mini" @click="handleAdd" v-hasPermi="['driver:credit:add']"  v-if="queryParams.status==0
        && checkPer(['businessmanage.credit.DriverCredit.add'])">新增</el-button>

      </el-col>
      <el-col :span="1.5">
        <el-button  size="mini" @click="handleExport" v-hasPermi="['driver:credit:export']">导出</el-button>
      </el-col>

      <el-col :span="20" style="height: 1px;"></el-col>
      <el-col :span="1.5">
        <el-button type="primary"  size="mini" @click="handleQuery">查询</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button  size="mini" @click="resetQuery">重置</el-button>
      </el-col>
    </el-row>

    <el-table v-loading="loading" :data="creditList" @selection-change="handleSelectionChange" :cell-style="colStyle" border>
      <el-table-column label="序号" align="center" type="index" />
      <el-table-column label="驾驶员姓名" align="center" prop="name" />
      <el-table-column label="证件号码" align="center" prop="idNumber" />
      <el-table-column label="车牌号" align="center" prop="licenseplateNo" />
      <el-table-column label="失信时间" align="center" prop="time" width="180" v-if="queryParams.status==0">
        <template slot-scope="scope">
          <span>{{ parseTime(scope.row.time, '{y}-{m}-{d}') }}</span>
        </template>
      </el-table-column>
      <el-table-column label="失信原因" align="center" prop="reason" />
      <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="handleUpdate(scope.row)" v-hasPermi="['driver:credit:edit']" v-if="queryParams.status==0&&
           checkPer(['businessmanage.credit.DriverCredit.revoke'])">撤销失信</el-button>
          <el-button size="mini" type="text" icon="el-icon-edit" @click="getDataInfo(scope.row)" v-if="queryParams.status==1">查看</el-button>
        </template>
      </el-table-column>
    </el-table>

    <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  v-loading="loading">
      <el-form ref="form" :model="form" :rules="rules" label-width="120px">
        <el-form-item label="驾驶员姓名" prop="name">
          <el-input
            v-model="form.name"
            placeholder="驾驶员姓名"
            @change="getObjId"/>
        </el-form-item>

        <el-form-item label="证件号码" prop="idNumber">
          <el-input v-model="form.idNumber" placeholder="证件号码" disabled/>
        </el-form-item>
        <el-form-item label="车牌号" prop="licenseplateNo">
          <el-input v-model="form.licenseplateNo" placeholder="车牌号" disabled/>
        </el-form-item>
        <el-form-item label="失信原因" prop="reason">
          <el-input v-model="form.reason" placeholder="失信原因" />
        </el-form-item>
        <el-input v-model="form.lostCredit" value="1" type="hidden" />
        <el-input v-model="form.objectId" type="hidden" />
      </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>


    <el-dialog  title="撤销失信" :visible.sync="isEdit"  width="500px" append-to-body  v-loading="loading">
      <el-form ref="form" :model="updateForm" :rules="rules" label-width="120px">
        <el-form-item label="情况说明" prop="reason">
          <el-input v-model="updateForm.reason" type="textarea" maxlength="200" show-word-limit/>
        </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>

    <el-dialog  title="历史失信" :visible.sync="infoDialog"  width="800px" append-to-body>
      <el-table v-loading="loading" :data="creditListInfo" :cell-style="colStyle" border>
        <el-table-column label="序号" align="center" type="index" />
        <el-table-column label="失信时间" align="center" prop="time" width="180">
        </el-table-column>
        <el-table-column label="情况说明" align="center" prop="reason" />
        <el-table-column label="操作历史" align="center" prop="lostCredit">
          <template slot-scope="scope">
            <span>{{ scope.row.lostCredit== 0 ? "撤销失信" : "失信" }}</span>
          </template>
        </el-table-column>
        
        <el-table-column label="操作用户" align="center" prop="createBy" />
      </el-table>
    </el-dialog>
  </div>
</template>

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