addfacility.vue 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686
  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.name}}</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.name}}</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="icon-wushuju 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. <!-- 二维码弹窗 -->
  32. <qrcode :dialog="myDialog" :qrcodeUrl="qrcodeUrl" :addBody="true" ref="qrcode"></qrcode>
  33. <!-- 型号弹窗 -->
  34. <firm :mess="{deviceId: firmId}" ref="firm" @changeFirm="firmChange" :dialog="myDialog"></firm>
  35. <!-- 供应商合同弹窗 -->
  36. <supply-dialog ref="supply" @change="supplyChange" :id="id" :dialog="myDialog"></supply-dialog>
  37. <!-- 供应商弹窗 -->
  38. <supplier-dialog ref="supplier" @changeSupplier="supplierChange" :dialog="myDialog"></supplier-dialog>
  39. <guarantee-dialog :id="id" ref="guarantee" @change="guaranteeChange" :dialog="myDialog"></guarantee-dialog>
  40. <upload-files-dialog :read="onlyRead ? true : false" ref="upload" @changeFile="fileChange" :keysArr="filesArr" :dialog="myDialog">
  41. </upload-files-dialog>
  42. <upload-img-dialog :read="onlyRead ? true : false" @changeFile="imgChange" :keysArr="imgsArr" :dialog="myDialog"></upload-img-dialog>
  43. <maintainer-dialog @changeMaintainer="changeMaintainer" ref="maintainer" :dialog="myDialog"></maintainer-dialog>
  44. <insurer-dialog @changeInsurer="changeInsurer" ref="insurer" :dialog="myDialog"></insurer-dialog>
  45. <pic-dialog :read="onlyRead ? true : false" :dialog="myDialog" :keysArr="picsArr" @change="changePics"></pic-dialog>
  46. <system-type :device="category" :dialog="myDialog" :type="onlyRead?'read':'edit'" @change="changeSystemType" :list="systemList"></system-type>
  47. <details-dialog :iframeSrc="iframeSrc" v-if="myDialog.details" :dialog="myDialog"></details-dialog>
  48. </div>
  49. </template>
  50. <script>
  51. import tools from "@/utils/scan/tools";
  52. import handsonUtils from "@/utils/hasontableUtils";
  53. import showTools from "@/utils/handsontable/notShow";
  54. import text from "@/utils/handsontable/mainText";
  55. import session from "@/framework/utils/storage";
  56. import buildFloor from '@/utils/handsontable/buildFloorData'
  57. import handsonTable from "@/components/common/handsontable";
  58. import {
  59. getDataDictionary,
  60. createEquip,
  61. createPropertyData,
  62. getEquipBelongs,
  63. getSpaceFloor,
  64. createEquipAndProperty
  65. } from "@/api/scan/request";
  66. import { mapGetters, mapActions } from "vuex";
  67. import qrcode from "@/components/ledger/lib/qrcode";
  68. import firm from "@/components/dialogs/list/firm";
  69. import supplyDialog from "@/components/dialogs/list/supplyDialog";
  70. import supplierDialog from "@/components/dialogs/list/supplierDialog";
  71. import maintainerDialog from "@/components/dialogs/list/maintainerDialog";
  72. import insurerDialog from "@/components/dialogs/list/insurerDialog";
  73. import guaranteeDialog from "@/components/dialogs/list/guaranteeDialog";
  74. import uploadFilesDialog from "@/components/dialogs/list/filesDialog";
  75. import uploadImgDialog from "@/components/dialogs/list/uploadImgDialog";
  76. import picDialog from "@/components/dialogs/list/picDialog";
  77. import systemType from "@/components/dialogs/list/systemType";
  78. export default {
  79. components: {
  80. qrcode, //二维码页面
  81. firm, //品牌型号弹窗
  82. supplyDialog,
  83. supplierDialog,
  84. maintainerDialog,
  85. insurerDialog,
  86. guaranteeDialog,
  87. uploadFilesDialog,
  88. uploadImgDialog,
  89. picDialog,
  90. systemType,
  91. handsonTable
  92. },
  93. data() {
  94. return {
  95. addNum: 1,
  96. onlyRead: false,
  97. tableHeader: [],
  98. tableData: session.get("deviceAddData")
  99. ? session.get("deviceAddData").length
  100. ? session.get("deviceAddData")
  101. : [{ Checked: 1 }]
  102. : [{ Checked: 1 }],
  103. copyTableData: [],
  104. category: "", //当前设备类
  105. myDialog: {
  106. qrcode: false, //二维码弹窗
  107. firm: false, //厂商弹窗
  108. supply: false, //选择供应合同
  109. supplier: false, //供应商选择
  110. guarantee: false, //选择保单
  111. maintainer: false, //选择维修商
  112. insurer: false, //选择保险公司
  113. uploadFiles: false, //上传文件
  114. uploadImgs: false, //上传单个图片
  115. pic: false, //多个图片
  116. addDevice: false,
  117. systemType: false,
  118. details: false, //详情页
  119. changeRea: false,
  120. lookPic: false //图片查看
  121. },
  122. qrcodeUrl: "", //二维码图片地址
  123. filesArr: [], //保存临时的文件key
  124. imgsArr: [], //临时保存的图片key数组
  125. picsArr: [], //临时设备图片keys数组
  126. systemList: [], //关联的系统
  127. systemId: null,
  128. graphyId: null,
  129. id: 0,
  130. showTypeFlag: true,
  131. EquipmentList: [],
  132. firmId: "", //品牌型号所需字段--族id三位编码(传设备类id或部件类id)
  133. buildFloorData: [],
  134. };
  135. },
  136. computed: {
  137. ...mapGetters("layout", ["projectId", "secret", "userId"])
  138. },
  139. created() {
  140. this.category = this.$route.query;
  141. buildFloor.getData(this.buildFloorData)
  142. this.getBelongs();
  143. this.getTableHeader();
  144. },
  145. methods: {
  146. //查询设备类对应的 族
  147. getBelongs() {
  148. let params = {
  149. data: {
  150. Filters: `EquipCode='${this.category.deviceId}'`,
  151. PageNumber: 1,
  152. PageSize: 50
  153. }
  154. }
  155. getEquipBelongs(params, res => {
  156. this.firmId = res.Content[0].Family;
  157. })
  158. },
  159. //维护建筑
  160. changeAssetsFalg() {
  161. if (this.floorFlag) {
  162. this.floorFlag = false
  163. } else {
  164. this.$confirm('<p>维护设备所在建筑楼层后,对后续数据影响较大,如业务空间中的所在关系or其他?暂未梳理明白……</p><p>后续要修改设备所属建筑楼层,只能通过模型中的待建模清单操作</p>', '提示', {
  165. dangerouslyUseHTMLString: true,
  166. confirmButtonText: '就要维护设备所属建筑楼层',
  167. cancelButtonText: '暂时不搞了',
  168. confirmButtonClass: 'confirmButtonClass',
  169. cancelButtonClass: 'cancelButtonClass'
  170. }).then(_ => {
  171. this.floorFlag = true
  172. this.getTableHeader()
  173. }).catch(_ => {
  174. this.$message("取消")
  175. })
  176. }
  177. },
  178. //将数组转换成optiosn格式
  179. changeArr(arr) {
  180. return arr.map(item => {
  181. if (item.floors && item.floors.length) {
  182. return {
  183. value: item.id,
  184. label: item.infos.BuildLocalName,
  185. children: item.floors.map(i => {
  186. return {
  187. value: i.id,
  188. label: i.infos.FloorLocalName || "未知",
  189. }
  190. })
  191. }
  192. } else {
  193. return {
  194. value: item.id,
  195. label: item.infos.BuildLocalName,
  196. children: null,
  197. isChilren: 1,
  198. }
  199. }
  200. })
  201. },
  202. // 获取表头数据(初始化表格)
  203. async getTableHeader() {
  204. let params = {
  205. data: {
  206. PageNumber: 1,
  207. PageSize: 500
  208. },
  209. type: this.category.deviceId
  210. };
  211. await getDataDictionary(params, res => {
  212. this.tableHeader = res.Content;
  213. this.initTable();
  214. });
  215. },
  216. // 创建设备数据
  217. async handleCreateTableData() {
  218. let newData = this.tableData.filter(item => {
  219. let keys = Object.keys(item);
  220. keys.map(key => {
  221. //将值为空字符串的属性删除
  222. if (item[key] == "") {
  223. delete item[key];
  224. }
  225. });
  226. let newK = Object.keys(item)
  227. if ((item.Checked && newK.length > 1) || (!item.Checked && newK.length)) {
  228. return item;
  229. }
  230. });
  231. if (!newData.length) {
  232. this.$message("创建信息为空,请录入信息后再创建!");
  233. return;
  234. }
  235. let flag = false;
  236. newData.map(item => {
  237. if (item.Checked && !item.EquipLocalName) {
  238. flag = true;
  239. }
  240. // 处理建筑-楼层
  241. if (item.flowBuild) {
  242. let bid = item.flowBuild.split("-");
  243. item.BuildingId = item.flowBuild.split("-")[0]
  244. if (bid[1]) {
  245. item.FloorId = item.flowBuild.split("-")[1]
  246. }
  247. }
  248. //处理管理的系统
  249. if (item.LinkSystem && item.LinkSystem.length) {
  250. item.SystemList = []
  251. item.LinkSystem.map(t => {
  252. item.SystemList.push(t.SysID)
  253. })
  254. }
  255. item.PropertyId = !!item.Checked;
  256. item.Category = this.category.deviceId;
  257. })
  258. if (flag) {
  259. this.$message.info("存在设备的本地名称为空,请检查")
  260. return;
  261. }
  262. // for (let i = 0; i < newData.length; i++) {
  263. // let params = newData[i]
  264. // params.Family = this.firmId;
  265. // params.Category = this.category.deviceId;
  266. // if (newData[i].PropertyId) {//同时创建资产
  267. // await createPropertyData([params], async res => {
  268. // params.PropertyId = res.EntityList[0].EquipID
  269. // await createEquip([params], res => {
  270. // if (i == newData.length - 1) {
  271. // this.$router.push({
  272. // path: "/ledger/facility",
  273. // query: { deviceId: this.category.deviceId }
  274. // });
  275. // session.remove("deviceAddData")
  276. // }
  277. // })
  278. // })
  279. // } else {
  280. // await createEquip([params], res => {
  281. // if (i == newData.length - 1) {
  282. // this.$router.push({
  283. // path: "/ledger/facility",
  284. // query: { deviceId: this.category.deviceId }
  285. // });
  286. // session.remove("deviceAddData")
  287. // }
  288. // });
  289. // }
  290. // }
  291. createEquipAndProperty(newData, res => {
  292. this.$message.success('创建成功')
  293. session.remove("deviceAddData")
  294. this.$router.push({
  295. name: "facilityLedger",
  296. params: { deviceId: this.category.deviceId }
  297. });
  298. })
  299. },
  300. // 删除表格行
  301. handleDeleteTableRow() {
  302. this.$message.success("删除成功");
  303. this.formaTableData();
  304. },
  305. // 添加行
  306. handleAddTableRow() {
  307. let addRowLength = this.addNum;
  308. for (let i = 0; i < addRowLength; i++) {
  309. this.tableData.push({ Checked: 1 });
  310. }
  311. this.initTable();
  312. this.formaTableData();
  313. },
  314. //修改
  315. handleUpdataTable(changeData, source) {
  316. this.formaTableData();
  317. },
  318. //保存去掉空字段的新增数据
  319. formaTableData() {
  320. let newData = this.tableData.filter(item => {
  321. let keys = Object.keys(item);
  322. keys.map(key => {
  323. //将值为空字符串的属性删除
  324. if (item[key] == "") {
  325. delete item[key];
  326. }
  327. });
  328. if (keys.length && Object.keys(item).length) {
  329. return item;
  330. }
  331. });
  332. session.set("deviceAddData", newData);
  333. },
  334. //格式化表头显示的数据
  335. formatHeaderData(list) {
  336. let arr = tools.copyArr(list);
  337. let showType = this.showTypeFlag ? 'partInfo' : 'all';
  338. let data = showTools.headerTextFilter(arr, 'equipment', this.onlyRead, showType, true);
  339. data.unshift("同时创建资产", "所属系统实例");
  340. if (this.floorFlag) {
  341. data.splice(1, 0, "所属建筑楼层")
  342. }
  343. return data;
  344. },
  345. formatHeaderType(list) {
  346. //格式化表头头映射的数据
  347. let arr = tools.copyArr(list);
  348. let showType = this.showTypeFlag ? 'partInfo' : 'all';
  349. let data = showTools.headerTypeFilter(arr, 'equipment', this.onlyRead, showType, true);
  350. data.unshift({
  351. type: "checkbox",
  352. checkedTemplate: 1,
  353. uncheckedTemplate: 0,
  354. data: "Checked",
  355. label: {
  356. position: "after"
  357. }
  358. }, {
  359. data: "LinkSystem",
  360. renderer: text.systemList,
  361. readOnly: true
  362. });
  363. if (this.floorFlag) {
  364. data.splice(1, 0, {
  365. data: "flowBuild",
  366. renderer: tools.customDropdownRenderer,
  367. editor: "chosen",
  368. chosenOptions: {
  369. // multiple: true,//多选
  370. data: this.buildFloorData
  371. }
  372. })
  373. }
  374. return data;
  375. },
  376. initTable() {
  377. //实例化表格
  378. let settings = {
  379. data: this.tableData,
  380. colHeaders: this.formatHeaderData(this.tableHeader),
  381. columns: this.formatHeaderType(this.tableHeader),
  382. rowHeights: 30,
  383. maxRows: this.tableData.length,
  384. contextMenu: {
  385. items: {
  386. remove_row: {
  387. name: "删除设备"
  388. }
  389. }
  390. },
  391. // 事件
  392. afterChange: this.handleUpdataTable, //修改后
  393. afterFilter: this.trimmedRows, //排序前
  394. afterRemoveRow: this.handleDeleteTableRow, //右键删除
  395. afterOnCellMouseDown: this.handleTdClick //鼠标点击
  396. };
  397. this.$nextTick(() => {
  398. this.tableExample = this.$refs.table.init(settings);
  399. });
  400. },
  401. //去除数组中相同的元素
  402. array_diff(a, b) {
  403. for (var i = 0; i < b.length; i++) {
  404. for (var j = 0; j < a.length; j++) {
  405. if (a[j] == b[i]) {
  406. a.splice(j, 1);
  407. j = j - 1;
  408. }
  409. }
  410. }
  411. return a;
  412. },
  413. //选择型号修改
  414. firmChange(data) {
  415. tools.setDataForKey(this.tableData[this.row], "LedgerParam.EquipManufactor.Brand", data.brand)
  416. tools.setDataForKey(this.tableData[this.row], "LedgerParam.EquipManufactor.Specification", data.name)
  417. tools.setDataForKey(this.tableData[this.row], "DPManufacturerID", data.venderId)
  418. },
  419. supplyChange(data) {
  420. let changeData = { id: data };
  421. this.utilToKey("id", "id", changeData, "SupplierContractID");
  422. },
  423. //如果选择供应商之后
  424. supplierChange(data) {
  425. tools.setDataForKey(this.tableData[this.row], "LedgerParam.SupplyPurchase.Supplier", data.name)
  426. tools.setDataForKey(this.tableData[this.row], "DPSupplierID", data.venderId)
  427. },
  428. //保险合同
  429. guaranteeChange(data) {
  430. for (let key in data) {
  431. this.utilToKey(key, "insuranceNo", data, "InsuranceNum");
  432. if (key == "contractFile") {
  433. if (!!data[key]) {
  434. data[key] = [data[key]];
  435. }
  436. }
  437. this.utilToKey(key, "contractFile", data, "InsuranceFile");
  438. }
  439. },
  440. //上传文件弹窗触发事件
  441. fileChange(keys) {
  442. this.setDataToMain(keys, this.messKey, this.row);
  443. },
  444. //上传图片弹窗触发事件
  445. imgChange(keys) {
  446. this.setDataToMain(keys, this.messKey, this.row);
  447. },
  448. //维修商变更
  449. changeMaintainer(data) {
  450. tools.setDataForKey(this.tableData[this.row], "LedgerParam.OperationMainte.Maintainer", data.name)
  451. tools.setDataForKey(this.tableData[this.row], "DPMaintainerID", data.venderId)
  452. },
  453. //保险商变更
  454. changeInsurer(data) {
  455. tools.setDataForKey(this.tableData[this.row], "LedgerParam.InsuranceDoc.Insurer", data.name)
  456. tools.setDataForKey(this.tableData[this.row], "DPInsurerID", data.venderId)
  457. },
  458. //设备图片弹窗改变事件
  459. changePics(keys) {
  460. this.setDataToMain(keys, this.messKey, this.row);
  461. },
  462. //关联系统变更
  463. changeSystemType(data) {
  464. tools.setDataForKey(this.tableData[this.row], "LinkSystem", data)
  465. },
  466. //表格点击事件
  467. handleTdClick(el, rowArr) {
  468. //点击的是表头
  469. if (rowArr.row < 0) {
  470. return;
  471. }
  472. //被筛选过后的数组
  473. let trimmedArr = this.trimmedRows();
  474. //是否启用了排序
  475. let isSort = this.tableExample.getPlugin("columnSorting").isSorted();
  476. if (trimmedArr.length && isSort) {
  477. let sortArr = this.myHotArr.getPlugin("columnSorting").rowsMapper
  478. .__arrayMap;
  479. let infos = this.tableData[trimmedArr[sortArr[rowArr.row]]];
  480. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  481. } else if (isSort) {
  482. //排序后的数组
  483. let sortArr = this.tableExample.getPlugin("columnSorting").rowsMapper
  484. .__arrayMap;
  485. let infos = this.tableData[sortArr[rowArr.row]];
  486. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  487. } else if (trimmedArr.length) {
  488. let infos = this.tableData[trimmedArr[rowArr.row]];
  489. this.getInfors(infos, { row: trimmedArr[rowArr.row], col: rowArr.col });
  490. } else {
  491. let infos = this.tableData[rowArr.row];
  492. this.getInfors(infos, rowArr);
  493. }
  494. },
  495. //获取被筛选掉的行号
  496. trimmedRows() {
  497. var plugin = this.tableExample.getPlugin("trimRows").trimmedRows;
  498. let dataLength = this.tableData.length;
  499. let dataArr = new Array();
  500. for (let i = 0; i < dataLength; i++) {
  501. dataArr.push(i);
  502. }
  503. if (plugin.length <= 0) {
  504. dataArr = undefined;
  505. } else {
  506. dataArr = this.array_diff(dataArr, plugin);
  507. }
  508. return dataArr || [];
  509. },
  510. getInfors(infos, row) {
  511. let val = this.tableExample.colToProp(row.col);
  512. switch (val) {
  513. //操作
  514. case 'caozuo':
  515. // window.open(`http://adm.sagacloud.cn:8058/spread?id=${infos.EquipID}&pid=${this.projectId}&secret=${this.secret}`,"_blank")
  516. this.$message("开发中...")
  517. break;
  518. //设备二维码图片
  519. case 'EquipQRCode':
  520. this.qrcodeUrl = this.tableData[row.row].EquipQRCode;
  521. if (!!this.qrcodeUrl) {
  522. this.myDialog.qrcode = true;
  523. } else {
  524. this.$message("此设备没有设备二维码");
  525. }
  526. break;
  527. //关联系统
  528. case 'LinkSystem':
  529. if (!this.onlyRead) {
  530. this.systemList = this.tableData[row.row].LinkSystem || [];
  531. this.myDialog.systemType = true;
  532. }
  533. break;
  534. //关联资产
  535. case 'LinkEquipLocalName':
  536. if (this.linkNameFalg) {
  537. this.myDialog.changeRea = true;
  538. }
  539. break;
  540. //品牌型号弹窗
  541. case 'DPManufacturerID':
  542. if (!this.onlyRead) {
  543. this.myDialog.firm = true;
  544. }
  545. break;
  546. //供应商信息弹窗
  547. case 'DPSupplierID':
  548. if (!this.onlyRead) {
  549. this.myDialog.supplier = true;
  550. }
  551. break;
  552. //维修商信息弹窗
  553. case 'DPMaintainerID':
  554. if (!this.onlyRead) {
  555. this.myDialog.maintainer = true;
  556. }
  557. break;
  558. //保险公司信息
  559. case 'DPInsurerID':
  560. if (!this.onlyRead) {
  561. this.myDialog.insurer = true;
  562. }
  563. break;
  564. //供应合同编号
  565. case 'LedgerParam.SupplyPurchase.SupplierContractID':
  566. if (!this.onlyRead) {
  567. let ContractIDflag = null;
  568. let DPSdata = this.tableData[row.row].DPSupplierID;
  569. if (DPSdata) {
  570. ContractIDflag = DPSdata.split("-")[0];
  571. }
  572. if (!!ContractIDflag) {
  573. this.id = ContractIDflag;
  574. this.myDialog.supply = true;
  575. } else {
  576. this.$message("请先选择供应商");
  577. }
  578. }
  579. break;
  580. //保险单号
  581. case 'LedgerParam.InsuranceDoc.InsuranceNum':
  582. if (!this.onlyRead) {
  583. let DPInsurerIDflag = null;
  584. let DPIdata = this.tableData[row.row].DPInsurerID;
  585. if (DPIdata) {
  586. DPInsurerIDflag = DPIdata.split("-")[0];
  587. }
  588. if (!!DPInsurerIDflag) {
  589. this.id = DPInsurerIDflag;
  590. this.myDialog.guarantee = true;
  591. } else {
  592. this.$message("请先选择保险商");
  593. }
  594. }
  595. break;
  596. //保险文件--设备文档--安装质检报告
  597. case 'LedgerParam.InsuranceDoc.InsuranceFile':
  598. case 'LedgerParam.PhotoDoc.Archive':
  599. case 'LedgerParam.Siteinstall.CheckReport':
  600. let IPSdata = tools.dataForKey(this.tableData[row.row], val);
  601. this.filesArr = IPSdata ? IPSdata : [];
  602. this.myDialog.uploadFiles = true;
  603. break;
  604. //安装照片--安装图纸--设备铭牌照片--设备图纸
  605. case 'LedgerParam.Siteinstall.InstallPic':
  606. case 'LedgerParam.Siteinstall.InstallDrawing':
  607. case 'LedgerParam.PhotoDoc.Nameplate':
  608. case 'LedgerParam.PhotoDoc.Drawing':
  609. let SSPPdata = tools.dataForKey(this.tableData[row.row], val);
  610. this.imgsArr = SSPPdata ? SSPPdata : [];
  611. this.myDialog.uploadImgs = true;
  612. break;
  613. //设备照片
  614. case 'LedgerParam.PhotoDoc.Pic':
  615. let Pdata = tools.dataForKey(this.tableData[row.row], val);
  616. this.picsArr = Pdata ? Pdata : [];
  617. this.myDialog.pic = true;
  618. break;
  619. //包含的部件字段
  620. case 'Count':
  621. if (this.onlyRead) {
  622. this.$router.push({ path: '/ledger/parts', query: { deviceId: infos.EquipID } });
  623. } else {
  624. this.$router.push({ path: '/ledger/partsmanage', query: { deviceId: infos.EquipID, typeId: this.mess.deviceId } });
  625. }
  626. break;
  627. default:
  628. break;
  629. }
  630. this.row = row.row;
  631. this.messKey = val;
  632. },
  633. utilToKey(key, name, data, messName) {
  634. if (key == name) {
  635. this.setDataToMain(data[key], messName, this.row);
  636. }
  637. },
  638. //判断是否有值,有值赋值
  639. setDataToMain(data, key, row) {
  640. if (!!data && data != "--") {
  641. if (!!this.tableData[row]) {
  642. //铭牌照片特殊处理
  643. tools.setDataForKey(this.tableData[row], key, data)
  644. // this.tableData[row][key] = data;
  645. } else {
  646. this.tableData[row] = {};
  647. tools.setDataForKey(this.tableData[row], key, data)
  648. }
  649. } else {
  650. tools.setDataForKey(this.tableData[row], key, "")
  651. }
  652. }
  653. }
  654. };
  655. </script>
  656. <style lang="less" scoped>
  657. #deviceList {
  658. overflow: hidden;
  659. height: 100%;
  660. background-color: #fff;
  661. padding: 10px;
  662. position: relative;
  663. .right {
  664. background: #fff;
  665. }
  666. .search-header {
  667. overflow: hidden;
  668. padding: 0 10px 10px 10px;
  669. border-bottom: 1px solid #bcbcbc;
  670. }
  671. .tableBox {
  672. display: flex;
  673. height: calc(100% - 100px);
  674. margin-top: 10px;
  675. .tableLeft {
  676. flex: 1;
  677. }
  678. }
  679. .create_button {
  680. margin-top: 10px;
  681. }
  682. }
  683. </style>