system-phone 3.1.38 → 3.1.40

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/bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  100. package/src/bootstrap/less/.csscomb.json +304 -304
  101. package/src/bootstrap/less/.csslintrc +19 -19
  102. package/src/bootstrap/less/alerts.less +73 -73
  103. package/src/bootstrap/less/badges.less +66 -66
  104. package/src/bootstrap/less/bootstrap.less +56 -56
  105. package/src/bootstrap/less/breadcrumbs.less +26 -26
  106. package/src/bootstrap/less/button-groups.less +247 -247
  107. package/src/bootstrap/less/buttons.less +172 -172
  108. package/src/bootstrap/less/carousel.less +269 -269
  109. package/src/bootstrap/less/close.less +34 -34
  110. package/src/bootstrap/less/code.less +69 -69
  111. package/src/bootstrap/less/component-animations.less +33 -33
  112. package/src/bootstrap/less/dropdowns.less +216 -216
  113. package/src/bootstrap/less/forms.less +626 -626
  114. package/src/bootstrap/less/glyphicons.less +305 -305
  115. package/src/bootstrap/less/grid.less +84 -84
  116. package/src/bootstrap/less/input-groups.less +167 -167
  117. package/src/bootstrap/less/jumbotron.less +52 -52
  118. package/src/bootstrap/less/labels.less +64 -64
  119. package/src/bootstrap/less/list-group.less +141 -141
  120. package/src/bootstrap/less/media.less +66 -66
  121. package/src/bootstrap/less/mixins/alerts.less +14 -14
  122. package/src/bootstrap/less/mixins/background-variant.less +9 -9
  123. package/src/bootstrap/less/mixins/border-radius.less +18 -18
  124. package/src/bootstrap/less/mixins/buttons.less +69 -69
  125. package/src/bootstrap/less/mixins/center-block.less +7 -7
  126. package/src/bootstrap/less/mixins/clearfix.less +22 -22
  127. package/src/bootstrap/less/mixins/forms.less +90 -90
  128. package/src/bootstrap/less/mixins/gradients.less +59 -59
  129. package/src/bootstrap/less/mixins/grid-framework.less +92 -92
  130. package/src/bootstrap/less/mixins/grid.less +122 -122
  131. package/src/bootstrap/less/mixins/hide-text.less +21 -21
  132. package/src/bootstrap/less/mixins/image.less +33 -33
  133. package/src/bootstrap/less/mixins/labels.less +12 -12
  134. package/src/bootstrap/less/mixins/list-group.less +30 -30
  135. package/src/bootstrap/less/mixins/nav-divider.less +10 -10
  136. package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
  137. package/src/bootstrap/less/mixins/opacity.less +8 -8
  138. package/src/bootstrap/less/mixins/pagination.less +24 -24
  139. package/src/bootstrap/less/mixins/panels.less +24 -24
  140. package/src/bootstrap/less/mixins/progress-bar.less +10 -10
  141. package/src/bootstrap/less/mixins/reset-filter.less +8 -8
  142. package/src/bootstrap/less/mixins/reset-text.less +18 -18
  143. package/src/bootstrap/less/mixins/resize.less +6 -6
  144. package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
  145. package/src/bootstrap/less/mixins/size.less +10 -10
  146. package/src/bootstrap/less/mixins/tab-focus.less +9 -9
  147. package/src/bootstrap/less/mixins/table-row.less +44 -44
  148. package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
  149. package/src/bootstrap/less/mixins/text-overflow.less +8 -8
  150. package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
  151. package/src/bootstrap/less/mixins.less +40 -40
  152. package/src/bootstrap/less/modals.less +151 -151
  153. package/src/bootstrap/less/navbar.less +660 -660
  154. package/src/bootstrap/less/navs.less +286 -286
  155. package/src/bootstrap/less/normalize.less +424 -424
  156. package/src/bootstrap/less/pager.less +76 -76
  157. package/src/bootstrap/less/pagination.less +89 -89
  158. package/src/bootstrap/less/panels.less +275 -275
  159. package/src/bootstrap/less/popovers.less +131 -131
  160. package/src/bootstrap/less/print.less +101 -101
  161. package/src/bootstrap/less/progress-bars.less +87 -87
  162. package/src/bootstrap/less/responsive-embed.less +35 -35
  163. package/src/bootstrap/less/responsive-utilities.less +194 -194
  164. package/src/bootstrap/less/scaffolding.less +161 -161
  165. package/src/bootstrap/less/tables.less +262 -262
  166. package/src/bootstrap/less/theme.less +291 -291
  167. package/src/bootstrap/less/thumbnails.less +36 -36
  168. package/src/bootstrap/less/tooltip.less +102 -102
  169. package/src/bootstrap/less/type.less +303 -303
  170. package/src/bootstrap/less/utilities.less +55 -55
  171. package/src/bootstrap/less/variables.less +895 -895
  172. package/src/bootstrap/less/wells.less +29 -29
  173. package/src/components/AloneLoadParams.vue +26 -26
  174. package/src/components/LoadAppdata.vue +38 -38
  175. package/src/components/LoginAppV4.vue +790 -787
  176. package/src/components/ModifyPassWord.vue +216 -216
  177. package/src/components/PhoneSellInfo.vue +148 -148
  178. package/src/components/Test.vue +14 -14
  179. package/src/components/iot/InstructMessage.vue +313 -313
  180. package/src/components/iot/IotBaseInfo.vue +97 -97
  181. package/src/filiale/liaoyuan/LoginApp.vue +725 -0
  182. package/src/filiale/liaoyuan/systemphonegrid.js +1 -0
  183. package/src/plugins/GetStringData.js +18 -18
  184. package/src/plugins/LoadParams.js +24 -24
  185. package/src/plugins/validateStrongPasswordPhone.js +162 -0
  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>