|  |  |  | <template> | 
					
						
							|  |  |  |   <div> | 
					
						
							|  |  |  |     <div class="div_search"> | 
					
						
							|  |  |  |       <div class="resi-cell"> | 
					
						
							|  |  |  |         <div class="resi-cell-label">房主姓名</div> | 
					
						
							|  |  |  |         <div class="resi-cell-value"> | 
					
						
							|  |  |  |           <el-input v-model="ownerName" | 
					
						
							|  |  |  |                     class="resi-cell-input" | 
					
						
							|  |  |  |                     size="small" | 
					
						
							|  |  |  |                     clearable | 
					
						
							|  |  |  |                     placeholder="请输入内容"> | 
					
						
							|  |  |  |           </el-input> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |       <div class="resi-cell"> | 
					
						
							|  |  |  |         <div class="resi-cell-label">房主手机</div> | 
					
						
							|  |  |  |         <div class="resi-cell-value"> | 
					
						
							|  |  |  |           <el-input v-model="ownerPhone" | 
					
						
							|  |  |  |                     class="resi-cell-input" | 
					
						
							|  |  |  |                     size="small" | 
					
						
							|  |  |  |                     clearable | 
					
						
							|  |  |  |                     placeholder="请输入内容"> | 
					
						
							|  |  |  |           </el-input> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |       <el-button style="margin-left:10px" | 
					
						
							|  |  |  |                  type="primary" | 
					
						
							|  |  |  |                  size="small" | 
					
						
							|  |  |  |                  @click="handleSearch">查询</el-button> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |     <div class="div_btn"> | 
					
						
							|  |  |  |       <el-button style="float:left" | 
					
						
							|  |  |  |                  type="yellow" | 
					
						
							|  |  |  |                  size="small" | 
					
						
							|  |  |  |                  icon="el-icon-download" | 
					
						
							|  |  |  |                  @click="handleExport">导出</el-button> | 
					
						
							|  |  |  |       <el-button style="float:left" | 
					
						
							|  |  |  |                  type="green" | 
					
						
							|  |  |  |                  size="small" | 
					
						
							|  |  |  |                  icon="el-icon-plus" | 
					
						
							|  |  |  |                  @click="handleAdd">新增楼宇</el-button> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       <el-button style=";margin-left:10px" | 
					
						
							|  |  |  |                  type="blue" | 
					
						
							|  |  |  |                  size="small" | 
					
						
							|  |  |  |                  icon="el-icon-download" | 
					
						
							|  |  |  |                  @click="handleExportModule('building')">下载楼宇模板</el-button> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       <el-upload style="" | 
					
						
							|  |  |  |                  ref="upload_building" | 
					
						
							|  |  |  |                  :multiple='false' | 
					
						
							|  |  |  |                  :show-file-list='false' | 
					
						
							|  |  |  |                  :before-upload="((file)=>{beforeUpload(file, 'building')})" | 
					
						
							|  |  |  |                  action="" | 
					
						
							|  |  |  |                  accept=".xls,.xlsx" | 
					
						
							|  |  |  |                  :http-request="(()=>{uploadFile( 'building')})"> | 
					
						
							|  |  |  |         <el-button style="margin-left:10px" | 
					
						
							|  |  |  |                    size="small" | 
					
						
							|  |  |  |                    icon="el-icon-upload2" | 
					
						
							|  |  |  |                    :loading="importBuildingLoading" | 
					
						
							|  |  |  |                    type="red">导入楼宇数据</el-button> | 
					
						
							|  |  |  |       </el-upload> | 
					
						
							|  |  |  |       <el-button style=";margin-left:10px" | 
					
						
							|  |  |  |                  type="blue" | 
					
						
							|  |  |  |                  size="small" | 
					
						
							|  |  |  |                  icon="el-icon-download" | 
					
						
							|  |  |  |                  @click="handleExportModule('room')">下载房屋模板</el-button> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       <el-upload style="" | 
					
						
							|  |  |  |                  ref="upload_room" | 
					
						
							|  |  |  |                  :multiple='false' | 
					
						
							|  |  |  |                  :show-file-list='false' | 
					
						
							|  |  |  |                  :before-upload="((file)=>{beforeUpload(file, 'room')})" | 
					
						
							|  |  |  |                  action="" | 
					
						
							|  |  |  |                  accept=".xls,.xlsx" | 
					
						
							|  |  |  |                  :http-request="(()=>{uploadFile( 'room')})"> | 
					
						
							|  |  |  |         <el-button style="margin-left:10px" | 
					
						
							|  |  |  |                    size="small" | 
					
						
							|  |  |  |                    icon="el-icon-upload2" | 
					
						
							|  |  |  |                    :loading="importRoomLoading" | 
					
						
							|  |  |  |                    type="red">导入房屋数据</el-button> | 
					
						
							|  |  |  |       </el-upload> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <div class="div_table"> | 
					
						
							|  |  |  |       <el-table :data="tableData" | 
					
						
							|  |  |  |                 :header-cell-style="{background:'#2195FE',color:'#FFFFFF'}" | 
					
						
							|  |  |  |                 border | 
					
						
							|  |  |  |                 :height="tableHeight" | 
					
						
							|  |  |  |                 v-loading="tableLoading" | 
					
						
							|  |  |  |                 style="width: 100%"> | 
					
						
							|  |  |  |         <el-table-column prop="buildingName" | 
					
						
							|  |  |  |                          label="楼栋名称" | 
					
						
							|  |  |  |                          min-width="180"> | 
					
						
							|  |  |  |         </el-table-column> | 
					
						
							|  |  |  |         <el-table-column prop="neighborHoodName" | 
					
						
							|  |  |  |                          label="所属小区" | 
					
						
							|  |  |  |                          min-width="160"> | 
					
						
							|  |  |  |         </el-table-column> | 
					
						
							|  |  |  |         <el-table-column prop="buildingType" | 
					
						
							|  |  |  |                          label="楼栋类型" | 
					
						
							|  |  |  |                          min-width="140"> | 
					
						
							|  |  |  |         </el-table-column> | 
					
						
							|  |  |  |         <el-table-column prop="totalUnitNum" | 
					
						
							|  |  |  |                          label="单元数"> | 
					
						
							|  |  |  |         </el-table-column> | 
					
						
							|  |  |  |         <el-table-column prop="totalFloorNum" | 
					
						
							|  |  |  |                          label="层数"> | 
					
						
							|  |  |  |         </el-table-column> | 
					
						
							|  |  |  |         <el-table-column prop="totalHouseNum" | 
					
						
							|  |  |  |                          label="总户数"> | 
					
						
							|  |  |  |         </el-table-column> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         <el-table-column label="操作" | 
					
						
							|  |  |  |                          fixed="right" | 
					
						
							|  |  |  |                          width="140" | 
					
						
							|  |  |  |                          header-align="center" | 
					
						
							|  |  |  |                          align="center" | 
					
						
							|  |  |  |                          class="operate"> | 
					
						
							|  |  |  |           <template slot-scope="scope"> | 
					
						
							|  |  |  |             <!-- <el-button type="text" | 
					
						
							|  |  |  |                        style="color:#feb349;text-decoration: underline;" | 
					
						
							|  |  |  |                        size="small" | 
					
						
							|  |  |  |                        @click="handleToNextLevel(scope.row)">进入</el-button> --> | 
					
						
							|  |  |  |             <el-button type="text" | 
					
						
							|  |  |  |                        style="color:#1C6AFD;text-decoration: underline;" | 
					
						
							|  |  |  |                        size="small" | 
					
						
							|  |  |  |                        @click="handleDetail(scope.row)">查看</el-button> | 
					
						
							|  |  |  |             <el-button type="text" | 
					
						
							|  |  |  |                        style="color:#00A7A9;text-decoration: underline;" | 
					
						
							|  |  |  |                        size="small" | 
					
						
							|  |  |  |                        @click="handleEdit(scope.row)">修改</el-button> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             <el-button type="text" | 
					
						
							|  |  |  |                        style="color:#D51010;text-decoration: underline;" | 
					
						
							|  |  |  |                        size="small" | 
					
						
							|  |  |  |                        @click="handleDelete(scope.row)">删除</el-button> | 
					
						
							|  |  |  |           </template> | 
					
						
							|  |  |  |         </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> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <!-- 修改弹出框 --> | 
					
						
							|  |  |  |     <el-dialog :visible.sync="formShow" | 
					
						
							|  |  |  |                :close-on-click-modal="false" | 
					
						
							|  |  |  |                :close-on-press-escape="false" | 
					
						
							|  |  |  |                :title="formTitle" | 
					
						
							|  |  |  |                top="5vh" | 
					
						
							|  |  |  |                width="900px" | 
					
						
							|  |  |  |                @closed="diaClose"> | 
					
						
							|  |  |  |       <build-form ref="ref_form" | 
					
						
							|  |  |  |                   @dialogCancle="addFormCancle" | 
					
						
							|  |  |  |                   @dialogOk="addFormOk"></build-form> | 
					
						
							|  |  |  |     </el-dialog> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import BuildForm from './buildForm' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { requestPost } from "@/js/dai/request"; | 
					
						
							|  |  |  | import { mapGetters } from 'vuex' | 
					
						
							|  |  |  | import { Loading } from 'element-ui' // 引入Loading服务
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | let loading // 加载动画
 | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   data () { | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       importBuildingLoading: false, | 
					
						
							|  |  |  |       importRoomLoading: false, | 
					
						
							|  |  |  |       total: 0, | 
					
						
							|  |  |  |       pageSize: 20, | 
					
						
							|  |  |  |       pageNo: 0, | 
					
						
							|  |  |  |       tableLoading: true, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       agencyObj: {},//树所选的小区对象
 | 
					
						
							|  |  |  |       ownerName: '', | 
					
						
							|  |  |  |       ownerPhone: '', | 
					
						
							|  |  |  |       tableData: [], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       //form相关
 | 
					
						
							|  |  |  |       formShow: false, | 
					
						
							|  |  |  |       formTitle: '新增楼宇', | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   components: { | 
					
						
							|  |  |  |     BuildForm | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   async mounted () { | 
					
						
							|  |  |  |     console.log('building11111111111111111111111111') | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   computed: { | 
					
						
							|  |  |  |     tableHeight () { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       return (this.clientHeight - 300) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ...mapGetters(['clientHeight']) | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleSearch () { | 
					
						
							|  |  |  |       this.loadTable() | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async loadTable (fromTree, treeObj) { | 
					
						
							|  |  |  |       this.tableLoading = true | 
					
						
							|  |  |  |       if (fromTree) { | 
					
						
							|  |  |  |         this.agencyObj = treeObj | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       console.log(this.agencyObj) | 
					
						
							|  |  |  |       const url = "/gov/org/building/buildinglist" | 
					
						
							|  |  |  |       let params = { | 
					
						
							|  |  |  |         pageSize: this.pageSize, | 
					
						
							|  |  |  |         pageNo: this.pageNo, | 
					
						
							|  |  |  |         ownerName: this.ownerName, | 
					
						
							|  |  |  |         ownerPhone: this.ownerPhone, | 
					
						
							|  |  |  |         neighborHoodId: this.agencyObj.id | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       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 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     diaClose () { | 
					
						
							|  |  |  |       this.$refs.ref_form.resetData() | 
					
						
							|  |  |  |       this.formShow = false | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleDetail (row) { | 
					
						
							|  |  |  |       this.formTitle = '楼栋详情' | 
					
						
							|  |  |  |       this.formShow = true | 
					
						
							|  |  |  |       this.$nextTick(() => { | 
					
						
							|  |  |  |         this.$refs.ref_form.initForm('detail', row, this.agencyObj) | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleAdd () { | 
					
						
							|  |  |  |       this.formTitle = '新增楼栋' | 
					
						
							|  |  |  |       this.formShow = true | 
					
						
							|  |  |  |       this.$nextTick(() => { | 
					
						
							|  |  |  |         this.$refs.ref_form.initForm('add', null, this.agencyObj) | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleEdit (row) { | 
					
						
							|  |  |  |       this.formTitle = '修改楼栋' | 
					
						
							|  |  |  |       this.formShow = true | 
					
						
							|  |  |  |       this.$nextTick(() => { | 
					
						
							|  |  |  |         this.$refs.ref_form.initForm('edit', row, this.agencyObj) | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleToNextLevel (row) { | 
					
						
							|  |  |  |       this.$emit('toNextLevel', row, 'building') | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     addFormCancle () { | 
					
						
							|  |  |  |       this.formShow = false | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     addFormOk () { | 
					
						
							|  |  |  |       this.formShow = false | 
					
						
							|  |  |  |       this.loadTable() | 
					
						
							|  |  |  |       this.$emit('refreshTree') | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async handleDelete (row) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.$confirm("确认删除?", "提示", { | 
					
						
							|  |  |  |         confirmButtonText: "确定", | 
					
						
							|  |  |  |         cancelButtonText: "取消", | 
					
						
							|  |  |  |         type: "warning" | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |         .then(() => { | 
					
						
							|  |  |  |           this.deleteBuild(row) | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         .catch(err => { | 
					
						
							|  |  |  |           if (err == "cancel") { | 
					
						
							|  |  |  |             // this.$message({
 | 
					
						
							|  |  |  |             //   type: "info",
 | 
					
						
							|  |  |  |             //   message: "已取消删除"
 | 
					
						
							|  |  |  |             // });
 | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async deleteBuild (row) { | 
					
						
							|  |  |  |       const url = "/gov/org/building/buildingdel" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let params = { | 
					
						
							|  |  |  |         buildingId: row.buildingId | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const { data, code, msg } = await requestPost(url, params) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (code === 0) { | 
					
						
							|  |  |  |         this.$message({ | 
					
						
							|  |  |  |           type: "success", | 
					
						
							|  |  |  |           message: "删除成功" | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         this.$emit('refreshTree') | 
					
						
							|  |  |  |         this.loadTable() | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.$message.error(msg) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //导出表格
 | 
					
						
							|  |  |  |     async handleExport () { | 
					
						
							|  |  |  |       let title = this.agencyObj.label | 
					
						
							|  |  |  |       title = title + '—楼栋列表' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const url = "/gov/org/building/exportbuildinginfo" | 
					
						
							|  |  |  |       let params = { | 
					
						
							|  |  |  |         ownerName: this.ownerName, | 
					
						
							|  |  |  |         ownerPhone: this.ownerPhone, | 
					
						
							|  |  |  |         neighborHoodId: this.agencyObj.id | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       app.ajax.exportFilePost( | 
					
						
							|  |  |  |         url, | 
					
						
							|  |  |  |         params, | 
					
						
							|  |  |  |         (data, rspMsg) => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           this.download(data, title + '.xls') | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         (rspMsg, data) => { | 
					
						
							|  |  |  |           this.$message.error(rspMsg); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // 下载文件
 | 
					
						
							|  |  |  |     download (data, fileName) { | 
					
						
							|  |  |  |       if (!data) { | 
					
						
							|  |  |  |         return | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       var csvData = new Blob([data]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (window.navigator && window.navigator.msSaveOrOpenBlob) { | 
					
						
							|  |  |  |         window.navigator.msSaveOrOpenBlob(csvData, fileName); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       // for Non-IE (chrome, firefox etc.)
 | 
					
						
							|  |  |  |       else { | 
					
						
							|  |  |  |         var a = document.createElement('a'); | 
					
						
							|  |  |  |         document.body.appendChild(a); | 
					
						
							|  |  |  |         a.style = 'display: none'; | 
					
						
							|  |  |  |         var url = window.URL.createObjectURL(csvData); | 
					
						
							|  |  |  |         a.href = url; | 
					
						
							|  |  |  |         a.download = fileName; | 
					
						
							|  |  |  |         a.click(); | 
					
						
							|  |  |  |         a.remove(); | 
					
						
							|  |  |  |         window.URL.revokeObjectURL(url); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleExportModule (type) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let title = '' | 
					
						
							|  |  |  |       let url = "" | 
					
						
							|  |  |  |       if (type === 'building') { | 
					
						
							|  |  |  |         title = '楼宇导入模板' | 
					
						
							|  |  |  |         url = '/gov/org/building/exporttemplate' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       } else if (type === 'room') { | 
					
						
							|  |  |  |         title = '房屋导入模板' | 
					
						
							|  |  |  |         url = '/gov/org/house/exporttemplate' | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let params = {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       app.ajax.exportFilePost( | 
					
						
							|  |  |  |         url, | 
					
						
							|  |  |  |         params, | 
					
						
							|  |  |  |         (data, rspMsg) => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           this.download(data, title + '.xls') | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         (rspMsg, data) => { | 
					
						
							|  |  |  |           this.$message.error(rspMsg); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // 上传文件之前的钩子
 | 
					
						
							|  |  |  |     beforeUpload (file, type) { | 
					
						
							|  |  |  |       this.files = file; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const isText = file.type === 'application/vnd.ms-excel' | 
					
						
							|  |  |  |       const isTextComputer = file.type === 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (!isText && !isTextComputer) { | 
					
						
							|  |  |  |         this.$message.error('请选择正确格式的文件') | 
					
						
							|  |  |  |         this.files = null | 
					
						
							|  |  |  |         this.fileName = '' | 
					
						
							|  |  |  |         return false | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.fileName = file.name; | 
					
						
							|  |  |  |         return true | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 上传文件个数超过定义的数量
 | 
					
						
							|  |  |  |     handleExceed (files, fileList) { | 
					
						
							|  |  |  |       this.$message.warning(`当前限制选择 1 个文件,请删除后继续上传`) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async uploadFile (type) { | 
					
						
							|  |  |  |       if (this.fileName == "") { | 
					
						
							|  |  |  |         this.$message.warning('请选择要上传的文件!') | 
					
						
							|  |  |  |         return false | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       this.$message({ | 
					
						
							|  |  |  |         showClose: true, | 
					
						
							|  |  |  |         message: '导入中,请到系统管理-导入记录中查看进度', | 
					
						
							|  |  |  |         duration: 0 | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       //清空上传列表
 | 
					
						
							|  |  |  |       let url = '' | 
					
						
							|  |  |  |       let params = {} | 
					
						
							|  |  |  |       let fileFormData = new FormData(); | 
					
						
							|  |  |  |       fileFormData.append('file', this.files);//filename是键,file是值,就是要传的文件,test.zip是要传的文件名
 | 
					
						
							|  |  |  |       fileFormData.append('orgId', this.agencyObj.id);//filename是键,file是值,就是要传的文件,test.zip是要传的文件名
 | 
					
						
							|  |  |  |       fileFormData.append('orgType', this.agencyObj.level);//filename是键,file是值,就是要传的文件,test.zip是要传的文件名
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // params.file = fileFormData
 | 
					
						
							|  |  |  |       // params.orgId = this.agencyObj.id
 | 
					
						
							|  |  |  |       // params.orgType = this.agencyObj.level
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (type === 'building') { | 
					
						
							|  |  |  |         this.$refs['upload_building'].clearFiles() | 
					
						
							|  |  |  |         // url = 'http://192.168.51.26:8080/api/gov/org/building/buildingimport'
 | 
					
						
							|  |  |  |         url = '/gov/org/building/buildingimport' | 
					
						
							|  |  |  |         this.importBuildingLoading = true | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       } else if (type === 'room') { | 
					
						
							|  |  |  |         this.$refs['upload_room'].clearFiles() | 
					
						
							|  |  |  |         // url = 'http://192.168.51.26:8080/api/gov/org/house/houseimport'
 | 
					
						
							|  |  |  |         url = '/gov/org/house/houseimport' | 
					
						
							|  |  |  |         this.importRoomLoading = true | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       window.app.ajax.post2(url, fileFormData, | 
					
						
							|  |  |  |         (data, rspMsg) => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (data.code === 0 || data.code > 8000) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           this.$emit('refreshTree') | 
					
						
							|  |  |  |           this.loadTable() | 
					
						
							|  |  |  |           if (type === 'building') { | 
					
						
							|  |  |  |             this.importBuildingLoading = false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           } else if (type === 'room') { | 
					
						
							|  |  |  |             this.importRoomLoading = false | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         (rspMsg, data) => { | 
					
						
							|  |  |  |           if (type === 'building') { | 
					
						
							|  |  |  |             this.importBuildingLoading = false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           } else if (type === 'room') { | 
					
						
							|  |  |  |             this.importRoomLoading = false | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         }, { headers: { 'Content-Type': 'multipart/form-data' } }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     showMessage (msg) { | 
					
						
							|  |  |  |       this.$alert(msg, '操作结果', { | 
					
						
							|  |  |  |         confirmButtonText: '关闭', | 
					
						
							|  |  |  |         callback: action => { | 
					
						
							|  |  |  |           this.$emit('refreshTree') | 
					
						
							|  |  |  |           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() | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   watch: { | 
					
						
							|  |  |  |     filterText (val) { | 
					
						
							|  |  |  |       this.$refs.tree.filter(val); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   props: { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | <style lang="scss" scoped > | 
					
						
							|  |  |  | @import "@/assets/scss/buttonstyle.scss"; | 
					
						
							|  |  |  | .div_search { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .resi-cell { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     .resi-cell-label { | 
					
						
							|  |  |  |       width: 70px; | 
					
						
							|  |  |  |       box-sizing: border-box; | 
					
						
							|  |  |  |       margin-right: 15px; | 
					
						
							|  |  |  |       text-align: right; | 
					
						
							|  |  |  |       // line-height: 32;
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .resi-cell-input { | 
					
						
							|  |  |  |       width: 180px; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .div_table { | 
					
						
							|  |  |  |   margin-top: 20px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .div_search { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .resi-cell { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     .resi-cell-label { | 
					
						
							|  |  |  |       width: 70px; | 
					
						
							|  |  |  |       box-sizing: border-box; | 
					
						
							|  |  |  |       margin-right: 15px; | 
					
						
							|  |  |  |       text-align: right; | 
					
						
							|  |  |  |       // line-height: 32;
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .resi-cell-input { | 
					
						
							|  |  |  |       width: 180px; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .div_btn { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   margin-top: 20px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .el-row { | 
					
						
							|  |  |  |   /* margin-bottom: 20px; */ | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   flex-wrap: wrap; | 
					
						
							|  |  |  |   margin-top: 10px; | 
					
						
							|  |  |  |   margin-right: 50px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </style> |