addproperty.vue 21 KB

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