user.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409
  1. <template>
  2. <basic-container>
  3. <avue-crud :option="option"
  4. :data="data"
  5. ref="crud"
  6. v-model="form"
  7. :permission="permissionList"
  8. @row-del="rowDel"
  9. @row-update="rowUpdate"
  10. @row-save="rowSave"
  11. :before-open="beforeOpen"
  12. :page="page"
  13. @search-change="searchChange"
  14. @search-reset="searchReset"
  15. @selection-change="selectionChange"
  16. @on-load="onLoad">
  17. <template slot="menuLeft">
  18. <el-button type="danger"
  19. size="small"
  20. icon="el-icon-delete"
  21. plain
  22. v-if="permission.user_delete"
  23. @click="handleDelete">删 除
  24. </el-button>
  25. <el-button type="primary"
  26. size="small"
  27. plain
  28. v-if="permission. user_reset"
  29. icon="el-icon-refresh"
  30. @click="handleReset">密码重置
  31. </el-button>
  32. </template>
  33. <template slot-scope="{row}"
  34. slot="roleId">
  35. <el-tag>{{row.roleName}}</el-tag>
  36. </template>
  37. <template slot-scope="{row}"
  38. slot="deptId">
  39. <el-tag>{{row.deptName}}</el-tag>
  40. </template>
  41. </avue-crud>
  42. </basic-container>
  43. </template>
  44. <script>
  45. import {
  46. getList,
  47. getUser,
  48. remove,
  49. update,
  50. add,
  51. resetPassword
  52. } from "@/api/system/user";
  53. import {getDeptTree} from "@/api/system/dept";
  54. import {getRoleTree} from "@/api/system/role";
  55. import {mapGetters} from "vuex";
  56. export default {
  57. data() {
  58. const validatePass = (rule, value, callback) => {
  59. if (value === '') {
  60. callback(new Error('请输入密码'));
  61. } else {
  62. callback();
  63. }
  64. };
  65. const validatePass2 = (rule, value, callback) => {
  66. debugger
  67. if (value === '') {
  68. callback(new Error('请再次输入密码'));
  69. } else if (value !== this.form.password) {
  70. callback(new Error('两次输入密码不一致!'));
  71. } else {
  72. callback();
  73. }
  74. };
  75. return {
  76. form: {},
  77. selectionList: [],
  78. page: {
  79. pageSize: 10,
  80. currentPage: 1,
  81. total: 0
  82. },
  83. init: {
  84. roleTree: [],
  85. deptTree: [],
  86. },
  87. option: {
  88. tip: false,
  89. border: true,
  90. index: true,
  91. selection: true,
  92. viewBtn: true,
  93. dialogHeight: 450,
  94. column: [
  95. {
  96. label: "登录账号",
  97. prop: "account",
  98. search: true,
  99. rules: [{
  100. required: true,
  101. message: "请输入登录账号",
  102. trigger: "blur"
  103. }]
  104. },
  105. {
  106. label: "租户编号",
  107. prop: "tenantCode",
  108. addDisplay: false,
  109. editDisplay: false,
  110. viewDisplay: false,
  111. },
  112. {
  113. label: "所属租户",
  114. prop: "tenantCode",
  115. type: "tree",
  116. dicUrl: "/api/blade-system/tenant/select",
  117. props: {
  118. label: "tenantName",
  119. value: "tenantCode"
  120. },
  121. search: true,
  122. rules: [{
  123. required: true,
  124. message: "请输入所属租户",
  125. trigger: "click"
  126. }]
  127. },
  128. {
  129. label: '密码',
  130. prop: 'password',
  131. hide: true,
  132. editDisplay: false,
  133. viewDisplay: false,
  134. rules: [{required: true, validator: validatePass, trigger: 'blur'}]
  135. },
  136. {
  137. label: '确认密码',
  138. prop: 'password2',
  139. hide: true,
  140. editDisplay: false,
  141. viewDisplay: false,
  142. rules: [{required: true, validator: validatePass2, trigger: 'blur'}]
  143. },
  144. {
  145. label: "用户昵称",
  146. prop: "name",
  147. search: true,
  148. rules: [{
  149. required: true,
  150. message: "请输入用户昵称",
  151. trigger: "blur"
  152. }]
  153. },
  154. {
  155. label: "用户姓名",
  156. prop: "realName",
  157. rules: [{
  158. required: true,
  159. message: "请输入用户姓名",
  160. trigger: "blur"
  161. }]
  162. },
  163. {
  164. label: "所属角色",
  165. prop: "roleId",
  166. multiple: true,
  167. type: "tree",
  168. dicData: [],
  169. props: {
  170. label: "title"
  171. },
  172. slot: true,
  173. rules: [{
  174. required: true,
  175. message: "请选择所属角色",
  176. trigger: "click"
  177. }]
  178. },
  179. {
  180. label: "所属部门",
  181. prop: "deptId",
  182. type: "tree",
  183. multiple: true,
  184. dicData: [],
  185. props: {
  186. label: "title"
  187. },
  188. slot: true,
  189. rules: [{
  190. required: true,
  191. message: "请选择所属部门",
  192. trigger: "click"
  193. }]
  194. },
  195. {
  196. label: "手机号码",
  197. prop: "phone",
  198. overHidden: true
  199. },
  200. {
  201. label: "电子邮箱",
  202. prop: "email",
  203. hide: true,
  204. overHidden: true
  205. },
  206. {
  207. label: "用户性别",
  208. prop: "sex",
  209. type: "select",
  210. dicData: [
  211. {
  212. label: "男",
  213. value: 1
  214. },
  215. {
  216. label: "女",
  217. value: 2
  218. },
  219. {
  220. label: "未知",
  221. value: 3
  222. }
  223. ],
  224. hide: true
  225. },
  226. {
  227. label: "用户生日",
  228. type: "date",
  229. prop: "birthday",
  230. format: "yyyy-MM-dd hh:mm:ss",
  231. valueFormat: "yyyy-MM-dd hh:mm:ss",
  232. hide: true
  233. },
  234. {
  235. label: "账号状态",
  236. prop: "statusName",
  237. hide: true,
  238. display: false
  239. }
  240. ]
  241. },
  242. data: []
  243. };
  244. },
  245. watch: {
  246. 'form.tenantCode'() {
  247. if (this.form.tenantCode !== '') {
  248. getDeptTree(this.form.tenantCode).then(res => {
  249. const index = this.$refs.crud.findColumnIndex("deptId");
  250. this.option.column[index].dicData = res.data.data;
  251. });
  252. getRoleTree(this.form.tenantCode).then(res => {
  253. const index = this.$refs.crud.findColumnIndex("roleId");
  254. this.option.column[index].dicData = res.data.data;
  255. });
  256. }
  257. }
  258. },
  259. computed: {
  260. ...mapGetters(["permission"]),
  261. permissionList() {
  262. return {
  263. addBtn: this.vaildData(this.permission.user_add, false),
  264. viewBtn: this.vaildData(this.permission.user_view, false),
  265. delBtn: this.vaildData(this.permission.user_delete, false),
  266. editBtn: this.vaildData(this.permission.user_edit, false)
  267. };
  268. },
  269. ids() {
  270. let ids = [];
  271. this.selectionList.forEach(ele => {
  272. ids.push(ele.id);
  273. });
  274. return ids.join(",");
  275. }
  276. },
  277. methods: {
  278. rowSave(row, loading) {
  279. row.deptId = row.deptId.join(",");
  280. row.roleId = row.roleId.join(",");
  281. add(row).then(() => {
  282. loading();
  283. this.onLoad(this.page);
  284. this.$message({
  285. type: "success",
  286. message: "操作成功!"
  287. });
  288. });
  289. },
  290. rowUpdate(row, index, loading) {
  291. row.deptId = row.deptId.join(",");
  292. row.roleId = row.roleId.join(",");
  293. update(row).then(() => {
  294. loading();
  295. this.onLoad(this.page);
  296. this.$message({
  297. type: "success",
  298. message: "操作成功!"
  299. });
  300. });
  301. },
  302. rowDel(row) {
  303. this.$confirm("确定将选择数据删除?", {
  304. confirmButtonText: "确定",
  305. cancelButtonText: "取消",
  306. type: "warning"
  307. })
  308. .then(() => {
  309. return remove(row.id);
  310. })
  311. .then(() => {
  312. this.onLoad(this.page);
  313. this.$message({
  314. type: "success",
  315. message: "操作成功!"
  316. });
  317. });
  318. },
  319. searchReset() {
  320. this.onLoad(this.page);
  321. },
  322. searchChange(params) {
  323. this.onLoad(this.page, params);
  324. },
  325. selectionChange(list) {
  326. this.selectionList = list;
  327. },
  328. handleDelete() {
  329. if (this.selectionList.length === 0) {
  330. this.$message.warning("请选择至少一条数据");
  331. return;
  332. }
  333. this.$confirm("确定将选择数据删除?", {
  334. confirmButtonText: "确定",
  335. cancelButtonText: "取消",
  336. type: "warning"
  337. })
  338. .then(() => {
  339. return remove(this.ids);
  340. })
  341. .then(() => {
  342. this.onLoad(this.page);
  343. this.$message({
  344. type: "success",
  345. message: "操作成功!"
  346. });
  347. this.$refs.crud.toggleSelection();
  348. });
  349. },
  350. handleReset() {
  351. if (this.selectionList.length === 0) {
  352. this.$message.warning("请选择至少一条数据");
  353. return;
  354. }
  355. this.$confirm("确定将选择账号密码重置为123456?", {
  356. confirmButtonText: "确定",
  357. cancelButtonText: "取消",
  358. type: "warning"
  359. })
  360. .then(() => {
  361. return resetPassword(this.ids);
  362. })
  363. .then(() => {
  364. this.$message({
  365. type: "success",
  366. message: "操作成功!"
  367. });
  368. this.$refs.crud.toggleSelection();
  369. });
  370. },
  371. beforeOpen(done, type) {
  372. if (["edit", "view"].includes(type)) {
  373. getUser(this.form.id).then(res => {
  374. this.form = res.data.data;
  375. this.form.deptId = this.form.deptId.split(",");
  376. this.form.deptId.forEach((ele, index) => {
  377. this.form.deptId[index] = Number(ele);
  378. });
  379. this.form.roleId = this.form.roleId.split(",");
  380. this.form.roleId.forEach((ele, index) => {
  381. this.form.roleId[index] = Number(ele);
  382. });
  383. });
  384. }
  385. done();
  386. },
  387. onLoad(page, params = {}) {
  388. getList(page.currentPage, page.pageSize, params).then(res => {
  389. const data = res.data.data;
  390. this.page.total = data.total;
  391. this.data = data.records;
  392. });
  393. getDeptTree(this.form.tenantCode).then(res => {
  394. const index = this.$refs.crud.findColumnIndex("deptId");
  395. this.option.column[index].dicData = res.data.data;
  396. });
  397. getRoleTree(this.form.tenantCode).then(res => {
  398. const index = this.$refs.crud.findColumnIndex("roleId");
  399. this.option.column[index].dicData = res.data.data;
  400. });
  401. }
  402. }
  403. };
  404. </script>
  405. <style>
  406. </style>