system-phone 3.0.49-57 → 3.0.49-59

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 (280) hide show
  1. package/.babelrc +5 -5
  2. package/.editorconfig +9 -9
  3. package/.eslintrc.js +16 -16
  4. package/.gradle/buildOutputCleanup/cache.properties +2 -2
  5. package/CHANGELOG.md +1 -1
  6. package/Dockerfile +3 -3
  7. package/README.md +36 -36
  8. package/SystemPhone.iml +8 -8
  9. package/build/css-loaders.js +34 -34
  10. package/build/dev-client.js +8 -8
  11. package/build/dev-server.js +141 -141
  12. package/build/example-server.js +80 -80
  13. package/build/release.sh +28 -28
  14. package/build/utils.js +71 -71
  15. package/build/webpack.base.conf.js +82 -82
  16. package/build/webpack.dev.conf.js +31 -31
  17. package/build/webpack.example.conf.js +49 -49
  18. package/build/webpack.prod.conf.js +60 -60
  19. package/build/webpack.test.conf.js +31 -31
  20. package/build.gradle +27 -27
  21. package/config/dev.env.js +6 -6
  22. package/config/index.js +38 -38
  23. package/config/prod.env.js +3 -3
  24. package/config/test.env.js +6 -6
  25. package/gradle/wrapper/gradle-wrapper.properties +5 -5
  26. package/gradlew +183 -183
  27. package/gradlew.bat +100 -100
  28. package/index.html +21 -21
  29. package/nginx.conf +304 -304
  30. package/package.json +1 -1
  31. package/release.bat +5 -5
  32. package/src/App.vue +25 -25
  33. package/src/Util.js +415 -415
  34. package/src/android-bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  35. package/src/android-bootstrap/less/.csscomb.json +304 -304
  36. package/src/android-bootstrap/less/.csslintrc +19 -19
  37. package/src/android-bootstrap/less/alerts.less +73 -73
  38. package/src/android-bootstrap/less/badges.less +66 -66
  39. package/src/android-bootstrap/less/bootstrap.less +56 -56
  40. package/src/android-bootstrap/less/breadcrumbs.less +26 -26
  41. package/src/android-bootstrap/less/button-groups.less +247 -247
  42. package/src/android-bootstrap/less/buttons.less +173 -173
  43. package/src/android-bootstrap/less/carousel.less +269 -269
  44. package/src/android-bootstrap/less/close.less +34 -34
  45. package/src/android-bootstrap/less/code.less +69 -69
  46. package/src/android-bootstrap/less/component-animations.less +33 -33
  47. package/src/android-bootstrap/less/dropdowns.less +216 -216
  48. package/src/android-bootstrap/less/forms.less +626 -626
  49. package/src/android-bootstrap/less/glyphicons.less +305 -305
  50. package/src/android-bootstrap/less/grid.less +84 -84
  51. package/src/android-bootstrap/less/input-groups.less +167 -167
  52. package/src/android-bootstrap/less/jumbotron.less +52 -52
  53. package/src/android-bootstrap/less/labels.less +64 -64
  54. package/src/android-bootstrap/less/list-group.less +141 -141
  55. package/src/android-bootstrap/less/media.less +66 -66
  56. package/src/android-bootstrap/less/mixins/alerts.less +14 -14
  57. package/src/android-bootstrap/less/mixins/background-variant.less +9 -9
  58. package/src/android-bootstrap/less/mixins/border-radius.less +18 -18
  59. package/src/android-bootstrap/less/mixins/buttons.less +69 -69
  60. package/src/android-bootstrap/less/mixins/center-block.less +7 -7
  61. package/src/android-bootstrap/less/mixins/clearfix.less +22 -22
  62. package/src/android-bootstrap/less/mixins/forms.less +90 -90
  63. package/src/android-bootstrap/less/mixins/gradients.less +59 -59
  64. package/src/android-bootstrap/less/mixins/grid-framework.less +92 -92
  65. package/src/android-bootstrap/less/mixins/grid.less +122 -122
  66. package/src/android-bootstrap/less/mixins/hide-text.less +21 -21
  67. package/src/android-bootstrap/less/mixins/image.less +33 -33
  68. package/src/android-bootstrap/less/mixins/labels.less +12 -12
  69. package/src/android-bootstrap/less/mixins/list-group.less +30 -30
  70. package/src/android-bootstrap/less/mixins/nav-divider.less +10 -10
  71. package/src/android-bootstrap/less/mixins/nav-vertical-align.less +9 -9
  72. package/src/android-bootstrap/less/mixins/opacity.less +8 -8
  73. package/src/android-bootstrap/less/mixins/pagination.less +24 -24
  74. package/src/android-bootstrap/less/mixins/panels.less +24 -24
  75. package/src/android-bootstrap/less/mixins/progress-bar.less +10 -10
  76. package/src/android-bootstrap/less/mixins/reset-filter.less +8 -8
  77. package/src/android-bootstrap/less/mixins/reset-text.less +18 -18
  78. package/src/android-bootstrap/less/mixins/resize.less +6 -6
  79. package/src/android-bootstrap/less/mixins/responsive-visibility.less +15 -15
  80. package/src/android-bootstrap/less/mixins/size.less +10 -10
  81. package/src/android-bootstrap/less/mixins/tab-focus.less +9 -9
  82. package/src/android-bootstrap/less/mixins/table-row.less +44 -44
  83. package/src/android-bootstrap/less/mixins/text-emphasis.less +9 -9
  84. package/src/android-bootstrap/less/mixins/text-overflow.less +8 -8
  85. package/src/android-bootstrap/less/mixins/vendor-prefixes.less +227 -227
  86. package/src/android-bootstrap/less/mixins.less +40 -40
  87. package/src/android-bootstrap/less/modals.less +151 -151
  88. package/src/android-bootstrap/less/navbar.less +660 -660
  89. package/src/android-bootstrap/less/navs.less +290 -290
  90. package/src/android-bootstrap/less/normalize.less +424 -424
  91. package/src/android-bootstrap/less/pager.less +76 -76
  92. package/src/android-bootstrap/less/pagination.less +89 -89
  93. package/src/android-bootstrap/less/panels.less +274 -274
  94. package/src/android-bootstrap/less/popovers.less +131 -131
  95. package/src/android-bootstrap/less/print.less +101 -101
  96. package/src/android-bootstrap/less/progress-bars.less +87 -87
  97. package/src/android-bootstrap/less/responsive-embed.less +35 -35
  98. package/src/android-bootstrap/less/responsive-utilities.less +194 -194
  99. package/src/android-bootstrap/less/scaffolding.less +161 -161
  100. package/src/android-bootstrap/less/tables.less +262 -262
  101. package/src/android-bootstrap/less/theme.less +291 -291
  102. package/src/android-bootstrap/less/thumbnails.less +36 -36
  103. package/src/android-bootstrap/less/tooltip.less +102 -102
  104. package/src/android-bootstrap/less/type.less +303 -303
  105. package/src/android-bootstrap/less/utilities.less +55 -55
  106. package/src/android-bootstrap/less/variables.less +896 -896
  107. package/src/android-bootstrap/less/wells.less +29 -29
  108. package/src/assets//347/224/250/346/210/267/345/273/272/346/241/243.png +0 -0
  109. package/src/assets//350/256/241/345/210/222/345/256/211/346/243/200.png +0 -0
  110. package/src/bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  111. package/src/bootstrap/less/.csscomb.json +304 -304
  112. package/src/bootstrap/less/.csslintrc +19 -19
  113. package/src/bootstrap/less/alerts.less +73 -73
  114. package/src/bootstrap/less/badges.less +66 -66
  115. package/src/bootstrap/less/bootstrap.less +56 -56
  116. package/src/bootstrap/less/breadcrumbs.less +26 -26
  117. package/src/bootstrap/less/button-groups.less +247 -247
  118. package/src/bootstrap/less/buttons.less +172 -172
  119. package/src/bootstrap/less/carousel.less +269 -269
  120. package/src/bootstrap/less/close.less +34 -34
  121. package/src/bootstrap/less/code.less +69 -69
  122. package/src/bootstrap/less/component-animations.less +33 -33
  123. package/src/bootstrap/less/dropdowns.less +216 -216
  124. package/src/bootstrap/less/forms.less +626 -626
  125. package/src/bootstrap/less/glyphicons.less +305 -305
  126. package/src/bootstrap/less/grid.less +84 -84
  127. package/src/bootstrap/less/input-groups.less +167 -167
  128. package/src/bootstrap/less/jumbotron.less +52 -52
  129. package/src/bootstrap/less/labels.less +64 -64
  130. package/src/bootstrap/less/list-group.less +141 -141
  131. package/src/bootstrap/less/media.less +66 -66
  132. package/src/bootstrap/less/mixins/alerts.less +14 -14
  133. package/src/bootstrap/less/mixins/background-variant.less +9 -9
  134. package/src/bootstrap/less/mixins/border-radius.less +18 -18
  135. package/src/bootstrap/less/mixins/buttons.less +69 -69
  136. package/src/bootstrap/less/mixins/center-block.less +7 -7
  137. package/src/bootstrap/less/mixins/clearfix.less +22 -22
  138. package/src/bootstrap/less/mixins/forms.less +90 -90
  139. package/src/bootstrap/less/mixins/gradients.less +59 -59
  140. package/src/bootstrap/less/mixins/grid-framework.less +92 -92
  141. package/src/bootstrap/less/mixins/grid.less +122 -122
  142. package/src/bootstrap/less/mixins/hide-text.less +21 -21
  143. package/src/bootstrap/less/mixins/image.less +33 -33
  144. package/src/bootstrap/less/mixins/labels.less +12 -12
  145. package/src/bootstrap/less/mixins/list-group.less +30 -30
  146. package/src/bootstrap/less/mixins/nav-divider.less +10 -10
  147. package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
  148. package/src/bootstrap/less/mixins/opacity.less +8 -8
  149. package/src/bootstrap/less/mixins/pagination.less +24 -24
  150. package/src/bootstrap/less/mixins/panels.less +24 -24
  151. package/src/bootstrap/less/mixins/progress-bar.less +10 -10
  152. package/src/bootstrap/less/mixins/reset-filter.less +8 -8
  153. package/src/bootstrap/less/mixins/reset-text.less +18 -18
  154. package/src/bootstrap/less/mixins/resize.less +6 -6
  155. package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
  156. package/src/bootstrap/less/mixins/size.less +10 -10
  157. package/src/bootstrap/less/mixins/tab-focus.less +9 -9
  158. package/src/bootstrap/less/mixins/table-row.less +44 -44
  159. package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
  160. package/src/bootstrap/less/mixins/text-overflow.less +8 -8
  161. package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
  162. package/src/bootstrap/less/mixins.less +40 -40
  163. package/src/bootstrap/less/modals.less +151 -151
  164. package/src/bootstrap/less/navbar.less +660 -660
  165. package/src/bootstrap/less/navs.less +286 -286
  166. package/src/bootstrap/less/normalize.less +424 -424
  167. package/src/bootstrap/less/pager.less +76 -76
  168. package/src/bootstrap/less/pagination.less +89 -89
  169. package/src/bootstrap/less/panels.less +275 -275
  170. package/src/bootstrap/less/popovers.less +131 -131
  171. package/src/bootstrap/less/print.less +101 -101
  172. package/src/bootstrap/less/progress-bars.less +87 -87
  173. package/src/bootstrap/less/responsive-embed.less +35 -35
  174. package/src/bootstrap/less/responsive-utilities.less +194 -194
  175. package/src/bootstrap/less/scaffolding.less +161 -161
  176. package/src/bootstrap/less/tables.less +262 -262
  177. package/src/bootstrap/less/theme.less +291 -291
  178. package/src/bootstrap/less/thumbnails.less +36 -36
  179. package/src/bootstrap/less/tooltip.less +102 -102
  180. package/src/bootstrap/less/type.less +303 -303
  181. package/src/bootstrap/less/utilities.less +55 -55
  182. package/src/bootstrap/less/variables.less +895 -895
  183. package/src/bootstrap/less/wells.less +29 -29
  184. package/src/components/AloneLoadParams.vue +26 -26
  185. package/src/components/AlreadyService.vue +193 -193
  186. package/src/components/AttendManage.vue +534 -534
  187. package/src/components/LoadAppdata.vue +38 -38
  188. package/src/components/LoginApp.vue +732 -732
  189. package/src/components/LoginAppNew.vue +587 -587
  190. package/src/components/ModifyPassWord.vue +216 -216
  191. package/src/components/NavBottom.vue +117 -117
  192. package/src/components/NavBottomV.vue +141 -141
  193. package/src/components/NavBottomVVV.vue +185 -185
  194. package/src/components/OnlineManage.vue +256 -256
  195. package/src/components/PhoneAllInfo.vue +68 -68
  196. package/src/components/PhoneChangemeterInfo.vue +116 -116
  197. package/src/components/PhoneImageInfo.vue +102 -102
  198. package/src/components/PhoneInfoTable.vue +39 -39
  199. package/src/components/PhoneMeterInfo.vue +132 -132
  200. package/src/components/PhoneRepairInfo.vue +146 -146
  201. package/src/components/PhoneSafeInfo.vue +101 -101
  202. package/src/components/PhoneSellInfo.vue +148 -148
  203. package/src/components/PhoneSellInfoLite.vue +112 -112
  204. package/src/components/PhoneUser.vue +202 -202
  205. package/src/components/PhoneUserDetil.vue +70 -70
  206. package/src/components/PhoneUserFind.vue +138 -138
  207. package/src/components/RightTree.vue +217 -217
  208. package/src/components/SystemSetUp.vue +332 -332
  209. package/src/components/TabBarPhone.vue +81 -81
  210. package/src/components/Test.vue +14 -14
  211. package/src/components/ToolsPage.vue +199 -199
  212. package/src/components/UploadManage.vue +194 -194
  213. package/src/components/gaomi/NavBottomV.vue +223 -223
  214. package/src/components/gaomi/NavBottomVVVV.vue +210 -210
  215. package/src/components/gaomi/Scroller.vue +63 -63
  216. package/src/components/gaomi/SystemSetUp.vue +186 -186
  217. package/src/components/gaomi/ToolsPage.vue +168 -168
  218. package/src/components/idea/feedBack.vue +150 -150
  219. package/src/components/idea/feedbackAdd.vue +366 -366
  220. package/src/components/info/ConfigInfo.vue +122 -122
  221. package/src/components/info/FindUserInfo.vue +157 -157
  222. package/src/components/info/InfoTable.vue +37 -37
  223. package/src/components/iot/InstructMessage.vue +313 -313
  224. package/src/components/iot/IotBaseInfo.vue +97 -97
  225. package/src/components/iot/IotMeterInfo.vue +77 -77
  226. package/src/components/iot/iotMonitoringMain.vue +501 -501
  227. package/src/components/online/ApplyOnline.vue +581 -581
  228. package/src/components/online/BJZhongRan/ApplyOnline.vue +600 -600
  229. package/src/components/screen/ChargeContentPage.vue +656 -656
  230. package/src/components/screen/ContentPage.vue +611 -611
  231. package/src/components/screen/GongdanContentPage.vue +149 -149
  232. package/src/components/screen/ListCountItem.vue +93 -93
  233. package/src/components/screen/ModuleTitle.vue +48 -48
  234. package/src/components/screen/SafeOrderContentPage.vue +440 -440
  235. package/src/components/screen/SecurityCheckItem.vue +50 -50
  236. package/src/components/screen/TotalItem.vue +76 -76
  237. package/src/components/screen/TotalUserNumber.vue +77 -77
  238. package/src/components/screen/WorkOrderItem.vue +51 -51
  239. package/src/components/screen/WorkOrderRightDownItem.vue +103 -103
  240. package/src/components/screen/WorkOrderRightItem.vue +115 -115
  241. package/src/components/userinfo/paymentQuery.vue +189 -189
  242. package/src/components/userinfo/queryFile.vue +190 -190
  243. package/src/components/wasm.vue +18 -18
  244. package/src/expandcssAndroid.less +521 -521
  245. package/src/filiale/yulinyuchuan/AlreadyService.vue +194 -194
  246. package/src/filiale/yulinyuchuan/AttendManage.vue +537 -537
  247. package/src/filiale/yulinyuchuan/LoginApp.vue +741 -741
  248. package/src/filiale/yulinyuchuan/OnlineManage.vue +256 -256
  249. package/src/filiale/yulinyuchuan/SystemSetUp.vue +332 -332
  250. package/src/filiale/yulinyuchuan/UploadManage.vue +195 -195
  251. package/src/filiale/yulinyuchuan/systemphonegrid.js +9 -9
  252. package/src/index.js +9 -9
  253. package/src/main.js +38 -38
  254. package/src/plugins/GetStringData.js +18 -18
  255. package/src/plugins/LoadParams.js +24 -24
  256. package/src/plugins/const.js +404 -404
  257. package/src/plugins/vue-py.js +37 -37
  258. package/src/services/ConfigService.js +24 -24
  259. package/src/stores/AppData.js +91 -73
  260. package/src/systemphone-gaomi.js +105 -105
  261. package/src/systemphone.js +58 -58
  262. package/src/systemphonegrid.js +181 -181
  263. package/src/util/LdapHelper.js +75 -75
  264. package/static/app.json +4 -4
  265. package/static/const.js +404 -404
  266. package/static/globals.txt +74 -74
  267. package/static/layui/font/iconfont.svg +554 -554
  268. package/static/vue-py.js +37 -37
  269. package/static/wasm_exec.js +465 -465
  270. package/test/unit/.eslintrc +5 -5
  271. package/test/unit/TestUtil.js +35 -35
  272. package/test/unit/context.html +20 -20
  273. package/test/unit/index.js +13 -13
  274. package/test/unit/init.js +13 -13
  275. package/test/unit/karma.conf.js +50 -50
  276. package/test/unit/specs/App.spec.js +17 -17
  277. package/test/unit/specs/Test.spec.js +28 -28
  278. package/test/unit/specs/components/LoginApp.spec.js +21 -21
  279. package/test/unit/specs/sevices/ConfigService.spec.js +23 -23
  280. package/test/unit/specs/sevices/GetDBTest.spec.js +28 -28
@@ -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}/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}/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,117 +1,117 @@
1
- <template>
2
- <div class="no-close row android-repair-order">
3
- <div :class="[fullpage ? 'menu-hide' : 'col-sm-3 col-xs-3']" >
4
- <ul class="nav nav-tabs">
5
- <li>
6
- <p style="padding-left: 15px; color: white; font-weight: 550">
7
- 登录人:{{loginInfo.name}}
8
- </p>
9
- <!--({{loginInfo.id}})-->
10
- </li>
11
- <li v-for="tab in tabs" @click="tabSelect(tab.link)" :class="{active: tab.link === componentName}">
12
- <a href="#" class="tab-befor-img">
13
- <img :src="getImg(tab.icon)" style="height: 30px;width:30px;">
14
- {{tab.name}}</a>
15
- </li>
16
- <li @click="mute()">
17
- <a href="#" class="repair-mute-class" >
18
- <img src="../assets/guanbishengyin.png" style="height: 30px;width:30px;border-width:0">关闭声音</a>
19
- </li>
20
- </ul>
21
- </div>
22
- <div :class="[fullpage ? 'col-sm-12 col-xs-12' : 'col-sm-9 col-xs-9']" style="overflow: auto;">
23
- <!--<route v-ref:route></route>-->
24
- <repair-first v-if="componentName === 'repair-first'"></repair-first>
25
- <completed-repair v-if="componentName === 'completed-repair'"></completed-repair>
26
- <up-load v-if="componentName === 'up-load'"></up-load>
27
- <check-page v-if="componentName === 'check-page'"></check-page>
28
- <readmeter-home v-if="componentName === 'readmeter-home'"></readmeter-home>
29
- <repair-send v-if="componentName === 'repair-send'"></repair-send>
30
- </div>
31
- </div>
32
- </template>
33
-
34
- <script scoped>
35
- import Vue from 'vue'
36
- import * as Util from '../Util'
37
- export default {
38
- title: '底部导航',
39
- data () {
40
- return {
41
- componentName: 'repair-first',
42
- tabs: Util.f.functions,
43
- text: '导航组件this',
44
- fullpage: false,
45
- loginInfo: {}
46
- }
47
- },
48
- ready () {
49
- this.loginInfo = Object.assign({}, this.loginInfo, Vue.user)
50
- console.log(this.loginInfo, 'loginINfo')
51
- // this.$refs.route.init('repair-first')
52
- },
53
- methods: {
54
- // 选择tab
55
- tabSelect (name) {
56
- this.componentName = name
57
- // this.$refs.route.init(name)
58
- if (name !== 'text-chat-pane') {
59
- this.notified('false')
60
- } else {
61
- this.notified('true')
62
- }
63
- },
64
- notified (stopped) {
65
- console.log('txtServiceStopped invoked$')
66
- if (this.$androidUtil.isAndroid) {
67
- HostApp.setPreference('txtServiceStopped', stopped)
68
- HostApp.setPreference('msgCount', '0')
69
- }
70
- },
71
- mute () {
72
- if(navigator.userAgent.match('iPad') || navigator.userAgent.match('iPhone')){
73
- window.prompt("mute","")
74
- }else{
75
- HostApp.mute()
76
- }
77
- },
78
- getImg (param) {
79
- return require(`../assets/${param}.png`)
80
- }
81
- },
82
- events: {
83
- showFullPage () {
84
- this.fullpage = true
85
- },
86
- hideFullPage () {
87
- this.fullpage = false
88
- }
89
- }
90
- }
91
- </script>
92
- <style lang="less">
93
- .tab-befor-img {
94
- margin: 3px 0;
95
- content: '';
96
- background-size: 30px;
97
- display: inline-block;
98
- margin-right: 8px;
99
- height: 30px;
100
- width: 100%;
101
- vertical-align: -35%;
102
- }
103
- img[src=""],img:not([src]){
104
- opacity: 0;
105
- border:none;
106
- visibility: hidden;
107
- max-width: none;
108
- }
109
- /* .repair-mute-class {
110
- &::before {
111
- .tab-befor-img("../assets/guanbishengyin.png")
112
- }
113
- }*/
114
- .menu-hide {
115
- display: none;
116
- }
117
- </style>
1
+ <template>
2
+ <div class="no-close row android-repair-order">
3
+ <div :class="[fullpage ? 'menu-hide' : 'col-sm-3 col-xs-3']" >
4
+ <ul class="nav nav-tabs">
5
+ <li>
6
+ <p style="padding-left: 15px; color: white; font-weight: 550">
7
+ 登录人:{{loginInfo.name}}
8
+ </p>
9
+ <!--({{loginInfo.id}})-->
10
+ </li>
11
+ <li v-for="tab in tabs" @click="tabSelect(tab.link)" :class="{active: tab.link === componentName}">
12
+ <a href="#" class="tab-befor-img">
13
+ <img :src="getImg(tab.icon)" style="height: 30px;width:30px;">
14
+ {{tab.name}}</a>
15
+ </li>
16
+ <li @click="mute()">
17
+ <a href="#" class="repair-mute-class" >
18
+ <img src="../assets/guanbishengyin.png" style="height: 30px;width:30px;border-width:0">关闭声音</a>
19
+ </li>
20
+ </ul>
21
+ </div>
22
+ <div :class="[fullpage ? 'col-sm-12 col-xs-12' : 'col-sm-9 col-xs-9']" style="overflow: auto;">
23
+ <!--<route v-ref:route></route>-->
24
+ <repair-first v-if="componentName === 'repair-first'"></repair-first>
25
+ <completed-repair v-if="componentName === 'completed-repair'"></completed-repair>
26
+ <up-load v-if="componentName === 'up-load'"></up-load>
27
+ <check-page v-if="componentName === 'check-page'"></check-page>
28
+ <readmeter-home v-if="componentName === 'readmeter-home'"></readmeter-home>
29
+ <repair-send v-if="componentName === 'repair-send'"></repair-send>
30
+ </div>
31
+ </div>
32
+ </template>
33
+
34
+ <script scoped>
35
+ import Vue from 'vue'
36
+ import * as Util from '../Util'
37
+ export default {
38
+ title: '底部导航',
39
+ data () {
40
+ return {
41
+ componentName: 'repair-first',
42
+ tabs: Util.f.functions,
43
+ text: '导航组件this',
44
+ fullpage: false,
45
+ loginInfo: {}
46
+ }
47
+ },
48
+ ready () {
49
+ this.loginInfo = Object.assign({}, this.loginInfo, Vue.user)
50
+ console.log(this.loginInfo, 'loginINfo')
51
+ // this.$refs.route.init('repair-first')
52
+ },
53
+ methods: {
54
+ // 选择tab
55
+ tabSelect (name) {
56
+ this.componentName = name
57
+ // this.$refs.route.init(name)
58
+ if (name !== 'text-chat-pane') {
59
+ this.notified('false')
60
+ } else {
61
+ this.notified('true')
62
+ }
63
+ },
64
+ notified (stopped) {
65
+ console.log('txtServiceStopped invoked$')
66
+ if (this.$androidUtil.isAndroid) {
67
+ HostApp.setPreference('txtServiceStopped', stopped)
68
+ HostApp.setPreference('msgCount', '0')
69
+ }
70
+ },
71
+ mute () {
72
+ if(navigator.userAgent.match('iPad') || navigator.userAgent.match('iPhone')){
73
+ window.prompt("mute","")
74
+ }else{
75
+ HostApp.mute()
76
+ }
77
+ },
78
+ getImg (param) {
79
+ return require(`../assets/${param}.png`)
80
+ }
81
+ },
82
+ events: {
83
+ showFullPage () {
84
+ this.fullpage = true
85
+ },
86
+ hideFullPage () {
87
+ this.fullpage = false
88
+ }
89
+ }
90
+ }
91
+ </script>
92
+ <style lang="less">
93
+ .tab-befor-img {
94
+ margin: 3px 0;
95
+ content: '';
96
+ background-size: 30px;
97
+ display: inline-block;
98
+ margin-right: 8px;
99
+ height: 30px;
100
+ width: 100%;
101
+ vertical-align: -35%;
102
+ }
103
+ img[src=""],img:not([src]){
104
+ opacity: 0;
105
+ border:none;
106
+ visibility: hidden;
107
+ max-width: none;
108
+ }
109
+ /* .repair-mute-class {
110
+ &::before {
111
+ .tab-befor-img("../assets/guanbishengyin.png")
112
+ }
113
+ }*/
114
+ .menu-hide {
115
+ display: none;
116
+ }
117
+ </style>