system-clients 4.1.1 → 4.1.2
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 +1 -1
- package/src/components/Util.js +343 -343
- package/src/components/equipment/PosAdd.vue +13 -4
- package/src/components/equipment/PosList.vue +17 -3
- package/src/components/equipment/PosManage.vue +1 -1
- package/src/components/server/Menu.vue +188 -188
- package/.gradle/8.9/checksums/checksums.lock +0 -0
- package/.gradle/8.9/dependencies-accessors/gc.properties +0 -0
- package/.gradle/8.9/executionHistory/executionHistory.lock +0 -0
- package/.gradle/8.9/fileChanges/last-build.bin +0 -0
- package/.gradle/8.9/fileHashes/fileHashes.lock +0 -0
- package/.gradle/8.9/gc.properties +0 -0
- package/.gradle/9.0.0/checksums/checksums.lock +0 -0
- package/.gradle/9.0.0/fileChanges/last-build.bin +0 -0
- package/.gradle/9.0.0/fileHashes/fileHashes.bin +0 -0
- package/.gradle/9.0.0/fileHashes/fileHashes.lock +0 -0
- package/.gradle/9.0.0/gc.properties +0 -0
package/package.json
CHANGED
package/src/components/Util.js
CHANGED
|
@@ -1,343 +1,343 @@
|
|
|
1
|
-
import Vue from 'vue'
|
|
2
|
-
// 登录后获取的所有数据,需要自行获取
|
|
3
|
-
export var f
|
|
4
|
-
|
|
5
|
-
export function getAttendanceState (item, timeToWork, timeToGo) {
|
|
6
|
-
item.f_state = ''
|
|
7
|
-
if (!item.f_signin_time || !item.f_knockoff_time) {
|
|
8
|
-
item.f_state = '缺勤'
|
|
9
|
-
} else {
|
|
10
|
-
let signin_time = item.f_signin_time.substring(11, 16)
|
|
11
|
-
let knockoff_time = item.f_knockoff_time.substring(11, 16)
|
|
12
|
-
if (signin_time > timeToWork) {
|
|
13
|
-
item.f_state = '迟到'
|
|
14
|
-
}
|
|
15
|
-
if (knockoff_time < timeToGo) {
|
|
16
|
-
item.f_state = item.f_state + '早退'
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
if (!item.f_state) {
|
|
20
|
-
item.f_state = '正常'
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export function toStandardYearMonth () {
|
|
25
|
-
let dt = new Date()
|
|
26
|
-
let month = dt.getMonth() + 1
|
|
27
|
-
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month)
|
|
28
|
-
}
|
|
29
|
-
export function toStandardYearMonth1 () {
|
|
30
|
-
let dt = new Date()
|
|
31
|
-
let month = dt.getMonth() + 1
|
|
32
|
-
return dt.getFullYear() + (month < 10 ? '0' + month : month)
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
export function toStandardDateString () {
|
|
36
|
-
let dt = new Date()
|
|
37
|
-
let month = dt.getMonth() + 1
|
|
38
|
-
let date = dt.getDate()
|
|
39
|
-
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
export function toStartAndEndDateString () {
|
|
43
|
-
let dt = new Date()
|
|
44
|
-
let month = dt.getMonth() + 1
|
|
45
|
-
// let date = dt.getDate()
|
|
46
|
-
return [dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-01',
|
|
47
|
-
dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (new Date(dt.getFullYear(), month, 0).getDate())]
|
|
48
|
-
// return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export function toStandardTimeString () {
|
|
52
|
-
let dt = new Date()
|
|
53
|
-
let month = dt.getMonth() + 1
|
|
54
|
-
let date = dt.getDate()
|
|
55
|
-
let hour = dt.getHours()
|
|
56
|
-
let min = dt.getMinutes()
|
|
57
|
-
let sec = dt.getSeconds()
|
|
58
|
-
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date) +
|
|
59
|
-
' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
export function to3339TimeString () {
|
|
63
|
-
let dt = new Date()
|
|
64
|
-
let month = dt.getMonth() + 1
|
|
65
|
-
let date = dt.getDate()
|
|
66
|
-
let hour = dt.getHours()
|
|
67
|
-
let min = dt.getMinutes()
|
|
68
|
-
let sec = dt.getSeconds()
|
|
69
|
-
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date) +
|
|
70
|
-
'T' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
export function parse3339String (strDate) {
|
|
74
|
-
return new Date(
|
|
75
|
-
strDate.substr(0, 4), strDate.substr(5, 2) - 1, strDate.substr(8, 2),
|
|
76
|
-
strDate.substr(11, 2), strDate.substr(14, 2), strDate.substr(17, 2)
|
|
77
|
-
)
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
export function format3339TimeString (dt) {
|
|
81
|
-
let month = dt.getMonth() + 1
|
|
82
|
-
let date = dt.getDate()
|
|
83
|
-
let hour = dt.getHours()
|
|
84
|
-
let min = dt.getMinutes()
|
|
85
|
-
let sec = dt.getSeconds()
|
|
86
|
-
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
|
|
87
|
-
+ 'T' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
export function guid () {
|
|
91
|
-
let buf = new Uint16Array(8)
|
|
92
|
-
window.crypto.getRandomValues(buf)
|
|
93
|
-
let S4 = function (num) {
|
|
94
|
-
let ret = num.toString(16)
|
|
95
|
-
while (ret.length < 4) {
|
|
96
|
-
ret = '0' + ret
|
|
97
|
-
}
|
|
98
|
-
return ret
|
|
99
|
-
}
|
|
100
|
-
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]))
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
export function choices (role, param, hasBlank = false, blankHint = '请选择') {
|
|
104
|
-
if (role == 'view') {
|
|
105
|
-
Vue.getParams(param, [null])
|
|
106
|
-
} else {
|
|
107
|
-
let result = []
|
|
108
|
-
if (hasBlank)
|
|
109
|
-
result.push({label: blankHint, value: null})
|
|
110
|
-
if (!Vue.param || !Vue.param[param])
|
|
111
|
-
result.push({label: '请在系统设置里更新参数', value: '请在系统设置里更新参数'})
|
|
112
|
-
else {
|
|
113
|
-
let p = Vue.param[param]
|
|
114
|
-
p.forEach(function (item) {
|
|
115
|
-
result.push({label: item.name, value: item.name})
|
|
116
|
-
})
|
|
117
|
-
}
|
|
118
|
-
return result
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
export function required (param) {
|
|
123
|
-
if (typeof param === 'number' && param == 0)
|
|
124
|
-
return false
|
|
125
|
-
if (!param)
|
|
126
|
-
return true
|
|
127
|
-
param = param + ''
|
|
128
|
-
param = param.trim()
|
|
129
|
-
if (!param)
|
|
130
|
-
return true
|
|
131
|
-
return false
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
export function isInt (n) {
|
|
135
|
-
return !window.isNaN(n) && n % 1 === 0
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
export function isFloat (n) {
|
|
139
|
-
return !window.isNaN(n)
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
// this will convert all true/false to boolean
|
|
143
|
-
export function booleanFilter (paper) {
|
|
144
|
-
for (let key in paper) {
|
|
145
|
-
if (!paper.hasOwnProperty(key))
|
|
146
|
-
continue
|
|
147
|
-
if (typeof paper[key] == 'object' && paper[key] != null) {
|
|
148
|
-
booleanFilter(paper[key])
|
|
149
|
-
} else {
|
|
150
|
-
if (paper[key] === 'true' || paper[key] == 'false')
|
|
151
|
-
paper[key] = (paper[key] === 'true')
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
// recursively traverse through each path
|
|
156
|
-
export function ratifyPics (paper) {
|
|
157
|
-
for (let key in paper) {
|
|
158
|
-
if (key.endsWith('_path')) {
|
|
159
|
-
if (!paper[key]) {
|
|
160
|
-
paper[key] = 'rs/db/file/nopic.png'
|
|
161
|
-
} else {
|
|
162
|
-
paper[key] = 'rs/db/file/' + paper[key]
|
|
163
|
-
}
|
|
164
|
-
} else if (paper[key] !== null && typeof (paper[key]) == 'object') {
|
|
165
|
-
ratifyPics(paper[key])
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
// load script and other stuff
|
|
171
|
-
export function loadscript (type, fileName) {
|
|
172
|
-
return new Promise((resolve, reject) => {
|
|
173
|
-
let element
|
|
174
|
-
if (type == 'css') {
|
|
175
|
-
element = document.createElement('link')
|
|
176
|
-
element.setAttribute('rel', 'stylesheet')
|
|
177
|
-
element.setAttribute('type', 'text/css')
|
|
178
|
-
element.setAttribute('href', fileName)
|
|
179
|
-
} else if (type == 'js') {
|
|
180
|
-
element = document.createElement('script')
|
|
181
|
-
element.setAttribute('type', 'text/javascript')
|
|
182
|
-
element.setAttribute('src', fileName)
|
|
183
|
-
}
|
|
184
|
-
if (element) {
|
|
185
|
-
element.setAttribute('async', '')
|
|
186
|
-
element.setAttribute('defer', '')
|
|
187
|
-
element.addEventListener('load', function () {
|
|
188
|
-
resolve(element)
|
|
189
|
-
}, false)
|
|
190
|
-
element.addEventListener('error', function () {
|
|
191
|
-
reject(element)
|
|
192
|
-
}, false)
|
|
193
|
-
document.body.appendChild(element)
|
|
194
|
-
}
|
|
195
|
-
})
|
|
196
|
-
}
|
|
197
|
-
// 不能选择器中截取掉多余的字符
|
|
198
|
-
export function orgName (name) {
|
|
199
|
-
return name.substring(10)
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
export function getNowDate (name) {
|
|
203
|
-
// 求取当前时间的工具
|
|
204
|
-
let myweekday = ''
|
|
205
|
-
let year = ''
|
|
206
|
-
let mydate = new Date()
|
|
207
|
-
myweekday = mydate.getDay()
|
|
208
|
-
let mymonth = mydate.getMonth() + 1
|
|
209
|
-
let myday = mydate.getDate()
|
|
210
|
-
let myyear = mydate.getYear()
|
|
211
|
-
year = (myyear > 200) ? myyear : 1900 + myyear
|
|
212
|
-
let week = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期日', '星期六']
|
|
213
|
-
// document.write("<font color=#ffffff>今天是 "+year+"年"+mymonth+"月"+myday+"日 "+weekday+"</font>");
|
|
214
|
-
return year + '年' + mymonth + '月' + myday + '日 ' + week[myweekday]
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
export function addDate (date, days) {
|
|
218
|
-
// 求取当前时间的工具
|
|
219
|
-
let endDate = new Date(date)
|
|
220
|
-
endDate = endDate.valueOf()
|
|
221
|
-
endDate = endDate + days * 24 * 60 * 60 * 1000
|
|
222
|
-
endDate = new Date(endDate)
|
|
223
|
-
let month = endDate.getMonth() + 1
|
|
224
|
-
let day = endDate.getDate()
|
|
225
|
-
let hour = endDate.getHours()
|
|
226
|
-
let min = endDate.getMinutes()
|
|
227
|
-
let sec = endDate.getSeconds()
|
|
228
|
-
return endDate.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (day < 10 ? '0' + day : day) +
|
|
229
|
-
' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
|
|
230
|
-
// return a
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
// 通过地址栏的参数获取参数内容
|
|
234
|
-
export function getUrlParames (param) {
|
|
235
|
-
var query = window.location.search
|
|
236
|
-
var iLen = param.length
|
|
237
|
-
var iStart = query.indexOf(param)
|
|
238
|
-
if (iStart === -1) {
|
|
239
|
-
return ''
|
|
240
|
-
}
|
|
241
|
-
iStart += iLen + 1
|
|
242
|
-
var iEnd = query.indexOf('&', iStart)
|
|
243
|
-
if (iEnd === -1) {
|
|
244
|
-
return query.substring(iStart)
|
|
245
|
-
}
|
|
246
|
-
return query.substring(iStart, iEnd)
|
|
247
|
-
}
|
|
248
|
-
|
|
249
|
-
// 从地址栏获取加密的参数
|
|
250
|
-
export function getUrlCompileParames (param) {
|
|
251
|
-
var query = uncompileStr(window.location.search.slice(1, window.location.search.length))
|
|
252
|
-
var iLen = param.length
|
|
253
|
-
var iStart = query.indexOf(param)
|
|
254
|
-
if (iStart === -1) {
|
|
255
|
-
return ''
|
|
256
|
-
}
|
|
257
|
-
iStart += iLen + 1
|
|
258
|
-
var iEnd = query.indexOf('&', iStart)
|
|
259
|
-
if (iEnd === -1) {
|
|
260
|
-
return query.substring(iStart)
|
|
261
|
-
}
|
|
262
|
-
return query.substring(iStart, iEnd)
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
// 对字符串进行加密
|
|
266
|
-
export function compileStr (code) {
|
|
267
|
-
let c = String.fromCharCode(code.charCodeAt(0) + code.length)
|
|
268
|
-
for (let i = 1; i < code.length; i++) {
|
|
269
|
-
c += String.fromCharCode(code.charCodeAt(i) + code.charCodeAt(i - 1))
|
|
270
|
-
}
|
|
271
|
-
return escape(c)
|
|
272
|
-
}
|
|
273
|
-
// 字符串进行解密
|
|
274
|
-
export function uncompileStr (code) {
|
|
275
|
-
code = unescape(code)
|
|
276
|
-
let c = String.fromCharCode(code.charCodeAt(0) - code.length)
|
|
277
|
-
for (var i = 1; i < code.length; i++) {
|
|
278
|
-
c += String.fromCharCode(code.charCodeAt(i) - c.charCodeAt(i - 1))
|
|
279
|
-
}
|
|
280
|
-
return c
|
|
281
|
-
}
|
|
282
|
-
|
|
283
|
-
export function dateDescripte (date) {
|
|
284
|
-
let nowTime = new Date().getTime()
|
|
285
|
-
let oldTime = new Date(date).getTime()
|
|
286
|
-
let timeDiff = nowTime - oldTime
|
|
287
|
-
// 规则说明
|
|
288
|
-
// 小于等于2分钟为刚刚
|
|
289
|
-
// 大于2分钟小于等于1小时为取整的分钟前(例如:35分钟前)
|
|
290
|
-
// 大于1小时小于等于24小时为取整的小时前(例如:15小时前)
|
|
291
|
-
// 大于24小时小于等于30天为取整的天前(例如:12天前)
|
|
292
|
-
// 大于30天小于等于12月为取整的月前,月份统一为30天一月,不做额外处理(例如:3个月前)
|
|
293
|
-
// 大于365取整的年前,(例如:2年前)
|
|
294
|
-
let minute = 1000 * 60
|
|
295
|
-
let hour = minute * 60
|
|
296
|
-
let day = hour * 24
|
|
297
|
-
let month = day * 30
|
|
298
|
-
let year = month * 12
|
|
299
|
-
let des = ''
|
|
300
|
-
if (timeDiff <= minute * 2) {
|
|
301
|
-
des = '刚刚'
|
|
302
|
-
} else if (minute * 2 < timeDiff && timeDiff < hour) {
|
|
303
|
-
des = `${Math.floor(timeDiff / minute)}分钟前`
|
|
304
|
-
} else if (hour < timeDiff && timeDiff <= day) {
|
|
305
|
-
des = `${Math.floor(timeDiff / hour)}小时前`
|
|
306
|
-
} else if (day < timeDiff && timeDiff <= month) {
|
|
307
|
-
des = `${Math.floor(timeDiff / day)}天前`
|
|
308
|
-
} else if (month < timeDiff && timeDiff <= year) {
|
|
309
|
-
des = `${Math.floor(timeDiff / month)}个月前`
|
|
310
|
-
} else if (year < timeDiff) {
|
|
311
|
-
des = `${Math.floor(timeDiff / year)}年前`
|
|
312
|
-
}
|
|
313
|
-
return des
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
export function nextMonth20 (date) {
|
|
317
|
-
let ds = date.split('-')
|
|
318
|
-
let nextMonth = ds[1] - 0 + 1
|
|
319
|
-
return ds[0] + '-' + (nextMonth < 10 ? '0' + nextMonth : nextMonth) + '-20 00:00:00'
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
// export function getNowDate () {
|
|
323
|
-
// // 求取当前时间的工具
|
|
324
|
-
// let myweekday = ''
|
|
325
|
-
// let year = ''
|
|
326
|
-
// let mydate = new Date()
|
|
327
|
-
// myweekday = mydate.getDay()
|
|
328
|
-
// let mymonth = mydate.getMonth() + 1
|
|
329
|
-
// let myday = mydate.getDate()
|
|
330
|
-
// let myyear = mydate.getYear()
|
|
331
|
-
// year = (myyear > 200) ? myyear : 1900 + myyear
|
|
332
|
-
// let week = ['星期日','星期一','星期二','星期三','星期四','星期五','星期日','星期六']
|
|
333
|
-
// let weekday = week[myweekday]
|
|
334
|
-
//
|
|
335
|
-
// // document.write("<font color=#ffffff>今天是 "+year+"年"+mymonth+"月"+myday+"日 "+weekday+"</font>");
|
|
336
|
-
// return year + '年' + mymonth + '月' + myday + '日 ' + weekday
|
|
337
|
-
// }
|
|
338
|
-
//
|
|
339
|
-
// export function getImgsrc (name) {
|
|
340
|
-
// return "http://127.0.0.1:8081/images/"+name+".gif"
|
|
341
|
-
// }
|
|
342
|
-
//
|
|
343
|
-
// export var f;
|
|
1
|
+
import Vue from 'vue'
|
|
2
|
+
// 登录后获取的所有数据,需要自行获取
|
|
3
|
+
export var f
|
|
4
|
+
|
|
5
|
+
export function getAttendanceState (item, timeToWork, timeToGo) {
|
|
6
|
+
item.f_state = ''
|
|
7
|
+
if (!item.f_signin_time || !item.f_knockoff_time) {
|
|
8
|
+
item.f_state = '缺勤'
|
|
9
|
+
} else {
|
|
10
|
+
let signin_time = item.f_signin_time.substring(11, 16)
|
|
11
|
+
let knockoff_time = item.f_knockoff_time.substring(11, 16)
|
|
12
|
+
if (signin_time > timeToWork) {
|
|
13
|
+
item.f_state = '迟到'
|
|
14
|
+
}
|
|
15
|
+
if (knockoff_time < timeToGo) {
|
|
16
|
+
item.f_state = item.f_state + '早退'
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
if (!item.f_state) {
|
|
20
|
+
item.f_state = '正常'
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export function toStandardYearMonth () {
|
|
25
|
+
let dt = new Date()
|
|
26
|
+
let month = dt.getMonth() + 1
|
|
27
|
+
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month)
|
|
28
|
+
}
|
|
29
|
+
export function toStandardYearMonth1 () {
|
|
30
|
+
let dt = new Date()
|
|
31
|
+
let month = dt.getMonth() + 1
|
|
32
|
+
return dt.getFullYear() + (month < 10 ? '0' + month : month)
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
export function toStandardDateString () {
|
|
36
|
+
let dt = new Date()
|
|
37
|
+
let month = dt.getMonth() + 1
|
|
38
|
+
let date = dt.getDate()
|
|
39
|
+
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export function toStartAndEndDateString () {
|
|
43
|
+
let dt = new Date()
|
|
44
|
+
let month = dt.getMonth() + 1
|
|
45
|
+
// let date = dt.getDate()
|
|
46
|
+
return [dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-01',
|
|
47
|
+
dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (new Date(dt.getFullYear(), month, 0).getDate())]
|
|
48
|
+
// return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export function toStandardTimeString () {
|
|
52
|
+
let dt = new Date()
|
|
53
|
+
let month = dt.getMonth() + 1
|
|
54
|
+
let date = dt.getDate()
|
|
55
|
+
let hour = dt.getHours()
|
|
56
|
+
let min = dt.getMinutes()
|
|
57
|
+
let sec = dt.getSeconds()
|
|
58
|
+
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date) +
|
|
59
|
+
' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
export function to3339TimeString () {
|
|
63
|
+
let dt = new Date()
|
|
64
|
+
let month = dt.getMonth() + 1
|
|
65
|
+
let date = dt.getDate()
|
|
66
|
+
let hour = dt.getHours()
|
|
67
|
+
let min = dt.getMinutes()
|
|
68
|
+
let sec = dt.getSeconds()
|
|
69
|
+
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date) +
|
|
70
|
+
'T' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export function parse3339String (strDate) {
|
|
74
|
+
return new Date(
|
|
75
|
+
strDate.substr(0, 4), strDate.substr(5, 2) - 1, strDate.substr(8, 2),
|
|
76
|
+
strDate.substr(11, 2), strDate.substr(14, 2), strDate.substr(17, 2)
|
|
77
|
+
)
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
export function format3339TimeString (dt) {
|
|
81
|
+
let month = dt.getMonth() + 1
|
|
82
|
+
let date = dt.getDate()
|
|
83
|
+
let hour = dt.getHours()
|
|
84
|
+
let min = dt.getMinutes()
|
|
85
|
+
let sec = dt.getSeconds()
|
|
86
|
+
return dt.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (date < 10 ? '0' + date : date)
|
|
87
|
+
+ 'T' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
export function guid () {
|
|
91
|
+
let buf = new Uint16Array(8)
|
|
92
|
+
window.crypto.getRandomValues(buf)
|
|
93
|
+
let S4 = function (num) {
|
|
94
|
+
let ret = num.toString(16)
|
|
95
|
+
while (ret.length < 4) {
|
|
96
|
+
ret = '0' + ret
|
|
97
|
+
}
|
|
98
|
+
return ret
|
|
99
|
+
}
|
|
100
|
+
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]))
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
export function choices (role, param, hasBlank = false, blankHint = '请选择') {
|
|
104
|
+
if (role == 'view') {
|
|
105
|
+
Vue.getParams(param, [null])
|
|
106
|
+
} else {
|
|
107
|
+
let result = []
|
|
108
|
+
if (hasBlank)
|
|
109
|
+
result.push({label: blankHint, value: null})
|
|
110
|
+
if (!Vue.param || !Vue.param[param])
|
|
111
|
+
result.push({label: '请在系统设置里更新参数', value: '请在系统设置里更新参数'})
|
|
112
|
+
else {
|
|
113
|
+
let p = Vue.param[param]
|
|
114
|
+
p.forEach(function (item) {
|
|
115
|
+
result.push({label: item.name, value: item.name})
|
|
116
|
+
})
|
|
117
|
+
}
|
|
118
|
+
return result
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
export function required (param) {
|
|
123
|
+
if (typeof param === 'number' && param == 0)
|
|
124
|
+
return false
|
|
125
|
+
if (!param)
|
|
126
|
+
return true
|
|
127
|
+
param = param + ''
|
|
128
|
+
param = param.trim()
|
|
129
|
+
if (!param)
|
|
130
|
+
return true
|
|
131
|
+
return false
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
export function isInt (n) {
|
|
135
|
+
return !window.isNaN(n) && n % 1 === 0
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
export function isFloat (n) {
|
|
139
|
+
return !window.isNaN(n)
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
// this will convert all true/false to boolean
|
|
143
|
+
export function booleanFilter (paper) {
|
|
144
|
+
for (let key in paper) {
|
|
145
|
+
if (!paper.hasOwnProperty(key))
|
|
146
|
+
continue
|
|
147
|
+
if (typeof paper[key] == 'object' && paper[key] != null) {
|
|
148
|
+
booleanFilter(paper[key])
|
|
149
|
+
} else {
|
|
150
|
+
if (paper[key] === 'true' || paper[key] == 'false')
|
|
151
|
+
paper[key] = (paper[key] === 'true')
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
// recursively traverse through each path
|
|
156
|
+
export function ratifyPics (paper) {
|
|
157
|
+
for (let key in paper) {
|
|
158
|
+
if (key.endsWith('_path')) {
|
|
159
|
+
if (!paper[key]) {
|
|
160
|
+
paper[key] = 'rs/db/file/nopic.png'
|
|
161
|
+
} else {
|
|
162
|
+
paper[key] = 'rs/db/file/' + paper[key]
|
|
163
|
+
}
|
|
164
|
+
} else if (paper[key] !== null && typeof (paper[key]) == 'object') {
|
|
165
|
+
ratifyPics(paper[key])
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
// load script and other stuff
|
|
171
|
+
export function loadscript (type, fileName) {
|
|
172
|
+
return new Promise((resolve, reject) => {
|
|
173
|
+
let element
|
|
174
|
+
if (type == 'css') {
|
|
175
|
+
element = document.createElement('link')
|
|
176
|
+
element.setAttribute('rel', 'stylesheet')
|
|
177
|
+
element.setAttribute('type', 'text/css')
|
|
178
|
+
element.setAttribute('href', fileName)
|
|
179
|
+
} else if (type == 'js') {
|
|
180
|
+
element = document.createElement('script')
|
|
181
|
+
element.setAttribute('type', 'text/javascript')
|
|
182
|
+
element.setAttribute('src', fileName)
|
|
183
|
+
}
|
|
184
|
+
if (element) {
|
|
185
|
+
element.setAttribute('async', '')
|
|
186
|
+
element.setAttribute('defer', '')
|
|
187
|
+
element.addEventListener('load', function () {
|
|
188
|
+
resolve(element)
|
|
189
|
+
}, false)
|
|
190
|
+
element.addEventListener('error', function () {
|
|
191
|
+
reject(element)
|
|
192
|
+
}, false)
|
|
193
|
+
document.body.appendChild(element)
|
|
194
|
+
}
|
|
195
|
+
})
|
|
196
|
+
}
|
|
197
|
+
// 不能选择器中截取掉多余的字符
|
|
198
|
+
export function orgName (name) {
|
|
199
|
+
return name.substring(10)
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
export function getNowDate (name) {
|
|
203
|
+
// 求取当前时间的工具
|
|
204
|
+
let myweekday = ''
|
|
205
|
+
let year = ''
|
|
206
|
+
let mydate = new Date()
|
|
207
|
+
myweekday = mydate.getDay()
|
|
208
|
+
let mymonth = mydate.getMonth() + 1
|
|
209
|
+
let myday = mydate.getDate()
|
|
210
|
+
let myyear = mydate.getYear()
|
|
211
|
+
year = (myyear > 200) ? myyear : 1900 + myyear
|
|
212
|
+
let week = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期日', '星期六']
|
|
213
|
+
// document.write("<font color=#ffffff>今天是 "+year+"年"+mymonth+"月"+myday+"日 "+weekday+"</font>");
|
|
214
|
+
return year + '年' + mymonth + '月' + myday + '日 ' + week[myweekday]
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
export function addDate (date, days) {
|
|
218
|
+
// 求取当前时间的工具
|
|
219
|
+
let endDate = new Date(date)
|
|
220
|
+
endDate = endDate.valueOf()
|
|
221
|
+
endDate = endDate + days * 24 * 60 * 60 * 1000
|
|
222
|
+
endDate = new Date(endDate)
|
|
223
|
+
let month = endDate.getMonth() + 1
|
|
224
|
+
let day = endDate.getDate()
|
|
225
|
+
let hour = endDate.getHours()
|
|
226
|
+
let min = endDate.getMinutes()
|
|
227
|
+
let sec = endDate.getSeconds()
|
|
228
|
+
return endDate.getFullYear() + '-' + (month < 10 ? '0' + month : month) + '-' + (day < 10 ? '0' + day : day) +
|
|
229
|
+
' ' + (hour < 10 ? '0' + hour : hour) + ':' + (min < 10 ? '0' + min : min) + ':' + (sec < 10 ? '0' + sec : sec)
|
|
230
|
+
// return a
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
// 通过地址栏的参数获取参数内容
|
|
234
|
+
export function getUrlParames (param) {
|
|
235
|
+
var query = window.location.search
|
|
236
|
+
var iLen = param.length
|
|
237
|
+
var iStart = query.indexOf(param)
|
|
238
|
+
if (iStart === -1) {
|
|
239
|
+
return ''
|
|
240
|
+
}
|
|
241
|
+
iStart += iLen + 1
|
|
242
|
+
var iEnd = query.indexOf('&', iStart)
|
|
243
|
+
if (iEnd === -1) {
|
|
244
|
+
return query.substring(iStart)
|
|
245
|
+
}
|
|
246
|
+
return query.substring(iStart, iEnd)
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
// 从地址栏获取加密的参数
|
|
250
|
+
export function getUrlCompileParames (param) {
|
|
251
|
+
var query = uncompileStr(window.location.search.slice(1, window.location.search.length))
|
|
252
|
+
var iLen = param.length
|
|
253
|
+
var iStart = query.indexOf(param)
|
|
254
|
+
if (iStart === -1) {
|
|
255
|
+
return ''
|
|
256
|
+
}
|
|
257
|
+
iStart += iLen + 1
|
|
258
|
+
var iEnd = query.indexOf('&', iStart)
|
|
259
|
+
if (iEnd === -1) {
|
|
260
|
+
return query.substring(iStart)
|
|
261
|
+
}
|
|
262
|
+
return query.substring(iStart, iEnd)
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
// 对字符串进行加密
|
|
266
|
+
export function compileStr (code) {
|
|
267
|
+
let c = String.fromCharCode(code.charCodeAt(0) + code.length)
|
|
268
|
+
for (let i = 1; i < code.length; i++) {
|
|
269
|
+
c += String.fromCharCode(code.charCodeAt(i) + code.charCodeAt(i - 1))
|
|
270
|
+
}
|
|
271
|
+
return escape(c)
|
|
272
|
+
}
|
|
273
|
+
// 字符串进行解密
|
|
274
|
+
export function uncompileStr (code) {
|
|
275
|
+
code = unescape(code)
|
|
276
|
+
let c = String.fromCharCode(code.charCodeAt(0) - code.length)
|
|
277
|
+
for (var i = 1; i < code.length; i++) {
|
|
278
|
+
c += String.fromCharCode(code.charCodeAt(i) - c.charCodeAt(i - 1))
|
|
279
|
+
}
|
|
280
|
+
return c
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
export function dateDescripte (date) {
|
|
284
|
+
let nowTime = new Date().getTime()
|
|
285
|
+
let oldTime = new Date(date).getTime()
|
|
286
|
+
let timeDiff = nowTime - oldTime
|
|
287
|
+
// 规则说明
|
|
288
|
+
// 小于等于2分钟为刚刚
|
|
289
|
+
// 大于2分钟小于等于1小时为取整的分钟前(例如:35分钟前)
|
|
290
|
+
// 大于1小时小于等于24小时为取整的小时前(例如:15小时前)
|
|
291
|
+
// 大于24小时小于等于30天为取整的天前(例如:12天前)
|
|
292
|
+
// 大于30天小于等于12月为取整的月前,月份统一为30天一月,不做额外处理(例如:3个月前)
|
|
293
|
+
// 大于365取整的年前,(例如:2年前)
|
|
294
|
+
let minute = 1000 * 60
|
|
295
|
+
let hour = minute * 60
|
|
296
|
+
let day = hour * 24
|
|
297
|
+
let month = day * 30
|
|
298
|
+
let year = month * 12
|
|
299
|
+
let des = ''
|
|
300
|
+
if (timeDiff <= minute * 2) {
|
|
301
|
+
des = '刚刚'
|
|
302
|
+
} else if (minute * 2 < timeDiff && timeDiff < hour) {
|
|
303
|
+
des = `${Math.floor(timeDiff / minute)}分钟前`
|
|
304
|
+
} else if (hour < timeDiff && timeDiff <= day) {
|
|
305
|
+
des = `${Math.floor(timeDiff / hour)}小时前`
|
|
306
|
+
} else if (day < timeDiff && timeDiff <= month) {
|
|
307
|
+
des = `${Math.floor(timeDiff / day)}天前`
|
|
308
|
+
} else if (month < timeDiff && timeDiff <= year) {
|
|
309
|
+
des = `${Math.floor(timeDiff / month)}个月前`
|
|
310
|
+
} else if (year < timeDiff) {
|
|
311
|
+
des = `${Math.floor(timeDiff / year)}年前`
|
|
312
|
+
}
|
|
313
|
+
return des
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
export function nextMonth20 (date) {
|
|
317
|
+
let ds = date.split('-')
|
|
318
|
+
let nextMonth = ds[1] - 0 + 1
|
|
319
|
+
return ds[0] + '-' + (nextMonth < 10 ? '0' + nextMonth : nextMonth) + '-20 00:00:00'
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
// export function getNowDate () {
|
|
323
|
+
// // 求取当前时间的工具
|
|
324
|
+
// let myweekday = ''
|
|
325
|
+
// let year = ''
|
|
326
|
+
// let mydate = new Date()
|
|
327
|
+
// myweekday = mydate.getDay()
|
|
328
|
+
// let mymonth = mydate.getMonth() + 1
|
|
329
|
+
// let myday = mydate.getDate()
|
|
330
|
+
// let myyear = mydate.getYear()
|
|
331
|
+
// year = (myyear > 200) ? myyear : 1900 + myyear
|
|
332
|
+
// let week = ['星期日','星期一','星期二','星期三','星期四','星期五','星期日','星期六']
|
|
333
|
+
// let weekday = week[myweekday]
|
|
334
|
+
//
|
|
335
|
+
// // document.write("<font color=#ffffff>今天是 "+year+"年"+mymonth+"月"+myday+"日 "+weekday+"</font>");
|
|
336
|
+
// return year + '年' + mymonth + '月' + myday + '日 ' + weekday
|
|
337
|
+
// }
|
|
338
|
+
//
|
|
339
|
+
// export function getImgsrc (name) {
|
|
340
|
+
// return "http://127.0.0.1:8081/images/"+name+".gif"
|
|
341
|
+
// }
|
|
342
|
+
//
|
|
343
|
+
// export var f;
|
|
@@ -218,30 +218,39 @@ import {HttpResetClass, PagedList} from 'vue-client'
|
|
|
218
218
|
},
|
|
219
219
|
getEditState () {
|
|
220
220
|
if (this.model.f_state === '正常') {
|
|
221
|
-
this.$showMessage(`当前设备号: ${this.model.f_terminal_number} ,确认停用该设备?`, ['confirm', 'cancel']).then((res) => {
|
|
221
|
+
this.$showMessage(`当前设备号: ${this.model.f_terminal_number} ,确认停用该设备?`, ['confirm', 'cancel']).then(async (res) => {
|
|
222
222
|
if (res === 'confirm') {
|
|
223
223
|
this.$showAlert(`已向设备号: ${this.model.f_terminal_number}发送停用指令,请稍后查看执行结果!`, 'success', 2500)
|
|
224
224
|
this.model.f_state = '停用'
|
|
225
225
|
try {
|
|
226
|
-
this.$resetpost('api/af-system/logic/batchPos',{data: {tasks: [this.data], taskState: 0}}, {rejectMsg: null, resolveMsg: null})
|
|
226
|
+
await this.$resetpost('api/af-system/logic/batchPos',{data: {tasks: [{... this.data, sn: this.data.f_terminal_number, taskState: '0'}], taskState: 0}}, {rejectMsg: null, resolveMsg: null})
|
|
227
|
+
await this.$resetpost('api/af-revenue/logic/saveEquipmentLogicV3', {f_state: '停用', id: this.model.id, type: 'one'}, {
|
|
228
|
+
rejectMsg: null,
|
|
229
|
+
resolveMsg: null
|
|
230
|
+
})
|
|
227
231
|
} catch (error) {
|
|
228
232
|
this.search()
|
|
229
233
|
}
|
|
230
234
|
}
|
|
231
235
|
})
|
|
232
236
|
} else if (this.model.f_state === '停用'){
|
|
233
|
-
this.$showMessage(`当前设备号: ${this.model.f_terminal_number} ,确认启用该设备?`, ['confirm', 'cancel']).then((res) => {
|
|
237
|
+
this.$showMessage(`当前设备号: ${this.model.f_terminal_number} ,确认启用该设备?`, ['confirm', 'cancel']).then(async (res) => {
|
|
234
238
|
if (res === 'confirm') {
|
|
235
239
|
this.$showAlert(`已向设备号: ${this.model.f_terminal_number}发送启用指令,请稍后查看执行结果!`, 'success', 2500)
|
|
236
240
|
this.model.f_state = '正常'
|
|
237
241
|
try {
|
|
238
|
-
this.$resetpost('api/af-system/logic/batchPos',{data: {tasks: [this.data], taskState: 1}}, {rejectMsg: null, resolveMsg: null})
|
|
242
|
+
await this.$resetpost('api/af-system/logic/batchPos',{data: {tasks: [{... this.data, sn: this.data.f_terminal_number, taskState: '1'}], taskState: 1}}, {rejectMsg: null, resolveMsg: null})
|
|
243
|
+
await this.$resetpost('api/af-revenue/logic/saveEquipmentLogicV3', {f_state: '正常', id: this.model.id, type: 'one'}, {
|
|
244
|
+
rejectMsg: null,
|
|
245
|
+
resolveMsg: null
|
|
246
|
+
})
|
|
239
247
|
} catch (error) {
|
|
240
248
|
this.search()
|
|
241
249
|
}
|
|
242
250
|
}
|
|
243
251
|
})
|
|
244
252
|
}
|
|
253
|
+
|
|
245
254
|
},
|
|
246
255
|
editBeizhu (val) {
|
|
247
256
|
this.editshow = true
|
|
@@ -233,31 +233,45 @@
|
|
|
233
233
|
// 批量操作
|
|
234
234
|
async batchRoot(val) {
|
|
235
235
|
let arrs = []
|
|
236
|
+
let entityArr = []
|
|
236
237
|
let alertMessage = ''
|
|
237
238
|
let selPos = this.selPos
|
|
238
239
|
if (val === '0') {
|
|
239
240
|
alertMessage = '停用'
|
|
240
241
|
for (const tmp of selPos) {
|
|
241
|
-
if (tmp.f_state === '正常')
|
|
242
|
+
if (tmp.f_state === '正常') {
|
|
243
|
+
arrs.push({... tmp, sn: tmp.f_terminal_number, taskState: val})
|
|
244
|
+
entityArr.push({id: tmp.id, version: tmp.version, f_state: '停用'})
|
|
245
|
+
}
|
|
242
246
|
}
|
|
243
247
|
} else if (val === '1') {
|
|
244
248
|
alertMessage = '启用'
|
|
245
249
|
for (const tmp of selPos) {
|
|
246
|
-
if (tmp.f_state === '停用')
|
|
250
|
+
if (tmp.f_state === '停用') {
|
|
251
|
+
arrs.push({... tmp, sn: tmp.f_terminal_number, taskState: val})
|
|
252
|
+
entityArr.push({id: tmp.id, version: tmp.version, f_state: '正常'})
|
|
253
|
+
}
|
|
247
254
|
}
|
|
248
255
|
} else if (val === '2') {
|
|
249
256
|
alertMessage = '升级'
|
|
250
257
|
for (const tmp of selPos) {
|
|
251
|
-
if (tmp.f_state === '正常') arrs.push(tmp)
|
|
258
|
+
if (tmp.f_state === '正常') arrs.push({... tmp, sn: tmp.f_terminal_number, taskState: val})
|
|
252
259
|
}
|
|
253
260
|
} else {
|
|
254
261
|
this.showAlert('出现异常,请重新进操作')
|
|
255
262
|
return
|
|
256
263
|
}
|
|
264
|
+
console.log('arrs', arrs)
|
|
265
|
+
console.log('entityArr', entityArr)
|
|
257
266
|
await this.$resetpost('api/af-system/logic/batchPos', {data: {tasks: arrs, taskState: val}}, {
|
|
258
267
|
rejectMsg: null,
|
|
259
268
|
resolveMsg: null
|
|
260
269
|
})
|
|
270
|
+
await this.$resetpost('api/af-revenue/logic/saveEquipmentLogicV3', {arr: entityArr, type: 'batch'}, {
|
|
271
|
+
rejectMsg: null,
|
|
272
|
+
resolveMsg: null
|
|
273
|
+
})
|
|
274
|
+
this.search()
|
|
261
275
|
// 需要提示
|
|
262
276
|
this.$showAlert(`已经开始批量${alertMessage},选择${selPos.length},其中${arrs.length}台可以正常${alertMessage},具体请留意设备情况,并刷新列表查看执行结果!`,'success', 2500)
|
|
263
277
|
this.$dispatch('close')
|
|
@@ -1,188 +1,188 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div class="auto">
|
|
3
|
-
<div class="head">
|
|
4
|
-
<img src="../../../static/loginlogo.png" alt="图片加载未完成"
|
|
5
|
-
style="float:left;width: 100px; height: 80px; margin: 10px 20px 20px 20px;"/>
|
|
6
|
-
<div style="float:left;width:auto;height:130px;padding-top:10px;">
|
|
7
|
-
<h3 style="font-size: 22px;">欢迎使用陕西燃气管理系统</h3>
|
|
8
|
-
<h5 style="font-size: 15px;">Welcome to ShanXi GAS Manage System</h5>
|
|
9
|
-
</div>
|
|
10
|
-
|
|
11
|
-
<h5 style="float:right;margin-top:70px;margin-right:80px;">
|
|
12
|
-
|
|
13
|
-
<span class="glyphicon glyphicon-calendar"></span>
|
|
14
|
-
{{ date }}
|
|
15
|
-
|
|
16
|
-
<span class="glyphicon glyphicon-copyright-mark"></span>
|
|
17
|
-
系统版本:V1.0.0
|
|
18
|
-
|
|
19
|
-
<span class="glyphicon glyphicon-th-large"></span>
|
|
20
|
-
蓝色主题
|
|
21
|
-
<a href="#" style="color:#fff;text-decoration:none;" @click.stop.prevent="modify=true">
|
|
22
|
-
<span class="glyphicon glyphicon-cog"></span>
|
|
23
|
-
修改密码
|
|
24
|
-
</a>
|
|
25
|
-
</h5>
|
|
26
|
-
</div>
|
|
27
|
-
<div class="auto">
|
|
28
|
-
<!-- 白线div -->
|
|
29
|
-
<div class="whiteline">
|
|
30
|
-
</div>
|
|
31
|
-
<select-menu :model="functions.functions"></select-menu>
|
|
32
|
-
</div>
|
|
33
|
-
<modal v-ref:modal :show.sync="modify" :backdrop="false" class="auto">
|
|
34
|
-
<header slot="modal-header" class="modal-header">
|
|
35
|
-
<h4 class="modal-title">修改密码</h4>
|
|
36
|
-
</header>
|
|
37
|
-
<article slot="modal-body" class="modal-body modifystyle">
|
|
38
|
-
<validator name="v">
|
|
39
|
-
|
|
40
|
-
<div class="has-feedback"
|
|
41
|
-
:class="{'has-warning':$v.password.required,'has-error':$v.password.equalValid && !($v.password.required),
|
|
42
|
-
'has-success': !$v.password.required && !($v.password.equalValid && !($v.password.required))}">
|
|
43
|
-
<label for="password" class="control-label">原始密码: </label>
|
|
44
|
-
<input type="password" v-model="deliver.password" class="form-control" id="password" v-validate:password="{ required: true, equalValid: functions.password }">
|
|
45
|
-
<span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.password.required && !($v.password.equalValid && !($v.password.required))"></span>
|
|
46
|
-
<!-- <span class="glyphicon form-control-feedback"
|
|
47
|
-
:class="{'glyphicon-warning-sign':$v.password.required,'glyphicon-remove'$v.password.equalValid && !($v.password.required):,
|
|
48
|
-
'glyphicon-ok':!$v.password.required && !($v.password.equalValid && !($v.password.required))}"></span> -->
|
|
49
|
-
<span v-if="$v.password.required">不能为空</span>
|
|
50
|
-
<span v-if="$v.password.equalValid && !($v.password.required)">原始密码错误 !!</span>
|
|
51
|
-
</div>
|
|
52
|
-
|
|
53
|
-
<div class="has-feedback"
|
|
54
|
-
:class="{'has-warning':$v.newpassword.required, 'has-success': !$v.newpassword.required}">
|
|
55
|
-
<label for="newpassword" class="control-label">新的密码: </label>
|
|
56
|
-
<input type="password" v-model="deliver.newpassword" class="form-control" id="newpassword" v-validate:newpassword='{ required: true }'>
|
|
57
|
-
<span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.newpassword.required"></span>
|
|
58
|
-
<!-- <span class="glyphicon form-control-feedback"
|
|
59
|
-
:class="{'glyphicon-warning-sign':$v.newpassword.required,'glyphicon-ok':!$v.newpassword.required }"></span> -->
|
|
60
|
-
<span v-if="$v.newpassword.required">不能为空</span>
|
|
61
|
-
</div>
|
|
62
|
-
|
|
63
|
-
<div class="has-feedback"
|
|
64
|
-
:class="{'has-warning':$v.affirmpassword.required,'has-error':$v.affirmpassword.equalValid && !($v.affirmpassword.required),
|
|
65
|
-
'has-success': !$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))}">
|
|
66
|
-
<label for="affirmpassword" class="control-label">确认密码: </label>
|
|
67
|
-
<input type="password" v-model="deliver.affirmpassword" class="form-control" id="affirmpassword" v-validate:affirmpassword="{ required: true, equalValid: deliver.newpassword }">
|
|
68
|
-
<span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))"></span>
|
|
69
|
-
<!-- <span class="glyphicon form-control-feedback"
|
|
70
|
-
:class="{'glyphicon-warning-sign':$v.affirmpassword.required,'glyphicon-remove'$v.affirmpassword.equalValid && !($v.affirmpassword.required):,
|
|
71
|
-
'glyphicon-ok':!$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))}"></span> -->
|
|
72
|
-
<span v-if="$v.affirmpassword.required">不能为空</span>
|
|
73
|
-
<span v-if="$v.affirmpassword.equalValid && !($v.affirmpassword.required)">两次密码不一致 !!</span>
|
|
74
|
-
</div>
|
|
75
|
-
|
|
76
|
-
</validator>
|
|
77
|
-
</article>
|
|
78
|
-
<footer slot="modal-footer" class="footerbtn">
|
|
79
|
-
<button type="button" class="btn btn-success" @click='confirm' :disabled="!$v.valid">确认</button>
|
|
80
|
-
<button type="button" class="btn btn-default" @click='close'>取消</button>
|
|
81
|
-
</footer>
|
|
82
|
-
<modal>
|
|
83
|
-
<!-- modifyPassword() -->
|
|
84
|
-
</modal>
|
|
85
|
-
</modal>
|
|
86
|
-
</div>
|
|
87
|
-
</template>
|
|
88
|
-
|
|
89
|
-
<script>
|
|
90
|
-
import co from 'co'
|
|
91
|
-
import * as Util from '../Util'
|
|
92
|
-
|
|
93
|
-
let saveGen = function * (self) {
|
|
94
|
-
self.deliver.ename = self.functions.ename
|
|
95
|
-
// let res = yield self.$post('rs/user/entity', {data: self.deliver})
|
|
96
|
-
// let res = yield self.$post('rs/db/modifypassword', {data: self.deliver})
|
|
97
|
-
let res = yield self.$post('rs/db/modifypwd', {data: self.deliver})
|
|
98
|
-
if (res.status === 200 || res.status === 204) {
|
|
99
|
-
self.modify = false
|
|
100
|
-
self.deliver.password = ''
|
|
101
|
-
self.deliver.newpassword = ''
|
|
102
|
-
self.deliver.affirmpassword = ''
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
export default {
|
|
107
|
-
title: '菜单选择',
|
|
108
|
-
props: ['functions'],
|
|
109
|
-
data () {
|
|
110
|
-
return {
|
|
111
|
-
modify: false,
|
|
112
|
-
deliver: {
|
|
113
|
-
password: '',
|
|
114
|
-
newpassword: '',
|
|
115
|
-
affirmpassword: ''
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
},
|
|
119
|
-
computed: {
|
|
120
|
-
date () {
|
|
121
|
-
return Util.getNowDate()
|
|
122
|
-
}
|
|
123
|
-
},
|
|
124
|
-
methods: {
|
|
125
|
-
open (row) {
|
|
126
|
-
if (row.link) {
|
|
127
|
-
// this.$goto(row.link, {userid: this.functions, source: {isRead: 'modify'}}, 'home-page')
|
|
128
|
-
this.$goto(row.link, {f: this.functions}, 'home-page')
|
|
129
|
-
}
|
|
130
|
-
},
|
|
131
|
-
// 修改密码操作
|
|
132
|
-
close () {
|
|
133
|
-
this.modify = false
|
|
134
|
-
},
|
|
135
|
-
confirm () {
|
|
136
|
-
let gen = saveGen(this)
|
|
137
|
-
co(gen)
|
|
138
|
-
}
|
|
139
|
-
},
|
|
140
|
-
events: {
|
|
141
|
-
'select-changed': function (data) {
|
|
142
|
-
// 事件回调内的 `this` 自动绑定到注册它的实例上
|
|
143
|
-
this.open(data.val)
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
</script>
|
|
148
|
-
<style>
|
|
149
|
-
/* 头部样式,大部分使用放在标签内 */
|
|
150
|
-
.head {
|
|
151
|
-
color: #fff;
|
|
152
|
-
height: 110px;
|
|
153
|
-
width: 100%;
|
|
154
|
-
}
|
|
155
|
-
/* 菜单头部与内容区域的中间的白色线 */
|
|
156
|
-
.whiteline {
|
|
157
|
-
height: 1px;
|
|
158
|
-
background: #fff;
|
|
159
|
-
margin: 0px 30px;
|
|
160
|
-
}
|
|
161
|
-
/*修改密码body界面样式*/
|
|
162
|
-
.modifystyle {
|
|
163
|
-
background: #FCFEEE;
|
|
164
|
-
}
|
|
165
|
-
.modifystyle div{
|
|
166
|
-
height: auto;
|
|
167
|
-
margin-bottom: 15px;
|
|
168
|
-
/*text-align: center;*/
|
|
169
|
-
margin-left: 20%;
|
|
170
|
-
}
|
|
171
|
-
/*bootstrap字体图标要手动调整,所以使用字体图标的span必须紧跟在input后面,负责会错位*/
|
|
172
|
-
.modifystyle div input + span{
|
|
173
|
-
top: 0!important;
|
|
174
|
-
right: 32%;
|
|
175
|
-
}
|
|
176
|
-
.modifystyle span{
|
|
177
|
-
color: red;
|
|
178
|
-
}
|
|
179
|
-
/*修改密码底部按钮部分样式*/
|
|
180
|
-
.footerbtn {
|
|
181
|
-
text-align: center;
|
|
182
|
-
padding: 15px;
|
|
183
|
-
}
|
|
184
|
-
.footerbtn button {
|
|
185
|
-
width: 100px;
|
|
186
|
-
margin-left: 20px;
|
|
187
|
-
}
|
|
188
|
-
</style>
|
|
1
|
+
<template>
|
|
2
|
+
<div class="auto">
|
|
3
|
+
<div class="head">
|
|
4
|
+
<img src="../../../static/loginlogo.png" alt="图片加载未完成"
|
|
5
|
+
style="float:left;width: 100px; height: 80px; margin: 10px 20px 20px 20px;"/>
|
|
6
|
+
<div style="float:left;width:auto;height:130px;padding-top:10px;">
|
|
7
|
+
<h3 style="font-size: 22px;">欢迎使用陕西燃气管理系统</h3>
|
|
8
|
+
<h5 style="font-size: 15px;">Welcome to ShanXi GAS Manage System</h5>
|
|
9
|
+
</div>
|
|
10
|
+
|
|
11
|
+
<h5 style="float:right;margin-top:70px;margin-right:80px;">
|
|
12
|
+
|
|
13
|
+
<span class="glyphicon glyphicon-calendar"></span>
|
|
14
|
+
{{ date }}
|
|
15
|
+
|
|
16
|
+
<span class="glyphicon glyphicon-copyright-mark"></span>
|
|
17
|
+
系统版本:V1.0.0
|
|
18
|
+
|
|
19
|
+
<span class="glyphicon glyphicon-th-large"></span>
|
|
20
|
+
蓝色主题
|
|
21
|
+
<a href="#" style="color:#fff;text-decoration:none;" @click.stop.prevent="modify=true">
|
|
22
|
+
<span class="glyphicon glyphicon-cog"></span>
|
|
23
|
+
修改密码
|
|
24
|
+
</a>
|
|
25
|
+
</h5>
|
|
26
|
+
</div>
|
|
27
|
+
<div class="auto">
|
|
28
|
+
<!-- 白线div -->
|
|
29
|
+
<div class="whiteline">
|
|
30
|
+
</div>
|
|
31
|
+
<select-menu :model="functions.functions"></select-menu>
|
|
32
|
+
</div>
|
|
33
|
+
<modal v-ref:modal :show.sync="modify" :backdrop="false" class="auto">
|
|
34
|
+
<header slot="modal-header" class="modal-header">
|
|
35
|
+
<h4 class="modal-title">修改密码</h4>
|
|
36
|
+
</header>
|
|
37
|
+
<article slot="modal-body" class="modal-body modifystyle">
|
|
38
|
+
<validator name="v">
|
|
39
|
+
|
|
40
|
+
<div class="has-feedback"
|
|
41
|
+
:class="{'has-warning':$v.password.required,'has-error':$v.password.equalValid && !($v.password.required),
|
|
42
|
+
'has-success': !$v.password.required && !($v.password.equalValid && !($v.password.required))}">
|
|
43
|
+
<label for="password" class="control-label">原始密码: </label>
|
|
44
|
+
<input type="password" v-model="deliver.password" class="form-control" id="password" v-validate:password="{ required: true, equalValid: functions.password }">
|
|
45
|
+
<span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.password.required && !($v.password.equalValid && !($v.password.required))"></span>
|
|
46
|
+
<!-- <span class="glyphicon form-control-feedback"
|
|
47
|
+
:class="{'glyphicon-warning-sign':$v.password.required,'glyphicon-remove'$v.password.equalValid && !($v.password.required):,
|
|
48
|
+
'glyphicon-ok':!$v.password.required && !($v.password.equalValid && !($v.password.required))}"></span> -->
|
|
49
|
+
<span v-if="$v.password.required">不能为空</span>
|
|
50
|
+
<span v-if="$v.password.equalValid && !($v.password.required)">原始密码错误 !!</span>
|
|
51
|
+
</div>
|
|
52
|
+
|
|
53
|
+
<div class="has-feedback"
|
|
54
|
+
:class="{'has-warning':$v.newpassword.required, 'has-success': !$v.newpassword.required}">
|
|
55
|
+
<label for="newpassword" class="control-label">新的密码: </label>
|
|
56
|
+
<input type="password" v-model="deliver.newpassword" class="form-control" id="newpassword" v-validate:newpassword='{ required: true }'>
|
|
57
|
+
<span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.newpassword.required"></span>
|
|
58
|
+
<!-- <span class="glyphicon form-control-feedback"
|
|
59
|
+
:class="{'glyphicon-warning-sign':$v.newpassword.required,'glyphicon-ok':!$v.newpassword.required }"></span> -->
|
|
60
|
+
<span v-if="$v.newpassword.required">不能为空</span>
|
|
61
|
+
</div>
|
|
62
|
+
|
|
63
|
+
<div class="has-feedback"
|
|
64
|
+
:class="{'has-warning':$v.affirmpassword.required,'has-error':$v.affirmpassword.equalValid && !($v.affirmpassword.required),
|
|
65
|
+
'has-success': !$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))}">
|
|
66
|
+
<label for="affirmpassword" class="control-label">确认密码: </label>
|
|
67
|
+
<input type="password" v-model="deliver.affirmpassword" class="form-control" id="affirmpassword" v-validate:affirmpassword="{ required: true, equalValid: deliver.newpassword }">
|
|
68
|
+
<span class="glyphicon glyphicon-ok form-control-feedback" v-if="!$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))"></span>
|
|
69
|
+
<!-- <span class="glyphicon form-control-feedback"
|
|
70
|
+
:class="{'glyphicon-warning-sign':$v.affirmpassword.required,'glyphicon-remove'$v.affirmpassword.equalValid && !($v.affirmpassword.required):,
|
|
71
|
+
'glyphicon-ok':!$v.affirmpassword.required && !($v.affirmpassword.equalValid && !($v.affirmpassword.required))}"></span> -->
|
|
72
|
+
<span v-if="$v.affirmpassword.required">不能为空</span>
|
|
73
|
+
<span v-if="$v.affirmpassword.equalValid && !($v.affirmpassword.required)">两次密码不一致 !!</span>
|
|
74
|
+
</div>
|
|
75
|
+
|
|
76
|
+
</validator>
|
|
77
|
+
</article>
|
|
78
|
+
<footer slot="modal-footer" class="footerbtn">
|
|
79
|
+
<button type="button" class="btn btn-success" @click='confirm' :disabled="!$v.valid">确认</button>
|
|
80
|
+
<button type="button" class="btn btn-default" @click='close'>取消</button>
|
|
81
|
+
</footer>
|
|
82
|
+
<modal>
|
|
83
|
+
<!-- modifyPassword() -->
|
|
84
|
+
</modal>
|
|
85
|
+
</modal>
|
|
86
|
+
</div>
|
|
87
|
+
</template>
|
|
88
|
+
|
|
89
|
+
<script>
|
|
90
|
+
import co from 'co'
|
|
91
|
+
import * as Util from '../Util'
|
|
92
|
+
|
|
93
|
+
let saveGen = function * (self) {
|
|
94
|
+
self.deliver.ename = self.functions.ename
|
|
95
|
+
// let res = yield self.$post('rs/user/entity', {data: self.deliver})
|
|
96
|
+
// let res = yield self.$post('rs/db/modifypassword', {data: self.deliver})
|
|
97
|
+
let res = yield self.$post('rs/db/modifypwd', {data: self.deliver})
|
|
98
|
+
if (res.status === 200 || res.status === 204) {
|
|
99
|
+
self.modify = false
|
|
100
|
+
self.deliver.password = ''
|
|
101
|
+
self.deliver.newpassword = ''
|
|
102
|
+
self.deliver.affirmpassword = ''
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
export default {
|
|
107
|
+
title: '菜单选择',
|
|
108
|
+
props: ['functions'],
|
|
109
|
+
data () {
|
|
110
|
+
return {
|
|
111
|
+
modify: false,
|
|
112
|
+
deliver: {
|
|
113
|
+
password: '',
|
|
114
|
+
newpassword: '',
|
|
115
|
+
affirmpassword: ''
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
},
|
|
119
|
+
computed: {
|
|
120
|
+
date () {
|
|
121
|
+
return Util.getNowDate()
|
|
122
|
+
}
|
|
123
|
+
},
|
|
124
|
+
methods: {
|
|
125
|
+
open (row) {
|
|
126
|
+
if (row.link) {
|
|
127
|
+
// this.$goto(row.link, {userid: this.functions, source: {isRead: 'modify'}}, 'home-page')
|
|
128
|
+
this.$goto(row.link, {f: this.functions}, 'home-page')
|
|
129
|
+
}
|
|
130
|
+
},
|
|
131
|
+
// 修改密码操作
|
|
132
|
+
close () {
|
|
133
|
+
this.modify = false
|
|
134
|
+
},
|
|
135
|
+
confirm () {
|
|
136
|
+
let gen = saveGen(this)
|
|
137
|
+
co(gen)
|
|
138
|
+
}
|
|
139
|
+
},
|
|
140
|
+
events: {
|
|
141
|
+
'select-changed': function (data) {
|
|
142
|
+
// 事件回调内的 `this` 自动绑定到注册它的实例上
|
|
143
|
+
this.open(data.val)
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
</script>
|
|
148
|
+
<style>
|
|
149
|
+
/* 头部样式,大部分使用放在标签内 */
|
|
150
|
+
.head {
|
|
151
|
+
color: #fff;
|
|
152
|
+
height: 110px;
|
|
153
|
+
width: 100%;
|
|
154
|
+
}
|
|
155
|
+
/* 菜单头部与内容区域的中间的白色线 */
|
|
156
|
+
.whiteline {
|
|
157
|
+
height: 1px;
|
|
158
|
+
background: #fff;
|
|
159
|
+
margin: 0px 30px;
|
|
160
|
+
}
|
|
161
|
+
/*修改密码body界面样式*/
|
|
162
|
+
.modifystyle {
|
|
163
|
+
background: #FCFEEE;
|
|
164
|
+
}
|
|
165
|
+
.modifystyle div{
|
|
166
|
+
height: auto;
|
|
167
|
+
margin-bottom: 15px;
|
|
168
|
+
/*text-align: center;*/
|
|
169
|
+
margin-left: 20%;
|
|
170
|
+
}
|
|
171
|
+
/*bootstrap字体图标要手动调整,所以使用字体图标的span必须紧跟在input后面,负责会错位*/
|
|
172
|
+
.modifystyle div input + span{
|
|
173
|
+
top: 0!important;
|
|
174
|
+
right: 32%;
|
|
175
|
+
}
|
|
176
|
+
.modifystyle span{
|
|
177
|
+
color: red;
|
|
178
|
+
}
|
|
179
|
+
/*修改密码底部按钮部分样式*/
|
|
180
|
+
.footerbtn {
|
|
181
|
+
text-align: center;
|
|
182
|
+
padding: 15px;
|
|
183
|
+
}
|
|
184
|
+
.footerbtn button {
|
|
185
|
+
width: 100px;
|
|
186
|
+
margin-left: 20px;
|
|
187
|
+
}
|
|
188
|
+
</style>
|
|
Binary file
|
|
File without changes
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
File without changes
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
File without changes
|