Ver código fonte

提交代码

JX.Li 1 ano atrás
pai
commit
a7baeaaeb9

+ 12 - 0
src/api/gas/area.js

@@ -14,6 +14,12 @@ export function flushProgress() {
     method: 'get',
   })
 }
+export function flushProgressA() {
+  return request({
+    url: '/gas/valveWellPosition/flushProgress',
+    method: 'get',
+  })
+}
 // 小区导入滚动条监控接口
 export function flushProgressqqq() {
   return request({
@@ -29,6 +35,12 @@ export function clearFlushProgresddd() {
   })
 }
 // 小区导入滚动条停止监控接口
+export function clearFlushProgressA() {
+  return request({
+    url: '/gas/valveWellPosition/clearFlushProgress',
+    method: 'get',
+  })
+}
 export function clearFlushProgress() {
   return request({
     url: '/gas/area/clearFlushProgress',

+ 7 - 0
src/api/gas/courtyardNetworkManagement.js

@@ -34,6 +34,13 @@ export function updateCourtyardNetworkManagement(data) {
     data: data
   })
 }
+export function batchReview(data) {
+  return request({
+    url: '/gas/courtyardNetworkManagement/batchReview',
+    method: 'POST',
+    data: data
+  })
+}
 
 // 删除庭院网管
 export function delCourtyardNetworkManagement(id) {

+ 7 - 0
src/api/gas/regulatingBoxMaintenance.js

@@ -34,6 +34,13 @@ export function updateRegulatingBoxMaintenance(data) {
     data: data
   })
 }
+export function batchReview(data) {
+  return request({
+    url: '/gas/regulatingBoxMaintenance/batchReview',
+    method: 'post',
+    data: data
+  })
+}
 
 // 删除调压箱维护
 export function delRegulatingBoxMaintenance(id) {

+ 8 - 0
src/api/gas/regulatorBox.js

@@ -35,6 +35,14 @@ export function updateRegulatorBox(data) {
   })
 }
 
+export function batchReview(data) {
+  return request({
+    url: '/gas/regulatorBox/batchReview',
+    method: 'post',
+    data: data
+  })
+}
+
 // 删除调压箱管理
 export function delRegulatorBox(id) {
   return request({

+ 46 - 19
src/views/gas/courtyardNetworkManagement/index.vue

@@ -2,7 +2,8 @@
   <div class="app-container">
     <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
       <el-form-item label="小区名称" prop="areaName">
-        <el-input v-model="queryParams.areaName" placeholder="请输入小区名称" clearable size="small" @keyup.enter.native="handleQuery"/>
+        <el-input v-model="queryParams.areaName" placeholder="请输入小区名称" clearable size="small"
+                  @keyup.enter.native="handleQuery"/>
       </el-form-item>
       <el-form-item label="发现问题" prop="findProblem">
         <el-select v-model="queryParams.findProblem" placeholder="请选择发现问题" clearable size="small">
@@ -15,15 +16,16 @@
         </el-select>
       </el-form-item>
       <el-form-item label="创建人" prop="createBy">
-      <el-select v-model="queryParams.createBy" filterable placeholder="请选择创建人" clearable size="small">
-        <el-option v-for="item in workerList"
-                   :key="item.id"
-                   :label="item.name"
-                   :value="item.id"/>
-      </el-select>
-    </el-form-item>
-      <el-form-item label="队伍" >
-        <el-select v-model="queryParams.ranks" clearable placeholder="请选择队伍" :disabled="postName.indexOf('xx') > -1">
+        <el-select v-model="queryParams.createBy" filterable placeholder="请选择创建人" clearable size="small">
+          <el-option v-for="item in workerList"
+                     :key="item.id"
+                     :label="item.name"
+                     :value="item.id"/>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="队伍">
+        <el-select v-model="queryParams.ranks" clearable placeholder="请选择队伍"
+                   :disabled="postName.indexOf('xx') > -1">
           <el-option
             v-for="item in postOptions"
             :key="item.postId"
@@ -74,6 +76,18 @@
       </el-col>
       <el-col :span="1.5">
         <el-button
+          type="danger"
+          plain
+          icon="el-icon-delete"
+          size="mini"
+          :disabled="multiple"
+          @click="openshShow(null,true)"
+          v-hasPermi="['gas:regulatingBoxMaintenance:remove']"
+        >批量审核
+        </el-button>
+      </el-col>
+      <el-col :span="1.5">
+        <el-button
           type="warning"
           plain
           icon="el-icon-download"
@@ -92,7 +106,7 @@
       <el-table-column label="主键id" align="center" prop="id" v-if="false"/>
       <el-table-column label="所属小区" align="center" prop="areaName"/>
       <el-table-column label="所属楼宇" align="center" prop="buildingName"/>
-<!--      <el-table-column label="所属单元" align="center" prop="unitName"/>-->
+      <!--      <el-table-column label="所属单元" align="center" prop="unitName"/>-->
       <el-table-column label="发现问题" align="center" prop="findProblem">
         <template slot-scope="scope">
           <dict-tag :options="dict.type.find_problem" :value="scope.row.findProblem"/>
@@ -201,7 +215,8 @@
               v-for="dict in dict.type.find_problem"
               :key="dict.value"
               :label="dict.value"
-            >{{dict.label}}</el-radio>
+            >{{ dict.label }}
+            </el-radio>
           </el-radio-group>
         </el-form-item>
         <el-form-item label="照片" prop="photoList">
@@ -225,7 +240,7 @@ import {
   getCourtyardNetworkManagement,
   delCourtyardNetworkManagement,
   addCourtyardNetworkManagement,
-  updateCourtyardNetworkManagement
+  updateCourtyardNetworkManagement, batchReview
 } from "@/api/gas/courtyardNetworkManagement";
 import {getAreaList} from "@/api/gas/area";
 import {getBuildingList} from "@/api/gas/building";
@@ -274,11 +289,11 @@ export default {
         pageSize: 10,
         unitId: undefined,
         findProblem: undefined,
-        ranks:(Cookies.get("postName").indexOf('xx') > -1 ? parseInt(Cookies.get("postId")) : undefined),
+        ranks: (Cookies.get("postName").indexOf('xx') > -1 ? parseInt(Cookies.get("postId")) : undefined),
       },
       // 岗位选项
       postOptions: [],
-      postName:Cookies.get("postName"),
+      postName: Cookies.get("postName"),
       // 表单参数
       form: {},
       formSH: {},
@@ -314,8 +329,8 @@ export default {
     this.getList();
   },
   methods: {
-    getPostList(){
-      listPostAll({remark:'ranks'}).then(response => {
+    getPostList() {
+      listPostAll({remark: 'ranks'}).then(response => {
         this.postOptions = response.data;
       });
     },
@@ -336,17 +351,29 @@ export default {
             }).finally(() => {
               this.buttonLoading = false;
             });
+          }else if (this.formSH.uids.length > 0) {
+            batchReview(this.formSH).then(response => {
+              this.$modal.msgSuccess("审核成功");
+              this.openSH = false;
+              this.getList();
+            }).finally(() => {
+              this.buttonLoading = false;
+            });
           }
         }
       })
     },
-    openshShow(data) {
+    openshShow(data, isBatch) {
       this.formSH = {
         id: undefined,
+        uids: [],
         processStatus: undefined,
         processComments: undefined,
       }
-      this.formSH.id = data.id
+      if (isBatch)
+        this.formSH.uids = this.ids
+      else
+        this.formSH.id = data.id
       this.openSH = true
     },
     // 小区下拉

+ 41 - 13
src/views/gas/emergencyRepair/index.vue

@@ -20,7 +20,8 @@
         />
       </el-form-item>
       <el-form-item label="报修类型" prop="repairType">
-        <el-select v-model="queryParams.repairType" placeholder="请选择报修类型" clearable size="small">
+        <el-select v-model="queryParams.repairType" placeholder="请选择报修类型" clearable size="small"
+                   @keyup.enter.native="handleQuery">
           <el-option
             v-for="dict in dict.type.repair_type"
             :key="dict.value"
@@ -60,6 +61,22 @@
           end-placeholder="结束日期">
         </el-date-picker>
       </el-form-item>
+      <el-form-item label="报修时间">
+        <el-date-picker
+          value-format="yyyy-MM-dd"
+          v-model="queryParams.ydm"
+          type="date"
+          placeholder="报修时间年月日">
+        </el-date-picker>
+      </el-form-item>
+      <el-form-item label="报修时间">
+        <el-time-picker
+          v-model="queryParams.hsm"
+          value-format="HH:mm:ss"
+          placeholder="报修时间时分秒">
+        </el-time-picker>
+      </el-form-item>
+
       <el-form-item>
         <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
         <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
@@ -190,17 +207,17 @@
             v-hasPermi="['gas:emergencyRepair:remove']"
           >审核记录
           </el-button>
-<!--          <el-button-->
-<!--            size="mini"-->
-<!--            type="text"-->
-<!--            icon="el-icon-edit"-->
-<!--            v-show="postName == 'admin' && (scope.row.processList.length == 0-->
-<!--            || scope.row.processList.filter(item => item.userPost == 'admin').length == 0-->
-<!--            || scope.row.processList.filter(item => item.userPost == 'admin' && item.processStatus == '0').length == 0)"-->
-<!--            @click="openshShow(scope.row,'admin',true)"-->
-<!--            v-hasPermi="['gas:emergencyRepair:remove']"-->
-<!--          >工程审核-->
-<!--          </el-button>-->
+          <!--          <el-button-->
+          <!--            size="mini"-->
+          <!--            type="text"-->
+          <!--            icon="el-icon-edit"-->
+          <!--            v-show="postName == 'admin' && (scope.row.processList.length == 0-->
+          <!--            || scope.row.processList.filter(item => item.userPost == 'admin').length == 0-->
+          <!--            || scope.row.processList.filter(item => item.userPost == 'admin' && item.processStatus == '0').length == 0)"-->
+          <!--            @click="openshShow(scope.row,'admin',true)"-->
+          <!--            v-hasPermi="['gas:emergencyRepair:remove']"-->
+          <!--          >工程审核-->
+          <!--          </el-button>-->
           <el-button
             size="mini"
             type="text"
@@ -263,7 +280,7 @@
             label="岗位"
             width="65">
             <template slot-scope="scope">
-<!--              <span v-if="scope.row.userPost == 'admin'">管理员</span>-->
+              <!--              <span v-if="scope.row.userPost == 'admin'">管理员</span>-->
               <span v-if="scope.row.userPost == 'deputyDirector'">副处长</span>
               <span v-if="scope.row.userPost == 'director'">处长</span>
             </template>
@@ -526,6 +543,10 @@ export default {
         pageNum: 1,
         pageSize: 10,
         repairName: undefined,
+        enginName: undefined,
+        time: undefined,
+        ydm: '',
+        hsm: '',
         repairType: undefined,
         causesOfDamage: undefined,
         pipelinePressure: undefined,
@@ -644,6 +665,8 @@ export default {
     /** 查询抢险维修列表 */
     getList() {
       this.loading = true;
+      console.log(this.queryParams)
+      debugger
       listEmergencyRepair(this.queryParams).then(response => {
         this.emergencyRepairList = response.rows;
         this.total = response.total;
@@ -685,6 +708,11 @@ export default {
     },
     /** 搜索按钮操作 */
     handleQuery() {
+      if ((this.queryParams.hsm != '' && this.queryParams.hsm != null && this.queryParams.hsm != undefined )
+        && (this.queryParams.ydm == '' || this.queryParams.ydm == null || this.queryParams.ydm == undefined)) {
+        this.$message.info("请选择报修日期")
+        return
+      }
       this.queryParams.pageNum = 1;
       this.getList();
     },

+ 54 - 24
src/views/gas/regulatingBoxMaintenance/index.vue

@@ -103,6 +103,18 @@
       </el-col>
       <el-col :span="1.5">
         <el-button
+          type="danger"
+          plain
+          icon="el-icon-delete"
+          size="mini"
+          :disabled="multiple"
+          @click="process(null,true)"
+          v-hasPermi="['gas:regulatingBoxMaintenance:remove']"
+        >批量审核
+        </el-button>
+      </el-col>
+      <el-col :span="1.5">
+        <el-button
           type="warning"
           plain
           icon="el-icon-download"
@@ -135,7 +147,8 @@
       <el-table-column label="上传时间" align="center" prop="createTime"/>
       <el-table-column label="审核状态" align="center" prop="processStatus">
         <template slot-scope="scope">
-          <dict-tag :options="dict.type.process_status" :value="scope.row.processStatus" v-if="scope.row.processStatus != null"/>
+          <dict-tag :options="dict.type.process_status" :value="scope.row.processStatus"
+                    v-if="scope.row.processStatus != null"/>
           <span v-else>未审核</span>
         </template>
       </el-table-column>
@@ -200,7 +213,8 @@
       width="30%">
       <el-form ref="shFrom" :model="shFrom" label-width="80px">
         <el-form-item label="审核状态" prop="processStatus">
-          <el-select v-model="shFrom.processStatus" placeholder="请选择审核状态" clearable size="small" @change="$forceUpdate">
+          <el-select v-model="shFrom.processStatus" placeholder="请选择审核状态" clearable size="small"
+                     @change="$forceUpdate">
             <el-option
               v-for="dict in dict.type.process_status"
               :key="dict.value"
@@ -251,14 +265,15 @@
           <imageUpload v-model="form.photoList" :disabled="disabled"/>
         </el-form-item>
         <el-form-item label="审核状态" v-show="isDisabled && form.processStatus!=null">
-          <el-select v-model="form.processStatus" placeholder="请选择审核状态" clearable size="small" @change="$forceUpdate">
-          <el-option
-            v-for="dict in dict.type.process_status"
-            :key="dict.value"
-            :label="dict.label"
-            :value="dict.value"
-          />
-        </el-select>
+          <el-select v-model="form.processStatus" placeholder="请选择审核状态" clearable size="small"
+                     @change="$forceUpdate">
+            <el-option
+              v-for="dict in dict.type.process_status"
+              :key="dict.value"
+              :label="dict.label"
+              :value="dict.value"
+            />
+          </el-select>
         </el-form-item>
         <el-form-item label="审核备注" v-show="isDisabled && form.processStatus!=null">
           <el-input type="textarea" v-model="form.remarks" placeholder=""/>
@@ -279,7 +294,7 @@ import {
   getRegulatingBoxMaintenance,
   delRegulatingBoxMaintenance,
   addRegulatingBoxMaintenance,
-  updateRegulatingBoxMaintenance
+  updateRegulatingBoxMaintenance, batchReview
 } from "@/api/gas/regulatingBoxMaintenance";
 import Cookies from "js-cookie";
 import {listPostAll} from "@/api/system/post";
@@ -329,9 +344,10 @@ export default {
       },
       // 表单参数
       form: {},
-      shFrom:{
+      shFrom: {
         id: '',
-        processStatus:'',
+        uids: [],
+        processStatus: '',
         remarks: ""
       },
       // 表单校验
@@ -362,20 +378,34 @@ export default {
     this.getList();
   },
   methods: {
-    upprocess(){
-      if (this.shFrom.processStatus == undefined || this.shFrom.processStatus == ''){
+    upprocess() {
+      if (this.shFrom.processStatus == undefined || this.shFrom.processStatus == '') {
         this.$message.warning("请选择审核状态")
       }
-      updateRegulatingBoxMaintenance(this.shFrom).then(response => {
-        this.$modal.msgSuccess("审核成功");
-        this.getList();
-      }).finally(() => {
-        this.dialogVisible = false;
-      });
+      if (this.shFrom.uids.length == 0){
+        updateRegulatingBoxMaintenance(this.shFrom).then(response => {
+          this.$modal.msgSuccess("审核成功");
+          this.getList();
+        }).finally(() => {
+          this.dialogVisible = false;
+        });
+      }else {
+        batchReview(this.shFrom).then(response => {
+          this.$modal.msgSuccess("审核成功");
+          this.getList();
+        }).finally(() => {
+          this.dialogVisible = false;
+        });
+      }
+
     },
-    process(data) {
+    process(data, isBatch) {
       this.shFrom.id = undefined
-      this.shFrom.id = data.id;
+      this.shFrom.uids = []
+      if (isBatch)
+        this.shFrom.uids = this.ids
+      else
+        this.shFrom.id = data.id;
       this.shFrom.processStatus = '';
       this.shFrom.remarks = '';
       this.dialogVisible = true;
@@ -439,7 +469,7 @@ export default {
       this.title = "添加调压箱维护";
     },
     /** 修改按钮操作 */
-    handleUpdate(row,isDisabled) {
+    handleUpdate(row, isDisabled) {
       this.loading = true;
       this.isDisabled = isDisabled;
       this.reset();

+ 29 - 6
src/views/gas/regulatorBox/index.vue

@@ -84,6 +84,18 @@
       </el-col>
       <el-col :span="1.5">
         <el-button
+          type="danger"
+          plain
+          icon="el-icon-delete"
+          size="mini"
+          :disabled="multiple"
+          @click="process(null,true)"
+          v-hasPermi="['gas:regulatingBoxMaintenance:remove']"
+        >批量审核
+        </el-button>
+      </el-col>
+      <el-col :span="1.5">
+        <el-button
           type="warning"
           plain
           icon="el-icon-download"
@@ -588,7 +600,7 @@ import {
   getRegulatorBox,
   delRegulatorBox,
   addRegulatorBox,
-  updateRegulatorBox
+  updateRegulatorBox, batchReview
 } from "@/api/gas/regulatorBox";
 import {getAreaList} from "@/api/gas/area";
 import {getBuildingList} from "@/api/gas/building";
@@ -597,7 +609,6 @@ import el from "element-ui/src/locale/lang/el";
 import {getWorker} from "@/api/gas/user";
 import Cookies from "js-cookie";
 import {listPostAll} from "@/api/system/post";
-import {updateRegulatingBoxMaintenance} from "@/api/gas/regulatingBoxMaintenance";
 
 export default {
   name: "RegulatorBox",
@@ -635,6 +646,7 @@ export default {
       dialogVisible: false,
       shFrom:{
         id: '',
+        uids: [],
         processStatus:'',
         remarks: ""
       },
@@ -760,13 +772,20 @@ export default {
     upprocess(){
       if (this.shFrom.processStatus == undefined || this.shFrom.processStatus == ''){
         this.$message.warning("请选择审核状态")
-      }
+      } if (this.shFrom.uids.length == 0){
       updateRegulatorBox(this.shFrom).then(response => {
         this.$modal.msgSuccess("审核成功");
         this.getList();
       }).finally(() => {
         this.dialogVisible = false;
-      });
+      });}else {
+        batchReview(this.shFrom).then(response => {
+          this.$modal.msgSuccess("审核成功");
+          this.getList();
+        }).finally(() => {
+          this.dialogVisible = false;
+        });
+      }
     },
     getPostList(){
       listPostAll({remark:'ranks'}).then(response => {
@@ -900,9 +919,13 @@ export default {
         this.title = "查看调压箱管理";
       });
     },
-    process(data) {
+    process(data, isBatch) {
       this.shFrom.id = undefined
-      this.shFrom.id = data.id;
+      this.shFrom.uids = []
+      if (isBatch)
+        this.shFrom.uids = this.ids
+      else
+        this.shFrom.id = data.id;
       this.shFrom.processStatus = '';
       this.shFrom.remarks = '';
       this.dialogVisible = true;

+ 178 - 3
src/views/gas/valveWellPosition/index.vue

@@ -78,6 +78,17 @@
       </el-col>
       <el-col :span="1.5">
         <el-button
+          type="info"
+          plain
+          icon="el-icon-upload2"
+          size="mini"
+          @click="handleImport"
+          v-hasPermi="['system:user:import']"
+        >导入
+        </el-button>
+      </el-col>
+      <el-col :span="1.5">
+        <el-button
           type="warning"
           plain
           icon="el-icon-download"
@@ -103,6 +114,19 @@
       <el-table-column label="经度" align="center" prop="longitude" />
       <el-table-column label="纬度" align="center" prop="latitude" />
       <el-table-column label="控制区域" align="center" prop="remark" />
+      <el-table-column label="行政区" align="center" prop="district" >
+        <template slot-scope="scope">
+          <dict-tag :options="dict.type.district" :value="scope.row.district"/>
+        </template>
+      </el-table-column>
+      <el-table-column label="队伍" align="center" prop="team" />
+      <el-table-column label="阀头形状" align="center" prop="valveHeadShape" />
+      <el-table-column label="阀井深度(米)" align="center" prop="valveWellDepth" />
+      <el-table-column label="井盖代别" align="center" prop="manholeCoverInstead" />
+      <el-table-column label="积水情况" align="center" prop="waterCondition" />
+      <el-table-column label="压力等级" align="center" prop="pressureRating" />
+      <el-table-column label="是否需要下井才能开关阀门" align="center" prop="isXyxjcnkg" />
+      <el-table-column label="备注" align="center" prop="remarks" />
       <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
         <template slot-scope="scope">
           <el-button
@@ -123,6 +147,46 @@
       </el-table-column>
     </el-table>
 
+    <!-- 用户导入对话框 -->
+    <el-dialog :title="upload.title" :visible.sync="upload.open" width="400px" append-to-body>
+      <el-upload
+        ref="upload"
+        :limit="1"
+        accept=".xlsx, .xls"
+        :headers="upload.headers"
+        :action="upload.url + '?updateSupport=' + upload.updateSupport"
+        :disabled="upload.isUploading"
+        :on-progress="handleFileUploadProgress"
+        :on-success="handleFileSuccess"
+        :auto-upload="false"
+        drag
+      >
+        <i class="el-icon-upload"></i>
+        <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
+        <div class="el-upload__tip text-center" slot="tip">
+          <!--<div class="el-upload__tip" slot="tip">-->
+          <!--<el-checkbox v-model="upload.updateSupport"/>-->
+          <!--是否更新已经存在的用户数据-->
+          <!--</div>-->
+          <span>仅允许导入xls、xlsx格式文件。</span>
+          <el-link type="primary" :underline="false" style="font-size:12px;vertical-align: baseline;"
+                   @click="importTemplate"
+          >下载模板
+          </el-link>
+        </div>
+      </el-upload>
+      <div style="padding-top: 15px;line-height: 25px;font-size: 14px;">
+        完成度:{{ bfb }}%
+        <progress max="100" :value="bfb" style="width: 200px;height: 18px;"></progress>
+        <br>
+        导入结果:{{ jdtMsg }}
+      </div>
+      <div slot="footer" class="dialog-footer">
+        <el-button type="primary" @click="submitFileForm">确 定</el-button>
+        <el-button @click="upload.open = false;bfb='0';jdtMsg=''">取 消</el-button>
+      </div>
+    </el-dialog>
+
     <pagination
       v-show="total>0"
       :total="total"
@@ -132,8 +196,8 @@
     />
 
     <!-- 添加或修改阀井位置对话框 -->
-    <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
-      <el-form ref="form" :model="form" :rules="rules" label-width="80px">
+    <el-dialog :title="title" :visible.sync="open" width="850px" append-to-body>
+      <el-form ref="form" :model="form" :rules="rules" label-width="180px"  :inline="true">
         <el-form-item label="阀井名称" prop="valveWellName">
           <el-input v-model="form.valveWellName" placeholder="请输入阀井名称" />
         </el-form-item>
@@ -147,7 +211,48 @@
           <el-input v-model="form.latitude" placeholder="请输入纬度" />
         </el-form-item>
         <el-form-item label="控制区域" prop="remark">
-          <el-input v-model="form.remark" type="textarea" placeholder="请输入内容" />
+          <el-input v-model="form.remark" placeholder="请输入内容" />
+        </el-form-item>
+        <el-form-item label="行政区" prop="district">
+          <el-select v-model="form.district" placeholder="请选择行政区" style="width: 100%">
+            <el-option
+              v-for="dict in dict.type.district"
+              :key="dict.value"
+              :label="dict.label"
+              :value="dict.value"
+            ></el-option>
+          </el-select>
+        </el-form-item>
+        <el-form-item label="队伍" prop="team">
+          <el-select v-model="form.team" clearable placeholder="请选择队伍">
+          <el-option
+            v-for="item in postOptions"
+            :key="item.postName"
+            :label="item.postName"
+            :value="item.postName"
+          ></el-option>
+        </el-select>
+        </el-form-item>
+        <el-form-item label="阀头形状" prop="valveHeadShape">
+          <el-input v-model="form.valveHeadShape" placeholder="请输入内容" />
+        </el-form-item>
+        <el-form-item label="阀井深度(米)" prop="valveWellDepth">
+          <el-input v-model="form.valveWellDepth" placeholder="请输入内容" />
+        </el-form-item>
+        <el-form-item label="井盖代别" prop="manholeCoverInstead">
+          <el-input v-model="form.manholeCoverInstead" placeholder="请输入内容" />
+        </el-form-item>
+        <el-form-item label="积水情况" prop="waterCondition">
+          <el-input v-model="form.waterCondition" placeholder="请输入内容" />
+        </el-form-item>
+        <el-form-item label="压力等级" prop="pressureRating">
+          <el-input v-model="form.pressureRating" placeholder="请输入内容" />
+        </el-form-item>
+        <el-form-item label="是否需要下井才能开关阀门" prop="isXyxjcnkg">
+          <el-input v-model="form.isXyxjcnkg" placeholder="请输入内容" />
+        </el-form-item>
+        <el-form-item label="备注" prop="remarks">
+          <el-input v-model="form.remarks" placeholder="请输入内容" />
         </el-form-item>
       </el-form>
       <div slot="footer" class="dialog-footer">
@@ -160,17 +265,27 @@
 
 <script>
 import { listValveWellPosition, getValveWellPosition, delValveWellPosition, addValveWellPosition, updateValveWellPosition } from "@/api/gas/valveWellPosition";
+import {listPostAll} from "@/api/system/post";
+import {getToken} from "@/utils/auth";
+import {clearFlushProgress, clearFlushProgressA, flushProgress, flushProgressA} from "@/api/gas/area";
 
 export default {
   name: "ValveWellPosition",
+  dicts: ['district'],
   data() {
     return {
+      //进度条
+      timeInterval: null,
+      bfb: '0',
+      jdtMsg: '',
       // 按钮loading
       buttonLoading: false,
       // 遮罩层
       loading: true,
       // 导出遮罩层
       exportLoading: false,
+      // 岗位选项
+      postOptions: [],
       // 选中数组
       ids: [],
       // 非单个禁用
@@ -198,6 +313,21 @@ export default {
       },
       // 表单参数
       form: {},
+      // 用户导入参数
+      upload: {
+        // 是否显示弹出层(用户导入)
+        open: false,
+        // 弹出层标题(用户导入)
+        title: '',
+        // 是否禁用上传
+        isUploading: false,
+        // 是否更新已经存在的用户数据
+        updateSupport: 0,
+        // 设置上传的请求头部
+        headers: { Authorization: 'Bearer ' + getToken() },
+        // 上传的地址
+        url: process.env.VUE_APP_BASE_API + '/gas/valveWellPosition/importData'
+      },
       // 表单校验
       rules: {
         id: [
@@ -219,9 +349,54 @@ export default {
     };
   },
   created() {
+    this.getPostList();
     this.getList();
   },
   methods: {
+    /** 下载模板操作 */
+    importTemplate() {
+      this.$download.excel('/gas/valveWellPosition/importTemplate')
+    },
+    // 提交上传文件
+    submitFileForm() {
+      const ther = this
+      this.timeInterval = setInterval(function() {
+        ther.flushProgress()
+      }, 1500)
+      this.$refs.upload.submit()
+    },
+    // 提交上传文件
+    flushProgress() {
+      flushProgressA().then(response => {
+        this.bfb = parseInt(response.data.bfb) >= 100 ? 100 : response.data.bfb
+        this.jdtMsg = response.data.message
+        if (response.data.message != null && response.data.message != '') {
+          clearFlushProgressA().then(response => {
+          })
+          clearInterval(this.timeInterval)
+        }
+      })
+    },
+    // 文件上传中处理
+    handleFileUploadProgress(event, file, fileList) {
+      this.upload.isUploading = true
+    },
+    // 文件上传成功处理
+    handleFileSuccess(response, file, fileList) {
+      this.upload.isUploading = false
+      this.$refs.upload.clearFiles()
+      this.getList()
+    },
+    /** 导入按钮操作 */
+    handleImport() {
+      this.upload.title = '导入'
+      this.upload.open = true
+    },
+    getPostList(){
+      listPostAll({remark:'ranks'}).then(response => {
+        this.postOptions = response.data;
+      });
+    },
     /** 查询阀井位置列表 */
     getList() {
       this.loading = true;