index.vue 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877
  1. <template>
  2. <div class="app-container">
  3. <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
  4. <el-form-item label="所属小区" prop="areaId">
  5. <el-select v-model="queryParams.areaId" filterable clearable placeholder="请选择所属小区"
  6. @change="getBuilding(queryParams.areaId),resetqueryform()"
  7. >
  8. <el-option v-for="item in areaList" :key="item.id" :value="item.id" :label="item.name">{{
  9. item.name
  10. }}
  11. </el-option>
  12. </el-select>
  13. </el-form-item>
  14. <el-form-item label="所属楼宇" prop="buildingId">
  15. <el-select v-model="queryParams.buildingId" filterable clearable placeholder="请选择楼宇"
  16. @change="getUnit(queryParams.buildingId),resetqueryunitform()"
  17. >
  18. <el-option v-for="item in buildingList" :key="item.id" :value="item.id" :label="item.name">{{
  19. item.name
  20. }}
  21. </el-option>
  22. </el-select>
  23. </el-form-item>
  24. <el-form-item label="所属单元" prop="unitId">
  25. <el-select v-model="queryParams.unitId" filterable clearable placeholder="请选择单元"
  26. @change="getHouse(queryParams.unitId),resetqueryhouseform()"
  27. >
  28. <el-option v-for="item in unitList" :key="item.id" :value="item.id" :label="item.name">{{
  29. item.name
  30. }}
  31. </el-option>
  32. </el-select>
  33. </el-form-item>
  34. <el-form-item label="房屋" prop="houseId">
  35. <el-select v-model="queryParams.houseId" filterable clearable placeholder="请选择房屋" @change="setHouseName(queryParams.houseId)" >
  36. <el-option v-for="item in houseList" :key="item.id" :value="item.id" :label="item.name">{{
  37. item.name
  38. }}
  39. </el-option>
  40. </el-select>
  41. </el-form-item>
  42. <el-form-item label="服务类别" prop="serviceType">
  43. <el-select v-model="queryParams.serviceType" placeholder="请选择服务类别" clearable size="small">
  44. <el-option
  45. v-for="dict in dict.type.service_type"
  46. :key="dict.value"
  47. :label="dict.label"
  48. :value="dict.value"
  49. />
  50. </el-select>
  51. </el-form-item>
  52. <el-form-item label="职工" prop="userId">
  53. <el-select v-model="queryParams.userId" filterable placeholder="请选择职工">
  54. <el-option v-for="item in workerList" :key="item.id" :value="item.id" :label="item.name">{{
  55. item.name
  56. }}
  57. </el-option>
  58. </el-select>
  59. </el-form-item>
  60. <el-form-item label="订单状态" prop="orderStatus">
  61. <el-select v-model="queryParams.orderStatus" placeholder="请选择订单状态" clearable size="small">
  62. <el-option
  63. v-for="dict in dict.type.order_status"
  64. :key="dict.value"
  65. :label="dict.label"
  66. :value="dict.value"
  67. />
  68. </el-select>
  69. </el-form-item>
  70. <el-form-item label="审核状态" prop="examineStatus">
  71. <el-select v-model="queryParams.examineStatus" placeholder="请选择审核状态" clearable size="small">
  72. <el-option
  73. v-for="dict in dict.type.examine_status"
  74. :key="dict.value"
  75. :label="dict.label"
  76. :value="dict.value"
  77. />
  78. </el-select>
  79. </el-form-item>
  80. <el-form-item label="开始时间" prop="starTime">
  81. <el-date-picker clearable size="small"
  82. v-model="queryParams.starTime"
  83. type="date"
  84. value-format="yyyy-MM-dd"
  85. placeholder="选择日期"
  86. >
  87. </el-date-picker>
  88. </el-form-item>
  89. <el-form-item label="结束时间" prop="endTime">
  90. <el-date-picker clearable size="small"
  91. v-model="queryParams.endTime"
  92. type="date"
  93. value-format="yyyy-MM-dd"
  94. placeholder="选择日期"
  95. >
  96. </el-date-picker>
  97. </el-form-item>
  98. <el-form-item label="工号" prop="jobNum">
  99. <el-input
  100. v-model="queryParams.jobNum"
  101. :maxlength="4"
  102. placeholder="请输入工号前四位"
  103. clearable
  104. size="small"
  105. @keyup.enter.native="handleQuery"
  106. />
  107. </el-form-item>
  108. <el-form-item>
  109. <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
  110. <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
  111. </el-form-item>
  112. </el-form>
  113. <el-row :gutter="10" class="mb8">
  114. <el-col :span="1.5">
  115. <el-button
  116. type="primary"
  117. plain
  118. icon="el-icon-plus"
  119. size="mini"
  120. @click="handleAdd"
  121. v-hasPermi="['gas:order:add']"
  122. >新增
  123. </el-button>
  124. </el-col>
  125. <el-col :span="1.5">
  126. <el-button
  127. type="danger"
  128. plain
  129. icon="el-icon-delete"
  130. size="mini"
  131. :disabled="multiple"
  132. @click="handleDelete"
  133. v-hasPermi="['gas:order:remove']"
  134. >删除
  135. </el-button>
  136. </el-col>
  137. <el-col :span="1.5">
  138. <el-button
  139. type="warning"
  140. plain
  141. icon="el-icon-download"
  142. size="mini"
  143. :loading="exportLoading"
  144. @click="handleExport"
  145. v-hasPermi="['gas:order:export']"
  146. >导出
  147. </el-button>
  148. </el-col>
  149. <!-- <el-col :span="1.5">-->
  150. <!-- <el-button-->
  151. <!-- type="warning"-->
  152. <!-- plain-->
  153. <!-- icon="el-icon-download"-->
  154. <!-- size="mini"-->
  155. <!-- :loading="exportLoading"-->
  156. <!-- @click="backup"-->
  157. <!-- v-hasPermi="['gas:order:export']"-->
  158. <!-- >备份</el-button>-->
  159. <!-- </el-col>-->
  160. <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
  161. </el-row>
  162. <el-table v-loading="loading" :data="orderList" @selection-change="handleSelectionChange">
  163. <el-table-column type="selection" width="55" align="center"/>
  164. <el-table-column label="服务类别" align="center" prop="serviceType">
  165. <template slot-scope="scope">
  166. <dict-tag :options="dict.type.service_type" :value="scope.row.serviceType"/>
  167. </template>
  168. </el-table-column>
  169. <el-table-column label="职工" align="center" prop="userName"/>
  170. <el-table-column label="房屋" align="center" prop="house"/>
  171. <el-table-column label="管子类型" align="center" prop="pipeType"/>
  172. <el-table-column label="管子长度" align="center" prop="pipeLength"/>
  173. <el-table-column label="自闭阀类型" align="center" prop="valveType"/>
  174. <el-table-column label="订单时间" align="center" prop="time"/>
  175. <el-table-column label="订单状态" align="center" prop="orderStatus">
  176. <template slot-scope="scope">
  177. <dict-tag :options="dict.type.order_status" :value="scope.row.orderStatus"/>
  178. </template>
  179. </el-table-column>
  180. <el-table-column label="审核状态" align="center" prop="examineStatus">
  181. <template slot-scope="scope">
  182. <dict-tag :options="dict.type.examine_status" :value="scope.row.examineStatus"/>
  183. </template>
  184. </el-table-column>
  185. <el-table-column label="照片" align="center" prop="photoList">
  186. <template slot-scope="scope">
  187. <el-image
  188. v-if="scope.row.photoList.length> 0"
  189. style="width: 100px; height: 100px"
  190. :src="scope.row.photoList[0]"
  191. :preview-src-list="scope.row.photoList"
  192. >
  193. </el-image>
  194. </template>
  195. </el-table-column>
  196. <el-table-column label="备注" align="center" prop="remark"/>
  197. <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
  198. <template slot-scope="scope">
  199. <el-button v-show="scope.row.orderStatus ==='001'"
  200. size="mini"
  201. type="text"
  202. icon="el-icon-edit"
  203. @click="handleUpdate(scope.row)"
  204. v-hasPermi="['gas:order:edit']"
  205. >修改
  206. </el-button>
  207. <el-button v-show="scope.row.orderStatus ==='002'"
  208. size="mini"
  209. type="text"
  210. icon="el-icon-edit"
  211. @click="handleUpdate1(scope.row)"
  212. v-hasPermi="['gas:order:edit']"
  213. >复审
  214. </el-button>
  215. </template>
  216. </el-table-column>
  217. </el-table>
  218. <pagination
  219. v-show="total>0"
  220. :total="total"
  221. :page.sync="queryParams.pageNum"
  222. :limit.sync="queryParams.pageSize"
  223. @pagination="getList"
  224. />
  225. <!-- 添加或修改工程管理对话框 -->
  226. <el-dialog :title="title" :visible.sync="open" width="1000px" append-to-body>
  227. <el-row :gutter="15">
  228. <el-form ref="form" :model="form" :rules="rules" label-width="100px">
  229. <el-col :span="22">
  230. <el-form-item label="服务类别" prop="serviceType">
  231. <el-select v-model="form.serviceType" placeholder="请选择服务类别" clearable :style="{width: '100%'}">
  232. <el-option
  233. v-for="dict in dict.type.service_type"
  234. :key="dict.value"
  235. :label="dict.label"
  236. :value="dict.value"
  237. ></el-option>
  238. </el-select>
  239. </el-form-item>
  240. </el-col>
  241. <el-col :span="23">
  242. <el-form-item label="照片" prop="photoList">
  243. <imageUpload v-model="form.photoList"/>
  244. </el-form-item>
  245. </el-col>
  246. <el-col :span="11">
  247. <el-form-item label="职工" prop="userId">
  248. <el-select v-model="form.userId" filterable placeholder="请选择职工" clearable :style="{width: '100%'}">
  249. <el-option v-for="item in workerList" :key="item.id" :value="item.id" :label="item.name">{{
  250. item.name
  251. }}
  252. </el-option>
  253. </el-select>
  254. </el-form-item>
  255. </el-col>
  256. <el-col :span="11">
  257. <el-form-item label="所属小区" prop="areaId">
  258. <el-select v-model="form.areaId" filterable placeholder="请选择小区" clearable :style="{width: '100%'}"
  259. @change="getBuilding(form.areaId),resetform()"
  260. >
  261. <el-option v-for="item in areaList" :key="item.id" :value="item.id" :label="item.name">{{
  262. item.name
  263. }}
  264. </el-option>
  265. </el-select>
  266. </el-form-item>
  267. </el-col>
  268. <el-col :span="11">
  269. <el-form-item label="所属楼宇" prop="buildingId">
  270. <el-select v-model="form.buildingId" filterable placeholder="请选择楼宇" clearable :style="{width: '100%'}"
  271. @change="getUnit(form.buildingId),resetunitform()"
  272. >
  273. <el-option v-for="item in buildingList" :key="item.id" :value="item.id" :label="item.name">{{
  274. item.name
  275. }}
  276. </el-option>
  277. </el-select>
  278. </el-form-item>
  279. </el-col>
  280. <el-col :span="11">
  281. <el-form-item label="所属单元" prop="unitId">
  282. <el-select v-model="form.unitId" filterable placeholder="请选择单元" clearable :style="{width: '100%'}"
  283. @change="getHouse(form.unitId),resethouseform()"
  284. >
  285. <el-option v-for="item in unitList" :key="item.id" :value="item.id" :label="item.name">{{
  286. item.name
  287. }}
  288. </el-option>
  289. </el-select>
  290. </el-form-item>
  291. </el-col>
  292. <el-col :span="11">
  293. <el-form-item label="房屋" prop="houseId">
  294. <el-select v-model="form.houseId" filterable placeholder="请选择房屋" clearable :style="{width: '100%'}">
  295. <el-option v-for="item in houseList" :key="item.id" :value="item.id" :label="item.name">{{ item.name }}
  296. </el-option>
  297. </el-select>
  298. </el-form-item>
  299. </el-col>
  300. <el-col :span="11">
  301. <el-form-item label="管子类型" prop="pipeType">
  302. <el-radio-group v-model="form.pipeType">
  303. <el-radio
  304. v-for="item in pipeTypeList"
  305. :key="item.pipeType"
  306. :label="item.pipeType"
  307. >{{ item.pipeType }}
  308. </el-radio>
  309. </el-radio-group>
  310. </el-form-item>
  311. </el-col>
  312. <el-col :span="11">
  313. <el-form-item label="管子长度" prop="pipeLength" >
  314. <el-radio-group v-model="form.pipeLength">
  315. <el-radio
  316. v-for="item in pipeLengthList"
  317. :key="item.pipeLength"
  318. :label="item.pipeLength"
  319. >{{ item.pipeLength }}
  320. </el-radio>
  321. </el-radio-group>
  322. </el-form-item>
  323. </el-col>
  324. <el-col :span="11">
  325. <el-form-item label="自闭阀类型" prop="valveType">
  326. <el-radio-group v-model="form.valveType">
  327. <el-radio
  328. v-for="item in valveTypeList"
  329. :key="item.valveType"
  330. :label="item.valveType"
  331. >{{ item.valveType }}
  332. </el-radio>
  333. </el-radio-group>
  334. </el-form-item>
  335. </el-col>
  336. <el-col :span="22">
  337. <el-form-item label="备注" prop="remark">
  338. <el-input v-model="form.remark" type="textarea" placeholder="请输入内容"/>
  339. </el-form-item>
  340. </el-col>
  341. </el-form>
  342. </el-row>
  343. <div slot="footer" class="dialog-footer">
  344. <el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
  345. <el-button @click="cancel">取 消</el-button>
  346. </div>
  347. </el-dialog>
  348. <!-- 复审对话框 -->
  349. <el-dialog :title="title" :visible.sync="open1" width="500px" append-to-body>
  350. <el-form ref="form" :model="form" :rules="rules" label-width="80px">
  351. <el-form-item label="服务类别" prop="serviceType">
  352. <el-select disabled v-model="form.serviceType" placeholder="请选择服务类别">
  353. <el-option
  354. v-for="dict in dict.type.service_type"
  355. :key="dict.value"
  356. :label="dict.label"
  357. :value="dict.value"
  358. ></el-option>
  359. </el-select>
  360. </el-form-item>
  361. <el-form-item label="照片">
  362. <imageUpload v-model="form.photoList" :disabled="true"/>
  363. </el-form-item>
  364. <el-form-item label="职工" prop="userId">
  365. <el-select disabled v-model="form.userId" filterable placeholder="请选择职工">
  366. <el-option v-for="item in workerList" :key="item.id" :value="item.id" :label="item.name">{{
  367. item.name
  368. }}
  369. </el-option>
  370. </el-select>
  371. </el-form-item>
  372. <el-form-item label="所属小区" prop="areaId">
  373. <el-select disabled v-model="form.areaId" filterable placeholder="请选择小区"
  374. @change="getBuilding(form.areaId),resetform()"
  375. >
  376. <el-option v-for="item in areaList" :key="item.id" :value="item.id" :label="item.name">{{
  377. item.name
  378. }}
  379. </el-option>
  380. </el-select>
  381. </el-form-item>
  382. <el-form-item label="所属楼宇" prop="buildingId">
  383. <el-select disabled v-model="form.buildingId" filterable placeholder="请选择楼宇"
  384. @change="getUnit(form.buildingId),resetunitform()"
  385. >
  386. <el-option v-for="item in buildingList" :key="item.id" :value="item.id" :label="item.name">{{
  387. item.name
  388. }}
  389. </el-option>
  390. </el-select>
  391. </el-form-item>
  392. <el-form-item label="所属单元" prop="unitId">
  393. <el-select disabled v-model="form.unitId" filterable placeholder="请选择单元"
  394. @change="getHouse(form.unitId),resethouseform()"
  395. >
  396. <el-option v-for="item in unitList" :key="item.id" :value="item.id" :label="item.name">{{
  397. item.name
  398. }}
  399. </el-option>
  400. </el-select>
  401. </el-form-item>
  402. <el-form-item label="房屋" prop="houseId">
  403. <el-select disabled v-model="form.houseId" filterable placeholder="请选择房屋">
  404. <el-option v-for="item in houseList" :key="item.id" :value="item.id" :label="item.name">{{
  405. item.name
  406. }}
  407. </el-option>
  408. </el-select>
  409. </el-form-item>
  410. <el-form-item label="管子类型" prop="pipeType">
  411. <el-radio-group disabled v-model="form.pipeType">
  412. <el-radio
  413. v-for="item in pipeTypeList"
  414. :key="item.pipeType"
  415. :label="item.pipeType"
  416. >{{ item.pipeType }}
  417. </el-radio>
  418. </el-radio-group>
  419. </el-form-item>
  420. <el-form-item label="管子长度" prop="pipeLength">
  421. <el-radio-group disabled v-model="form.pipeLength">
  422. <el-radio
  423. v-for="item in pipeLengthList"
  424. :key="item.pipeLength"
  425. :label="item.pipeLength"
  426. >{{ item.pipeLength }}
  427. </el-radio>
  428. </el-radio-group>
  429. </el-form-item>
  430. <el-form-item label="自闭阀类型" prop="valveType">
  431. <el-radio-group disabled v-model="form.valveType">
  432. <el-radio
  433. v-for="item in valveTypeList"
  434. :key="item.valveType"
  435. :label="item.valveType"
  436. >{{ item.valveType }}
  437. </el-radio>
  438. </el-radio-group>
  439. </el-form-item>
  440. <el-form-item label="备注" prop="remark">
  441. <el-input disabled v-model="form.remark" type="textarea" placeholder="请输入内容"/>
  442. </el-form-item>
  443. <el-form-item label="审核意见" prop="reason">
  444. <el-input v-model="form.reason" type="textarea" placeholder="请输入内容"/>
  445. </el-form-item>
  446. </el-form>
  447. <div slot="footer" class="dialog-footer">
  448. <el-button :loading="buttonLoading" type="primary" @click="submitY">合格</el-button>
  449. <el-button :loading="buttonLoading" type="primary" @click="submitN">不合格</el-button>
  450. <el-button @click="cancel">取 消</el-button>
  451. </div>
  452. </el-dialog>
  453. </div>
  454. </template>
  455. <script>
  456. import {
  457. listOrder,
  458. getOrderForStatus,
  459. getHouse,
  460. backup,
  461. getUnit,
  462. getArea,
  463. getBuilding,
  464. getOrder,
  465. getWorker,
  466. getPipeType,
  467. getValveType,
  468. getPipeLength,
  469. delOrder,
  470. addOrder,
  471. submitY,
  472. submitN,
  473. updateOrder
  474. } from '@/api/gas/order'
  475. export default {
  476. name: 'Order',
  477. inheritAttrs: false,
  478. dicts: ['service_type', 'order_status', 'examine_status'],
  479. data() {
  480. return {
  481. // 按钮loading
  482. buttonLoading: false,
  483. // 遮罩层
  484. loading: true,
  485. // 导出遮罩层
  486. exportLoading: false,
  487. //职工下拉
  488. workerList: [],
  489. pipeLengthList: [],
  490. pipeTypeList: [],
  491. valveTypeList: [],
  492. areaList: [],
  493. buildingList: [],
  494. unitList: [],
  495. houseList: [],
  496. // 选中数组
  497. ids: [],
  498. // 选中数组的乐观锁
  499. versions: [],
  500. // 非单个禁用
  501. single: true,
  502. // 非多个禁用
  503. multiple: true,
  504. // 显示搜索条件
  505. showSearch: true,
  506. // 总条数
  507. total: 0,
  508. // 工程管理表格数据
  509. orderList: [],
  510. // 弹出层标题
  511. title: '',
  512. // 是否显示弹出层
  513. open: false,
  514. open1: false,
  515. // 查询参数
  516. queryParams: {
  517. pageNum: 1,
  518. pageSize: 10,
  519. serviceType: undefined,
  520. starTime: undefined,
  521. endTime: undefined,
  522. areaId: undefined,
  523. buildingId: undefined,
  524. unitId: undefined,
  525. houseId: undefined,
  526. userId: undefined,
  527. orderStatus: undefined,
  528. examineStatus: undefined,
  529. jobNum: undefined
  530. },
  531. // 表单参数
  532. form: {},
  533. // 表单校验
  534. rules: {
  535. serviceType: [
  536. { required: true, message: '服务类别不能为空', trigger: 'change' }
  537. ],
  538. photoList: [
  539. { required: false, message: '请上传照片', trigger: 'change' }
  540. ],
  541. userId: [
  542. { required: true, message: '职工不能为空', trigger: 'blur' }
  543. ],
  544. houseId: [
  545. { required: true, message: '房屋不能为空', trigger: 'change' }
  546. ]
  547. }
  548. }
  549. },
  550. created() {
  551. this.getList()
  552. this.getWorker()
  553. this.getArea()
  554. this.getPipeLength()
  555. this.getPipeType()
  556. this.getValveType()
  557. },
  558. methods: {
  559. backup() {
  560. backup().then(response => {
  561. })
  562. },
  563. /** 查询工程管理列表 */
  564. getList() {
  565. this.loading = true
  566. listOrder(this.queryParams).then(response => {
  567. this.orderList = response.rows
  568. this.total = response.total
  569. this.loading = false
  570. })
  571. },
  572. /**职工下拉框*/
  573. getWorker() {
  574. getWorker().then(response => {
  575. this.workerList = response.data
  576. })
  577. },
  578. //管子长度
  579. getPipeLength() {
  580. getPipeLength().then(response => {
  581. this.pipeLengthList = response.data
  582. })
  583. },
  584. //管子类别
  585. getPipeType() {
  586. getPipeType().then(response => {
  587. this.pipeTypeList = response.data
  588. })
  589. },
  590. //自闭阀类别
  591. getValveType() {
  592. getValveType().then(response => {
  593. this.valveTypeList = response.data
  594. })
  595. },
  596. /**小区下拉框*/
  597. getArea() {
  598. getArea().then(response => {
  599. this.areaList = response.data
  600. })
  601. },
  602. /**楼宇下拉框*/
  603. getBuilding(areaId) {
  604. this.form.areaName = this.areaList.filter(item => item.id == areaId )[0].name
  605. getBuilding(areaId).then(response => {
  606. this.buildingList = response.data
  607. })
  608. },
  609. getUnit(buildingId) {
  610. this.form.buildingName = this.buildingList.filter(item => item.id == buildingId )[0].name
  611. getUnit(buildingId).then(response => {
  612. this.unitList = response.data
  613. })
  614. },
  615. getHouse(unitId) {
  616. this.form.unitName = this.unitList.filter(item => item.id == unitId )[0].name
  617. getHouse(unitId).then(response => {
  618. this.houseList = response.data
  619. })
  620. },
  621. setHouseName(houseId) {
  622. this.form.houseName = this.houseList.filter(item => item.id == houseId )[0].name
  623. },
  624. /**
  625. * 联级清空
  626. */
  627. resetform() {
  628. this.form.buildingId = undefined
  629. this.form.unitId = undefined
  630. this.form.houseId = undefined
  631. },
  632. resetunitform() {
  633. this.form.unitId = undefined
  634. this.form.houseId = undefined
  635. },
  636. resethouseform() {
  637. this.form.houseId = undefined
  638. },
  639. resetqueryform() {
  640. this.queryParams.buildingId = undefined
  641. this.queryParams.unitId = undefined
  642. this.queryParams.houseId = undefined
  643. },
  644. resetqueryunitform() {
  645. this.queryParams.unitId = undefined
  646. this.queryParams.houseId = undefined
  647. },
  648. resetqueryhouseform() {
  649. this.queryParams.houseId = undefined
  650. },
  651. // 取消按钮
  652. cancel() {
  653. this.open = false
  654. this.open1 = false
  655. this.reset()
  656. },
  657. // 表单重置
  658. reset() {
  659. this.form = {
  660. id: undefined,
  661. serviceType: undefined,
  662. photoList: [],
  663. userId: undefined,
  664. unitId: undefined,
  665. buildingId: undefined,
  666. areaId: undefined,
  667. houseId: undefined,
  668. pipeLength: undefined,
  669. pipeType: undefined,
  670. remark: undefined,
  671. delFlag: undefined,
  672. createBy: undefined,
  673. createTime: undefined,
  674. updateBy: undefined,
  675. updateTime: undefined,
  676. reason: undefined
  677. }
  678. this.resetForm('form')
  679. },
  680. /** 搜索按钮操作 */
  681. handleQuery() {
  682. this.queryParams.pageNum = 1
  683. this.getList()
  684. },
  685. /** 重置按钮操作 */
  686. resetQuery() {
  687. // this.resetForm("queryForm");
  688. this.$refs['queryForm'].resetFields()
  689. this.handleQuery()
  690. },
  691. // 多选框选中数据
  692. handleSelectionChange(selection) {
  693. this.ids = selection.map(item => item.id)
  694. this.single = selection.length !== 1
  695. this.multiple = !selection.length
  696. },
  697. /** 新增按钮操作 */
  698. handleAdd() {
  699. this.reset()
  700. this.open = true
  701. this.title = '添加工程管理'
  702. this.getWorker()
  703. this.getPipeLength()
  704. this.getPipeType()
  705. this.getValveType()
  706. this.getArea()
  707. },
  708. /** 修改按钮操作 */
  709. handleUpdate(row) {
  710. this.reset()
  711. this.getWorker()
  712. this.getPipeLength()
  713. this.getPipeType()
  714. this.getValveType()
  715. this.getArea()
  716. const id = row.id || this.ids
  717. getOrder(id).then(response => {
  718. this.loading = false
  719. this.form = response.data
  720. this.open = true
  721. this.title = '修改工程管理'
  722. this.getBuilding(this.form.areaId)
  723. this.getUnit(this.form.buildingId)
  724. this.getHouse(this.form.unitId)
  725. })
  726. },
  727. /** 复审按钮操作 */
  728. handleUpdate1(row) {
  729. this.loading = true
  730. this.reset()
  731. this.getWorker()
  732. this.getPipeLength()
  733. this.getPipeType()
  734. this.getValveType()
  735. this.getArea()
  736. const id = row.id || this.ids
  737. getOrder(id).then(response => {
  738. this.loading = false
  739. this.form = response.data
  740. this.open1 = true
  741. this.title = '审核信息'
  742. this.getBuilding(this.form.areaId)
  743. this.getUnit(this.form.buildingId)
  744. this.getHouse(this.form.unitId)
  745. })
  746. },
  747. /** 提交按钮 */
  748. submitForm() {
  749. this.$refs['form'].validate(valid => {
  750. if (valid) {
  751. this.buttonLoading = true
  752. if (this.form.id != null) {
  753. if (typeof this.form.photoList === 'string') {
  754. this.form.photoList = this.form.photoList.split(',')
  755. }
  756. updateOrder(this.form).then(response => {
  757. this.$modal.msgSuccess('修改成功')
  758. this.open = false
  759. this.getList()
  760. this.getWorker()
  761. }).finally(() => {
  762. this.buttonLoading = false
  763. })
  764. } else {
  765. // this.form.photoList = this.form.photoList.split(',')
  766. addOrder(this.form).then(response => {
  767. this.$modal.msgSuccess('新增成功')
  768. this.open = false
  769. this.getList()
  770. this.getWorker()
  771. }).finally(() => {
  772. this.buttonLoading = false
  773. })
  774. }
  775. }
  776. })
  777. },
  778. /** 删除按钮操作 */
  779. handleDelete(row) {
  780. const ids = row.id || this.ids
  781. this.$modal.confirm('是否确认删除工程管理编号为"' + ids + '"的数据项?').then(() => {
  782. this.loading = true
  783. return delOrder(ids)
  784. }).then(() => {
  785. this.loading = false
  786. this.getList()
  787. this.getWorker()
  788. this.$modal.msgSuccess('删除成功')
  789. }).finally(() => {
  790. this.loading = false
  791. })
  792. },
  793. /** 导出按钮操作 */
  794. handleExport() {
  795. this.$download.excel('/gas/order/export', this.queryParams)
  796. },
  797. submitY(row) {
  798. if (this.form.id != null) {
  799. const ids = this.form.id
  800. const versions = this.form.version
  801. this.$modal.confirm('确定审核?').then(() => {
  802. this.loading = true
  803. return submitY(ids, this.form.reason, versions)
  804. }).then((res) => {
  805. this.open1 = false
  806. this.loading = false
  807. this.getList()
  808. this.getWorker()
  809. this.$modal.msgSuccess(res.msg)
  810. }).finally(() => {
  811. this.loading = false
  812. })
  813. } else {
  814. const ids = row.id || this.ids
  815. const versions = row.version || this.versions
  816. this.$modal.confirm('确定审核?').then(() => {
  817. this.loading = true
  818. return submitY(ids, this.form.reason, versions)
  819. }).then((res) => {
  820. this.loading = false
  821. this.getList()
  822. this.getWorker()
  823. this.$modal.msgSuccess(res.msg)
  824. }).finally(() => {
  825. this.loading = false
  826. })
  827. }
  828. },
  829. submitN(row) {
  830. if (this.form.id != null) {
  831. const ids = this.form.id
  832. const versions = this.form.version
  833. this.$modal.confirm('确定审核?').then(() => {
  834. this.loading = true
  835. return submitN(ids, this.form.reason, versions)
  836. }).then((res) => {
  837. this.open1 = false
  838. this.loading = false
  839. this.getList()
  840. this.getWorker()
  841. this.$modal.msgSuccess(res.msg)
  842. }).finally(() => {
  843. this.loading = false
  844. })
  845. } else {
  846. const ids = row.id || this.ids
  847. const versions = row.version || this.versions
  848. this.$modal.confirm('确定审核?').then(() => {
  849. this.loading = true
  850. return submitN(ids, this.form.reason, versions)
  851. }).then((res) => {
  852. this.loading = false
  853. this.getList()
  854. this.getWorker()
  855. this.$modal.msgSuccess(res.msg)
  856. }).finally(() => {
  857. this.loading = false
  858. })
  859. }
  860. }
  861. }
  862. }
  863. </script>