system-clients 3.2.103-temp → 3.2.105-temp

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,125 +1,125 @@
1
- <template>
2
- <div>
3
- <validator name="v">
4
- <modal :show.sync="show" v-ref:modal backdrop="false">
5
- <header slot="modal-header" class="modal-header">
6
- <button type="button" class="close" @click="rest"><span>&times;</span></button>
7
- <h4 class="modal-title">修改密码</h4>
8
- </header>
9
- <article slot="modal-body" class="modal-body modifystyle auto form-horizontal">
10
- <div class="has-feedback form-group"
11
- :class="{'has-warning':$v.password.required,'has-error': $v.password.required,
12
- 'has-success':!$v.password.required}">
13
- <label for="password" class="col-sm-4 col-sm-offset-1 control-label">原始密码:&nbsp;&nbsp;</label>
14
- <div class="col-sm-4">
15
- <input type="password" v-model="deliver.password" class="form-control" id="password" v-validate:password="{ required: true}">
16
- <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.password.required"></span>
17
- <span v-if="$v.password.required">不能为空</span>
18
- </div>
19
- </div>
20
- <div class="has-feedback form-group"
21
- :class="{'has-warning':$v.newpassword.required,'has-error':($v.newpassword.numbersAndLetter8to16 || $v.newpassword.minlength)&& !$v.newpassword.required && !$v.newpassword.chinesePassword,
22
- 'has-success': !$v.newpassword.required && !$v.newpassword.numbersAndLetter8to16&&!$v.newpassword.minlength && !$v.newpassword.chinesePassword}">
23
- <label for="newpassword" class="col-sm-4 col-sm-offset-1 control-label">新的密码:&nbsp;&nbsp;</label>
24
- <div class="col-sm-4">
25
- <input type="password" v-model="deliver.newpassword" class="form-control" id="newpassword" v-validate:newpassword='{required:true, numbersAndLetter8to16: true, minlength: 6,chinesePassword: true}'>
26
- <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.newpassword.required && !$v.newpassword.minlength && !($v.newpassword.numbersAndLetter8to16 && !($v.newpassword.required)) && !($v.newpassword.chinesePassword) "></span>
27
- <span v-if="$v.newpassword.required">不能为空</span>
28
- <span v-if="($v.newpassword.numbersAndLetter8to16||$v.newpassword.minlength) && !($v.newpassword.required&&$v.newpassword.minlength)">密码必须是8~16位数字与大小字母外加特殊字符的组合,并且不能出现类似'123','abc'等连贯数字或者字母</span>
29
- <span v-if="$v.newpassword.chinesePassword">密码不能包含中文</span>
30
- </div>
31
- </div>
32
- <div class="has-feedback form-group"
33
- :class="{'has-warning':$v.affirmpassword.required,'has-error':$v.affirmpassword.equalValid && !($v.affirmpassword.required),
34
- 'has-success': !$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))}">
35
- <label for="affirmpassword" class="col-sm-4 col-sm-offset-1 control-label">确认密码:&nbsp;&nbsp;</label>
36
- <div class="col-sm-4">
37
- <input type="password" v-model="deliver.affirmpassword" class="form-control" id="affirmpassword" v-validate:affirmpassword="{ required: true, equalValid: deliver.newpassword }">
38
- <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))"></span>
39
- <span v-if="$v.affirmpassword.required">不能为空</span>
40
- <span v-if="$v.affirmpassword.equalValid && !($v.affirmpassword.required)">两次密码不一致 !!</span>
41
- </div>
42
- </div>
43
- </article>
44
-
45
- <footer slot="modal-footer" class="modal-footer">
46
- <button type="button" class="btn btn-success" @click='confirm' :disabled="!$v.valid">确认</button>
47
- <button type="button" class="btn btn-default" @click='rest'>取消</button>
48
- </footer>
49
- </modal>
50
- </validator>
51
- </div>
52
-
53
-
54
- </template>
55
- <script>
56
- import co from 'co'
57
- import validator from '../../plugins/validation';
58
-
59
- let saveGen = function * (self) {
60
- self.deliver.ename = self.functions.ename
61
- // let res = yield self.$post('rs/user/entity', {data: self.deliver})
62
- // let res = yield self.$post('rs/db/modifypassword', {data: self.deliver})
63
- // let res = yield self.$resetpost('/rs/db/modifypwd', {data: self.deliver})
64
- // Util.f.password = self.deliver.newpassword
65
- let res = yield self.$resetpost('/rs/user/modifypwd', {data: self.deliver }, {resolveMsg: null,rejectMsg: null})
66
- self.$login.f.password = self.deliver.newpassword
67
- if (res.data) {
68
- console.log("修改密码返回:" , res.data)
69
- // 兼容旧版ldao,旧版不返回code
70
- if (res.data.code === 200) {
71
- self.deliver.password = ''
72
- self.deliver.newpassword = ''
73
- self.deliver.affirmpassword = ''
74
- self.show = false
75
- self.$showAlert("修改密码成功", 'success', 2000)
76
- } else {
77
- // 兼容旧版ldao,旧版不返回code
78
- self.deliver.password = ''
79
- self.deliver.newpassword = ''
80
- self.deliver.affirmpassword = ''
81
- self.show = false
82
- self.$showAlert("修改密码成功", 'success', 2000)
83
- }
84
- } else {
85
- if (res.data.code) {
86
- self.$showAlert("修改密码失败,原因:" + res.data.msg, 'warning', 2000)
87
- } else {
88
- self.$showMessage(res.data)
89
- }
90
- }
91
- }
92
- export default {
93
- title: '系统管理-密码修改',
94
- data () {
95
- return {
96
- deliver: {
97
- password: '',
98
- newpassword: '',
99
- affirmpassword: ''
100
- },
101
- functions: this.$login.f
102
- }
103
- },
104
- props: ['show'],
105
- methods: {
106
- confirm () {
107
- let gen = saveGen(this)
108
- co(gen)
109
- },
110
- rest () {
111
- this.show = false
112
- this.deliver = {password: '', newpassword: '', affirmpassword: ''}
113
- }
114
- }
115
- }
116
- </script>
117
- <style>
118
- /*修改密码body界面样式*/
119
- .modifystyle {
120
- background: #FCFEEE;
121
- }
122
- .modifystyle span{
123
- color: red;
124
- }
125
- </style>
1
+ <template>
2
+ <div>
3
+ <validator name="v">
4
+ <modal :show.sync="show" v-ref:modal backdrop="false">
5
+ <header slot="modal-header" class="modal-header">
6
+ <button type="button" class="close" @click="rest"><span>&times;</span></button>
7
+ <h4 class="modal-title">修改密码</h4>
8
+ </header>
9
+ <article slot="modal-body" class="modal-body modifystyle auto form-horizontal">
10
+ <div class="has-feedback form-group"
11
+ :class="{'has-warning':$v.password.required,'has-error': $v.password.required,
12
+ 'has-success':!$v.password.required}">
13
+ <label for="password" class="col-sm-4 col-sm-offset-1 control-label">原始密码:&nbsp;&nbsp;</label>
14
+ <div class="col-sm-4">
15
+ <input type="password" v-model="deliver.password" class="form-control" id="password" v-validate:password="{ required: true}">
16
+ <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.password.required"></span>
17
+ <span v-if="$v.password.required">不能为空</span>
18
+ </div>
19
+ </div>
20
+ <div class="has-feedback form-group"
21
+ :class="{'has-warning':$v.newpassword.required,'has-error':($v.newpassword.numbersAndLetter8to16 || $v.newpassword.minlength)&& !$v.newpassword.required && !$v.newpassword.chinesePassword,
22
+ 'has-success': !$v.newpassword.required && !$v.newpassword.numbersAndLetter8to16&&!$v.newpassword.minlength && !$v.newpassword.chinesePassword}">
23
+ <label for="newpassword" class="col-sm-4 col-sm-offset-1 control-label">新的密码:&nbsp;&nbsp;</label>
24
+ <div class="col-sm-4">
25
+ <input type="password" v-model="deliver.newpassword" class="form-control" id="newpassword" v-validate:newpassword='{required:true, numbersAndLetter8to16: true, minlength: 6,chinesePassword: true}'>
26
+ <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.newpassword.required && !$v.newpassword.minlength && !($v.newpassword.numbersAndLetter8to16 && !($v.newpassword.required)) && !($v.newpassword.chinesePassword) "></span>
27
+ <span v-if="$v.newpassword.required">不能为空</span>
28
+ <span v-if="($v.newpassword.numbersAndLetter8to16||$v.newpassword.minlength) && !($v.newpassword.required&&$v.newpassword.minlength)">密码必须是8~16位数字与大小字母外加特殊字符的组合,并且不能出现类似'123','abc'等连贯数字或者字母</span>
29
+ <span v-if="$v.newpassword.chinesePassword">密码不能包含中文</span>
30
+ </div>
31
+ </div>
32
+ <div class="has-feedback form-group"
33
+ :class="{'has-warning':$v.affirmpassword.required,'has-error':$v.affirmpassword.equalValid && !($v.affirmpassword.required),
34
+ 'has-success': !$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))}">
35
+ <label for="affirmpassword" class="col-sm-4 col-sm-offset-1 control-label">确认密码:&nbsp;&nbsp;</label>
36
+ <div class="col-sm-4">
37
+ <input type="password" v-model="deliver.affirmpassword" class="form-control" id="affirmpassword" v-validate:affirmpassword="{ required: true, equalValid: deliver.newpassword }">
38
+ <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))"></span>
39
+ <span v-if="$v.affirmpassword.required">不能为空</span>
40
+ <span v-if="$v.affirmpassword.equalValid && !($v.affirmpassword.required)">两次密码不一致 !!</span>
41
+ </div>
42
+ </div>
43
+ </article>
44
+
45
+ <footer slot="modal-footer" class="modal-footer">
46
+ <button type="button" class="btn btn-success" @click='confirm' :disabled="!$v.valid">确认</button>
47
+ <button type="button" class="btn btn-default" @click='rest'>取消</button>
48
+ </footer>
49
+ </modal>
50
+ </validator>
51
+ </div>
52
+
53
+
54
+ </template>
55
+ <script>
56
+ import co from 'co'
57
+ import validator from '../../plugins/validation';
58
+
59
+ let saveGen = function * (self) {
60
+ self.deliver.ename = self.ename || self.functions.ename
61
+ // let res = yield self.$post('rs/user/entity', {data: self.deliver})
62
+ // let res = yield self.$post('rs/db/modifypassword', {data: self.deliver})
63
+ // let res = yield self.$resetpost('/rs/db/modifypwd', {data: self.deliver})
64
+ // Util.f.password = self.deliver.newpassword
65
+ let res = yield self.$resetpost('/rs/user/modifypwd', {data: self.deliver }, {resolveMsg: null,rejectMsg: null})
66
+ self.$login.f.password = self.deliver.newpassword
67
+ if (res.data) {
68
+ console.log("修改密码返回:" , res.data)
69
+ // 兼容旧版ldao,旧版不返回code
70
+ if (res.data.code === 200) {
71
+ self.deliver.password = ''
72
+ self.deliver.newpassword = ''
73
+ self.deliver.affirmpassword = ''
74
+ self.show = false
75
+ self.$showAlert("修改密码成功", 'success', 2000)
76
+ } else {
77
+ // 兼容旧版ldao,旧版不返回code
78
+ self.deliver.password = ''
79
+ self.deliver.newpassword = ''
80
+ self.deliver.affirmpassword = ''
81
+ self.show = false
82
+ self.$showAlert("修改密码成功", 'success', 2000)
83
+ }
84
+ } else {
85
+ if (res.data.code) {
86
+ self.$showAlert("修改密码失败,原因:" + res.data.msg, 'warning', 2000)
87
+ } else {
88
+ self.$showMessage(res.data)
89
+ }
90
+ }
91
+ }
92
+ export default {
93
+ title: '系统管理-密码修改',
94
+ data () {
95
+ return {
96
+ deliver: {
97
+ password: '',
98
+ newpassword: '',
99
+ affirmpassword: ''
100
+ },
101
+ functions: this.$login.f
102
+ }
103
+ },
104
+ props: ['show','ename'],
105
+ methods: {
106
+ confirm () {
107
+ let gen = saveGen(this)
108
+ co(gen)
109
+ },
110
+ rest () {
111
+ this.show = false
112
+ this.deliver = {password: '', newpassword: '', affirmpassword: ''}
113
+ }
114
+ }
115
+ }
116
+ </script>
117
+ <style>
118
+ /*修改密码body界面样式*/
119
+ .modifystyle {
120
+ background: #FCFEEE;
121
+ }
122
+ .modifystyle span{
123
+ color: red;
124
+ }
125
+ </style>
@@ -1,175 +1,175 @@
1
- <template>
2
- <v-select :options='resoptions' placeholder='请选择'
3
- :value.sync="selectres"
4
- :multiple="isMul"
5
- search="true"
6
- :disabled="mustselect"
7
- :close-on-select="!isMul"
8
- @change="resChange"
9
- >
10
- </v-select>
11
- </template>
12
- <script>
13
- import {HttpResetClass} from 'vue-client'
14
-
15
- export default {
16
- title: '资源选择',
17
- props: {
18
-
19
- //资源类型
20
- restype:'',
21
- //是否只查询营业厅
22
- specialquery: {
23
- type: Boolean,
24
- default: false
25
- },
26
- //资源数据
27
- resObj:{},
28
- isMul: {
29
- type: Boolean,
30
- default: true
31
- },
32
- //资源初始化数据
33
- initresid: {
34
- type: Array,
35
- default() { return [] },
36
- },
37
- //父层id
38
- parentresid: {
39
- type: Array,
40
- default() { return [] },
41
- },
42
- mustselect: {
43
- type: Boolean,
44
- default: false
45
- },
46
- },
47
- data () {
48
- return {
49
- //资源数据
50
- resObj:{},
51
- //资源数据列表
52
- resoptions:[],
53
- //选中资源数据
54
- selectres: [],
55
- }
56
- },
57
- ready () {
58
- //获取资源列表
59
- this.getResList()
60
- },
61
- methods:{
62
- //树形结构变成list
63
- findById(val) {
64
- if(val){
65
- if(this.checkidres(val)){
66
- this.treetoList(val,'')
67
- }else if(val.children.length>0){
68
- for (let value of val.children) {
69
- this.findById(value)
70
- }
71
- }
72
- }
73
- },
74
- //树形结构变成list
75
- treetoList(val,parentname) {
76
- for (let value of val.children) {
77
- this.ergodicList(value,parentname)
78
- }
79
- },
80
- //找到跟节点
81
- ergodicList (val,parentname) {
82
- if(val.children.length > 0 ){
83
- parentname=parentname+val.name
84
- this.treetoList(val,parentname)
85
- }else {
86
- //截取组织机构【组织机构】
87
- if(this.restype=='organization'){
88
- parentname=parentname.replace("组织机构","")
89
- this.resoptions.push({label: val.name+' - '+parentname, value: val.id})
90
- }else{
91
- if (this.specialquery && this.restype == 'department') {
92
- if (val.f_dep_type === '营业厅') {
93
- this.resoptions.push({label: val.name, value: val.id})
94
- }
95
- }else {
96
- this.resoptions.push({label: val.name, value: val.id})
97
- }
98
- }
99
- }
100
- },
101
- //检查id是否存在
102
- checkidres(val){
103
- let flag=false
104
- //如果没传值得话 不过滤
105
- if(this.parentresid.length==0&&this.restype=='organization'){
106
- flag=true
107
- }
108
- this.parentresid.forEach((item) => {
109
- if(item==val.id){
110
- flag=true
111
- }
112
- })
113
- return flag;
114
- },
115
- //资源改变
116
- resChange(val){
117
- let orgnames=[]
118
- Object.keys(this.resoptions).forEach((key) => {
119
- if(this.selectres.includes(this.resoptions[key].value))
120
- orgnames.push(this.resoptions[key].label)
121
- })
122
- console.log('资源改变。。', val, orgnames)
123
- this.$dispatch('res-select', this.selectres, orgnames)
124
- },
125
- //获取资源数据
126
- async getResList() {
127
-
128
- let http = new HttpResetClass()
129
-
130
- let req = await http.load('POST', '/rs/search', {data: {
131
- source: `tool.getFullTree(this.getRights().where(row.getType()==$${this.restype}$))`,
132
- userid: this.$login.f.id
133
- }}, {resolveMsg: null, rejectMsg: '获取组织结构数据出错'})
134
- this.resObj=req.data[0]
135
- this.dealdata()
136
- },
137
- dealdata(){
138
- this.resoptions=[]
139
- this.findById(this.resObj);
140
- //赋值资源数据
141
- let arryselect=[]
142
- this.resoptions.forEach((item) => {
143
- if(this.initresid.length>0){
144
- this.initresid.forEach((init) => {
145
- if(item.value==init){
146
- arryselect.push(item.value)
147
- }
148
- })
149
- }
150
- })
151
- //赋值资源选中初始值
152
- this.selectres=arryselect
153
- }
154
- },
155
- watch: {
156
- //监听初始化资源id
157
- 'initresid.length'(){
158
- this.dealdata()
159
- },
160
- //监听初始化资源id
161
- 'parentresid'(){
162
- this.dealdata()
163
- },
164
- initresid: {
165
- handler(newVal, oldVal) {
166
- // 避免重复触发
167
- if (JSON.stringify(newVal) === JSON.stringify(oldVal)) {
168
- return;
169
- }
170
- this.dealdata();
171
- },
172
- }
173
- },
174
- }
175
- </script>
1
+ <template>
2
+ <v-select :options='resoptions' placeholder='请选择'
3
+ :value.sync="selectres"
4
+ :multiple="isMul"
5
+ search="true"
6
+ :disabled="mustselect"
7
+ :close-on-select="!isMul"
8
+ @change="resChange"
9
+ >
10
+ </v-select>
11
+ </template>
12
+ <script>
13
+ import {HttpResetClass} from 'vue-client'
14
+
15
+ export default {
16
+ title: '资源选择',
17
+ props: {
18
+
19
+ //资源类型
20
+ restype:'',
21
+ //是否只查询营业厅
22
+ specialquery: {
23
+ type: Boolean,
24
+ default: false
25
+ },
26
+ //资源数据
27
+ resObj:{},
28
+ isMul: {
29
+ type: Boolean,
30
+ default: true
31
+ },
32
+ //资源初始化数据
33
+ initresid: {
34
+ type: Array,
35
+ default() { return [] },
36
+ },
37
+ //父层id
38
+ parentresid: {
39
+ type: Array,
40
+ default() { return [] },
41
+ },
42
+ mustselect: {
43
+ type: Boolean,
44
+ default: false
45
+ },
46
+ },
47
+ data () {
48
+ return {
49
+ //资源数据
50
+ resObj:{},
51
+ //资源数据列表
52
+ resoptions:[],
53
+ //选中资源数据
54
+ selectres: [],
55
+ }
56
+ },
57
+ ready () {
58
+ //获取资源列表
59
+ this.getResList()
60
+ },
61
+ methods:{
62
+ //树形结构变成list
63
+ findById(val) {
64
+ if(val){
65
+ if(this.checkidres(val)){
66
+ this.treetoList(val,'')
67
+ }else if(val.children.length>0){
68
+ for (let value of val.children) {
69
+ this.findById(value)
70
+ }
71
+ }
72
+ }
73
+ },
74
+ //树形结构变成list
75
+ treetoList(val,parentname) {
76
+ for (let value of val.children) {
77
+ this.ergodicList(value,parentname)
78
+ }
79
+ },
80
+ //找到跟节点
81
+ ergodicList (val,parentname) {
82
+ if(val.children.length > 0 ){
83
+ parentname=parentname+val.name
84
+ this.treetoList(val,parentname)
85
+ }else {
86
+ //截取组织机构【组织机构】
87
+ if(this.restype=='organization'){
88
+ parentname=parentname.replace("组织机构","")
89
+ this.resoptions.push({label: val.name+' - '+parentname, value: val.id})
90
+ }else{
91
+ if (this.specialquery && this.restype == 'department') {
92
+ if (val.f_dep_type === '营业厅') {
93
+ this.resoptions.push({label: val.name, value: val.id})
94
+ }
95
+ }else {
96
+ this.resoptions.push({label: val.name, value: val.id})
97
+ }
98
+ }
99
+ }
100
+ },
101
+ //检查id是否存在
102
+ checkidres(val){
103
+ let flag=false
104
+ //如果没传值得话 不过滤
105
+ if(this.parentresid.length==0&&this.restype=='organization'){
106
+ flag=true
107
+ }
108
+ this.parentresid.forEach((item) => {
109
+ if(item==val.id){
110
+ flag=true
111
+ }
112
+ })
113
+ return flag;
114
+ },
115
+ //资源改变
116
+ resChange(val){
117
+ let orgnames=[]
118
+ Object.keys(this.resoptions).forEach((key) => {
119
+ if(this.selectres.includes(this.resoptions[key].value))
120
+ orgnames.push(this.resoptions[key].label)
121
+ })
122
+ console.log('资源改变。。', val, orgnames)
123
+ this.$dispatch('res-select', this.selectres, orgnames)
124
+ },
125
+ //获取资源数据
126
+ async getResList() {
127
+
128
+ let http = new HttpResetClass()
129
+
130
+ let req = await http.load('POST', '/rs/search', {data: {
131
+ source: `tool.getFullTree(this.getRights().where(row.getType()==$${this.restype}$))`,
132
+ userid: this.$login.f.id
133
+ }}, {resolveMsg: null, rejectMsg: '获取组织结构数据出错'})
134
+ this.resObj=req.data[0]
135
+ this.dealdata()
136
+ },
137
+ dealdata(){
138
+ this.resoptions=[]
139
+ this.findById(this.resObj);
140
+ //赋值资源数据
141
+ let arryselect=[]
142
+ this.resoptions.forEach((item) => {
143
+ if(this.initresid.length>0){
144
+ this.initresid.forEach((init) => {
145
+ if(item.value==init){
146
+ arryselect.push(item.value)
147
+ }
148
+ })
149
+ }
150
+ })
151
+ //赋值资源选中初始值
152
+ this.selectres=arryselect
153
+ }
154
+ },
155
+ watch: {
156
+ //监听初始化资源id
157
+ 'initresid.length'(){
158
+ this.dealdata()
159
+ },
160
+ //监听初始化资源id
161
+ 'parentresid'(){
162
+ this.dealdata()
163
+ },
164
+ initresid: {
165
+ handler(newVal, oldVal) {
166
+ // 避免重复触发
167
+ if (JSON.stringify(newVal) === JSON.stringify(oldVal)) {
168
+ return;
169
+ }
170
+ this.dealdata();
171
+ },
172
+ }
173
+ },
174
+ }
175
+ </script>