deviceTable.vue 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. <template>
  2. <div class="table-container">
  3. <div class="table-list" :style="tableData && tableData.length?'height:calc(100% - 50px);':'height:100%;'">
  4. <el-table :data="tableData" style="width: 100%" height="100%" v-loading="loading" :header-cell-style="headerStyle">
  5. <el-table-column label="所属建筑楼层" show-overflow-tooltip min-width="100">
  6. <template slot-scope="scope">
  7. <div>
  8. {{scope.row.Building?scope.row.Building.BuildLocalName?scope.row.Building.BuildLocalName:'':''}} -
  9. {{scope.row.Floor?scope.row.Floor.FloorLocalName?scope.row.Floor.FloorLocalName:'':''}}
  10. </div>
  11. </template>
  12. </el-table-column>
  13. <el-table-column :label="`${inSpaceType}本地名称`" show-overflow-tooltip min-width="100">
  14. <template slot-scope="scope">
  15. <div>
  16. {{scope.row.EquipLocalName}}
  17. <el-badge v-if="scope.row.Equipment?scope.row.Equipment.Component?scope.row.Equipment.Component.length:false:false"
  18. :value="scope.row.Equipment?scope.row.Equipment.Component?scope.row.Equipment.Component.length:0:0" class="item" type="warning">
  19. </el-badge>
  20. </div>
  21. </template>
  22. </el-table-column>
  23. <el-table-column prop="EquipLocalID" :label="`${inSpaceType}本地编码`" show-overflow-tooltip min-width="100"></el-table-column>
  24. <el-table-column prop="EquipCategory.EquipName" :label="`${inSpaceType}类型`" show-overflow-tooltip min-width="100"></el-table-column>
  25. <el-table-column prop="InstallLocation" label="安装位置" show-overflow-tooltip min-width="100"></el-table-column>
  26. <el-table-column prop="TaskState" label="任务执行情况" show-overflow-tooltip min-width="100"></el-table-column>
  27. <el-table-column prop="action" label="操作" min-width="100">
  28. <template slot-scope="scope">
  29. <i v-if="scope.row.TaskState == '待验证' || scope.row.TaskState == '未找到'" title="查看详情" class="iconfont icon-xiangqing table-button" @click="handleDetail(scope.$index, scope.row)"></i>
  30. <i v-if="scope.row.TaskState == '未找到'" title="重新生成任务" class="iconfont icon-Update table-button" @click="handleRegenerate(scope.$index, scope.row)"></i>
  31. <i v-if="scope.row.TaskState == '待验证'" title="删除任务" class="iconfont icon-delete table-button" @click="handleDelete(scope.$index, scope.row)"></i>
  32. <i v-if="scope.row.TaskState == '未找到'" title="认可此任务执行情况" class="iconfont icon-lijiqueren table-button" @click="handleConfirm(scope.$index, scope.row)"></i>
  33. </template>
  34. </el-table-column>
  35. <template slot="empty">
  36. <div style="height: 60%;transform: translateY(50%);">
  37. <i class="icon-wushuju iconfont"></i>
  38. 数据暂无
  39. </div>
  40. </template>
  41. </el-table>
  42. </div>
  43. <el-pagination class="right" v-show="tableData && tableData.length" @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="page.pageNumber"
  44. :page-sizes="page.pageSizes" :page-size="page.pageSize" layout="total, sizes, prev, pager, next, jumper" :total="page.total">
  45. </el-pagination>
  46. <el-drawer title="任务详情" :visible.sync="drawer" direction="rtl" size="600px">
  47. <device-detail :detail="detailDevice"></device-detail>
  48. </el-drawer>
  49. </div>
  50. </template>
  51. <script>
  52. import { queryDeviceTask, deleteDeviceTask, createDeviceTask, updateDeviceTask } from "@/api/data_admin/buildTaskApi"
  53. import { mapGetters } from "vuex"
  54. import deviceDetail from '../detail/deviceDetail'
  55. export default {
  56. components: {
  57. deviceDetail
  58. },
  59. computed: {
  60. ...mapGetters("layout", ["projectId"])
  61. },
  62. props: {
  63. paramsData: Object,
  64. },
  65. data() {
  66. return {
  67. inSpaceType: '设备',
  68. loading: false, // loading
  69. drawer: false, // 详情侧弹窗
  70. detailDevice: {},
  71. tableData: [], //列表数据
  72. page: {
  73. pageSize: 50,
  74. pageSizes: [10, 20, 50, 100],
  75. pageNumber: 1,
  76. total: 0
  77. },
  78. taskStateMap: {
  79. '-1': '未找到',
  80. '0': '已完成',
  81. '1': '待验证'
  82. },
  83. headerStyle: {
  84. backgroundColor: '#e1e4e5',
  85. color: '#2b2b2b',
  86. lineHeight: '30px'
  87. }, // 列表样式
  88. };
  89. },
  90. methods: {
  91. // 获取列表数据
  92. getTableData() {
  93. let params = {
  94. Filters: `ProjectId='${this.projectId}'`,
  95. Cascade: [
  96. {
  97. Name: 'component'
  98. }, {
  99. Name: 'scanScheme'
  100. }, {
  101. Name: 'building',
  102. }, {
  103. Name: 'floor',
  104. }, {
  105. Name: 'equipCategory'
  106. }
  107. ],
  108. Orders: "CreateTime desc, TaskId asc",
  109. PageNumber: this.page.pageNumber,
  110. PageSize: this.page.pageSize
  111. }
  112. if (this.paramsData.buildfloor[0] == "noKnow") {
  113. params.Filters += `;BuildingId isNull`
  114. } else if (this.paramsData.buildfloor[0] && this.paramsData.buildfloor[0] != "all") {
  115. params.Filters += `;BuildingId='${this.paramsData.buildfloor[0]}'`
  116. if (this.paramsData.buildfloor[1] == "noKnow") {
  117. params.Filters += `;FloorId isNull`
  118. } else if (this.paramsData.buildfloor[1] && this.paramsData.buildfloor[1] != "all") {
  119. params.Filters += `;FloorId='${this.paramsData.buildfloor[1]}'`
  120. }
  121. }
  122. if(this.paramsData.taskState !== ''){
  123. params.Filters += `;TaskState=${this.paramsData.taskState}`
  124. }
  125. if(this.paramsData.deviceCategory){
  126. params.Filters += `;Category='${this.paramsData.deviceCategory}'`
  127. }
  128. queryDeviceTask(params, res => {
  129. this.page.total = res.Total;
  130. this.tableData = res.Content.map(item => {
  131. if(item.Component && item.Component.length){
  132. item.ComponentCount = []
  133. item.Component.map(parts => {
  134. if(parts.EquipCategory && parts.EquipCategory.EquipCode && parts.EquipCategory.EquipName){
  135. let index = item.ComponentCount.findIndex(c => {return c.code == parts.EquipCategory.EquipCode})
  136. if(index != -1){
  137. item.ComponentCount[index].count++
  138. } else {
  139. item.ComponentCount.push({
  140. name: parts.EquipCategory.EquipName,
  141. code: parts.EquipCategory.EquipCode,
  142. count: 1
  143. })
  144. }
  145. }
  146. })
  147. }
  148. item.TaskState = this.taskStateMap[item.TaskState]
  149. return item
  150. })
  151. })
  152. },
  153. // 删除关系
  154. handleDelete(index, row) {
  155. this.$confirm("确认删除该任务?", "提示", {
  156. confirmButtonText: '确定',
  157. cancelButtonText: '取消',
  158. type: 'warning'
  159. }).then(() => {
  160. let params = [{TaskId: row.TaskId}]
  161. deleteDeviceTask(params, res => {
  162. this.$message.success('删除成功')
  163. this.getTableData()
  164. })
  165. }).catch(() => {
  166. this.$message("取消删除")
  167. })
  168. },
  169. //重新生成任务
  170. handleRegenerate(index, row){
  171. let params = {
  172. Content: [{
  173. EquipId: row.EquipId,
  174. TaskState: -1
  175. }]
  176. }
  177. createDeviceTask(params, res => {
  178. this.$message.success('重新生成任务成功!')
  179. this.getTableData()
  180. })
  181. },
  182. //认可此任务执行情况
  183. handleConfirm(index, row){
  184. let params = {
  185. Content: [{
  186. TaskId: row.TaskId,
  187. TaskState: 0
  188. }]
  189. }
  190. updateDeviceTask(params, res => {
  191. this.$message.success('更新成功!')
  192. this.getTableData()
  193. })
  194. },
  195. //查看任务详情
  196. handleDetail(index, row) {
  197. this.drawer = true
  198. this.detailDevice = row
  199. },
  200. // 改变pagesize
  201. handleSizeChange(pageSize) {
  202. this.page.pageNumber = 1
  203. this.page.pageSize = pageSize;
  204. this.getTableData()
  205. },
  206. // 改变pageno
  207. handleCurrentChange(pageNo) {
  208. this.page.pageNumber = pageNo;
  209. this.getTableData()
  210. }
  211. },
  212. watch: {
  213. paramsData: {
  214. handler(newName, oldName) {
  215. this.page.pageNumber = 1
  216. this.getTableData()
  217. },
  218. immediate: true,
  219. deep: true
  220. }
  221. }
  222. };
  223. </script>
  224. <style lang="less" scoped>
  225. /deep/ .el-drawer__body {
  226. height: calc(100% - 80px);
  227. border-top: 1px solid #c9c9c9;
  228. }
  229. /deep/ .el-drawer__header {
  230. margin-bottom: 12px;
  231. }
  232. .table-container {
  233. height: 100%;
  234. background: #fff;
  235. .table-button{
  236. cursor: pointer;
  237. margin-right: 15px;
  238. }
  239. }
  240. </style>