addfacility.vue 24 KB

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