3 changed files with 522 additions and 39 deletions
			
			
		| @ -0,0 +1,485 @@ | |||||
|  | <template> | ||||
|  |   <div class="div_main"> | ||||
|  |     <div class="div_search"> | ||||
|  |       <el-form :inline="true" | ||||
|  |                :model="formData" | ||||
|  |                ref="ref_searchform" | ||||
|  |                :label-width="'90px'"> | ||||
|  |         <div> | ||||
|  | 
 | ||||
|  |           <el-form-item label="所属网格" | ||||
|  |                         prop="gridId"> | ||||
|  |             <el-select class="item_width_1" | ||||
|  |                        v-model="formData.gridId" | ||||
|  |                        placeholder="全部" | ||||
|  |                        size="small" | ||||
|  |                        @change="handleChangeG" | ||||
|  |                        clearable> | ||||
|  |               <el-option v-for="item in gridList" | ||||
|  |                          :key="item.value" | ||||
|  |                          :label="item.label" | ||||
|  |                          :value="item.value"> | ||||
|  |               </el-option> | ||||
|  |             </el-select> | ||||
|  | 
 | ||||
|  |           </el-form-item> | ||||
|  | 
 | ||||
|  |           <el-form-item label="所属房屋"> | ||||
|  |             <div class="resi-cell-value"> | ||||
|  |               <div class="resi-cell-col"> | ||||
|  |                 <el-form-item prop="neighborHoodId"> | ||||
|  |                   <el-select v-model.trim="formData.neighborHoodId" | ||||
|  |                              :disabled="!this.formData.gridId" | ||||
|  |                              placeholder="小区" | ||||
|  |                              size="small" | ||||
|  |                              clearable | ||||
|  |                              class="resi-cell-select" | ||||
|  |                              @change="handleChangeV"> | ||||
|  |                     <el-option v-for="item in optionsV" | ||||
|  |                                :key="item.value" | ||||
|  |                                :label="item.label" | ||||
|  |                                :value="item.value"> | ||||
|  |                     </el-option> | ||||
|  |                   </el-select> | ||||
|  |                 </el-form-item> | ||||
|  |                 <el-form-item prop="buildingId"> | ||||
|  |                   <el-select v-model.trim="formData.buildingId" | ||||
|  |                              placeholder="楼号" | ||||
|  |                              :disabled="!this.formData.neighborHoodId" | ||||
|  |                              size="small" | ||||
|  |                              clearable | ||||
|  |                              class="resi-cell-select resi-cell-select-middle list_item_width_1" | ||||
|  |                              @change="handleChangeB"> | ||||
|  |                     <el-option v-for="item in optionsB" | ||||
|  |                                :key="item.value" | ||||
|  |                                :label="item.label" | ||||
|  |                                :value="item.value"> | ||||
|  |                     </el-option> | ||||
|  |                   </el-select> | ||||
|  |                 </el-form-item> | ||||
|  |                 <el-form-item prop="buildingUnitId"> | ||||
|  |                   <el-select v-model.trim="formData.buildingUnitId" | ||||
|  |                              placeholder="单元" | ||||
|  |                              size="small" | ||||
|  |                              :disabled="!this.formData.buildingId" | ||||
|  |                              clearable | ||||
|  |                              class="resi-cell-select resi-cell-select-middle list_item_width_1" | ||||
|  |                              @change="handleChangeD"> | ||||
|  |                     <el-option v-for="item in optionsD" | ||||
|  |                                :key="item.value" | ||||
|  |                                :label="item.label" | ||||
|  |                                :value="item.value"> | ||||
|  |                     </el-option> | ||||
|  |                   </el-select> | ||||
|  |                 </el-form-item> | ||||
|  |                 <el-form-item prop="houseId"> | ||||
|  |                   <el-select v-model.trim="formData.houseId" | ||||
|  |                              placeholder="房号" | ||||
|  |                              :disabled="!this.formData.buildingUnitId" | ||||
|  |                              size="small" | ||||
|  |                              clearable | ||||
|  |                              class="resi-cell-select resi-cell-select-middle list_item_width_1"> | ||||
|  |                     <el-option v-for="item in optionsH" | ||||
|  |                                :key="item.value" | ||||
|  |                                :label="item.label" | ||||
|  |                                :value="item.value"> | ||||
|  |                     </el-option> | ||||
|  |                   </el-select> | ||||
|  |                 </el-form-item> | ||||
|  |               </div> | ||||
|  | 
 | ||||
|  |             </div> | ||||
|  |           </el-form-item> | ||||
|  | 
 | ||||
|  |         </div> | ||||
|  | 
 | ||||
|  |         <div> | ||||
|  |           <el-form-item label="变更时间" | ||||
|  |                         prop="startDate"> | ||||
|  |             <el-date-picker v-model="timeRange" | ||||
|  |                             size="small" | ||||
|  |                             type="daterange" | ||||
|  |                             value-format="yyyy-MM-dd" | ||||
|  |                             @change="handleTimeChange" | ||||
|  |                             range-separator="至" | ||||
|  |                             start-placeholder="开始时间" | ||||
|  |                             end-placeholder="结束时间"> | ||||
|  |             </el-date-picker> | ||||
|  | 
 | ||||
|  |           </el-form-item> | ||||
|  |           <el-button style="margin-left:30px" | ||||
|  |                      size="small" | ||||
|  |                      class="diy-button--search" | ||||
|  |                      @click="handleSearch">查询</el-button> | ||||
|  |           <el-button style="margin-left:10px" | ||||
|  |                      size="small" | ||||
|  |                      class="diy-button--reset" | ||||
|  |                      @click="resetSearch">重置</el-button> | ||||
|  |         </div> | ||||
|  |       </el-form> | ||||
|  |     </div> | ||||
|  |     <div class="div_table"> | ||||
|  | 
 | ||||
|  |       <el-table ref="ref_table" | ||||
|  |                 class="table" | ||||
|  |                 :data="tableData" | ||||
|  |                 border | ||||
|  |                 :height="tableHeight" | ||||
|  |                 v-loading="tableLoading" | ||||
|  |                 :header-cell-style="{background:'#2195FE',color:'#FFFFFF'}" | ||||
|  |                 style="width: 100%"> | ||||
|  | 
 | ||||
|  |         <el-table-column label="序号" | ||||
|  |                          header-align="center" | ||||
|  |                          align="center" | ||||
|  |                          type="index" | ||||
|  |                          width="50"></el-table-column> | ||||
|  | 
 | ||||
|  |         <el-table-column prop="gridName" | ||||
|  |                          header-align="center" | ||||
|  |                          align="center" | ||||
|  |                          show-overflow-tooltip | ||||
|  |                          label="所属网格" | ||||
|  |                          min-width="150"> | ||||
|  |         </el-table-column> | ||||
|  |         <el-table-column prop="houseName" | ||||
|  |                          header-align="center" | ||||
|  |                          align="center" | ||||
|  |                          show-overflow-tooltip | ||||
|  |                          label="所属房屋" | ||||
|  |                          min-width="150"> | ||||
|  |         </el-table-column> | ||||
|  |         <el-table-column prop="changeBefore" | ||||
|  |                          header-align="center" | ||||
|  |                          align="center" | ||||
|  |                          show-overflow-tooltip | ||||
|  |                          label="变更前" | ||||
|  |                          min-width="250"> | ||||
|  |         </el-table-column> | ||||
|  |         <el-table-column prop="changeAfter" | ||||
|  |                          header-align="center" | ||||
|  |                          align="center" | ||||
|  |                          show-overflow-tooltip | ||||
|  |                          label="变更后" | ||||
|  |                          min-width="250"> | ||||
|  |         </el-table-column> | ||||
|  |         <el-table-column prop="changeTime" | ||||
|  |                          header-align="center" | ||||
|  |                          align="center" | ||||
|  |                          label="变更时间" | ||||
|  |                          width="130"> | ||||
|  |         </el-table-column> | ||||
|  | 
 | ||||
|  |       </el-table> | ||||
|  |       <div> | ||||
|  |         <el-pagination @size-change="handleSizeChange" | ||||
|  |                        @current-change="handleCurrentChange" | ||||
|  |                        :current-page.sync="pageNo" | ||||
|  |                        :page-sizes="[20, 50, 100, 200]" | ||||
|  |                        :page-size="pageSize" | ||||
|  |                        layout="sizes, prev, pager, next, total" | ||||
|  |                        :total="total"> | ||||
|  |         </el-pagination> | ||||
|  |       </div> | ||||
|  | 
 | ||||
|  |     </div> | ||||
|  | 
 | ||||
|  |   </div> | ||||
|  | </template> | ||||
|  | 
 | ||||
|  | <script> | ||||
|  | 
 | ||||
|  | 
 | ||||
|  | import util from '@js/util.js'; | ||||
|  | import { requestPost } from "@/js/dai/request"; | ||||
|  | import { mapGetters } from 'vuex' | ||||
|  | import { Loading } from 'element-ui' // 引入Loading服务 | ||||
|  | 
 | ||||
|  | let loading // 加载动画 | ||||
|  | export default { | ||||
|  |   data () { | ||||
|  |     return { | ||||
|  |       loading: false, | ||||
|  |       total: 0, | ||||
|  |       pageSize: 20, | ||||
|  |       pageNo: 1, | ||||
|  |       tableLoading: false, | ||||
|  | 
 | ||||
|  |       optionsV: [], | ||||
|  |       optionsB: [], | ||||
|  |       optionsH: [], | ||||
|  |       optionsD: [], | ||||
|  | 
 | ||||
|  | 
 | ||||
|  |       tableData: [], | ||||
|  | 
 | ||||
|  |       agencyId: '', | ||||
|  |       gridList: [],//所属网格list--场所区域 | ||||
|  |       timeRange: [], | ||||
|  |       formData: { | ||||
|  |         gridId: '',//所属网格【网格Id】 | ||||
|  |         neighborHoodId: '',//小区ID	 | ||||
|  |         buildingId: '',//楼栋ID	 | ||||
|  |         buildingUnitId: '',//楼栋单元ID	 | ||||
|  |         houseId: '',//房屋ID	 | ||||
|  |         startDate: '',//开始日期,eg:20220510	 | ||||
|  |         endDate: '',//结束日期,eg:20220510	 | ||||
|  |       } | ||||
|  | 
 | ||||
|  | 
 | ||||
|  |     } | ||||
|  |   }, | ||||
|  |   components: { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  |   async created () { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  |   activated () { | ||||
|  |     this.$refs['ref_table'].doLayout() | ||||
|  |   }, | ||||
|  |   async mounted () { | ||||
|  | 
 | ||||
|  |     const { user } = this.$store.state | ||||
|  |     this.agencyId = user.agencyId | ||||
|  |     //获取网格下拉框数据 | ||||
|  |     await this.loadGrid() | ||||
|  | 
 | ||||
|  |     await this.loadTable() | ||||
|  |   }, | ||||
|  | 
 | ||||
|  |   methods: { | ||||
|  |     handleSearch () { | ||||
|  | 
 | ||||
|  |       this.loadTable() | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     async loadGrid () { | ||||
|  |       const url = "/gov/org/customergrid/gridoption" | ||||
|  | 
 | ||||
|  |       let params = { | ||||
|  |         agencyId: this.agencyId | ||||
|  |       } | ||||
|  | 
 | ||||
|  |       const { data, code, msg } = await requestPost(url, params) | ||||
|  | 
 | ||||
|  |       if (code === 0) { | ||||
|  |         this.gridList = data | ||||
|  | 
 | ||||
|  |       } else { | ||||
|  |         this.$message.error(msg) | ||||
|  |       } | ||||
|  | 
 | ||||
|  |     }, | ||||
|  | 
 | ||||
|  | 
 | ||||
|  |     async loadTable () { | ||||
|  |       this.tableLoading = true | ||||
|  | 
 | ||||
|  |       const url = "/gov/org/icHouseChangeRecord/list" | ||||
|  |       // const url = "http://yapi.elinkservice.cn/mock/245/epmetuser/icEpidemicSpecialAttention/list" | ||||
|  |       let params = { | ||||
|  |         pageSize: this.pageSize, | ||||
|  |         pageNo: this.pageNo, | ||||
|  |         ...this.formData | ||||
|  |       } | ||||
|  | 
 | ||||
|  |       const { data, code, msg } = await requestPost(url, params) | ||||
|  | 
 | ||||
|  |       if (code === 0) { | ||||
|  |         this.total = data.total | ||||
|  |         this.tableData = data.list | ||||
|  | 
 | ||||
|  | 
 | ||||
|  |       } else { | ||||
|  |         this.$message.error(msg) | ||||
|  |       } | ||||
|  |       this.tableLoading = false | ||||
|  |     }, | ||||
|  | 
 | ||||
|  | 
 | ||||
|  |     handleChangeG (val) { | ||||
|  |       console.log('val', val) | ||||
|  |       this.formData.neighborHoodId = '' | ||||
|  |       this.formData.buildingId = '' | ||||
|  |       this.formData.buildingUnitId = '' | ||||
|  |       this.formData.houseId = '' | ||||
|  |       this.getValiheList() | ||||
|  |       this.getBuildList() | ||||
|  |       this.getUniList() | ||||
|  |       this.getHouseList() | ||||
|  |     }, | ||||
|  |     handleChangeV (val) { | ||||
|  |       console.log('val', val) | ||||
|  |       this.formData.buildingId = '' | ||||
|  |       this.formData.buildingUnitId = '' | ||||
|  |       this.formData.houseId = '' | ||||
|  |       this.getBuildList() | ||||
|  |       this.getUniList() | ||||
|  |       this.getHouseList() | ||||
|  |     }, | ||||
|  |     handleChangeB (val) { | ||||
|  |       console.log('val', val) | ||||
|  |       this.formData.buildingUnitId = '' | ||||
|  |       this.formData.houseId = '' | ||||
|  |       this.getUniList() | ||||
|  |       this.getHouseList() | ||||
|  |     }, | ||||
|  |     handleChangeD () { | ||||
|  |       this.formData.houseId = '' | ||||
|  |       this.getHouseList() | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     getValiheList () { | ||||
|  |       const { user } = this.$store.state | ||||
|  |       this.$http | ||||
|  |         .post('/gov/org/icneighborhood/neighborhoodoption', { gridId: this.formData.gridId }) | ||||
|  |         .then(({ data: res }) => { | ||||
|  |           if (res.code !== 0) { | ||||
|  |             return this.$message.error(res.msg) | ||||
|  |           } else { | ||||
|  |             console.log('获取查询详情成功', res.data) | ||||
|  |             this.optionsV = res.data | ||||
|  |           } | ||||
|  |         }) | ||||
|  |         .catch(() => { | ||||
|  |           return this.$message.error('网络错误') | ||||
|  |         }) | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     getBuildList () { | ||||
|  |       this.$http | ||||
|  |         .post('/gov/org/icbuilding/buildingoption', { neighborHoodId: this.formData.neighborHoodId }) | ||||
|  |         .then(({ data: res }) => { | ||||
|  |           if (res.code !== 0) { | ||||
|  |             return this.$message.error(res.msg) | ||||
|  |           } else { | ||||
|  |             console.log('获取查询详情成功', res.data) | ||||
|  |             this.optionsB = res.data | ||||
|  |           } | ||||
|  |         }) | ||||
|  |         .catch(() => { | ||||
|  |           return this.$message.error('网络错误') | ||||
|  |         }) | ||||
|  |     }, | ||||
|  |     getUniList () { | ||||
|  |       this.$http | ||||
|  |         .post('/gov/org/icbuildingunit/unitoption', { buildingId: this.formData.buildingId }) | ||||
|  |         .then(({ data: res }) => { | ||||
|  |           if (res.code !== 0) { | ||||
|  |             return this.$message.error(res.msg) | ||||
|  |           } else { | ||||
|  |             console.log('获取查询详情成功', res.data) | ||||
|  |             this.optionsD = res.data | ||||
|  |           } | ||||
|  |         }) | ||||
|  |         .catch(() => { | ||||
|  |           return this.$message.error('网络错误') | ||||
|  |         }) | ||||
|  |     }, | ||||
|  |     getHouseList () { | ||||
|  |       this.$http | ||||
|  |         .post('/gov/org/ichouse/houseoption', { buildingUnitId: this.formData.buildingUnitId }) | ||||
|  |         .then(({ data: res }) => { | ||||
|  |           if (res.code !== 0) { | ||||
|  |             return this.$message.error(res.msg) | ||||
|  |           } else { | ||||
|  |             console.log('获取查询详情成功', res.data) | ||||
|  |             this.optionsH = res.data | ||||
|  |           } | ||||
|  |         }) | ||||
|  |         .catch(() => { | ||||
|  |           return this.$message.error('网络错误') | ||||
|  |         }) | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     handleTimeChange (time) { | ||||
|  |       if (time) { | ||||
|  |         const startTimeArray = util.dateFormatter(time[0], 'date').split('-') | ||||
|  |         const endTimeArray = util.dateFormatter(time[1], 'date').split('-') | ||||
|  | 
 | ||||
|  |         this.formData.startDate = startTimeArray[0] + startTimeArray[1] + startTimeArray[2] | ||||
|  |         this.formData.endDate = endTimeArray[0] + endTimeArray[1] + endTimeArray[2] | ||||
|  | 
 | ||||
|  |         // this.startTimeShow = startTimeArray[0] + '年' + startTimeArray[1] + '月' + startTimeArray[2] + '日' | ||||
|  |         // this.endTimeShow = endTimeArray[0] + '年' + endTimeArray[1] + '月' + endTimeArray[2] + '日' | ||||
|  |       } else { | ||||
|  |         this.formData.startDate = '' | ||||
|  |         this.formData.endDate = '' | ||||
|  |         // this.startTimeShow = '' | ||||
|  |         // this.endTimeShow = '' | ||||
|  |       } | ||||
|  | 
 | ||||
|  |     }, | ||||
|  | 
 | ||||
|  | 
 | ||||
|  | 
 | ||||
|  | 
 | ||||
|  |     //重置搜索条件 | ||||
|  |     resetSearch () { | ||||
|  |       this.timeRange = [] | ||||
|  |       this.formData = { | ||||
|  |         gridId: '',//所属网格【网格Id】 | ||||
|  |         neighborHoodId: '',//小区ID	 | ||||
|  |         buildingId: '',//楼栋ID	 | ||||
|  |         buildingUnitId: '',//楼栋单元ID	 | ||||
|  |         houseId: '',//房屋ID	 | ||||
|  |         startDate: '',//开始日期,eg:20220510	 | ||||
|  |         endDate: '',//结束日期,eg:20220510	 | ||||
|  |       } | ||||
|  | 
 | ||||
|  |       this.pageNo = 1 | ||||
|  |       // this.loadTable() | ||||
|  |     }, | ||||
|  | 
 | ||||
|  | 
 | ||||
|  |     handleSizeChange (val) { | ||||
|  |       this.pageSize = val | ||||
|  |       this.pageNo = 1 | ||||
|  |       this.loadTable() | ||||
|  |     }, | ||||
|  |     handleCurrentChange (val) { | ||||
|  |       this.pageNo = val | ||||
|  |       this.loadTable() | ||||
|  |     }, | ||||
|  | 
 | ||||
|  | 
 | ||||
|  |     // 开启加载动画 | ||||
|  |     startLoading () { | ||||
|  |       loading = Loading.service({ | ||||
|  |         lock: true, // 是否锁定 | ||||
|  |         text: '正在加载……', // 加载中需要显示的文字 | ||||
|  |         background: 'rgba(0,0,0,.7)' // 背景颜色 | ||||
|  |       }) | ||||
|  |     }, | ||||
|  |     // 结束加载动画 | ||||
|  |     endLoading () { | ||||
|  |       // clearTimeout(timer); | ||||
|  |       if (loading) { | ||||
|  |         loading.close() | ||||
|  |       } | ||||
|  |     } | ||||
|  |   }, | ||||
|  |   computed: { | ||||
|  |     tableHeight () { | ||||
|  |       return this.$store.state.inIframe ? this.clientHeight - 415 + this.iframeHeight : this.clientHeight - 415 | ||||
|  | 
 | ||||
|  |     }, | ||||
|  | 
 | ||||
|  |     ...mapGetters(['clientHeight', 'iframeHeight']) | ||||
|  |   }, | ||||
|  |   watch: { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  |   props: { | ||||
|  | 
 | ||||
|  |   } | ||||
|  | } | ||||
|  | </script> | ||||
|  | 
 | ||||
|  | <style lang="scss" scoped > | ||||
|  | @import "@/assets/scss/modules/management/epidemic.scss"; | ||||
|  | </style> | ||||
|  | 
 | ||||
|  | 
 | ||||
|  | 
 | ||||
					Loading…
					
					
				
		Reference in new issue