system-phone 3.0.49-4 → 3.0.49-41

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 (298) 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/images//346/211/223/345/215/241.png +0 -0
  109. package/src/assets//344/277/235/351/231/251/347/231/273/350/256/260.png +0 -0
  110. package/src/assets//345/210/240/351/231/244/347/205/247/347/211/207.png +0 -0
  111. package/src/assets//345/215/217/345/212/251/345/256/211/346/243/200.png +0 -0
  112. package/src/assets//345/215/241/350/241/250/346/212/204/350/241/250/345/276/205/345/212/236.png +0 -0
  113. package/src/assets//345/233/236/350/256/277.png +0 -0
  114. package/src/assets//345/234/260/345/235/200/345/217/230/346/233/264.png +0 -0
  115. package/src/assets//345/256/211/346/243/200/347/256/241/347/220/206/346/234/252/351/200/211/344/270/255.png +0 -0
  116. package/src/assets//345/256/211/346/243/200/347/256/241/347/220/206/351/200/211/344/270/255.png +0 -0
  117. package/src/assets//345/256/211/346/243/200/350/275/254/345/215/225/345/256/241/346/240/270.png +0 -0
  118. package/src/assets//346/212/204/350/241/250/351/207/215/344/274/240.png +0 -0
  119. package/src/assets//346/226/275/345/260/201.png +0 -0
  120. package/src/assets//346/226/275/345/260/201/347/256/241/347/220/206.png +0 -0
  121. package/src/assets//346/260/221/347/224/250/345/256/211/346/243/200.png +0 -0
  122. package/src/assets//347/205/247/347/211/207/345/210/240/351/231/244.png +0 -0
  123. package/src/assets//347/224/250/346/210/267/350/256/260/345/275/225.png +0 -0
  124. package/src/assets//347/273/264/344/277/256/345/234/250/347/272/277/346/237/245/350/257/242.png +0 -0
  125. package/src/assets//347/273/264/344/277/256/347/231/273/350/256/260.png +0 -0
  126. package/src/assets//351/200/232/346/260/224/346/211/223/345/216/213/347/225/231/345/272/225.png +0 -0
  127. package/src/assets//351/230/200/346/216/247/347/256/241/347/220/206.png +0 -0
  128. package/src/assets//351/235/236/346/260/221/347/224/250/345/256/211/346/243/200.png +0 -0
  129. package/src/assets//351/246/226/351/241/265/345/244/247/345/233/276.png +0 -0
  130. package/src/bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  131. package/src/bootstrap/less/.csscomb.json +304 -304
  132. package/src/bootstrap/less/.csslintrc +19 -19
  133. package/src/bootstrap/less/alerts.less +73 -73
  134. package/src/bootstrap/less/badges.less +66 -66
  135. package/src/bootstrap/less/bootstrap.less +56 -56
  136. package/src/bootstrap/less/breadcrumbs.less +26 -26
  137. package/src/bootstrap/less/button-groups.less +247 -247
  138. package/src/bootstrap/less/buttons.less +172 -172
  139. package/src/bootstrap/less/carousel.less +269 -269
  140. package/src/bootstrap/less/close.less +34 -34
  141. package/src/bootstrap/less/code.less +69 -69
  142. package/src/bootstrap/less/component-animations.less +33 -33
  143. package/src/bootstrap/less/dropdowns.less +216 -216
  144. package/src/bootstrap/less/forms.less +626 -626
  145. package/src/bootstrap/less/glyphicons.less +305 -305
  146. package/src/bootstrap/less/grid.less +84 -84
  147. package/src/bootstrap/less/input-groups.less +167 -167
  148. package/src/bootstrap/less/jumbotron.less +52 -52
  149. package/src/bootstrap/less/labels.less +64 -64
  150. package/src/bootstrap/less/list-group.less +141 -141
  151. package/src/bootstrap/less/media.less +66 -66
  152. package/src/bootstrap/less/mixins/alerts.less +14 -14
  153. package/src/bootstrap/less/mixins/background-variant.less +9 -9
  154. package/src/bootstrap/less/mixins/border-radius.less +18 -18
  155. package/src/bootstrap/less/mixins/buttons.less +69 -69
  156. package/src/bootstrap/less/mixins/center-block.less +7 -7
  157. package/src/bootstrap/less/mixins/clearfix.less +22 -22
  158. package/src/bootstrap/less/mixins/forms.less +90 -90
  159. package/src/bootstrap/less/mixins/gradients.less +59 -59
  160. package/src/bootstrap/less/mixins/grid-framework.less +92 -92
  161. package/src/bootstrap/less/mixins/grid.less +122 -122
  162. package/src/bootstrap/less/mixins/hide-text.less +21 -21
  163. package/src/bootstrap/less/mixins/image.less +33 -33
  164. package/src/bootstrap/less/mixins/labels.less +12 -12
  165. package/src/bootstrap/less/mixins/list-group.less +30 -30
  166. package/src/bootstrap/less/mixins/nav-divider.less +10 -10
  167. package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
  168. package/src/bootstrap/less/mixins/opacity.less +8 -8
  169. package/src/bootstrap/less/mixins/pagination.less +24 -24
  170. package/src/bootstrap/less/mixins/panels.less +24 -24
  171. package/src/bootstrap/less/mixins/progress-bar.less +10 -10
  172. package/src/bootstrap/less/mixins/reset-filter.less +8 -8
  173. package/src/bootstrap/less/mixins/reset-text.less +18 -18
  174. package/src/bootstrap/less/mixins/resize.less +6 -6
  175. package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
  176. package/src/bootstrap/less/mixins/size.less +10 -10
  177. package/src/bootstrap/less/mixins/tab-focus.less +9 -9
  178. package/src/bootstrap/less/mixins/table-row.less +44 -44
  179. package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
  180. package/src/bootstrap/less/mixins/text-overflow.less +8 -8
  181. package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
  182. package/src/bootstrap/less/mixins.less +40 -40
  183. package/src/bootstrap/less/modals.less +151 -151
  184. package/src/bootstrap/less/navbar.less +660 -660
  185. package/src/bootstrap/less/navs.less +286 -286
  186. package/src/bootstrap/less/normalize.less +424 -424
  187. package/src/bootstrap/less/pager.less +76 -76
  188. package/src/bootstrap/less/pagination.less +89 -89
  189. package/src/bootstrap/less/panels.less +275 -275
  190. package/src/bootstrap/less/popovers.less +131 -131
  191. package/src/bootstrap/less/print.less +101 -101
  192. package/src/bootstrap/less/progress-bars.less +87 -87
  193. package/src/bootstrap/less/responsive-embed.less +35 -35
  194. package/src/bootstrap/less/responsive-utilities.less +194 -194
  195. package/src/bootstrap/less/scaffolding.less +161 -161
  196. package/src/bootstrap/less/tables.less +262 -262
  197. package/src/bootstrap/less/theme.less +291 -291
  198. package/src/bootstrap/less/thumbnails.less +36 -36
  199. package/src/bootstrap/less/tooltip.less +102 -102
  200. package/src/bootstrap/less/type.less +303 -303
  201. package/src/bootstrap/less/utilities.less +55 -55
  202. package/src/bootstrap/less/variables.less +895 -895
  203. package/src/bootstrap/less/wells.less +29 -29
  204. package/src/components/AloneLoadParams.vue +26 -26
  205. package/src/components/AlreadyService.vue +193 -193
  206. package/src/components/AttendManage.vue +120 -1
  207. package/src/components/LoadAppdata.vue +38 -38
  208. package/src/components/LoginApp.vue +730 -724
  209. package/src/components/LoginAppNew.vue +587 -587
  210. package/src/components/ModifyPassWord.vue +216 -216
  211. package/src/components/NavBottom.vue +117 -117
  212. package/src/components/NavBottomV.vue +141 -141
  213. package/src/components/NavBottomVVV.vue +185 -185
  214. package/src/components/OnlineManage.vue +1 -0
  215. package/src/components/PhoneAllInfo.vue +68 -68
  216. package/src/components/PhoneChangemeterInfo.vue +116 -116
  217. package/src/components/PhoneImageInfo.vue +102 -0
  218. package/src/components/PhoneInfoTable.vue +39 -39
  219. package/src/components/PhoneMeterInfo.vue +132 -132
  220. package/src/components/PhoneRepairInfo.vue +146 -146
  221. package/src/components/PhoneSellInfo.vue +123 -123
  222. package/src/components/PhoneSellInfoLite.vue +112 -112
  223. package/src/components/PhoneUser.vue +202 -202
  224. package/src/components/PhoneUserDetil.vue +70 -70
  225. package/src/components/PhoneUserFind.vue +138 -138
  226. package/src/components/SystemSetUp.vue +10 -4
  227. package/src/components/TabBarPhone.vue +81 -81
  228. package/src/components/Test.vue +14 -14
  229. package/src/components/ToolsPage.vue +2 -0
  230. package/src/components/UploadManage.vue +194 -194
  231. package/src/components/gaomi/NavBottomV.vue +223 -223
  232. package/src/components/gaomi/NavBottomVVVV.vue +210 -210
  233. package/src/components/gaomi/Scroller.vue +63 -63
  234. package/src/components/gaomi/SystemSetUp.vue +186 -186
  235. package/src/components/gaomi/ToolsPage.vue +168 -168
  236. package/src/components/idea/feedBack.vue +150 -150
  237. package/src/components/idea/feedbackAdd.vue +366 -366
  238. package/src/components/info/ConfigInfo.vue +122 -122
  239. package/src/components/info/FindUserInfo.vue +157 -157
  240. package/src/components/info/InfoTable.vue +37 -37
  241. package/src/components/iot/InstructMessage.vue +313 -313
  242. package/src/components/iot/IotBaseInfo.vue +97 -97
  243. package/src/components/iot/IotMeterInfo.vue +77 -77
  244. package/src/components/iot/iotMonitoringMain.vue +501 -501
  245. package/src/components/online/ApplyOnline.vue +581 -581
  246. package/src/components/online/BJZhongRan/ApplyOnline.vue +600 -600
  247. package/src/components/screen/ChargeContentPage.vue +656 -656
  248. package/src/components/screen/ContentPage.vue +611 -611
  249. package/src/components/screen/GongdanContentPage.vue +149 -149
  250. package/src/components/screen/ListCountItem.vue +93 -93
  251. package/src/components/screen/ModuleTitle.vue +48 -48
  252. package/src/components/screen/SafeOrderContentPage.vue +440 -440
  253. package/src/components/screen/SecurityCheckItem.vue +50 -50
  254. package/src/components/screen/TotalItem.vue +76 -76
  255. package/src/components/screen/TotalUserNumber.vue +77 -77
  256. package/src/components/screen/WorkOrderItem.vue +51 -51
  257. package/src/components/screen/WorkOrderRightDownItem.vue +103 -103
  258. package/src/components/screen/WorkOrderRightItem.vue +115 -115
  259. package/src/components/userinfo/paymentQuery.vue +189 -189
  260. package/src/components/userinfo/queryFile.vue +190 -190
  261. package/src/components/wasm.vue +18 -18
  262. package/src/expandcssAndroid.less +521 -521
  263. package/src/filiale/yulinyuchuan/AlreadyService.vue +194 -0
  264. package/src/filiale/yulinyuchuan/AttendManage.vue +537 -0
  265. package/src/filiale/yulinyuchuan/LoginApp.vue +736 -0
  266. package/src/filiale/yulinyuchuan/OnlineManage.vue +256 -0
  267. package/src/filiale/yulinyuchuan/SystemSetUp.vue +332 -0
  268. package/src/filiale/yulinyuchuan/UploadManage.vue +195 -0
  269. package/src/filiale/yulinyuchuan/systemphonegrid.js +9 -0
  270. package/src/index.js +9 -9
  271. package/src/main.js +38 -38
  272. package/src/plugins/GetStringData.js +18 -18
  273. package/src/plugins/LoadParams.js +24 -24
  274. package/src/plugins/const.js +404 -404
  275. package/src/plugins/vue-py.js +37 -37
  276. package/src/services/ConfigService.js +24 -24
  277. package/src/stores/AppData.js +65 -63
  278. package/src/systemphone-gaomi.js +105 -105
  279. package/src/systemphone.js +58 -58
  280. package/src/systemphonegrid.js +11 -40
  281. package/src/util/LdapHelper.js +75 -75
  282. package/static/app.json +4 -4
  283. package/static/const.js +404 -404
  284. package/static/globals.txt +74 -74
  285. package/static/layui/font/iconfont.svg +554 -554
  286. package/static/vue-py.js +37 -37
  287. package/static/wasm_exec.js +465 -465
  288. package/test/unit/.eslintrc +5 -5
  289. package/test/unit/TestUtil.js +35 -35
  290. package/test/unit/context.html +20 -20
  291. package/test/unit/index.js +13 -13
  292. package/test/unit/init.js +13 -13
  293. package/test/unit/karma.conf.js +50 -50
  294. package/test/unit/specs/App.spec.js +17 -17
  295. package/test/unit/specs/Test.spec.js +28 -28
  296. package/test/unit/specs/components/LoginApp.spec.js +21 -21
  297. package/test/unit/specs/sevices/ConfigService.spec.js +23 -23
  298. package/test/unit/specs/sevices/GetDBTest.spec.js +28 -28
@@ -1,501 +1,501 @@
1
- <template>
2
- <div class="auto" style="background: #f8f8f8;">
3
- <div partial class="bg-white ">
4
- <div class="row app-row " style="margin-top: 10px">
5
- <div class="col-xs-4">
6
- <img src="../../assets/表号.png" style="width: 20px;margin-bottom: 5px" alt="">
7
- <label class="font ">表号:</label>
8
- </div>
9
- <div class="col-xs-8" >
10
- <input class="search_input input-font" placeholder="请输入您要查询的表号" v-model="f_meternumber" />
11
- </div>
12
- </div>
13
- <div class="row app-row " style="margin-top: 10px">
14
- <div class="col-xs-4">
15
- <img src="../../assets/用户编号.png" style="width: 20px;margin-bottom: 5px" alt="">
16
- <label class="font ">用户编号:</label>
17
- </div>
18
- <div class="col-xs-8" >
19
- <input class="search_input input-font" placeholder="请输入用户编号" v-model="f_userinfo_code" />
20
- </div>
21
- </div>
22
- <div class="row text-center" style="padding-top: 10px;padding-bottom:10px;text-align: center">
23
- <button type="button" class="btn btn-font" style="width: 25%;
24
- margin-right: 3%; background-color: #499edf;color:#FFFFFF;border-radius: 10px ;" @click="query(querytitle)">查询</button>
25
- <button type="button" class="btn btn-font btn-color1" style="width: 25%;margin-right: 3%" @click="empty">清空</button>
26
- <button type="button" class="btn btn-font btn-color1" style="width: 25%;margin-right: 3%" @click="Scanningtable">扫表号</button>
27
- </div>
28
- </div>
29
- <div class="meterinfo auto bg-white">
30
- <iot-meter-info :row="row"></iot-meter-info>
31
- </div>
32
- <div class="">
33
- <div class="row bg-white" style="padding: 10px;margin-bottom: 5px">
34
- <div class="col-sm-12 " >
35
- <img src="../../assets/caozuo.png" style="width: 20px;margin-bottom: 5px" alt="">
36
- <label class="font ">操作</label>
37
- <button type="button" class="btn btn-font btn-color" style="width: 20%" @click="OpenValve('1')">开阀</button>
38
- <button type="button" class="btn btn-font btn-color" style="width: 20%" @click="valveShutoff('0')">关阀</button>
39
- <button type="button" class="btn btn-font btn-color" style="width: 25%" @click="againOpening">重新开户</button>
40
- </div>
41
- </div>
42
-
43
- </div>
44
- <div class="bg-white" >
45
- <!--<div class="row" style="padding-left: 10px">-->
46
- <!--<label class="font_normal_body">信息查询</label>-->
47
- <!--</div>-->
48
- <div class="row auto flex-row" style="justify-content: space-between">
49
- <div @click="setquery('基础')" >
50
- <label :class="querytitle == '基础' ? 'text-center div_ul2' : 'text-center div_ul'">基础</label>
51
- </div>
52
- <div @click="setquery('指令查询')" >
53
- <label :class="querytitle == '指令查询' ? 'text-center div_ul2' : 'text-center div_ul'">指令</label>
54
- </div>
55
- <div @click="setquery('抄表查询')" >
56
- <label :class="querytitle == '抄表查询' ? 'text-center div_ul2' : 'text-center div_ul'">抄表</label>
57
- </div>
58
- <div @click="setquery('售气查询')" >
59
- <label :class="querytitle == '售气查询' ? 'text-center div_ul2' : 'text-center div_ul'">售气</label>
60
- </div>
61
- <div @click="setquery('上报查询')" >
62
- <label :class="querytitle == '上报查询' ? ' text-center div_ul2' : 'text-center div_ul'">上报</label>
63
- </div>
64
- </div>
65
- <div v-if="model.rows.length == 0 && querytitle !== '基础'" style="margin-top: 20px">
66
- <label class="font_normal_body"><b>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;暂无记录...&nbsp;&nbsp;&nbsp;</b></label>
67
- </div>
68
- <div class="iotbaseinfo " v-if="querytitle == '基础'">
69
- <iot-base-info :row="row"></iot-base-info>
70
- </div>
71
- <list :model="model" partial='list' style="padding-bottom: 10px" v-if="querytitle == '指令查询'">
72
- <div partial>
73
- <div class="auto app-text" style="margin-top: 5px; " @click="$parent.$parent.goto(row)">
74
- <div class="panel" style="padding: 10px 10px 5px 10px;">
75
- <div class="panel-body panel-self " style="border: 2px solid #499EDF; border-radius: 10px">
76
- <div class="col-xs-12">
77
- <p class="panel-title col-xs-5 text-left font" style="float: left"><b>指令类型:</b></p>
78
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_instruct_type }}</p>
79
- </div>
80
- <div class="col-xs-12">
81
- <p class="panel-title col-xs-5 text-left font" style="float: left"><b>指令标题:</b></p>
82
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_instruct_title }}</p>
83
- </div>
84
- <div class="col-xs-12">
85
- <p class="panel-title col-xs-5 text-left font"><b>执行状态:</b></p>
86
- <p class="panel-title col-xs-7 text-left input-font">{{ row.f_instruct_state }}
87
- </p>
88
- </div>
89
- <div class="col-xs-12">
90
- <p class="panel-title col-xs-5 text-left font"><b>执行结果:</b></p>
91
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_receive_state }}
92
- </p>
93
- </div>
94
- <div class="col-xs-12">
95
- <p class="panel-title col-xs-5 text-left font"><b>生成人员:</b></p>
96
- <p class="panel-title col-xs-7 text-left input-font">{{ row.f_inputtor }}</p>
97
- </div>
98
- <div class="col-xs-12">
99
- <p class="panel-title col-xs-5 text-left font"><b>生成时间:</b></p>
100
- <p class="panel-title col-xs-7 text-left input-font">{{ row.f_instruct_date }}</p>
101
- </div>
102
- </div>
103
- </div>
104
- </div>
105
- </div>
106
- </list>
107
- <list :model="model" partial='list' style="padding-bottom: 10px" v-if="querytitle == '抄表查询'">
108
- <div partial>
109
- <div class="auto app-text" style="margin-top: 5px;">
110
- <div class="panel" style="padding: 10px 10px 5px 10px;">
111
- <div class="panel-body panel-self" style="border: 2px solid #499EDF; border-radius: 10px">
112
- <div class="col-xs-12">
113
- <p class="panel-title col-xs-5 text-left font" style="float: left"><b>本次抄表底数:</b></p>
114
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_tablebase }}</p>
115
- </div>
116
- <div class="col-xs-12">
117
- <p class="panel-title col-xs-5 text-left font" style="float: left"><b>上次抄表底数:</b></p>
118
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_last_tablebase }}</p>
119
- </div>
120
- <div class="col-xs-12">
121
- <p class="panel-title col-xs-5 text-left font"><b>操作员:</b></p>
122
- <p class="panel-title col-xs-7 text-left input-font">{{ row.f_inputtor }}
123
- </p>
124
- </div>
125
- <div class="col-xs-12">
126
- <p class="panel-title col-xs-5 text-left font"><b>抄表日期:</b></p>
127
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_input_date }}
128
- </p>
129
- </div>
130
- </div>
131
- </div>
132
- </div>
133
- </div>
134
- </list>
135
- <list :model="model" partial='list' style="padding-bottom: 10px" v-if="querytitle == '售气查询'">
136
- <div partial>
137
- <div class="auto app-text" style="margin-top: 5px;">
138
- <div class="panel" style="padding: 10px 10px 5px 10px;">
139
- <div class="panel-body panel-self" style="border: 2px solid #499EDF; border-radius: 10px">
140
- <div class="col-xs-12">
141
- <p class="panel-title col-xs-5 text-left font" style="float: left"><b>预购气量:</b></p>
142
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_pregas }}</p>
143
- </div>
144
- <div class="col-xs-12">
145
- <p class="panel-title col-xs-5 text-left font" style="float: left"><b>预购金额:</b></p>
146
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_preamount }}</p>
147
- </div>
148
- <div class="col-xs-12">
149
- <p class="panel-title col-xs-5 text-left font"><b>累购气量:</b></p>
150
- <p class="panel-title col-xs-7 text-left input-font">{{ row.f_total_gas }}
151
- </p>
152
- </div>
153
- <div class="col-xs-12">
154
- <p class="panel-title col-xs-5 text-left font"><b>累购金额:</b></p>
155
- <p class="panel-title col-xs-7 text-left input-font">{{ row.f_total_fee }}
156
- </p>
157
- </div>
158
- <div class="col-xs-12">
159
- <p class="panel-title col-xs-5 text-left font"><b>缴费日期:</b></p>
160
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_operate_date }}
161
- </p>
162
- </div>
163
- </div>
164
- </div>
165
- </div>
166
- </div>
167
- </list>
168
- <list :model="model" partial='list' style="padding-bottom: 10px" v-if="querytitle == '上报查询'">
169
- <div partial>
170
- <div class="auto app-text" style="margin-top: 5px;">
171
- <div class="panel" style="padding: 10px 10px 5px 10px;">
172
- <div class="panel-body panel-self" style="border: 2px solid #499EDF; border-radius: 10px">
173
- <div class="col-xs-12">
174
- <p class="panel-title col-xs-5 text-left font" style="float: left"><b>上报类型:</b></p>
175
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_upload_type }}</p>
176
- </div>
177
- <div class="col-xs-12">
178
- <p class="panel-title col-xs-5 text-left font" style="float: left"><b>阀门状态:</b></p>
179
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_valvestate }}</p>
180
- </div>
181
- <div class="col-xs-12">
182
- <p class="panel-title col-xs-5 text-left font"><b>表内单价:</b></p>
183
- <p class="panel-title col-xs-7 text-left input-font">{{ row.f_price }}
184
- </p>
185
- </div>
186
- <div class="col-xs-12">
187
- <p class="panel-title col-xs-5 text-left font"><b>抄表底数:</b></p>
188
- <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_tablebase }}
189
- </p>
190
- </div>
191
- <div class="col-xs-12">
192
- <p class="panel-title col-xs-5 text-left font"><b>上报日期:</b></p>
193
- <p class="panel-title col-xs-7 text-left input-font">{{ row.f_hand_date }}</p>
194
- </div>
195
- <div class="col-xs-12">
196
- <p class="panel-title col-xs-5 text-left font"><b>系统接收日期:</b></p>
197
- <p class="panel-title col-xs-7 text-left input-font">{{ row.f_insert_date }}</p>
198
- </div>
199
- </div>
200
- </div>
201
- </div>
202
- </div>
203
- </list>
204
- </div>
205
-
206
- </div>
207
-
208
- </template>
209
-
210
- <script>
211
- import Vue from 'vue'
212
- import {HttpResetClass} from 'vue-client'
213
- import IotMeterInfo from "./IotMeterInfo";
214
- export default {
215
- components: {IotMeterInfo},
216
- title: '物联网监控',
217
- data () {
218
- return {
219
- f_meternumber: '',
220
- f_userinfo_code:'',
221
- querytitle: '基础',
222
- row:{},
223
- model: {
224
- rows: [{}]
225
- }
226
-
227
- }
228
- },
229
- ready () {
230
- console.log('物联网监控')
231
- },
232
- methods: {
233
- goto(row){
234
- console.log(row)
235
- let _this=this
236
- var pardate = {
237
- _this:_this,
238
- title:'指令信息',
239
- safe:false
240
- }
241
- this.$dispatch('gotoson',pardate)
242
- this.$goto('instruct-message',{row:row}, 'self')
243
- },
244
- empty () {
245
- console.log('清空')
246
- this.f_meternumber = ''
247
- this.f_userinfo_code = ''
248
- },
249
- // 查询表别名
250
- queryAlias() {
251
- console.log('查询表别名'+JSON.stringify(this.f_meternumber))
252
- let data = {
253
- items: ' f_alias , f_user_id ',
254
- tablename: ' t_userfiles uf LEFT JOIN t_gasbrand gb ON uf.f_gasbrand_id = gb.id ',
255
- orderitem: 'gb.id desc',
256
- condition: ` f_meternumber = '${this.f_meternumber}'`
257
- }
258
- // console.log('查询条件'+ JSON.stringify(data))
259
- // this.$resetpost(`/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
260
- this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
261
- // console.log('查询返回'+JSON.stringify(row))
262
- return row.data[0]
263
- }).catch((e) => {
264
- this.$showMessage('表别名获取失败!')
265
- // console.log('错误信息+++++++'+JSON.stringify(e))
266
- })
267
-
268
- },
269
- async OpenValve(type) {
270
- // console.log('开阀')
271
- if (!this.f_meternumber) {
272
- this.$showMessage('请输入/扫描用户表号!')
273
- return
274
- }
275
- this.$showMessage(`您确认要生成开阀指令吗?`, ['confirm', 'cancel']).then(async (res) => {
276
- if (res === 'confirm') {
277
- // let alias = await this.queryAlias()
278
- let data = {
279
- userId: this.row.f_user_id,
280
- content: {isOpen: type},
281
- alias: this.row.f_alias,
282
- inputtor: Vue.user.name,
283
- moduleName: this.row.f_alias
284
- }
285
- // console.log('请求参数'+JSON.stringify(data))
286
- // http://ip:port/webmeter/rs/logic/syncSaveValveControlTemplate
287
- let http = new HttpResetClass()
288
- http.load('POST',`${this.$androidUtil.getProxyUrl()}/webmeter/rs/logic/syncSaveValveControlTemplate`, {data: data}).then((row) => {
289
- // http.load('POST',`${this.$androidUtil.getProxyUrl()}/SJwebmeter`, {data: data}).then((row) => {
290
- // console.log('执行结果'+JSON.stringify(row))
291
- this.$showMessage('发送成功!')
292
- }).catch((e) => {
293
- this.$showMessage('发送失败!')
294
- // console.log('错误信息+++++++'+JSON.stringify(e))
295
- })
296
- }
297
- })
298
- },
299
- valveShutoff (type) {
300
- // console.log('关阀')
301
- if (!this.f_meternumber) {
302
- this.$showMessage('请输入/扫描用户表号!')
303
- return
304
- }
305
- this.$showMessage(`您确认要生成关阀指令吗?`, ['confirm', 'cancel']).then(async (res) => {
306
- if (res === 'confirm') {
307
- // let alias = await this.queryAlias()
308
- let data = {
309
- userId: this.row.f_user_id,
310
- content: {isOpen: type},
311
- alias: this.row.f_alias,
312
- inputtor: Vue.user.name,
313
- moduleName: this.row.f_alias
314
- }
315
- // console.log('请求参数'+JSON.stringify(data))
316
- // http://ip:port/webmeter/rs/logic/syncSaveValveControlTemplate
317
- let http = new HttpResetClass()
318
- http.load('POST',`${this.$androidUtil.getProxyUrl()}/webmeter/rs/logic/syncSaveValveControlTemplate`, {data: data}).then((row) => {
319
- // http.load('POST',`${this.$androidUtil.getProxyUrl()}/SJwebmeter`, {data: data}).then((row) => {
320
- // console.log('执行结果'+JSON.stringify(row))
321
- this.$showMessage('发送成功!')
322
- }).catch((e) => {
323
- this.$showMessage('发送失败!')
324
- // console.log('错误信息+++++++'+JSON.stringify(e))
325
- })
326
- }
327
- })
328
- },
329
- againOpening () {
330
- console.log('重新开户')
331
- if (!this.f_meternumber) {
332
- this.$showMessage('请输入/扫描用户表号!')
333
- return
334
- }
335
- this.$showMessage(`您确认要重新开户吗?`, ['confirm', 'cancel']).then(async (res) => {
336
- if (res === 'confirm') {
337
- let http = new HttpResetClass()
338
- let condition = `f_meternumber = '${this.f_meternumber}'`
339
- console.log('修改条件===' + JSON.stringify(condition))
340
- http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/logic/againOpenAccountnvm `, {data: {condition: condition}},{resolveMsg: null, rejectMsg: null}).then((row) => {
341
- // console.log('修改返回' + JSON.stringify(row))
342
- this.$showMessage('操作成功!将会在一段时间内重新生成开户指令!')
343
- }).catch((e) => {
344
- this.$showMessage('操作失败!请稍后重试!')
345
- console.log('错误信息+++++++'+JSON.stringify(e))
346
- })
347
- }
348
- })
349
-
350
-
351
- },
352
- query (title) {
353
- console.log('查询'+ JSON.stringify(title))
354
- if (!this.f_meternumber&&!this.f_userinfo_code) {
355
- this.$showMessage('请输入/扫描用户表号或输入用户编号!')
356
- return
357
- }
358
- let condition = this.f_meternumber!==''? `f_meternumber = '${this.f_meternumber}'`:`f_userinfo_code = '${this.f_userinfo_code}'`
359
- let data = {
360
- items: '*',
361
- tablename: 't_instruct',
362
- orderitem: 'f_instruct_date desc',
363
- f_meternumber: this.meternumber
364
- }
365
- if(title==='基础'){
366
- // let condition = `f_meternumber = '${this.f_meternumber}'`
367
- this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/getUserByMeter`, {data: {condition:condition}}).then((row) => {
368
- if(row.data.length===0)
369
- this.$showMessage('未查询到用户信息')
370
- // console.log('查询返回'+JSON.stringify(row))
371
- // this.f_meternumber = row.data[0].f_meternumber
372
- // this.f_userinfo_code = row.data[0].f_userinfo_code?row.data[0].f_userinfo_code:this.f_userinfo_code
373
- this.row = row.data[0]
374
- }).catch((e) => {
375
- console.log('错误信息+++++++'+JSON.stringify(e))
376
- })
377
- } else {
378
- if (title == '指令查询') {
379
- data = {
380
- items: '*',
381
- tablename: 't_instruct',
382
- orderitem: 'f_instruct_date desc',
383
- condition: condition
384
- }
385
- }else if (title == '抄表查询') {
386
- data = {
387
- items: '*',
388
- tablename: 't_handplan',
389
- orderitem: 'f_input_date desc',
390
- condition: condition
391
- }
392
- }else if (title == '售气查询') {
393
- if (!this.f_meternumber) {
394
- this.$showMessage('请输入/扫描用户表号!')
395
- return
396
- }
397
- data = {
398
- items: '*',
399
- tablename: 't_sellinggas',
400
- orderitem: 'f_operate_date desc',
401
- condition: condition
402
- }
403
- }else if (title == '上报查询') {
404
- if (!this.f_meternumber) {
405
- this.$showMessage('请输入/扫描用户表号!')
406
- return
407
- }
408
- data = {
409
- items: '*',
410
- tablename: 't_meteread',
411
- orderitem: 'f_hand_date desc',
412
- condition: condition
413
- }
414
- }
415
- console.log('查询条件'+ JSON.stringify(data))
416
- // this.$resetpost(`/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
417
- this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
418
- console.log('查询返回'+JSON.stringify(row))
419
- this.model.rows = row.data
420
- // this.f_meternumber = row.data[0].f_meternumber
421
- // this.f_userinfo_code = row.data[0].f_userinfo_code?row.data[0].f_userinfo_code:this.f_userinfo_code
422
- }).catch((e) => {
423
- console.log('正在维护!')
424
- console.log('错误信息+++++++'+JSON.stringify(e))
425
- })
426
- }
427
- },
428
- setquery (msg) {
429
- console.log(msg)
430
- this.querytitle = msg
431
- // 查询
432
- this.query(msg)
433
- },
434
- Scanningtable() {
435
- console.log('扫表号6666666')
436
- HostApp.__this__ = this
437
- HostApp.scanCode({callback:"javascript:HostApp.__this__.getCode();"})
438
- },
439
- getCode () {
440
- var datapa = HostApp.getCode().data
441
- console.log(`扫码返回值${datapa}`)
442
- this.f_meternumber = datapa
443
- this.$showMessage(`扫码返回值为:${datapa}`)
444
- },
445
-
446
- }
447
- }
448
- </script>
449
-
450
- <style scoped>
451
- .btn-color{
452
- background-color: #499edf;
453
- border-radius: 10px ;
454
- border: 1px solid #499EDF;
455
- font:600 16px PingFang-SC-Bold;
456
- color: #FFFFFF;
457
-
458
- }
459
- .btn-color1{
460
- background-color: #FFFFFF;
461
- border-radius: 10px ;
462
- border: 1px solid #499EDF;
463
- font:600 16px PingFang-SC-Bold;
464
- color: #499EDF;
465
- }
466
- .app-row {
467
- background-color: white;
468
- padding: 10px 10px 0 10px;
469
- border-bottom: 1px solid rgba(235, 235, 235, 0.5);
470
- }
471
- .search_input {
472
- border: 0;
473
- outline: none;
474
- }
475
- .font{
476
- font: 15px PingFang-SC-Medium;
477
- color: #666666;
478
- }
479
- .input-font{
480
- font: 15px PingFang-SC-Medium;
481
- color: #333333;
482
- }
483
- .div_ul {
484
- height: 36px;
485
- color:rgb(153,153,153);
486
- /*border-right: 1px solid royalblue;*/
487
- line-height: 36px;
488
- }
489
- .div_ul2 {
490
- height: 36px;
491
- /*border-right: 1px solid royalblue;*/
492
- line-height: 36px;
493
- color:#6eb0e3;
494
- border-bottom: 2px solid #6eb0e3;
495
- }
496
- .meterinfo{
497
- padding: 10px;
498
- margin-top: 5px;
499
- margin-bottom: 5px;
500
- }
501
- </style>
1
+ <template>
2
+ <div class="auto" style="background: #f8f8f8;">
3
+ <div partial class="bg-white ">
4
+ <div class="row app-row " style="margin-top: 10px">
5
+ <div class="col-xs-4">
6
+ <img src="../../assets/表号.png" style="width: 20px;margin-bottom: 5px" alt="">
7
+ <label class="font ">表号:</label>
8
+ </div>
9
+ <div class="col-xs-8" >
10
+ <input class="search_input input-font" placeholder="请输入您要查询的表号" v-model="f_meternumber" />
11
+ </div>
12
+ </div>
13
+ <div class="row app-row " style="margin-top: 10px">
14
+ <div class="col-xs-4">
15
+ <img src="../../assets/用户编号.png" style="width: 20px;margin-bottom: 5px" alt="">
16
+ <label class="font ">用户编号:</label>
17
+ </div>
18
+ <div class="col-xs-8" >
19
+ <input class="search_input input-font" placeholder="请输入用户编号" v-model="f_userinfo_code" />
20
+ </div>
21
+ </div>
22
+ <div class="row text-center" style="padding-top: 10px;padding-bottom:10px;text-align: center">
23
+ <button type="button" class="btn btn-font" style="width: 25%;
24
+ margin-right: 3%; background-color: #499edf;color:#FFFFFF;border-radius: 10px ;" @click="query(querytitle)">查询</button>
25
+ <button type="button" class="btn btn-font btn-color1" style="width: 25%;margin-right: 3%" @click="empty">清空</button>
26
+ <button type="button" class="btn btn-font btn-color1" style="width: 25%;margin-right: 3%" @click="Scanningtable">扫表号</button>
27
+ </div>
28
+ </div>
29
+ <div class="meterinfo auto bg-white">
30
+ <iot-meter-info :row="row"></iot-meter-info>
31
+ </div>
32
+ <div class="">
33
+ <div class="row bg-white" style="padding: 10px;margin-bottom: 5px">
34
+ <div class="col-sm-12 " >
35
+ <img src="../../assets/caozuo.png" style="width: 20px;margin-bottom: 5px" alt="">
36
+ <label class="font ">操作</label>
37
+ <button type="button" class="btn btn-font btn-color" style="width: 20%" @click="OpenValve('1')">开阀</button>
38
+ <button type="button" class="btn btn-font btn-color" style="width: 20%" @click="valveShutoff('0')">关阀</button>
39
+ <button type="button" class="btn btn-font btn-color" style="width: 25%" @click="againOpening">重新开户</button>
40
+ </div>
41
+ </div>
42
+
43
+ </div>
44
+ <div class="bg-white" >
45
+ <!--<div class="row" style="padding-left: 10px">-->
46
+ <!--<label class="font_normal_body">信息查询</label>-->
47
+ <!--</div>-->
48
+ <div class="row auto flex-row" style="justify-content: space-between">
49
+ <div @click="setquery('基础')" >
50
+ <label :class="querytitle == '基础' ? 'text-center div_ul2' : 'text-center div_ul'">基础</label>
51
+ </div>
52
+ <div @click="setquery('指令查询')" >
53
+ <label :class="querytitle == '指令查询' ? 'text-center div_ul2' : 'text-center div_ul'">指令</label>
54
+ </div>
55
+ <div @click="setquery('抄表查询')" >
56
+ <label :class="querytitle == '抄表查询' ? 'text-center div_ul2' : 'text-center div_ul'">抄表</label>
57
+ </div>
58
+ <div @click="setquery('售气查询')" >
59
+ <label :class="querytitle == '售气查询' ? 'text-center div_ul2' : 'text-center div_ul'">售气</label>
60
+ </div>
61
+ <div @click="setquery('上报查询')" >
62
+ <label :class="querytitle == '上报查询' ? ' text-center div_ul2' : 'text-center div_ul'">上报</label>
63
+ </div>
64
+ </div>
65
+ <div v-if="model.rows.length == 0 && querytitle !== '基础'" style="margin-top: 20px">
66
+ <label class="font_normal_body"><b>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;暂无记录...&nbsp;&nbsp;&nbsp;</b></label>
67
+ </div>
68
+ <div class="iotbaseinfo " v-if="querytitle == '基础'">
69
+ <iot-base-info :row="row"></iot-base-info>
70
+ </div>
71
+ <list :model="model" partial='list' style="padding-bottom: 10px" v-if="querytitle == '指令查询'">
72
+ <div partial>
73
+ <div class="auto app-text" style="margin-top: 5px; " @click="$parent.$parent.goto(row)">
74
+ <div class="panel" style="padding: 10px 10px 5px 10px;">
75
+ <div class="panel-body panel-self " style="border: 2px solid #499EDF; border-radius: 10px">
76
+ <div class="col-xs-12">
77
+ <p class="panel-title col-xs-5 text-left font" style="float: left"><b>指令类型:</b></p>
78
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_instruct_type }}</p>
79
+ </div>
80
+ <div class="col-xs-12">
81
+ <p class="panel-title col-xs-5 text-left font" style="float: left"><b>指令标题:</b></p>
82
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_instruct_title }}</p>
83
+ </div>
84
+ <div class="col-xs-12">
85
+ <p class="panel-title col-xs-5 text-left font"><b>执行状态:</b></p>
86
+ <p class="panel-title col-xs-7 text-left input-font">{{ row.f_instruct_state }}
87
+ </p>
88
+ </div>
89
+ <div class="col-xs-12">
90
+ <p class="panel-title col-xs-5 text-left font"><b>执行结果:</b></p>
91
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_receive_state }}
92
+ </p>
93
+ </div>
94
+ <div class="col-xs-12">
95
+ <p class="panel-title col-xs-5 text-left font"><b>生成人员:</b></p>
96
+ <p class="panel-title col-xs-7 text-left input-font">{{ row.f_inputtor }}</p>
97
+ </div>
98
+ <div class="col-xs-12">
99
+ <p class="panel-title col-xs-5 text-left font"><b>生成时间:</b></p>
100
+ <p class="panel-title col-xs-7 text-left input-font">{{ row.f_instruct_date }}</p>
101
+ </div>
102
+ </div>
103
+ </div>
104
+ </div>
105
+ </div>
106
+ </list>
107
+ <list :model="model" partial='list' style="padding-bottom: 10px" v-if="querytitle == '抄表查询'">
108
+ <div partial>
109
+ <div class="auto app-text" style="margin-top: 5px;">
110
+ <div class="panel" style="padding: 10px 10px 5px 10px;">
111
+ <div class="panel-body panel-self" style="border: 2px solid #499EDF; border-radius: 10px">
112
+ <div class="col-xs-12">
113
+ <p class="panel-title col-xs-5 text-left font" style="float: left"><b>本次抄表底数:</b></p>
114
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_tablebase }}</p>
115
+ </div>
116
+ <div class="col-xs-12">
117
+ <p class="panel-title col-xs-5 text-left font" style="float: left"><b>上次抄表底数:</b></p>
118
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_last_tablebase }}</p>
119
+ </div>
120
+ <div class="col-xs-12">
121
+ <p class="panel-title col-xs-5 text-left font"><b>操作员:</b></p>
122
+ <p class="panel-title col-xs-7 text-left input-font">{{ row.f_inputtor }}
123
+ </p>
124
+ </div>
125
+ <div class="col-xs-12">
126
+ <p class="panel-title col-xs-5 text-left font"><b>抄表日期:</b></p>
127
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_input_date }}
128
+ </p>
129
+ </div>
130
+ </div>
131
+ </div>
132
+ </div>
133
+ </div>
134
+ </list>
135
+ <list :model="model" partial='list' style="padding-bottom: 10px" v-if="querytitle == '售气查询'">
136
+ <div partial>
137
+ <div class="auto app-text" style="margin-top: 5px;">
138
+ <div class="panel" style="padding: 10px 10px 5px 10px;">
139
+ <div class="panel-body panel-self" style="border: 2px solid #499EDF; border-radius: 10px">
140
+ <div class="col-xs-12">
141
+ <p class="panel-title col-xs-5 text-left font" style="float: left"><b>预购气量:</b></p>
142
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_pregas }}</p>
143
+ </div>
144
+ <div class="col-xs-12">
145
+ <p class="panel-title col-xs-5 text-left font" style="float: left"><b>预购金额:</b></p>
146
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_preamount }}</p>
147
+ </div>
148
+ <div class="col-xs-12">
149
+ <p class="panel-title col-xs-5 text-left font"><b>累购气量:</b></p>
150
+ <p class="panel-title col-xs-7 text-left input-font">{{ row.f_total_gas }}
151
+ </p>
152
+ </div>
153
+ <div class="col-xs-12">
154
+ <p class="panel-title col-xs-5 text-left font"><b>累购金额:</b></p>
155
+ <p class="panel-title col-xs-7 text-left input-font">{{ row.f_total_fee }}
156
+ </p>
157
+ </div>
158
+ <div class="col-xs-12">
159
+ <p class="panel-title col-xs-5 text-left font"><b>缴费日期:</b></p>
160
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_operate_date }}
161
+ </p>
162
+ </div>
163
+ </div>
164
+ </div>
165
+ </div>
166
+ </div>
167
+ </list>
168
+ <list :model="model" partial='list' style="padding-bottom: 10px" v-if="querytitle == '上报查询'">
169
+ <div partial>
170
+ <div class="auto app-text" style="margin-top: 5px;">
171
+ <div class="panel" style="padding: 10px 10px 5px 10px;">
172
+ <div class="panel-body panel-self" style="border: 2px solid #499EDF; border-radius: 10px">
173
+ <div class="col-xs-12">
174
+ <p class="panel-title col-xs-5 text-left font" style="float: left"><b>上报类型:</b></p>
175
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_upload_type }}</p>
176
+ </div>
177
+ <div class="col-xs-12">
178
+ <p class="panel-title col-xs-5 text-left font" style="float: left"><b>阀门状态:</b></p>
179
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_valvestate }}</p>
180
+ </div>
181
+ <div class="col-xs-12">
182
+ <p class="panel-title col-xs-5 text-left font"><b>表内单价:</b></p>
183
+ <p class="panel-title col-xs-7 text-left input-font">{{ row.f_price }}
184
+ </p>
185
+ </div>
186
+ <div class="col-xs-12">
187
+ <p class="panel-title col-xs-5 text-left font"><b>抄表底数:</b></p>
188
+ <p class="panel-title col-xs-7 text-left input-font" >{{ row.f_tablebase }}
189
+ </p>
190
+ </div>
191
+ <div class="col-xs-12">
192
+ <p class="panel-title col-xs-5 text-left font"><b>上报日期:</b></p>
193
+ <p class="panel-title col-xs-7 text-left input-font">{{ row.f_hand_date }}</p>
194
+ </div>
195
+ <div class="col-xs-12">
196
+ <p class="panel-title col-xs-5 text-left font"><b>系统接收日期:</b></p>
197
+ <p class="panel-title col-xs-7 text-left input-font">{{ row.f_insert_date }}</p>
198
+ </div>
199
+ </div>
200
+ </div>
201
+ </div>
202
+ </div>
203
+ </list>
204
+ </div>
205
+
206
+ </div>
207
+
208
+ </template>
209
+
210
+ <script>
211
+ import Vue from 'vue'
212
+ import {HttpResetClass} from 'vue-client'
213
+ import IotMeterInfo from "./IotMeterInfo";
214
+ export default {
215
+ components: {IotMeterInfo},
216
+ title: '物联网监控',
217
+ data () {
218
+ return {
219
+ f_meternumber: '',
220
+ f_userinfo_code:'',
221
+ querytitle: '基础',
222
+ row:{},
223
+ model: {
224
+ rows: [{}]
225
+ }
226
+
227
+ }
228
+ },
229
+ ready () {
230
+ console.log('物联网监控')
231
+ },
232
+ methods: {
233
+ goto(row){
234
+ console.log(row)
235
+ let _this=this
236
+ var pardate = {
237
+ _this:_this,
238
+ title:'指令信息',
239
+ safe:false
240
+ }
241
+ this.$dispatch('gotoson',pardate)
242
+ this.$goto('instruct-message',{row:row}, 'self')
243
+ },
244
+ empty () {
245
+ console.log('清空')
246
+ this.f_meternumber = ''
247
+ this.f_userinfo_code = ''
248
+ },
249
+ // 查询表别名
250
+ queryAlias() {
251
+ console.log('查询表别名'+JSON.stringify(this.f_meternumber))
252
+ let data = {
253
+ items: ' f_alias , f_user_id ',
254
+ tablename: ' t_userfiles uf LEFT JOIN t_gasbrand gb ON uf.f_gasbrand_id = gb.id ',
255
+ orderitem: 'gb.id desc',
256
+ condition: ` f_meternumber = '${this.f_meternumber}'`
257
+ }
258
+ // console.log('查询条件'+ JSON.stringify(data))
259
+ // this.$resetpost(`/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
260
+ this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
261
+ // console.log('查询返回'+JSON.stringify(row))
262
+ return row.data[0]
263
+ }).catch((e) => {
264
+ this.$showMessage('表别名获取失败!')
265
+ // console.log('错误信息+++++++'+JSON.stringify(e))
266
+ })
267
+
268
+ },
269
+ async OpenValve(type) {
270
+ // console.log('开阀')
271
+ if (!this.f_meternumber) {
272
+ this.$showMessage('请输入/扫描用户表号!')
273
+ return
274
+ }
275
+ this.$showMessage(`您确认要生成开阀指令吗?`, ['confirm', 'cancel']).then(async (res) => {
276
+ if (res === 'confirm') {
277
+ // let alias = await this.queryAlias()
278
+ let data = {
279
+ userId: this.row.f_user_id,
280
+ content: {isOpen: type},
281
+ alias: this.row.f_alias,
282
+ inputtor: Vue.user.name,
283
+ moduleName: this.row.f_alias
284
+ }
285
+ // console.log('请求参数'+JSON.stringify(data))
286
+ // http://ip:port/webmeter/rs/logic/syncSaveValveControlTemplate
287
+ let http = new HttpResetClass()
288
+ http.load('POST',`${this.$androidUtil.getProxyUrl()}/webmeter/rs/logic/syncSaveValveControlTemplate`, {data: data}).then((row) => {
289
+ // http.load('POST',`${this.$androidUtil.getProxyUrl()}/SJwebmeter`, {data: data}).then((row) => {
290
+ // console.log('执行结果'+JSON.stringify(row))
291
+ this.$showMessage('发送成功!')
292
+ }).catch((e) => {
293
+ this.$showMessage('发送失败!')
294
+ // console.log('错误信息+++++++'+JSON.stringify(e))
295
+ })
296
+ }
297
+ })
298
+ },
299
+ valveShutoff (type) {
300
+ // console.log('关阀')
301
+ if (!this.f_meternumber) {
302
+ this.$showMessage('请输入/扫描用户表号!')
303
+ return
304
+ }
305
+ this.$showMessage(`您确认要生成关阀指令吗?`, ['confirm', 'cancel']).then(async (res) => {
306
+ if (res === 'confirm') {
307
+ // let alias = await this.queryAlias()
308
+ let data = {
309
+ userId: this.row.f_user_id,
310
+ content: {isOpen: type},
311
+ alias: this.row.f_alias,
312
+ inputtor: Vue.user.name,
313
+ moduleName: this.row.f_alias
314
+ }
315
+ // console.log('请求参数'+JSON.stringify(data))
316
+ // http://ip:port/webmeter/rs/logic/syncSaveValveControlTemplate
317
+ let http = new HttpResetClass()
318
+ http.load('POST',`${this.$androidUtil.getProxyUrl()}/webmeter/rs/logic/syncSaveValveControlTemplate`, {data: data}).then((row) => {
319
+ // http.load('POST',`${this.$androidUtil.getProxyUrl()}/SJwebmeter`, {data: data}).then((row) => {
320
+ // console.log('执行结果'+JSON.stringify(row))
321
+ this.$showMessage('发送成功!')
322
+ }).catch((e) => {
323
+ this.$showMessage('发送失败!')
324
+ // console.log('错误信息+++++++'+JSON.stringify(e))
325
+ })
326
+ }
327
+ })
328
+ },
329
+ againOpening () {
330
+ console.log('重新开户')
331
+ if (!this.f_meternumber) {
332
+ this.$showMessage('请输入/扫描用户表号!')
333
+ return
334
+ }
335
+ this.$showMessage(`您确认要重新开户吗?`, ['confirm', 'cancel']).then(async (res) => {
336
+ if (res === 'confirm') {
337
+ let http = new HttpResetClass()
338
+ let condition = `f_meternumber = '${this.f_meternumber}'`
339
+ console.log('修改条件===' + JSON.stringify(condition))
340
+ http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/logic/againOpenAccountnvm `, {data: {condition: condition}},{resolveMsg: null, rejectMsg: null}).then((row) => {
341
+ // console.log('修改返回' + JSON.stringify(row))
342
+ this.$showMessage('操作成功!将会在一段时间内重新生成开户指令!')
343
+ }).catch((e) => {
344
+ this.$showMessage('操作失败!请稍后重试!')
345
+ console.log('错误信息+++++++'+JSON.stringify(e))
346
+ })
347
+ }
348
+ })
349
+
350
+
351
+ },
352
+ query (title) {
353
+ console.log('查询'+ JSON.stringify(title))
354
+ if (!this.f_meternumber&&!this.f_userinfo_code) {
355
+ this.$showMessage('请输入/扫描用户表号或输入用户编号!')
356
+ return
357
+ }
358
+ let condition = this.f_meternumber!==''? `f_meternumber = '${this.f_meternumber}'`:`f_userinfo_code = '${this.f_userinfo_code}'`
359
+ let data = {
360
+ items: '*',
361
+ tablename: 't_instruct',
362
+ orderitem: 'f_instruct_date desc',
363
+ f_meternumber: this.meternumber
364
+ }
365
+ if(title==='基础'){
366
+ // let condition = `f_meternumber = '${this.f_meternumber}'`
367
+ this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/getUserByMeter`, {data: {condition:condition}}).then((row) => {
368
+ if(row.data.length===0)
369
+ this.$showMessage('未查询到用户信息')
370
+ // console.log('查询返回'+JSON.stringify(row))
371
+ // this.f_meternumber = row.data[0].f_meternumber
372
+ // this.f_userinfo_code = row.data[0].f_userinfo_code?row.data[0].f_userinfo_code:this.f_userinfo_code
373
+ this.row = row.data[0]
374
+ }).catch((e) => {
375
+ console.log('错误信息+++++++'+JSON.stringify(e))
376
+ })
377
+ } else {
378
+ if (title == '指令查询') {
379
+ data = {
380
+ items: '*',
381
+ tablename: 't_instruct',
382
+ orderitem: 'f_instruct_date desc',
383
+ condition: condition
384
+ }
385
+ }else if (title == '抄表查询') {
386
+ data = {
387
+ items: '*',
388
+ tablename: 't_handplan',
389
+ orderitem: 'f_input_date desc',
390
+ condition: condition
391
+ }
392
+ }else if (title == '售气查询') {
393
+ if (!this.f_meternumber) {
394
+ this.$showMessage('请输入/扫描用户表号!')
395
+ return
396
+ }
397
+ data = {
398
+ items: '*',
399
+ tablename: 't_sellinggas',
400
+ orderitem: 'f_operate_date desc',
401
+ condition: condition
402
+ }
403
+ }else if (title == '上报查询') {
404
+ if (!this.f_meternumber) {
405
+ this.$showMessage('请输入/扫描用户表号!')
406
+ return
407
+ }
408
+ data = {
409
+ items: '*',
410
+ tablename: 't_meteread',
411
+ orderitem: 'f_hand_date desc',
412
+ condition: condition
413
+ }
414
+ }
415
+ console.log('查询条件'+ JSON.stringify(data))
416
+ // this.$resetpost(`/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
417
+ this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
418
+ console.log('查询返回'+JSON.stringify(row))
419
+ this.model.rows = row.data
420
+ // this.f_meternumber = row.data[0].f_meternumber
421
+ // this.f_userinfo_code = row.data[0].f_userinfo_code?row.data[0].f_userinfo_code:this.f_userinfo_code
422
+ }).catch((e) => {
423
+ console.log('正在维护!')
424
+ console.log('错误信息+++++++'+JSON.stringify(e))
425
+ })
426
+ }
427
+ },
428
+ setquery (msg) {
429
+ console.log(msg)
430
+ this.querytitle = msg
431
+ // 查询
432
+ this.query(msg)
433
+ },
434
+ Scanningtable() {
435
+ console.log('扫表号6666666')
436
+ HostApp.__this__ = this
437
+ HostApp.scanCode({callback:"javascript:HostApp.__this__.getCode();"})
438
+ },
439
+ getCode () {
440
+ var datapa = HostApp.getCode().data
441
+ console.log(`扫码返回值${datapa}`)
442
+ this.f_meternumber = datapa
443
+ this.$showMessage(`扫码返回值为:${datapa}`)
444
+ },
445
+
446
+ }
447
+ }
448
+ </script>
449
+
450
+ <style scoped>
451
+ .btn-color{
452
+ background-color: #499edf;
453
+ border-radius: 10px ;
454
+ border: 1px solid #499EDF;
455
+ font:600 16px PingFang-SC-Bold;
456
+ color: #FFFFFF;
457
+
458
+ }
459
+ .btn-color1{
460
+ background-color: #FFFFFF;
461
+ border-radius: 10px ;
462
+ border: 1px solid #499EDF;
463
+ font:600 16px PingFang-SC-Bold;
464
+ color: #499EDF;
465
+ }
466
+ .app-row {
467
+ background-color: white;
468
+ padding: 10px 10px 0 10px;
469
+ border-bottom: 1px solid rgba(235, 235, 235, 0.5);
470
+ }
471
+ .search_input {
472
+ border: 0;
473
+ outline: none;
474
+ }
475
+ .font{
476
+ font: 15px PingFang-SC-Medium;
477
+ color: #666666;
478
+ }
479
+ .input-font{
480
+ font: 15px PingFang-SC-Medium;
481
+ color: #333333;
482
+ }
483
+ .div_ul {
484
+ height: 36px;
485
+ color:rgb(153,153,153);
486
+ /*border-right: 1px solid royalblue;*/
487
+ line-height: 36px;
488
+ }
489
+ .div_ul2 {
490
+ height: 36px;
491
+ /*border-right: 1px solid royalblue;*/
492
+ line-height: 36px;
493
+ color:#6eb0e3;
494
+ border-bottom: 2px solid #6eb0e3;
495
+ }
496
+ .meterinfo{
497
+ padding: 10px;
498
+ margin-top: 5px;
499
+ margin-bottom: 5px;
500
+ }
501
+ </style>