addfacility.vue 24 KB

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