index.vue 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596
  1. <template>
  2. <div id="deviceList">
  3. <el-row class="right">
  4. <span style="float: left">当前选择的分区类型:{{ space.spaceName }}</span>
  5. <el-select
  6. v-model="showType"
  7. @change="initTable"
  8. style="width: 140px; margin-right: 10px; vertical-align: bottom"
  9. >
  10. <el-option
  11. v-for="item in showTypes"
  12. :key="item.value"
  13. :label="item.label"
  14. :value="item.value"
  15. ></el-option>
  16. </el-select>
  17. <span>增加</span>
  18. <el-input-number
  19. v-model="addNum"
  20. :controls="false"
  21. style="width: 50px"
  22. :min="1"
  23. :max="50"
  24. ></el-input-number>
  25. <span>个{{ space.spaceName }}</span>
  26. <el-button @click="handleAddTableRow">增加</el-button>
  27. </el-row>
  28. <div class="tableBox">
  29. <div
  30. class="center middle_sty"
  31. style="flex: 2"
  32. v-show="tableData && !tableData.length"
  33. >
  34. <p>
  35. <i class="icon-wushuju iconfont"></i>
  36. 暂无数据
  37. </p>
  38. </div>
  39. <div class="tableLeft" v-show="tableData && tableData.length">
  40. <handson-table ref="table"></handson-table>
  41. </div>
  42. </div>
  43. <el-row class="center">
  44. <el-button
  45. type="primary"
  46. size="medium"
  47. @click="handleCreateTableData"
  48. :disabled="createDisable"
  49. class="create_button"
  50. >创建业务空间</el-button
  51. >
  52. </el-row>
  53. <!--二维码弹窗 -->
  54. <qrcode
  55. :dialog="myDialog"
  56. :qrcodeUrl="qrcodeUrl"
  57. :addBody="true"
  58. ref="qrcode"
  59. ></qrcode>
  60. <!--上传图片-->
  61. <upload-img-dialog
  62. :read="false"
  63. @changeFile="imgChange"
  64. :keysArr="imgsArr"
  65. :dialog="myDialog"
  66. />
  67. <!-- 多选枚举类型维护 -->
  68. <menum
  69. :dialog="myDialog"
  70. :updateInfoData="updateInfoData"
  71. :updateInput="updateInput"
  72. @change="handleChangeMenum"
  73. ></menum>
  74. <!-- 不支持的输入方式 -->
  75. <el-dialog
  76. title="临时维护信息点"
  77. :visible.sync="myDialog.update"
  78. @close="handleCloseUpdate"
  79. width="670px"
  80. >
  81. <el-row>
  82. 该信息点未定义对应组件,现在维护数据不确定后续是否可用。如确实需要维护,请点击
  83. <el-link
  84. @click="updateInputShow = true"
  85. type="primary"
  86. :underline="false"
  87. >继续维护</el-link
  88. >
  89. </el-row>
  90. <el-row style="margin-top: 20px" v-show="updateInputShow">
  91. <el-input
  92. type="textarea"
  93. :autosize="{ minRows: 4, maxRows: 8 }"
  94. placeholder="请输入内容"
  95. v-model="updateInput"
  96. ></el-input>
  97. </el-row>
  98. <span slot="footer" class="dialog-footer">
  99. <el-button @click="myDialog.update = false">取 消</el-button>
  100. <el-button type="primary" @click="handleClickUpdate">确 认</el-button>
  101. </span>
  102. </el-dialog>
  103. </div>
  104. </template>
  105. <script>
  106. import tools from "@/utils/old-adm/scan/tools";
  107. import showTools from "@/utils/old-adm/handsontable/notShow";
  108. import session from "@/utils/storageUtil";
  109. import buildFloor from "@/utils/old-adm/handsontable/buildFloorData";
  110. import handsonTable from "@/components/old-adm/common/handsontable";
  111. import menum from "@/components/old-adm/dialogs/list/menum";
  112. import {logicConfig} from "@/logicConfig";
  113. import ScanController from "@/controller/old-adm/ScanController";
  114. import Dic from "@/controller/old-adm/dicController";
  115. import { mapGetters } from "vuex";
  116. import qrcode from "@/components/old-adm/ledger/components/lib/qrcode";
  117. import uploadImgDialog from "@/components/old-adm/dialogs/list/uploadImgDialog";
  118. export default {
  119. components: {
  120. qrcode, //二维码页面
  121. uploadImgDialog,
  122. handsonTable,
  123. menum,
  124. },
  125. data() {
  126. return {
  127. addNum: 1,
  128. onlyRead: false,
  129. showTypes: [
  130. { value: "Visible", label: "只看需交付的" },
  131. { value: "all", label: "全部" },
  132. ],
  133. tableHeader: [],
  134. tableData: session.get("spaceAddData")
  135. ? session.get("spaceAddData").length
  136. ? session.get("spaceAddData")
  137. : [{}]
  138. : [{}],
  139. copyTableData: [],
  140. category: {}, //路由参数
  141. myDialog: {
  142. qrcode: false, //二维码弹窗
  143. uploadImgs: false, //上传单个图片
  144. update: false, //临时维护信息点
  145. menum: false, //临时多选枚举类型信息点
  146. },
  147. inputMap: {
  148. flowBuild: {
  149. editable: true,
  150. code: "flowBuild",
  151. name: "建筑楼层",
  152. path: "flowBuild",
  153. category: "STATIC",
  154. dataType: "ENUM",
  155. },
  156. }, //信息点和输入方式映射表
  157. updateInputShow: false, //是否显示临时维护输入框
  158. updateInfoData: {}, //当前信息点信息
  159. updateInfoPoint: "", //临时维护信息点
  160. updateInput: "", //临时维护信息点值
  161. qrcodeUrl: "", //二维码图片地址
  162. imgsArr: [], //临时保存的图片key数组
  163. showType: this.$route.query.showType,
  164. buildFloorData: [],
  165. createDisable: false,
  166. };
  167. },
  168. computed: {
  169. ...mapGetters("layout", ["projectId", "secret", "userId"]),
  170. flowBuild() {
  171. let buildFloorSelectd = this.space.buildFloorSelectd;
  172. if (buildFloorSelectd && buildFloorSelectd.length == 0) {
  173. return "";
  174. } else if (buildFloorSelectd && buildFloorSelectd.length == 1) {
  175. let build = buildFloorSelectd[0];
  176. if (build == "all" || build == "noKnow") {
  177. return "";
  178. } else {
  179. return build;
  180. }
  181. } else if (buildFloorSelectd && buildFloorSelectd.length == 2) {
  182. let build = buildFloorSelectd[0],
  183. floor = buildFloorSelectd[1];
  184. if (build && (floor == "all" || floor == "noKnow")) {
  185. return build;
  186. } else {
  187. return `${build}-${floor}`;
  188. }
  189. }
  190. },
  191. },
  192. created() {
  193. this.space = this.$route.query;
  194. buildFloor.getData(this.buildFloorData);
  195. this.getTableHeader();
  196. },
  197. methods: {
  198. // 获取表头数据(初始化表格)
  199. async getTableHeader() {
  200. let params = {
  201. orders: "sort asc, name desc",
  202. pageNumber: 1,
  203. pageSize: 1000,
  204. type: this.space.spaceType,
  205. };
  206. Dic.getDataDictionary(params, (res) => {
  207. this.tableHeader = res.content;
  208. this.tableHeader.forEach((item) => {
  209. if (item.path) {
  210. this.inputMap[item.path] = item;
  211. }
  212. });
  213. this.tableData[0].flowBuild = this.flowBuild;
  214. this.initTable();
  215. });
  216. },
  217. // 创建业务空间数据
  218. async handleCreateTableData() {
  219. let newData = this.tableData.filter((item) => {
  220. let keys = Object.keys(item);
  221. keys.map((key) => {
  222. //将值为空字符串的属性删除
  223. if (item[key] == "") {
  224. delete item[key];
  225. }
  226. });
  227. let newK = Object.keys(item);
  228. if (newK.length) {
  229. return item;
  230. }
  231. });
  232. if (!newData.length) {
  233. this.$message("创建信息为空,请录入信息后再创建!");
  234. return;
  235. }
  236. let flag = false;
  237. newData.map((item) => {
  238. if (!item.localName) {
  239. flag = true;
  240. }
  241. // 处理建筑-楼层
  242. if (item.flowBuild) {
  243. let bid = item.flowBuild.split("-");
  244. if (bid[0] && bid[0] != "all" && bid[0] != "noKnow") {
  245. item.buildingId = item.flowBuild.split("-")[0];
  246. if (bid[1]) {
  247. if (bid[1] != "noKnow" && bid[1] != "all") {
  248. item.floorId = item.flowBuild.split("-")[1];
  249. }
  250. }
  251. }
  252. }
  253. item.classCode = this.space.spaceType;
  254. });
  255. if (flag) {
  256. this.$message.info("存在业务空间的本地名称为空,请检查");
  257. return;
  258. }
  259. //待接口修改为关联创建即可修改
  260. let param = {
  261. content: newData,
  262. };
  263. this.createDisable = true;
  264. ScanController.zoneCreate(param, (res) => {
  265. this.createDisable = false;
  266. switch (res.result) {
  267. case logicConfig.resultObj.success:
  268. this.$message.success("创建成功");
  269. session.remove("spaceAddData");
  270. this.$router.push({
  271. // name: "spacelist",
  272. path: "/ledger/spacelist",
  273. params: {
  274. zone: this.space.otherType
  275. ? this.space.otherType
  276. : this.space.spaceType,
  277. buildFloorSelectd: ["all"],
  278. isMyTab: "2",
  279. otherType: this.space.otherType ? this.space.spaceType : "",
  280. },
  281. });
  282. break;
  283. default:
  284. this.$message.error("创建失败");
  285. break;
  286. }
  287. });
  288. },
  289. // 删除表格行
  290. handleDeleteTableRow(a, b, c, d) {
  291. if (d && d === "ContextMenu.removeRow") {
  292. this.$message.success("删除成功");
  293. this.formaTableData();
  294. }
  295. },
  296. // 添加行
  297. handleAddTableRow() {
  298. let addRowLength = this.addNum;
  299. for (let i = 0; i < addRowLength; i++) {
  300. this.tableData.push({ flowBuild: this.flowBuild });
  301. }
  302. this.initTable();
  303. this.formaTableData();
  304. },
  305. //修改
  306. handleUpdataTable(changeData, source) {
  307. if (!this.onlyRead && source != "ObserveChanges.change") {
  308. this.formaTableData();
  309. }
  310. },
  311. //保存去掉空字段的新增数据
  312. formaTableData() {
  313. let newData = this.tableData.filter((item) => {
  314. let keys = Object.keys(item);
  315. keys.map((key) => {
  316. //将值为空字符串的属性删除
  317. if (item[key] == "") {
  318. delete item[key];
  319. }
  320. });
  321. if (keys.length && Object.keys(item).length) {
  322. return item;
  323. }
  324. });
  325. session.set("spaceAddData", newData);
  326. },
  327. //格式化表头显示的数据
  328. formatHeaderData(list) {
  329. let arr = tools.copyArr(list);
  330. let data = showTools.headerTextFilter(
  331. arr,
  332. "space",
  333. this.onlyRead,
  334. this.showType,
  335. true
  336. );
  337. data.unshift("所属建筑楼层");
  338. return data;
  339. },
  340. formatHeaderType(list) {
  341. //格式化表头头映射的数据
  342. let arr = tools.copyArr(list);
  343. let data = showTools.headerTypeFilter(
  344. arr,
  345. "space",
  346. this.onlyRead,
  347. this.showType,
  348. true
  349. );
  350. data.unshift({
  351. data: "flowBuild",
  352. renderer: tools.customDropdownRenderer,
  353. editor: "chosen",
  354. chosenOptions: {
  355. data: this.buildFloorData,
  356. },
  357. });
  358. return data;
  359. },
  360. initTable() {
  361. //实例化表格
  362. let settings = {
  363. data: this.tableData,
  364. colHeaders: this.formatHeaderData(this.tableHeader),
  365. columns: this.formatHeaderType(this.tableHeader),
  366. rowHeights: 30,
  367. fillHandle: "vertical", //允许纵向填充
  368. maxRows: this.tableData.length,
  369. contextMenu: this.onlyRead
  370. ? false
  371. : {
  372. items: {
  373. remove_row: {
  374. name: "删除业务空间",
  375. },
  376. },
  377. },
  378. // 事件
  379. afterChange: this.handleUpdataTable, //修改后
  380. afterFilter: this.trimmedRows, //排序前
  381. afterRemoveRow: this.handleDeleteTableRow, //右键删除
  382. afterOnCellMouseDown: this.handleTdClick, //鼠标点击
  383. };
  384. this.$nextTick(() => {
  385. this.tableExample = this.$refs.table.init(settings);
  386. });
  387. },
  388. //去除数组中相同的元素
  389. array_diff(a, b) {
  390. for (var i = 0; i < b.length; i++) {
  391. for (var j = 0; j < a.length; j++) {
  392. if (a[j] == b[i]) {
  393. a.splice(j, 1);
  394. j = j - 1;
  395. }
  396. }
  397. }
  398. return a;
  399. },
  400. //表格点击事件
  401. handleTdClick(el, rowArr) {
  402. //点击的是表头
  403. if (rowArr.row < 0) {
  404. return;
  405. }
  406. //被筛选过后的数组
  407. let trimmedArr = this.trimmedRows();
  408. //是否启用了排序
  409. let isSort = this.tableExample.getPlugin("columnSorting").isSorted();
  410. if (trimmedArr.length && isSort) {
  411. let sortArr =
  412. this.myHotArr.getPlugin("columnSorting").rowsMapper.__arrayMap;
  413. let infos = this.tableData[trimmedArr[sortArr[rowArr.row]]];
  414. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  415. } else if (isSort) {
  416. //排序后的数组
  417. let sortArr =
  418. this.tableExample.getPlugin("columnSorting").rowsMapper.__arrayMap;
  419. let infos = this.tableData[sortArr[rowArr.row]];
  420. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  421. } else if (trimmedArr.length) {
  422. let infos = this.tableData[trimmedArr[rowArr.row]];
  423. this.getInfors(infos, { row: trimmedArr[rowArr.row], col: rowArr.col });
  424. } else {
  425. let infos = this.tableData[rowArr.row];
  426. this.getInfors(infos, rowArr);
  427. }
  428. },
  429. //获取被筛选掉的行号
  430. trimmedRows() {
  431. var plugin = this.tableExample.getPlugin("trimRows").trimmedRows;
  432. let dataLength = this.tableData.length;
  433. let dataArr = new Array();
  434. for (let i = 0; i < dataLength; i++) {
  435. dataArr.push(i);
  436. }
  437. if (plugin.length <= 0) {
  438. dataArr = undefined;
  439. } else {
  440. dataArr = this.array_diff(dataArr, plugin);
  441. }
  442. return dataArr || [];
  443. },
  444. getInfors(infos, row) {
  445. let val = this.tableExample.colToProp(row.col);
  446. this.row = row.row;
  447. this.messKey = val;
  448. let inputData = this.inputMap[val];
  449. switch (val) {
  450. //空间二维码图片
  451. case "qRCodePicgg":
  452. this.qrcodeUrl = this.tableData[row.row].qRCodePic;
  453. if (!!this.qrcodeUrl) {
  454. this.myDialog.qrcode = true;
  455. } else {
  456. this.$message("此空间没有二维码");
  457. }
  458. break;
  459. case "pic":
  460. let Pdata = tools.dataForKey(this.tableData[row.row], val);
  461. this.imgsArr = Pdata ? Pdata : [];
  462. this.myDialog.uploadImgs = true;
  463. break;
  464. default:
  465. break;
  466. }
  467. // 维护多选枚举值
  468. if (!this.onlyRead && inputData.dataType == "MENUM") {
  469. this.updateInfoData = inputData;
  470. this.updateInfoPoint = val;
  471. this.updateInput = tools.dataForKey(this.tableData[row.row], val);
  472. this.myDialog.menum = true;
  473. return false;
  474. }
  475. if (!this.onlyRead && !inputData.editable) {
  476. this.$confirm("该信息点的值为自动生成,不可人工维护!", "提示", {
  477. confirmButtonText: "我知道了",
  478. showCancelButton: false,
  479. type: "warning",
  480. center: true,
  481. }).then(() => {
  482. return false;
  483. });
  484. }
  485. if (
  486. !this.onlyRead &&
  487. showTools.inputModeArr.indexOf(inputData.dataType) == "-1"
  488. ) {
  489. this.updateInfoPoint = val;
  490. this.updateInput = tools.dataForKey(this.tableData[row.row], val);
  491. this.myDialog.update = true;
  492. return false;
  493. }
  494. },
  495. //关闭临时维护弹窗回调
  496. handleCloseUpdate() {
  497. this.updateInputShow = false;
  498. this.updateInfoPoint = "";
  499. this.updateInput = "";
  500. },
  501. //更新临时维护信息点
  502. handleClickUpdate() {
  503. tools.setDataForKey(
  504. this.tableData[this.row],
  505. this.updateInfoPoint,
  506. this.updateInput
  507. );
  508. this.handleUpdataTable(
  509. [[this.row, this.updateInfoPoint, null, this.updateInput]],
  510. "edit"
  511. );
  512. this.updateInputShow = false;
  513. this.myDialog.update = false;
  514. this.updateInput = "";
  515. },
  516. //多选枚举类型值修改
  517. handleChangeMenum(newValue) {
  518. tools.setDataForKey(
  519. this.tableData[this.row],
  520. this.updateInfoPoint,
  521. newValue
  522. );
  523. this.handleUpdataTable(
  524. [[this.row, this.updateInfoPoint, null, newValue]],
  525. "edit"
  526. );
  527. this.myDialog.menum = false;
  528. this.updateInput = "";
  529. },
  530. utilToKey(key, name, data, messName) {
  531. if (key == name) {
  532. this.setDataToMain(data[key], messName, this.row);
  533. }
  534. },
  535. //上传图片弹窗触发事件
  536. imgChange(keys) {
  537. this.setDataToMain(keys, "pic", this.row);
  538. },
  539. //判断是否有值,有值赋值
  540. setDataToMain(data, key, row) {
  541. if (!!data && data != "--") {
  542. if (!!this.tableData[row]) {
  543. //铭牌照片特殊处理
  544. tools.setDataForKey(this.tableData[row], key, data);
  545. // this.tableData[row][key] = data;
  546. } else {
  547. this.tableData[row] = {};
  548. tools.setDataForKey(this.tableData[row], key, data);
  549. }
  550. } else {
  551. tools.setDataForKey(this.tableData[row], key, "");
  552. }
  553. },
  554. },
  555. };
  556. </script>
  557. <style lang="less" scoped>
  558. #deviceList {
  559. overflow: hidden;
  560. height: 100%;
  561. background-color: #fff;
  562. padding: 10px;
  563. position: relative;
  564. .right {
  565. background: #fff;
  566. }
  567. .search-header {
  568. overflow: hidden;
  569. padding: 0 10px 10px 10px;
  570. border-bottom: 1px solid #bcbcbc;
  571. }
  572. .tableBox {
  573. display: flex;
  574. height: calc(100% - 100px);
  575. margin-top: 10px;
  576. .tableLeft {
  577. flex: 1;
  578. }
  579. }
  580. .create_button {
  581. margin-top: 10px;
  582. }
  583. }
  584. </style>