index.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601
  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. PageNumber: 1,
  162. PageSize: 500
  163. },
  164. type: this.category.Code
  165. // Filters: `type='Equipment' or type='${this.category.Code}'`
  166. };
  167. await getDataDictionary(params, res => {
  168. this.tableHeader = res.Content;
  169. this.initTable();
  170. });
  171. },
  172. // 创建部件数据
  173. async handleCreateTableData() {
  174. let newData = this.tableData.filter(item => {
  175. let keys = Object.keys(item);
  176. keys.map(key => {
  177. //将值为空字符串的属性删除
  178. if (item[key] == "") {
  179. delete item[key];
  180. }
  181. });
  182. let newK = Object.keys(item)
  183. if ((item.Checked && newK.length > 1) || (!item.Checked && newK.length)) {
  184. return item;
  185. }
  186. });
  187. if (!newData.length) {
  188. this.$message("创建信息为空,请录入信息后再创建!");
  189. return;
  190. }
  191. let flag = false;
  192. newData.map(item => {
  193. if (item.Checked && !item.EquipLocalName) {
  194. flag = true;
  195. }
  196. })
  197. if (flag) {
  198. this.$message.info("存在设备的本地名称为空,请检查")
  199. return;
  200. }
  201. for (let i = 0; i < newData.length; i++) {
  202. newData[i].ParentId = this.category.deviceId //当前设备id
  203. newData[i].Category = this.category.Code //当前部件分类
  204. newData[i].Family = this.firmId;
  205. //待接口修改为关联创建
  206. let param = {
  207. Cascade:[],
  208. Content:[newData[i]]
  209. }
  210. await createPart(param, async res => {
  211. if (newData[i].Checked) {//同时创建资产
  212. param.Content[0].EquipmentId = res.EntityList[0].EquipID
  213. await createPropertyData(param, res => { })
  214. }
  215. if (i == newData.length - 1) {
  216. this.$message.success('创建成功')
  217. session.remove("partsAddData")
  218. this.$router.push({
  219. path: "/ledger/partsmanage",
  220. query: {
  221. deviceId: this.category.deviceId,
  222. typeId: this.category.ParentId
  223. }
  224. });
  225. }
  226. })
  227. // if (newData[i].Checked) {//同时创建资产
  228. // await createPropertyData([params], async res => {
  229. // params.PropertyId = res.Id
  230. // })
  231. // }
  232. // else {
  233. // await createPart(params, res => {
  234. // if (i == newData.length - 1) {
  235. // this.$router.push({
  236. // path: "/ledger/partsmanage",
  237. // query: {
  238. // deviceId: this.category.deviceId,
  239. // typeId: this.category.ParentId
  240. // }
  241. // });
  242. // session.remove("partsAddData")
  243. // }
  244. // });
  245. // }
  246. }
  247. },
  248. // 删除表格行
  249. handleDeleteTableRow() {
  250. this.$message.success("删除成功");
  251. this.formaTableData();
  252. },
  253. // 添加行
  254. handleAddTableRow() {
  255. let addRowLength = this.addNum;
  256. for (let i = 0; i < addRowLength; i++) {
  257. this.tableData.push({ Checked: 1 });
  258. }
  259. this.initTable();
  260. this.formaTableData();
  261. },
  262. //修改
  263. handleUpdataTable(changeData, source) {
  264. this.formaTableData();
  265. },
  266. //保存去掉空字段的新增数据
  267. formaTableData() {
  268. let newData = this.tableData.filter(item => {
  269. let keys = Object.keys(item);
  270. keys.map(key => {
  271. //将值为空字符串的属性删除
  272. if (item[key] == "") {
  273. delete item[key];
  274. }
  275. });
  276. if (keys.length && Object.keys(item).length) {
  277. return item;
  278. }
  279. });
  280. session.set("partsAddData", newData);
  281. },
  282. //格式化表头显示的数据
  283. formatHeaderData(list) {
  284. let arr = tools.copyArr(list)
  285. let data = showTools.headerTextFilter(arr, "parts", this.onlyRead, this.showType, true)
  286. data.unshift("同时创建资产")
  287. return data
  288. },
  289. formatHeaderType(list) {
  290. //格式化表头头映射的数据
  291. let arr = tools.copyArr(list);
  292. let data = showTools.headerTypeFilter(arr, "parts", this.onlyRead, this.showType, true)
  293. data.unshift({
  294. type: "checkbox",
  295. checkedTemplate: 1,
  296. uncheckedTemplate: 0,
  297. data: "Checked",
  298. label: {
  299. position: "after"
  300. }
  301. });
  302. return data;
  303. },
  304. initTable() {
  305. //实例化表格
  306. let settings = {
  307. data: this.tableData,
  308. colHeaders: this.formatHeaderData(this.tableHeader),
  309. columns: this.formatHeaderType(this.tableHeader),
  310. rowHeights: 30,
  311. maxRows: this.tableData.length,
  312. contextMenu: {
  313. items: {
  314. remove_row: {
  315. name: "删除部件"
  316. }
  317. }
  318. },
  319. // 事件
  320. afterChange: this.handleUpdataTable, //修改后
  321. afterFilter: this.trimmedRows, //排序前
  322. afterRemoveRow: this.handleDeleteTableRow, //右键删除
  323. afterOnCellMouseDown: this.handleTdClick //鼠标点击
  324. };
  325. this.$nextTick(() => {
  326. this.tableExample = this.$refs.table.init(settings);
  327. });
  328. },
  329. //去除数组中相同的元素
  330. array_diff(a, b) {
  331. for (var i = 0; i < b.length; i++) {
  332. for (var j = 0; j < a.length; j++) {
  333. if (a[j] == b[i]) {
  334. a.splice(j, 1);
  335. j = j - 1;
  336. }
  337. }
  338. }
  339. return a;
  340. },
  341. //选择型号修改
  342. firmChange(data) {
  343. tools.setDataForKey(this.tableData[this.row], "LedgerParam.EquipManufactor.Brand", data.brand)
  344. tools.setDataForKey(this.tableData[this.row], "LedgerParam.EquipManufactor.Specification", data.name)
  345. tools.setDataForKey(this.tableData[this.row], "DPManufacturerID", data.venderId)
  346. },
  347. //供应商变更
  348. supplierChange(data) {
  349. tools.setDataForKey(this.tableData[this.row], "LedgerParam.SupplyPurchase.Supplier", data.name)
  350. tools.setDataForKey(this.tableData[this.row], "DPSupplierID", data.venderId)
  351. },
  352. //保险商变更
  353. changeInsurer(data) {
  354. tools.setDataForKey(this.tableData[this.row], "LedgerParam.InsuranceDoc.Insurer", data.name)
  355. tools.setDataForKey(this.tableData[this.row], "DPInsurerID", data.venderId)
  356. },
  357. //维修商变更
  358. changeMaintainer(data) {
  359. tools.setDataForKey(this.tableData[this.row], "LedgerParam.OperationMainte.Maintainer", data.name)
  360. tools.setDataForKey(this.tableData[this.row], "DPMaintainerID", data.venderId)
  361. },
  362. supplyChange(data) {
  363. let changeData = { id: data };
  364. this.utilToKey("id", "id", changeData, "SupplierContractID");
  365. },
  366. //保险合同
  367. guaranteeChange(data) {
  368. for (let key in data) {
  369. this.utilToKey(key, "insuranceNo", data, "InsuranceNum");
  370. if (key == "contractFile") {
  371. if (!!data[key]) {
  372. data[key] = [data[key]];
  373. }
  374. }
  375. this.utilToKey(key, "contractFile", data, "InsuranceFile");
  376. }
  377. },
  378. //上传文件弹窗触发事件
  379. fileChange(keys) {
  380. this.setDataToMain(keys, this.messKey, this.row);
  381. },
  382. //上传图片弹窗触发事件
  383. imgChange(keys) {
  384. this.setDataToMain(keys, this.messKey, this.row);
  385. },
  386. //设备图片弹窗改变事件
  387. changePics(keys) {
  388. this.setDataToMain(keys, this.messKey, this.row);
  389. },
  390. //表格点击事件
  391. handleTdClick(el, rowArr) {
  392. //点击的是表头
  393. if (rowArr.row < 0) {
  394. return;
  395. }
  396. //被筛选过后的数组
  397. let trimmedArr = this.trimmedRows();
  398. //是否启用了排序
  399. let isSort = this.tableExample.getPlugin("columnSorting").isSorted();
  400. if (trimmedArr.length && isSort) {
  401. let sortArr = this.myHotArr.getPlugin("columnSorting").rowsMapper
  402. .__arrayMap;
  403. let infos = this.tableData[trimmedArr[sortArr[rowArr.row]]];
  404. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  405. } else if (isSort) {
  406. //排序后的数组
  407. let sortArr = this.tableExample.getPlugin("columnSorting").rowsMapper
  408. .__arrayMap;
  409. let infos = this.tableData[sortArr[rowArr.row]];
  410. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  411. } else if (trimmedArr.length) {
  412. let infos = this.tableData[trimmedArr[rowArr.row]];
  413. this.getInfors(infos, { row: trimmedArr[rowArr.row], col: rowArr.col });
  414. } else {
  415. let infos = this.tableData[rowArr.row];
  416. this.getInfors(infos, rowArr);
  417. }
  418. },
  419. //获取被筛选掉的行号
  420. trimmedRows() {
  421. var plugin = this.tableExample.getPlugin("trimRows").trimmedRows;
  422. let dataLength = this.tableData.length;
  423. let dataArr = new Array();
  424. for (let i = 0; i < dataLength; i++) {
  425. dataArr.push(i);
  426. }
  427. if (plugin.length <= 0) {
  428. dataArr = undefined;
  429. } else {
  430. dataArr = this.array_diff(dataArr, plugin);
  431. }
  432. return dataArr || [];
  433. },
  434. getInfors(infos, row) {
  435. //其他的开始判断
  436. let val = this.tableExample.colToProp(row.col);
  437. //设备二维码图片
  438. if (val == "EquipQRCode") {
  439. this.myDialog.qrcode = true;
  440. this.$refs.qrcode.getCanvas(1111);
  441. }
  442. //关联系统
  443. if (val == "linkSystem") {
  444. // this.systemList = this.tableData[row.row].linkSystem || [];
  445. this.myDialog.systemType = true;
  446. }
  447. //品牌型号弹窗
  448. if (val == "DPManufacturerID") {
  449. this.myDialog.firm = true;
  450. }
  451. //供应商信息弹窗
  452. if (val == "DPSupplierID") {
  453. this.myDialog.supplier = true;
  454. }
  455. //维修商信息弹窗
  456. if (val == "DPMaintainerID") {
  457. this.myDialog.maintainer = true;
  458. }
  459. //保险公司信息
  460. if (val == "DPInsurerID") {
  461. this.myDialog.insurer = true;
  462. }
  463. //供应合同编号
  464. if (val == "LedgerParam.SupplyPurchase.SupplierContractID") {
  465. let falg = null;
  466. let data = this.tableData[row.row].DPSupplierID;
  467. if (data) {
  468. falg = data.split("-")[0];
  469. }
  470. if (!!falg) {
  471. this.id = falg;
  472. this.myDialog.supply = true;
  473. } else {
  474. this.$message("请先选择供应商");
  475. }
  476. }
  477. //保险单号
  478. if (val == "LedgerParam.InsuranceDoc.InsuranceNum") {
  479. //选择保单
  480. let falg = null;
  481. let data = this.tableData[row.row].DPInsurerID
  482. if (data) {
  483. falg = data.split("-")[0];
  484. }
  485. if (!!falg) {
  486. this.id = falg;
  487. this.myDialog.guarantee = true;
  488. } else {
  489. this.$message("请先选择保险商");
  490. }
  491. }
  492. //保险文件--设备文档--安装质检报告
  493. if (
  494. val == "LedgerParam.InsuranceDoc.InsuranceFile" ||
  495. val == "LedgerParam.PhotoDoc.Archive" ||
  496. val == "LedgerParam.Siteinstall.CheckReport"
  497. ) {
  498. let data = tools.dataForKey(this.tableData[row.row], val)
  499. this.filesArr = data ? data : []
  500. // this.filesArr = this.tableData[row.row].infos
  501. // ? this.tableData[row.row].infos[val.split(".")[1]]
  502. // ? [this.tableData[row.row].infos[val.split(".")[1]]]
  503. // : []
  504. // : [];
  505. this.myDialog.uploadFiles = true;
  506. }
  507. //安装照片--安装图纸--设备铭牌照片--设备图纸
  508. if (
  509. val == "LedgerParam.Siteinstall.InstallPic" ||
  510. val == "LedgerParam.Siteinstall.InstallDrawing" ||
  511. val == "LedgerParam.PhotoDoc.Nameplate" ||
  512. val == "LedgerParam.PhotoDoc.Drawing"
  513. ) {
  514. let data = tools.dataForKey(this.tableData[row.row], val)
  515. this.imgsArr = data ? data : []
  516. // if (val == "LedgerParam.PhotoDoc.Nameplate") {
  517. // this.imgsArr = this.tableData[row.row].infos
  518. // ? this.tableData[row.row].infos[val.split(".")[1]]
  519. // ? [this.tableData[row.row].infos[val.split(".")[1]].key]
  520. // : []
  521. // : [];
  522. // } else {
  523. // this.imgsArr = this.tableData[row.row].infos
  524. // ? this.tableData[row.row].infos[val.split(".")[1]]
  525. // ? [this.tableData[row.row].infos[val.split(".")[1]]]
  526. // : []
  527. // : [];
  528. // }
  529. this.myDialog.uploadImgs = true;
  530. }
  531. //设备照片
  532. if (val == "LedgerParam.PhotoDoc.Pic") {
  533. let data = tools.dataForKey(this.tableData[row.row], val)
  534. this.picsArr = data ? data : []
  535. // this.picsArr = this.tableData[row.row].infos
  536. // ? this.tableData[row.row].infos[val.split(".")[1]]
  537. // ? this.tableData[row.row].infos[val.split(".")[1]]
  538. // : []
  539. // : [];
  540. this.myDialog.pic = true;
  541. }
  542. this.row = row.row;
  543. this.messKey = val;
  544. },
  545. utilToKey(key, name, data, messName) {
  546. if (key == name) {
  547. this.setDataToMain(data[key], messName, this.row);
  548. }
  549. },
  550. //判断是否有值,有值赋值
  551. setDataToMain(data, key, row) {
  552. if (!!data && data != "--") {
  553. if (!!this.tableData[row]) {
  554. //铭牌照片特殊处理
  555. tools.setDataForKey(this.tableData[row], key, data)
  556. // this.tableData[row][key] = data;
  557. } else {
  558. this.tableData[row] = {};
  559. tools.setDataForKey(this.tableData[row], key, data)
  560. }
  561. } else {
  562. tools.setDataForKey(this.tableData[row], key, "")
  563. }
  564. }
  565. }
  566. };
  567. </script>
  568. <style lang="less" scoped>
  569. #deviceList {
  570. overflow: hidden;
  571. height: 100%;
  572. background-color: #fff;
  573. padding: 10px;
  574. position: relative;
  575. .right {
  576. background: #fff;
  577. }
  578. .search-header {
  579. overflow: hidden;
  580. padding: 0 10px 10px 10px;
  581. border-bottom: 1px solid #bcbcbc;
  582. }
  583. .tableBox {
  584. display: flex;
  585. height: calc(100% - 100px);
  586. margin-top: 10px;
  587. .tableLeft {
  588. flex: 1;
  589. }
  590. }
  591. .create_button {
  592. margin-top: 10px;
  593. }
  594. }
  595. </style>