system-clients 3.2.2 → 3.2.3-aodeToV4

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.
Files changed (60) hide show
  1. package/.gradle/7.1/dependencies-accessors/dependencies-accessors.lock +0 -0
  2. package/.gradle/7.1/executionHistory/executionHistory.bin +0 -0
  3. package/.gradle/7.1/executionHistory/executionHistory.lock +0 -0
  4. package/.gradle/7.1/fileChanges/last-build.bin +0 -0
  5. package/.gradle/7.1/fileHashes/fileHashes.bin +0 -0
  6. package/.gradle/7.1/fileHashes/fileHashes.lock +0 -0
  7. package/.gradle/buildOutputCleanup/buildOutputCleanup.lock +0 -0
  8. package/.gradle/buildOutputCleanup/cache.properties +2 -2
  9. package/.gradle/buildOutputCleanup/outputFiles.bin +0 -0
  10. package/.gradle/checksums/checksums.lock +0 -0
  11. package/build/webpack.base.conf.js +4 -1
  12. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  13. package/gradle/wrapper/gradle-wrapper.properties +5 -0
  14. package/gradlew +185 -0
  15. package/gradlew.bat +89 -0
  16. package/package.json +102 -102
  17. package/src/App.vue +1 -1
  18. package/src/components/Main.vue +515 -621
  19. package/src/components/equipment/EquipmentManage.vue +3 -3
  20. package/src/components/equipment/PcAdd.vue +1 -1
  21. package/src/components/equipment/PcList.vue +4 -3
  22. package/src/components/equipment/PhoneAdd.vue +1 -1
  23. package/src/components/equipment/PhoneList.vue +2 -2
  24. package/src/components/equipment/PosAdd.vue +24 -5
  25. package/src/components/equipment/PosList.vue +15 -15
  26. package/src/components/equipment/PosManage.vue +3 -2
  27. package/src/components/materialManage/materialList.vue +1 -1
  28. package/src/components/parammanage/ParamPage.vue +6 -6
  29. package/src/components/parammanage/ParamPages.vue +5 -5
  30. package/src/components/parammanage/SinglePage.vue +3 -3
  31. package/src/components/parammanage/SinglePages.vue +3 -3
  32. package/src/components/server/AddChangeMsg.vue +1 -1
  33. package/src/components/server/ChangeDeclare.vue +1 -1
  34. package/src/components/server/Login.vue +630 -528
  35. package/src/components/server/ModifyPw.vue +11 -5
  36. package/src/components/server/NewResSelectGroup.vue +211 -0
  37. package/src/components/server/ResSelect.vue +3 -0
  38. package/src/components/server/ResSelectGroup.vue +23 -6
  39. package/src/components/server/RightTree.vue +86 -6
  40. package/src/components/server/RoleSelector.vue +4 -3
  41. package/src/components/server/TestResSelectGroup.vue +2 -2
  42. package/src/plugins/EncryptUtil.js +53 -0
  43. package/src/plugins/GetLoginInfoService.js +499 -515
  44. package/src/plugins/HeatGetLoginInfoService.js +491 -0
  45. package/src/plugins/validation.js +1 -1
  46. package/src/project/State.js +1 -1
  47. package/src/stores/AppData.js +1 -1
  48. package/src/stores/HeatAppData.js +38 -0
  49. package/src/styles/less/aofeng/themeOne/systemStyle.less +6 -6
  50. package/src/styles/less/aofeng/themeOne.less +4 -1
  51. package/src/styles/less/fonts-list.less +4 -4
  52. package/src/styles/less/stand.less +1 -1
  53. package/src/system.js +9 -0
  54. package/static/aodelogo.png +0 -0
  55. package/static/aodenewlogo.png +0 -0
  56. package/static/ewmlogo.png +0 -0
  57. package/.gradle/buildOutputCleanup/cache.properties.lock +0 -1
  58. package/static/logo.png +0 -0
  59. /package/.gradle/{5.2.1 → 7.1/dependencies-accessors}/gc.properties +0 -0
  60. /package/.gradle/{buildOutputCleanup/built.bin → 7.1/gc.properties} +0 -0
@@ -0,0 +1,491 @@
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
+ data = '$' + encrypt.encrypt(JSON.stringify(data));
11
+ console.log(data)
12
+
13
+ let getLogin = await Vue.resetpost('rs/heat/logic/getLogin', data, {resolveMsg: null, rejectMsg: null})
14
+ if (getLogin.data.states === '登录成功') {
15
+ // 调用远程登录服务,获取所有有权访问的功能
16
+ data = {username: name, password: password}
17
+ data = encrypt.encrypt(JSON.stringify(data))
18
+ let resource = await Vue.resetpost(`rs/heat/user/userLogin/客服系统`, data, {
19
+ resolveMsg: null,
20
+ rejectMsg: null
21
+ })
22
+ console.log('登陆获取Util', JSON.stringify(resource.data))
23
+ Vue.$loginHeat.f = resource.data
24
+ //获取jwt
25
+ Vue.$loginHeat.jwt = getLogin.data.jwt
26
+ // 把登录用户添加到cookie里
27
+ Vue.cookie.set('loginIdHeat', Vue.$loginHeat.f.id)
28
+ if (Vue.$loginHeat.f.id !== '11') {
29
+
30
+ try {
31
+ let getAllArea = await Vue.resetpost('rs/heat/search', {
32
+ source: 'this.getParentByType($organization$).getChildByName($区$).getChildren()',
33
+ userid: Vue.$loginHeat.f.id
34
+ }, {resolveMsg: null, rejectMsg: null})
35
+
36
+ let areaTemp = []
37
+ for (let i = 0; i < getAllArea.data.length; i++) {
38
+ let getSliceArea = await Vue.resetpost('rs/heat/search',
39
+ {source: 'this.getChildren()', userid: getAllArea.data[i].id},
40
+ {resolveMsg: null, rejectMsg: null})
41
+ let sliceTemp = []
42
+ for (let j = 0; j < getSliceArea.data.length; j++) {
43
+ sliceTemp.push({label: getSliceArea.data[j].name, value: getSliceArea.data[j].name})
44
+ }
45
+ areaTemp.push({label: getAllArea.data[i].name, value: sliceTemp})
46
+ }
47
+ Vue.$loginHeat.f.f_allArea = areaTemp
48
+ }catch (error) {
49
+ Vue.$loginHeat.f.f_allArea =[]
50
+ console.log('获取区县',error)
51
+ }
52
+
53
+ // 获取抄表员
54
+ try {
55
+ let getGasman = await Vue.resetpost('rs/heat/search', {
56
+ source: 'this.getParentByType($organization$).getChildByName($抄表员$).getUsers()',
57
+ userid: Vue.$loginHeat.f.id
58
+ }, {resolveMsg: null, rejectMsg: null})
59
+ let gasman = []
60
+ for (let i = 0; i < getGasman.data.length; i++) {
61
+ gasman.push(getGasman.data[i])
62
+ }
63
+ Vue.$loginHeat.f.f_gasman = gasman
64
+ }catch (error) {
65
+ Vue.$loginHeat.f.f_gasman = []
66
+ console.log('抄表员模块',error)
67
+ }
68
+
69
+
70
+ // 获取安装人
71
+ try {
72
+ let getInstallman = await Vue.resetpost('rs/heat/search', {
73
+ source: 'this.getParentByType($organization$).getChildByName($安装员$).getUsers()',
74
+ userid: Vue.$loginHeat.f.id
75
+ }, {resolveMsg: null, rejectMsg: null})
76
+ console.log('获取安装员', getInstallman)
77
+ let installman = []
78
+ for (let i = 0; i < getInstallman.data.length; i++) {
79
+ installman.push(getInstallman.data[i])
80
+ }
81
+ Vue.$loginHeat.f.f_installman = installman
82
+ }catch (error) {
83
+ Vue.$loginHeat.f.f_installman =[]
84
+ console.log('安装人模块',error)
85
+ }
86
+
87
+
88
+
89
+ // 获取换表员
90
+ try {
91
+ let getChangeMeterman = await Vue.resetpost('rs/heat/search', {
92
+ source: 'this.getParentByType($organization$).getChildByName($换表员$).getUsers()',
93
+ userid: Vue.$loginHeat.f.id
94
+ }, {resolveMsg: null, rejectMsg: null})
95
+ let changemeterman = []
96
+ for (let i = 0; i < getChangeMeterman.data.length; i++) {
97
+ changemeterman.push(getChangeMeterman.data[i])
98
+ }
99
+ Vue.$loginHeat.f.f_changemeterman = changemeterman
100
+ }catch (error) {
101
+ Vue.$loginHeat.f.f_changemeterman = []
102
+ console.log('换表员模块',error)
103
+ }
104
+
105
+
106
+ // 票据使用人
107
+ try {
108
+ let getPaperUseman = await Vue.resetpost('rs/heat/search', {
109
+ source: 'this.getParentByType($organization$).getChildByName($票据使用人$).getUsers()',
110
+ userid: Vue.$loginHeat.f.id
111
+ }, {resolveMsg: null, rejectMsg: null})
112
+ let perperuseman = []
113
+ for (let i = 0; i < getPaperUseman.data.length; i++) {
114
+ perperuseman.push(getPaperUseman.data[i])
115
+ }
116
+ Vue.$loginHeat.f.f_paperUseman = perperuseman
117
+ }catch (error) {
118
+ Vue.$loginHeat.f.f_paperUseman = []
119
+ console.log('票据使用人模块',error)
120
+
121
+ }
122
+
123
+
124
+ // 票据分配人
125
+ try {
126
+ let getPaperAllotman = await Vue.resetpost('rs/heat/search', {
127
+ source: 'this.getParentByType($organization$).getChildByName($票据分配人$).getUsers()',
128
+ userid: Vue.$loginHeat.f.id
129
+ }, {resolveMsg: null, rejectMsg: null})
130
+ let paperallotman = []
131
+ for (let i = 0; i < getPaperAllotman.data.length; i++) {
132
+ paperallotman.push(getPaperAllotman.data[i])
133
+ }
134
+ Vue.$loginHeat.f.f_paperAllotman = paperallotman
135
+ }catch (error) {
136
+ Vue.$loginHeat.f.f_paperAllotman = []
137
+ console.log('票据分配人模块',error)
138
+ }
139
+
140
+
141
+ // TODO 处理界面细节
142
+ try {
143
+ let viewDetails = await Vue.resetpost('rs/heat/search', {
144
+ source: 'this.getRights().where(row.getType()==$function$ && row.getPath($name$).indexOf($功能权限$) != -1)',
145
+ userid: Vue.$loginHeat.f.id
146
+ }, {resolveMsg: null, rejectMsg: null})
147
+ let r = viewDetails.data
148
+ Vue.$loginHeat.r = []
149
+ r.forEach(x => Vue.$loginHeat.r.push(x.name))
150
+ }catch (error) {
151
+ Vue.$loginHeat.r = []
152
+ console.log('加载模块失败',error)
153
+ }
154
+
155
+ // 调用登录后处理
156
+ for(let proc of Vue.$loginHeat.afterLogin) {
157
+ await proc(Vue.$loginHeat.f)
158
+ }
159
+
160
+ // 定时发送心跳
161
+ setInterval(()=> {
162
+ let http = new HttpResetClass()
163
+ http.load('GET', `rs/user/access/${Vue.$loginHeat.f.id}`, {}, {resolveMsg: null, rejectMsg: null})
164
+ }, 2 * 60 * 1000)
165
+ }
166
+ } else {
167
+ let error = {status: 401, data: getLogin.data.states}
168
+ // 抛出错误
169
+ throw error
170
+ }
171
+ }
172
+
173
+ let GetLoginInfoService = {
174
+ // 登录后要处理的异步对象
175
+ afterLogin: [],
176
+
177
+ install (Vue, options) {
178
+ // 给vue增添对话框显示方法
179
+ Vue.$loginHeat = Vue.prototype.$loginHeat = GetLoginInfoService
180
+ },
181
+
182
+ f: {
183
+
184
+ },
185
+
186
+ /**
187
+ * 登录
188
+ * @param name
189
+ * @param password
190
+ */
191
+ login (name, password) {
192
+ return loginGen(name, password)
193
+ },
194
+
195
+ getAttendanceState (item, timeToWork, timeToGo) {
196
+ item.f_state = ''
197
+ if (!item.f_signin_time || !item.f_knockoff_time) {
198
+ item.f_state = '缺勤'
199
+ } else {
200
+ let signin_time = item.f_signin_time.substring(11, 16)
201
+ let knockoff_time = item.f_knockoff_time.substring(11, 16)
202
+ if (signin_time > timeToWork) {
203
+ item.f_state = '迟到'
204
+ }
205
+ if (knockoff_time < timeToGo) {
206
+ item.f_state = item.f_state + '早退'
207
+ }
208
+ }
209
+ if (!item.f_state) {
210
+ item.f_state = '正常'
211
+ }
212
+ },
213
+
214
+ toStandardYearMonth () {
215
+ let dt = new Date()
216
+ let month = dt.getMonth() + 1
217
+ return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month)
218
+ },
219
+
220
+ toStandardYearMonth1 () {
221
+ let dt = new Date()
222
+ let month = dt.getMonth() + 1
223
+ return dt.getFullYear() + (month < 10 ? '0' + month : month)
224
+ },
225
+
226
+ toStandardDateString () {
227
+ let dt = new Date()
228
+ let month = dt.getMonth() + 1
229
+ let date = dt.getDate()
230
+ return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
231
+ },
232
+
233
+ toStartAndEndDateString () {
234
+ let dt = new Date()
235
+ let month = dt.getMonth() + 1
236
+ // let date = dt.getDate()
237
+ return [dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-01',
238
+ dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (new Date(dt.getFullYear(), month, 0).getDate())]
239
+ // return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
240
+ },
241
+
242
+ toStandardTimeString () {
243
+ let dt = new Date()
244
+ let month = dt.getMonth() + 1
245
+ let date = dt.getDate()
246
+ let hour = dt.getHours()
247
+ let min = dt.getMinutes()
248
+ let sec = dt.getSeconds()
249
+ return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date) +
250
+ ' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
251
+ },
252
+
253
+ guid () {
254
+ let buf = new Uint16Array(8)
255
+ window.crypto.getRandomValues(buf)
256
+ let S4 = function (num) {
257
+ let ret = num.toString(16)
258
+ while (ret.length < 4) {
259
+ ret = '0' + ret
260
+ }
261
+ return ret
262
+ }
263
+ 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]))
264
+ },
265
+
266
+ choices (role, param, hasBlank = false, blankHint = '请选择') {
267
+ if (role == 'view') {
268
+ Vue.getParams(param, [null])
269
+ } else {
270
+ let result = []
271
+ if (hasBlank)
272
+ result.push({label: blankHint, value: null})
273
+ if (!Vue.param || !Vue.param[param])
274
+ result.push({label: '请在系统设置里更新参数', value: '请在系统设置里更新参数'})
275
+ else {
276
+ let p = Vue.param[param]
277
+ p.forEach(function (item) {
278
+ result.push({label: item.name, value: item.name})
279
+ })
280
+ }
281
+ return result
282
+ }
283
+ },
284
+
285
+ required (param) {
286
+ if (typeof param === 'number' && param == 0)
287
+ return false
288
+ if (!param)
289
+ return true
290
+ param = param + ''
291
+ param = param.trim()
292
+ if (!param)
293
+ return true
294
+ return false
295
+ },
296
+
297
+ isInt (n) {
298
+ return !window.isNaN(n) && n % 1 === 0
299
+ },
300
+
301
+ isFloat (n) {
302
+ return !window.isNaN(n)
303
+ },
304
+
305
+ // this will convert all true/false to boolean
306
+ booleanFilter (paper) {
307
+ for (let key in paper) {
308
+ if (!paper.hasOwnProperty(key))
309
+ continue
310
+ if (typeof paper[key] == 'object' && paper[key] != null) {
311
+ booleanFilter(paper[key])
312
+ } else {
313
+ if (paper[key] === 'true' || paper[key] == 'false')
314
+ paper[key] = (paper[key] === 'true')
315
+ }
316
+ }
317
+ },
318
+ // recursively traverse through each path
319
+ ratifyPics (paper) {
320
+ for (let key in paper) {
321
+ if (key.endsWith('_path')) {
322
+ if (!paper[key]) {
323
+ paper[key] = 'rs/db/file/nopic.png'
324
+ } else {
325
+ paper[key] = 'rs/db/file/' + paper[key]
326
+ }
327
+ } else if (paper[key] !== null && typeof (paper[key]) == 'object') {
328
+ ratifyPics(paper[key])
329
+ }
330
+ }
331
+ },
332
+
333
+ // load script and other stuff
334
+ loadscript (type, fileName) {
335
+ return new Promise((resolve, reject) => {
336
+ let element
337
+ if (type == 'css') {
338
+ element = document.createElement('link')
339
+ element.setAttribute('rel', 'stylesheet')
340
+ element.setAttribute('type', 'text/css')
341
+ element.setAttribute('href', fileName)
342
+ } else if (type == 'js') {
343
+ element = document.createElement('script')
344
+ element.setAttribute('type', 'text/javascript')
345
+ element.setAttribute('src', fileName)
346
+ }
347
+ if (element) {
348
+ element.setAttribute('async', '')
349
+ element.setAttribute('defer', '')
350
+ element.addEventListener('load', function () {
351
+ resolve(element)
352
+ }, false)
353
+ element.addEventListener('error', function () {
354
+ reject(element)
355
+ }, false)
356
+ document.body.appendChild(element)
357
+ }
358
+ })
359
+ },
360
+ // 不能选择器中截取掉多余的字符
361
+ orgName (name) {
362
+ return name.substring(10)
363
+ },
364
+
365
+ getNowDate (name) {
366
+ // 求取当前时间的工具
367
+ let myweekday = ''
368
+ let year = ''
369
+ let mydate = new Date()
370
+ myweekday = mydate.getDay()
371
+ let mymonth = mydate.getMonth() + 1
372
+ let myday = mydate.getDate()
373
+ let myyear = mydate.getYear()
374
+ year = (myyear > 200) ? myyear : 1900 + myyear
375
+ let week = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期日', '星期六']
376
+ // document.write("<font color=#ffffff>今天是 "+year+"年"+mymonth+"月"+myday+"日 "+weekday+"</font>");
377
+ return year + '年' + mymonth + '月' + myday + '日 ' + week[myweekday]
378
+ },
379
+
380
+ addDate (date, days) {
381
+ // 求取当前时间的工具
382
+ let endDate = new Date(date)
383
+ endDate = endDate.valueOf()
384
+ endDate = endDate + days * 24 * 60 * 60 * 1000
385
+ endDate = new Date(endDate)
386
+ let month = endDate.getMonth() + 1
387
+ let day = endDate.getDate()
388
+ let hour = endDate.getHours()
389
+ let min = endDate.getMinutes()
390
+ let sec = endDate.getSeconds()
391
+ return endDate.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (day < 10 ? '0' + day : day) +
392
+ ' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
393
+ // return a
394
+ },
395
+
396
+ // 通过地址栏的参数获取参数内容
397
+ getUrlParames (param) {
398
+ var query = window.location.search
399
+ var iLen = param.length
400
+ var iStart = query.indexOf(param)
401
+ if (iStart === -1) {
402
+ return ''
403
+ }
404
+ iStart += iLen + 1
405
+ var iEnd = query.indexOf('&', iStart)
406
+ if (iEnd === -1) {
407
+ return query.substring(iStart)
408
+ }
409
+ return query.substring(iStart, iEnd)
410
+ },
411
+
412
+ // 从地址栏获取加密的参数
413
+ getUrlCompileParames (param) {
414
+ console.log('2222222', window.location.search.slice(1, window.location.search.length))
415
+ let code = unescape(window.location.search.slice(1, window.location.search.length))
416
+ let query = String.fromCharCode(code.charCodeAt(0) - code.length)
417
+ for (var i = 1; i < code.length; i++) {
418
+ query += String.fromCharCode(code.charCodeAt(i) - query.charCodeAt(i - 1))
419
+ }
420
+ let iLen = param.length
421
+ let iStart = query.indexOf(param)
422
+ if (iStart === -1) {
423
+ return ''
424
+ }
425
+ iStart += iLen + 1
426
+ let iEnd = query.indexOf('&', iStart)
427
+ if (iEnd === -1) {
428
+ return query.substring(iStart)
429
+ }
430
+ return query.substring(iStart, iEnd)
431
+ },
432
+
433
+ // 对字符串进行加密
434
+ compileStr (code) {
435
+ let c = String.fromCharCode(code.charCodeAt(0) + code.length)
436
+ for (let i = 1; i < code.length; i++) {
437
+ c += String.fromCharCode(code.charCodeAt(i) + code.charCodeAt(i - 1))
438
+ }
439
+ return escape(c)
440
+ },
441
+ // 字符串进行解密
442
+ uncompileStr (code) {
443
+ code = unescape(code)
444
+ let c = String.fromCharCode(code.charCodeAt(0) - code.length)
445
+ for (var i = 1; i < code.length; i++) {
446
+ c += String.fromCharCode(code.charCodeAt(i) - c.charCodeAt(i - 1))
447
+ }
448
+ return c
449
+ },
450
+
451
+ dateDescripte (date) {
452
+ let nowTime = new Date().getTime()
453
+ let oldTime = new Date(date).getTime()
454
+ let timeDiff = nowTime - oldTime
455
+ // 规则说明
456
+ // 小于等于2分钟为刚刚
457
+ // 大于2分钟小于等于1小时为取整的分钟前(例如:35分钟前)
458
+ // 大于1小时小于等于24小时为取整的小时前(例如:15小时前)
459
+ // 大于24小时小于等于30天为取整的天前(例如:12天前)
460
+ // 大于30天小于等于12月为取整的月前,月份统一为30天一月,不做额外处理(例如:3个月前)
461
+ // 大于365取整的年前,(例如:2年前)
462
+ let minute = 1000 * 60
463
+ let hour = minute * 60
464
+ let day = hour * 24
465
+ let month = day * 30
466
+ let year = month * 12
467
+ let des = ''
468
+ if (timeDiff <= minute * 2) {
469
+ des = '刚刚'
470
+ } else if (minute * 2 < timeDiff && timeDiff < hour) {
471
+ des = `${Math.floor(timeDiff / minute)}分钟前`
472
+ } else if (hour < timeDiff && timeDiff <= day) {
473
+ des = `${Math.floor(timeDiff / hour)}小时前`
474
+ } else if (day < timeDiff && timeDiff <= month) {
475
+ des = `${Math.floor(timeDiff / day)}天前`
476
+ } else if (month < timeDiff && timeDiff <= year) {
477
+ des = `${Math.floor(timeDiff / month)}个月前`
478
+ } else if (year < timeDiff) {
479
+ des = `${Math.floor(timeDiff / year)}年前`
480
+ }
481
+ return des
482
+ },
483
+
484
+ nextMonth20 (date) {
485
+ let ds = date.split('-')
486
+ let nextMonth = ds[1] - 0 + 1
487
+ return ds[0] + '-' + (nextMonth < 10 ? '0' + nextMonth : nextMonth) + '-20 00:00:00'
488
+ }
489
+ }
490
+
491
+ export default GetLoginInfoService
@@ -3,5 +3,5 @@ import Validator from 'vue-validator'
3
3
  Vue.use(Validator)
4
4
  //密码强度验证器(必须为为大小写字母、阿拉伯数字、字符)
5
5
  Vue.validator('strongpassword', function (val) {
6
- return /^(?:(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9])(?=.*[^A-Za-z0-9])).*$/.test(val)
6
+ return /^(?:(?=.*[a-zA-Z])(?=.*[0-9])(?=.*[^A-Za-z0-9])).*$/.test(val)
7
7
  });
@@ -4,7 +4,7 @@ export default class {
4
4
  constructor () {
5
5
  this.selected = null
6
6
  // 左侧项目树
7
- this.projects = new TreeList('/rs/sql/project.sql')
7
+ this.projects = new TreeList('/api/af-system/sql/project.sql')
8
8
  }
9
9
 
10
10
  select (selected) {
@@ -9,7 +9,7 @@ let GetAppDataService = {
9
9
 
10
10
  // 开启卡监听
11
11
  load () {
12
- return Vue.resetpost('rs/logic/getInitData', {data: {f_filialeids: Vue.$login.f.orgid}}, {resolveMsg: null, rejectMsg: null}).then((res) => {
12
+ return Vue.resetpost('api/af-system/logic/getInitData', {data: {f_filialeids: Vue.$login.f.orgid}}, {resolveMsg: null, rejectMsg: null}).then((res) => {
13
13
  res.data.singleValues.forEach((item) => {
14
14
  this.singleValues[item.name] = item.value
15
15
  })
@@ -0,0 +1,38 @@
1
+ import Vue from 'vue'
2
+
3
+ let GetAppDataService = {
4
+ install(Vue, options) {
5
+ // 给vue增添对话框显示方法
6
+
7
+ Vue.$appdataHeat = Vue.prototype.$appdataHeat = GetAppDataService
8
+ },
9
+
10
+ // 开启卡监听
11
+ load () {
12
+ return Vue.resetpost('rs/heat/logic/getInitData', {data: {f_filialeids: Vue.$loginHeat.f.f_orgids}}, {resolveMsg: null, rejectMsg: null}).then((res) => {
13
+ res.data.singleValues.forEach((item) => {
14
+ this.singleValues[item.name] = item.value
15
+ })
16
+ res.data.params.forEach((item) => {
17
+ let value = []
18
+ item.f_paramvalues.forEach((item, index) => {
19
+ value[index] = {}
20
+ value[index].label = item.name
21
+ value[index].value = item.name
22
+ })
23
+ this.params[item.name] = value
24
+ })
25
+ })
26
+ },
27
+
28
+ params: {},
29
+ singleValues: {},
30
+
31
+ getParam(key) {
32
+ return this.params[key]
33
+ },
34
+ getSingleValue(key) {
35
+ return this.singleValues[key]
36
+ }
37
+ }
38
+ export default GetAppDataService
@@ -333,7 +333,7 @@ input{outline:none;}
333
333
  //system左侧树列表
334
334
  .system-left {
335
335
  float: left;
336
- width: 8%;
336
+ width: 9%;
337
337
  height: 100%;
338
338
 
339
339
  .system-left-chi {
@@ -760,7 +760,7 @@ input{outline:none;}
760
760
  //system左侧树列表
761
761
  .system-left{
762
762
  float: left;
763
- width: 9%;
763
+ width: 10%;
764
764
 
765
765
  height: 100%;
766
766
 
@@ -1193,7 +1193,7 @@ input{outline:none;}
1193
1193
  //system左侧树列表
1194
1194
  .system-left{
1195
1195
  float: left;
1196
- width: 10%;
1196
+ width: 11%;
1197
1197
  height: 100%;
1198
1198
  .system-left-chi{
1199
1199
  height: 96%;
@@ -1610,7 +1610,7 @@ input{outline:none;}
1610
1610
  //system左侧树列表
1611
1611
  .system-left{
1612
1612
  float: left;
1613
- width: 10%;
1613
+ width: 11%;
1614
1614
  height:100%;
1615
1615
  .system-left-chi{
1616
1616
  height: 96%;
@@ -2033,7 +2033,7 @@ input{outline:none;}
2033
2033
  //system左侧树列表
2034
2034
  .system-left{
2035
2035
  float: left;
2036
- width: 10%;
2036
+ width: 11%;
2037
2037
  height: 100%;
2038
2038
  .system-left-chi{
2039
2039
  height: 96%;
@@ -2448,7 +2448,7 @@ input{outline:none;}
2448
2448
  //system左侧树列表
2449
2449
  .system-left{
2450
2450
  float: left;
2451
- width: 12%;
2451
+ width: 13%;
2452
2452
  height: 100%;
2453
2453
  .system-left-chi{
2454
2454
  height: 96%;
@@ -8,7 +8,10 @@
8
8
  //功能内容标准
9
9
  @import "standard.less";
10
10
 
11
-
11
+ .btn-gn {
12
+ font-size: 18px!important;
13
+ padding: 10px 16px!important;
14
+ }
12
15
  //div{
13
16
  // font-family: PingFang;
14
17
  //}
@@ -8,18 +8,18 @@
8
8
 
9
9
  @font-face {
10
10
  font-family: 'PINGFANG-MEDIUM'; //重命名字体名
11
- src: url('../fonts/pingfang-medium.ttf'); //引入字体
11
+ //src: url('../fonts/pingfang-medium.ttf'); //引入字体
12
12
  }
13
13
  @font-face {
14
14
  font-family: 'PINGFANG-BOLD'; //重命名字体名
15
- src: url('../fonts/pingfang-bold.ttf'); //引入字体
15
+ //src: url('../fonts/pingfang-bold.ttf'); //引入字体
16
16
  }
17
17
  @font-face {
18
18
  font-family: 'PINGFANG-REGULAR'; //重命名字体名
19
- src: url('../fonts/pingfang-regular.ttf'); //引入字体
19
+ //src: url('../fonts/pingfang-regular.ttf'); //引入字体
20
20
  }
21
21
 
22
22
  @font-face {
23
23
  font-family: PingFang;
24
- src:url('../fonts/PingFangSC-Regular.ttf');
24
+ //src:url('../fonts/PingFangSC-Regular.ttf');
25
25
  }
@@ -1,7 +1,7 @@
1
1
  /*=========================通用样式表=========================*/
2
2
  @font-face {
3
3
  font-family: PingFang;
4
- src:url('../fonts/PingFangSC-Regular.ttf');
4
+ //src:url('../fonts/PingFangSC-Regular.ttf');
5
5
  }
6
6
 
7
7
 
package/src/system.js CHANGED
@@ -1,6 +1,11 @@
1
1
  import Vue from 'vue'
2
2
  import GetLoginInfoService from './plugins/GetLoginInfoService'
3
3
  import GetAppDataService from './stores/AppData'
4
+ // 热力
5
+ import HeatGetLoginInfoService from './plugins/HeatGetLoginInfoService'
6
+ import HeatGetAppDataService from './stores/HeatAppData'
7
+ // 热力登陆控制
8
+ Vue.$heatCompatibility = Vue.prototype.$heatCompatibility = false
4
9
 
5
10
  // /** **************************登录与主界面相关******************************/
6
11
 
@@ -21,6 +26,7 @@ import ResSelectGroup from './components/server/ResSelectGroup'
21
26
  //资源选择测试
22
27
  import TestResSelect from './components/server/TestResSelect'
23
28
  import RoleSelector from "./components/server/RoleSelector";
29
+ import NewResSelectGroup from "./components/server/NewResSelectGroup.vue";
24
30
  export default function (val) {
25
31
  //验证码开关赋值
26
32
  if(val!=null){
@@ -28,6 +34,8 @@ export default function (val) {
28
34
  }
29
35
  Vue.use(GetLoginInfoService)
30
36
  Vue.use(GetAppDataService)
37
+ Vue.use(HeatGetLoginInfoService)
38
+ Vue.use(HeatGetAppDataService)
31
39
 
32
40
  Vue.component('login', login)
33
41
  Vue.component('change-declare', changeDeclare)
@@ -43,6 +51,7 @@ export default function (val) {
43
51
  //资源选择
44
52
  Vue.component('res-select', ResSelect)
45
53
  Vue.component('res-select-group', ResSelectGroup)
54
+ Vue.component('new-select-group', NewResSelectGroup)
46
55
  //资源选择测试
47
56
  Vue.component('test-res-select', TestResSelect)
48
57
 
Binary file