safecheck-client 3.0.39-6 → 3.0.39-60

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 (92) hide show
  1. package/.trae/.ignore +0 -0
  2. package/.vscode/settings.json +3 -0
  3. package/package.json +134 -134
  4. package/src/App.vue +26 -31
  5. package/src/assets//345/256/232/344/275/215.png +0 -0
  6. package/src/components/android/AndroidDefectDeal.vue +2 -2
  7. package/src/components/android/SafecheckOrderV.vue +1 -1
  8. package/src/components/pc/AddPlanItemYyChange.vue +5 -1
  9. package/src/components/pc/PaperDefectMain.vue +1 -1
  10. package/src/components/pc/RoleSelector.vue +172 -172
  11. package/src/components/pc/SafeCheckOrder/SafeCheckOrderList.vue +34 -0
  12. package/src/components/rongcheng/AddPlanItem.vue +344 -344
  13. package/src/components/rongcheng/CheckCurrentCreate.vue +1081 -1081
  14. package/src/components/rongcheng/PaperDefectMain.vue +828 -828
  15. package/src/components/rongcheng/PaperStatem.vue +6 -6
  16. package/src/components/rongcheng/PhoneUpUserinfo.vue +1 -0
  17. package/src/filiale/BFshiye/android/PhoneUpUserinfo.vue +3 -1
  18. package/src/filiale/BFshiye/android/SafecheckUserInfo.vue +2 -8
  19. package/src/filiale/BFshiye/pc/checkUserList.vue +772 -772
  20. package/src/filiale/baiyin/android/SafecheckUserInfo.vue +775 -0
  21. package/src/filiale/baiyin/android.js +1 -0
  22. package/src/filiale/bayan/pc/NewCheckpaper.vue +2 -2
  23. package/src/filiale/bayan/pc/SelectAreaReport.vue +1 -0
  24. package/src/filiale/bayan/pc/SummaryOfSecurityInspectionProgress.vue +7 -7
  25. package/src/filiale/dexin/android/SafecheckOrderV.vue +1 -1
  26. package/src/filiale/dexin/android/SafecheckOrderVTemp.vue +4 -1
  27. package/src/filiale/dexin/pc/PaperList.vue +840 -840
  28. package/src/filiale/hanzhong/pc/CheckHiddenDanger.vue +2 -2
  29. package/src/filiale/hanzhong/pc/CheckNumberStatistics.vue +1 -1
  30. package/src/filiale/hanzhong/pc/CheckSafeDetail.vue +6 -1
  31. package/src/filiale/hanzhong/pc/CheckSafeStatus.vue +1 -1
  32. package/src/filiale/hanzhong/pc/CheckerSafeDetail.vue +1 -1
  33. package/src/filiale/huatong/android/SafecheckOrderV.vue +2 -2
  34. package/src/filiale/jinhuang/android/AddPlanItem.vue +430 -0
  35. package/src/filiale/jinhuang/android/PhoneUpUserinfo.vue +182 -144
  36. package/src/filiale/jinhuang/android.js +2 -1
  37. package/src/filiale/kelai/android/PaperFeedback.vue +1384 -1370
  38. package/src/filiale/kelai/android/PhoneUpUserinfo.vue +1 -1
  39. package/src/filiale/kelai/android/SafecheckOrderV.vue +1 -1
  40. package/src/filiale/kelai/android/SafecheckUserInfo.vue +1 -1
  41. package/src/filiale/kelai/pc/PaperList.vue +13 -0
  42. package/src/filiale/kelai/pc/UserInfoAudit.vue +126 -90
  43. package/src/filiale/liaoyuan/pc/DefectPaperWeiXiu.vue +4 -6
  44. package/src/filiale/liaoyuan/pc/NewCheckpaper.vue +7 -7
  45. package/src/filiale/liaoyuan/pc/checkPlanList.vue +2 -3
  46. package/src/filiale/qingjian/android/PhoneUpUserinfo.vue +125 -38
  47. package/src/filiale/qingjian/android/SafecheckDevices.vue +1 -1
  48. package/src/filiale/qingjian/android/SafecheckOrderV.vue +2921 -2918
  49. package/src/filiale/qingjian/android/SafecheckUserInfo.vue +42 -19
  50. package/src/filiale/qingjian/pc/NewCheckpaper.vue +1919 -1919
  51. package/src/filiale/rongchuang/android/AddPlanItemVisitingWithoutMeeting.vue +454 -0
  52. package/src/filiale/rongchuang/android/AddPlanItemYy.vue +498 -0
  53. package/src/filiale/rongchuang/android/PhoneUpUserinfo.vue +1262 -0
  54. package/src/filiale/rongchuang/android/SafecheckDevices.vue +1 -1
  55. package/src/filiale/rongchuang/android/SafecheckOrderV.vue +3 -2
  56. package/src/filiale/rongchuang/android.js +3 -0
  57. package/src/filiale/rongchuang/pc/NewCheckpaper.vue +13 -1
  58. package/src/filiale/rongchuang/pc/checkPlanList.vue +398 -0
  59. package/src/filiale/rongchuang/pc.js +1 -0
  60. package/src/filiale/siyang/android/PhoneInsurancePurchaseDetail.vue +57 -24
  61. package/src/filiale/tongchuan/android/SafecheckDevices.vue +909 -885
  62. package/src/filiale/tongchuan/pc/AMapTrailShowZk.vue +226 -0
  63. package/src/filiale/tongchuan/pc/CheckPlanCountChartAreaByWangGeYuan.vue +137 -0
  64. package/src/filiale/tongchuan/pc/CheckSearchUser.vue +47 -1
  65. package/src/filiale/tongchuan/pc/DefectPaperWeiXiu.vue +46 -0
  66. package/src/filiale/tongchuan/pc/NoCheckplanSafecheck.vue +34 -0
  67. package/src/filiale/tongchuan/pc/PaperDefectMain.vue +34 -0
  68. package/src/filiale/tongchuan/pc/PaperList.vue +44 -10
  69. package/src/filiale/tongchuan/pc/PersonTrack.vue +269 -0
  70. package/src/filiale/tongchuan/pc/SelectCheckPlan.vue +42 -2
  71. package/src/filiale/tongchuan/pc.js +3 -0
  72. package/src/filiale/wensu/android/SafecheckOrderV.vue +2444 -2444
  73. package/src/filiale/wensu/android/SafecheckUserInfo.vue +712 -712
  74. package/src/filiale/wensu/pc/CheckSearchUser.vue +1251 -1251
  75. package/src/filiale/wenxi/pc/PaperList.vue +9 -3
  76. package/src/filiale/wuan/android/SafecheckOrderV.vue +1 -1
  77. package/src/filiale/wuan/android/SafecheckUserInfo.vue +12 -8
  78. package/src/filiale/yangchunboneng/android/AndiroidSecurityAudit.vue +2 -1
  79. package/src/filiale/yangchunboneng/android/CurrentCreate.vue +1191 -1191
  80. package/src/filiale/yangchunboneng/android/SafecheckUserInfo.vue +913 -913
  81. package/src/filiale/yangchunboneng/android.js +21 -21
  82. package/src/filiale/yangchunboneng/pc/CheckBookList.vue +353 -353
  83. package/src/filiale/yangchunboneng/pc/CheckPlanAreaList.vue +677 -677
  84. package/src/filiale/yangchunboneng/pc/CheckSearchUser.vue +1197 -1197
  85. package/src/filiale/yangchunboneng/pc/HiddenSituation.vue +171 -171
  86. package/src/filiale/yangchunboneng/pc/PaperDefectMain.vue +1112 -1112
  87. package/src/filiale/yangchunboneng/pc/PaperList.vue +757 -757
  88. package/src/filiale/yangchunboneng/pc/SelectCheckPlan.vue +331 -331
  89. package/src/filiale/yangchunboneng/pc.js +29 -29
  90. package/src/main.js +33 -33
  91. package/src/rongcheng.js +319 -319
  92. package/yarn-error.log +140 -0
@@ -253,7 +253,7 @@ export default {
253
253
  page:{},
254
254
  selectindex:null,
255
255
  lives:[{label: '是', value: '是'},{label: '否', value: '否'}],
256
- deals:[{label: '现场处理', value: '现场处理'},{label: '自行处理', value: '自行处理'}],
256
+ deals:[{label: '自行处理', value: '自行处理'},{label: '现场整改', value: '现场整改'}],
257
257
  f_live_dispose:'否',
258
258
  f_deal_dispose:'未处理',
259
259
  // 初始表底
@@ -30,7 +30,7 @@
30
30
  <div class="panel-body ">
31
31
  <div class="row auto">
32
32
  <div class="col-xs-12 col-sm-12 col-md-12 flex-between" style="margin-top: 20px;">
33
- <div class="col-xs-3 col-sm-3 col-md-3" v-if="parentPage=='CurrentCreate'">
33
+ <div class="col-xs-3 col-sm-3 col-md-3" v-if="parentPage=='CurrentCreate' || parentPage=='AddPlanItemYy'">
34
34
  <button type="button" name="button" class="col-sm-3 btn btn-primary" @click="save('temp')">
35
35
  临时保存
36
36
  </button>
@@ -160,6 +160,7 @@ import AppInstallationMaterial from './AppInstallationMaterial'
160
160
  data: {
161
161
  f_devices: [],
162
162
  f_defect_content:'',
163
+ f_repair_approved_note:'',
163
164
  f_recording1_path:'',
164
165
  f_visit_number:'',
165
166
  f_remark:''
@@ -1035,7 +1036,7 @@ import AppInstallationMaterial from './AppInstallationMaterial'
1035
1036
  alias: 'getUserinfomation',
1036
1037
  data: {condition: "f_userinfoid = '" + this.item.f_userinfoid + "' and f_no_checkplan in ('无计划安检','复检')"}
1037
1038
  })
1038
- if ((this.item.f_no_checkplan == '无计划安检' || this.item.f_no_checkplan == '复检') && this.item.f_no_checkplan != '打回') {
1039
+ if ((this.item.f_no_checkplan == '无计划安检' || this.item.f_no_checkplan == '复检' || this.item.f_no_checkplan == '预约安检') && this.item.f_no_checkplan != '打回') {
1039
1040
  codata.f_devices = this.f_devices
1040
1041
  if (this.rowCodata && this.rowCodata.istoRepair=='转维修') {
1041
1042
  this.rowCodata = Object.assign({},this.rowCodata,codata)
@@ -9,6 +9,9 @@ let specialComp = {
9
9
  'checkpapermsg': (resolve) => { require(['./android/checkpapermsg'], resolve) },
10
10
  'safecheck-userinfo': (resolve) => { require(['./android/SafecheckUserInfo'], resolve) },
11
11
  'switch-valve': (resolve) => { require(['./android/SwitchValve'], resolve) },
12
+ 'PhoneUpUserinfo': (resolve) => { require(['./android/PhoneUpUserinfo'], resolve) },
13
+ 'add-plan-item-yy': (resolve) => { require(['./android/AddPlanItemYy'], resolve) },
14
+ 'add-plan-item-vwm': (resolve) => { require(['./android/AddPlanItemVisitingWithoutMeeting'], resolve) },
12
15
  }
13
16
 
14
17
  exports.specialComp = specialComp
@@ -212,7 +212,12 @@ div {
212
212
  </button-link>
213
213
  </td>
214
214
  </tr>
215
-
215
+ <tr>
216
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">备注:</td>
217
+ <td colspan="2" style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">
218
+ {{ data.f_repair_approved_note }}
219
+ </td>
220
+ </tr>
216
221
  </tbody>
217
222
  </table>
218
223
  <table class="table table-striped table-bordered" style="margin-top: 40px"
@@ -617,6 +622,13 @@ div {
617
622
  </button-link>
618
623
  </td>
619
624
  </tr>
625
+ <tr>
626
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">备注:</td>
627
+ <td colspan="3"
628
+ style="text-align: center;border: #E9E9E9 solid 1px;word-wrap:break-word;word-break:break-all;width:87%">
629
+ {{ paperdata.f_repair_approved_note }}
630
+ </td>
631
+ </tr>
620
632
 
621
633
  </tbody>
622
634
  </table>
@@ -0,0 +1,398 @@
1
+ <template>
2
+ <div>
3
+ <criteria-paged :model="model" v-ref:paged>
4
+ <criteria partial='criteria' @condition-changed='$parent.selfSearch' v-ref:criteria>
5
+ <div partial>
6
+ <div class="row">
7
+ <label class="form-group font_normal_body"><b>计划信息</b></label>
8
+ <div class="form-group col-sm-1" v-show="false">
9
+ <!--隐藏条件-->
10
+ <input type="text" class="input_search" v-model="model.f_plan_id"
11
+ style="width: 95%" placeholder="计划id" condition=" i.f_plan_id='{}'">
12
+ </div>
13
+ <div class="form-group col-sm-1" >
14
+ <input type="text" class="input_search" v-model="model.f_userinfo_code"
15
+ style="width: 95%" placeholder="客户编号" condition="i.f_userinfo_code='{}'">
16
+ </div>
17
+ <div class="form-group col-sm-1" >
18
+ <input type="text" class="input_search" v-model="model.f_user_name"
19
+ style="width: 95%" placeholder="客户名称" condition="i.f_user_name like '%{}%'">
20
+ </div>
21
+ <div class="form-group col-sm-1" >
22
+ <input type="text" class="input_search" v-model="model.f_address"
23
+ style="width: 95%" placeholder="客户地址" condition="i.f_address like '%{}%'">
24
+ </div>
25
+ <!--<div class="form-group col-sm-1" >
26
+ <v-select :width="'95%'"
27
+ class="select select_list"
28
+ :value.sync="$parent.$parent.f_state"
29
+ v-model="$parent.$parent.f_state"
30
+ :options='$parent.$parent.checkState'
31
+ placeholder='安检状态'
32
+ close-on-select
33
+ value-single
34
+ >
35
+ </v-select>
36
+ </div>-->
37
+ <div class="form-group col-sm-3" >
38
+ <button class="button_new" style="margin-right: 10px" @click="$parent.$parent.showUserCondition()">更多条件</button>
39
+ <button class="button_search" style="margin-right: 10px" @click="search()">查询</button>
40
+ <!-- <button class="button_search" style="margin-right: 10px" @click="clear()">清除</button>-->
41
+ <export-excel-safe :data="$parent.$parent.exportParameter"
42
+ :field="$parent.$parent.exportExcelField"
43
+ style="margin-left: 0px"
44
+ sqlurl="rs/logic/SafeExportExcel" sql-name="planItem"
45
+ :template-name="$parent.$parent.selectplan.f_plan_name + '安检计划导出'" :choose-col="true">
46
+ </export-excel-safe>
47
+ </div>
48
+ <div class="form-group col-sm-2 safe_p">
49
+ <label class="font_normal_body" :title="$parent.$parent.selectplan.f_plan_name">{{$parent.$parent.selectplan.f_plan_name?'当前选中 : '+$parent.$parent.selectplan.f_plan_name:''}}</label>
50
+ </div>
51
+ <div class="form-group col-sm-2" style="float: right">
52
+ <button class="button_search" style="margin-right: 10px" @click="$parent.$parent.showplanModal()">计划调整</button>
53
+ <button class="button_search" style="margin-right: 10px" @click="$parent.$parent.delPlanItem()" v-show="$parent.$parent.isdelete">移出计划</button>
54
+ </div>
55
+ <modal :show.sync="$parent.$parent.showCondtion" v-ref:modal :width="'50%'" :backdrop="false">
56
+ <div slot="modal-header" class="modal-header">
57
+ <h4 class="modal-title">
58
+ 计划内用户查询条件
59
+ </h4>
60
+ </div>
61
+ <div slot="modal-body" class="modal-body">
62
+ <div class="row">
63
+ <div class="form-group col-sm-4" >
64
+ <label class="font_normal_body">是否已检:</label>
65
+ <v-select
66
+ class="select select_list"
67
+ :value.sync="model.f_state"
68
+ v-model="model.f_state"
69
+ :options='$parent.$parent.checkState'
70
+ @change="$parent.$parent.checkStateChange(model.f_state)"
71
+ placeholder='请选择'
72
+ condition="i.f_state='{}'"
73
+ close-on-select
74
+ value-single
75
+ >
76
+ </v-select>
77
+ </div>
78
+ <div class="form-group col-sm-4" >
79
+ <label class="font_normal_body">安检结果:</label>
80
+ <v-select
81
+ class="select select_list"
82
+ :value.sync="model.f_check_state"
83
+ v-model="model.f_check_state"
84
+ :options='$parent.$parent.checkResults'
85
+ placeholder='请选择'
86
+ condition="i.f_last_check_state='{}'"
87
+ close-on-select
88
+ value-single
89
+ >
90
+ </v-select>
91
+ </div>
92
+ <div class="form-group col-sm-4" >
93
+ <label class="font_normal_body">安检起始:</label>
94
+ <datepicker
95
+ placeholder='请选择'
96
+ style="width:60%"
97
+ :disabled-days-of-week="[]"
98
+ :format="'yyyy-MM-dd'"
99
+ :show-rest-button="reset"
100
+ :value.sync="model.f_startfile_time"
101
+ v-model="model.f_startfile_time"
102
+ condition="i.f_last_check_date >='{} 00:00:00'">
103
+ </datepicker>
104
+ </div>
105
+ <div class="form-group col-sm-4" >
106
+ <label class="font_normal_body">安检截止:</label>
107
+ <datepicker
108
+ placeholder='请选择'
109
+ :disabled-days-of-week="[]"
110
+ style="width:60%"
111
+ :format="'yyyy-MM-dd'"
112
+ :show-rest-button="reset"
113
+ :value.sync="model.f_endfile_time"
114
+ v-model="model.f_endfile_time"
115
+ condition="i.f_last_check_date <='{} 00:00:00'">
116
+ </datepicker>
117
+ </div>
118
+ <div class="form-group col-sm-4" >
119
+ <label class="font_normal_body">小区名称:</label>
120
+ <v-select
121
+ class="select select_list"
122
+ :value.sync="model.f_residential_area"
123
+ v-model="model.f_residential_area"
124
+ :options='$parent.$parent.area'
125
+ placeholder='请选择'
126
+ condition="i.f_residential_area='{}'"
127
+ close-on-select
128
+ value-single
129
+ >
130
+ </v-select>
131
+ </div>
132
+ </div>
133
+ </div>
134
+ <div slot="modal-footer" class="modal-footer" style="text-align: center">
135
+ <button class="button_search" style="margin-right: 15px" @click="search()">查询</button>
136
+ <button class="button_search" @click="$parent.$parent.cancel">取消</button>
137
+ </div>
138
+ </modal>
139
+ </div>
140
+ </div>
141
+ </criteria>
142
+ <data-grid :model="model" partial='list' class="table_sy">
143
+
144
+ <template partial='head'>
145
+ <tr>
146
+ <th><nobr><input type="checkbox" onClick="event.cancelBubble = true" :checked="$parent.$parent.$parent.checkAll" @change="$parent.$parent.$parent.setCheckAll()"/> 全选</nobr></th>
147
+ <th><nobr>用户编号</nobr></th>
148
+ <th><nobr>用户名称</nobr></th>
149
+ <th><nobr>用户电话</nobr></th>
150
+ <th><nobr>用户类型</nobr></th>
151
+ <th><nobr>小区名称</nobr></th>
152
+ <th><nobr>安检状态</nobr></th>
153
+ <th><nobr>地址</nobr></th>
154
+ </tr>
155
+ </template>
156
+ <template partial='body'>
157
+ <td style="text-align: center;white-space:nowrap;"><input type="checkbox" onClick="event.cancelBubble = true" :checked="$parent.$parent.$parent.isChecked(row.f_check_item_id)" @change="$parent.$parent.$parent.setCheckes(row.f_check_item_id)" /></td>
158
+ <td style="text-align: center"><nobr>{{row.f_userinfo_code}}</nobr></td>
159
+ <td style="text-align: center"><nobr>{{row.f_user_name}}</nobr></td>
160
+ <td style="text-align: center"><nobr>{{row.f_user_phone}}</nobr></td>
161
+ <td style="text-align: center"><nobr>{{row.f_user_type}}</nobr></td>
162
+ <td style="text-align: center"><nobr>{{row.f_residential_area}}</nobr></td>
163
+ <td style="text-align: center"><nobr>{{row.f_state==='已检'?row.f_last_check_state:'未检'}}</nobr></td>
164
+ <td style="text-align: center"><nobr>{{row.f_address}}</nobr></td>
165
+ </template>
166
+ </data-grid>
167
+ </criteria-paged>
168
+ <modal :show.sync="showPlanModal" v-ref:modalp>
169
+ <div slot="modal-header" class="modal-header">
170
+ <h4 class="modal-title">
171
+ 计划内用户调整
172
+ </h4>
173
+ </div>
174
+ <div slot="modal-body" class="modal-body">
175
+ <plan-chooser :f.sync="userlogin.orgid" v-ref:chooser></plan-chooser>
176
+ </div>
177
+ <div slot="modal-footer" class="modal-footer" style="text-align: center">
178
+ <button class="button_search" style="margin-right: 15px" @click="dragtoOtherPlanIteem">确认</button>
179
+ <button class="button_search" @click="cancel">取消</button>
180
+ </div>
181
+ </modal>
182
+ </div>
183
+ </template>
184
+
185
+ <script>
186
+ import {HttpResetClass, PagedList} from "vue-client";
187
+ import Vue from "vue";
188
+
189
+ export default {
190
+ name: "PlanManage",
191
+ title: '计划管理',
192
+ data() {
193
+ return {
194
+ model:new PagedList('/rs/sql/planItem', 100, {}),
195
+ isdelete:this.$login.r ? this.$login.r.includes("安检计划删除"):false,
196
+ a:'1',
197
+ opt:[{label:"测试",value:"测试"}],
198
+ showCondtion:false,
199
+ checkAll:false,
200
+ checkes:[],
201
+ checkResults:[{label:'到访不遇',value:'到访不遇'},{label:'拒检',value:'拒检'},{label:'入户',value:'入户'}],
202
+ checkState:[{label:'全部',value:''},{label:'未检',value:'未检'},{label:'已检',value:'已检'}],
203
+ showPlanModal:false,
204
+ exportExcelField: {
205
+ 'f_userinfo_code':'用户编号',
206
+ 'f_user_name':'用户名称',
207
+ 'f_user_type':'用户类型',
208
+ 'f_residential_area':'小区名称',
209
+ 'f_state':'安检状态',
210
+ 'f_address':'地址',
211
+ 'f_user_phone':'用户电话',
212
+ 'f_newfile_date':'建档日期'
213
+ },
214
+ area:[]
215
+ }
216
+ },
217
+ props:["selectplan","userlogin"],
218
+ ready(){
219
+ this.getarea()
220
+ },
221
+ computed:{
222
+ exportParameter(){
223
+ // excel 导出条件拼接
224
+ return {
225
+ condition: this.$refs.paged.model.condition,
226
+ groupName: this.groupNameForSql
227
+ }
228
+ }
229
+ },
230
+ methods:{
231
+ async getarea() {
232
+ this.area = []
233
+ let res = await new HttpResetClass().load("POST", `/rs/sql/safe_singleTable_OrderBy`, {
234
+ data: {
235
+ items: "*",
236
+ tablename: "t_area",
237
+ orderitem: "id",
238
+ condition: `f_orgid = '${this.$login.f.orgid}'`
239
+ }
240
+ }, {resolveMsg: null, rejectMsg: null})
241
+ res.data.forEach((result) => {
242
+ this.area.push({label: result.f_residential_area, value: result.f_residential_area})
243
+ })
244
+ },
245
+ clear(){
246
+ this.model.f_plan_id = '';
247
+ this.model.f_userinfo_code = '';
248
+ this.model.f_user_name = '';
249
+ this.model.f_address='';
250
+
251
+ },
252
+ //将某个计划下的一项拖到另一个计划
253
+ async dragtoOtherPlanIteem() {
254
+ //tag)
255
+
256
+ if (!this.$refs.modalp.$children[0].selectedRow.id) {
257
+ this.$showMessage("请选择需要调整到那个计划中!")
258
+ return
259
+ }
260
+ this.$parent.isSend=true
261
+ try{
262
+ let res=await new HttpResetClass().load("POST", "/rs/logic/UpCheckPlanItem", {
263
+ data:{
264
+ f_operator:this.userlogin.name,
265
+ f_plan_id:this.$refs.modalp.$children[0].selectedRow.id,
266
+ condition:this.model.condition,
267
+ switchCheckAll:true,
268
+ checkAll:this.checkAll,
269
+ param:this.checkes,
270
+ columnName: "i.id"
271
+ }
272
+ }, {resolveMsg: null, rejectMsg: null})
273
+ this.$parent.isSend=false
274
+ if(res.data.code==200){
275
+ this.$showMessage("更换安检计划成功!")
276
+ this.$parent.refreshPlan()
277
+ }else{
278
+ this.$showMessage("更换安检计划失败!")
279
+ }
280
+ }catch (e) {
281
+ this.$parent.isSend=false
282
+ this.$showMessage("更换安检计划失败!")
283
+ }
284
+ },
285
+ showplanModal(){
286
+ if(!this.selectplan || !this.selectplan.id){
287
+ this.$showMessage("请先打开一个计划再进行操作")
288
+ return
289
+ }
290
+ if(!this.checkAll && this.checkes.length==0){
291
+ this.$showMessage("请先在计划中勾选你要调整的用户!")
292
+ return
293
+ }
294
+ this.showPlanModal=true
295
+ },
296
+ showUserCondition(){
297
+ this.showCondtion=true
298
+ },
299
+ isChecked(v) {
300
+ // 如果全选,不在的按选中算,否则,在的按选中算
301
+ if (this.checkAll) {
302
+ return this.checkes.indexOf(v) == -1
303
+ } else {
304
+ return this.checkes.indexOf(v) != -1
305
+ }
306
+ },
307
+ setCheckAll() {
308
+ this.checkAll=this.checkAll?false:true;
309
+ // 全选改变后,清空选中数据
310
+ this.checkes = []
311
+ },
312
+ setCheckes(id) {
313
+ let index=this.checkes.indexOf(id)
314
+ if(index<0){
315
+ this.checkes.push(id)
316
+ }else{
317
+ this.checkes.splice(index,1)
318
+ }
319
+ },
320
+ cancel(){
321
+ this.showCondtion=false
322
+ this.showPlanModal=false
323
+ },
324
+ selfSearch (args) {
325
+ if(!this.selectplan.id){
326
+ this.$showMessage("请先选择一个计划!")
327
+ return
328
+ }
329
+ this.cancel()
330
+ this.checkes=[]
331
+ this.checkAll=false
332
+ args.condition+= ` and i.f_state!= '作废'`
333
+ this.model.search(args.condition, args.model, args.condValue)
334
+ },
335
+ checkStateChange(val){
336
+ if(val=='未检'){
337
+ this.checkResults=[]
338
+ this.$refs.paged.$refs.criteria.model.f_check_state=''
339
+ }else{
340
+ this.checkResults=[{label:'到访不遇',value:'到访不遇'},{label:'拒检',value:'拒检'},{label:'入户',value:'入户'}]
341
+ }
342
+ },
343
+ //修改计划项状态为作废
344
+ async delPlanItem() {
345
+ if(!this.selectplan || !this.selectplan.id){
346
+ this.$showMessage("请先打开一个计划再进行操作")
347
+ return
348
+ }
349
+ if(!this.checkAll && this.checkes.length==0){
350
+ this.$showMessage("请先在计划中勾选你要作废的用户!")
351
+ return
352
+ }
353
+ this.$showMessage("此操作无法撤回,确定要执行作废安检单操作吗?",['confirm','cancel']).then((button)=>{
354
+ if(button=='confirm'){
355
+ let resu=new HttpResetClass().load("POST", "/rs/logic/UpCheckPlanItemState", {
356
+ data: {
357
+ f_operator:this.userlogin.name,
358
+ condition:this.model.condition,
359
+ switchCheckAll:true,
360
+ checkAll:this.checkAll,
361
+ param:this.checkes,
362
+ columnName: "i.id"
363
+ }
364
+ }, {resolveMsg: null, rejectMsg: null}).then((resu)=>{
365
+
366
+ //tag)
367
+ if(resu.data.code==200){
368
+ this.$showMessage("移除安检单成功! 成功移除:"+resu.data.res.up+"条"+(resu.data.res.noup>0?"有"+resu.data.res.noup+"条已经不是 ‘未检’ 状态!":""))
369
+ //this.checkes=[]
370
+ //this.checkAll=false
371
+ this.$parent.refresh()
372
+ }else{
373
+ this.$showMessage("取消安检计划失败!")
374
+ }
375
+ })
376
+ }
377
+ })
378
+ }
379
+ },
380
+ watch:{
381
+ 'selectplan.id' (){
382
+ //tag
383
+ if(this.selectplan.id){
384
+ this.$refs.paged.$refs.criteria.model.f_plan_id=this.selectplan.id
385
+ this.$refs.paged.$refs.criteria.search()
386
+ }
387
+ }
388
+ }
389
+ }
390
+ </script>
391
+
392
+ <style scoped>
393
+ .safe_p{
394
+ white-space: nowrap;
395
+ overflow: hidden;
396
+ text-overflow: ellipsis;
397
+ }
398
+ </style>
@@ -6,6 +6,7 @@ let specialComp = {
6
6
  // 计划管理用户
7
7
  'check-user-list': (resolve) => { require(['./pc/checkUserList'], resolve) },
8
8
  'check-search-user': (resolve) => { require(['./pc/CheckSearchUser'], resolve) },
9
+ 'check-plan-list': (resolve) => { require(['./pc/checkPlanList'], resolve) },
9
10
  // 'paper-main': (resolve) => { require(['./pc/PaperList'], resolve) },
10
11
  // 'new-check-paper': (resolve) => { require(['./pc/NewCheckpaper'], resolve) },
11
12
 
@@ -210,7 +210,8 @@ export default {
210
210
  showmOrder:false,
211
211
  zfCode:false,
212
212
  isSubmitting: false, // 添加防重复提交标志
213
- isSaveing:false // 添加防重复提交标志
213
+ isSaveing:false, // 添加防重复提交标志
214
+ isCheckingOrder: false,
214
215
  }
215
216
  },
216
217
  props: {
@@ -282,6 +283,10 @@ export default {
282
283
  closeModel(){
283
284
  this.showmOrder = false
284
285
  this.isSubmitting = false
286
+ if (this.orderInterval) {
287
+ clearTimeout(this.orderInterval)
288
+ this.orderInterval = null
289
+ }
285
290
  },
286
291
  commitBefore(){
287
292
  if (!this.model.f_money) {
@@ -333,29 +338,57 @@ export default {
333
338
  },
334
339
  async getOrderInformation() {
335
340
  console.log('查询订单信息!!!')
336
- let http = new HttpResetClass()
337
- let res = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/wx/rs/pay/microPayOrderStatus`, {
338
- "filiale": "siyang",
339
- "flag": "microPayRongHaoJsbc",
340
- "f_out_trade_no": `${this.f_out_trade_no}`,
341
- "posid": this.$androidUtil.getDeviceIEMI()
342
- }, {
343
- resolveMsg: null,
344
- rejectMsg: '订单查询失败!!!'
345
- })
346
- // 支付成功
347
- if (res.data.trade_state.includes('已支付')) {
348
- this.orderinfo = res.data
349
- clearTimeout(this.orderInterval)
350
- this.$showMessage('支付成功!!!')
351
- await this.commit()
352
- this.clearQrCode()
353
- this.closeModel()
354
- }else{
355
- //重新查询订单状态
356
- this.orderInterval = setTimeout(() => {
357
- this.getOrderInformation()
358
- }, 3000)
341
+ // 添加标志位,防止重复执行
342
+ if (this.isCheckingOrder) {
343
+ return;
344
+ }
345
+ try {
346
+ this.isCheckingOrder = true;
347
+ let http = new HttpResetClass()
348
+ let res = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/wx/rs/pay/microPayOrderStatus`, {
349
+ "filiale": "siyang",
350
+ "flag": "microPayRongHaoJsbc",
351
+ "f_out_trade_no": `${this.f_out_trade_no}`,
352
+ "posid": this.$androidUtil.getDeviceIEMI()
353
+ }, {
354
+ resolveMsg: null,
355
+ rejectMsg: '订单查询失败!!!'
356
+ })
357
+ // 支付成功
358
+ if (res.data.trade_state.includes('已支付')) {
359
+ this.orderinfo = res.data
360
+ clearTimeout(this.orderInterval)
361
+ this.$showMessage('支付成功!!!')
362
+ await this.commit()
363
+ this.clearQrCode()
364
+ this.closeModel()
365
+ } else if (res.data.trade_state.includes("已退款")) {
366
+ this.$showMessage("已退款,请重新下单支付!!!");
367
+ this.clearQrCode();
368
+ this.closeModel()
369
+ if (this.orderInterval) {
370
+ clearTimeout(this.orderInterval);
371
+ this.orderInterval = null
372
+ }
373
+ }else{
374
+ this.isCheckingOrder = false
375
+ //重新查询订单状态
376
+ this.orderInterval = setTimeout(() => {
377
+ this.getOrderInformation()
378
+ }, 3000)
379
+ }
380
+ } catch (error) {
381
+ console.error("查询订单状态失败:", error);
382
+ if (this.orderInterval) {
383
+ clearTimeout(this.orderInterval);
384
+ this.orderInterval = null
385
+ }
386
+ this.isCheckingOrder = false; // 发生错误时重置标志位
387
+ } finally {
388
+ // 确保在非轮询状态下重置标志位
389
+ if (!this.orderInterval) {
390
+ this.isCheckingOrder = false;
391
+ }
359
392
  }
360
393
  },
361
394
  async openQrcode() {