1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
| <template>
| <div>
| <basic-container>
| <avue-form
| :option="option"
| v-model="form"
| @tab-click="handleTabClick"
| @submit="handleSubmit"
| ></avue-form>
| </basic-container>
| </div>
| </template>
|
| <script>
| import option from '@/option/user/info';
| import { getUserInfo, updateInfo, updatePassword } from '@/api/system/user';
| import md5 from 'js-md5';
| import func from '@/utils/func';
| import { validatenull } from '@/utils/validate';
| import { sensitive } from '@/utils/sensitive';
|
| export default {
| data() {
| return {
| index: 0,
| option: option,
| form: {},
| sensitiveManager: null,
| };
| },
| created() {
| this.handleWitch();
| },
| methods: {
| handleSubmit(form, done) {
| if (this.index === 0) {
| const submitData = this.sensitiveManager.getSubmitData(form);
| updateInfo(submitData).then(
| res => {
| if (res.data.success) {
| this.$message({
| type: 'success',
| message: '修改信息成功!',
| });
| } else {
| this.$message({
| type: 'error',
| message: res.data.msg,
| });
| }
| done();
| },
| error => {
| window.console.log(error);
| done();
| }
| );
| } else {
| updatePassword(md5(form.oldPassword), md5(form.newPassword), md5(form.newPassword1)).then(
| res => {
| if (res.data.success) {
| this.$message({
| type: 'success',
| message: '修改密码成功!',
| });
| } else {
| this.$message({
| type: 'error',
| message: res.data.msg,
| });
| }
| done();
| },
| error => {
| window.console.log(error);
| done();
| }
| );
| }
| },
| handleWitch() {
| // 创建脱敏工具实例
| this.sensitiveManager = sensitive.create({
| fields: ['phone', 'email'], // 配置需要脱敏的字段
| });
| if (this.index === 0) {
| getUserInfo().then(res => {
| const user = res.data.data;
| this.form = {
| id: user.id,
| avatar: user.avatar,
| name: user.name,
| realName: user.realName,
| phone: user.phone,
| email: user.email,
| };
| // 保存初始脱敏数据
| this.sensitiveManager.saveInitialData(this.form);
| });
| }
| },
| handleTabClick(tabs) {
| if (validatenull(tabs.index)) {
| return;
| }
| this.index = func.toInt(tabs.index, 0);
| this.handleWitch();
| },
| },
| };
| </script>
|
| <style></style>
|
|