addfacility.vue 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691
  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. //待接口修改为关联创建即可修改
  292. let param = {
  293. Cascade: [],
  294. Content: newData
  295. }
  296. createEquipAndProperty(param, res => {
  297. this.$message.success('创建成功')
  298. session.remove("deviceAddData")
  299. this.$router.push({
  300. name: "facilityLedger",
  301. params: { deviceId: this.category.deviceId }
  302. });
  303. })
  304. },
  305. // 删除表格行
  306. handleDeleteTableRow() {
  307. this.$message.success("删除成功");
  308. this.formaTableData();
  309. },
  310. // 添加行
  311. handleAddTableRow() {
  312. let addRowLength = this.addNum;
  313. for (let i = 0; i < addRowLength; i++) {
  314. this.tableData.push({ Checked: 1 });
  315. }
  316. this.initTable();
  317. this.formaTableData();
  318. },
  319. //修改
  320. handleUpdataTable(changeData, source) {
  321. this.formaTableData();
  322. },
  323. //保存去掉空字段的新增数据
  324. formaTableData() {
  325. let newData = this.tableData.filter(item => {
  326. let keys = Object.keys(item);
  327. keys.map(key => {
  328. //将值为空字符串的属性删除
  329. if (item[key] == "") {
  330. delete item[key];
  331. }
  332. });
  333. if (keys.length && Object.keys(item).length) {
  334. return item;
  335. }
  336. });
  337. session.set("deviceAddData", newData);
  338. },
  339. //格式化表头显示的数据
  340. formatHeaderData(list) {
  341. let arr = tools.copyArr(list);
  342. let showType = this.showTypeFlag ? 'partInfo' : 'all';
  343. let data = showTools.headerTextFilter(arr, 'equipment', this.onlyRead, showType, true);
  344. data.unshift("同时创建资产", "所属系统实例");
  345. if (this.floorFlag) {
  346. data.splice(1, 0, "所属建筑楼层")
  347. }
  348. return data;
  349. },
  350. formatHeaderType(list) {
  351. //格式化表头头映射的数据
  352. let arr = tools.copyArr(list);
  353. let showType = this.showTypeFlag ? 'partInfo' : 'all';
  354. let data = showTools.headerTypeFilter(arr, 'equipment', this.onlyRead, showType, true);
  355. data.unshift({
  356. type: "checkbox",
  357. checkedTemplate: 1,
  358. uncheckedTemplate: 0,
  359. data: "Checked",
  360. label: {
  361. position: "after"
  362. }
  363. }, {
  364. data: "LinkSystem",
  365. renderer: text.systemList,
  366. readOnly: true
  367. });
  368. if (this.floorFlag) {
  369. data.splice(1, 0, {
  370. data: "flowBuild",
  371. renderer: tools.customDropdownRenderer,
  372. editor: "chosen",
  373. chosenOptions: {
  374. // multiple: true,//多选
  375. data: this.buildFloorData
  376. }
  377. })
  378. }
  379. return data;
  380. },
  381. initTable() {
  382. //实例化表格
  383. let settings = {
  384. data: this.tableData,
  385. colHeaders: this.formatHeaderData(this.tableHeader),
  386. columns: this.formatHeaderType(this.tableHeader),
  387. rowHeights: 30,
  388. maxRows: this.tableData.length,
  389. contextMenu: {
  390. items: {
  391. remove_row: {
  392. name: "删除设备"
  393. }
  394. }
  395. },
  396. // 事件
  397. afterChange: this.handleUpdataTable, //修改后
  398. afterFilter: this.trimmedRows, //排序前
  399. afterRemoveRow: this.handleDeleteTableRow, //右键删除
  400. afterOnCellMouseDown: this.handleTdClick //鼠标点击
  401. };
  402. this.$nextTick(() => {
  403. this.tableExample = this.$refs.table.init(settings);
  404. });
  405. },
  406. //去除数组中相同的元素
  407. array_diff(a, b) {
  408. for (var i = 0; i < b.length; i++) {
  409. for (var j = 0; j < a.length; j++) {
  410. if (a[j] == b[i]) {
  411. a.splice(j, 1);
  412. j = j - 1;
  413. }
  414. }
  415. }
  416. return a;
  417. },
  418. //选择型号修改
  419. firmChange(data) {
  420. tools.setDataForKey(this.tableData[this.row], "LedgerParam.EquipManufactor.Brand", data.brand)
  421. tools.setDataForKey(this.tableData[this.row], "LedgerParam.EquipManufactor.Specification", data.name)
  422. tools.setDataForKey(this.tableData[this.row], "DPManufacturerID", data.venderId)
  423. },
  424. supplyChange(data) {
  425. let changeData = { id: data };
  426. this.utilToKey("id", "id", changeData, "SupplierContractID");
  427. },
  428. //如果选择供应商之后
  429. supplierChange(data) {
  430. tools.setDataForKey(this.tableData[this.row], "LedgerParam.SupplyPurchase.Supplier", data.name)
  431. tools.setDataForKey(this.tableData[this.row], "DPSupplierID", data.venderId)
  432. },
  433. //保险合同
  434. guaranteeChange(data) {
  435. for (let key in data) {
  436. this.utilToKey(key, "insuranceNo", data, "InsuranceNum");
  437. if (key == "contractFile") {
  438. if (!!data[key]) {
  439. data[key] = [data[key]];
  440. }
  441. }
  442. this.utilToKey(key, "contractFile", data, "InsuranceFile");
  443. }
  444. },
  445. //上传文件弹窗触发事件
  446. fileChange(keys) {
  447. this.setDataToMain(keys, this.messKey, this.row);
  448. },
  449. //上传图片弹窗触发事件
  450. imgChange(keys) {
  451. this.setDataToMain(keys, this.messKey, this.row);
  452. },
  453. //维修商变更
  454. changeMaintainer(data) {
  455. tools.setDataForKey(this.tableData[this.row], "LedgerParam.OperationMainte.Maintainer", data.name)
  456. tools.setDataForKey(this.tableData[this.row], "DPMaintainerID", data.venderId)
  457. },
  458. //保险商变更
  459. changeInsurer(data) {
  460. tools.setDataForKey(this.tableData[this.row], "LedgerParam.InsuranceDoc.Insurer", data.name)
  461. tools.setDataForKey(this.tableData[this.row], "DPInsurerID", data.venderId)
  462. },
  463. //设备图片弹窗改变事件
  464. changePics(keys) {
  465. this.setDataToMain(keys, this.messKey, this.row);
  466. },
  467. //关联系统变更
  468. changeSystemType(data) {
  469. tools.setDataForKey(this.tableData[this.row], "LinkSystem", data)
  470. },
  471. //表格点击事件
  472. handleTdClick(el, rowArr) {
  473. //点击的是表头
  474. if (rowArr.row < 0) {
  475. return;
  476. }
  477. //被筛选过后的数组
  478. let trimmedArr = this.trimmedRows();
  479. //是否启用了排序
  480. let isSort = this.tableExample.getPlugin("columnSorting").isSorted();
  481. if (trimmedArr.length && isSort) {
  482. let sortArr = this.myHotArr.getPlugin("columnSorting").rowsMapper
  483. .__arrayMap;
  484. let infos = this.tableData[trimmedArr[sortArr[rowArr.row]]];
  485. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  486. } else if (isSort) {
  487. //排序后的数组
  488. let sortArr = this.tableExample.getPlugin("columnSorting").rowsMapper
  489. .__arrayMap;
  490. let infos = this.tableData[sortArr[rowArr.row]];
  491. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  492. } else if (trimmedArr.length) {
  493. let infos = this.tableData[trimmedArr[rowArr.row]];
  494. this.getInfors(infos, { row: trimmedArr[rowArr.row], col: rowArr.col });
  495. } else {
  496. let infos = this.tableData[rowArr.row];
  497. this.getInfors(infos, rowArr);
  498. }
  499. },
  500. //获取被筛选掉的行号
  501. trimmedRows() {
  502. var plugin = this.tableExample.getPlugin("trimRows").trimmedRows;
  503. let dataLength = this.tableData.length;
  504. let dataArr = new Array();
  505. for (let i = 0; i < dataLength; i++) {
  506. dataArr.push(i);
  507. }
  508. if (plugin.length <= 0) {
  509. dataArr = undefined;
  510. } else {
  511. dataArr = this.array_diff(dataArr, plugin);
  512. }
  513. return dataArr || [];
  514. },
  515. getInfors(infos, row) {
  516. let val = this.tableExample.colToProp(row.col);
  517. switch (val) {
  518. //操作
  519. case 'caozuo':
  520. // window.open(`http://adm.sagacloud.cn:8058/spread?id=${infos.EquipID}&pid=${this.projectId}&secret=${this.secret}`,"_blank")
  521. this.$message("开发中...")
  522. break;
  523. //设备二维码图片
  524. case 'EquipQRCode':
  525. this.qrcodeUrl = this.tableData[row.row].EquipQRCode;
  526. if (!!this.qrcodeUrl) {
  527. this.myDialog.qrcode = true;
  528. } else {
  529. this.$message("此设备没有设备二维码");
  530. }
  531. break;
  532. //关联系统
  533. case 'LinkSystem':
  534. if (!this.onlyRead) {
  535. this.systemList = this.tableData[row.row].LinkSystem || [];
  536. this.myDialog.systemType = true;
  537. }
  538. break;
  539. //关联资产
  540. case 'LinkEquipLocalName':
  541. if (this.linkNameFalg) {
  542. this.myDialog.changeRea = true;
  543. }
  544. break;
  545. //品牌型号弹窗
  546. case 'DPManufacturerID':
  547. if (!this.onlyRead) {
  548. this.myDialog.firm = true;
  549. }
  550. break;
  551. //供应商信息弹窗
  552. case 'DPSupplierID':
  553. if (!this.onlyRead) {
  554. this.myDialog.supplier = true;
  555. }
  556. break;
  557. //维修商信息弹窗
  558. case 'DPMaintainerID':
  559. if (!this.onlyRead) {
  560. this.myDialog.maintainer = true;
  561. }
  562. break;
  563. //保险公司信息
  564. case 'DPInsurerID':
  565. if (!this.onlyRead) {
  566. this.myDialog.insurer = true;
  567. }
  568. break;
  569. //供应合同编号
  570. case 'LedgerParam.SupplyPurchase.SupplierContractID':
  571. if (!this.onlyRead) {
  572. let ContractIDflag = null;
  573. let DPSdata = this.tableData[row.row].DPSupplierID;
  574. if (DPSdata) {
  575. ContractIDflag = DPSdata.split("-")[0];
  576. }
  577. if (!!ContractIDflag) {
  578. this.id = ContractIDflag;
  579. this.myDialog.supply = true;
  580. } else {
  581. this.$message("请先选择供应商");
  582. }
  583. }
  584. break;
  585. //保险单号
  586. case 'LedgerParam.InsuranceDoc.InsuranceNum':
  587. if (!this.onlyRead) {
  588. let DPInsurerIDflag = null;
  589. let DPIdata = this.tableData[row.row].DPInsurerID;
  590. if (DPIdata) {
  591. DPInsurerIDflag = DPIdata.split("-")[0];
  592. }
  593. if (!!DPInsurerIDflag) {
  594. this.id = DPInsurerIDflag;
  595. this.myDialog.guarantee = true;
  596. } else {
  597. this.$message("请先选择保险商");
  598. }
  599. }
  600. break;
  601. //保险文件--设备文档--安装质检报告
  602. case 'LedgerParam.InsuranceDoc.InsuranceFile':
  603. case 'LedgerParam.PhotoDoc.Archive':
  604. case 'LedgerParam.Siteinstall.CheckReport':
  605. let IPSdata = tools.dataForKey(this.tableData[row.row], val);
  606. this.filesArr = IPSdata ? IPSdata : [];
  607. this.myDialog.uploadFiles = true;
  608. break;
  609. //安装照片--安装图纸--设备铭牌照片--设备图纸
  610. case 'LedgerParam.Siteinstall.InstallPic':
  611. case 'LedgerParam.Siteinstall.InstallDrawing':
  612. case 'LedgerParam.PhotoDoc.Nameplate':
  613. case 'LedgerParam.PhotoDoc.Drawing':
  614. let SSPPdata = tools.dataForKey(this.tableData[row.row], val);
  615. this.imgsArr = SSPPdata ? SSPPdata : [];
  616. this.myDialog.uploadImgs = true;
  617. break;
  618. //设备照片
  619. case 'LedgerParam.PhotoDoc.Pic':
  620. let Pdata = tools.dataForKey(this.tableData[row.row], val);
  621. this.picsArr = Pdata ? Pdata : [];
  622. this.myDialog.pic = true;
  623. break;
  624. //包含的部件字段
  625. case 'Count':
  626. if (this.onlyRead) {
  627. this.$router.push({ path: '/ledger/parts', query: { deviceId: infos.EquipID } });
  628. } else {
  629. this.$router.push({ path: '/ledger/partsmanage', query: { deviceId: infos.EquipID, typeId: this.mess.deviceId } });
  630. }
  631. break;
  632. default:
  633. break;
  634. }
  635. this.row = row.row;
  636. this.messKey = val;
  637. },
  638. utilToKey(key, name, data, messName) {
  639. if (key == name) {
  640. this.setDataToMain(data[key], messName, this.row);
  641. }
  642. },
  643. //判断是否有值,有值赋值
  644. setDataToMain(data, key, row) {
  645. if (!!data && data != "--") {
  646. if (!!this.tableData[row]) {
  647. //铭牌照片特殊处理
  648. tools.setDataForKey(this.tableData[row], key, data)
  649. // this.tableData[row][key] = data;
  650. } else {
  651. this.tableData[row] = {};
  652. tools.setDataForKey(this.tableData[row], key, data)
  653. }
  654. } else {
  655. tools.setDataForKey(this.tableData[row], key, "")
  656. }
  657. }
  658. }
  659. };
  660. </script>
  661. <style lang="less" scoped>
  662. #deviceList {
  663. overflow: hidden;
  664. height: 100%;
  665. background-color: #fff;
  666. padding: 10px;
  667. position: relative;
  668. .right {
  669. background: #fff;
  670. }
  671. .search-header {
  672. overflow: hidden;
  673. padding: 0 10px 10px 10px;
  674. border-bottom: 1px solid #bcbcbc;
  675. }
  676. .tableBox {
  677. display: flex;
  678. height: calc(100% - 100px);
  679. margin-top: 10px;
  680. .tableLeft {
  681. flex: 1;
  682. }
  683. }
  684. .create_button {
  685. margin-top: 10px;
  686. }
  687. }
  688. </style>