user.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421
  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. @current-change="currentChange"
  17. @size-change="sizeChange"
  18. @on-load="onLoad">
  19. <template slot="menuLeft">
  20. <el-button type="danger"
  21. size="small"
  22. icon="el-icon-delete"
  23. plain
  24. v-if="permission.user_delete"
  25. @click="handleDelete">删 除
  26. </el-button>
  27. <el-button type="primary"
  28. size="small"
  29. plain
  30. v-if="permission.user_reset"
  31. icon="el-icon-refresh"
  32. @click="handleReset">密码重置
  33. </el-button>
  34. </template>
  35. <template slot-scope="{row}"
  36. slot="roleId">
  37. <el-tag>{{row.roleName}}</el-tag>
  38. </template>
  39. <template slot-scope="{row}"
  40. slot="deptId">
  41. <el-tag>{{row.deptName}}</el-tag>
  42. </template>
  43. </avue-crud>
  44. </basic-container>
  45. </template>
  46. <script>
  47. import {
  48. getList,
  49. getUser,
  50. remove,
  51. update,
  52. add,
  53. resetPassword
  54. } from "@/api/system/user";
  55. import {getDeptTree} from "@/api/system/dept";
  56. import {getRoleTree} from "@/api/system/role";
  57. import {mapGetters} from "vuex";
  58. import website from '@/config/website';
  59. export default {
  60. data() {
  61. const validatePass = (rule, value, callback) => {
  62. if (value === '') {
  63. callback(new Error('请输入密码'));
  64. } else {
  65. callback();
  66. }
  67. };
  68. const validatePass2 = (rule, value, callback) => {
  69. if (value === '') {
  70. callback(new Error('请再次输入密码'));
  71. } else if (value !== this.form.password) {
  72. callback(new Error('两次输入密码不一致!'));
  73. } else {
  74. callback();
  75. }
  76. };
  77. return {
  78. form: {},
  79. selectionList: [],
  80. page: {
  81. pageSize: 10,
  82. currentPage: 1,
  83. total: 0
  84. },
  85. init: {
  86. roleTree: [],
  87. deptTree: [],
  88. },
  89. option: {
  90. tip: false,
  91. border: true,
  92. index: true,
  93. selection: true,
  94. viewBtn: true,
  95. dialogHeight: 450,
  96. column: [
  97. {
  98. label: "登录账号",
  99. prop: "account",
  100. search: true,
  101. rules: [{
  102. required: true,
  103. message: "请输入登录账号",
  104. trigger: "blur"
  105. }],
  106. span: website.tenantMode ? 12 : 24,
  107. },
  108. {
  109. label: "所属租户",
  110. prop: "tenantId",
  111. type: "tree",
  112. dicUrl: "/api/blade-system/tenant/select",
  113. props: {
  114. label: "tenantName",
  115. value: "tenantId"
  116. },
  117. hide: !website.tenantMode,
  118. addDisplay: website.tenantMode,
  119. editDisplay: website.tenantMode,
  120. viewDisplay: website.tenantMode,
  121. search: website.tenantMode,
  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.tenantId'() {
  247. if (this.form.tenantId !== '') {
  248. getDeptTree(this.form.tenantId).then(res => {
  249. const index = this.$refs.crud.findColumnIndex("deptId");
  250. this.option.column[index].dicData = res.data.data;
  251. });
  252. getRoleTree(this.form.tenantId).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, done) {
  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. }, error => {
  289. done();
  290. console.log(error);
  291. });
  292. },
  293. rowUpdate(row, index, loading, done) {
  294. row.deptId = row.deptId.join(",");
  295. row.roleId = row.roleId.join(",");
  296. update(row).then(() => {
  297. loading();
  298. this.onLoad(this.page);
  299. this.$message({
  300. type: "success",
  301. message: "操作成功!"
  302. });
  303. }, error => {
  304. done();
  305. console.log(error);
  306. });
  307. },
  308. rowDel(row) {
  309. this.$confirm("确定将选择数据删除?", {
  310. confirmButtonText: "确定",
  311. cancelButtonText: "取消",
  312. type: "warning"
  313. })
  314. .then(() => {
  315. return remove(row.id);
  316. })
  317. .then(() => {
  318. this.onLoad(this.page);
  319. this.$message({
  320. type: "success",
  321. message: "操作成功!"
  322. });
  323. });
  324. },
  325. searchReset() {
  326. this.onLoad(this.page);
  327. },
  328. searchChange(params) {
  329. this.onLoad(this.page, params);
  330. },
  331. selectionChange(list) {
  332. this.selectionList = list;
  333. },
  334. handleDelete() {
  335. if (this.selectionList.length === 0) {
  336. this.$message.warning("请选择至少一条数据");
  337. return;
  338. }
  339. this.$confirm("确定将选择数据删除?", {
  340. confirmButtonText: "确定",
  341. cancelButtonText: "取消",
  342. type: "warning"
  343. })
  344. .then(() => {
  345. return remove(this.ids);
  346. })
  347. .then(() => {
  348. this.onLoad(this.page);
  349. this.$message({
  350. type: "success",
  351. message: "操作成功!"
  352. });
  353. this.$refs.crud.toggleSelection();
  354. });
  355. },
  356. handleReset() {
  357. if (this.selectionList.length === 0) {
  358. this.$message.warning("请选择至少一条数据");
  359. return;
  360. }
  361. this.$confirm("确定将选择账号密码重置为123456?", {
  362. confirmButtonText: "确定",
  363. cancelButtonText: "取消",
  364. type: "warning"
  365. })
  366. .then(() => {
  367. return resetPassword(this.ids);
  368. })
  369. .then(() => {
  370. this.$message({
  371. type: "success",
  372. message: "操作成功!"
  373. });
  374. this.$refs.crud.toggleSelection();
  375. });
  376. },
  377. beforeOpen(done, type) {
  378. if (["edit", "view"].includes(type)) {
  379. getUser(this.form.id).then(res => {
  380. this.form = res.data;
  381. this.form.deptId = this.form.deptId.split(",");
  382. this.form.deptId.forEach((ele, index) => {
  383. this.form.deptId[index] = Number(ele);
  384. });
  385. this.form.roleId = this.form.roleId.split(",");
  386. this.form.roleId.forEach((ele, index) => {
  387. this.form.roleId[index] = Number(ele);
  388. });
  389. });
  390. }
  391. done();
  392. },
  393. currentChange(currentPage){
  394. this.page.currentPage = currentPage;
  395. },
  396. sizeChange(pageSize){
  397. this.page.pageSize = pageSize;
  398. },
  399. onLoad(page, params = {}) {
  400. getList(page.currentPage, page.pageSize, params).then(res => {
  401. const data = res.data.data;
  402. this.page.total = data.total;
  403. this.data = data.records;
  404. });
  405. getDeptTree(this.form.tenantId).then(res => {
  406. const index = this.$refs.crud.findColumnIndex("deptId");
  407. this.option.column[index].dicData = res.data.data;
  408. });
  409. getRoleTree(this.form.tenantId).then(res => {
  410. const index = this.$refs.crud.findColumnIndex("roleId");
  411. this.option.column[index].dicData = res.data.data;
  412. });
  413. }
  414. }
  415. };
  416. </script>
  417. <style>
  418. </style>