system-phone 3.1.35 → 3.1.37

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 (196) 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 +1 -1
  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/bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  100. package/src/bootstrap/less/.csscomb.json +304 -304
  101. package/src/bootstrap/less/.csslintrc +19 -19
  102. package/src/bootstrap/less/alerts.less +73 -73
  103. package/src/bootstrap/less/badges.less +66 -66
  104. package/src/bootstrap/less/bootstrap.less +56 -56
  105. package/src/bootstrap/less/breadcrumbs.less +26 -26
  106. package/src/bootstrap/less/button-groups.less +247 -247
  107. package/src/bootstrap/less/buttons.less +172 -172
  108. package/src/bootstrap/less/carousel.less +269 -269
  109. package/src/bootstrap/less/close.less +34 -34
  110. package/src/bootstrap/less/code.less +69 -69
  111. package/src/bootstrap/less/component-animations.less +33 -33
  112. package/src/bootstrap/less/dropdowns.less +216 -216
  113. package/src/bootstrap/less/forms.less +626 -626
  114. package/src/bootstrap/less/glyphicons.less +305 -305
  115. package/src/bootstrap/less/grid.less +84 -84
  116. package/src/bootstrap/less/input-groups.less +167 -167
  117. package/src/bootstrap/less/jumbotron.less +52 -52
  118. package/src/bootstrap/less/labels.less +64 -64
  119. package/src/bootstrap/less/list-group.less +141 -141
  120. package/src/bootstrap/less/media.less +66 -66
  121. package/src/bootstrap/less/mixins/alerts.less +14 -14
  122. package/src/bootstrap/less/mixins/background-variant.less +9 -9
  123. package/src/bootstrap/less/mixins/border-radius.less +18 -18
  124. package/src/bootstrap/less/mixins/buttons.less +69 -69
  125. package/src/bootstrap/less/mixins/center-block.less +7 -7
  126. package/src/bootstrap/less/mixins/clearfix.less +22 -22
  127. package/src/bootstrap/less/mixins/forms.less +90 -90
  128. package/src/bootstrap/less/mixins/gradients.less +59 -59
  129. package/src/bootstrap/less/mixins/grid-framework.less +92 -92
  130. package/src/bootstrap/less/mixins/grid.less +122 -122
  131. package/src/bootstrap/less/mixins/hide-text.less +21 -21
  132. package/src/bootstrap/less/mixins/image.less +33 -33
  133. package/src/bootstrap/less/mixins/labels.less +12 -12
  134. package/src/bootstrap/less/mixins/list-group.less +30 -30
  135. package/src/bootstrap/less/mixins/nav-divider.less +10 -10
  136. package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
  137. package/src/bootstrap/less/mixins/opacity.less +8 -8
  138. package/src/bootstrap/less/mixins/pagination.less +24 -24
  139. package/src/bootstrap/less/mixins/panels.less +24 -24
  140. package/src/bootstrap/less/mixins/progress-bar.less +10 -10
  141. package/src/bootstrap/less/mixins/reset-filter.less +8 -8
  142. package/src/bootstrap/less/mixins/reset-text.less +18 -18
  143. package/src/bootstrap/less/mixins/resize.less +6 -6
  144. package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
  145. package/src/bootstrap/less/mixins/size.less +10 -10
  146. package/src/bootstrap/less/mixins/tab-focus.less +9 -9
  147. package/src/bootstrap/less/mixins/table-row.less +44 -44
  148. package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
  149. package/src/bootstrap/less/mixins/text-overflow.less +8 -8
  150. package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
  151. package/src/bootstrap/less/mixins.less +40 -40
  152. package/src/bootstrap/less/modals.less +151 -151
  153. package/src/bootstrap/less/navbar.less +660 -660
  154. package/src/bootstrap/less/navs.less +286 -286
  155. package/src/bootstrap/less/normalize.less +424 -424
  156. package/src/bootstrap/less/pager.less +76 -76
  157. package/src/bootstrap/less/pagination.less +89 -89
  158. package/src/bootstrap/less/panels.less +275 -275
  159. package/src/bootstrap/less/popovers.less +131 -131
  160. package/src/bootstrap/less/print.less +101 -101
  161. package/src/bootstrap/less/progress-bars.less +87 -87
  162. package/src/bootstrap/less/responsive-embed.less +35 -35
  163. package/src/bootstrap/less/responsive-utilities.less +194 -194
  164. package/src/bootstrap/less/scaffolding.less +161 -161
  165. package/src/bootstrap/less/tables.less +262 -262
  166. package/src/bootstrap/less/theme.less +291 -291
  167. package/src/bootstrap/less/thumbnails.less +36 -36
  168. package/src/bootstrap/less/tooltip.less +102 -102
  169. package/src/bootstrap/less/type.less +303 -303
  170. package/src/bootstrap/less/utilities.less +55 -55
  171. package/src/bootstrap/less/variables.less +895 -895
  172. package/src/bootstrap/less/wells.less +29 -29
  173. package/src/components/AloneLoadParams.vue +26 -26
  174. package/src/components/AlreadyService.vue +1 -1
  175. package/src/components/LoadAppdata.vue +38 -38
  176. package/src/components/LoginAppV4.vue +3 -1
  177. package/src/components/ModifyPassWord.vue +216 -216
  178. package/src/components/PhoneSellInfo.vue +148 -148
  179. package/src/components/Test.vue +14 -14
  180. package/src/components/info/FindUserInfo.vue +176 -176
  181. package/src/plugins/GetStringData.js +18 -18
  182. package/src/plugins/LoadParams.js +24 -24
  183. package/src/services/ConfigService.js +24 -24
  184. package/static/app.json +4 -4
  185. package/static/globals.txt +74 -74
  186. package/test/unit/.eslintrc +5 -5
  187. package/test/unit/TestUtil.js +35 -35
  188. package/test/unit/context.html +20 -20
  189. package/test/unit/index.js +13 -13
  190. package/test/unit/init.js +13 -13
  191. package/test/unit/karma.conf.js +50 -50
  192. package/test/unit/specs/App.spec.js +17 -17
  193. package/test/unit/specs/Test.spec.js +28 -28
  194. package/test/unit/specs/components/LoginApp.spec.js +21 -21
  195. package/test/unit/specs/sevices/ConfigService.spec.js +23 -23
  196. package/test/unit/specs/sevices/GetDBTest.spec.js +28 -28
@@ -1,29 +1,29 @@
1
- //
2
- // Wells
3
- // --------------------------------------------------
4
-
5
-
6
- // Base class
7
- .well {
8
- min-height: 20px;
9
- padding: 19px;
10
- margin-bottom: 20px;
11
- background-color: @well-bg;
12
- border: 1px solid @well-border;
13
- border-radius: @border-radius-base;
14
- .box-shadow(inset 0 1px 1px rgba(0,0,0,.05));
15
- blockquote {
16
- border-color: #ddd;
17
- border-color: rgba(0,0,0,.15);
18
- }
19
- }
20
-
21
- // Sizes
22
- .well-lg {
23
- padding: 24px;
24
- border-radius: @border-radius-large;
25
- }
26
- .well-sm {
27
- padding: 9px;
28
- border-radius: @border-radius-small;
29
- }
1
+ //
2
+ // Wells
3
+ // --------------------------------------------------
4
+
5
+
6
+ // Base class
7
+ .well {
8
+ min-height: 20px;
9
+ padding: 19px;
10
+ margin-bottom: 20px;
11
+ background-color: @well-bg;
12
+ border: 1px solid @well-border;
13
+ border-radius: @border-radius-base;
14
+ .box-shadow(inset 0 1px 1px rgba(0,0,0,.05));
15
+ blockquote {
16
+ border-color: #ddd;
17
+ border-color: rgba(0,0,0,.15);
18
+ }
19
+ }
20
+
21
+ // Sizes
22
+ .well-lg {
23
+ padding: 24px;
24
+ border-radius: @border-radius-large;
25
+ }
26
+ .well-sm {
27
+ padding: 9px;
28
+ border-radius: @border-radius-small;
29
+ }
@@ -1,26 +1,26 @@
1
- <template>
2
- <div>
3
- <p>获取参数中,请保持网络畅通</p>
4
- </div>
5
- </template>
6
-
7
- <script>
8
- import co from 'co'
9
- import Vue from 'vue'
10
- import LoadParams from '../plugins/LoadParams'
11
-
12
- export default {
13
- title: '加载参数',
14
- props: {
15
- componentName: {
16
- type: String
17
- }
18
- },
19
- ready () {
20
- LoadParams.load().then(() => {
21
- // this.$resetpost(Vue.dataUrl + 'rs/logic/androidLog', {data: {name: 'path', msg: '加载参数成功'}}, {resolveMsg: null, rejectMsg: null})
22
- this.$goto(this.componentName)
23
- })
24
- }
25
- }
26
- </script>
1
+ <template>
2
+ <div>
3
+ <p>获取参数中,请保持网络畅通</p>
4
+ </div>
5
+ </template>
6
+
7
+ <script>
8
+ import co from 'co'
9
+ import Vue from 'vue'
10
+ import LoadParams from '../plugins/LoadParams'
11
+
12
+ export default {
13
+ title: '加载参数',
14
+ props: {
15
+ componentName: {
16
+ type: String
17
+ }
18
+ },
19
+ ready () {
20
+ LoadParams.load().then(() => {
21
+ // this.$resetpost(Vue.dataUrl + 'rs/logic/androidLog', {data: {name: 'path', msg: '加载参数成功'}}, {resolveMsg: null, rejectMsg: null})
22
+ this.$goto(this.componentName)
23
+ })
24
+ }
25
+ }
26
+ </script>
@@ -49,7 +49,7 @@
49
49
  let criteria = {
50
50
  items: 'id',
51
51
  tablename: 't_check_plan_item',
52
- condition: `f_no_checkplan = '有计划安检' and f_approved = '打回'`,
52
+ condition: `f_no_checkplan = '有计划安检' and f_approved = '不通过'`,
53
53
  groupitem: 'id'
54
54
  }
55
55
  let result = HostApp._executeTask({'type':'sql', 'data':{'alias': 'safe_singleTable_GroupBy', 'criteria': criteria}})
@@ -1,38 +1,38 @@
1
- <template>
2
- <div class="loadingdata" :class="{'loaderror': show, 'loadsuccess': !show}">
3
- <!-- <h2 style="margin: 0" v-if="show">{{msg}}</h2> -->
4
- <h2 style="margin: 0" v-if="show">参数加载失败,请检查网络状态和服务状态...</h2>
5
- </div>
6
- </template>
7
-
8
- <script>
9
- export default {
10
- title: '加载参数',
11
- data () {
12
- return {
13
- msg: '',
14
- show: false
15
- }
16
- },
17
- ready () {
18
- this.$appdata.load().then(() => {
19
- this.$emit('ready')
20
- })
21
- }
22
- }
23
- </script>
24
- <style media="screen">
25
- .loadingdata {
26
- position: fixed;
27
- background: #fff;
28
- opacity: 0.6;
29
- top: 0;
30
- width: 100%;
31
- }
32
- .loaderror {
33
- opacity: 1;
34
- }
35
- .loadsuccess {
36
- display: none;
37
- }
38
- </style>
1
+ <template>
2
+ <div class="loadingdata" :class="{'loaderror': show, 'loadsuccess': !show}">
3
+ <!-- <h2 style="margin: 0" v-if="show">{{msg}}</h2> -->
4
+ <h2 style="margin: 0" v-if="show">参数加载失败,请检查网络状态和服务状态...</h2>
5
+ </div>
6
+ </template>
7
+
8
+ <script>
9
+ export default {
10
+ title: '加载参数',
11
+ data () {
12
+ return {
13
+ msg: '',
14
+ show: false
15
+ }
16
+ },
17
+ ready () {
18
+ this.$appdata.load().then(() => {
19
+ this.$emit('ready')
20
+ })
21
+ }
22
+ }
23
+ </script>
24
+ <style media="screen">
25
+ .loadingdata {
26
+ position: fixed;
27
+ background: #fff;
28
+ opacity: 0.6;
29
+ top: 0;
30
+ width: 100%;
31
+ }
32
+ .loaderror {
33
+ opacity: 1;
34
+ }
35
+ .loadsuccess {
36
+ display: none;
37
+ }
38
+ </style>
@@ -100,7 +100,9 @@ let asyncReady = async function (self, url) {
100
100
  // 判断是否需要弱密码校验
101
101
  if (self.config && self.config.telephone && self.config.telephone.LoginApp && 'undefined' != typeof self.config.telephone.LoginApp.weakPassword) {
102
102
  self.weakPassword = self.config.telephone.LoginApp.weakPassword
103
+ Vue.weakPassword = self.config.telephone.LoginApp.weakPassword
103
104
  }
105
+
104
106
  console.log('手机端获取.json文件')
105
107
  console.log(JSON.stringify(self.config))
106
108
  return true
@@ -354,7 +356,7 @@ export default {
354
356
  console.log('获取参数结束')
355
357
  this.loaderShow = false
356
358
  // 弱口令验证
357
- if (this.weakPassword && !(/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?!.*(123|321|abc|cba))[a-zA-Z\d!@#$%^&*()_+-=<>?]{8,16}$/.test(this.password))) {
359
+ if (this.weakPassword && !(/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[!@#$%^&*(),.?":{}|<>~`+=_\\-])[A-Za-z\d!@#$%^&*(),.?":{}|<>~`+=_\\-]{8,}$/.test(this.password))) {
358
360
  await this.$showMessage('登录系统: 此账户的密码过于简单,请修改密码后重新登陆!!!', ['confirm'])
359
361
  this.modifyPassword = true
360
362
  return
@@ -1,216 +1,216 @@
1
- <template>
2
- <!--<div class="app-botton" @click="back()">-->
3
- <!--<span class="glyphicon glyphicon-menu-left">返回</span>-->
4
- <!--</div>-->
5
- <div class="auto">
6
- <div class="row app-row">
7
- <div class="col-xs-4">
8
- <img src="../assets/姓名.png" style="width: 20px;margin-bottom: 5px" alt="">
9
- <span class="text-left font">账号</span>
10
- </div>
11
- <div class="col-xs-8 input-font">
12
- <input type="text" class="search_input input-font" v-model="model.ename" readonly/>
13
- </div>
14
- </div>
15
- <div class="row app-row">
16
- <div class="col-xs-4" style="margin-top: 8px">
17
- <img src="../assets/原始密码.png" style="width: 20px;margin-bottom: 5px" alt="">
18
- <span class="text-left font">原始密码</span>
19
- </div>
20
- <div class="col-xs-8">
21
- <input type="password" id="oldpassword" class="search_input input-font" v-model="model.oldpassword"
22
- placeholder="请输入原始密码"/>
23
- </div>
24
- </div>
25
- <div class="row app-row">
26
- <div class="col-xs-4" style="margin-top: 8px">
27
- <img src="../assets/密码.png" style="width: 20px;margin-bottom: 5px">
28
- <span class="text-left font">新密码</span>
29
- </div>
30
- <div class="col-xs-8">
31
- <input type="password" id="newpassword1" class="search_input input-font" v-model="model.password"
32
- :placeholder="weakPassword?'需要包含大小写字母符号数字':'请输入新密码'"/>
33
- </div>
34
- </div>
35
- <div class="row app-row">
36
- <div class="col-xs-4" style="margin-top: 8px">
37
- <img src="../assets/密码.png" style="width: 20px;margin-bottom: 5px" alt="">
38
- <span class="text-left font">确认密码</span>
39
- </div>
40
- <div class="col-xs-8">
41
- <input type="password" id="newpassword2" class="search_input input-font" v-model="model.newpassword"
42
- placeholder="请重新输入新密码"/>
43
- </div>
44
- </div>
45
- <div class="row app-row">
46
- <div class="col-xs-4" style="margin-top: 8px">
47
- <img src="../assets/选中.png" style="width: 20px;margin-bottom: 5px" alt="" v-if="showpass" @click="showoff()">
48
- <img src="../assets/未选.png" style="width: 20px;margin-bottom: 5px" alt="" v-if="!showpass" @click="showon()">
49
- <span class="text-left font">显示密码</span>
50
- </div>
51
- </div>
52
- <div class="row app-row text-center">
53
- <button type="button" class="btn btn-lg btn-font btn-color" style="width: 45%;" @click="save()">提交</button>
54
- </div>
55
- </div>
56
- </template>
57
- <script>
58
- import Vue from 'vue'
59
-
60
- let asyncCheck = async function (self, url) {
61
- try {
62
- let that = self
63
- let user = {
64
- ename: that.model.ename,
65
- newpassword: that.model.password,
66
- affirmpassword: that.model.newpassword,
67
- password: that.model.oldpassword
68
- }
69
- let res = await Vue.resetpost(`${url}/${Vue.isv4 ?'api/af-system':'rs'}/user/modifypwd`, {data: user}, {resolveMsg: null, rejectMsg: null})
70
- console.log("手机端验证登陆原始密码")
71
- console.log(res.data)
72
- if ((JSON.stringify(res.data).startsWith("{") || JSON.stringify(res.data).startsWith("[")) && res.data.code && res.data.msg) {
73
- if (res.data.code === 200) {
74
- that.$showMessage('修改密码成功!')
75
- if (that.sourse == 'login') {
76
- that.$emit('success', that.model.password)
77
- return
78
- }
79
- that.$back()
80
- } else {
81
- that.$showMessage('修改密码失败,请重新输入!' + res.data.msg)
82
- console.log(res.data)
83
- return
84
- }
85
- } else {
86
- if(res.data){
87
- that.$showMessage('修改密码成功!')
88
- if(that.sourse == 'login'){
89
- that.$emit('success',that.model.password)
90
- return
91
- }
92
- that.$back()
93
- }else {
94
- that.$showMessage('修改密码失败,请重新输入!')
95
- console.log(res.data)
96
- return
97
- }
98
- }
99
- } catch (error) {
100
- if (error.status == 500) {
101
- that.$showMessage('网络异常,请检查手机网络!')
102
- } else {
103
- throw error
104
- }
105
- }
106
- }
107
-
108
- export default {
109
- title: '修改密码',
110
- data() {
111
- return {
112
- model: {
113
- user: Vue.user.name,
114
- userid: Vue.user.id,
115
- ename: Vue.user.ename,
116
- oldpassword: '',
117
- password: '',
118
- newpassword: ''
119
- },
120
- showpass: false
121
- }
122
- },
123
- props: {
124
- sourse: '',
125
- weakPassword: false
126
- },
127
- ready() {
128
-
129
- },
130
- methods: {
131
- back() {
132
- let _this = this
133
- this.$showMessage('所填写内容将不可恢复!', ['confirm', 'cancel']).then((res) => {
134
- if (res === 'confirm') {
135
- _this.$back()
136
- }
137
- })
138
- },
139
- // showpass(){
140
- // console.log('1')
141
- // document.getElementById("oldpassword").type = "text"
142
- // },
143
- showon() {
144
- this.showpass = true
145
- document.getElementById("oldpassword").type = "text"
146
- document.getElementById("newpassword1").type = "text"
147
- document.getElementById("newpassword2").type = "text"
148
- },
149
- showoff() {
150
- this.showpass = false
151
- document.getElementById("oldpassword").type = "password"
152
- document.getElementById("newpassword1").type = "password"
153
- document.getElementById("newpassword2").type = "password"
154
- },
155
- save() {
156
- // 先对新密码和确认密码是否一致
157
- if (this.model.password != this.model.newpassword) {
158
- this.$showMessage('两次输入密码不一致!')
159
- return
160
- }
161
- if (this.weakPassword && this.model.password && !(/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?!.*(123|321|abc|cba))[a-zA-Z\d!@#$%^&*()_+-=<>?]{8,16}$/.test(this.model.password))) {
162
- this.$showMessage("密码必须是8~16位数字与大小字母外加特殊字符的组合,并且不能出现类似'123','abc'等连贯数字或者字母")
163
- return
164
- }
165
- // 检验原始密码是否符合 并修改密码
166
- asyncCheck(this, this.$androidUtil.getProxyUrl())
167
- }
168
- }
169
- }
170
- </script>
171
- <style>
172
- .search_input {
173
- border: 0;
174
- outline: none;
175
- }
176
-
177
- .app-row {
178
- background-color: white;
179
- padding: 10px 10px 0 10px;
180
- border-bottom: 1px solid rgba(235, 235, 235, 0.5);
181
- }
182
-
183
- .font {
184
- font: 15px PingFang-SC-Medium;
185
- }
186
-
187
- .btn-font {
188
- font: 600 16px PingFang-SC-Bold;
189
- color: #499EDF;
190
- }
191
-
192
- .btn-color {
193
- background-color: #FFFFFF;
194
- border-radius: 10px;
195
- border: 1px solid #499EDF;
196
- }
197
-
198
- .input-font {
199
- font: 15px PingFang-SC-Medium;
200
- color: #333333;
201
- }
202
-
203
- .app-botton {
204
- position: fixed;
205
- background: #87b2dd;
206
- color: #FFF;
207
- padding: 8px;
208
- text-align: center;
209
- font-size: 1.2em;
210
- z-index: 10;
211
- opacity: 0.5;
212
- bottom: 50px;
213
- margin-top: -10px;
214
- height: 40px;
215
- }
216
- </style>
1
+ <template>
2
+ <!--<div class="app-botton" @click="back()">-->
3
+ <!--<span class="glyphicon glyphicon-menu-left">返回</span>-->
4
+ <!--</div>-->
5
+ <div class="auto">
6
+ <div class="row app-row">
7
+ <div class="col-xs-4">
8
+ <img src="../assets/姓名.png" style="width: 20px;margin-bottom: 5px" alt="">
9
+ <span class="text-left font">账号</span>
10
+ </div>
11
+ <div class="col-xs-8 input-font">
12
+ <input type="text" class="search_input input-font" v-model="model.ename" readonly/>
13
+ </div>
14
+ </div>
15
+ <div class="row app-row">
16
+ <div class="col-xs-4" style="margin-top: 8px">
17
+ <img src="../assets/原始密码.png" style="width: 20px;margin-bottom: 5px" alt="">
18
+ <span class="text-left font">原始密码</span>
19
+ </div>
20
+ <div class="col-xs-8">
21
+ <input type="password" id="oldpassword" class="search_input input-font" v-model="model.oldpassword"
22
+ placeholder="请输入原始密码"/>
23
+ </div>
24
+ </div>
25
+ <div class="row app-row">
26
+ <div class="col-xs-4" style="margin-top: 8px">
27
+ <img src="../assets/密码.png" style="width: 20px;margin-bottom: 5px">
28
+ <span class="text-left font">新密码</span>
29
+ </div>
30
+ <div class="col-xs-8">
31
+ <input type="password" id="newpassword1" class="search_input input-font" v-model="model.password"
32
+ :placeholder="weakPassword?'需要包含大小写字母符号数字':'请输入新密码'"/>
33
+ </div>
34
+ </div>
35
+ <div class="row app-row">
36
+ <div class="col-xs-4" style="margin-top: 8px">
37
+ <img src="../assets/密码.png" style="width: 20px;margin-bottom: 5px" alt="">
38
+ <span class="text-left font">确认密码</span>
39
+ </div>
40
+ <div class="col-xs-8">
41
+ <input type="password" id="newpassword2" class="search_input input-font" v-model="model.newpassword"
42
+ placeholder="请重新输入新密码"/>
43
+ </div>
44
+ </div>
45
+ <div class="row app-row">
46
+ <div class="col-xs-4" style="margin-top: 8px">
47
+ <img src="../assets/选中.png" style="width: 20px;margin-bottom: 5px" alt="" v-if="showpass" @click="showoff()">
48
+ <img src="../assets/未选.png" style="width: 20px;margin-bottom: 5px" alt="" v-if="!showpass" @click="showon()">
49
+ <span class="text-left font">显示密码</span>
50
+ </div>
51
+ </div>
52
+ <div class="row app-row text-center">
53
+ <button type="button" class="btn btn-lg btn-font btn-color" style="width: 45%;" @click="save()">提交</button>
54
+ </div>
55
+ </div>
56
+ </template>
57
+ <script>
58
+ import Vue from 'vue'
59
+
60
+ let asyncCheck = async function (self, url) {
61
+ try {
62
+ let that = self
63
+ let user = {
64
+ ename: that.model.ename,
65
+ newpassword: that.model.password,
66
+ affirmpassword: that.model.newpassword,
67
+ password: that.model.oldpassword
68
+ }
69
+ let res = await Vue.resetpost(`${url}/${Vue.isv4 ?'api/af-system':'rs'}/user/modifypwd`, {data: user}, {resolveMsg: null, rejectMsg: null})
70
+ console.log("手机端验证登陆原始密码")
71
+ console.log(res.data)
72
+ if ((JSON.stringify(res.data).startsWith("{") || JSON.stringify(res.data).startsWith("[")) && res.data.code && res.data.msg) {
73
+ if (res.data.code === 200) {
74
+ that.$showMessage('修改密码成功!')
75
+ if (that.sourse == 'login') {
76
+ that.$emit('success', that.model.password)
77
+ return
78
+ }
79
+ that.$back()
80
+ } else {
81
+ that.$showMessage('修改密码失败,请重新输入!' + res.data.msg)
82
+ console.log(res.data)
83
+ return
84
+ }
85
+ } else {
86
+ if(res.data){
87
+ that.$showMessage('修改密码成功!')
88
+ if(that.sourse == 'login'){
89
+ that.$emit('success',that.model.password)
90
+ return
91
+ }
92
+ that.$back()
93
+ }else {
94
+ that.$showMessage('修改密码失败,请重新输入!')
95
+ console.log(res.data)
96
+ return
97
+ }
98
+ }
99
+ } catch (error) {
100
+ if (error.status == 500) {
101
+ that.$showMessage('网络异常,请检查手机网络!')
102
+ } else {
103
+ throw error
104
+ }
105
+ }
106
+ }
107
+
108
+ export default {
109
+ title: '修改密码',
110
+ data() {
111
+ return {
112
+ model: {
113
+ user: Vue.user.name,
114
+ userid: Vue.user.id,
115
+ ename: Vue.user.ename,
116
+ oldpassword: '',
117
+ password: '',
118
+ newpassword: ''
119
+ },
120
+ showpass: false
121
+ }
122
+ },
123
+ props: {
124
+ sourse: '',
125
+ weakPassword: false
126
+ },
127
+ ready() {
128
+
129
+ },
130
+ methods: {
131
+ back() {
132
+ let _this = this
133
+ this.$showMessage('所填写内容将不可恢复!', ['confirm', 'cancel']).then((res) => {
134
+ if (res === 'confirm') {
135
+ _this.$back()
136
+ }
137
+ })
138
+ },
139
+ // showpass(){
140
+ // console.log('1')
141
+ // document.getElementById("oldpassword").type = "text"
142
+ // },
143
+ showon() {
144
+ this.showpass = true
145
+ document.getElementById("oldpassword").type = "text"
146
+ document.getElementById("newpassword1").type = "text"
147
+ document.getElementById("newpassword2").type = "text"
148
+ },
149
+ showoff() {
150
+ this.showpass = false
151
+ document.getElementById("oldpassword").type = "password"
152
+ document.getElementById("newpassword1").type = "password"
153
+ document.getElementById("newpassword2").type = "password"
154
+ },
155
+ save() {
156
+ // 先对新密码和确认密码是否一致
157
+ if (this.model.password != this.model.newpassword) {
158
+ this.$showMessage('两次输入密码不一致!')
159
+ return
160
+ }
161
+ if (Vue.weakPassword && !(/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[!@#$%^&*(),.?":{}|<>~`+=_\\-])[A-Za-z\d!@#$%^&*(),.?":{}|<>~`+=_\\-]{8,}$/.test(this.model.password))) {
162
+ this.$showMessage("密码必须是8~16位数字与大小字母外加特殊字符的组合,并且不能出现类似'123','abc'等连贯数字或者字母")
163
+ return
164
+ }
165
+ // 检验原始密码是否符合 并修改密码
166
+ asyncCheck(this, this.$androidUtil.getProxyUrl())
167
+ }
168
+ }
169
+ }
170
+ </script>
171
+ <style>
172
+ .search_input {
173
+ border: 0;
174
+ outline: none;
175
+ }
176
+
177
+ .app-row {
178
+ background-color: white;
179
+ padding: 10px 10px 0 10px;
180
+ border-bottom: 1px solid rgba(235, 235, 235, 0.5);
181
+ }
182
+
183
+ .font {
184
+ font: 15px PingFang-SC-Medium;
185
+ }
186
+
187
+ .btn-font {
188
+ font: 600 16px PingFang-SC-Bold;
189
+ color: #499EDF;
190
+ }
191
+
192
+ .btn-color {
193
+ background-color: #FFFFFF;
194
+ border-radius: 10px;
195
+ border: 1px solid #499EDF;
196
+ }
197
+
198
+ .input-font {
199
+ font: 15px PingFang-SC-Medium;
200
+ color: #333333;
201
+ }
202
+
203
+ .app-botton {
204
+ position: fixed;
205
+ background: #87b2dd;
206
+ color: #FFF;
207
+ padding: 8px;
208
+ text-align: center;
209
+ font-size: 1.2em;
210
+ z-index: 10;
211
+ opacity: 0.5;
212
+ bottom: 50px;
213
+ margin-top: -10px;
214
+ height: 40px;
215
+ }
216
+ </style>