addproperty.vue 17 KB

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