addsystem.vue 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519
  1. <template>
  2. <div id="deviceList">
  3. <el-row class="right">
  4. <span style="width:20px;float:left;display:block;height:20px;cursor: pointer;" @click="changeAssetsFalg">
  5. <i class="el-icon-fa el-icon-fa-compass"></i>
  6. </span>
  7. <span style="float:left;">当前选择的系统类型:{{category.CategoryName}}</span>
  8. <div style="width:200px;display:inline-block;text-align:left;color:gray;">
  9. <span>隐藏自动填充的信息</span>
  10. <el-checkbox v-model="showTypeFlag" @change="getTableHeader"></el-checkbox>
  11. </div>
  12. <span>增加</span>
  13. <el-input v-model="addNum" style="width:40px;" size="small"></el-input>
  14. <span>个{{category.CategoryName}}</span>
  15. <el-button @click="handleAddTableRow">增加</el-button>
  16. </el-row>
  17. <div class="tableBox">
  18. <div class="center middle_sty" style="flex:2;" v-show="tableData && !tableData.length">
  19. <p>
  20. <i class="iconwushuju iconfont"></i>
  21. 暂无数据
  22. </p>
  23. </div>
  24. <div class="tableLeft" v-show="tableData && tableData.length">
  25. <handson-table ref="table"></handson-table>
  26. </div>
  27. </div>
  28. <el-row class="center">
  29. <el-button type="primary" size="medium" @click="handleCreateTableData" class="create_button">创建系统</el-button>
  30. </el-row>
  31. </div>
  32. </template>
  33. <script>
  34. import tools from "@/utils/scan/tools";
  35. import handsonUtils from "@/utils/hasontableUtils";
  36. import showTools from "@/utils/handsontable/notShow";
  37. import text from "@/utils/handsontable/mainText";
  38. import session from "@/framework/utils/storage";
  39. import handsonTable from "@/components/common/handsontable";
  40. import {
  41. getDataDictionary,
  42. createGeneralSys,
  43. getSpaceFloor
  44. } from "@/api/scan/request";
  45. import { mapGetters, mapActions } from "vuex";
  46. import qrcode from "@/components/ledger/lib/qrcode";
  47. export default {
  48. components: {
  49. handsonTable
  50. },
  51. data() {
  52. return {
  53. addNum: 1,
  54. onlyRead: false,
  55. tableHeader: [],
  56. tableData: session.get("systemAddData")
  57. ? session.get("systemAddData").length
  58. ? session.get("systemAddData")
  59. : [{}]
  60. : [{}],
  61. copyTableData: [],
  62. category: "", //当前设备类
  63. myDialog: {
  64. qrcode: false, //二维码弹窗
  65. firm: false, //厂商弹窗
  66. supply: false, //选择供应合同
  67. supplier: false, //供应商选择
  68. guarantee: false, //选择保单
  69. maintainer: false, //选择维修商
  70. insurer: false, //选择保险公司
  71. uploadFiles: false, //上传文件
  72. uploadImgs: false, //上传单个图片
  73. pic: false, //多个图片
  74. addDevice: false,
  75. systemType: false,
  76. details: false, //详情页
  77. changeRea: false,
  78. lookPic: false //图片查看
  79. },
  80. qrcodeUrl: "", //二维码图片地址
  81. filesArr: [], //保存临时的文件key
  82. imgsArr: [], //临时保存的图片key数组
  83. picsArr: [], //临时设备图片keys数组
  84. systemId: null,
  85. graphyId: null,
  86. id: 0,
  87. showTypeFlag: true,
  88. EquipmentList: [],
  89. };
  90. },
  91. computed: {
  92. ...mapGetters("layout", ["projectId", "secret", "userId"])
  93. },
  94. created() {
  95. this.category = this.$route.query;
  96. this.getFloorData();
  97. this.getTableHeader();
  98. },
  99. methods: {
  100. //维护建筑
  101. changeAssetsFalg() {
  102. if (this.floorFlag) {
  103. this.floorFlag = false
  104. } else {
  105. this.$confirm('<p>维护设备所在建筑楼层后,对后续数据影响较大,如业务空间中的所在关系or其他?暂未梳理明白……</p><p>后续要修改设备所属建筑楼层,只能通过模型中的待建模清单操作</p>', '提示', {
  106. dangerouslyUseHTMLString: true,
  107. confirmButtonText: '就要维护设备所属建筑楼层',
  108. cancelButtonText: '暂时不搞了',
  109. confirmButtonClass: 'confirmButtonClass',
  110. cancelButtonClass: 'cancelButtonClass'
  111. }).then(_ => {
  112. this.floorFlag = true
  113. this.getTableHeader()
  114. }).catch(_ => {
  115. this.$message("取消")
  116. })
  117. }
  118. },
  119. //获取楼层数据
  120. getFloorData() {
  121. let param = {
  122. ProjId: this.projectId,
  123. secret: this.secret
  124. }
  125. getSpaceFloor(param).then(res => {
  126. if (res.data.Result == 'success') {
  127. let data = this.changeArr(res.data.Content), floorData = []
  128. data.map(item => {
  129. floorData.push({
  130. Code: item.value,
  131. Name: item.label
  132. })
  133. })
  134. this.floorData = floorData
  135. this.floorData = floorData
  136. } else {
  137. this.$message.error(res.data.ResultMsg)
  138. }
  139. }).catch(() => {
  140. this.$message.error("请求出错")
  141. })
  142. },
  143. //将数组转换成optiosn格式
  144. changeArr(arr) {
  145. return arr.map(item => {
  146. if (item.floors && item.floors.length) {
  147. return {
  148. value: item.id,
  149. label: item.infos.BuildLocalName,
  150. children: item.floors.map(i => {
  151. return {
  152. value: i.id,
  153. label: i.infos.FloorLocalName || "未知",
  154. }
  155. })
  156. }
  157. } else {
  158. return {
  159. value: item.id,
  160. label: item.infos.BuildLocalName,
  161. children: null,
  162. isChilren: 1,
  163. }
  164. }
  165. })
  166. },
  167. // 获取表头数据(初始化表格)
  168. async getTableHeader() {
  169. let params = {
  170. data: {
  171. PageNumber: 1,
  172. PageSize: 500
  173. },
  174. type: this.category.Category
  175. };
  176. await getDataDictionary(params, res => {
  177. this.tableHeader = res.Content;
  178. this.initTable();
  179. });
  180. },
  181. // 创建设备数据
  182. async handleCreateTableData() {
  183. let newData = this.tableData.filter(item => {
  184. let keys = Object.keys(item);
  185. keys.map(key => {
  186. //将值为空字符串的属性删除
  187. if (item[key] == "") {
  188. delete item[key];
  189. }
  190. });
  191. let newK = Object.keys(item)
  192. if (newK.length) {
  193. return item;
  194. }
  195. });
  196. if (!newData.length) {
  197. this.$message("创建信息为空,请录入信息后再创建!");
  198. return;
  199. }
  200. let flag = false;
  201. newData.map(item => {
  202. if (!item.SysLocalName) {
  203. flag = true;
  204. }
  205. // 处理建筑
  206. if (item.flowBuild) {
  207. item.BuildingId = item.flowBuild
  208. }
  209. item.Category = this.category.Category
  210. })
  211. if (flag) {
  212. this.$message.info("存在系统的本地名称为空,请检查")
  213. return;
  214. }
  215. createGeneralSys(newData, res => {
  216. this.$message.success('创建成功')
  217. session.remove("systemAddData")
  218. this.$router.push({
  219. path: "/system/list",
  220. query: { deviceId: this.category.Category }
  221. });
  222. })
  223. },
  224. // 删除表格行
  225. handleDeleteTableRow() {
  226. this.$message.success("删除成功");
  227. this.formaTableData();
  228. },
  229. // 添加行
  230. handleAddTableRow() {
  231. let addRowLength = this.addNum;
  232. for (let i = 0; i < addRowLength; i++) {
  233. this.tableData.push({});
  234. }
  235. this.initTable();
  236. this.formaTableData();
  237. },
  238. //修改
  239. handleUpdataTable(changeData, source) {
  240. this.formaTableData();
  241. },
  242. //保存去掉空字段的新增数据
  243. formaTableData() {
  244. let newData = this.tableData.filter(item => {
  245. let keys = Object.keys(item);
  246. keys.map(key => {
  247. //将值为空字符串的属性删除
  248. if (item[key] == "") {
  249. delete item[key];
  250. }
  251. });
  252. if (keys.length && Object.keys(item).length) {
  253. return item;
  254. }
  255. });
  256. session.set("systemAddData", newData);
  257. },
  258. //格式化表头显示的数据
  259. formatHeaderData(list) {
  260. let arr = tools.copyArr(list);
  261. let showType = this.showTypeFlag ? 'partInfo' : 'all';
  262. let data = showTools.headerTextFilter(arr, 'system', this.onlyRead, showType);
  263. data.unshift("所属建筑");
  264. return data;
  265. },
  266. formatHeaderType(list) {
  267. //格式化表头头映射的数据
  268. let arr = tools.copyArr(list);
  269. let showType = this.showTypeFlag ? 'partInfo' : 'all';
  270. let data = showTools.headerTypeFilter(arr, 'system', this.onlyRead, showType);
  271. data.unshift({
  272. data: "flowBuild",
  273. renderer: tools.customDropdownRenderer,
  274. editor: "chosen",
  275. chosenOptions: {
  276. // multiple: true,//多选
  277. data: this.floorData
  278. }
  279. });
  280. return data;
  281. },
  282. initTable() {
  283. //实例化表格
  284. let settings = {
  285. data: this.tableData,
  286. colHeaders: this.formatHeaderData(this.tableHeader),
  287. columns: this.formatHeaderType(this.tableHeader),
  288. rowHeights: 30,
  289. maxRows: this.tableData.length,
  290. contextMenu: {
  291. items: {
  292. remove_row: {
  293. name: "删除设备"
  294. }
  295. }
  296. },
  297. // 事件
  298. afterChange: this.handleUpdataTable, //修改后
  299. afterFilter: this.trimmedRows, //排序前
  300. afterRemoveRow: this.handleDeleteTableRow, //右键删除
  301. afterOnCellMouseDown: this.handleTdClick //鼠标点击
  302. };
  303. this.$nextTick(() => {
  304. this.tableExample = this.$refs.table.init(settings);
  305. });
  306. },
  307. //去除数组中相同的元素
  308. array_diff(a, b) {
  309. for (var i = 0; i < b.length; i++) {
  310. for (var j = 0; j < a.length; j++) {
  311. if (a[j] == b[i]) {
  312. a.splice(j, 1);
  313. j = j - 1;
  314. }
  315. }
  316. }
  317. return a;
  318. },
  319. //表格点击事件
  320. handleTdClick(el, rowArr) {
  321. //点击的是表头
  322. if (rowArr.row < 0) {
  323. return;
  324. }
  325. //被筛选过后的数组
  326. let trimmedArr = this.trimmedRows();
  327. //是否启用了排序
  328. let isSort = this.tableExample.getPlugin("columnSorting").isSorted();
  329. if (trimmedArr.length && isSort) {
  330. let sortArr = this.myHotArr.getPlugin("columnSorting").rowsMapper
  331. .__arrayMap;
  332. let infos = this.tableData[trimmedArr[sortArr[rowArr.row]]];
  333. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  334. } else if (isSort) {
  335. //排序后的数组
  336. let sortArr = this.tableExample.getPlugin("columnSorting").rowsMapper
  337. .__arrayMap;
  338. let infos = this.tableData[sortArr[rowArr.row]];
  339. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  340. } else if (trimmedArr.length) {
  341. let infos = this.tableData[trimmedArr[rowArr.row]];
  342. this.getInfors(infos, { row: trimmedArr[rowArr.row], col: rowArr.col });
  343. } else {
  344. let infos = this.tableData[rowArr.row];
  345. this.getInfors(infos, rowArr);
  346. }
  347. },
  348. //获取被筛选掉的行号
  349. trimmedRows() {
  350. var plugin = this.tableExample.getPlugin("trimRows").trimmedRows;
  351. let dataLength = this.tableData.length;
  352. let dataArr = new Array();
  353. for (let i = 0; i < dataLength; i++) {
  354. dataArr.push(i);
  355. }
  356. if (plugin.length <= 0) {
  357. dataArr = undefined;
  358. } else {
  359. dataArr = this.array_diff(dataArr, plugin);
  360. }
  361. return dataArr || [];
  362. },
  363. getInfors(infos, row) {
  364. let val = this.tableExample.colToProp(row.col);
  365. console.log(val)
  366. switch (val) {
  367. //操作
  368. case 'caozuo':
  369. // window.open(`http://adm.sagacloud.cn:8058/spread?id=${infos.EquipID}&pid=${this.projectId}&secret=${this.secret}`,"_blank")
  370. this.$message("开发中...")
  371. break;
  372. //设备二维码图片
  373. case 'EquipQRCode':
  374. this.qrcodeUrl = this.tableData[row.row].EquipQRCode;
  375. if (!!this.qrcodeUrl) {
  376. this.myDialog.qrcode = true;
  377. } else {
  378. this.$message("此设备没有设备二维码");
  379. }
  380. break;
  381. //关联系统
  382. case 'linkSystem':
  383. if (!this.onlyRead) {
  384. this.systemList = this.tableData[row.row].LinkSystem || [];
  385. this.myDialog.systemType = true;
  386. }
  387. break;
  388. //关联资产
  389. case 'LinkEquipLocalName':
  390. if (this.linkNameFalg) {
  391. this.myDialog.changeRea = true;
  392. }
  393. break;
  394. //品牌型号弹窗
  395. case 'DPManufacturerID':
  396. if (!this.onlyRead) {
  397. this.myDialog.firm = true;
  398. }
  399. break;
  400. //供应商信息弹窗
  401. case 'DPSupplierID':
  402. if (!this.onlyRead) {
  403. this.myDialog.supplier = true;
  404. }
  405. break;
  406. //维修商信息弹窗
  407. case 'DPMaintainerID':
  408. if (!this.onlyRead) {
  409. this.myDialog.maintainer = true;
  410. }
  411. break;
  412. //保险公司信息
  413. case 'DPInsurerID':
  414. if (!this.onlyRead) {
  415. this.myDialog.insurer = true;
  416. }
  417. break;
  418. //供应合同编号
  419. case 'LedgerParam.SupplyPurchase.SupplierContractID':
  420. if (!this.onlyRead) {
  421. let ContractIDflag = null;
  422. let DPSdata = this.tableData[row.row].DPSupplierID;
  423. if (DPSdata) {
  424. ContractIDflag = DPSdata.split("-")[0];
  425. }
  426. if (!!ContractIDflag) {
  427. this.id = ContractIDflag;
  428. this.myDialog.supply = true;
  429. } else {
  430. this.$message("请先选择供应商");
  431. }
  432. }
  433. break;
  434. //保险单号
  435. case 'LedgerParam.InsuranceDoc.InsuranceNum':
  436. if (!this.onlyRead) {
  437. let DPInsurerIDflag = null;
  438. let DPIdata = this.tableData[row.row].DPInsurerID;
  439. if (DPIdata) {
  440. DPInsurerIDflag = DPIdata.split("-")[0];
  441. }
  442. if (!!DPInsurerIDflag) {
  443. this.id = DPInsurerIDflag;
  444. this.myDialog.guarantee = true;
  445. } else {
  446. this.$message("请先选择保险商");
  447. }
  448. }
  449. break;
  450. //保险文件--设备文档--安装质检报告
  451. case 'LedgerParam.InsuranceDoc.InsuranceFile':
  452. case 'LedgerParam.PhotoDoc.Archive':
  453. case 'LedgerParam.Siteinstall.CheckReport':
  454. let IPSdata = tools.dataForKey(this.tableData[row.row], val);
  455. this.filesArr = IPSdata ? IPSdata : [];
  456. this.myDialog.uploadFiles = true;
  457. break;
  458. //安装照片--安装图纸--设备铭牌照片--设备图纸
  459. case 'LedgerParam.Siteinstall.InstallPic':
  460. case 'LedgerParam.Siteinstall.InstallDrawing':
  461. case 'LedgerParam.PhotoDoc.Nameplate':
  462. case 'LedgerParam.PhotoDoc.Drawing':
  463. let SSPPdata = tools.dataForKey(this.tableData[row.row], val);
  464. this.imgsArr = SSPPdata ? SSPPdata : [];
  465. this.myDialog.uploadImgs = true;
  466. break;
  467. //设备照片
  468. case 'LedgerParam.PhotoDoc.Pic':
  469. let Pdata = tools.dataForKey(this.tableData[row.row], val);
  470. this.picsArr = Pdata ? Pdata : [];
  471. this.myDialog.pic = true;
  472. break;
  473. //包含的部件字段
  474. case 'Count':
  475. if (this.onlyRead) {
  476. this.$router.push({ path: '/ledger/parts', query: { deviceId: infos.EquipID } });
  477. } else {
  478. this.$router.push({ path: '/ledger/partsmanage', query: { deviceId: infos.EquipID, typeId: this.mess.deviceId } });
  479. }
  480. break;
  481. default:
  482. break;
  483. }
  484. this.row = row.row;
  485. this.messKey = val;
  486. },
  487. }
  488. };
  489. </script>
  490. <style lang="less" scoped>
  491. #deviceList {
  492. overflow: hidden;
  493. height: 100%;
  494. background-color: #fff;
  495. padding: 10px;
  496. position: relative;
  497. .right {
  498. background: #fff;
  499. }
  500. .search-header {
  501. overflow: hidden;
  502. padding: 0 10px 10px 10px;
  503. border-bottom: 1px solid #bcbcbc;
  504. }
  505. .tableBox {
  506. display: flex;
  507. height: calc(100% - 100px);
  508. margin-top: 10px;
  509. .tableLeft {
  510. flex: 1;
  511. }
  512. }
  513. .create_button {
  514. margin-top: 10px;
  515. }
  516. }
  517. </style>