index.vue 15.8 KB
<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="105px">
      <el-row>
      <el-form-item label="所属区域" prop="owningRegion">
        <el-select v-model="queryParams.owningRegion" multiple placeholder="请选择所属区域"  size="small">
          <el-option  v-for="item in areas" :label="item.name" :value="item.name" />
        </el-select>

      </el-form-item>
      <el-form-item label="预警类型" prop="violationType">
        <el-select v-model="queryParams.violationType" placeholder="请选择预警类型"  size="small">
          <el-option  v-for="item in caseType" v-if="item.status=='0'" :label="item.dictLabel" :value="item.dictValue" />
        </el-select>
      </el-form-item>


      <el-form-item label="预警对象类型" prop="violationObjectType">
        <el-select v-model="queryParams.violationObjectType" placeholder="请选择预警对象类型"  size="small">
          <el-option label="工地" value="0" />
          <el-option label="处理场所" value="1" />
          <el-option label="企业" value="2" />
        </el-select>
      </el-form-item>
    </el-row>
      <el-row>
      <el-form-item label="预警对象" prop="projectName">
        <el-input
          v-model="queryParams.projectName"
          placeholder="请输入预警对象"
          size="small"
        />
      </el-form-item>

      <el-form-item label="日期" prop="createTime">
        <el-date-picker  size="small"
        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 label="数据来源" prop="needUpload">
        <el-select v-model="queryParams.needUpload" placeholder="数据来源"  size="small">
          <el-option label="平台数据" value="0" />
          <el-option label="综管数据" value="1" />
        </el-select>
      </el-form-item>
      <el-form-item label="审批状态" prop="status">
        <el-select v-model="queryParams.status" placeholder="状态" size="small">
            <el-option label="结束" value="1"/>
            <el-option label="驳回" value="2"/>
            <el-option label="审核中" value="0"/>
        </el-select>
      </el-form-item>
      <el-form-item label="状态" prop="status1">
        <el-select v-model="queryParams.status1" placeholder="状态" size="small">
            <el-option label="未回复" value="0"/>
            <el-option label="已回复" value="1"/>
            <el-option label="审核中" value="2"/>
            <el-option label="结案存档" value="3"/>
        </el-select>
      </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-row>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button
          type="primary"
          icon="el-icon-plus"
          size="mini"
          @click="handleAdd"
          v-hasPermi="['casefile:violationCaseFile:add']"

          v-if="checkPer(['intelligencecontrols.messagemanage.enter'])"
        >预警信息录入</el-button>
      </el-col>
<!--      <el-col :span="1.5">-->
<!--        <el-button-->
<!--          type="danger"-->
<!--          icon="el-icon-delete"-->
<!--          size="mini"-->
<!--          :disabled="multiple"-->
<!--          @click="handleDelete"-->
<!--          v-hasPermi="['casefile:violationCaseFile:remove']"-->
<!--        >删除</el-button>-->
<!--      </el-col>-->
      <el-col :span="1.5">
        <el-button
          type="warning"
          icon="el-icon-download"
          size="mini"
          @click="handleExport"
          v-hasPermi="['casefile:violationCaseFile:export']"
        >导出</el-button>
      </el-col>
	  <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
    </el-row>

    <el-table v-loading="loading" :data="violationCaseFileList" @selection-change="handleSelectionChange">
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column label="序号" align="center" type='index'/>
      <el-table-column label="所属区域" align="center" prop="owningRegion" />
      <el-table-column label="预警对象" align="center" prop="projectName" />
      <el-table-column label="预警对象类型" align="center" prop="violationObjectType">
      <template slot-scope="scope">
        <span>{{scope.row.violationObjectType == 0 ? "工地" :scope.row.violationObjectType == 1 ?"处理场所":"企业"}}</span>
      </template>
      </el-table-column>
      <el-table-column label="预警类型" align="center" prop="violationType">
        <template slot-scope="scope">
          <span>{{getCaseType(scope.row.violationType)}}</span>
        </template>

        </el-table-column>
      <el-table-column label="日期" align="center" prop="createTime">
      </el-table-column>
      <el-table-column label="状态" align="center" prop="status1">
        <template slot-scope="scope">
            <span>{{getCaseStatus(scope.row)}}</span>
          </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-view"
            @click="openFunction(scope.row,1)"
            v-if="!scope.row.status && scope.row.status!=0 && scope.row.needUpload == 1"
          >综管数据回退</el-button>
          <el-button
            size="mini"
            type="text"
            icon="el-icon-view"
            @click="openFunction(scope.row,2)"
            v-if="!scope.row.status && scope.row.status!=1 && scope.row.needUpload == 1"
          >延期处理</el-button>
          <el-button
            size="mini"
            type="text"
            icon="el-icon-view"
            @click="handleUpdate(scope.row)"
            v-if="!scope.row.status && scope.row.status!=0 && scope.row.needUpload == 1"
          >综管数据补填</el-button>
          <el-button
            size="mini"
            type="text"
            icon="el-icon-view"
            @click="handleUpdate(scope.row)"
            v-if="scope.row.status == 2"
          >重新提交</el-button>
          <el-button
            size="mini"
            type="text"
            icon="el-icon-view"
            @click="handleInfo(scope.row)"
            v-hasPermi="['casefile:violationCaseFile:edit']"
          >详情</el-button>
<!--          <el-button-->
<!--            size="mini"-->
<!--            type="text"-->
<!--            icon="el-icon-edit"-->
<!--            @click="handleUpdate(scope.row)"-->
<!--            v-hasPermi="['casefile:violationCaseFile:edit']"-->
<!--          >修改</el-button>-->
<!--          <el-button-->
<!--            size="mini"-->
<!--            type="text"-->
<!--            icon="el-icon-delete"-->
<!--            @click="handleDelete(scope.row)"-->
<!--            v-hasPermi="['casefile:violationCaseFile:remove']"-->
<!--          >删除</el-button>-->
        </template>
      </el-table-column>
    </el-table>

    <el-dialog title="回退" :visible.sync="deleteDialog" width="400px" append-to-body >
      <el-input v-model="form.describe" type="textarea" placeholder="填写理由" :row="4"/>
      <div slot="footer" class="dialog-footer">
        <el-button @click="deleteUpCase();">确 认</el-button>
        <el-button @click="deleteDialog = false;">取 消</el-button>
      </div>
    </el-dialog>

    <el-dialog title="延期" :visible.sync="delayDialog" width="400px" append-to-body >
      <el-select v-model="form.timeType" placeholder="时间类型"  size="small" style="width: 100%">
        <el-option label="小时" value="0" />
        <el-option label="工作日" value="1" />
        <el-option label="紧急工作时" value="2" />
      </el-select>
      <el-input v-model="form.delayedTime" placeholder="时间" />
      <el-input v-model="form.describe" type="textarea" placeholder="填写理由" :row="4"/>
      <div slot="footer" class="dialog-footer">
        <el-button @click="delayUpCase();">确 认</el-button>
        <el-button @click="delayDialog = false;">取 消</el-button>
      </div>
    </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="850px" append-to-body :close-on-click-modal="false">
      <el-form ref="form" :model="form" :rules="rules" label-width="115px">
        <el-row :gutter="2">
          <el-col :span="11">
            <el-form-item label="案卷编号" prop="number">
              <el-input v-model="form.number" placeholder="请输入案卷编号" :disabled="true"/>
            </el-form-item>
          </el-col>
          <el-col :span="11">
            <el-form-item label="预警对象类型" prop="violationObjectType">
              <el-select v-model="form.violationObjectType" placeholder="请选择预警对象类型"  size="small" style="width: 100%">
                <el-option label="工地" value="0" />
                <el-option label="处理场所" value="1" />
                <el-option label="企业" value="2" />
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row :gutter="2">
          <el-col :span="11">
            <el-form-item label="所属区域" prop="owningRegion">
              <el-select v-model="form.owningRegion" placeholder="请输入所属区域" style="width: 100%;">
                    <el-option  v-for="item in areas" :label="item.name" :value="item.name"/>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="11">
            <el-form-item label="预警类型" prop="violationType">
              <el-select v-model="form.violationType" placeholder="请选择预警类型" style="width: 100%;">
                <el-option  v-for="item in caseType" v-if="item.status=='0'" :label="item.dictLabel" :value="item.dictValue" />
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row :gutter="2">
          <el-col :span="11">
            <el-form-item label="预警等级" prop="violationGrade">
              <el-select v-model="form.violationGrade" placeholder="请选择预警等级" style="width: 100%;">
                <el-option label="一般类" value="一般类"/>
                <el-option label="重点类" value="重点类" />
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="11">
            <el-form-item label="预警对象" prop="projectName">
                <el-select
                v-model="form.projectName"
                :filterable="true"
                :loading="isLoading" placeholder="请输入项目名称" style="width: 100%;"
                 :filter-method="getRemoteDate">
                  <el-option v-for="item in projectNameList[form.violationObjectType]"
                  :key="item.name" :label="item.name" :value="item.name" :title="item.name"
                  @click.native="getAreaName(item.areaCode)"></el-option>
                </el-select>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row :gutter="2">
          <el-col :span="11">
            <el-form-item label="公司" prop="companyName">
              <el-select v-model="form.companyName" :filterable="true"
              :filter-method="getCompanys" :loading="isLoadingCompany"
              placeholder="请输入项目名称" style="width: 100%;">
                <el-option v-for="item in companyList" :key="item.name" :label="item.name" :value="item.name"></el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="11">
          </el-col>
        </el-row>


        <el-row :gutter="2">
          <el-col :span="8" :offset="3">
            <el-button style="margin-left: 14px" type="primary" @click="createDescribe">生成预警描述</el-button>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="22">
            <el-form-item label="预警描述" prop="describe">
              <el-input v-model="form.describe" type="textarea" placeholder="请输入内容" :row="4"/>
            </el-form-item>
          </el-col>
        </el-row>
        <el-form-item label="推送对象">
          <el-radio-group v-model="form.sendObject">
            <el-radio label="区管理部门">区管理部门</el-radio>
            <el-radio label="运输企业">运输企业</el-radio>
          </el-radio-group>
        </el-form-item>

        <el-form-item label="综管服">
          <el-radio-group v-model="form.needUpload">
            <el-radio label="0" checked="checked" >否</el-radio>
            <el-radio label="1">是</el-radio>
          </el-radio-group>
        </el-form-item>
        <el-form-item label="附件预览" v-if="slide1.length!=0">
          <el-image v-for="item in slide1"
                    style="width: 150px; height: 100px; margin: 5px;"
                    :src="item"
                    :preview-src-list="slide1"
                    :z-index="2000">
          </el-image>
          <div style="display: inline-block;margin: 5px;position: relative; width: 150px;height: 100px;overflow:hidden;" v-for="item in videoSrc" >
            <video width="100%" controls="controls" height="100%" :src="item"></video>
          </div>
        </el-form-item>
        <el-form-item prop="fileEntityList" label="附件">
          <el-upload
            ref="upload"
            action=""
            accept=".docx,.doc,.pdf,.png,.jpeg,.png,.jpg,.mp4,.avi"
            :on-change="fileChange"
            :auto-upload="false"
            :show-file-list="false"
            multiple
            :file-list="fileEntityList">
            <el-button size="small" type="primary" icon="el-icon-upload">上传附件</el-button>
          </el-upload>
        </el-form-item>
        <el-table :data="fileEntityList">
          <el-table-column property="name" label="附件名称" header-align="center" align="center"></el-table-column>
          <el-table-column label="操作" class-name="small-padding fixed-width" header-align="center" align="center">
            <template slot-scope="scope">
              <el-button
                size="small" type="success"
                icon="el-icon-download"
                @click="downloadFA(scope.row)"
                v-hasPermi="['office:management:edit']"
                v-if="form.id!=null"
                round>下载
              </el-button>
              <el-button
                size="small" type="danger"
                icon="el-icon-delete"
                @click="handleDeleteFile(scope.$index)"
                v-hasPermi="['office:management:remove']"
                round>删除
              </el-button>
            </template>
          </el-table-column>
        </el-table>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="submitForm"
        v-loading.fullscreen.lock="modalLoading">确 定</el-button>
        <el-button @click="cancel">取 消</el-button>
      </div>
    </el-dialog>
    <el-dialog :title="title" :visible.sync="openInfo" width="850px" append-to-body :close-on-click-modal="false">
      <violationCaseFileInfo :idInfo="idInfo" v-if="openInfo" :entryType="0"/>
      <div slot="footer" class="dialog-footer">
        <el-button @click="cancel">取 消</el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script src="@/api/vio_casefile">
</script>