system-phone 3.1.49 → 3.1.51

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (199) hide show
  1. package/.babelrc +5 -5
  2. package/.editorconfig +9 -9
  3. package/.eslintrc.js +16 -16
  4. package/CHANGELOG.md +1 -1
  5. package/Dockerfile +3 -3
  6. package/README.md +36 -36
  7. package/build/css-loaders.js +34 -34
  8. package/build/dev-client.js +8 -8
  9. package/build/example-server.js +80 -80
  10. package/build/release.sh +28 -28
  11. package/build/utils.js +71 -71
  12. package/build/webpack.dev.conf.js +31 -31
  13. package/build/webpack.example.conf.js +49 -49
  14. package/build/webpack.prod.conf.js +60 -60
  15. package/build/webpack.test.conf.js +31 -31
  16. package/config/dev.env.js +6 -6
  17. package/config/index.js +38 -38
  18. package/config/prod.env.js +3 -3
  19. package/config/test.env.js +6 -6
  20. package/nginx.conf +304 -304
  21. package/package.json +100 -100
  22. package/release.bat +5 -5
  23. package/src/App.vue +25 -25
  24. package/src/Util.js +415 -415
  25. package/src/android-bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  26. package/src/android-bootstrap/less/.csscomb.json +304 -304
  27. package/src/android-bootstrap/less/.csslintrc +19 -19
  28. package/src/android-bootstrap/less/alerts.less +73 -73
  29. package/src/android-bootstrap/less/badges.less +66 -66
  30. package/src/android-bootstrap/less/bootstrap.less +56 -56
  31. package/src/android-bootstrap/less/breadcrumbs.less +26 -26
  32. package/src/android-bootstrap/less/button-groups.less +247 -247
  33. package/src/android-bootstrap/less/buttons.less +173 -173
  34. package/src/android-bootstrap/less/carousel.less +269 -269
  35. package/src/android-bootstrap/less/close.less +34 -34
  36. package/src/android-bootstrap/less/code.less +69 -69
  37. package/src/android-bootstrap/less/component-animations.less +33 -33
  38. package/src/android-bootstrap/less/dropdowns.less +216 -216
  39. package/src/android-bootstrap/less/forms.less +626 -626
  40. package/src/android-bootstrap/less/glyphicons.less +305 -305
  41. package/src/android-bootstrap/less/grid.less +84 -84
  42. package/src/android-bootstrap/less/input-groups.less +167 -167
  43. package/src/android-bootstrap/less/jumbotron.less +52 -52
  44. package/src/android-bootstrap/less/labels.less +64 -64
  45. package/src/android-bootstrap/less/list-group.less +141 -141
  46. package/src/android-bootstrap/less/media.less +66 -66
  47. package/src/android-bootstrap/less/mixins/alerts.less +14 -14
  48. package/src/android-bootstrap/less/mixins/background-variant.less +9 -9
  49. package/src/android-bootstrap/less/mixins/border-radius.less +18 -18
  50. package/src/android-bootstrap/less/mixins/buttons.less +69 -69
  51. package/src/android-bootstrap/less/mixins/center-block.less +7 -7
  52. package/src/android-bootstrap/less/mixins/clearfix.less +22 -22
  53. package/src/android-bootstrap/less/mixins/forms.less +90 -90
  54. package/src/android-bootstrap/less/mixins/gradients.less +59 -59
  55. package/src/android-bootstrap/less/mixins/grid-framework.less +92 -92
  56. package/src/android-bootstrap/less/mixins/grid.less +122 -122
  57. package/src/android-bootstrap/less/mixins/hide-text.less +21 -21
  58. package/src/android-bootstrap/less/mixins/image.less +33 -33
  59. package/src/android-bootstrap/less/mixins/labels.less +12 -12
  60. package/src/android-bootstrap/less/mixins/list-group.less +30 -30
  61. package/src/android-bootstrap/less/mixins/nav-divider.less +10 -10
  62. package/src/android-bootstrap/less/mixins/nav-vertical-align.less +9 -9
  63. package/src/android-bootstrap/less/mixins/opacity.less +8 -8
  64. package/src/android-bootstrap/less/mixins/pagination.less +24 -24
  65. package/src/android-bootstrap/less/mixins/panels.less +24 -24
  66. package/src/android-bootstrap/less/mixins/progress-bar.less +10 -10
  67. package/src/android-bootstrap/less/mixins/reset-filter.less +8 -8
  68. package/src/android-bootstrap/less/mixins/reset-text.less +18 -18
  69. package/src/android-bootstrap/less/mixins/resize.less +6 -6
  70. package/src/android-bootstrap/less/mixins/responsive-visibility.less +15 -15
  71. package/src/android-bootstrap/less/mixins/size.less +10 -10
  72. package/src/android-bootstrap/less/mixins/tab-focus.less +9 -9
  73. package/src/android-bootstrap/less/mixins/table-row.less +44 -44
  74. package/src/android-bootstrap/less/mixins/text-emphasis.less +9 -9
  75. package/src/android-bootstrap/less/mixins/text-overflow.less +8 -8
  76. package/src/android-bootstrap/less/mixins/vendor-prefixes.less +227 -227
  77. package/src/android-bootstrap/less/mixins.less +40 -40
  78. package/src/android-bootstrap/less/modals.less +151 -151
  79. package/src/android-bootstrap/less/navbar.less +660 -660
  80. package/src/android-bootstrap/less/navs.less +290 -290
  81. package/src/android-bootstrap/less/normalize.less +424 -424
  82. package/src/android-bootstrap/less/pager.less +76 -76
  83. package/src/android-bootstrap/less/pagination.less +89 -89
  84. package/src/android-bootstrap/less/panels.less +274 -274
  85. package/src/android-bootstrap/less/popovers.less +131 -131
  86. package/src/android-bootstrap/less/print.less +101 -101
  87. package/src/android-bootstrap/less/progress-bars.less +87 -87
  88. package/src/android-bootstrap/less/responsive-embed.less +35 -35
  89. package/src/android-bootstrap/less/responsive-utilities.less +194 -194
  90. package/src/android-bootstrap/less/scaffolding.less +161 -161
  91. package/src/android-bootstrap/less/tables.less +262 -262
  92. package/src/android-bootstrap/less/theme.less +291 -291
  93. package/src/android-bootstrap/less/thumbnails.less +36 -36
  94. package/src/android-bootstrap/less/tooltip.less +102 -102
  95. package/src/android-bootstrap/less/type.less +303 -303
  96. package/src/android-bootstrap/less/utilities.less +55 -55
  97. package/src/android-bootstrap/less/variables.less +896 -896
  98. package/src/android-bootstrap/less/wells.less +29 -29
  99. package/src/assets//345/215/241/350/241/250/346/212/204/350/241/250.png +0 -0
  100. package/src/assets//347/275/221/350/241/250/346/212/204/350/241/250.png +0 -0
  101. package/src/bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  102. package/src/bootstrap/less/.csscomb.json +304 -304
  103. package/src/bootstrap/less/.csslintrc +19 -19
  104. package/src/bootstrap/less/alerts.less +73 -73
  105. package/src/bootstrap/less/badges.less +66 -66
  106. package/src/bootstrap/less/bootstrap.less +56 -56
  107. package/src/bootstrap/less/breadcrumbs.less +26 -26
  108. package/src/bootstrap/less/button-groups.less +247 -247
  109. package/src/bootstrap/less/buttons.less +172 -172
  110. package/src/bootstrap/less/carousel.less +269 -269
  111. package/src/bootstrap/less/close.less +34 -34
  112. package/src/bootstrap/less/code.less +69 -69
  113. package/src/bootstrap/less/component-animations.less +33 -33
  114. package/src/bootstrap/less/dropdowns.less +216 -216
  115. package/src/bootstrap/less/forms.less +626 -626
  116. package/src/bootstrap/less/glyphicons.less +305 -305
  117. package/src/bootstrap/less/grid.less +84 -84
  118. package/src/bootstrap/less/input-groups.less +167 -167
  119. package/src/bootstrap/less/jumbotron.less +52 -52
  120. package/src/bootstrap/less/labels.less +64 -64
  121. package/src/bootstrap/less/list-group.less +141 -141
  122. package/src/bootstrap/less/media.less +66 -66
  123. package/src/bootstrap/less/mixins/alerts.less +14 -14
  124. package/src/bootstrap/less/mixins/background-variant.less +9 -9
  125. package/src/bootstrap/less/mixins/border-radius.less +18 -18
  126. package/src/bootstrap/less/mixins/buttons.less +69 -69
  127. package/src/bootstrap/less/mixins/center-block.less +7 -7
  128. package/src/bootstrap/less/mixins/clearfix.less +22 -22
  129. package/src/bootstrap/less/mixins/forms.less +90 -90
  130. package/src/bootstrap/less/mixins/gradients.less +59 -59
  131. package/src/bootstrap/less/mixins/grid-framework.less +92 -92
  132. package/src/bootstrap/less/mixins/grid.less +122 -122
  133. package/src/bootstrap/less/mixins/hide-text.less +21 -21
  134. package/src/bootstrap/less/mixins/image.less +33 -33
  135. package/src/bootstrap/less/mixins/labels.less +12 -12
  136. package/src/bootstrap/less/mixins/list-group.less +30 -30
  137. package/src/bootstrap/less/mixins/nav-divider.less +10 -10
  138. package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
  139. package/src/bootstrap/less/mixins/opacity.less +8 -8
  140. package/src/bootstrap/less/mixins/pagination.less +24 -24
  141. package/src/bootstrap/less/mixins/panels.less +24 -24
  142. package/src/bootstrap/less/mixins/progress-bar.less +10 -10
  143. package/src/bootstrap/less/mixins/reset-filter.less +8 -8
  144. package/src/bootstrap/less/mixins/reset-text.less +18 -18
  145. package/src/bootstrap/less/mixins/resize.less +6 -6
  146. package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
  147. package/src/bootstrap/less/mixins/size.less +10 -10
  148. package/src/bootstrap/less/mixins/tab-focus.less +9 -9
  149. package/src/bootstrap/less/mixins/table-row.less +44 -44
  150. package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
  151. package/src/bootstrap/less/mixins/text-overflow.less +8 -8
  152. package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
  153. package/src/bootstrap/less/mixins.less +40 -40
  154. package/src/bootstrap/less/modals.less +151 -151
  155. package/src/bootstrap/less/navbar.less +660 -660
  156. package/src/bootstrap/less/navs.less +286 -286
  157. package/src/bootstrap/less/normalize.less +424 -424
  158. package/src/bootstrap/less/pager.less +76 -76
  159. package/src/bootstrap/less/pagination.less +89 -89
  160. package/src/bootstrap/less/panels.less +275 -275
  161. package/src/bootstrap/less/popovers.less +131 -131
  162. package/src/bootstrap/less/print.less +101 -101
  163. package/src/bootstrap/less/progress-bars.less +87 -87
  164. package/src/bootstrap/less/responsive-embed.less +35 -35
  165. package/src/bootstrap/less/responsive-utilities.less +194 -194
  166. package/src/bootstrap/less/scaffolding.less +161 -161
  167. package/src/bootstrap/less/tables.less +262 -262
  168. package/src/bootstrap/less/theme.less +291 -291
  169. package/src/bootstrap/less/thumbnails.less +36 -36
  170. package/src/bootstrap/less/tooltip.less +102 -102
  171. package/src/bootstrap/less/type.less +303 -303
  172. package/src/bootstrap/less/utilities.less +55 -55
  173. package/src/bootstrap/less/variables.less +895 -895
  174. package/src/bootstrap/less/wells.less +29 -29
  175. package/src/components/AloneLoadParams.vue +26 -26
  176. package/src/components/LoadAppdata.vue +38 -38
  177. package/src/components/LoginAppV4.vue +790 -790
  178. package/src/components/ModifyPassWord.vue +219 -219
  179. package/src/components/PhoneSellInfo.vue +148 -148
  180. package/src/components/Test.vue +14 -14
  181. package/src/components/iot/InstructMessage.vue +313 -313
  182. package/src/components/iot/IotBaseInfo.vue +97 -97
  183. package/src/plugins/GetStringData.js +18 -18
  184. package/src/plugins/LoadParams.js +24 -24
  185. package/src/plugins/validateStrongPasswordPhone.js +172 -172
  186. package/src/services/ConfigService.js +24 -24
  187. package/static/app.json +4 -4
  188. package/static/globals.txt +74 -74
  189. package/test/unit/.eslintrc +5 -5
  190. package/test/unit/TestUtil.js +35 -35
  191. package/test/unit/context.html +20 -20
  192. package/test/unit/index.js +13 -13
  193. package/test/unit/init.js +13 -13
  194. package/test/unit/karma.conf.js +50 -50
  195. package/test/unit/specs/App.spec.js +17 -17
  196. package/test/unit/specs/Test.spec.js +28 -28
  197. package/test/unit/specs/components/LoginApp.spec.js +21 -21
  198. package/test/unit/specs/sevices/ConfigService.spec.js +23 -23
  199. package/test/unit/specs/sevices/GetDBTest.spec.js +28 -28
@@ -1,313 +1,313 @@
1
- <template>
2
- <div class="flex " style="background: #f8f8f8">
3
- <div class="auto bg-white" style="line-height: 32px;padding: 10px">
4
- <label style="float: left">指令:{{row.f_instruct_title}} </label>
5
- <div class="auto" style="float: right">
6
- <!--<button type="button" class="btn btn-default btn-sm" @click="$back">返回</button>-->
7
- <button type="button" class="btn btn-default btn-sm" @click="refresh">刷新</button>
8
- <button type="button" class="btn btn-primary btn-sm" @click="cancle">取消</button>
9
- <button type="button" class="btn btn-primary btn-sm" @click="resend">重送</button>
10
- </div>
11
- </div>
12
- <div class="instruct-state flex-row bg-white" style="margin-top: 5px;height:auto;padding: 10px">
13
- <div class="instruct-left col-sm-12 auto">
14
- <div class="col-sm-6 col-md-6 col-xs-6 auto">
15
- <p class="flex-row">
16
- <span >指令状态:</span>
17
- <span class="instruct-content" style="color: #499edf;font-size: 16px;font-weight: bold">{{row.f_instruct_state}}</span>
18
- </p>
19
- </div>
20
- <div class="col-sm-6 col-md-6 col-xs-6 auto">
21
- <p class="flex-row">
22
- <span>执行状态:</span>
23
- <span class="instruct-content" style="color: #499edf;font-size: 16px;font-weight: bold">{{row.f_receive_state}}</span>
24
- </p>
25
- </div>
26
- <div class="col-sm-6 col-md-6 col-xs-6 auto">
27
- <p class="flex-row">
28
- <span>指令编号:</span>
29
- <span class="instruct-content">{{row.id}}</span>
30
- </p>
31
- </div>
32
- <div class="col-sm-6 col-md-6 col-xs-6 auto">
33
-
34
- <p class="flex-row">
35
- <span>表编号:</span>
36
- <span class="instruct-content">{{row.f_user_id}}</span>
37
- </p>
38
- </div>
39
- <div class="col-sm-6 col-md-6 col-xs-6 auto">
40
- <p class="flex-row">
41
- <span>表号:</span>
42
- <span class="instruct-content">{{row.f_meternumber}}</span>
43
- </p>
44
- </div>
45
- <div class="col-sm-6 col-md-6 col-xs-6 auto">
46
- <p class="flex-row">
47
- <span>操作人员:</span>
48
- <span class="instruct-content">{{row.f_inputtor}}</span>
49
- </p>
50
- </div>
51
- <div class="col-sm-6 col-md-6 col-xs-6 auto">
52
- <p class="flex-row">
53
- <span>指令说明:</span>
54
- <span class="instruct-content">{{row.f_instruct_state}}</span>
55
- </p>
56
- </div>
57
- <div class="col-sm-6 col-md-6 col-xs-6 auto">
58
- <p class="flex-row">
59
- <span>表厂别名:</span>
60
- <span class="instruct-content">{{row.f_alias}}</span>
61
- </p>
62
- </div>
63
- <div class="col-sm-6 col-md-6 col-xs-12 auto">
64
- <p class="flex-row">
65
- <span>生成时间:</span>
66
- <span class="instruct-content" style="flex:3 !important;">{{row.f_instruct_date}}</span>
67
- </p>
68
- </div>
69
- <div class="col-sm-6 col-md-6 col-xs-12 auto">
70
- <p class="flex-row">
71
- <span>最后发送时间:</span>
72
- <span class="instruct-content" style="flex:3 !important;">{{row.f_send_date}}</span>
73
- </p>
74
- </div>
75
- <div class="col-sm-6 col-md-6 col-xs-12 auto">
76
- <p class="flex-row">
77
- <span>最后响应时间:</span>
78
- <span class="instruct-content" style="flex:3 !important;">{{row.f_callback_date}}</span>
79
- </p>
80
- </div>
81
- </div>
82
-
83
- </div>
84
- <div class="auto bg-white" style="margin-top: 5px;padding: 10px">
85
- <div class="title auto">
86
- <span>指令状态</span>
87
- </div>
88
- <div class="flex-row" style="font-size: 10px;padding: 10px">
89
- <timeline>
90
- <timeline-item color="#499edf">
91
- <p>待发送</p>
92
- <p>指令已就绪</p>
93
- <p>{{row.f_instruct_date}}</p>
94
- </timeline-item>
95
- <timeline-item :color="row.f_instruct_state==='已发送'?'#499edf':''" >
96
- <p>已发送</p>
97
- <p>已发送,等待响应结果</p>
98
- <p>{{row.f_send_date}}</p>
99
- </timeline-item>
100
- <timeline-item color="red" v-if="row.f_instruct_state==='执行失败'">
101
- <p>执行失败</p>
102
- <p>失败,请查看响应结果</p>
103
- <p>{{row.f_callback_date}}</p>
104
- </timeline-item>
105
- <timeline-item :color="row.f_instruct_state==='执行成功'?'#499edf':''" v-if="row.f_instruct_state!=='执行失败'">
106
- <p>执行成功</p>
107
- <p>指令已执行成功</p>
108
- <p>{{row.f_callback_date}}</p>
109
- </timeline-item>
110
- </timeline>
111
- <!--<div class="step">-->
112
- <!--<div class="step-icon">-->
113
- <!--<img src="../../assets/对号.png" class="send-line" style="height: 32px;width:32px;margin-bottom: 5px;padding-right: 5px" alt="" >-->
114
- <!--</div>-->
115
- <!--<p>待发送</p>-->
116
- <!--<p>指令已就绪</p>-->
117
- <!--<p>{{row.f_instruct_date}}</p>-->
118
-
119
- <!--</div>-->
120
- <!--<div class="step" >-->
121
- <!--<div class="step-icon">-->
122
- <!--<img src="../../assets/对号.png" style="height: 32px;width:32px;margin-bottom: 5px;padding-right: 5px" alt="" >-->
123
- <!--</div>-->
124
- <!--<p class="flex-row">待发送</p>-->
125
- <!--<p class="flex-row">指令已发送</p>-->
126
- <!--<p>{{row.f_send_date}}</p>-->
127
- <!--</div>-->
128
-
129
- <!--<div class="step" >-->
130
- <!--<div style="height: auto">-->
131
- <!--<img src="../../assets/对号.png" class="" style="height: 32px;width:32px;margin-bottom: 5px;padding-right: 5px" alt="" >-->
132
- <!--</div>-->
133
- <!--<p class="flex-row">待发送</p>-->
134
- <!--<p>指令已执行成功</p>-->
135
- <!--<p>{{row.f_callback_date}}</p>-->
136
- <!--</div>-->
137
- </div>
138
-
139
- </div>
140
- <div class="row bg-white" style="margin-top: 5px;">
141
- <div class="content-head" style="background: #fafafa;height: 2em;">
142
- <p style="padding-left: 10px;line-height: 2em">指令内容</p>
143
- </div>
144
- <div style="height: auto;padding: 10px" >
145
- <p>{</p>
146
- <p v-for="item in content">
147
- <span>{{item}}</span>
148
- <span v-if="$index<content.length-1">,</span>
149
- </p>
150
- <p>}</p>
151
- </div>
152
- </div>
153
- </div>
154
- </template>
155
- <script>
156
- import {HttpResetClass} from 'vue-client'
157
- export default {
158
- title: '指令信息',
159
- data () {
160
- return {
161
- content:[],
162
- msg: '',
163
- show: false
164
- }
165
- },
166
- props:['row'],
167
- methods:{
168
- refresh(){
169
- let data = {
170
- items: '*',
171
- tablename: 't_instruct',
172
- orderitem: 'id desc',
173
- condition: ` id = '${this.row.id}'`
174
- }
175
- this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
176
- // console.log('查询返回'+JSON.stringify(row))
177
- this.row = row.data[0]
178
- }).catch((e) => {
179
- // console.log('正在维护!')
180
- // console.log('错误信息+++++++'+JSON.stringify(e))
181
- })
182
- },
183
- cancle(){
184
- this.$showMessage(`您确认要取消指令吗?`, ['confirm', 'cancel']).then(async (res) => {
185
- if (res === 'confirm') {
186
- let http = new HttpResetClass()
187
- let condition = `id = '${this.row.id}'`
188
- // console.log('修改条件===' + JSON.stringify(condition))
189
- http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/logic/cancelSendInstruct`, {data: {condition: condition}}).then((row) => {
190
- this.$showMessage('取消指令操作成功!')
191
- this.refresh()
192
- // console.log('修改返回' + JSON.stringify(row))
193
- // this.$showMessage('操作成功!将会在一段时间内重新生成开户指令!')
194
- }).catch((e) => {
195
- this.$showMessage('操作失败!请稍后重试!')
196
- // console.log('错误信息+++++++'+JSON.stringify(e))
197
- })
198
- }
199
- })
200
- },
201
- resend(){
202
- this.$showMessage(`您确认要重新发送指令?`, ['confirm', 'cancel']).then(async (res) => {
203
- if (res === 'confirm') {
204
- let http = new HttpResetClass()
205
- let condition = `id = '${this.row.id}'`
206
- // console.log('修改条件===' + JSON.stringify(condition))
207
- http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/logic/againSendInstruct`, {data: {condition: condition}}).then((row) => {
208
- // console.log('修改返回' + JSON.stringify(row))
209
- this.refresh()
210
- this.$showMessage('操作成功!将会在一段时间内重新发送指令!')
211
- }).catch((e) => {
212
- this.$showMessage('操作失败!请稍后重试!')
213
- // console.log('错误信息+++++++'+JSON.stringify(e))
214
- })
215
- }
216
- })
217
- },
218
- getInitData(){
219
- let data = JSON.parse(this.row.f_instruct_content)
220
- this.content = []
221
- for(let key in data){
222
- let param = key+':'+data[key]
223
- this.content.push(param)
224
- }
225
- },
226
- },
227
- watch:{
228
- 'row'(val){
229
- if(val){
230
- this.getInitData()
231
- }
232
- }
233
- },
234
- ready () {
235
- this.getInitData()
236
- }
237
- }
238
- </script>
239
- <style media="screen" scoped>
240
- div::-webkit-scrollbar {
241
- width: 0 !important;
242
- height: 0 !important;
243
- }
244
-
245
- div {
246
- -ms-overflow-style: none;
247
- overflow: -moz-scrollbars-none;
248
- }
249
-
250
- .font-head{
251
- font-size: 14px;
252
- font-weight: bold;
253
- color: #333;
254
- }
255
- .instruct-content{
256
- flex:1.5 !important;
257
- }
258
- .font-content{
259
- font-size: 12px;
260
- font-weight: normal;
261
- color: #666666;
262
- }
263
- .meterinfo{
264
- border:1px solid #eeeeee;
265
- /*border-right: 2px solid #eeeeee;*/
266
- }
267
- .instruct-right div{
268
- height: auto;
269
- }
270
- .instruct-state{
271
- font-size: 14px;
272
- }
273
- .instruct{
274
- font-size: 10px;
275
- }
276
- .step{
277
- flex:1
278
- }
279
- .step-icon{
280
- height: auto;
281
- }
282
- @media screen and (max-width: 1920px){
283
- .step-icon:after{
284
- content: "";
285
- width: 30%;
286
- height: 2px;
287
- margin-top: 16px;
288
- background-color: #6eb0e3;
289
- position: absolute;
290
- /*top: 10px;*/
291
-
292
- }
293
- }
294
- @media screen and (max-width: 768px){
295
- .step-icon:after{
296
- content: "";
297
- width: 22%;
298
- height: 2px;
299
- margin-top: 16px;
300
- background-color: #6eb0e3;
301
- position: absolute;
302
- /*top: 10px;*/
303
-
304
- }
305
- }
306
-
307
- .step p{
308
- margin-bottom: 5px !important;
309
- }
310
- p span{
311
- flex:1
312
- }
313
- </style>
1
+ <template>
2
+ <div class="flex " style="background: #f8f8f8">
3
+ <div class="auto bg-white" style="line-height: 32px;padding: 10px">
4
+ <label style="float: left">指令:{{row.f_instruct_title}} </label>
5
+ <div class="auto" style="float: right">
6
+ <!--<button type="button" class="btn btn-default btn-sm" @click="$back">返回</button>-->
7
+ <button type="button" class="btn btn-default btn-sm" @click="refresh">刷新</button>
8
+ <button type="button" class="btn btn-primary btn-sm" @click="cancle">取消</button>
9
+ <button type="button" class="btn btn-primary btn-sm" @click="resend">重送</button>
10
+ </div>
11
+ </div>
12
+ <div class="instruct-state flex-row bg-white" style="margin-top: 5px;height:auto;padding: 10px">
13
+ <div class="instruct-left col-sm-12 auto">
14
+ <div class="col-sm-6 col-md-6 col-xs-6 auto">
15
+ <p class="flex-row">
16
+ <span >指令状态:</span>
17
+ <span class="instruct-content" style="color: #499edf;font-size: 16px;font-weight: bold">{{row.f_instruct_state}}</span>
18
+ </p>
19
+ </div>
20
+ <div class="col-sm-6 col-md-6 col-xs-6 auto">
21
+ <p class="flex-row">
22
+ <span>执行状态:</span>
23
+ <span class="instruct-content" style="color: #499edf;font-size: 16px;font-weight: bold">{{row.f_receive_state}}</span>
24
+ </p>
25
+ </div>
26
+ <div class="col-sm-6 col-md-6 col-xs-6 auto">
27
+ <p class="flex-row">
28
+ <span>指令编号:</span>
29
+ <span class="instruct-content">{{row.id}}</span>
30
+ </p>
31
+ </div>
32
+ <div class="col-sm-6 col-md-6 col-xs-6 auto">
33
+
34
+ <p class="flex-row">
35
+ <span>表编号:</span>
36
+ <span class="instruct-content">{{row.f_user_id}}</span>
37
+ </p>
38
+ </div>
39
+ <div class="col-sm-6 col-md-6 col-xs-6 auto">
40
+ <p class="flex-row">
41
+ <span>表号:</span>
42
+ <span class="instruct-content">{{row.f_meternumber}}</span>
43
+ </p>
44
+ </div>
45
+ <div class="col-sm-6 col-md-6 col-xs-6 auto">
46
+ <p class="flex-row">
47
+ <span>操作人员:</span>
48
+ <span class="instruct-content">{{row.f_inputtor}}</span>
49
+ </p>
50
+ </div>
51
+ <div class="col-sm-6 col-md-6 col-xs-6 auto">
52
+ <p class="flex-row">
53
+ <span>指令说明:</span>
54
+ <span class="instruct-content">{{row.f_instruct_state}}</span>
55
+ </p>
56
+ </div>
57
+ <div class="col-sm-6 col-md-6 col-xs-6 auto">
58
+ <p class="flex-row">
59
+ <span>表厂别名:</span>
60
+ <span class="instruct-content">{{row.f_alias}}</span>
61
+ </p>
62
+ </div>
63
+ <div class="col-sm-6 col-md-6 col-xs-12 auto">
64
+ <p class="flex-row">
65
+ <span>生成时间:</span>
66
+ <span class="instruct-content" style="flex:3 !important;">{{row.f_instruct_date}}</span>
67
+ </p>
68
+ </div>
69
+ <div class="col-sm-6 col-md-6 col-xs-12 auto">
70
+ <p class="flex-row">
71
+ <span>最后发送时间:</span>
72
+ <span class="instruct-content" style="flex:3 !important;">{{row.f_send_date}}</span>
73
+ </p>
74
+ </div>
75
+ <div class="col-sm-6 col-md-6 col-xs-12 auto">
76
+ <p class="flex-row">
77
+ <span>最后响应时间:</span>
78
+ <span class="instruct-content" style="flex:3 !important;">{{row.f_callback_date}}</span>
79
+ </p>
80
+ </div>
81
+ </div>
82
+
83
+ </div>
84
+ <div class="auto bg-white" style="margin-top: 5px;padding: 10px">
85
+ <div class="title auto">
86
+ <span>指令状态</span>
87
+ </div>
88
+ <div class="flex-row" style="font-size: 10px;padding: 10px">
89
+ <timeline>
90
+ <timeline-item color="#499edf">
91
+ <p>待发送</p>
92
+ <p>指令已就绪</p>
93
+ <p>{{row.f_instruct_date}}</p>
94
+ </timeline-item>
95
+ <timeline-item :color="row.f_instruct_state==='已发送'?'#499edf':''" >
96
+ <p>已发送</p>
97
+ <p>已发送,等待响应结果</p>
98
+ <p>{{row.f_send_date}}</p>
99
+ </timeline-item>
100
+ <timeline-item color="red" v-if="row.f_instruct_state==='执行失败'">
101
+ <p>执行失败</p>
102
+ <p>失败,请查看响应结果</p>
103
+ <p>{{row.f_callback_date}}</p>
104
+ </timeline-item>
105
+ <timeline-item :color="row.f_instruct_state==='执行成功'?'#499edf':''" v-if="row.f_instruct_state!=='执行失败'">
106
+ <p>执行成功</p>
107
+ <p>指令已执行成功</p>
108
+ <p>{{row.f_callback_date}}</p>
109
+ </timeline-item>
110
+ </timeline>
111
+ <!--<div class="step">-->
112
+ <!--<div class="step-icon">-->
113
+ <!--<img src="../../assets/对号.png" class="send-line" style="height: 32px;width:32px;margin-bottom: 5px;padding-right: 5px" alt="" >-->
114
+ <!--</div>-->
115
+ <!--<p>待发送</p>-->
116
+ <!--<p>指令已就绪</p>-->
117
+ <!--<p>{{row.f_instruct_date}}</p>-->
118
+
119
+ <!--</div>-->
120
+ <!--<div class="step" >-->
121
+ <!--<div class="step-icon">-->
122
+ <!--<img src="../../assets/对号.png" style="height: 32px;width:32px;margin-bottom: 5px;padding-right: 5px" alt="" >-->
123
+ <!--</div>-->
124
+ <!--<p class="flex-row">待发送</p>-->
125
+ <!--<p class="flex-row">指令已发送</p>-->
126
+ <!--<p>{{row.f_send_date}}</p>-->
127
+ <!--</div>-->
128
+
129
+ <!--<div class="step" >-->
130
+ <!--<div style="height: auto">-->
131
+ <!--<img src="../../assets/对号.png" class="" style="height: 32px;width:32px;margin-bottom: 5px;padding-right: 5px" alt="" >-->
132
+ <!--</div>-->
133
+ <!--<p class="flex-row">待发送</p>-->
134
+ <!--<p>指令已执行成功</p>-->
135
+ <!--<p>{{row.f_callback_date}}</p>-->
136
+ <!--</div>-->
137
+ </div>
138
+
139
+ </div>
140
+ <div class="row bg-white" style="margin-top: 5px;">
141
+ <div class="content-head" style="background: #fafafa;height: 2em;">
142
+ <p style="padding-left: 10px;line-height: 2em">指令内容</p>
143
+ </div>
144
+ <div style="height: auto;padding: 10px" >
145
+ <p>{</p>
146
+ <p v-for="item in content">
147
+ <span>{{item}}</span>
148
+ <span v-if="$index<content.length-1">,</span>
149
+ </p>
150
+ <p>}</p>
151
+ </div>
152
+ </div>
153
+ </div>
154
+ </template>
155
+ <script>
156
+ import {HttpResetClass} from 'vue-client'
157
+ export default {
158
+ title: '指令信息',
159
+ data () {
160
+ return {
161
+ content:[],
162
+ msg: '',
163
+ show: false
164
+ }
165
+ },
166
+ props:['row'],
167
+ methods:{
168
+ refresh(){
169
+ let data = {
170
+ items: '*',
171
+ tablename: 't_instruct',
172
+ orderitem: 'id desc',
173
+ condition: ` id = '${this.row.id}'`
174
+ }
175
+ this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/iot_singleTable_OrderBy`, {data: data}).then((row) => {
176
+ // console.log('查询返回'+JSON.stringify(row))
177
+ this.row = row.data[0]
178
+ }).catch((e) => {
179
+ // console.log('正在维护!')
180
+ // console.log('错误信息+++++++'+JSON.stringify(e))
181
+ })
182
+ },
183
+ cancle(){
184
+ this.$showMessage(`您确认要取消指令吗?`, ['confirm', 'cancel']).then(async (res) => {
185
+ if (res === 'confirm') {
186
+ let http = new HttpResetClass()
187
+ let condition = `id = '${this.row.id}'`
188
+ // console.log('修改条件===' + JSON.stringify(condition))
189
+ http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/logic/cancelSendInstruct`, {data: {condition: condition}}).then((row) => {
190
+ this.$showMessage('取消指令操作成功!')
191
+ this.refresh()
192
+ // console.log('修改返回' + JSON.stringify(row))
193
+ // this.$showMessage('操作成功!将会在一段时间内重新生成开户指令!')
194
+ }).catch((e) => {
195
+ this.$showMessage('操作失败!请稍后重试!')
196
+ // console.log('错误信息+++++++'+JSON.stringify(e))
197
+ })
198
+ }
199
+ })
200
+ },
201
+ resend(){
202
+ this.$showMessage(`您确认要重新发送指令?`, ['confirm', 'cancel']).then(async (res) => {
203
+ if (res === 'confirm') {
204
+ let http = new HttpResetClass()
205
+ let condition = `id = '${this.row.id}'`
206
+ // console.log('修改条件===' + JSON.stringify(condition))
207
+ http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/logic/againSendInstruct`, {data: {condition: condition}}).then((row) => {
208
+ // console.log('修改返回' + JSON.stringify(row))
209
+ this.refresh()
210
+ this.$showMessage('操作成功!将会在一段时间内重新发送指令!')
211
+ }).catch((e) => {
212
+ this.$showMessage('操作失败!请稍后重试!')
213
+ // console.log('错误信息+++++++'+JSON.stringify(e))
214
+ })
215
+ }
216
+ })
217
+ },
218
+ getInitData(){
219
+ let data = JSON.parse(this.row.f_instruct_content)
220
+ this.content = []
221
+ for(let key in data){
222
+ let param = key+':'+data[key]
223
+ this.content.push(param)
224
+ }
225
+ },
226
+ },
227
+ watch:{
228
+ 'row'(val){
229
+ if(val){
230
+ this.getInitData()
231
+ }
232
+ }
233
+ },
234
+ ready () {
235
+ this.getInitData()
236
+ }
237
+ }
238
+ </script>
239
+ <style media="screen" scoped>
240
+ div::-webkit-scrollbar {
241
+ width: 0 !important;
242
+ height: 0 !important;
243
+ }
244
+
245
+ div {
246
+ -ms-overflow-style: none;
247
+ overflow: -moz-scrollbars-none;
248
+ }
249
+
250
+ .font-head{
251
+ font-size: 14px;
252
+ font-weight: bold;
253
+ color: #333;
254
+ }
255
+ .instruct-content{
256
+ flex:1.5 !important;
257
+ }
258
+ .font-content{
259
+ font-size: 12px;
260
+ font-weight: normal;
261
+ color: #666666;
262
+ }
263
+ .meterinfo{
264
+ border:1px solid #eeeeee;
265
+ /*border-right: 2px solid #eeeeee;*/
266
+ }
267
+ .instruct-right div{
268
+ height: auto;
269
+ }
270
+ .instruct-state{
271
+ font-size: 14px;
272
+ }
273
+ .instruct{
274
+ font-size: 10px;
275
+ }
276
+ .step{
277
+ flex:1
278
+ }
279
+ .step-icon{
280
+ height: auto;
281
+ }
282
+ @media screen and (max-width: 1920px){
283
+ .step-icon:after{
284
+ content: "";
285
+ width: 30%;
286
+ height: 2px;
287
+ margin-top: 16px;
288
+ background-color: #6eb0e3;
289
+ position: absolute;
290
+ /*top: 10px;*/
291
+
292
+ }
293
+ }
294
+ @media screen and (max-width: 768px){
295
+ .step-icon:after{
296
+ content: "";
297
+ width: 22%;
298
+ height: 2px;
299
+ margin-top: 16px;
300
+ background-color: #6eb0e3;
301
+ position: absolute;
302
+ /*top: 10px;*/
303
+
304
+ }
305
+ }
306
+
307
+ .step p{
308
+ margin-bottom: 5px !important;
309
+ }
310
+ p span{
311
+ flex:1
312
+ }
313
+ </style>