index.vue 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307
  1. <template>
  2. <div id="deviceList">
  3. <el-row class="right">
  4. <!-- <span style="float:left;">当前选择的部件类型:{{page.total || '--'}}</span> -->
  5. <span>增加</span>
  6. <el-input v-model="addNum" style="width:40px;" size="small"></el-input>
  7. <span>个租户</span>
  8. <el-button @click="handleAddTableRow">增加</el-button>
  9. </el-row>
  10. <div class="tableBox">
  11. <div class="center middle_sty" style="flex:2;" v-show="tableData && !tableData.length">
  12. <p>
  13. <i class="icon-wushuju iconfont"></i>
  14. 暂无数据
  15. </p>
  16. </div>
  17. <div class="tableLeft" v-show="tableData && tableData.length">
  18. <handson-table ref="table"></handson-table>
  19. </div>
  20. </div>
  21. <el-row class="center create_button">
  22. <el-button type="primary" size="medium" @click="handleCreateTableData">创建租户</el-button>
  23. </el-row>
  24. </div>
  25. </template>
  26. <script>
  27. import tools from "@/utils/scan/tools"
  28. import handsonUtils from "@/utils/hasontableUtils"
  29. import showTools from "@/utils/handsontable/notShow"
  30. import text from "@/utils/handsontable/mainText"
  31. import session from "@/framework/utils/storage"
  32. import handsonTable from "@/components/common/handsontable"
  33. import { getDataDictionary, getRentTableHeader, createRentTableData } from "@/api/scan/request"
  34. import { mapGetters, mapActions } from "vuex";
  35. export default {
  36. components: {
  37. handsonTable
  38. },
  39. data() {
  40. return {
  41. addNum: 1,
  42. isTableRightShow: false,
  43. relationids: "",
  44. onlyRead: false,
  45. showType: "all",
  46. tableHeader: [],
  47. tableData: session.get("rentAddData")? session.get("rentAddData").length? session.get("rentAddData"): [{}]: [{}],
  48. copyTableData: []
  49. };
  50. },
  51. computed: {
  52. ...mapGetters("layout", [
  53. "projectId",
  54. "secret",
  55. "userId"
  56. ])
  57. },
  58. created() {
  59. this.getTableHeader()
  60. },
  61. // watch: {
  62. // },
  63. methods: {
  64. // 获取表头数据(初始化表格)
  65. async getTableHeader() {
  66. let param = {
  67. data: {
  68. PageNumber: 1,
  69. PageSize: 500,
  70. },
  71. type: 'Tenant'
  72. }
  73. await getDataDictionary(param, res => {
  74. this.tableHeader = res.Content
  75. this.initTable()
  76. })
  77. },
  78. // 创建租户数据
  79. async handleCreateTableData() {
  80. let flag = 0;//1.存在未填写租户本地名称的数据
  81. let newData = this.tableData.filter((item) => {
  82. let keys = Object.keys(item)
  83. keys.map((key) => { //将值为空字符串的属性删除
  84. if(item[key] == "") {
  85. delete item[key]
  86. }
  87. })
  88. if (!item.TenantLocalName) {
  89. flag = 1
  90. }
  91. if(keys.length && Object.keys(item).length) {
  92. return item
  93. }
  94. })
  95. if(!newData.length) {
  96. this.$message("创建信息为空,请录入信息后再创建!")
  97. return
  98. } else if (flag == 1) {
  99. this.$message("存在未填写租户本地名称的数据,请填写信息后再创建!")
  100. return
  101. }
  102. await createRentTableData(newData, (res) => {
  103. this.$message.success("添加成功!")
  104. session.remove("rentAddData")
  105. this.$router.push({ name: 'rentlist'})
  106. })
  107. },
  108. // 删除表格行
  109. handleDeleteTableRow() {
  110. this.$message.success("删除成功")
  111. this.formaTableData()
  112. },
  113. // 添加行
  114. handleAddTableRow() {
  115. let addRowLength = this.addNum
  116. for(let i = 0; i < addRowLength; i++){
  117. this.tableData.push({})
  118. }
  119. this.initTable()
  120. this.formaTableData()
  121. },
  122. //修改
  123. handleUpdataTable(changeData, source) {
  124. this.formaTableData()
  125. },
  126. //保存去掉空字段的新增数据
  127. formaTableData() {
  128. let newData = this.tableData.filter((item) => {
  129. let keys = Object.keys(item)
  130. keys.map((key) => { //将值为空字符串的属性删除
  131. if(item[key] == "") {
  132. delete item[key]
  133. }
  134. })
  135. if(keys.length && Object.keys(item).length) {
  136. return item
  137. }
  138. })
  139. session.set("rentAddData", newData)
  140. },
  141. //关闭右侧关联元空间输入按钮
  142. handleCloseRight() {
  143. this.isTableRightShow = false
  144. },
  145. formatHeaderData(list) {//格式化表头显示的数据
  146. let arr = tools.copyArr(list)
  147. let data = showTools.headerTextFilter(arr, "tenant", this.onlyRead, this.showType)
  148. // data.unshift("关联的元空间");
  149. return data;
  150. },
  151. formatHeaderType(list) {//格式化表头头映射的数据
  152. let arr = tools.copyArr(list);
  153. let data = showTools.headerTypeFilter(arr, "tenant", this.onlyRead, this.showType)
  154. // data.unshift({
  155. // data: "SpaceCount",
  156. // readOnly: this.onlyRead
  157. // })
  158. return data;
  159. },
  160. initTable() {//实例化表格
  161. let settings = {
  162. data: this.tableData,
  163. colHeaders: this.formatHeaderData(this.tableHeader),
  164. columns: this.formatHeaderType(this.tableHeader),
  165. rowHeights: 30,
  166. maxRows: this.tableData.length,
  167. contextMenu: {
  168. items: {
  169. remove_row: {
  170. name: "删除租户"
  171. }
  172. }
  173. },
  174. // 事件
  175. afterChange: this.handleUpdataTable, //修改后
  176. afterFilter: this.trimmedRows, //排序前
  177. afterRemoveRow: this.handleDeleteTableRow, //右键删除
  178. afterOnCellMouseDown: this.handleTdClick //鼠标点击
  179. };
  180. this.$nextTick(() => {
  181. console.log(this.$refs.table);
  182. this.tableExample = this.$refs.table.init(settings);
  183. });
  184. },
  185. //获取到了正确的信息
  186. getInfors(infos, row) {
  187. //其他的开始判断
  188. let val = this.tableExample.colToProp(row.col);
  189. this.row = row.row //要操作的列号
  190. this.messKey = val //要操作的列类型
  191. //点击关联的元空间
  192. // if (val === "SpaceCount") {
  193. // this.isTableRightShow = true;
  194. // }
  195. },
  196. //表格点击事件
  197. handleTdClick(el, rowArr) {
  198. //点击的是表头
  199. if (rowArr.row < 0) {
  200. return;
  201. }
  202. //被筛选过后的数组
  203. let trimmedArr = this.trimmedRows();
  204. //是否启用了排序
  205. let isSort = this.tableExample.getPlugin("columnSorting").isSorted();
  206. if (trimmedArr.length && isSort) {
  207. let sortArr = this.myHotArr.getPlugin("columnSorting").rowsMapper
  208. .__arrayMap;
  209. let infos = this.tableData[trimmedArr[sortArr[rowArr.row]]];
  210. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  211. } else if (isSort) {
  212. //排序后的数组
  213. let sortArr = this.tableExample.getPlugin("columnSorting").rowsMapper.__arrayMap;
  214. let infos = this.tableData[sortArr[rowArr.row]];
  215. this.getInfors(infos, { row: sortArr[rowArr.row], col: rowArr.col });
  216. } else if (trimmedArr.length) {
  217. let infos = this.tableData[trimmedArr[rowArr.row]];
  218. this.getInfors(infos, { row: trimmedArr[rowArr.row], col: rowArr.col });
  219. } else {
  220. let infos = this.tableData[rowArr.row];
  221. this.getInfors(infos, rowArr);
  222. }
  223. },
  224. //获取被筛选掉的行号
  225. trimmedRows() {
  226. // var plugin = hot.getPlugin('trimRows').trimmedRows;//获取被筛选掉的行号
  227. var plugin = this.tableExample.getPlugin("trimRows").trimmedRows;
  228. let dataLength = this.tableData.length;
  229. let dataArr = new Array();
  230. for (let i = 0; i < dataLength; i++) {
  231. dataArr.push(i);
  232. }
  233. if (plugin.length <= 0) {
  234. dataArr = undefined;
  235. } else {
  236. dataArr = this.array_diff(dataArr, plugin);
  237. }
  238. return dataArr || [];
  239. // var DataArray = new Array();
  240. // for (var i = 0; i < plugin.length; i++) {
  241. // // 通过行号获取数据
  242. // DataArray.push(this.tableExample.getSourceDataAtRow(plugin[i]));
  243. // }
  244. },
  245. //去除数组中相同的元素
  246. array_diff(a, b) {
  247. for (var i = 0; i < b.length; i++) {
  248. for (var j = 0; j < a.length; j++) {
  249. if (a[j] == b[i]) {
  250. a.splice(j, 1);
  251. j = j - 1;
  252. }
  253. }
  254. }
  255. return a;
  256. }
  257. }
  258. };
  259. </script>
  260. <style lang="less" scoped>
  261. #deviceList {
  262. overflow: hidden;
  263. height: 100%;
  264. background-color: #fff;
  265. padding: 10px;
  266. position: relative;
  267. .right {
  268. background: #fff;
  269. }
  270. .search-header {
  271. overflow: hidden;
  272. padding:0 10px 10px 10px;
  273. border-bottom: 1px solid #bcbcbc;
  274. }
  275. .tableBox {
  276. display: flex;
  277. height: calc(100% - 100px);
  278. margin-top: 10px;
  279. .tableLeft {
  280. flex: 2;
  281. }
  282. .tableRight {
  283. flex: 1;
  284. // display: none;
  285. border-left: 1px solid #dadada;
  286. padding: 5px 15px;
  287. margin-right: 5px;
  288. box-shadow: 0px 1px 5px 0px rgba(59, 66, 84, 0.15);
  289. .table_right_box::after{
  290. display: block;
  291. content: "";
  292. clear: both;
  293. }
  294. .close_right {
  295. float: right;
  296. cursor: pointer;
  297. }
  298. }
  299. }
  300. .create_button{
  301. margin-top: 10px;
  302. }
  303. }
  304. </style>