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.
Files changed (199) hide show
  1. package/.babelrc +5 -5
  2. package/.editorconfig +9 -9
  3. package/.eslintrc.js +16 -16
  4. package/CHANGELOG.md +1 -1
  5. package/Dockerfile +3 -3
  6. package/README.md +36 -36
  7. package/build/css-loaders.js +34 -34
  8. package/build/dev-client.js +8 -8
  9. package/build/example-server.js +80 -80
  10. package/build/release.sh +28 -28
  11. package/build/utils.js +71 -71
  12. package/build/webpack.dev.conf.js +31 -31
  13. package/build/webpack.example.conf.js +49 -49
  14. package/build/webpack.prod.conf.js +60 -60
  15. package/build/webpack.test.conf.js +31 -31
  16. package/config/dev.env.js +6 -6
  17. package/config/index.js +38 -38
  18. package/config/prod.env.js +3 -3
  19. package/config/test.env.js +6 -6
  20. package/nginx.conf +304 -304
  21. package/package.json +100 -100
  22. package/release.bat +5 -5
  23. package/src/App.vue +25 -25
  24. package/src/Util.js +415 -415
  25. package/src/android-bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  26. package/src/android-bootstrap/less/.csscomb.json +304 -304
  27. package/src/android-bootstrap/less/.csslintrc +19 -19
  28. package/src/android-bootstrap/less/alerts.less +73 -73
  29. package/src/android-bootstrap/less/badges.less +66 -66
  30. package/src/android-bootstrap/less/bootstrap.less +56 -56
  31. package/src/android-bootstrap/less/breadcrumbs.less +26 -26
  32. package/src/android-bootstrap/less/button-groups.less +247 -247
  33. package/src/android-bootstrap/less/buttons.less +173 -173
  34. package/src/android-bootstrap/less/carousel.less +269 -269
  35. package/src/android-bootstrap/less/close.less +34 -34
  36. package/src/android-bootstrap/less/code.less +69 -69
  37. package/src/android-bootstrap/less/component-animations.less +33 -33
  38. package/src/android-bootstrap/less/dropdowns.less +216 -216
  39. package/src/android-bootstrap/less/forms.less +626 -626
  40. package/src/android-bootstrap/less/glyphicons.less +305 -305
  41. package/src/android-bootstrap/less/grid.less +84 -84
  42. package/src/android-bootstrap/less/input-groups.less +167 -167
  43. package/src/android-bootstrap/less/jumbotron.less +52 -52
  44. package/src/android-bootstrap/less/labels.less +64 -64
  45. package/src/android-bootstrap/less/list-group.less +141 -141
  46. package/src/android-bootstrap/less/media.less +66 -66
  47. package/src/android-bootstrap/less/mixins/alerts.less +14 -14
  48. package/src/android-bootstrap/less/mixins/background-variant.less +9 -9
  49. package/src/android-bootstrap/less/mixins/border-radius.less +18 -18
  50. package/src/android-bootstrap/less/mixins/buttons.less +69 -69
  51. package/src/android-bootstrap/less/mixins/center-block.less +7 -7
  52. package/src/android-bootstrap/less/mixins/clearfix.less +22 -22
  53. package/src/android-bootstrap/less/mixins/forms.less +90 -90
  54. package/src/android-bootstrap/less/mixins/gradients.less +59 -59
  55. package/src/android-bootstrap/less/mixins/grid-framework.less +92 -92
  56. package/src/android-bootstrap/less/mixins/grid.less +122 -122
  57. package/src/android-bootstrap/less/mixins/hide-text.less +21 -21
  58. package/src/android-bootstrap/less/mixins/image.less +33 -33
  59. package/src/android-bootstrap/less/mixins/labels.less +12 -12
  60. package/src/android-bootstrap/less/mixins/list-group.less +30 -30
  61. package/src/android-bootstrap/less/mixins/nav-divider.less +10 -10
  62. package/src/android-bootstrap/less/mixins/nav-vertical-align.less +9 -9
  63. package/src/android-bootstrap/less/mixins/opacity.less +8 -8
  64. package/src/android-bootstrap/less/mixins/pagination.less +24 -24
  65. package/src/android-bootstrap/less/mixins/panels.less +24 -24
  66. package/src/android-bootstrap/less/mixins/progress-bar.less +10 -10
  67. package/src/android-bootstrap/less/mixins/reset-filter.less +8 -8
  68. package/src/android-bootstrap/less/mixins/reset-text.less +18 -18
  69. package/src/android-bootstrap/less/mixins/resize.less +6 -6
  70. package/src/android-bootstrap/less/mixins/responsive-visibility.less +15 -15
  71. package/src/android-bootstrap/less/mixins/size.less +10 -10
  72. package/src/android-bootstrap/less/mixins/tab-focus.less +9 -9
  73. package/src/android-bootstrap/less/mixins/table-row.less +44 -44
  74. package/src/android-bootstrap/less/mixins/text-emphasis.less +9 -9
  75. package/src/android-bootstrap/less/mixins/text-overflow.less +8 -8
  76. package/src/android-bootstrap/less/mixins/vendor-prefixes.less +227 -227
  77. package/src/android-bootstrap/less/mixins.less +40 -40
  78. package/src/android-bootstrap/less/modals.less +151 -151
  79. package/src/android-bootstrap/less/navbar.less +660 -660
  80. package/src/android-bootstrap/less/navs.less +290 -290
  81. package/src/android-bootstrap/less/normalize.less +424 -424
  82. package/src/android-bootstrap/less/pager.less +76 -76
  83. package/src/android-bootstrap/less/pagination.less +89 -89
  84. package/src/android-bootstrap/less/panels.less +274 -274
  85. package/src/android-bootstrap/less/popovers.less +131 -131
  86. package/src/android-bootstrap/less/print.less +101 -101
  87. package/src/android-bootstrap/less/progress-bars.less +87 -87
  88. package/src/android-bootstrap/less/responsive-embed.less +35 -35
  89. package/src/android-bootstrap/less/responsive-utilities.less +194 -194
  90. package/src/android-bootstrap/less/scaffolding.less +161 -161
  91. package/src/android-bootstrap/less/tables.less +262 -262
  92. package/src/android-bootstrap/less/theme.less +291 -291
  93. package/src/android-bootstrap/less/thumbnails.less +36 -36
  94. package/src/android-bootstrap/less/tooltip.less +102 -102
  95. package/src/android-bootstrap/less/type.less +303 -303
  96. package/src/android-bootstrap/less/utilities.less +55 -55
  97. package/src/android-bootstrap/less/variables.less +896 -896
  98. package/src/android-bootstrap/less/wells.less +29 -29
  99. package/src/assets//345/215/241/350/241/250/346/212/204/350/241/250.png +0 -0
  100. package/src/assets//347/275/221/350/241/250/346/212/204/350/241/250.png +0 -0
  101. package/src/bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  102. package/src/bootstrap/less/.csscomb.json +304 -304
  103. package/src/bootstrap/less/.csslintrc +19 -19
  104. package/src/bootstrap/less/alerts.less +73 -73
  105. package/src/bootstrap/less/badges.less +66 -66
  106. package/src/bootstrap/less/bootstrap.less +56 -56
  107. package/src/bootstrap/less/breadcrumbs.less +26 -26
  108. package/src/bootstrap/less/button-groups.less +247 -247
  109. package/src/bootstrap/less/buttons.less +172 -172
  110. package/src/bootstrap/less/carousel.less +269 -269
  111. package/src/bootstrap/less/close.less +34 -34
  112. package/src/bootstrap/less/code.less +69 -69
  113. package/src/bootstrap/less/component-animations.less +33 -33
  114. package/src/bootstrap/less/dropdowns.less +216 -216
  115. package/src/bootstrap/less/forms.less +626 -626
  116. package/src/bootstrap/less/glyphicons.less +305 -305
  117. package/src/bootstrap/less/grid.less +84 -84
  118. package/src/bootstrap/less/input-groups.less +167 -167
  119. package/src/bootstrap/less/jumbotron.less +52 -52
  120. package/src/bootstrap/less/labels.less +64 -64
  121. package/src/bootstrap/less/list-group.less +141 -141
  122. package/src/bootstrap/less/media.less +66 -66
  123. package/src/bootstrap/less/mixins/alerts.less +14 -14
  124. package/src/bootstrap/less/mixins/background-variant.less +9 -9
  125. package/src/bootstrap/less/mixins/border-radius.less +18 -18
  126. package/src/bootstrap/less/mixins/buttons.less +69 -69
  127. package/src/bootstrap/less/mixins/center-block.less +7 -7
  128. package/src/bootstrap/less/mixins/clearfix.less +22 -22
  129. package/src/bootstrap/less/mixins/forms.less +90 -90
  130. package/src/bootstrap/less/mixins/gradients.less +59 -59
  131. package/src/bootstrap/less/mixins/grid-framework.less +92 -92
  132. package/src/bootstrap/less/mixins/grid.less +122 -122
  133. package/src/bootstrap/less/mixins/hide-text.less +21 -21
  134. package/src/bootstrap/less/mixins/image.less +33 -33
  135. package/src/bootstrap/less/mixins/labels.less +12 -12
  136. package/src/bootstrap/less/mixins/list-group.less +30 -30
  137. package/src/bootstrap/less/mixins/nav-divider.less +10 -10
  138. package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
  139. package/src/bootstrap/less/mixins/opacity.less +8 -8
  140. package/src/bootstrap/less/mixins/pagination.less +24 -24
  141. package/src/bootstrap/less/mixins/panels.less +24 -24
  142. package/src/bootstrap/less/mixins/progress-bar.less +10 -10
  143. package/src/bootstrap/less/mixins/reset-filter.less +8 -8
  144. package/src/bootstrap/less/mixins/reset-text.less +18 -18
  145. package/src/bootstrap/less/mixins/resize.less +6 -6
  146. package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
  147. package/src/bootstrap/less/mixins/size.less +10 -10
  148. package/src/bootstrap/less/mixins/tab-focus.less +9 -9
  149. package/src/bootstrap/less/mixins/table-row.less +44 -44
  150. package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
  151. package/src/bootstrap/less/mixins/text-overflow.less +8 -8
  152. package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
  153. package/src/bootstrap/less/mixins.less +40 -40
  154. package/src/bootstrap/less/modals.less +151 -151
  155. package/src/bootstrap/less/navbar.less +660 -660
  156. package/src/bootstrap/less/navs.less +286 -286
  157. package/src/bootstrap/less/normalize.less +424 -424
  158. package/src/bootstrap/less/pager.less +76 -76
  159. package/src/bootstrap/less/pagination.less +89 -89
  160. package/src/bootstrap/less/panels.less +275 -275
  161. package/src/bootstrap/less/popovers.less +131 -131
  162. package/src/bootstrap/less/print.less +101 -101
  163. package/src/bootstrap/less/progress-bars.less +87 -87
  164. package/src/bootstrap/less/responsive-embed.less +35 -35
  165. package/src/bootstrap/less/responsive-utilities.less +194 -194
  166. package/src/bootstrap/less/scaffolding.less +161 -161
  167. package/src/bootstrap/less/tables.less +262 -262
  168. package/src/bootstrap/less/theme.less +291 -291
  169. package/src/bootstrap/less/thumbnails.less +36 -36
  170. package/src/bootstrap/less/tooltip.less +102 -102
  171. package/src/bootstrap/less/type.less +303 -303
  172. package/src/bootstrap/less/utilities.less +55 -55
  173. package/src/bootstrap/less/variables.less +895 -895
  174. package/src/bootstrap/less/wells.less +29 -29
  175. package/src/components/AloneLoadParams.vue +26 -26
  176. package/src/components/LoadAppdata.vue +38 -38
  177. package/src/components/LoginAppV4.vue +790 -790
  178. package/src/components/ModifyPassWord.vue +219 -219
  179. package/src/components/PhoneSellInfo.vue +148 -148
  180. package/src/components/Test.vue +14 -14
  181. package/src/components/iot/InstructMessage.vue +313 -313
  182. package/src/components/iot/IotBaseInfo.vue +97 -97
  183. package/src/plugins/GetStringData.js +18 -18
  184. package/src/plugins/LoadParams.js +24 -24
  185. package/src/plugins/validateStrongPasswordPhone.js +172 -172
  186. package/src/services/ConfigService.js +24 -24
  187. package/static/app.json +4 -4
  188. package/static/globals.txt +74 -74
  189. package/test/unit/.eslintrc +5 -5
  190. package/test/unit/TestUtil.js +35 -35
  191. package/test/unit/context.html +20 -20
  192. package/test/unit/index.js +13 -13
  193. package/test/unit/init.js +13 -13
  194. package/test/unit/karma.conf.js +50 -50
  195. package/test/unit/specs/App.spec.js +17 -17
  196. package/test/unit/specs/Test.spec.js +28 -28
  197. package/test/unit/specs/components/LoginApp.spec.js +21 -21
  198. package/test/unit/specs/sevices/ConfigService.spec.js +23 -23
  199. 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
+ };