|  |  |  | 
|---|
|  |  |  | <TableLayout :permissions="['business:ywworkorder:query']"> | 
|---|
|  |  |  | <!-- 搜索表单 --> | 
|---|
|  |  |  | <el-form ref="searchForm" slot="search-form" :model="searchForm" label-width="100px" inline> | 
|---|
|  |  |  | <el-form-item prop="areaType"> | 
|---|
|  |  |  | <el-form-item prop="areaType" label="位置类型"> | 
|---|
|  |  |  | <el-select v-model="searchForm.areaType"> | 
|---|
|  |  |  | <el-option label="室内维修" value="0"></el-option> | 
|---|
|  |  |  | <el-option label="公共维修" value="1"></el-option> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="请选择报修区域" prop="buildingId"> | 
|---|
|  |  |  | <el-input v-model="searchForm.buildingId" placeholder="请输入所属项目编码(关联yw_building)" | 
|---|
|  |  |  | @keypress.enter.native="search"></el-input> | 
|---|
|  |  |  | <el-form-item label="选择项目" prop="projectId"> | 
|---|
|  |  |  | <el-select v-model="searchForm.projectId" @change="getBuild" clearable filterable> | 
|---|
|  |  |  | <el-option v-for="item in projectList" :label="item.name" :value="item.id" /> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item prop="cateId"> | 
|---|
|  |  |  | <el-input v-model="searchForm.cateId" placeholder="报修物品类别" @keypress.enter.native="search"></el-input> | 
|---|
|  |  |  | <el-form-item label="选择楼宇" prop="buildingId"> | 
|---|
|  |  |  | <el-select v-model="searchForm.buildingId" clearable filterable> | 
|---|
|  |  |  | <el-option v-for="item in buildList" :label="item.name" :value="item.id" /> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item prop="cateId" label="工单分类"> | 
|---|
|  |  |  | <el-cascader v-model="searchForm.areaIds" @change="changeSel" placeholder="请选择工单分类" clearable | 
|---|
|  |  |  | :options="cateList" :props="{ | 
|---|
|  |  |  | label: 'name', | 
|---|
|  |  |  | value: 'id', | 
|---|
|  |  |  | children: 'childCategoryList' | 
|---|
|  |  |  | }"></el-cascader> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="来源" prop="origin"> | 
|---|
|  |  |  | <el-select v-model="searchForm.origin" clearable filterable> | 
|---|
|  |  |  | <el-option label="自建" :value="0" /> | 
|---|
|  |  |  | <el-option label="问题转工单" :value="1" /> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="上报时间"> | 
|---|
|  |  |  | <el-date-picker v-model="searchForm.selDate" @change="changeSelDate" format="yyyy-MM-dd" | 
|---|
|  |  |  | value-format="yyyy-MM-dd" type="daterange"></el-date-picker> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <section> | 
|---|
|  |  |  | <el-button type="primary" @click="search">搜索</el-button> | 
|---|
|  |  |  | <el-button type="primary" :loading="isWorking.export" v-permissions="['business:ywworkorder:exportExcel']" | 
|---|
|  |  |  | @click="exportExcel">导出</el-button> | 
|---|
|  |  |  | <el-button @click="reset">重置</el-button> | 
|---|
|  |  |  | </section> | 
|---|
|  |  |  | </el-form> | 
|---|
|  |  |  | 
|---|
|  |  |  | <ul class="toolbar" v-permissions="['business:ywworkorder:create', 'business:ywworkorder:delete']"> | 
|---|
|  |  |  | <li><el-button type="primary" @click="$refs.operaYwWorkorderWindow.open('新建工单')" icon="el-icon-plus" | 
|---|
|  |  |  | v-permissions="['business:ywworkorder:create']">新建</el-button></li> | 
|---|
|  |  |  | <li><el-button @click="deleteByIdInBatch" icon="el-icon-delete" | 
|---|
|  |  |  | v-permissions="['business:ywworkorder:delete']">删除</el-button></li> | 
|---|
|  |  |  | <el-button type="primary" :loading="isWorking.export" v-permissions="['business:ywworkorder:exportExcel']" | 
|---|
|  |  |  | @click="exportExcel" plain>导出</el-button> | 
|---|
|  |  |  | </ul> | 
|---|
|  |  |  | <el-table v-loading="isWorking.search" :data="tableData.list" stripe> | 
|---|
|  |  |  | <el-table-column prop="areaType" label="位置类型" min-width="80px"> | 
|---|
|  |  |  | <el-table-column prop="areaType" label="位置类型" min-width="70px"> | 
|---|
|  |  |  | <template v-slot="scope"> | 
|---|
|  |  |  | <span v-if="scope.row.areaType == 0">室内装修</span> | 
|---|
|  |  |  | <span v-if="scope.row.areaType == 1">公共区域</span> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column prop="" label="报修区域" min-width="100px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="cateName" label="报修物品类型" min-width="100px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="userName" label="上报人" min-width="100px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="submitDate" label="上报时间" min-width="100px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="dealUserName" label="处理人" min-width="100px"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="处理结果" min-width="100px"> | 
|---|
|  |  |  | <el-table-column prop="" label="报修区域" min-width="100px"> | 
|---|
|  |  |  | <template v-slot="scope"> | 
|---|
|  |  |  | <span>{{ scope.row.buildingName }} / {{ scope.row.areaType == 0 ? scope.row.roomNum : scope.row.floorName | 
|---|
|  |  |  | }}</span> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column prop="categoryName" label="工单分类" min-width="100px"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="来源" min-width="100px"> | 
|---|
|  |  |  | <template slot-scope="{row}"> | 
|---|
|  |  |  | <span v-if="row.origin == 0">自建</span> | 
|---|
|  |  |  | <span v-if="row.origin == 1">问题转工单</span> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column prop="creatorName" label="上报人" min-width="80px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="createDate" label="上报时间" min-width="100px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="dealUserName" label="处理人" min-width="80px"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="工单状态" min-width="70px"> | 
|---|
|  |  |  | <template slot-scope="{row}"> | 
|---|
|  |  |  | <span v-if="row.dealStatus == 0">待指派</span> | 
|---|
|  |  |  | <span v-if="row.dealStatus == 1">已指派</span> | 
|---|
|  |  |  | <span v-if="row.dealStatus == 2">已处理</span> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column v-if="containPermissions(['business:ywworkorder:update'])" | 
|---|
|  |  |  | label="操作" min-width="80" fixed="right"> | 
|---|
|  |  |  | <el-table-column v-if="containPermissions(['business:ywworkorder:update'])" label="操作" width="80" | 
|---|
|  |  |  | fixed="right"> | 
|---|
|  |  |  | <template slot-scope="{row}"> | 
|---|
|  |  |  | <span class="primaryColor cu">查看详情</span> | 
|---|
|  |  |  | <span @click="handleDetail(row)" class="primaryColor cu">查看详情</span> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | </el-table> | 
|---|
|  |  |  | <pagination @size-change="handleSizeChange" @current-change="handlePageChange" :pagination="tableData.pagination"> | 
|---|
|  |  |  | </pagination> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | <Detail v-if="openDetail" ref="DetailRef" @close="openDetail = false" @success="search" /> | 
|---|
|  |  |  | <!-- 新建/修改 --> | 
|---|
|  |  |  | <OperaYwWorkorderWindow ref="operaYwWorkorderWindow" @success="handlePageChange" /> | 
|---|
|  |  |  | </TableLayout> | 
|---|
|  |  |  | 
|---|
|  |  |  | import TableLayout from '@/layouts/TableLayout' | 
|---|
|  |  |  | import Pagination from '@/components/common/Pagination' | 
|---|
|  |  |  | import OperaYwWorkorderWindow from './components/OperaYwWorkorderWindow' | 
|---|
|  |  |  | import Detail from './components/detail' | 
|---|
|  |  |  | import { getBuildList } from '@/api/project/ywBuilding' | 
|---|
|  |  |  | import { getProjectList } from '@/api/project/ywProject' | 
|---|
|  |  |  | import { fetchList as getCateList } from '@/api/business/category.js' | 
|---|
|  |  |  | export default { | 
|---|
|  |  |  | name: 'YwWorkorder', | 
|---|
|  |  |  | extends: BaseTable, | 
|---|
|  |  |  | components: { TableLayout, Pagination, OperaYwWorkorderWindow }, | 
|---|
|  |  |  | components: { TableLayout, Pagination, Detail, OperaYwWorkorderWindow }, | 
|---|
|  |  |  | data() { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | // 搜索 | 
|---|
|  |  |  | openDetail: false, | 
|---|
|  |  |  | searchForm: { | 
|---|
|  |  |  | areaType: '', | 
|---|
|  |  |  | creator: '', | 
|---|
|  |  |  | createDate: '', | 
|---|
|  |  |  | editor: '', | 
|---|
|  |  |  | editDate: '', | 
|---|
|  |  |  | isdeleted: '', | 
|---|
|  |  |  | title: '', | 
|---|
|  |  |  | remark: '', | 
|---|
|  |  |  | status: '', | 
|---|
|  |  |  | sortnum: '', | 
|---|
|  |  |  | content: '', | 
|---|
|  |  |  | getDate: '', | 
|---|
|  |  |  | selDate: [], | 
|---|
|  |  |  | areaIds: '', | 
|---|
|  |  |  | projectId: '', | 
|---|
|  |  |  | buildingId: '', | 
|---|
|  |  |  | roomId: '', | 
|---|
|  |  |  | userId: '', | 
|---|
|  |  |  | phone: '', | 
|---|
|  |  |  | submitDate: '', | 
|---|
|  |  |  | cateId: '', | 
|---|
|  |  |  | code: '', | 
|---|
|  |  |  | dealStatus: '', | 
|---|
|  |  |  | dispatchUserId: '', | 
|---|
|  |  |  | dispatchDate: '', | 
|---|
|  |  |  | dispatchInfo: '', | 
|---|
|  |  |  | dealUserId: '', | 
|---|
|  |  |  | dealDate: '', | 
|---|
|  |  |  | dealInfo: '', | 
|---|
|  |  |  | dealType: '' | 
|---|
|  |  |  | } | 
|---|
|  |  |  | origin: '' | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | projectList: [], | 
|---|
|  |  |  | buildList: [], | 
|---|
|  |  |  | cateList: [], | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | created() { | 
|---|
|  |  |  | 
|---|
|  |  |  | 'field.main': 'id' | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | this.search() | 
|---|
|  |  |  | this.initData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | methods: { | 
|---|
|  |  |  | handleDetail(row) { | 
|---|
|  |  |  | this.openDetail = true | 
|---|
|  |  |  | this.$nextTick(() => { | 
|---|
|  |  |  | this.$refs.DetailRef.open('工单详情', { workorderId: row.id }, true) | 
|---|
|  |  |  | // this.$refs.DetailRef.isShow = true | 
|---|
|  |  |  | // this.$refs.DetailRef.visible = true | 
|---|
|  |  |  | // this.$refs.DetailRef.id = row.id | 
|---|
|  |  |  | // this.$refs.DetailRef.getDetail() | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | initData() { | 
|---|
|  |  |  | getProjectList({}).then(res => { | 
|---|
|  |  |  | this.projectList = res | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | getCateList({ | 
|---|
|  |  |  | model: { type: 3 }, | 
|---|
|  |  |  | capacity: 1000, | 
|---|
|  |  |  | page: 1, | 
|---|
|  |  |  | }).then(res => { | 
|---|
|  |  |  | this.cateList = res.records || [] | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | getBuild(projectId) { | 
|---|
|  |  |  | this.$set(this.searchForm, 'buildingId', '') | 
|---|
|  |  |  | getBuildList({ projectId }).then(res => { | 
|---|
|  |  |  | this.buildList = res | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | changeSel(e) { | 
|---|
|  |  |  | if (e && e.length == 2) { | 
|---|
|  |  |  | this.$set(this.searchForm, 'cateId', e[1]) | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$set(this.searchForm, 'cateId', '') | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | reset() { | 
|---|
|  |  |  | this.searchForm = { | 
|---|
|  |  |  | selDate: [], | 
|---|
|  |  |  | areaType: '', | 
|---|
|  |  |  | areaIds: '', | 
|---|
|  |  |  | projectId: '', | 
|---|
|  |  |  | buildingId: '', | 
|---|
|  |  |  | cateId: '', | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.buildList = [] | 
|---|
|  |  |  | this.search() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | changeSelDate(e) { | 
|---|
|  |  |  | if (e && e.length > 0) { | 
|---|
|  |  |  | this.$set(this.searchForm, 'queryStartTime', e[0] + ' 00:00:00') | 
|---|
|  |  |  | this.$set(this.searchForm, 'queryEndTime', e[1] + ' 23:59:59') | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$set(this.searchForm, 'queryStartTime', '') | 
|---|
|  |  |  | this.$set(this.searchForm, 'queryEndTime', '') | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </script> | 
|---|