Browse Source

2024.1.10电话筛选

bulusiLuo 1 year ago
parent
commit
63e71b4b19

+ 15 - 0
.vscode/launch.json

@@ -0,0 +1,15 @@
+{
+    // 使用 IntelliSense 了解相关属性。 
+    // 悬停以查看现有属性的描述。
+    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
+    "version": "0.2.0",
+    "configurations": [
+        {
+            "type": "chrome",
+            "request": "launch",
+            "name": "针对 localhost 启动 Chrome",
+            "url": "http://localhost:8080",
+            "webRoot": "${workspaceFolder}"
+        }
+    ]
+}

+ 10 - 2
src/views/currentSystem/waterHotline/statisticalReport/callList.vue

@@ -4,7 +4,7 @@
     <div v-show="showStatistic" class="statisticsPage">
       <div class="head">
         <el-row class="search_box" type="flex" :gutter="10" justify="space-between">
-          <el-col :span="12" class="searchs">
+          <el-col :span="18" class="searchs">
             <el-date-picker v-model="statisticvalue1" size="mini" clearable type="date" placeholder="开始日期" style=""
               value-format="yyyy-MM-dd" />
             &nbsp;至&nbsp;
@@ -17,9 +17,15 @@
               <el-option key="1" label="接通" value="1" />
               <el-option key="2" label="未接通" value="3" />
             </el-select>
+            &nbsp;&nbsp;
+            <span class="title2">用户电话:</span>
+            <el-input v-model="telephone" clearable filterable
+              style="display: inline-block; margin-left: 5px;margin-right: 5px; width: 140px" size="mini"
+              placeholder="请输入用户电话">
+            </el-input>
             <el-button type="primary" size="mini" @click="searchBtn">查询</el-button>
           </el-col>
-          <el-col :span="12" style="text-align: end">
+          <el-col :span="6" style="text-align: end">
             <el-button type="primary" size="mini" :disabled="multipleSelection.length !== 1" @click="start">播放</el-button>
             <el-button type="primary" size="mini" :disabled="multipleSelection.length !== 1"
               @click="dowmMP3">下载</el-button>
@@ -60,6 +66,7 @@ export default {
     // start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
     return {
       transferResult: "",
+      telephone: "",
       dialogVisible: false,
       audioSrc: "",
       dialogGDVisible: false,
@@ -254,6 +261,7 @@ export default {
         endTime: this.statisticvalue2 + " 23:59:59",
         startTime: this.statisticvalue1 + " 00:00:00",
         transferResult: this.transferResult,
+        telephone: this.telephone
       };
       Object.assign(params, this.pagination);
       getCallList(params).then((res) => {

+ 9 - 3
src/views/currentSystem/waterHotline/statisticalReport/callLogStatistics.vue

@@ -10,6 +10,11 @@
           <el-date-picker v-model="statisticvalue2" size="small" clearable type="date" placeholder="结束日期"
             value-format="yyyy-MM-dd" />
           &nbsp;&nbsp;
+          <span class="title2">用户电话:</span>
+          <el-input v-model="telephone" clearable filterable style="display: inline-block; margin-left: 5px; width: 140px"
+            size="mini" placeholder="请输入用户电话">
+          </el-input>
+          &nbsp;&nbsp;
           <el-button type="primary" size="small" @click="searchBtn">查询</el-button>
         </el-col>
         <el-col :span="8" style="text-align:end;">
@@ -63,6 +68,7 @@ export default {
       // 统计页面
       Bm: '',
       user: '',
+      telephone: '',
       departmentList: [],
       UserList: [],
       statisticvalue1: parseTime(start, '{y}-{m}-{d}'),
@@ -232,7 +238,8 @@ export default {
       }
       const params = {
         endTime: this.statisticvalue2 + ' 23:59:59',
-        startTime: this.statisticvalue1 + ' 00:00:00'
+        startTime: this.statisticvalue1 + ' 00:00:00',
+        telephone: this.telephone
       }
       Object.assign(params, this.pagination)
       getCallRecord(params).then(res => {
@@ -368,5 +375,4 @@ export default {
   margin-top: 10px;
   height: 375px;
   width: 90%;
-}
-</style>
+}</style>

+ 114 - 143
src/views/zhpt/buildsitemanage/components/buildDetails.vue

@@ -84,19 +84,16 @@
           <span class="flexTitle">附件:</span>
           <div class="flexInfo demo-image__preview">
             <div style="float:left;">
-              <el-image
-                v-for="(item,index) in buildReportData.filelist"
-                :key="index"
-                style=""
-                :src="item"
-                :preview-src-list="buildReportData.filelist"
-              />
+              <el-image v-for="(item, index) in buildReportData.filelist" :key="index" style="" :src="item"
+                :preview-src-list="buildReportData.filelist" />
             </div>
             <div>
-              <audio v-for="(item,index) in buildReportData.audioFileList" :key="index" controls="controls" preload="auto" :src="item" />
+              <audio v-for="(item, index) in buildReportData.audioFileList" :key="index" controls="controls" preload="auto"
+                :src="item" />
             </div>
             <div>
-              <video v-for="(item,index) in buildReportData.videoFileList" :key="index" controls="controls" preload="auto" :src="item" />
+              <video v-for="(item, index) in buildReportData.videoFileList" :key="index" controls="controls" preload="auto"
+                :src="item" />
             </div>
           </div>
         </div>
@@ -135,25 +132,25 @@
             <el-input v-model="checkHandleData.auditNotes" type="textarea" :rows="1" size="small" :disabled="true" />
           </div>
         </div>
-        <div v-show="checkHandleData.isrespect==='是'" class="flexDiv">
-          <span class="flexTitle">巡检组:</span>
+        <div v-show="checkHandleData.isrespect === '是'" class="flexDiv">
+          <span class="flexTitle">部门:</span>
           <div class="flexInfo">
             <el-input v-model="checkHandleData.inspectGroupIdName" size="small" :disabled="true" />
           </div>
         </div>
-        <div v-show="checkHandleData.isrespect==='是'" class="flexDiv">
+        <div v-show="checkHandleData.isrespect === '是'" class="flexDiv">
           <span class="flexTitle">巡查人:</span>
           <div class="flexInfo">
             <el-input v-model="checkHandleData.inspectUserName" size="small" :disabled="true" />
           </div>
         </div>
-        <div v-show="checkHandleData.isrespect==='是'" class="flexDiv">
+        <div v-show="checkHandleData.isrespect === '是'" class="flexDiv">
           <span class="flexTitle">巡查周期:</span>
           <div class="flexInfo">
             <el-input v-model="checkHandleData.periodName" size="small" :disabled="true" />
           </div>
         </div>
-        <div v-show="checkHandleData.isrespect==='是'" class="flexDivMax">
+        <div v-show="checkHandleData.isrespect === '是'" class="flexDivMax">
           <span class="flexTitle">起止时间:</span>
           <div class="flexInfo">
             <el-input v-model="checkHandleData.planDate" size="small" :disabled="true" />
@@ -162,12 +159,8 @@
       </div>
     </tf-table-legend>
     <tf-table-legend label="工地巡查记录" isopen="false" style="margin-top: 8px;">
-      <div
-        v-for="(item,index) in dangerXjRecordData"
-        v-show="dangerXjRecordData.length>0"
-        :key="index"
-        style="width: 100%; display: flex; flex-wrap: wrap;"
-      >
+      <div v-for="(item, index) in dangerXjRecordData" v-show="dangerXjRecordData.length > 0" :key="index"
+        style="width: 100%; display: flex; flex-wrap: wrap;">
         <div class="flexDiv">
           <span class="flexTitle">上报时间:</span>
           <div class="flexInfo">
@@ -196,84 +189,58 @@
           <span class="flexTitle">附件:</span>
           <div class="flexInfo demo-image__preview">
             <div style="float:left;">
-              <el-image
-                v-for="(file,fileindex) in item.filelist"
-                :key="fileindex"
-                style=""
-                :src="file"
-                :preview-src-list="item.filelist"
-              />
+              <el-image v-for="(file, fileindex) in item.filelist" :key="fileindex" style="" :src="file"
+                :preview-src-list="item.filelist" />
             </div>
             <div>
-              <audio v-for="(file,index) in item.audioFileList" :key="index" controls="controls" preload="auto" :src="file" />
+              <audio v-for="(file, index) in item.audioFileList" :key="index" controls="controls" preload="auto"
+                :src="file" />
             </div>
             <div>
-              <video v-for="(file,index) in item.videoFileList" :key="index" controls="controls" preload="auto" :src="file" />
+              <video v-for="(file, index) in item.videoFileList" :key="index" controls="controls" preload="auto"
+                :src="file" />
             </div>
           </div>
         </div>
-        <hr v-show=" index !== (dangerXjRecordData.length-1) " class="box-hr">
+        <hr v-show="index !== (dangerXjRecordData.length - 1)" class="box-hr">
       </div>
-      <div
-        v-show="dangerXjRecordData.length <=0 "
-        style="width: 100%; display: flex; flex-wrap: wrap;"
-      >
+      <div v-show="dangerXjRecordData.length <= 0" style="width: 100%; display: flex; flex-wrap: wrap;">
         <div style="width: 100%; height:40px;line-height:40px; text-align:center;">暂无工地巡查记录</div>
       </div>
     </tf-table-legend>
     <tf-table-legend label="工地消除登记" isopen="false" style="margin-top: 8px;">
-      <div
-        v-for="(item,index) in dangerRemoveCheckData"
-        v-show="dangerRemoveCheckData.length>0"
-        :key="index"
-        style="width: 100%; display: flex; flex-wrap: wrap;"
-      >
+      <div v-for="(item, index) in dangerRemoveCheckData" v-show="dangerRemoveCheckData.length > 0" :key="index"
+        style="width: 100%; display: flex; flex-wrap: wrap;">
         <div class="flexDivMax">
           <span class="flexTitle">消除工地情况:</span>
           <div class="flexInfo">
-            <el-input
-              v-model="item.notes"
-              placeholder="消除工地情况说明"
-              type="textarea"
-              :rows="1"
-              size="small"
-              :disabled="true"
-            />
+            <el-input v-model="item.notes" placeholder="消除工地情况说明" type="textarea" :rows="1" size="small"
+              :disabled="true" />
           </div>
         </div>
         <div class="flexImage">
           <span class="flexTitle">附件:</span>
           <div class="flexInfo demo-image__preview">
             <div style="float:left;">
-              <el-image
-                v-for="(file,fileindex) in item.filelist"
-                :key="fileindex"
-                style=""
-                :src="file"
-                :preview-src-list="item.filelist"
-              />
+              <el-image v-for="(file, fileindex) in item.filelist" :key="fileindex" style="" :src="file"
+                :preview-src-list="item.filelist" />
             </div>
             <div>
-              <audio v-for="(file,index) in item.audioFileList" :key="index" controls="controls" preload="auto" :src="file" />
+              <audio v-for="(file, index) in item.audioFileList" :key="index" controls="controls" preload="auto"
+                :src="file" />
             </div>
           </div>
         </div>
       </div>
-      <div
-        v-show="dangerRemoveCheckData.length <=0 "
-        style="width: 100%; display: flex; flex-wrap: wrap;"
-      >
+      <div v-show="dangerRemoveCheckData.length <= 0" style="width: 100%; display: flex; flex-wrap: wrap;">
         <div style="width: 100%; height:40px;line-height:40px; text-align:center;">暂无工地消除登记</div>
       </div>
     </tf-table-legend>
 
-    <tf-table-legend v-if="optionType === '1' " label="工地消除审核" :isopen="optionType !== '1' ? 'true' : 'false'" style="margin-top: 8px;">
-      <div
-        v-for="(item,index) in dangerRemoveCheckData"
-        v-show="dangerRemoveCheckData.length>0"
-        :key="index"
-        style="width: 100%; display: flex; flex-wrap: wrap;"
-      >
+    <tf-table-legend v-if="optionType === '1'" label="工地消除审核" :isopen="optionType !== '1' ? 'true' : 'false'"
+      style="margin-top: 8px;">
+      <div v-for="(item, index) in dangerRemoveCheckData" v-show="dangerRemoveCheckData.length > 0" :key="index"
+        style="width: 100%; display: flex; flex-wrap: wrap;">
         <div class="flexDiv">
           <span class="flexTitle">审核结果:</span>
           <div class="flexInfo">
@@ -298,17 +265,15 @@
             <el-input v-model="item.auditNotes" type="textarea" :rows="1" size="small" :disabled="true" />
           </div>
         </div>
-        <hr v-show=" index !== (dangerRemoveCheckData.length-1) " class="box-hr">
+        <hr v-show="index !== (dangerRemoveCheckData.length - 1)" class="box-hr">
       </div>
-      <div
-        v-show="dangerRemoveCheckData.length <=0 "
-        style="width: 100%; display: flex; flex-wrap: wrap;"
-      >
+      <div v-show="dangerRemoveCheckData.length <= 0" style="width: 100%; display: flex; flex-wrap: wrap;">
         <div style="width: 100%; height:40px;line-height:40px; text-align:center;">暂无工地消除审核</div>
       </div>
     </tf-table-legend>
 
-    <tf-table-legend v-if="optionType !== '1' " label="工地消除审核" :isopen="optionType !== '1' ? 'true' : 'false'" style="margin-top: 8px;">
+    <tf-table-legend v-if="optionType !== '1'" label="工地消除审核" :isopen="optionType !== '1' ? 'true' : 'false'"
+      style="margin-top: 8px;">
       <div style="width: 100%; display: flex; flex-wrap: wrap; ">
         <div class="flexDiv">
           <span class="flexTitle">审核结果:</span>
@@ -327,7 +292,7 @@
       </div>
     </tf-table-legend>
 
-    <span v-if="optionType !== '1' " slot="footer" class="dialog-footer">
+    <span v-if="optionType !== '1'" slot="footer" class="dialog-footer">
       <el-button size="small" @click="dialogClose()">取 消</el-button>&nbsp;&nbsp;
       <el-button type="primary" size="small" @click="confirmRemove()">确 定</el-button>
     </span>
@@ -368,7 +333,7 @@ export default {
         submitTime: '',		// 工地上报时间
         filelist: [], // 附件
         audioFileList: [],		// 语音文件
-        videoFileList:[],
+        videoFileList: [],
         ownerUnitName: '',		// 业主单位名称
         ownerUnitUser: '',		// 业主负责人
         ownerUnitPhone: ''		// 业主联系电话
@@ -412,25 +377,25 @@ export default {
     }
   },
   watch: {
-	  buildAry(newV, oldV) {
+    buildAry(newV, oldV) {
       console.log('工地ID:' + JSON.stringify(newV))
       this.buildAry = newV
       this.optionType = this.buildAry.optionType
       this.getTroubleById()
-	 }
+    }
   },
   mounted() {
     this.$nextTick(() => {
-     	console.log('入口参数:' + JSON.stringify(this.buildAry))
+      console.log('入口参数:' + JSON.stringify(this.buildAry))
       this.optionType = this.buildAry.optionType
-	 	this.getTroubleById()
+      this.getTroubleById()
     })
   },
   methods: {
-	  /**
-	   * @description 获取工地信息
-	   */
-	  getTroubleById() {
+    /**
+     * @description 获取工地信息
+     */
+    getTroubleById() {
       var that = this
       that.dangerXjRecordData = []
       that.dangerRemoveCheckData = []
@@ -511,7 +476,7 @@ export default {
                 createUser: element.createUserName, // 创建人
                 filelist: that.getFilePaths(element.filePathList, 1),		// 图片信息
                 audioFileList: that.getFilePaths(element.filePathList, 0),		// 语音信息
-                videoFileList:that.getFilePaths(element.filePathList, 2), // 视频信息
+                videoFileList: that.getFilePaths(element.filePathList, 2), // 视频信息
                 note: element.note,	// 情况说明
                 xaddr: element.xaddr,		// 地址描述
                 yaddr: element.yaddr		// 地址描述
@@ -531,7 +496,7 @@ export default {
                 auditUserName: element.auditUserName, // 审核人名称
                 filelist: that.getFilePaths(element.filePathList, 1),		// 图片信息
                 audioFileList: that.getFilePaths(element.filePathList, 0),		// 语音信息
-                videoFileList:that.getFilePaths(element.filePathList, 2), // 视频信息
+                videoFileList: that.getFilePaths(element.filePathList, 2), // 视频信息
                 createTime: element.createTime, // 创建时间
                 createUser: element.createUser, // 创建人
                 notes: element.notes,	// 消除工地情况说明
@@ -542,11 +507,11 @@ export default {
           }
         }
       })
-	  },
+    },
 
     /**
-	 * @description 获取工地详情
-	 */
+   * @description 获取工地详情
+   */
     getBuildById(buildId) {
       var that = this
       buildId = buildId || ''
@@ -569,8 +534,8 @@ export default {
     },
 
     /**
-	 * @description 附件处理
-	 */
+   * @description 附件处理
+   */
     getFilePaths(filePathList, fileType) {
       var that = this
       if (that.arrayIsNull(filePathList)) {
@@ -584,7 +549,7 @@ export default {
         if (esuffixt === 'amr' && fileType === 0) {
           const audioPath = `${IP}/base/file/loadAudio?remotePath=${es}&access_token=${token}`
           filepath.push(audioPath)
-          console.log(filepath,'filepath')
+          console.log(filepath, 'filepath')
           // getFileAudio(token,es).then(src => {
           // 	if (src) {
           // 		var reader = new FileReader();
@@ -609,9 +574,9 @@ export default {
           // 		this.$message.error('工地图片加载失败:' + src.message)
           // })
         }
-        if (esuffixt === 'mp4'&& fileType === 2) {
+        if (esuffixt === 'mp4' && fileType === 2) {
           console.log(es)
-          let fileName = es.substr(es.lastIndexOf('/')+1) // 获取文件名
+          let fileName = es.substr(es.lastIndexOf('/') + 1) // 获取文件名
           const videoPath = `${IP}/base/file/downloadFile?access_token=${token}&fileName=${fileName}&remotePath=${es}`
           filepath.push(videoPath)
         }
@@ -621,11 +586,11 @@ export default {
     },
 
     /**
-	 * @description 确认提交审核意见
-	 */
+   * @description 确认提交审核意见
+   */
     confirmRemove() {
       var that = this
-      	that.$confirm('确认提交审核意见?', '提示', {
+      that.$confirm('确认提交审核意见?', '提示', {
         confirmButtonText: '确定',
         cancelButtonText: '取消',
         type: 'warning'
@@ -639,7 +604,7 @@ export default {
 
         console.log('auditModel:' + JSON.stringify(auditModel))
         // 提交审核
-    		const auditData = JSON.parse(JSON.stringify(auditModel))
+        const auditData = JSON.parse(JSON.stringify(auditModel))
         reportBuildCheck(auditData).then(res => {
           if (res.code == -1) {
             that.$message.error('上报审核出错,请重试')
@@ -655,17 +620,17 @@ export default {
     },
 
     /**
-	 * @description 关闭弹窗
-	 */
+   * @description 关闭弹窗
+   */
     dialogClose() {
       console.log('触发关闭')
-      	// 触发父组件中的dialogVisibleEvent事件,并传递参数
-      	this.$emit('dialogVisibleEvent', false)
+      // 触发父组件中的dialogVisibleEvent事件,并传递参数
+      this.$emit('dialogVisibleEvent', false)
     },
 
     /**
-	 * @description 判断数组是否为空
-	 */
+   * @description 判断数组是否为空
+   */
     arrayIsNull(aryList) {
       return (typeof (aryList) == 'undefined' || aryList == null || aryList.length == 0)
     }
@@ -675,56 +640,62 @@ export default {
 
 <style lang='scss' scoped>
 .buildInfo {
-	height: 100%;
-	width: 100%;
-	padding: 5px;
+  height: 100%;
+  width: 100%;
+  padding: 5px;
 }
-.flexDiv{
-    width: 33%;
-    height: 30px;
-    line-height: 30px;
-    margin-top: 8px;
+
+.flexDiv {
+  width: 33%;
+  height: 30px;
+  line-height: 30px;
+  margin-top: 8px;
 }
-.flexDivMax{
-    width: 99%;
-   	min-height: 30px;
-    margin-top: 8px;
+
+.flexDivMax {
+  width: 99%;
+  min-height: 30px;
+  margin-top: 8px;
 }
-.flexImage{
-    width: 100%;
-    margin-top: 8px;
+
+.flexImage {
+  width: 100%;
+  margin-top: 8px;
 }
-.flexTitle{
-    min-width: 130px;
-    display: inline-block;
-    text-align: right;
+
+.flexTitle {
+  min-width: 130px;
+  display: inline-block;
+  text-align: right;
 }
-.flexInfo{
-	display: inline-block;
-	margin-left: 5px;
-	width:calc(100% - 140px);
+
+.flexInfo {
+  display: inline-block;
+  margin-left: 5px;
+  width: calc(100% - 140px);
 }
+
 /deep/.el-image__inner {
-	width: 100px;
-	height: 100px;
-	margin-right: 8px;
+  width: 100px;
+  height: 100px;
+  margin-right: 8px;
 
 }
 
-.box-hr{
-    width: 100%;
-    height: 1px;
-    background-color: #F0F0F0;
-    margin: 10px 0px 10px 0px;
-  }
+.box-hr {
+  width: 100%;
+  height: 1px;
+  background-color: #F0F0F0;
+  margin: 10px 0px 10px 0px;
+}
 
-.dialog-footer{
-	margin-top: 8px;
-display: flex;
-justify-content: flex-end;
-	padding-top: 10px;
-	text-align: right;
-	-webkit-box-sizing: border-box;
-	box-sizing: border-box;
+.dialog-footer {
+  margin-top: 8px;
+  display: flex;
+  justify-content: flex-end;
+  padding-top: 10px;
+  text-align: right;
+  -webkit-box-sizing: border-box;
+  box-sizing: border-box;
 }
 </style>

+ 1 - 1
src/views/zhpt/hiddendangermanage/components/troubleDetails.vue

@@ -138,7 +138,7 @@
           </div>
         </div>
         <div v-show="checkHandleData.isrespectName === '是'" class="flexDiv">
-          <span class="flexTitle">巡检组:</span>
+          <span class="flexTitle">部门:</span>
           <div class="flexInfo">
             <el-input v-model="checkHandleData.inspectGroupIdName" size="small" :disabled="true" />
           </div>