system-clients 3.1.100-aode → 3.1.101-aode

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.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "system-clients",
3
- "version": "3.1.100-aode",
3
+ "version": "3.1.101-aode",
4
4
  "description": "系统基础框架",
5
5
  "main": "src/index.js",
6
6
  "directories": {
@@ -115,7 +115,7 @@
115
115
  import co from 'co'
116
116
  import $ from 'jquery'
117
117
  import Vue from 'vue'
118
-
118
+ import cryptJS from '../../plugins/EncryptUtil'
119
119
  let saveGen = function* (self) {
120
120
  try {
121
121
  yield self.$login.login(self.model.ename, self.model.password)
@@ -207,6 +207,15 @@ export default {
207
207
  this.model.password = this.$login.getUrlCompileParames('password')
208
208
  this.confirm()
209
209
  }
210
+ if(this.$login&&this.$login.getUrlParames('token')){
211
+ console.log(this.$login.getUrlParames('token'))
212
+ let param = cryptJS.AESDecrypt(this.$login.getUrlParames('token'),'3KMKqvgwR8ULbR8Z')
213
+ console.log(param)
214
+ // param = JSON.parse(param)
215
+ this.model.ename = param.username
216
+ this.model.password = param.password
217
+ this.confirm()
218
+ }
210
219
  $('#login-button').click(function (event) {
211
220
  event.preventDefault()
212
221
  $('form').fadeOut(500)
@@ -1,112 +1,112 @@
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.strongpassword && !($v.newpassword.required),
22
- 'has-success': !$v.newpassword.required && !$v.newpassword.strongpassword }">
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, strongpassword: true}'>
26
- <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.newpassword.required && !($v.newpassword.strongpassword && !($v.newpassword.required))"></span>
27
- <span v-if="$v.newpassword.required">不能为空</span>
28
- <span v-if="$v.newpassword.strongpassword && !($v.newpassword.required)">密码必须包含英文大小写、阿拉伯数字、字符</span>
29
- </div>
30
- </div>
31
- <div class="has-feedback form-group"
32
- :class="{'has-warning':$v.affirmpassword.required,'has-error':$v.affirmpassword.equalValid && !($v.affirmpassword.required),
33
- 'has-success': !$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))}">
34
- <label for="affirmpassword" class="col-sm-4 col-sm-offset-1 control-label">确认密码:&nbsp;&nbsp;</label>
35
- <div class="col-sm-4">
36
- <input type="password" v-model="deliver.affirmpassword" class="form-control" id="affirmpassword" v-validate:affirmpassword="{ required: true, equalValid: deliver.newpassword }">
37
- <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))"></span>
38
- <span v-if="$v.affirmpassword.required">不能为空</span>
39
- <span v-if="$v.affirmpassword.equalValid && !($v.affirmpassword.required)">两次密码不一致 !!</span>
40
- </div>
41
- </div>
42
- </article>
43
-
44
- <footer slot="modal-footer" class="modal-footer">
45
- <button type="button" class="btn btn-success" @click='confirm' :disabled="!$v.valid">确认</button>
46
- <button type="button" class="btn btn-default" @click='rest'>取消</button>
47
- </footer>
48
- </modal>
49
- </validator>
50
- </div>
51
-
52
-
53
- </template>
54
- <script>
55
- import co from 'co'
56
- import validator from '../../plugins/validation';
57
-
58
- let saveGen = function * (self) {
59
- self.deliver.ename = self.functions.ename
60
- // let res = yield self.$post('rs/user/entity', {data: self.deliver})
61
- // let res = yield self.$post('rs/db/modifypassword', {data: self.deliver})
62
- // let res = yield self.$resetpost('/rs/db/modifypwd', {data: self.deliver})
63
- // Util.f.password = self.deliver.newpassword
64
- let res = yield self.$resetpost('/rs/user/modifypwd', {data: self.deliver }, { resolveMsg: null, rejectMsg: '请求错误,修改密码失败!' })
65
- self.$login.f.password = self.deliver.newpassword
66
- if (res.data) {
67
- console.log("修改密码返回:" , res.data)
68
- if (res.data.code === 200) {
69
- self.deliver.password = ''
70
- self.deliver.newpassword = ''
71
- self.deliver.affirmpassword = ''
72
- self.show = false
73
- self.$showAlert("修改密码成功", 'success', 2000)
74
- } else {
75
- self.$showAlert("修改密码失败,原因:" + res.data.msg, 'warning', 2000)
76
- }
77
- }
78
- }
79
- export default {
80
- title: '系统管理-密码修改',
81
- data () {
82
- return {
83
- deliver: {
84
- password: '',
85
- newpassword: '',
86
- affirmpassword: ''
87
- },
88
- functions: this.$login.f
89
- }
90
- },
91
- props: ['show'],
92
- methods: {
93
- confirm () {
94
- let gen = saveGen(this)
95
- co(gen)
96
- },
97
- rest () {
98
- this.show = false
99
- this.deliver = {password: '', newpassword: '', affirmpassword: ''}
100
- }
101
- }
102
- }
103
- </script>
104
- <style>
105
- /*修改密码body界面样式*/
106
- .modifystyle {
107
- background: #FCFEEE;
108
- }
109
- .modifystyle span{
110
- color: red;
111
- }
112
- </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.strongpassword && !($v.newpassword.required),
22
+ 'has-success': !$v.newpassword.required && !$v.newpassword.strongpassword }">
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, strongpassword: true}'>
26
+ <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.newpassword.required && !($v.newpassword.strongpassword && !($v.newpassword.required))"></span>
27
+ <span v-if="$v.newpassword.required">不能为空</span>
28
+ <span v-if="$v.newpassword.strongpassword && !($v.newpassword.required)">密码必须包含英文大小写、阿拉伯数字、字符</span>
29
+ </div>
30
+ </div>
31
+ <div class="has-feedback form-group"
32
+ :class="{'has-warning':$v.affirmpassword.required,'has-error':$v.affirmpassword.equalValid && !($v.affirmpassword.required),
33
+ 'has-success': !$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))}">
34
+ <label for="affirmpassword" class="col-sm-4 col-sm-offset-1 control-label">确认密码:&nbsp;&nbsp;</label>
35
+ <div class="col-sm-4">
36
+ <input type="password" v-model="deliver.affirmpassword" class="form-control" id="affirmpassword" v-validate:affirmpassword="{ required: true, equalValid: deliver.newpassword }">
37
+ <span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))"></span>
38
+ <span v-if="$v.affirmpassword.required">不能为空</span>
39
+ <span v-if="$v.affirmpassword.equalValid && !($v.affirmpassword.required)">两次密码不一致 !!</span>
40
+ </div>
41
+ </div>
42
+ </article>
43
+
44
+ <footer slot="modal-footer" class="modal-footer">
45
+ <button type="button" class="btn btn-success" @click='confirm' :disabled="!$v.valid">确认</button>
46
+ <button type="button" class="btn btn-default" @click='rest'>取消</button>
47
+ </footer>
48
+ </modal>
49
+ </validator>
50
+ </div>
51
+
52
+
53
+ </template>
54
+ <script>
55
+ import co from 'co'
56
+ import validator from '../../plugins/validation';
57
+
58
+ let saveGen = function * (self) {
59
+ self.deliver.ename = self.functions.ename
60
+ // let res = yield self.$post('rs/user/entity', {data: self.deliver})
61
+ // let res = yield self.$post('rs/db/modifypassword', {data: self.deliver})
62
+ // let res = yield self.$resetpost('/rs/db/modifypwd', {data: self.deliver})
63
+ // Util.f.password = self.deliver.newpassword
64
+ let res = yield self.$resetpost('/rs/user/modifypwd', {data: self.deliver }, { resolveMsg: null, rejectMsg: '请求错误,修改密码失败!' })
65
+ self.$login.f.password = self.deliver.newpassword
66
+ if (res.data) {
67
+ console.log("修改密码返回:" , res.data)
68
+ if (res.data.code === 200) {
69
+ self.deliver.password = ''
70
+ self.deliver.newpassword = ''
71
+ self.deliver.affirmpassword = ''
72
+ self.show = false
73
+ self.$showAlert("修改密码成功", 'success', 2000)
74
+ } else {
75
+ self.$showAlert("修改密码失败,原因:" + res.data.msg, 'warning', 2000)
76
+ }
77
+ }
78
+ }
79
+ export default {
80
+ title: '系统管理-密码修改',
81
+ data () {
82
+ return {
83
+ deliver: {
84
+ password: '',
85
+ newpassword: '',
86
+ affirmpassword: ''
87
+ },
88
+ functions: this.$login.f
89
+ }
90
+ },
91
+ props: ['show'],
92
+ methods: {
93
+ confirm () {
94
+ let gen = saveGen(this)
95
+ co(gen)
96
+ },
97
+ rest () {
98
+ this.show = false
99
+ this.deliver = {password: '', newpassword: '', affirmpassword: ''}
100
+ }
101
+ }
102
+ }
103
+ </script>
104
+ <style>
105
+ /*修改密码body界面样式*/
106
+ .modifystyle {
107
+ background: #FCFEEE;
108
+ }
109
+ .modifystyle span{
110
+ color: red;
111
+ }
112
+ </style>
@@ -0,0 +1,53 @@
1
+ import AesEncryptJS from "crypto-js"
2
+ import RsaEncryptJS from 'jsencrypt'
3
+
4
+ export default {
5
+ /**
6
+ * AES加密
7
+ * @param word
8
+ * @returns {*}
9
+ */
10
+ AESEncrypt(word, encryKey){
11
+ var key = AesEncryptJS.enc.Utf8.parse(encryKey);
12
+ var srcs = AesEncryptJS.enc.Utf8.parse(word);
13
+ var encrypted = AesEncryptJS.AES.encrypt(srcs, key, {mode:AesEncryptJS.mode.ECB,padding: AesEncryptJS.pad.Pkcs7});
14
+ return encrypted.toString();
15
+ },
16
+ /**
17
+ * AES解密
18
+ * @param word
19
+ * @returns {*}
20
+ */
21
+ AESDecrypt(word, encryKey){
22
+ var key = AesEncryptJS.enc.Utf8.parse(encryKey);
23
+ var decrypt = AesEncryptJS.AES.decrypt(word, key, {mode:AesEncryptJS.mode.ECB,padding: AesEncryptJS.pad.Pkcs7});
24
+ var ret = AesEncryptJS.enc.Utf8.stringify(decrypt).toString();
25
+ try{
26
+ return JSON.parse(ret) ;
27
+ }catch (e){
28
+ return ret
29
+ }
30
+ },
31
+ /**
32
+ * RSA加密
33
+ * @param word
34
+ * @returns {*}
35
+ */
36
+ RSAEncrypt(word){
37
+ let encrypt = new RsaEncryptJS();
38
+ encrypt.setPublicKey('MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCqPvovSfXcwBbW8cKMCgwqNpsYuzF8RPAPFb7LGsnVo44JhM/xxzDyzoYtdfNmtbIuKVi9PzIsyp6rg+09gbuI6UGwBZ5DWBDBMqv5MPdOF5dCQkB2Bbr5yPfURPENypUz+pBFBg41d+BC+rwRiXELwKy7Y9caD/MtJyHydj8OUwIDAQAB');
39
+ let resdata = encrypt.encrypt(word);
40
+ return resdata.toString();
41
+ },
42
+ /**
43
+ * RSA解密
44
+ * @param word
45
+ * @returns {*}
46
+ */
47
+ RSADecrypt(word){
48
+ let encrypt = new RsaEncryptJS();
49
+ encrypt.setPrivateKey('MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAKo++i9J9dzAFtbxwowKDCo2mxi7MXxE8A8VvssaydWjjgmEz/HHMPLOhi1182a1si4pWL0/MizKnquD7T2Bu4jpQbAFnkNYEMEyq/kw904Xl0JCQHYFuvnI99RE8Q3KlTP6kEUGDjV34EL6vBGJcQvArLtj1xoP8y0nIfJ2Pw5TAgMBAAECgYAGGB8IllMwxceLhjf6n1l0IWRH7FuHIUieoZ6k0p6rASHSgWiYNRMxfecbtX8zDAoG0QAWNi7rn40ygpR5gS1fWDAKhmnhKgQIT6wW0VmD4hraaeyP78iy8BLhlvblri2nCPIhDH5+l96v7D47ZZi3ZSOzcj89s1eS/k7/N4peEQJBAPEtGGJY+lBoCxQMhGyzuzDmgcS1Un1ZE2pt+XNCVl2b+T8fxWJH3tRRR8wOY5uvtPiK1HM/IjT0T5qwQeH8Yk0CQQC0tcv3d/bDb7bOe9QzUFDQkUSpTdPWAgMX2OVPxjdq3Sls9oA5+fGNYEy0OgyqTjde0b4iRzlD1O0OhLqPSUMfAkEAh5FIvqezdRU2/PsYSR4yoAdCdLdT+h/jGRVefhqQ/6eYUJJkWp15tTFHQX3pIe9/s6IeT/XyHYAjaxmevxAmlQJBAKSdhvQjf9KAjZKDEsa7vyJ/coCXuQUWSCMNHbcR5aGfXgE4e45UtUoIE1eKGcd6AM6LWhx3rR6xdFDpb9je8BkCQB0SpevGfOQkMk5i8xkEt9eeYP0fi8nv6eOUcK96EXbzs4jV2SAoQJ9oJegPtPROHbhIvVUmNQTbuP10Yjg59+8=');
50
+ let resdata = encrypt.decrypt(word);
51
+ return JSON.parse(resdata.toString()) ;
52
+ },
53
+ }
@@ -1,495 +1,495 @@
1
- import Vue from 'vue'
2
- import JSEncrypt from 'jsencrypt'
3
- import {HttpResetClass} from 'vue-client'
4
-
5
- let loginGen = async function (name, password) {
6
- let data = {name: name, password: password}
7
- // rsa加密
8
- let encrypt = new JSEncrypt();
9
- encrypt.setPublicKey('MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCqPvovSfXcwBbW8cKMCgwqNpsYuzF8RPAPFb7LGsnVo44JhM/xxzDyzoYtdfNmtbIuKVi9PzIsyp6rg+09gbuI6UGwBZ5DWBDBMqv5MPdOF5dCQkB2Bbr5yPfURPENypUz+pBFBg41d+BC+rwRiXELwKy7Y9caD/MtJyHydj8OUwIDAQAB');
10
- const getLogin = await Vue.resetpost('/rs/logic/getLogin', data, {resolveMsg: null, rejectMsg: null}, 'RSA')
11
- if (getLogin.data.states === '登录成功') {
12
- // 调用远程登录服务,获取所有有权访问的功能
13
- data = {username: name, password: password}
14
- data = encrypt.encrypt(JSON.stringify(data))
15
- const resource = await Vue.resetpost(`/rs/user/userLogin/客服系统`, data, {
16
- resolveMsg: null, rejectMsg: null
17
- })
18
-
19
- if (resource.data.code !== 200) {
20
- throw {status: resource.data.code, data: resource.data.msg}
21
- }
22
-
23
- console.log('登陆获取Util', resource.data)
24
- Vue.$login.f = resource.data.data
25
- //获取jwt
26
- Vue.$login.jwt = getLogin.data.jwt
27
- // 把登录用户添加到cookie里
28
- Vue.cookie.set('loginId', Vue.$login.f.id)
29
-
30
- try {
31
- //获取有权限的功能树
32
- let hasRight = await Vue.resetpost(`/rs/search`, {
33
- source: "tool.getFullTree(this.getRights().where(row.getType() == $function$))", userid: Vue.$login.f.id
34
- }, {
35
- resolveMsg: null, rejectMsg: null
36
- })
37
- console.log('有权限功能返回数据', JSON.stringify(hasRight.data))
38
- //准备替换功能树
39
- var fun = []
40
- hasRight.data[0].children[0].children.forEach((item) => {
41
- if (item.name == '客服系统') {
42
- item.children.forEach((item1) => {
43
- fun.push(item1)
44
- })
45
- }
46
- })
47
- Vue.$login.f.functions = fun
48
- } catch (error) {
49
- }
50
- if (Vue.$login.f.id !== '11') {
51
- try {
52
- let getAllArea = await Vue.resetpost('/rs/search', {
53
- source: 'this.getParentByType($organization$).getChildByName($片区$).getChildren()', userid: Vue.$login.f.id
54
- }, {resolveMsg: null, rejectMsg: null})
55
-
56
- let areaTemp = []
57
- for (let i = 0; i < getAllArea.data.length; i++) {
58
- areaTemp.push({label: getAllArea.data[i].name, value: getAllArea.data[i]})
59
- }
60
- Vue.$login.f.f_allArea = areaTemp
61
- } catch (error) {
62
- Vue.$login.f.f_allArea = []
63
- console.log('获取区县', error)
64
- }
65
- // 获取抄表员
66
- try {
67
- let getGasman = await Vue.resetpost('/rs/search', {
68
- source: 'this.getParentByType($organization$).getChildByName($抄表员$).getUsers()', userid: Vue.$login.f.id
69
- }, {resolveMsg: null, rejectMsg: null})
70
- let gasman = []
71
- for (let i = 0; i < getGasman.data.length; i++) {
72
- gasman.push(getGasman.data[i])
73
- }
74
- Vue.$login.f.f_gasman = gasman
75
- } catch (error) {
76
- Vue.$login.f.f_gasman = []
77
- console.log('抄表员模块', error)
78
- }
79
- // // 获取安装人
80
- // try {
81
- // let getInstallman = await Vue.resetpost('/rs/search', {
82
- // source: 'this.getParentByType($organization$).getChildByName($安装员$).getUsers()',
83
- // userid: Vue.$login.f.id
84
- // }, {resolveMsg: null, rejectMsg: null})
85
- // console.log('获取安装员', getInstallman)
86
- // let installman = []
87
- // for (let i = 0; i < getInstallman.data.length; i++) {
88
- // installman.push(getInstallman.data[i])
89
- // }
90
- // Vue.$login.f.f_installman = installman
91
- // }catch (error) {
92
- // Vue.$login.f.f_installman =[]
93
- // console.log('安装人模块',error)
94
- // }
95
- // 获取换表员
96
- // try {
97
- // let getChangeMeterman = await Vue.resetpost('/rs/search', {
98
- // source: 'this.getParentByType($organization$).getChildByName($换表员$).getUsers()',
99
- // userid: Vue.$login.f.id
100
- // }, {resolveMsg: null, rejectMsg: null})
101
- // let changemeterman = []
102
- // for (let i = 0; i < getChangeMeterman.data.length; i++) {
103
- // changemeterman.push(getChangeMeterman.data[i])
104
- // }
105
- // Vue.$login.f.f_changemeterman = changemeterman
106
- // }catch (error) {
107
- // Vue.$login.f.f_changemeterman = []
108
- // console.log('换表员模块',error)
109
- // }
110
- // 获取资源服务权限
111
- try {
112
- let getLic = await Vue.resetpost('/rs/search', {
113
- data: {
114
- source: 'this.getRights().where(row.getType()==$function$ && row.getPath($name$).indexOf($资源操作$) != -1)',
115
- userid: Vue.$login.f.id
116
- }
117
- }, {resolveMsg: null, rejectMsg: null})
118
- let arry = []
119
- getLic.data.forEach((item) => {
120
- arry.push(item.name)
121
- })
122
- Vue.$login.f.lics = arry
123
- } catch (error) {
124
- Vue.$login.f.f_gasman = []
125
- console.log('资源服务权限', error)
126
- }
127
- // // 票据使用人
128
- // try {
129
- // let getPaperUseman = await Vue.resetpost('/rs/search', {
130
- // source: 'this.getParentByType($organization$).getChildByName($票据使用人$).getUsers()',
131
- // userid: Vue.$login.f.id
132
- // }, {resolveMsg: null, rejectMsg: null})
133
- // let perperuseman = []
134
- // for (let i = 0; i < getPaperUseman.data.length; i++) {
135
- // perperuseman.push(getPaperUseman.data[i])
136
- // }
137
- // Vue.$login.f.f_paperUseman = perperuseman
138
- // }catch (error) {
139
- // Vue.$login.f.f_paperUseman = []
140
- // console.log('票据使用人模块',error)
141
- //
142
- // }
143
- // // 票据分配人
144
- // try {
145
- // let getPaperAllotman = await Vue.resetpost('/rs/search', {
146
- // source: 'this.getParentByType($organization$).getChildByName($票据分配人$).getUsers()',
147
- // userid: Vue.$login.f.id
148
- // }, {resolveMsg: null, rejectMsg: null})
149
- // let paperallotman = []
150
- // for (let i = 0; i < getPaperAllotman.data.length; i++) {
151
- // paperallotman.push(getPaperAllotman.data[i])
152
- // }
153
- // Vue.$login.f.f_paperAllotman = paperallotman
154
- // }catch (error) {
155
- // Vue.$login.f.f_paperAllotman = []
156
- // console.log('票据分配人模块',error)
157
- // }
158
- // TODO 处理界面细节
159
- try {
160
- let viewDetails = await Vue.resetpost('rs/search', {
161
- source: 'this.getRights().where(row.getType()==$function$ && row.getPath($name$).indexOf($功能权限$) != -1)',
162
- userid: Vue.$login.f.id
163
- }, {resolveMsg: null, rejectMsg: null})
164
- let r = viewDetails.data
165
- Vue.$login.r = []
166
- r.forEach(x => Vue.$login.r.push(x.name))
167
- } catch (error) {
168
- Vue.$login.r = []
169
- console.log('加载模块失败', error)
170
- }
171
- // 调用登录后处理
172
- for (let proc of Vue.$login.afterLogin) {
173
- await proc(Vue.$login.f)
174
- }
175
- // 定时发送心跳
176
- setInterval(() => {
177
- let http = new HttpResetClass()
178
- //暂时不出现不出现异地登录校验
179
- http.load('POST', `rs/user/access/${Vue.$login.f.id}`, {}, {resolveMsg: null, rejectMsg: null}).then((req) => {
180
- if (req.data.status == 710) {
181
- Vue.showMessage(req.data.msg + ",您将被强制退出系统", ['confirm']).then((res) => {
182
- if (res === 'confirm') {
183
- location.reload()
184
- }
185
- })
186
- }
187
- })
188
- }, 2 * 60 * 1000)
189
- }
190
-
191
- } else {
192
- // 抛出错误
193
- throw {status: 401, data: getLogin.data.states}
194
- }
195
- }
196
-
197
- let GetLoginInfoService = {
198
- // 登录后要处理的异步对象
199
- afterLogin: [], //验证码开关
200
- Verification: true, install(Vue, options) {
201
- // 给vue增添对话框显示方法
202
- Vue.$login = Vue.prototype.$login = GetLoginInfoService
203
- },
204
-
205
- f: {},
206
-
207
- /**
208
- * 登录
209
- * @param name
210
- * @param password
211
- */
212
- login(name, password) {
213
- return loginGen(name, password)
214
- },
215
-
216
- convertToIn(val) {
217
- let temp = ''
218
- if (val instanceof Array) {
219
- if (val.length >= 1) {
220
- temp = '('
221
- val.forEach((res) => {
222
- temp += `'${res}',`
223
- })
224
- temp = temp.substr(0, temp.length - 1) + ')'
225
- }
226
- }
227
- return temp
228
- },
229
-
230
- toStandardYearMonth() {
231
- let dt = new Date()
232
- let month = dt.getMonth() + 1
233
- return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month)
234
- },
235
-
236
- toStandardYearMonth1() {
237
- let dt = new Date()
238
- let month = dt.getMonth() + 1
239
- return dt.getFullYear() + (month < 10 ? '0' + month : month)
240
- },
241
-
242
- toStandardDateString() {
243
- let dt = new Date()
244
- let month = dt.getMonth() + 1
245
- let date = dt.getDate()
246
- return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
247
- },
248
-
249
- toStartAndEndDateString() {
250
- let dt = new Date()
251
- let month = dt.getMonth() + 1
252
- // let date = dt.getDate()
253
- return [dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-01', dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (new Date(dt.getFullYear(), month, 0).getDate())]
254
- // return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
255
- },
256
-
257
- toStandardTimeString() {
258
- let dt = new Date()
259
- let month = dt.getMonth() + 1
260
- let date = dt.getDate()
261
- let hour = dt.getHours()
262
- let min = dt.getMinutes()
263
- let sec = dt.getSeconds()
264
- return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date) + ' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
265
- },
266
-
267
- guid() {
268
- let buf = new Uint16Array(8)
269
- window.crypto.getRandomValues(buf)
270
- let S4 = function (num) {
271
- let ret = num.toString(16)
272
- while (ret.length < 4) {
273
- ret = '0' + ret
274
- }
275
- return ret
276
- }
277
- return (S4(buf[0]) + S4(buf[1]) + S4(buf[2]) + S4(buf[3]) + S4(buf[4]) + S4(buf[5]) + S4(buf[6]) + S4(buf[7]))
278
- },
279
-
280
- choices(role, param, hasBlank = false, blankHint = '请选择') {
281
- if (role == 'view') {
282
- Vue.getParams(param, [null])
283
- } else {
284
- let result = []
285
- if (hasBlank)
286
- result.push({label: blankHint, value: null})
287
- if (!Vue.param || !Vue.param[param])
288
- result.push({label: '请在系统设置里更新参数', value: '请在系统设置里更新参数'})
289
- else {
290
- let p = Vue.param[param]
291
- p.forEach(function (item) {
292
- result.push({label: item.name, value: item.name})
293
- })
294
- }
295
- return result
296
- }
297
- },
298
-
299
- required(param) {
300
- if (typeof param === 'number' && param == 0) return false
301
- if (!param) return true
302
- param = param + ''
303
- param = param.trim()
304
- if (!param) return true
305
- return false
306
- },
307
-
308
- isInt(n) {
309
- return !window.isNaN(n) && n % 1 === 0
310
- },
311
-
312
- isFloat(n) {
313
- return !window.isNaN(n)
314
- },
315
-
316
- // this will convert all true/false to boolean
317
- booleanFilter(paper) {
318
- for (let key in paper) {
319
- if (!paper.hasOwnProperty(key)) continue
320
- if (typeof paper[key] == 'object' && paper[key] != null) {
321
- booleanFilter(paper[key])
322
- } else {
323
- if (paper[key] === 'true' || paper[key] == 'false') paper[key] = (paper[key] === 'true')
324
- }
325
- }
326
- }, // recursively traverse through each path
327
- ratifyPics(paper) {
328
- for (let key in paper) {
329
- if (key.endsWith('_path')) {
330
- if (!paper[key]) {
331
- paper[key] = 'rs/db/file/nopic.png'
332
- } else {
333
- paper[key] = 'rs/db/file/' + paper[key]
334
- }
335
- } else if (paper[key] !== null && typeof (paper[key]) == 'object') {
336
- ratifyPics(paper[key])
337
- }
338
- }
339
- },
340
-
341
- // load script and other stuff
342
- loadscript(type, fileName) {
343
- return new Promise((resolve, reject) => {
344
- let element
345
- if (type == 'css') {
346
- element = document.createElement('link')
347
- element.setAttribute('rel', 'stylesheet')
348
- element.setAttribute('type', 'text/css')
349
- element.setAttribute('href', fileName)
350
- } else if (type == 'js') {
351
- element = document.createElement('script')
352
- element.setAttribute('type', 'text/javascript')
353
- element.setAttribute('src', fileName)
354
- }
355
- if (element) {
356
- element.setAttribute('async', '')
357
- element.setAttribute('defer', '')
358
- element.addEventListener('load', function () {
359
- resolve(element)
360
- }, false)
361
- element.addEventListener('error', function () {
362
- reject(element)
363
- }, false)
364
- document.body.appendChild(element)
365
- }
366
- })
367
- }, // 不能选择器中截取掉多余的字符
368
- orgName(name) {
369
- return name.substring(10)
370
- },
371
-
372
- getNowDate(name) {
373
- // 求取当前时间的工具
374
- let myweekday = ''
375
- let year = ''
376
- let mydate = new Date()
377
- myweekday = mydate.getDay()
378
- let mymonth = mydate.getMonth() + 1
379
- let myday = mydate.getDate()
380
- let myyear = mydate.getYear()
381
- year = (myyear > 200) ? myyear : 1900 + myyear
382
- let week = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期日', '星期六']
383
- // document.write("<font color=#ffffff>今天是 "+year+"年"+mymonth+"月"+myday+"日 "+weekday+"</font>");
384
- return year + '年' + mymonth + '月' + myday + '日 ' + week[myweekday]
385
- },
386
-
387
- addDate(date, days) {
388
- // 求取当前时间的工具
389
- let endDate = new Date(date)
390
- endDate = endDate.valueOf()
391
- endDate = endDate + days * 24 * 60 * 60 * 1000
392
- endDate = new Date(endDate)
393
- let month = endDate.getMonth() + 1
394
- let day = endDate.getDate()
395
- let hour = endDate.getHours()
396
- let min = endDate.getMinutes()
397
- let sec = endDate.getSeconds()
398
- return endDate.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (day < 10 ? '0' + day : day) + ' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
399
- // return a
400
- },
401
-
402
- // 通过地址栏的参数获取参数内容
403
- getUrlParames(param) {
404
- var query = window.location.search
405
- var iLen = param.length
406
- var iStart = query.indexOf(param)
407
- if (iStart === -1) {
408
- return ''
409
- }
410
- iStart += iLen + 1
411
- var iEnd = query.indexOf('&', iStart)
412
- if (iEnd === -1) {
413
- return query.substring(iStart)
414
- }
415
- return query.substring(iStart, iEnd)
416
- },
417
-
418
- // 从地址栏获取加密的参数
419
- getUrlCompileParames(param) {
420
- let code = unescape(window.location.search.slice(1, window.location.search.length))
421
- let query = String.fromCharCode(code.charCodeAt(0) - code.length)
422
- for (var i = 1; i < code.length; i++) {
423
- query += String.fromCharCode(code.charCodeAt(i) - query.charCodeAt(i - 1))
424
- }
425
- let iLen = param.length
426
- let iStart = query.indexOf(param)
427
- if (iStart === -1) {
428
- return ''
429
- }
430
- iStart += iLen + 1
431
- let iEnd = query.indexOf('&', iStart)
432
- if (iEnd === -1) {
433
- return query.substring(iStart)
434
- }
435
- return query.substring(iStart, iEnd)
436
- },
437
-
438
- // 对字符串进行加密
439
- compileStr(code) {
440
- let c = String.fromCharCode(code.charCodeAt(0) + code.length)
441
- for (let i = 1; i < code.length; i++) {
442
- c += String.fromCharCode(code.charCodeAt(i) + code.charCodeAt(i - 1))
443
- }
444
- return escape(c)
445
- }, // 字符串进行解密
446
- uncompileStr(code) {
447
- code = unescape(code)
448
- let c = String.fromCharCode(code.charCodeAt(0) - code.length)
449
- for (var i = 1; i < code.length; i++) {
450
- c += String.fromCharCode(code.charCodeAt(i) - c.charCodeAt(i - 1))
451
- }
452
- return c
453
- },
454
-
455
- dateDescripte(date) {
456
- let nowTime = new Date().getTime()
457
- let oldTime = new Date(date).getTime()
458
- let timeDiff = nowTime - oldTime
459
- // 规则说明
460
- // 小于等于2分钟为刚刚
461
- // 大于2分钟小于等于1小时为取整的分钟前(例如:35分钟前)
462
- // 大于1小时小于等于24小时为取整的小时前(例如:15小时前)
463
- // 大于24小时小于等于30天为取整的天前(例如:12天前)
464
- // 大于30天小于等于12月为取整的月前,月份统一为30天一月,不做额外处理(例如:3个月前)
465
- // 大于365取整的年前,(例如:2年前)
466
- let minute = 1000 * 60
467
- let hour = minute * 60
468
- let day = hour * 24
469
- let month = day * 30
470
- let year = month * 12
471
- let des = ''
472
- if (timeDiff <= minute * 2) {
473
- des = '刚刚'
474
- } else if (minute * 2 < timeDiff && timeDiff < hour) {
475
- des = `${Math.floor(timeDiff / minute)}分钟前`
476
- } else if (hour < timeDiff && timeDiff <= day) {
477
- des = `${Math.floor(timeDiff / hour)}小时前`
478
- } else if (day < timeDiff && timeDiff <= month) {
479
- des = `${Math.floor(timeDiff / day)}天前`
480
- } else if (month < timeDiff && timeDiff <= year) {
481
- des = `${Math.floor(timeDiff / month)}个月前`
482
- } else if (year < timeDiff) {
483
- des = `${Math.floor(timeDiff / year)}年前`
484
- }
485
- return des
486
- },
487
-
488
- nextMonth20(date) {
489
- let ds = date.split('-')
490
- let nextMonth = ds[1] - 0 + 1
491
- return ds[0] + '-' + (nextMonth < 10 ? '0' + nextMonth : nextMonth) + '-20 00:00:00'
492
- }
493
- }
494
-
495
- export default GetLoginInfoService
1
+ import Vue from 'vue'
2
+ import JSEncrypt from 'jsencrypt'
3
+ import {HttpResetClass} from 'vue-client'
4
+
5
+ let loginGen = async function (name, password) {
6
+ let data = {name: name, password: password}
7
+ // rsa加密
8
+ let encrypt = new JSEncrypt();
9
+ encrypt.setPublicKey('MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCqPvovSfXcwBbW8cKMCgwqNpsYuzF8RPAPFb7LGsnVo44JhM/xxzDyzoYtdfNmtbIuKVi9PzIsyp6rg+09gbuI6UGwBZ5DWBDBMqv5MPdOF5dCQkB2Bbr5yPfURPENypUz+pBFBg41d+BC+rwRiXELwKy7Y9caD/MtJyHydj8OUwIDAQAB');
10
+ const getLogin = await Vue.resetpost('/rs/logic/getLogin', data, {resolveMsg: null, rejectMsg: null}, 'RSA')
11
+ if (getLogin.data.states === '登录成功') {
12
+ // 调用远程登录服务,获取所有有权访问的功能
13
+ data = {username: name, password: password}
14
+ data = encrypt.encrypt(JSON.stringify(data))
15
+ const resource = await Vue.resetpost(`/rs/user/userLogin/客服系统`, data, {
16
+ resolveMsg: null, rejectMsg: null
17
+ })
18
+
19
+ if (resource.data.code !== 200) {
20
+ throw {status: resource.data.code, data: resource.data.msg}
21
+ }
22
+
23
+ console.log('登陆获取Util', resource.data)
24
+ Vue.$login.f = resource.data.data
25
+ //获取jwt
26
+ Vue.$login.jwt = getLogin.data.jwt
27
+ // 把登录用户添加到cookie里
28
+ Vue.cookie.set('loginId', Vue.$login.f.id)
29
+
30
+ try {
31
+ //获取有权限的功能树
32
+ let hasRight = await Vue.resetpost(`/rs/search`, {
33
+ source: "tool.getFullTree(this.getRights().where(row.getType() == $function$))", userid: Vue.$login.f.id
34
+ }, {
35
+ resolveMsg: null, rejectMsg: null
36
+ })
37
+ console.log('有权限功能返回数据', JSON.stringify(hasRight.data))
38
+ //准备替换功能树
39
+ var fun = []
40
+ hasRight.data[0].children[0].children.forEach((item) => {
41
+ if (item.name == '客服系统') {
42
+ item.children.forEach((item1) => {
43
+ fun.push(item1)
44
+ })
45
+ }
46
+ })
47
+ Vue.$login.f.functions = fun
48
+ } catch (error) {
49
+ }
50
+ if (Vue.$login.f.id !== '11') {
51
+ try {
52
+ let getAllArea = await Vue.resetpost('/rs/search', {
53
+ source: 'this.getParentByType($organization$).getChildByName($片区$).getChildren()', userid: Vue.$login.f.id
54
+ }, {resolveMsg: null, rejectMsg: null})
55
+
56
+ let areaTemp = []
57
+ for (let i = 0; i < getAllArea.data.length; i++) {
58
+ areaTemp.push({label: getAllArea.data[i].name, value: getAllArea.data[i]})
59
+ }
60
+ Vue.$login.f.f_allArea = areaTemp
61
+ } catch (error) {
62
+ Vue.$login.f.f_allArea = []
63
+ console.log('获取区县', error)
64
+ }
65
+ // 获取抄表员
66
+ try {
67
+ let getGasman = await Vue.resetpost('/rs/search', {
68
+ source: 'this.getParentByType($organization$).getChildByName($抄表员$).getUsers()', userid: Vue.$login.f.id
69
+ }, {resolveMsg: null, rejectMsg: null})
70
+ let gasman = []
71
+ for (let i = 0; i < getGasman.data.length; i++) {
72
+ gasman.push(getGasman.data[i])
73
+ }
74
+ Vue.$login.f.f_gasman = gasman
75
+ } catch (error) {
76
+ Vue.$login.f.f_gasman = []
77
+ console.log('抄表员模块', error)
78
+ }
79
+ // // 获取安装人
80
+ // try {
81
+ // let getInstallman = await Vue.resetpost('/rs/search', {
82
+ // source: 'this.getParentByType($organization$).getChildByName($安装员$).getUsers()',
83
+ // userid: Vue.$login.f.id
84
+ // }, {resolveMsg: null, rejectMsg: null})
85
+ // console.log('获取安装员', getInstallman)
86
+ // let installman = []
87
+ // for (let i = 0; i < getInstallman.data.length; i++) {
88
+ // installman.push(getInstallman.data[i])
89
+ // }
90
+ // Vue.$login.f.f_installman = installman
91
+ // }catch (error) {
92
+ // Vue.$login.f.f_installman =[]
93
+ // console.log('安装人模块',error)
94
+ // }
95
+ // 获取换表员
96
+ // try {
97
+ // let getChangeMeterman = await Vue.resetpost('/rs/search', {
98
+ // source: 'this.getParentByType($organization$).getChildByName($换表员$).getUsers()',
99
+ // userid: Vue.$login.f.id
100
+ // }, {resolveMsg: null, rejectMsg: null})
101
+ // let changemeterman = []
102
+ // for (let i = 0; i < getChangeMeterman.data.length; i++) {
103
+ // changemeterman.push(getChangeMeterman.data[i])
104
+ // }
105
+ // Vue.$login.f.f_changemeterman = changemeterman
106
+ // }catch (error) {
107
+ // Vue.$login.f.f_changemeterman = []
108
+ // console.log('换表员模块',error)
109
+ // }
110
+ // 获取资源服务权限
111
+ try {
112
+ let getLic = await Vue.resetpost('/rs/search', {
113
+ data: {
114
+ source: 'this.getRights().where(row.getType()==$function$ && row.getPath($name$).indexOf($资源操作$) != -1)',
115
+ userid: Vue.$login.f.id
116
+ }
117
+ }, {resolveMsg: null, rejectMsg: null})
118
+ let arry = []
119
+ getLic.data.forEach((item) => {
120
+ arry.push(item.name)
121
+ })
122
+ Vue.$login.f.lics = arry
123
+ } catch (error) {
124
+ Vue.$login.f.f_gasman = []
125
+ console.log('资源服务权限', error)
126
+ }
127
+ // // 票据使用人
128
+ // try {
129
+ // let getPaperUseman = await Vue.resetpost('/rs/search', {
130
+ // source: 'this.getParentByType($organization$).getChildByName($票据使用人$).getUsers()',
131
+ // userid: Vue.$login.f.id
132
+ // }, {resolveMsg: null, rejectMsg: null})
133
+ // let perperuseman = []
134
+ // for (let i = 0; i < getPaperUseman.data.length; i++) {
135
+ // perperuseman.push(getPaperUseman.data[i])
136
+ // }
137
+ // Vue.$login.f.f_paperUseman = perperuseman
138
+ // }catch (error) {
139
+ // Vue.$login.f.f_paperUseman = []
140
+ // console.log('票据使用人模块',error)
141
+ //
142
+ // }
143
+ // // 票据分配人
144
+ // try {
145
+ // let getPaperAllotman = await Vue.resetpost('/rs/search', {
146
+ // source: 'this.getParentByType($organization$).getChildByName($票据分配人$).getUsers()',
147
+ // userid: Vue.$login.f.id
148
+ // }, {resolveMsg: null, rejectMsg: null})
149
+ // let paperallotman = []
150
+ // for (let i = 0; i < getPaperAllotman.data.length; i++) {
151
+ // paperallotman.push(getPaperAllotman.data[i])
152
+ // }
153
+ // Vue.$login.f.f_paperAllotman = paperallotman
154
+ // }catch (error) {
155
+ // Vue.$login.f.f_paperAllotman = []
156
+ // console.log('票据分配人模块',error)
157
+ // }
158
+ // TODO 处理界面细节
159
+ try {
160
+ let viewDetails = await Vue.resetpost('rs/search', {
161
+ source: 'this.getRights().where(row.getType()==$function$ && row.getPath($name$).indexOf($功能权限$) != -1)',
162
+ userid: Vue.$login.f.id
163
+ }, {resolveMsg: null, rejectMsg: null})
164
+ let r = viewDetails.data
165
+ Vue.$login.r = []
166
+ r.forEach(x => Vue.$login.r.push(x.name))
167
+ } catch (error) {
168
+ Vue.$login.r = []
169
+ console.log('加载模块失败', error)
170
+ }
171
+ // 调用登录后处理
172
+ for (let proc of Vue.$login.afterLogin) {
173
+ await proc(Vue.$login.f)
174
+ }
175
+ // 定时发送心跳
176
+ setInterval(() => {
177
+ let http = new HttpResetClass()
178
+ //暂时不出现不出现异地登录校验
179
+ http.load('POST', `rs/user/access/${Vue.$login.f.id}`, {}, {resolveMsg: null, rejectMsg: null}).then((req) => {
180
+ if (req.data.status == 710) {
181
+ Vue.showMessage(req.data.msg + ",您将被强制退出系统", ['confirm']).then((res) => {
182
+ if (res === 'confirm') {
183
+ location.reload()
184
+ }
185
+ })
186
+ }
187
+ })
188
+ }, 2 * 60 * 1000)
189
+ }
190
+
191
+ } else {
192
+ // 抛出错误
193
+ throw {status: 401, data: getLogin.data.states}
194
+ }
195
+ }
196
+
197
+ let GetLoginInfoService = {
198
+ // 登录后要处理的异步对象
199
+ afterLogin: [], //验证码开关
200
+ Verification: true, install(Vue, options) {
201
+ // 给vue增添对话框显示方法
202
+ Vue.$login = Vue.prototype.$login = GetLoginInfoService
203
+ },
204
+
205
+ f: {},
206
+
207
+ /**
208
+ * 登录
209
+ * @param name
210
+ * @param password
211
+ */
212
+ login(name, password) {
213
+ return loginGen(name, password)
214
+ },
215
+
216
+ convertToIn(val) {
217
+ let temp = ''
218
+ if (val instanceof Array) {
219
+ if (val.length >= 1) {
220
+ temp = '('
221
+ val.forEach((res) => {
222
+ temp += `'${res}',`
223
+ })
224
+ temp = temp.substr(0, temp.length - 1) + ')'
225
+ }
226
+ }
227
+ return temp
228
+ },
229
+
230
+ toStandardYearMonth() {
231
+ let dt = new Date()
232
+ let month = dt.getMonth() + 1
233
+ return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month)
234
+ },
235
+
236
+ toStandardYearMonth1() {
237
+ let dt = new Date()
238
+ let month = dt.getMonth() + 1
239
+ return dt.getFullYear() + (month < 10 ? '0' + month : month)
240
+ },
241
+
242
+ toStandardDateString() {
243
+ let dt = new Date()
244
+ let month = dt.getMonth() + 1
245
+ let date = dt.getDate()
246
+ return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
247
+ },
248
+
249
+ toStartAndEndDateString() {
250
+ let dt = new Date()
251
+ let month = dt.getMonth() + 1
252
+ // let date = dt.getDate()
253
+ return [dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-01', dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (new Date(dt.getFullYear(), month, 0).getDate())]
254
+ // return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
255
+ },
256
+
257
+ toStandardTimeString() {
258
+ let dt = new Date()
259
+ let month = dt.getMonth() + 1
260
+ let date = dt.getDate()
261
+ let hour = dt.getHours()
262
+ let min = dt.getMinutes()
263
+ let sec = dt.getSeconds()
264
+ return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date) + ' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
265
+ },
266
+
267
+ guid() {
268
+ let buf = new Uint16Array(8)
269
+ window.crypto.getRandomValues(buf)
270
+ let S4 = function (num) {
271
+ let ret = num.toString(16)
272
+ while (ret.length < 4) {
273
+ ret = '0' + ret
274
+ }
275
+ return ret
276
+ }
277
+ return (S4(buf[0]) + S4(buf[1]) + S4(buf[2]) + S4(buf[3]) + S4(buf[4]) + S4(buf[5]) + S4(buf[6]) + S4(buf[7]))
278
+ },
279
+
280
+ choices(role, param, hasBlank = false, blankHint = '请选择') {
281
+ if (role == 'view') {
282
+ Vue.getParams(param, [null])
283
+ } else {
284
+ let result = []
285
+ if (hasBlank)
286
+ result.push({label: blankHint, value: null})
287
+ if (!Vue.param || !Vue.param[param])
288
+ result.push({label: '请在系统设置里更新参数', value: '请在系统设置里更新参数'})
289
+ else {
290
+ let p = Vue.param[param]
291
+ p.forEach(function (item) {
292
+ result.push({label: item.name, value: item.name})
293
+ })
294
+ }
295
+ return result
296
+ }
297
+ },
298
+
299
+ required(param) {
300
+ if (typeof param === 'number' && param == 0) return false
301
+ if (!param) return true
302
+ param = param + ''
303
+ param = param.trim()
304
+ if (!param) return true
305
+ return false
306
+ },
307
+
308
+ isInt(n) {
309
+ return !window.isNaN(n) && n % 1 === 0
310
+ },
311
+
312
+ isFloat(n) {
313
+ return !window.isNaN(n)
314
+ },
315
+
316
+ // this will convert all true/false to boolean
317
+ booleanFilter(paper) {
318
+ for (let key in paper) {
319
+ if (!paper.hasOwnProperty(key)) continue
320
+ if (typeof paper[key] == 'object' && paper[key] != null) {
321
+ booleanFilter(paper[key])
322
+ } else {
323
+ if (paper[key] === 'true' || paper[key] == 'false') paper[key] = (paper[key] === 'true')
324
+ }
325
+ }
326
+ }, // recursively traverse through each path
327
+ ratifyPics(paper) {
328
+ for (let key in paper) {
329
+ if (key.endsWith('_path')) {
330
+ if (!paper[key]) {
331
+ paper[key] = 'rs/db/file/nopic.png'
332
+ } else {
333
+ paper[key] = 'rs/db/file/' + paper[key]
334
+ }
335
+ } else if (paper[key] !== null && typeof (paper[key]) == 'object') {
336
+ ratifyPics(paper[key])
337
+ }
338
+ }
339
+ },
340
+
341
+ // load script and other stuff
342
+ loadscript(type, fileName) {
343
+ return new Promise((resolve, reject) => {
344
+ let element
345
+ if (type == 'css') {
346
+ element = document.createElement('link')
347
+ element.setAttribute('rel', 'stylesheet')
348
+ element.setAttribute('type', 'text/css')
349
+ element.setAttribute('href', fileName)
350
+ } else if (type == 'js') {
351
+ element = document.createElement('script')
352
+ element.setAttribute('type', 'text/javascript')
353
+ element.setAttribute('src', fileName)
354
+ }
355
+ if (element) {
356
+ element.setAttribute('async', '')
357
+ element.setAttribute('defer', '')
358
+ element.addEventListener('load', function () {
359
+ resolve(element)
360
+ }, false)
361
+ element.addEventListener('error', function () {
362
+ reject(element)
363
+ }, false)
364
+ document.body.appendChild(element)
365
+ }
366
+ })
367
+ }, // 不能选择器中截取掉多余的字符
368
+ orgName(name) {
369
+ return name.substring(10)
370
+ },
371
+
372
+ getNowDate(name) {
373
+ // 求取当前时间的工具
374
+ let myweekday = ''
375
+ let year = ''
376
+ let mydate = new Date()
377
+ myweekday = mydate.getDay()
378
+ let mymonth = mydate.getMonth() + 1
379
+ let myday = mydate.getDate()
380
+ let myyear = mydate.getYear()
381
+ year = (myyear > 200) ? myyear : 1900 + myyear
382
+ let week = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期日', '星期六']
383
+ // document.write("<font color=#ffffff>今天是 "+year+"年"+mymonth+"月"+myday+"日 "+weekday+"</font>");
384
+ return year + '年' + mymonth + '月' + myday + '日 ' + week[myweekday]
385
+ },
386
+
387
+ addDate(date, days) {
388
+ // 求取当前时间的工具
389
+ let endDate = new Date(date)
390
+ endDate = endDate.valueOf()
391
+ endDate = endDate + days * 24 * 60 * 60 * 1000
392
+ endDate = new Date(endDate)
393
+ let month = endDate.getMonth() + 1
394
+ let day = endDate.getDate()
395
+ let hour = endDate.getHours()
396
+ let min = endDate.getMinutes()
397
+ let sec = endDate.getSeconds()
398
+ return endDate.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (day < 10 ? '0' + day : day) + ' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
399
+ // return a
400
+ },
401
+
402
+ // 通过地址栏的参数获取参数内容
403
+ getUrlParames(param) {
404
+ var query = window.location.search
405
+ var iLen = param.length
406
+ var iStart = query.indexOf(param)
407
+ if (iStart === -1) {
408
+ return ''
409
+ }
410
+ iStart += iLen + 1
411
+ var iEnd = query.indexOf('&', iStart)
412
+ if (iEnd === -1) {
413
+ return query.substring(iStart)
414
+ }
415
+ return query.substring(iStart, iEnd)
416
+ },
417
+
418
+ // 从地址栏获取加密的参数
419
+ getUrlCompileParames(param) {
420
+ let code = unescape(window.location.search.slice(1, window.location.search.length))
421
+ let query = String.fromCharCode(code.charCodeAt(0) - code.length)
422
+ for (var i = 1; i < code.length; i++) {
423
+ query += String.fromCharCode(code.charCodeAt(i) - query.charCodeAt(i - 1))
424
+ }
425
+ let iLen = param.length
426
+ let iStart = query.indexOf(param)
427
+ if (iStart === -1) {
428
+ return ''
429
+ }
430
+ iStart += iLen + 1
431
+ let iEnd = query.indexOf('&', iStart)
432
+ if (iEnd === -1) {
433
+ return query.substring(iStart)
434
+ }
435
+ return query.substring(iStart, iEnd)
436
+ },
437
+
438
+ // 对字符串进行加密
439
+ compileStr(code) {
440
+ let c = String.fromCharCode(code.charCodeAt(0) + code.length)
441
+ for (let i = 1; i < code.length; i++) {
442
+ c += String.fromCharCode(code.charCodeAt(i) + code.charCodeAt(i - 1))
443
+ }
444
+ return escape(c)
445
+ }, // 字符串进行解密
446
+ uncompileStr(code) {
447
+ code = unescape(code)
448
+ let c = String.fromCharCode(code.charCodeAt(0) - code.length)
449
+ for (var i = 1; i < code.length; i++) {
450
+ c += String.fromCharCode(code.charCodeAt(i) - c.charCodeAt(i - 1))
451
+ }
452
+ return c
453
+ },
454
+
455
+ dateDescripte(date) {
456
+ let nowTime = new Date().getTime()
457
+ let oldTime = new Date(date).getTime()
458
+ let timeDiff = nowTime - oldTime
459
+ // 规则说明
460
+ // 小于等于2分钟为刚刚
461
+ // 大于2分钟小于等于1小时为取整的分钟前(例如:35分钟前)
462
+ // 大于1小时小于等于24小时为取整的小时前(例如:15小时前)
463
+ // 大于24小时小于等于30天为取整的天前(例如:12天前)
464
+ // 大于30天小于等于12月为取整的月前,月份统一为30天一月,不做额外处理(例如:3个月前)
465
+ // 大于365取整的年前,(例如:2年前)
466
+ let minute = 1000 * 60
467
+ let hour = minute * 60
468
+ let day = hour * 24
469
+ let month = day * 30
470
+ let year = month * 12
471
+ let des = ''
472
+ if (timeDiff <= minute * 2) {
473
+ des = '刚刚'
474
+ } else if (minute * 2 < timeDiff && timeDiff < hour) {
475
+ des = `${Math.floor(timeDiff / minute)}分钟前`
476
+ } else if (hour < timeDiff && timeDiff <= day) {
477
+ des = `${Math.floor(timeDiff / hour)}小时前`
478
+ } else if (day < timeDiff && timeDiff <= month) {
479
+ des = `${Math.floor(timeDiff / day)}天前`
480
+ } else if (month < timeDiff && timeDiff <= year) {
481
+ des = `${Math.floor(timeDiff / month)}个月前`
482
+ } else if (year < timeDiff) {
483
+ des = `${Math.floor(timeDiff / year)}年前`
484
+ }
485
+ return des
486
+ },
487
+
488
+ nextMonth20(date) {
489
+ let ds = date.split('-')
490
+ let nextMonth = ds[1] - 0 + 1
491
+ return ds[0] + '-' + (nextMonth < 10 ? '0' + nextMonth : nextMonth) + '-20 00:00:00'
492
+ }
493
+ }
494
+
495
+ export default GetLoginInfoService