addfacility.vue 22 KB

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