safecheck-client 3.0.33-gongyi → 3.0.35-gongyi-1

Sign up to get free protection for your applications and to get access to all the features.
@@ -20,14 +20,29 @@
20
20
  @re-res="$parent.$parent.getorg"
21
21
  :value.sync="model.f_checker_id"
22
22
  v-model="model.f_checker_id"
23
- condition="f_checker_name like '%{}%'">
23
+ condition="f_checker_name = '{}'">
24
24
  </role-selector-safe>
25
25
  </div>
26
+ <div :class="{'col-sm-3 form-group':$parent.$parent.$parent.isdetail,'col-sm-2 form-group':!$parent.$parent.$parent.isdetail}">
27
+ <label class="font_normal_body">安检科室</label>
28
+ <right-tree-safe islist :source="$parent.$parent.source" v-on:re-res="$parent.$parent.reres2" :textContent="'选择科室'" >
29
+ </right-tree-safe>
30
+ </div>
26
31
  <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
27
32
  <label class="font_normal_body">小区名称</label>
28
33
  <input type="text" class="input_search" style="width:60%" v-model="model.f_residential_area" placeholder='小区名称'
29
34
  condition="f_residential_area like '%{}%'" v-next-el="cx" v-el:qjmc>
30
35
  </div>
36
+ <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
37
+ <label class="font_normal_body">入户率 > </label>
38
+ <input type="text" class="input_search" style="width:60%" v-model="model.f_rh" placeholder='入户率'
39
+ v-next-el="cx" v-el:qjmc>
40
+ </div>
41
+ <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
42
+ <label class="font_normal_body">安检率 > </label>
43
+ <input type="text" class="input_search" style="width:60%" v-model="model.f_bv" placeholder='安检率'
44
+ v-next-el="cx" v-el:qjmc>
45
+ </div>
31
46
  <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
32
47
  <label class="font_normal_body">计划名称</label>
33
48
  <v-select class="select_list select"
@@ -41,13 +56,14 @@
41
56
  close-on-select clear-button></v-select>
42
57
 
43
58
  </div>
59
+
44
60
  <!--<div :class="{
45
61
  'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
46
62
  <label class="font_normal_body">安&ensp;检&ensp;员</label>
47
63
  <input type="text" class="input_search" style="width:60%" v-model="model.f_checker_name" placeholder='安检员'
48
64
  condition="f_checker_name like '%{}%'" v-next-el="cx" v-el:qjmc>
49
65
  </div>-->
50
- <div class="form-group col-sm-2" v-if="!$parent.$parent.$parent.isdetail"></div>
66
+ <!-- <div class="form-group col-sm-2" v-if="!$parent.$parent.$parent.isdetail"></div>-->
51
67
  <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}" style="float:right; padding-right: 25px">
52
68
  <div class="span" style="float:right;">
53
69
  <div style="float: right;margin-left:10px" class="button_spacing"
@@ -57,16 +73,34 @@
57
73
  :class="{'button_shrink_top':$parent.$parent.criteriaShow,'button_shrink_bottom':!$parent.$parent.criteriaShow}"
58
74
  @click="$parent.$parent.hidden()">
59
75
  </div>
60
- <!-- <export-excel-safe :data="$parent.$parent.exportParameter"
76
+ <export-excel-safe :data="$parent.$parent.exportParameter"
61
77
  :field="$parent.$parent.exportExcelField"
62
78
  sqlurl="rs/logic/SafeExportExcel" sql-name="getCheckPlanAreaList"
63
- template-name='安检汇总' :choose-col="true">
64
- </export-excel-safe>-->
65
- <button id="btnaaa" style="float: right" class="button_search"
79
+ template-name='安检汇总' :choose-col="true"
80
+ >
81
+ </export-excel-safe>
82
+ <button id="btnaaa" style="float: right;margin: 0px -140px 0px;position: fixed;" class="button_search"
66
83
  @click="$parent.$parent.getGroupName1(),search(),$parent.$parent.getexportExcelField(),$parent.$parent.$parent.isdetail=false,$parent.$parent.listflag=false"
67
84
  v-el:cx>查询</button>
85
+
68
86
  </div>
69
87
  </div>
88
+
89
+ <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}" v-if="$parent.$parent.criteriaShow">
90
+ <label class="font_normal_body">用户类型</label>
91
+ <v-select id="f_usertype"
92
+ placeholder='用户类型'
93
+ class="select select_list"
94
+ :value.sync="model.f_usertype"
95
+ :value-single="true"
96
+ :options='$parent.$parent.usertypes'
97
+ v-model="model.f_usertype"
98
+ condition="f_user_type='{}'"
99
+ close-on-select clear-button>
100
+ </v-select>
101
+ </div>
102
+
103
+
70
104
  <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}" v-if="$parent.$parent.criteriaShow">
71
105
  <label class="font_normal_body">起始时间</label>
72
106
  <datepicker
@@ -103,6 +137,8 @@
103
137
  <label for="f_plan_name">计划名称</label>
104
138
  <input type="checkbox" id="f_checker_name" value="f_checker_name" v-model="$parent.$parent.nameForSql"/>
105
139
  <label for="f_checker_name">安检员</label>
140
+ <input type="checkbox" id="f_dep" value="f_dep" v-model="$parent.$parent.nameForSql"/>
141
+ <label for="f_plan_name">安检科室</label>
106
142
  <input type="checkbox" id="f_user_number" value="f_user_number" v-model="$parent.$parent.nameForSql"/>
107
143
  <label for="f_checker_name">档案数量</label>
108
144
  </div>
@@ -121,6 +157,7 @@
121
157
  <th v-if="$parent.$parent.$parent.nameForSql.includes('f_residential_area')"><nobr>小区名称</nobr></th>
122
158
  <th v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_name')"><nobr>计划名称</nobr></th>
123
159
  <th v-if="$parent.$parent.$parent.nameForSql.includes('f_checker_name')"><nobr>安检员</nobr></th>
160
+ <th v-if="$parent.$parent.$parent.nameForSql.includes('f_dep')"><nobr>安检科室</nobr></th>
124
161
  <th v-if="$parent.$parent.$parent.nameForSql.includes('f_user_number')"><nobr>档案数量</nobr></th>
125
162
  <th>
126
163
  <nobr>计划总数</nobr>
@@ -140,6 +177,9 @@
140
177
  <th>
141
178
  <nobr>拒检</nobr>
142
179
  </th>
180
+ <th>
181
+ <nobr>入户率</nobr>
182
+ </th>
143
183
  <th>
144
184
  <nobr>安检率</nobr>
145
185
  </th>
@@ -156,6 +196,7 @@
156
196
  <td style="text-align:center" :class="{'td-0':row.f_residential_area==undefined,'td-1':model.rows.length!=($index+1)&&row.f_residential_area.indexOf('*&')==-1,'td-2':model.rows.length!=($index+1)&&row.f_residential_area.indexOf('*&')!=-1,'td-3':model.rows.length==($index+1)&&row.f_residential_area.indexOf('*&')!=-1,'td-4':model.rows.length==($index+1)&&row.f_residential_area.indexOf('*&')==-1}" v-if="$parent.$parent.$parent.nameForSql.includes('f_residential_area')">{{row.f_residential_area.indexOf('*&')!=-1?'':row.f_residential_area}}</td>
157
197
  <td style="text-align:center" :class="{'td-0':row.f_plan_name==undefined,'td-1':model.rows.length!=($index+1)&&row.f_plan_name.indexOf('*&')==-1,'td-2':model.rows.length!=($index+1)&&row.f_plan_name.indexOf('*&')!=-1,'td-3':model.rows.length==($index+1)&&row.f_plan_name.indexOf('*&')!=-1,'td-4':model.rows.length==($index+1)&&row.f_plan_name.indexOf('*&')==-1}" v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_name')">{{row.f_plan_name.indexOf('*&')!=-1?'':row.f_plan_name}}</td>
158
198
  <td style="text-align:center" :class="{'td-0':row.f_checker_name==undefined,'td-1':model.rows.length!=($index+1)&&row.f_checker_name.indexOf('*&')==-1,'td-2':model.rows.length!=($index+1)&&row.f_checker_name.indexOf('*&')!=-1,'td-3':model.rows.length==($index+1)&&row.f_checker_name.indexOf('*&')!=-1,'td-4':model.rows.length==($index+1)&&row.f_checker_name.indexOf('*&')==-1}" v-if="$parent.$parent.$parent.nameForSql.includes('f_checker_name')">{{row.f_checker_name.indexOf('*&')!=-1?'':row.f_checker_name}}</td>
199
+ <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_dep')">{{row.f_dep}}</td>
159
200
  <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_user_number')">{{row.f_user_number}}</td>
160
201
  <td style="text-align:center">{{row.f_plan_total}}</td>
161
202
  <td style="text-align:center">{{row.f_weijian}}</td>
@@ -163,6 +204,7 @@
163
204
  <td style="text-align:center"><nobr>{{row.f_ruhu}}</nobr></td>
164
205
  <td style="text-align:center">{{row.f_buyu}}</td>
165
206
  <td style="text-align:center"><nobr>{{row.f_jujian}}</nobr></td>
207
+ <td style="text-align:center"><nobr>{{row.f_check_rhbv}}</nobr></td>
166
208
  <td style="text-align:center"><nobr>{{row.f_check_bv}}</nobr></td>
167
209
  <!--<td style="text-align: center;">-->
168
210
  <!--<button class="btn btn-link" @click.stop="$parent.$parent.$parent.showhistory(row)">查看</button>-->
@@ -184,13 +226,17 @@
184
226
  export default {
185
227
  data () {
186
228
  return {
187
- model: new PagedList('rs/sql/getCheckPlanAreaList', 99999),
229
+ model: new PagedList('rs/sql/getCheckPlanAreaList',99999),
230
+ usertypes: this.usertypes(),
188
231
  // 公司下拉
189
232
  curorgid: [this.$login.f.orgid],
190
233
  row: {},
191
234
  f_orgid: '',
192
235
  nameForSql: [],
193
236
  groupNameForSql: '',
237
+ source:
238
+ 'dep=this.getParentByType($organization$).getSpecialResByType($department$),' +
239
+ 'tool.getFullTree(dep.where(row.hasSpecialRole($安检册二次分配$)))',
194
240
  listflag:false,
195
241
  nameflag:false,
196
242
  criteriaShow: false,
@@ -223,6 +269,24 @@
223
269
 
224
270
  },
225
271
  methods: {
272
+ usertypes () {
273
+ return this.$appdata.getParam('用户类型') ? [{
274
+ label: '全部',
275
+ value: ''
276
+ }, ...this.$appdata.getParam('用户类型')] : [{label: '全部', value: ''}]
277
+ },
278
+ reres2(val){
279
+ if (!val.resids || val.resids.length === 0 || val.resids[0] ==='undefined' || !val.resids[0] || val.resids.length>1){
280
+ console.log('未选择',val)
281
+ this.f_dep = ''
282
+ return
283
+ }
284
+ console.log('val2',val)
285
+ const resids = val.orgobj.filter(res=>res.resourcetype==='department')
286
+ if (resids.length>0){
287
+ this.f_dep = resids[0].name
288
+ }
289
+ },
226
290
  // 获取导出列
227
291
  getexportExcelField(){
228
292
  this.exportExcelField = {
@@ -248,6 +312,9 @@
248
312
  }
249
313
  if (ff==='f_checker_name') {
250
314
  this.exportExcelField.f_checker_name='安检员'
315
+ }
316
+ if (ff==='f_dep') {
317
+ this.exportExcelField.f_dep='安检科室'
251
318
  }if (ff==='f_residential_area') {
252
319
  this.exportExcelField.f_checker_name='小区名称'
253
320
  }if (ff==='f_user_number') {
@@ -302,19 +369,24 @@
302
369
  if(this.f_check_end){
303
370
  args.condition += ` and f_year<=${new Date(this.f_check_end).getFullYear()} and f_month<=${new Date(this.f_check_end).getMonth()+1} `
304
371
  }
372
+ if(this.f_dep){
373
+ args.condition += ` and f_dep = '${this.f_dep}'`
374
+ }
375
+ this.model.f_bv=this.$refs.paged.$refs.cri.model.f_bv?this.$refs.paged.$refs.cri.model.f_bv:''
376
+ this.model.f_rh=this.$refs.paged.$refs.cri.model.f_rh?this.$refs.paged.$refs.cri.model.f_rh:''
305
377
  this.$refs.paged.$refs.grid.$el.scrollTop = 0
306
378
  if (this.groupNameForSql=='undefined'){
307
379
  console.log("777777777")
308
380
  this.$showMessage("请至少选择一项进行汇总")
309
381
  return
310
382
  }
311
- this.model.paramSource = {groupName: `'${this.groupNameForSql}'`}
383
+ this.model.paramSource = {groupName: `'${this.groupNameForSql}'`,f_rh: 'this.f_rh',f_bv: 'this.f_bv'}
312
384
  this.model.search(args.condition, args.model)
313
385
  },
314
386
 
315
387
  // 拼接groupName1
316
388
  getGroupName1 () {
317
- var temp=['f_plan_month','f_no_checkplan','f_residential_area','f_plan_name','f_checker_name','f_user_number']
389
+ var temp=['f_plan_month','f_no_checkplan','f_residential_area','f_plan_name','f_checker_name','f_dep','f_user_number']
318
390
  var newtemp=[]
319
391
 
320
392
  for (var i=0;i<temp.length;i++){
@@ -107,7 +107,7 @@
107
107
  <td style="text-align:center;white-space: nowrap;">{{row.f_address}}</td>
108
108
  <td style="text-align:center">{{row.f_state}}</td>
109
109
  <td style="text-align:center">{{row.f_entry_status}}</td>
110
- <td style="text-align:center">{{row.f_offsite_time}}</td>
110
+ <td style="text-align:center">{{row.f_upload_date}}</td>
111
111
  <td style="text-align:center">{{row.f_defect_content}}</td>
112
112
  <td style="text-align:center">{{row.f_check_number}}</td>
113
113
  </tr>
@@ -199,7 +199,8 @@
199
199
  'checkrow' () {
200
200
  this.search()
201
201
  }
202
- },computed: {
202
+ },
203
+ computed: {
203
204
  // 导出到Excel的条件构造
204
205
  exportParameter() {
205
206
  return {
@@ -37,6 +37,64 @@
37
37
  :show-reset-button="reset">
38
38
  </datepicker>
39
39
  </div>
40
+
41
+
42
+
43
+ <div class="col-sm-2 form-group">
44
+ <label class="font_normal_body">气表类型</label>
45
+ <v-select class="select_list select"
46
+ placeholder='请选择' style="width: 60%"
47
+ :value.sync="model.meter_classify" v-model="model.meter_classify"
48
+ :options='$parent.$parent.meter_classifys'
49
+ filer-key="name"
50
+ close-on-select clear-button
51
+ condition="F_METER_CLASSIFY='{}'"
52
+ :value-single="true">
53
+ </v-select>
54
+ </div>
55
+ <div class="form-group col-sm-2">
56
+ <label class="font_normal_body">安装位置</label>
57
+ <v-select class="select_list select"
58
+ placeholder='请选择' style="width: 60%"
59
+ :value.sync="model.f_position" v-model="model.f_position"
60
+ :options='$parent.$parent.positions'
61
+ filer-key="name"
62
+ close-on-select clear-button
63
+ condition="f_position='{}'"
64
+ :value-single="true">
65
+ </v-select>
66
+ </div>
67
+ <div class="form-group col-sm-2" >
68
+ <label class="font_normal_body">房屋类型</label>
69
+ <v-select class="select_list select"
70
+ placeholder='请选择' style="width: 60%"
71
+ :value.sync="model.f_house_type" v-model="model.f_house_type"
72
+ :options='$parent.$parent.housetype'
73
+ filer-key="name"
74
+ close-on-select clear-button
75
+ condition="f_house_type='{}'"
76
+ :value-single="true">
77
+ </v-select>
78
+ </div>
79
+ <div class="form-group col-sm-2">
80
+ <label class="font_normal_body">安检科室</label>
81
+ <right-tree-safe islist :source="$parent.$parent.source" v-on:re-res="$parent.$parent.reres2" :textContent="'选择科室'" >
82
+ </right-tree-safe>
83
+ </div>
84
+ <div class="form-group col-sm-2">
85
+ <label class="font_normal_body">用户类型</label>
86
+ <v-select
87
+ placeholder='用户类型'
88
+ class="select select_list"
89
+ :value.sync="model.f_usertype"
90
+ :value-single="true"
91
+ :options='$parent.$parent.userTypes'
92
+ v-model="model.f_usertype"
93
+ condition="f_check_type='{}'"
94
+ close-on-select clear-button></v-select>
95
+ </div>
96
+
97
+
40
98
  <div class="col-sm-3 form-group" style="margin-top: 8px">
41
99
  <button class="button_search button_spacing" @click="search()">查询</button>
42
100
  <report-print class="button_export button_spacing" style="width:28%" id='shexian'></report-print>
@@ -82,20 +140,60 @@
82
140
  let model = new DataModel('rs/report/hiddensituation', {startDate: 'this.model.startDate', endDate: 'this.model.endDate', f_filialeid: 'this.f_filialeid'})
83
141
  model.f_filialeid = '(' + this.$login.f.orgid + ')'
84
142
  return {
143
+ userTypes: [],
85
144
  filialeNameStr: '',
86
145
  filialeCodeStr: '',
87
146
  userid: this.$login.f.id,
88
- source: `tool.getFullTree(this.getRights().where(row.getType() != $zone$).where(row.getType() == $organization$))`,
89
- model: model
147
+ // source: `tool.getFullTree(this.getRights().where(row.getType() != $zone$).where(row.getType() == $organization$))`,
148
+ model: model,
149
+ positions: [],
150
+ housetype: [],
151
+ source:
152
+ 'dep=this.getParentByType($organization$).getSpecialResByType($department$),' +
153
+ 'tool.getFullTree(dep.where(row.hasSpecialRole($安检册二次分配$)))',
154
+ meter_classifys:[]//气表类型
90
155
  }
91
156
  },
92
157
  methods: {
158
+ reres2(val){
159
+ if (!val.resids || val.resids.length === 0 || val.resids[0] ==='undefined' || !val.resids[0] || val.resids.length>1){
160
+ console.log('未选择',val)
161
+ this.f_dep = ''
162
+ return
163
+ }
164
+ console.log('val2',val)
165
+ const resids = val.orgobj.filter(res=>res.resourcetype==='department')
166
+ if (resids.length>0){
167
+ this.f_dep = resids[0].name
168
+ }
169
+ },
93
170
  getRes(obj) {
94
171
  this.model.f_filialeid = this.$login.convertToIn(obj.resids);
95
172
  console.log(this.model.f_filialeid)
96
173
  },
174
+ setConList(){
175
+ this.userTypes=this.$appdata.getParam('用户类型') ? [{
176
+ label: '全部',
177
+ value: ''
178
+ }, ...this.$appdata.getParam('用户类型')] : [{label: '全部', value: ''}]
179
+
180
+ this.meter_classifys=this.$appdata.getParam('气表类型') ? [{
181
+ label: '全部',
182
+ value: ''
183
+ }, ...this.$appdata.getParam('气表类型')] : [{label: '全部', value: ''}]
184
+
185
+ this.positions=this.$appdata.getParam('安装位置') ? [{
186
+ label: '全部',
187
+ value: ''
188
+ }, ...this.$appdata.getParam('安装位置')] : [{label: '全部', value: ''}]
189
+ this.housetype=this.$appdata.getParam('房屋类型') ? [{
190
+ label: '全部',
191
+ value: ''
192
+ }, ...this.$appdata.getParam('房屋类型')] : [{label: '全部', value: ''}]
193
+ },
97
194
  },
98
195
  ready() {
196
+ this.setConList()
99
197
  },
100
198
  computed: {
101
199
  selected() {
package/src/safecheck.js CHANGED
@@ -589,7 +589,7 @@ export default function (filiale) {
589
589
  require(['./components/defect/DefectListWeixiu'], resolve)
590
590
  })
591
591
  // 隐患查看
592
- Vue.component('defect-main-weixiu', (resolve) => {
592
+ Vue.component('defect-main-new', (resolve) => {
593
593
  require(['./components/defect/DefectMainWeixiu'], resolve)
594
594
  })
595
595
  // 隐患详情