system-clients 3.3.3 → 3.3.5

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