system-phone 3.1.49 → 3.1.51
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/.babelrc +5 -5
- package/.editorconfig +9 -9
- package/.eslintrc.js +16 -16
- package/CHANGELOG.md +1 -1
- package/Dockerfile +3 -3
- package/README.md +36 -36
- package/build/css-loaders.js +34 -34
- package/build/dev-client.js +8 -8
- package/build/example-server.js +80 -80
- package/build/release.sh +28 -28
- package/build/utils.js +71 -71
- package/build/webpack.dev.conf.js +31 -31
- package/build/webpack.example.conf.js +49 -49
- package/build/webpack.prod.conf.js +60 -60
- package/build/webpack.test.conf.js +31 -31
- package/config/dev.env.js +6 -6
- package/config/index.js +38 -38
- package/config/prod.env.js +3 -3
- package/config/test.env.js +6 -6
- package/nginx.conf +304 -304
- package/package.json +100 -100
- package/release.bat +5 -5
- package/src/App.vue +25 -25
- package/src/Util.js +415 -415
- package/src/android-bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
- package/src/android-bootstrap/less/.csscomb.json +304 -304
- package/src/android-bootstrap/less/.csslintrc +19 -19
- package/src/android-bootstrap/less/alerts.less +73 -73
- package/src/android-bootstrap/less/badges.less +66 -66
- package/src/android-bootstrap/less/bootstrap.less +56 -56
- package/src/android-bootstrap/less/breadcrumbs.less +26 -26
- package/src/android-bootstrap/less/button-groups.less +247 -247
- package/src/android-bootstrap/less/buttons.less +173 -173
- package/src/android-bootstrap/less/carousel.less +269 -269
- package/src/android-bootstrap/less/close.less +34 -34
- package/src/android-bootstrap/less/code.less +69 -69
- package/src/android-bootstrap/less/component-animations.less +33 -33
- package/src/android-bootstrap/less/dropdowns.less +216 -216
- package/src/android-bootstrap/less/forms.less +626 -626
- package/src/android-bootstrap/less/glyphicons.less +305 -305
- package/src/android-bootstrap/less/grid.less +84 -84
- package/src/android-bootstrap/less/input-groups.less +167 -167
- package/src/android-bootstrap/less/jumbotron.less +52 -52
- package/src/android-bootstrap/less/labels.less +64 -64
- package/src/android-bootstrap/less/list-group.less +141 -141
- package/src/android-bootstrap/less/media.less +66 -66
- package/src/android-bootstrap/less/mixins/alerts.less +14 -14
- package/src/android-bootstrap/less/mixins/background-variant.less +9 -9
- package/src/android-bootstrap/less/mixins/border-radius.less +18 -18
- package/src/android-bootstrap/less/mixins/buttons.less +69 -69
- package/src/android-bootstrap/less/mixins/center-block.less +7 -7
- package/src/android-bootstrap/less/mixins/clearfix.less +22 -22
- package/src/android-bootstrap/less/mixins/forms.less +90 -90
- package/src/android-bootstrap/less/mixins/gradients.less +59 -59
- package/src/android-bootstrap/less/mixins/grid-framework.less +92 -92
- package/src/android-bootstrap/less/mixins/grid.less +122 -122
- package/src/android-bootstrap/less/mixins/hide-text.less +21 -21
- package/src/android-bootstrap/less/mixins/image.less +33 -33
- package/src/android-bootstrap/less/mixins/labels.less +12 -12
- package/src/android-bootstrap/less/mixins/list-group.less +30 -30
- package/src/android-bootstrap/less/mixins/nav-divider.less +10 -10
- package/src/android-bootstrap/less/mixins/nav-vertical-align.less +9 -9
- package/src/android-bootstrap/less/mixins/opacity.less +8 -8
- package/src/android-bootstrap/less/mixins/pagination.less +24 -24
- package/src/android-bootstrap/less/mixins/panels.less +24 -24
- package/src/android-bootstrap/less/mixins/progress-bar.less +10 -10
- package/src/android-bootstrap/less/mixins/reset-filter.less +8 -8
- package/src/android-bootstrap/less/mixins/reset-text.less +18 -18
- package/src/android-bootstrap/less/mixins/resize.less +6 -6
- package/src/android-bootstrap/less/mixins/responsive-visibility.less +15 -15
- package/src/android-bootstrap/less/mixins/size.less +10 -10
- package/src/android-bootstrap/less/mixins/tab-focus.less +9 -9
- package/src/android-bootstrap/less/mixins/table-row.less +44 -44
- package/src/android-bootstrap/less/mixins/text-emphasis.less +9 -9
- package/src/android-bootstrap/less/mixins/text-overflow.less +8 -8
- package/src/android-bootstrap/less/mixins/vendor-prefixes.less +227 -227
- package/src/android-bootstrap/less/mixins.less +40 -40
- package/src/android-bootstrap/less/modals.less +151 -151
- package/src/android-bootstrap/less/navbar.less +660 -660
- package/src/android-bootstrap/less/navs.less +290 -290
- package/src/android-bootstrap/less/normalize.less +424 -424
- package/src/android-bootstrap/less/pager.less +76 -76
- package/src/android-bootstrap/less/pagination.less +89 -89
- package/src/android-bootstrap/less/panels.less +274 -274
- package/src/android-bootstrap/less/popovers.less +131 -131
- package/src/android-bootstrap/less/print.less +101 -101
- package/src/android-bootstrap/less/progress-bars.less +87 -87
- package/src/android-bootstrap/less/responsive-embed.less +35 -35
- package/src/android-bootstrap/less/responsive-utilities.less +194 -194
- package/src/android-bootstrap/less/scaffolding.less +161 -161
- package/src/android-bootstrap/less/tables.less +262 -262
- package/src/android-bootstrap/less/theme.less +291 -291
- package/src/android-bootstrap/less/thumbnails.less +36 -36
- package/src/android-bootstrap/less/tooltip.less +102 -102
- package/src/android-bootstrap/less/type.less +303 -303
- package/src/android-bootstrap/less/utilities.less +55 -55
- package/src/android-bootstrap/less/variables.less +896 -896
- package/src/android-bootstrap/less/wells.less +29 -29
- package/src/assets//345/215/241/350/241/250/346/212/204/350/241/250.png +0 -0
- package/src/assets//347/275/221/350/241/250/346/212/204/350/241/250.png +0 -0
- package/src/bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
- package/src/bootstrap/less/.csscomb.json +304 -304
- package/src/bootstrap/less/.csslintrc +19 -19
- package/src/bootstrap/less/alerts.less +73 -73
- package/src/bootstrap/less/badges.less +66 -66
- package/src/bootstrap/less/bootstrap.less +56 -56
- package/src/bootstrap/less/breadcrumbs.less +26 -26
- package/src/bootstrap/less/button-groups.less +247 -247
- package/src/bootstrap/less/buttons.less +172 -172
- package/src/bootstrap/less/carousel.less +269 -269
- package/src/bootstrap/less/close.less +34 -34
- package/src/bootstrap/less/code.less +69 -69
- package/src/bootstrap/less/component-animations.less +33 -33
- package/src/bootstrap/less/dropdowns.less +216 -216
- package/src/bootstrap/less/forms.less +626 -626
- package/src/bootstrap/less/glyphicons.less +305 -305
- package/src/bootstrap/less/grid.less +84 -84
- package/src/bootstrap/less/input-groups.less +167 -167
- package/src/bootstrap/less/jumbotron.less +52 -52
- package/src/bootstrap/less/labels.less +64 -64
- package/src/bootstrap/less/list-group.less +141 -141
- package/src/bootstrap/less/media.less +66 -66
- package/src/bootstrap/less/mixins/alerts.less +14 -14
- package/src/bootstrap/less/mixins/background-variant.less +9 -9
- package/src/bootstrap/less/mixins/border-radius.less +18 -18
- package/src/bootstrap/less/mixins/buttons.less +69 -69
- package/src/bootstrap/less/mixins/center-block.less +7 -7
- package/src/bootstrap/less/mixins/clearfix.less +22 -22
- package/src/bootstrap/less/mixins/forms.less +90 -90
- package/src/bootstrap/less/mixins/gradients.less +59 -59
- package/src/bootstrap/less/mixins/grid-framework.less +92 -92
- package/src/bootstrap/less/mixins/grid.less +122 -122
- package/src/bootstrap/less/mixins/hide-text.less +21 -21
- package/src/bootstrap/less/mixins/image.less +33 -33
- package/src/bootstrap/less/mixins/labels.less +12 -12
- package/src/bootstrap/less/mixins/list-group.less +30 -30
- package/src/bootstrap/less/mixins/nav-divider.less +10 -10
- package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
- package/src/bootstrap/less/mixins/opacity.less +8 -8
- package/src/bootstrap/less/mixins/pagination.less +24 -24
- package/src/bootstrap/less/mixins/panels.less +24 -24
- package/src/bootstrap/less/mixins/progress-bar.less +10 -10
- package/src/bootstrap/less/mixins/reset-filter.less +8 -8
- package/src/bootstrap/less/mixins/reset-text.less +18 -18
- package/src/bootstrap/less/mixins/resize.less +6 -6
- package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
- package/src/bootstrap/less/mixins/size.less +10 -10
- package/src/bootstrap/less/mixins/tab-focus.less +9 -9
- package/src/bootstrap/less/mixins/table-row.less +44 -44
- package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
- package/src/bootstrap/less/mixins/text-overflow.less +8 -8
- package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
- package/src/bootstrap/less/mixins.less +40 -40
- package/src/bootstrap/less/modals.less +151 -151
- package/src/bootstrap/less/navbar.less +660 -660
- package/src/bootstrap/less/navs.less +286 -286
- package/src/bootstrap/less/normalize.less +424 -424
- package/src/bootstrap/less/pager.less +76 -76
- package/src/bootstrap/less/pagination.less +89 -89
- package/src/bootstrap/less/panels.less +275 -275
- package/src/bootstrap/less/popovers.less +131 -131
- package/src/bootstrap/less/print.less +101 -101
- package/src/bootstrap/less/progress-bars.less +87 -87
- package/src/bootstrap/less/responsive-embed.less +35 -35
- package/src/bootstrap/less/responsive-utilities.less +194 -194
- package/src/bootstrap/less/scaffolding.less +161 -161
- package/src/bootstrap/less/tables.less +262 -262
- package/src/bootstrap/less/theme.less +291 -291
- package/src/bootstrap/less/thumbnails.less +36 -36
- package/src/bootstrap/less/tooltip.less +102 -102
- package/src/bootstrap/less/type.less +303 -303
- package/src/bootstrap/less/utilities.less +55 -55
- package/src/bootstrap/less/variables.less +895 -895
- package/src/bootstrap/less/wells.less +29 -29
- package/src/components/AloneLoadParams.vue +26 -26
- package/src/components/LoadAppdata.vue +38 -38
- package/src/components/LoginAppV4.vue +790 -790
- package/src/components/ModifyPassWord.vue +219 -219
- package/src/components/PhoneSellInfo.vue +148 -148
- package/src/components/Test.vue +14 -14
- package/src/components/iot/InstructMessage.vue +313 -313
- package/src/components/iot/IotBaseInfo.vue +97 -97
- package/src/plugins/GetStringData.js +18 -18
- package/src/plugins/LoadParams.js +24 -24
- package/src/plugins/validateStrongPasswordPhone.js +172 -172
- package/src/services/ConfigService.js +24 -24
- package/static/app.json +4 -4
- package/static/globals.txt +74 -74
- package/test/unit/.eslintrc +5 -5
- package/test/unit/TestUtil.js +35 -35
- package/test/unit/context.html +20 -20
- package/test/unit/index.js +13 -13
- package/test/unit/init.js +13 -13
- package/test/unit/karma.conf.js +50 -50
- package/test/unit/specs/App.spec.js +17 -17
- package/test/unit/specs/Test.spec.js +28 -28
- package/test/unit/specs/components/LoginApp.spec.js +21 -21
- package/test/unit/specs/sevices/ConfigService.spec.js +23 -23
- package/test/unit/specs/sevices/GetDBTest.spec.js +28 -28
|
@@ -1,97 +1,97 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div class="flex">
|
|
3
|
-
<div class="cols-sm-12 col-md-12 col-xs-12 " >
|
|
4
|
-
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
5
|
-
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
6
|
-
<img src="../../assets/pinpai.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
7
|
-
<span class="font-content">表具品牌</span>
|
|
8
|
-
<span class="font-head">{{row.f_meter_brand}}</span>
|
|
9
|
-
</div>
|
|
10
|
-
|
|
11
|
-
</div>
|
|
12
|
-
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
13
|
-
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
14
|
-
<img src="../../assets/leixing.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
15
|
-
<span class="font-content">表具类型</span>
|
|
16
|
-
<span class="font-head">{{row.f_meter_type}}</span>
|
|
17
|
-
</div>
|
|
18
|
-
</div>
|
|
19
|
-
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
20
|
-
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
21
|
-
<img src="../../assets/biaohao.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
22
|
-
<span class="font-content">表号</span>
|
|
23
|
-
<span class="font-head">{{row.f_meternumber}}</span>
|
|
24
|
-
</div>
|
|
25
|
-
</div>
|
|
26
|
-
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
27
|
-
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
28
|
-
<img src="../../assets/guige.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
29
|
-
<span class="font-content">表具规格</span>
|
|
30
|
-
<span class="font-head">{{row.f_meter_style}}</span>
|
|
31
|
-
</div>
|
|
32
|
-
</div>
|
|
33
|
-
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
34
|
-
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
35
|
-
<img src="../../assets/xinghao.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
36
|
-
<span class="font-content">表具型号</span>
|
|
37
|
-
<span class="font-head">{{row.f_type}}</span>
|
|
38
|
-
</div>
|
|
39
|
-
</div>
|
|
40
|
-
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
41
|
-
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
42
|
-
<img src="../../assets/bieming.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
43
|
-
<span class="font-content">表具别名</span>
|
|
44
|
-
<span class="font-head">{{row.f_alias}}</span>
|
|
45
|
-
</div>
|
|
46
|
-
</div>
|
|
47
|
-
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
48
|
-
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
49
|
-
<img src="../../assets/yue.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
50
|
-
<span class="font-content">剩余金额</span>
|
|
51
|
-
<span class="font-head">{{row.f_balance_amount}}</span>
|
|
52
|
-
</div>
|
|
53
|
-
</div>
|
|
54
|
-
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
55
|
-
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
56
|
-
<img src="../../assets/qiliang.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
57
|
-
<span class="font-content">累计用气量</span>
|
|
58
|
-
<span class="font-head">{{row.f_balance_gas}}</span>
|
|
59
|
-
</div>
|
|
60
|
-
</div>
|
|
61
|
-
</div>
|
|
62
|
-
</div>
|
|
63
|
-
</template>
|
|
64
|
-
|
|
65
|
-
<script>
|
|
66
|
-
export default {
|
|
67
|
-
title: '基础信息',
|
|
68
|
-
data () {
|
|
69
|
-
return {
|
|
70
|
-
msg: '',
|
|
71
|
-
show: false
|
|
72
|
-
}
|
|
73
|
-
},
|
|
74
|
-
props:['row'],
|
|
75
|
-
ready () {
|
|
76
|
-
// this.$appdata.load().then(() => {
|
|
77
|
-
// this.$emit('ready')
|
|
78
|
-
// })
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
</script>
|
|
82
|
-
<style media="screen" scoped>
|
|
83
|
-
.font-head{
|
|
84
|
-
font-size: 14px;
|
|
85
|
-
font-weight: bold;
|
|
86
|
-
color: #333;
|
|
87
|
-
}
|
|
88
|
-
.font-content{
|
|
89
|
-
font-size: 12px;
|
|
90
|
-
font-weight: normal;
|
|
91
|
-
color: #666666;
|
|
92
|
-
}
|
|
93
|
-
.meterinfo{
|
|
94
|
-
border:1px solid #eeeeee;
|
|
95
|
-
/*border-right: 2px solid #eeeeee;*/
|
|
96
|
-
}
|
|
97
|
-
</style>
|
|
1
|
+
<template>
|
|
2
|
+
<div class="flex">
|
|
3
|
+
<div class="cols-sm-12 col-md-12 col-xs-12 " >
|
|
4
|
+
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
5
|
+
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
6
|
+
<img src="../../assets/pinpai.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
7
|
+
<span class="font-content">表具品牌</span>
|
|
8
|
+
<span class="font-head">{{row.f_meter_brand}}</span>
|
|
9
|
+
</div>
|
|
10
|
+
|
|
11
|
+
</div>
|
|
12
|
+
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
13
|
+
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
14
|
+
<img src="../../assets/leixing.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
15
|
+
<span class="font-content">表具类型</span>
|
|
16
|
+
<span class="font-head">{{row.f_meter_type}}</span>
|
|
17
|
+
</div>
|
|
18
|
+
</div>
|
|
19
|
+
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
20
|
+
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
21
|
+
<img src="../../assets/biaohao.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
22
|
+
<span class="font-content">表号</span>
|
|
23
|
+
<span class="font-head">{{row.f_meternumber}}</span>
|
|
24
|
+
</div>
|
|
25
|
+
</div>
|
|
26
|
+
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
27
|
+
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
28
|
+
<img src="../../assets/guige.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
29
|
+
<span class="font-content">表具规格</span>
|
|
30
|
+
<span class="font-head">{{row.f_meter_style}}</span>
|
|
31
|
+
</div>
|
|
32
|
+
</div>
|
|
33
|
+
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
34
|
+
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
35
|
+
<img src="../../assets/xinghao.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
36
|
+
<span class="font-content">表具型号</span>
|
|
37
|
+
<span class="font-head">{{row.f_type}}</span>
|
|
38
|
+
</div>
|
|
39
|
+
</div>
|
|
40
|
+
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
41
|
+
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
42
|
+
<img src="../../assets/bieming.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
43
|
+
<span class="font-content">表具别名</span>
|
|
44
|
+
<span class="font-head">{{row.f_alias}}</span>
|
|
45
|
+
</div>
|
|
46
|
+
</div>
|
|
47
|
+
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
48
|
+
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
49
|
+
<img src="../../assets/yue.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
50
|
+
<span class="font-content">剩余金额</span>
|
|
51
|
+
<span class="font-head">{{row.f_balance_amount}}</span>
|
|
52
|
+
</div>
|
|
53
|
+
</div>
|
|
54
|
+
<div class="col-sm-3 col-md-3 col-xs-4 meterinfo">
|
|
55
|
+
<div class="flex" style="padding: 0.5rem;align-items: center">
|
|
56
|
+
<img src="../../assets/qiliang.png" style="height:32px;width:32px;margin-bottom: 5px" alt="" >
|
|
57
|
+
<span class="font-content">累计用气量</span>
|
|
58
|
+
<span class="font-head">{{row.f_balance_gas}}</span>
|
|
59
|
+
</div>
|
|
60
|
+
</div>
|
|
61
|
+
</div>
|
|
62
|
+
</div>
|
|
63
|
+
</template>
|
|
64
|
+
|
|
65
|
+
<script>
|
|
66
|
+
export default {
|
|
67
|
+
title: '基础信息',
|
|
68
|
+
data () {
|
|
69
|
+
return {
|
|
70
|
+
msg: '',
|
|
71
|
+
show: false
|
|
72
|
+
}
|
|
73
|
+
},
|
|
74
|
+
props:['row'],
|
|
75
|
+
ready () {
|
|
76
|
+
// this.$appdata.load().then(() => {
|
|
77
|
+
// this.$emit('ready')
|
|
78
|
+
// })
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
</script>
|
|
82
|
+
<style media="screen" scoped>
|
|
83
|
+
.font-head{
|
|
84
|
+
font-size: 14px;
|
|
85
|
+
font-weight: bold;
|
|
86
|
+
color: #333;
|
|
87
|
+
}
|
|
88
|
+
.font-content{
|
|
89
|
+
font-size: 12px;
|
|
90
|
+
font-weight: normal;
|
|
91
|
+
color: #666666;
|
|
92
|
+
}
|
|
93
|
+
.meterinfo{
|
|
94
|
+
border:1px solid #eeeeee;
|
|
95
|
+
/*border-right: 2px solid #eeeeee;*/
|
|
96
|
+
}
|
|
97
|
+
</style>
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
let GetStringdatas = {
|
|
3
|
-
|
|
4
|
-
install (Vue, options) {
|
|
5
|
-
// 给vue增添对话框显示方法
|
|
6
|
-
Vue.$getString = Vue.prototype.$getString = GetStringdatas
|
|
7
|
-
},
|
|
8
|
-
getSubStr (String) {
|
|
9
|
-
if(String.endsWith('phone')){
|
|
10
|
-
let oldStr = String
|
|
11
|
-
let index = oldStr.lastIndexOf("/")
|
|
12
|
-
return oldStr.substring(0, index)
|
|
13
|
-
}
|
|
14
|
-
return String
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export default GetStringdatas
|
|
1
|
+
|
|
2
|
+
let GetStringdatas = {
|
|
3
|
+
|
|
4
|
+
install (Vue, options) {
|
|
5
|
+
// 给vue增添对话框显示方法
|
|
6
|
+
Vue.$getString = Vue.prototype.$getString = GetStringdatas
|
|
7
|
+
},
|
|
8
|
+
getSubStr (String) {
|
|
9
|
+
if(String.endsWith('phone')){
|
|
10
|
+
let oldStr = String
|
|
11
|
+
let index = oldStr.lastIndexOf("/")
|
|
12
|
+
return oldStr.substring(0, index)
|
|
13
|
+
}
|
|
14
|
+
return String
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export default GetStringdatas
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import Vue from 'vue'
|
|
2
|
-
import AppData from '../stores/AppData'
|
|
3
|
-
|
|
4
|
-
let LoadParams = {
|
|
5
|
-
// 开启卡监听
|
|
6
|
-
load () {
|
|
7
|
-
return Vue.resetpost(`${Vue.androidUtil.getProxyUrl()}/rs/path/getParams`, {data: {}}, {resolveMsg: null, rejectMsg: null}).then((res) => {
|
|
8
|
-
res.data.forEach((item) => {
|
|
9
|
-
let value = []
|
|
10
|
-
item.f_paramvalues.forEach((item, index) => {
|
|
11
|
-
value[index] = {}
|
|
12
|
-
value[index].label = item.name
|
|
13
|
-
value[index].value = item.name
|
|
14
|
-
})
|
|
15
|
-
AppData.params[item.name] = value
|
|
16
|
-
})
|
|
17
|
-
}).catch((res) => {
|
|
18
|
-
this.msg = res.data
|
|
19
|
-
this.show = true
|
|
20
|
-
})
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export default LoadParams
|
|
1
|
+
import Vue from 'vue'
|
|
2
|
+
import AppData from '../stores/AppData'
|
|
3
|
+
|
|
4
|
+
let LoadParams = {
|
|
5
|
+
// 开启卡监听
|
|
6
|
+
load () {
|
|
7
|
+
return Vue.resetpost(`${Vue.androidUtil.getProxyUrl()}/rs/path/getParams`, {data: {}}, {resolveMsg: null, rejectMsg: null}).then((res) => {
|
|
8
|
+
res.data.forEach((item) => {
|
|
9
|
+
let value = []
|
|
10
|
+
item.f_paramvalues.forEach((item, index) => {
|
|
11
|
+
value[index] = {}
|
|
12
|
+
value[index].label = item.name
|
|
13
|
+
value[index].value = item.name
|
|
14
|
+
})
|
|
15
|
+
AppData.params[item.name] = value
|
|
16
|
+
})
|
|
17
|
+
}).catch((res) => {
|
|
18
|
+
this.msg = res.data
|
|
19
|
+
this.show = true
|
|
20
|
+
})
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export default LoadParams
|
|
@@ -1,172 +1,172 @@
|
|
|
1
|
-
const REG_STRONG_PWD =
|
|
2
|
-
/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[!@#$%^&*(),.?":{}|<>~`+=_\\-])[A-Za-z\d!@#$%^&*(),.?":{}|<>~`+=_\\-]{8,}$/;
|
|
3
|
-
|
|
4
|
-
// 常见密码列表(可以根据需要扩展)
|
|
5
|
-
const COMMON_PASSWORDS = [
|
|
6
|
-
"password",
|
|
7
|
-
"password123",
|
|
8
|
-
"123456",
|
|
9
|
-
"12345678",
|
|
10
|
-
"qwerty",
|
|
11
|
-
"abc123",
|
|
12
|
-
"Password1",
|
|
13
|
-
"password1",
|
|
14
|
-
"123456789",
|
|
15
|
-
"welcome",
|
|
16
|
-
"admin",
|
|
17
|
-
"letmein",
|
|
18
|
-
"monkey",
|
|
19
|
-
"dragon",
|
|
20
|
-
"master",
|
|
21
|
-
"superman",
|
|
22
|
-
"qwerty123",
|
|
23
|
-
"admin123",
|
|
24
|
-
"root",
|
|
25
|
-
"pass",
|
|
26
|
-
"test",
|
|
27
|
-
"guest",
|
|
28
|
-
"user",
|
|
29
|
-
"000000",
|
|
30
|
-
"111111",
|
|
31
|
-
"666666",
|
|
32
|
-
"888888",
|
|
33
|
-
"999999",
|
|
34
|
-
"iloveyou",
|
|
35
|
-
"welcome123",
|
|
36
|
-
"password!",
|
|
37
|
-
"Passw0rd!",
|
|
38
|
-
"Passw0rd",
|
|
39
|
-
"Password!",
|
|
40
|
-
"passw0rd",
|
|
41
|
-
"P@ssw0rd",
|
|
42
|
-
"P@ssword",
|
|
43
|
-
"Password@123",
|
|
44
|
-
];
|
|
45
|
-
|
|
46
|
-
// 检查连续数字(3个或以上)
|
|
47
|
-
const hasConsecutiveNumbers = (password) => {
|
|
48
|
-
for (let i = 0; i <= password.length - 3; i++) {
|
|
49
|
-
const substr = password.substring(i, i + 3);
|
|
50
|
-
if (/^\d{3,}$/.test(substr)) {
|
|
51
|
-
// 检查是否为连续数字
|
|
52
|
-
const digits = substr.split("").map(Number);
|
|
53
|
-
let isConsecutive = true;
|
|
54
|
-
for (let j = 1; j < digits.length; j++) {
|
|
55
|
-
if (digits[j] !== digits[j - 1] + 1) {
|
|
56
|
-
isConsecutive = false;
|
|
57
|
-
break;
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
if (isConsecutive) return true;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
return false;
|
|
64
|
-
};
|
|
65
|
-
|
|
66
|
-
// 检查连续字母(3个或以上)
|
|
67
|
-
const hasConsecutiveLetters = (password) => {
|
|
68
|
-
const lowerPassword = password.toLowerCase();
|
|
69
|
-
for (let i = 0; i <= lowerPassword.length - 3; i++) {
|
|
70
|
-
const substr = lowerPassword.substring(i, i + 3);
|
|
71
|
-
if (/^[a-z]{3,}$/.test(substr)) {
|
|
72
|
-
// 检查是否为连续字母
|
|
73
|
-
let isConsecutive = true;
|
|
74
|
-
for (let j = 1; j < substr.length; j++) {
|
|
75
|
-
if (substr.charCodeAt(j) !== substr.charCodeAt(j - 1) + 1) {
|
|
76
|
-
isConsecutive = false;
|
|
77
|
-
break;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
if (isConsecutive) return true;
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
return false;
|
|
84
|
-
};
|
|
85
|
-
|
|
86
|
-
// 检查重复字符(3个或以上相同字符)
|
|
87
|
-
const hasRepeatedChars = (password) => {
|
|
88
|
-
return /(.)\1{2,}/.test(password);
|
|
89
|
-
};
|
|
90
|
-
|
|
91
|
-
// 检查键盘连续按键(如 qwerty, asdf 等)
|
|
92
|
-
const hasKeyboardPattern = (password) => {
|
|
93
|
-
const keyboardRows = ["qwertyuiop", "asdfghjkl", "zxcvbnm", "1234567890"];
|
|
94
|
-
const lowerPassword = password.toLowerCase();
|
|
95
|
-
for (const row of keyboardRows) {
|
|
96
|
-
for (let i = 0; i <= row.length - 3; i++) {
|
|
97
|
-
const pattern = row.substring(i, i + 3);
|
|
98
|
-
if (lowerPassword.includes(pattern)) {
|
|
99
|
-
return true;
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
return false;
|
|
104
|
-
};
|
|
105
|
-
|
|
106
|
-
/**
|
|
107
|
-
* 密码校验结果对象
|
|
108
|
-
* @typedef {Object} PasswordValidationResult
|
|
109
|
-
* @property {boolean} isValid
|
|
110
|
-
* @property {string[]} errors
|
|
111
|
-
*/
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* 增强的密码校验函数
|
|
115
|
-
* @param {string} password
|
|
116
|
-
* @returns {PasswordValidationResult}
|
|
117
|
-
*/
|
|
118
|
-
export const validateStrongPasswordPhone = (password) => {
|
|
119
|
-
const result = {
|
|
120
|
-
isValid: true,
|
|
121
|
-
errors: [],
|
|
122
|
-
};
|
|
123
|
-
|
|
124
|
-
// 1. 基本格式校验
|
|
125
|
-
if (!REG_STRONG_PWD.test(password)) {
|
|
126
|
-
result.isValid = false;
|
|
127
|
-
result.errors.push(
|
|
128
|
-
"密码必须包含至少8个字符,包括大写字母、小写字母、数字和特殊字符"
|
|
129
|
-
);
|
|
130
|
-
return result;
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
// 2. 检查是否为常见密码
|
|
134
|
-
if (
|
|
135
|
-
COMMON_PASSWORDS.includes(password) ||
|
|
136
|
-
COMMON_PASSWORDS.includes(password.toLowerCase())
|
|
137
|
-
) {
|
|
138
|
-
result.isValid = false;
|
|
139
|
-
result.errors.push("不能使用常见密码");
|
|
140
|
-
return result;
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
// 3. 检查连续数字
|
|
144
|
-
if (hasConsecutiveNumbers(password)) {
|
|
145
|
-
result.isValid = false;
|
|
146
|
-
result.errors.push("不能包含连续数字");
|
|
147
|
-
return result;
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
// 4. 检查连续字母
|
|
151
|
-
if (hasConsecutiveLetters(password)) {
|
|
152
|
-
result.isValid = false;
|
|
153
|
-
result.errors.push("不能包含连续字母");
|
|
154
|
-
return result;
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
// 5. 检查重复字符
|
|
158
|
-
if (hasRepeatedChars(password)) {
|
|
159
|
-
result.isValid = false;
|
|
160
|
-
result.errors.push("不能包含3个或以上相同字符");
|
|
161
|
-
return result;
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
// 6. 检查键盘模式
|
|
165
|
-
if (hasKeyboardPattern(password)) {
|
|
166
|
-
result.isValid = false;
|
|
167
|
-
result.errors.push("不能包含键盘连续按键模式");
|
|
168
|
-
return result;
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
return result;
|
|
172
|
-
};
|
|
1
|
+
const REG_STRONG_PWD =
|
|
2
|
+
/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[!@#$%^&*(),.?":{}|<>~`+=_\\-])[A-Za-z\d!@#$%^&*(),.?":{}|<>~`+=_\\-]{8,}$/;
|
|
3
|
+
|
|
4
|
+
// 常见密码列表(可以根据需要扩展)
|
|
5
|
+
const COMMON_PASSWORDS = [
|
|
6
|
+
"password",
|
|
7
|
+
"password123",
|
|
8
|
+
"123456",
|
|
9
|
+
"12345678",
|
|
10
|
+
"qwerty",
|
|
11
|
+
"abc123",
|
|
12
|
+
"Password1",
|
|
13
|
+
"password1",
|
|
14
|
+
"123456789",
|
|
15
|
+
"welcome",
|
|
16
|
+
"admin",
|
|
17
|
+
"letmein",
|
|
18
|
+
"monkey",
|
|
19
|
+
"dragon",
|
|
20
|
+
"master",
|
|
21
|
+
"superman",
|
|
22
|
+
"qwerty123",
|
|
23
|
+
"admin123",
|
|
24
|
+
"root",
|
|
25
|
+
"pass",
|
|
26
|
+
"test",
|
|
27
|
+
"guest",
|
|
28
|
+
"user",
|
|
29
|
+
"000000",
|
|
30
|
+
"111111",
|
|
31
|
+
"666666",
|
|
32
|
+
"888888",
|
|
33
|
+
"999999",
|
|
34
|
+
"iloveyou",
|
|
35
|
+
"welcome123",
|
|
36
|
+
"password!",
|
|
37
|
+
"Passw0rd!",
|
|
38
|
+
"Passw0rd",
|
|
39
|
+
"Password!",
|
|
40
|
+
"passw0rd",
|
|
41
|
+
"P@ssw0rd",
|
|
42
|
+
"P@ssword",
|
|
43
|
+
"Password@123",
|
|
44
|
+
];
|
|
45
|
+
|
|
46
|
+
// 检查连续数字(3个或以上)
|
|
47
|
+
const hasConsecutiveNumbers = (password) => {
|
|
48
|
+
for (let i = 0; i <= password.length - 3; i++) {
|
|
49
|
+
const substr = password.substring(i, i + 3);
|
|
50
|
+
if (/^\d{3,}$/.test(substr)) {
|
|
51
|
+
// 检查是否为连续数字
|
|
52
|
+
const digits = substr.split("").map(Number);
|
|
53
|
+
let isConsecutive = true;
|
|
54
|
+
for (let j = 1; j < digits.length; j++) {
|
|
55
|
+
if (digits[j] !== digits[j - 1] + 1) {
|
|
56
|
+
isConsecutive = false;
|
|
57
|
+
break;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
if (isConsecutive) return true;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return false;
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
// 检查连续字母(3个或以上)
|
|
67
|
+
const hasConsecutiveLetters = (password) => {
|
|
68
|
+
const lowerPassword = password.toLowerCase();
|
|
69
|
+
for (let i = 0; i <= lowerPassword.length - 3; i++) {
|
|
70
|
+
const substr = lowerPassword.substring(i, i + 3);
|
|
71
|
+
if (/^[a-z]{3,}$/.test(substr)) {
|
|
72
|
+
// 检查是否为连续字母
|
|
73
|
+
let isConsecutive = true;
|
|
74
|
+
for (let j = 1; j < substr.length; j++) {
|
|
75
|
+
if (substr.charCodeAt(j) !== substr.charCodeAt(j - 1) + 1) {
|
|
76
|
+
isConsecutive = false;
|
|
77
|
+
break;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
if (isConsecutive) return true;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return false;
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
// 检查重复字符(3个或以上相同字符)
|
|
87
|
+
const hasRepeatedChars = (password) => {
|
|
88
|
+
return /(.)\1{2,}/.test(password);
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
// 检查键盘连续按键(如 qwerty, asdf 等)
|
|
92
|
+
const hasKeyboardPattern = (password) => {
|
|
93
|
+
const keyboardRows = ["qwertyuiop", "asdfghjkl", "zxcvbnm", "1234567890"];
|
|
94
|
+
const lowerPassword = password.toLowerCase();
|
|
95
|
+
for (const row of keyboardRows) {
|
|
96
|
+
for (let i = 0; i <= row.length - 3; i++) {
|
|
97
|
+
const pattern = row.substring(i, i + 3);
|
|
98
|
+
if (lowerPassword.includes(pattern)) {
|
|
99
|
+
return true;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
return false;
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* 密码校验结果对象
|
|
108
|
+
* @typedef {Object} PasswordValidationResult
|
|
109
|
+
* @property {boolean} isValid
|
|
110
|
+
* @property {string[]} errors
|
|
111
|
+
*/
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* 增强的密码校验函数
|
|
115
|
+
* @param {string} password
|
|
116
|
+
* @returns {PasswordValidationResult}
|
|
117
|
+
*/
|
|
118
|
+
export const validateStrongPasswordPhone = (password) => {
|
|
119
|
+
const result = {
|
|
120
|
+
isValid: true,
|
|
121
|
+
errors: [],
|
|
122
|
+
};
|
|
123
|
+
|
|
124
|
+
// 1. 基本格式校验
|
|
125
|
+
if (!REG_STRONG_PWD.test(password)) {
|
|
126
|
+
result.isValid = false;
|
|
127
|
+
result.errors.push(
|
|
128
|
+
"密码必须包含至少8个字符,包括大写字母、小写字母、数字和特殊字符"
|
|
129
|
+
);
|
|
130
|
+
return result;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
// 2. 检查是否为常见密码
|
|
134
|
+
if (
|
|
135
|
+
COMMON_PASSWORDS.includes(password) ||
|
|
136
|
+
COMMON_PASSWORDS.includes(password.toLowerCase())
|
|
137
|
+
) {
|
|
138
|
+
result.isValid = false;
|
|
139
|
+
result.errors.push("不能使用常见密码");
|
|
140
|
+
return result;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
// 3. 检查连续数字
|
|
144
|
+
if (hasConsecutiveNumbers(password)) {
|
|
145
|
+
result.isValid = false;
|
|
146
|
+
result.errors.push("不能包含连续数字");
|
|
147
|
+
return result;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
// 4. 检查连续字母
|
|
151
|
+
if (hasConsecutiveLetters(password)) {
|
|
152
|
+
result.isValid = false;
|
|
153
|
+
result.errors.push("不能包含连续字母");
|
|
154
|
+
return result;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
// 5. 检查重复字符
|
|
158
|
+
if (hasRepeatedChars(password)) {
|
|
159
|
+
result.isValid = false;
|
|
160
|
+
result.errors.push("不能包含3个或以上相同字符");
|
|
161
|
+
return result;
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
// 6. 检查键盘模式
|
|
165
|
+
if (hasKeyboardPattern(password)) {
|
|
166
|
+
result.isValid = false;
|
|
167
|
+
result.errors.push("不能包含键盘连续按键模式");
|
|
168
|
+
return result;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
return result;
|
|
172
|
+
};
|