index.vue 20 KB

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