safecheck-client 3.0.35-29 → 3.0.35-30

Sign up to get free protection for your applications and to get access to all the features.
Files changed (247) hide show
  1. package/.babelrc +5 -5
  2. package/.editorconfig +9 -9
  3. package/android.html +18 -18
  4. package/config/dev.env.js +6 -6
  5. package/config/index.js +38 -38
  6. package/config/prod.env.js +3 -3
  7. package/config/test.env.js +6 -6
  8. package/docs/AppBase.md +22 -22
  9. package/docs/Busy.md +14 -14
  10. package/docs/CriteriaPaged.md +47 -47
  11. package/docs/DataGrid.md +54 -54
  12. package/docs/DataModel.md +22 -22
  13. package/docs/Dynamic.md +42 -42
  14. package/docs/GetParams.md +11 -11
  15. package/docs/HttpBusy.md +13 -13
  16. package/docs/HttpStore.md +29 -29
  17. package/docs/MessageBox.md +28 -28
  18. package/docs/PagedList.md +29 -29
  19. package/docs/Pager.md +21 -21
  20. package/docs/Project.md +23 -23
  21. package/docs/Route.md +105 -105
  22. package/docs/SafetyCheck/AdjustPlan.md +13 -13
  23. package/docs/SafetyCheck/CheckerPlan.md +12 -12
  24. package/docs/Task.md +46 -46
  25. package/docs/TreeList.md +28 -28
  26. package/docs/TreeMixin.md +18 -18
  27. package/docs/all.md +10 -10
  28. package/docs/list.md +42 -42
  29. package/docs/partial.md +75 -75
  30. package/docs/selector.md +82 -82
  31. package/docs//345/274/200/345/217/221/346/226/207/346/241/243/Snippets.md +28 -28
  32. package/docs//345/274/200/345/217/221/346/226/207/346/241/243/vue-strap/345/217/230/346/233/264/350/256/260/345/275/225.md +7 -7
  33. package/docs//345/274/200/345/217/221/346/226/207/346/241/243/vue/345/217/230/346/233/264/350/256/260/345/275/225.md +13 -13
  34. package/docs//345/274/200/345/217/221/346/226/207/346/241/243//345/274/200/345/217/221/347/216/257/345/242/203/350/256/276/347/275/256.md +77 -77
  35. package/docs//347/225/214/351/235/242/345/210/266/344/275/234/350/247/204/350/214/203.md +54 -54
  36. package/examples/AddressList/App.vue +13 -13
  37. package/examples/AddressList/index.html +11 -11
  38. package/examples/DispatchList/App.vue +10 -10
  39. package/examples/DispatchList/BaseTree.vue +13 -13
  40. package/examples/DispatchList/Init.vue +22 -22
  41. package/examples/DispatchList/Test.vue +20 -20
  42. package/examples/DispatchList/index.html +11 -11
  43. package/examples/DispatchList/main.js +18 -18
  44. package/home.html +16 -16
  45. package/package.json +1 -1
  46. package/publish.bat +7 -7
  47. package/release.bat +5 -5
  48. package/src/Widget.vue +13 -13
  49. package/src/android-bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  50. package/src/android-bootstrap/less/.csscomb.json +304 -304
  51. package/src/android-bootstrap/less/.csslintrc +19 -19
  52. package/src/android-bootstrap/less/alerts.less +73 -73
  53. package/src/android-bootstrap/less/badges.less +66 -66
  54. package/src/android-bootstrap/less/bootstrap.less +56 -56
  55. package/src/android-bootstrap/less/breadcrumbs.less +26 -26
  56. package/src/android-bootstrap/less/button-groups.less +247 -247
  57. package/src/android-bootstrap/less/buttons.less +173 -173
  58. package/src/android-bootstrap/less/carousel.less +269 -269
  59. package/src/android-bootstrap/less/close.less +34 -34
  60. package/src/android-bootstrap/less/code.less +69 -69
  61. package/src/android-bootstrap/less/component-animations.less +33 -33
  62. package/src/android-bootstrap/less/grid.less +84 -84
  63. package/src/android-bootstrap/less/input-groups.less +167 -167
  64. package/src/android-bootstrap/less/jumbotron.less +52 -52
  65. package/src/android-bootstrap/less/labels.less +64 -64
  66. package/src/android-bootstrap/less/list-group.less +141 -141
  67. package/src/android-bootstrap/less/media.less +66 -66
  68. package/src/android-bootstrap/less/mixins/alerts.less +14 -14
  69. package/src/android-bootstrap/less/mixins/background-variant.less +9 -9
  70. package/src/android-bootstrap/less/mixins/border-radius.less +18 -18
  71. package/src/android-bootstrap/less/mixins/buttons.less +69 -69
  72. package/src/android-bootstrap/less/mixins/center-block.less +7 -7
  73. package/src/android-bootstrap/less/mixins/clearfix.less +22 -22
  74. package/src/android-bootstrap/less/mixins/forms.less +90 -90
  75. package/src/android-bootstrap/less/mixins/gradients.less +59 -59
  76. package/src/android-bootstrap/less/mixins/grid-framework.less +92 -92
  77. package/src/android-bootstrap/less/mixins/grid.less +122 -122
  78. package/src/android-bootstrap/less/mixins/hide-text.less +21 -21
  79. package/src/android-bootstrap/less/mixins/image.less +33 -33
  80. package/src/android-bootstrap/less/mixins/labels.less +12 -12
  81. package/src/android-bootstrap/less/mixins/list-group.less +30 -30
  82. package/src/android-bootstrap/less/mixins/nav-divider.less +10 -10
  83. package/src/android-bootstrap/less/mixins/nav-vertical-align.less +9 -9
  84. package/src/android-bootstrap/less/mixins/opacity.less +8 -8
  85. package/src/android-bootstrap/less/mixins/pagination.less +24 -24
  86. package/src/android-bootstrap/less/mixins/panels.less +24 -24
  87. package/src/android-bootstrap/less/mixins/progress-bar.less +10 -10
  88. package/src/android-bootstrap/less/mixins/reset-filter.less +8 -8
  89. package/src/android-bootstrap/less/mixins/reset-text.less +18 -18
  90. package/src/android-bootstrap/less/mixins/resize.less +6 -6
  91. package/src/android-bootstrap/less/mixins/responsive-visibility.less +15 -15
  92. package/src/android-bootstrap/less/mixins/size.less +10 -10
  93. package/src/android-bootstrap/less/mixins/tab-focus.less +9 -9
  94. package/src/android-bootstrap/less/mixins/table-row.less +44 -44
  95. package/src/android-bootstrap/less/mixins/text-emphasis.less +9 -9
  96. package/src/android-bootstrap/less/mixins/text-overflow.less +8 -8
  97. package/src/android-bootstrap/less/mixins/vendor-prefixes.less +227 -227
  98. package/src/android-bootstrap/less/mixins.less +40 -40
  99. package/src/android-bootstrap/less/modals.less +151 -151
  100. package/src/android-bootstrap/less/navbar.less +660 -660
  101. package/src/android-bootstrap/less/navs.less +290 -290
  102. package/src/android-bootstrap/less/normalize.less +424 -424
  103. package/src/android-bootstrap/less/pager.less +76 -76
  104. package/src/android-bootstrap/less/pagination.less +89 -89
  105. package/src/android-bootstrap/less/panels.less +274 -274
  106. package/src/android-bootstrap/less/popovers.less +131 -131
  107. package/src/android-bootstrap/less/print.less +101 -101
  108. package/src/android-bootstrap/less/progress-bars.less +87 -87
  109. package/src/android-bootstrap/less/responsive-embed.less +35 -35
  110. package/src/android-bootstrap/less/responsive-utilities.less +194 -194
  111. package/src/android-bootstrap/less/scaffolding.less +161 -161
  112. package/src/android-bootstrap/less/tables.less +262 -262
  113. package/src/android-bootstrap/less/theme.less +291 -291
  114. package/src/android-bootstrap/less/thumbnails.less +36 -36
  115. package/src/android-bootstrap/less/tooltip.less +102 -102
  116. package/src/android-bootstrap/less/type.less +303 -303
  117. package/src/android-bootstrap/less/utilities.less +55 -55
  118. package/src/android-bootstrap/less/variables.less +896 -896
  119. package/src/android-bootstrap/less/wells.less +29 -29
  120. package/src/androidTest.js +20 -20
  121. package/src/bootstrap/less/.csscomb.json +304 -304
  122. package/src/bootstrap/less/.csslintrc +19 -19
  123. package/src/bootstrap/less/alerts.less +73 -73
  124. package/src/bootstrap/less/badges.less +66 -66
  125. package/src/bootstrap/less/breadcrumbs.less +26 -26
  126. package/src/bootstrap/less/button-groups.less +247 -247
  127. package/src/bootstrap/less/buttons.less +172 -172
  128. package/src/bootstrap/less/carousel.less +269 -269
  129. package/src/bootstrap/less/close.less +34 -34
  130. package/src/bootstrap/less/code.less +69 -69
  131. package/src/bootstrap/less/component-animations.less +33 -33
  132. package/src/bootstrap/less/dropdowns.less +216 -216
  133. package/src/bootstrap/less/forms.less +626 -626
  134. package/src/bootstrap/less/grid.less +84 -84
  135. package/src/bootstrap/less/input-groups.less +167 -167
  136. package/src/bootstrap/less/jumbotron.less +52 -52
  137. package/src/bootstrap/less/labels.less +64 -64
  138. package/src/bootstrap/less/list-group.less +141 -141
  139. package/src/bootstrap/less/media.less +66 -66
  140. package/src/bootstrap/less/mixins/alerts.less +14 -14
  141. package/src/bootstrap/less/mixins/background-variant.less +9 -9
  142. package/src/bootstrap/less/mixins/border-radius.less +18 -18
  143. package/src/bootstrap/less/mixins/buttons.less +69 -69
  144. package/src/bootstrap/less/mixins/center-block.less +7 -7
  145. package/src/bootstrap/less/mixins/clearfix.less +22 -22
  146. package/src/bootstrap/less/mixins/forms.less +90 -90
  147. package/src/bootstrap/less/mixins/gradients.less +59 -59
  148. package/src/bootstrap/less/mixins/grid-framework.less +92 -92
  149. package/src/bootstrap/less/mixins/grid.less +122 -122
  150. package/src/bootstrap/less/mixins/hide-text.less +21 -21
  151. package/src/bootstrap/less/mixins/image.less +33 -33
  152. package/src/bootstrap/less/mixins/labels.less +12 -12
  153. package/src/bootstrap/less/mixins/list-group.less +30 -30
  154. package/src/bootstrap/less/mixins/nav-divider.less +10 -10
  155. package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
  156. package/src/bootstrap/less/mixins/opacity.less +8 -8
  157. package/src/bootstrap/less/mixins/pagination.less +24 -24
  158. package/src/bootstrap/less/mixins/panels.less +24 -24
  159. package/src/bootstrap/less/mixins/progress-bar.less +10 -10
  160. package/src/bootstrap/less/mixins/reset-filter.less +8 -8
  161. package/src/bootstrap/less/mixins/reset-text.less +18 -18
  162. package/src/bootstrap/less/mixins/resize.less +6 -6
  163. package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
  164. package/src/bootstrap/less/mixins/size.less +10 -10
  165. package/src/bootstrap/less/mixins/tab-focus.less +9 -9
  166. package/src/bootstrap/less/mixins/table-row.less +44 -44
  167. package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
  168. package/src/bootstrap/less/mixins/text-overflow.less +8 -8
  169. package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
  170. package/src/bootstrap/less/mixins.less +40 -40
  171. package/src/bootstrap/less/modals.less +151 -151
  172. package/src/bootstrap/less/navbar.less +660 -660
  173. package/src/bootstrap/less/normalize.less +424 -424
  174. package/src/bootstrap/less/pager.less +76 -76
  175. package/src/bootstrap/less/pagination.less +89 -89
  176. package/src/bootstrap/less/panels.less +275 -275
  177. package/src/bootstrap/less/popovers.less +131 -131
  178. package/src/bootstrap/less/print.less +101 -101
  179. package/src/bootstrap/less/progress-bars.less +87 -87
  180. package/src/bootstrap/less/responsive-embed.less +35 -35
  181. package/src/bootstrap/less/responsive-utilities.less +194 -194
  182. package/src/bootstrap/less/scaffolding.less +161 -161
  183. package/src/bootstrap/less/theme.less +291 -291
  184. package/src/bootstrap/less/thumbnails.less +36 -36
  185. package/src/bootstrap/less/tooltip.less +102 -102
  186. package/src/bootstrap/less/type.less +303 -303
  187. package/src/bootstrap/less/utilities.less +55 -55
  188. package/src/bootstrap/less/wells.less +29 -29
  189. package/src/components/FileUpload.vue +696 -696
  190. package/src/components/Hello.vue +39 -39
  191. package/src/components/LeftTree.vue +27 -27
  192. package/src/components/android/AddressList.vue +61 -61
  193. package/src/components/android/AttendanceTally.vue +116 -116
  194. package/src/components/android/Blank.vue +10 -10
  195. package/src/components/android/CheckUnplanPage.vue +56 -56
  196. package/src/components/android/Checker.vue +12 -12
  197. package/src/components/android/CheckerAnnual.vue +81 -81
  198. package/src/components/android/CheckerAvarta.vue +82 -82
  199. package/src/components/android/EquipmentInspection.vue +348 -348
  200. package/src/components/android/FootprintMap.vue +120 -120
  201. package/src/components/android/HiddentroubleInvestigation.vue +192 -192
  202. package/src/components/android/MasterMain.vue +77 -77
  203. package/src/components/android/Menu.vue +132 -132
  204. package/src/components/android/NavBottom.vue +157 -157
  205. package/src/components/android/PaperAlarm.vue +85 -85
  206. package/src/components/android/PaperDeviceNoncivil.vue +214 -214
  207. package/src/components/android/PlumberAnnual.vue +83 -83
  208. package/src/components/android/PlumberAnnualDetail.vue +65 -65
  209. package/src/components/android/PlumberMonthly.vue +84 -84
  210. package/src/components/android/PostMap.vue +83 -83
  211. package/src/components/android/QueryCheckHistory.vue +122 -122
  212. package/src/components/android/QueryCheckHistoryItem.vue +62 -62
  213. package/src/components/android/RepairMain.vue +60 -60
  214. package/src/components/android/Repairman.vue +12 -12
  215. package/src/components/android/StationMaster.vue +12 -12
  216. package/src/components/defects/DefectModal.vue +101 -101
  217. package/src/components/defects/DevicesAndItem.vue +39 -39
  218. package/src/components/issueplan/IssuePlanMain.vue +23 -23
  219. package/src/components/notice/NoticeForm.vue +100 -100
  220. package/src/components/notice/NoticeIssue.vue +20 -20
  221. package/src/components/paper/PicViewer.vue +18 -18
  222. package/src/components/phonestate/MonthlyTraffic.vue +66 -66
  223. package/src/components/phonestate/MonthlyTrafficRouter.vue +15 -15
  224. package/src/components/phonestate/PostMap.vue +82 -82
  225. package/src/components/planmanage/PlanManage.vue +888 -888
  226. package/src/components/querycheckpaper/PaperItem.vue +59 -59
  227. package/src/components/report/CheckPlanAreaList.vue +505 -505
  228. package/src/components/rongcheng/CheckSearchUser.vue +936 -936
  229. package/src/components/userfile/MeterFile.vue +145 -145
  230. package/src/components/userfile/MeterModify.vue +46 -46
  231. package/src/components/userfileaudit/MeterAuditFile.vue +129 -129
  232. package/src/filiale/huaran/pc/PlanManage.vue +934 -934
  233. package/src/filiale/huaran/pc/checkUserList.vue +900 -900
  234. package/src/filiale/huaran/pc.js +28 -28
  235. package/src/main.js +33 -33
  236. package/src/plugins/LoadData.js +10 -10
  237. package/src/plugins/LoadParams.js +24 -24
  238. package/src/stores/wxconfig.js +10 -10
  239. package/src/utils/getNowDate.js +33 -33
  240. package/test/e2e/custom-assertions/elementCount.js +26 -26
  241. package/test/e2e/nightwatch.conf.js +40 -40
  242. package/test/e2e/runner.js +30 -30
  243. package/test/e2e/specs/test.js +13 -13
  244. package/test/unit/.eslintrc +5 -5
  245. package/test/unit/TestUtil.js +62 -62
  246. package/test/unit/context.html +20 -20
  247. package/test/unit/index.js +13 -13
@@ -1,505 +1,505 @@
1
- <template>
2
- <div class="flex">
3
- <criteria-paged :model="model" v-ref:paged :pager="false">
4
- <criteria partial='criteria' @condition-changed='$parent.selfSearch' v-ref:cri>
5
- <div novalidate class="form-horizontal select-overspread container-fluid auto" partial>
6
- <div class="row">
7
- <!--<div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
8
- <label class="font_normal_body">组织机构</label>
9
- <res-select restype='organization'
10
- class="select select_list"
11
- style="width: 60%"
12
- @res-select="$parent.$parent.getorg"
13
- :initresid='$parent.$parent.curorgid'>
14
- </res-select>
15
- </div>-->
16
- <div :class="{'col-sm-6':$parent.$parent.$parent.isdetail,'col-sm-4':!$parent.$parent.$parent.isdetail}">
17
- <role-selector-safe
18
- role-name="安检员"
19
- role-lable="安&ensp;检&ensp;员"
20
- @re-res="$parent.$parent.getorg"
21
- :value.sync="model.f_checker_id"
22
- v-model="model.f_checker_id"
23
- condition="f_checker_name like '%{}%'">
24
- </role-selector-safe>
25
- </div>
26
- <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
27
- <label class="font_normal_body">小区名称</label>
28
- <input type="text" class="input_search" style="width:60%" v-model="model.f_residential_area" placeholder='小区名称'
29
- condition="f_residential_area like '%{}%'" v-next-el="cx" v-el:qjmc>
30
- </div>
31
- <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
32
- <label class="font_normal_body">计划名称</label>
33
- <v-select class="select_list select"
34
- placeholder='计划名称' style="width: 60%"
35
- :search="true"
36
- v-model="model.f_plan_name"
37
- :value.sync="model.f_plan_name"
38
- :options='$parent.$parent.planName'
39
- condition="f_plan_id = '{}'"
40
- :value-single="true"
41
- close-on-select clear-button></v-select>
42
-
43
- </div>
44
- <!--<div :class="{
45
- 'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
46
- <label class="font_normal_body">安&ensp;检&ensp;员</label>
47
- <input type="text" class="input_search" style="width:60%" v-model="model.f_checker_name" placeholder='安检员'
48
- condition="f_checker_name like '%{}%'" v-next-el="cx" v-el:qjmc>
49
- </div>-->
50
- <div class="form-group col-sm-2" v-if="!$parent.$parent.$parent.isdetail"></div>
51
- <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
- <div class="span" style="float:right;">
53
- <div style="float: right;margin-left:10px" class="button_spacing"
54
- :class="{'button_shrink_left':!$parent.$parent.$parent.isdetail,'button_shrink_right':$parent.$parent.$parent.isdetail}"
55
- @click="$parent.$parent.hiddenr()"></div>
56
- <div class="button_spacing" style="float: right;margin-left:10px"
57
- :class="{'button_shrink_top':$parent.$parent.criteriaShow,'button_shrink_bottom':!$parent.$parent.criteriaShow}"
58
- @click="$parent.$parent.hidden()">
59
- </div>
60
- <!-- <export-excel-safe :data="$parent.$parent.exportParameter"
61
- :field="$parent.$parent.exportExcelField"
62
- sqlurl="rs/logic/SafeExportExcel" sql-name="getCheckPlanAreaList"
63
- template-name='安检汇总' :choose-col="true">
64
- </export-excel-safe>-->
65
- <button id="btnaaaa" style="float: right" class="button_search"
66
- @click="$parent.$parent.exportexcel()"
67
- v-el:cx>导出</button>
68
- <button id="btnaaa" style="float: right" class="button_search"
69
- @click="$parent.$parent.getGroupName1(),search(),$parent.$parent.getexportExcelField(),$parent.$parent.$parent.isdetail=false,$parent.$parent.listflag=false"
70
- v-el:cx>查询</button>
71
- </div>
72
- </div>
73
- <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">
74
- <label class="font_normal_body">起始时间</label>
75
- <datepicker
76
- :value.sync="$parent.$parent.f_check_start"
77
- placeholder='起始时间' style="width:60%"
78
- :disabled-days-of-week="[]"
79
- :format="'yyyy-MM'"
80
- :select-month="true"
81
- :show-rest-button="reset">
82
- </datepicker>
83
- </div>
84
- <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">
85
- <label class="font_normal_body">结束时间</label>
86
- <datepicker
87
- :value.sync="$parent.$parent.f_check_end"
88
- placeholder='结束时间' style="width:60%"
89
- :disabled-days-of-week="[]"
90
- :format="'yyyy-MM'"
91
- :select-month="true"
92
- :show-rest-button="reset">
93
- </datepicker>
94
- </div>
95
- </div>
96
- <div class="row">
97
- <div class="col-sm-12">
98
- <label class="control-label" style="color: #c7254e">汇 总 项</label>
99
- <input type="checkbox" id="f_plan_month" value="f_plan_month" v-model="$parent.$parent.nameForSql"/>
100
- <label for="f_plan_month">计划月份</label>
101
- <input type="checkbox" id="f_no_checkplan" value="f_no_checkplan" v-model="$parent.$parent.nameForSql"/>
102
- <label for="f_no_checkplan">计划类型</label>
103
- <input type="checkbox" id="f_residential_area" value="f_residential_area" v-model="$parent.$parent.nameForSql"/>
104
- <label for="f_residential_area">小区名称</label>
105
- <input type="checkbox" id="f_plan_name" value="f_plan_name" v-model="$parent.$parent.nameForSql"/>
106
- <label for="f_plan_name">计划名称</label>
107
- <input type="checkbox" id="f_checker_name" value="f_checker_name" v-model="$parent.$parent.nameForSql"/>
108
- <label for="f_checker_name">安检员</label>
109
- <input type="checkbox" id="f_user_number" value="f_user_number" v-model="$parent.$parent.nameForSql"/>
110
- <label for="f_checker_name">档案数量</label>
111
- </div>
112
- </div>
113
- </div>
114
-
115
- </criteria>
116
- <data-grid id="excelid" :model="model" partial='list' class="list_area table_sy excelid" v-ref:grid>
117
- <template partial='head'>
118
- <tr>
119
- <th>
120
- <nobr>序号</nobr>
121
- </th>
122
- <th v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_month')"><nobr>计划月份</nobr></th>
123
- <th v-if="$parent.$parent.$parent.nameForSql.includes('f_no_checkplan')"><nobr>计划类型</nobr></th>
124
- <th v-if="$parent.$parent.$parent.nameForSql.includes('f_residential_area')"><nobr>小区名称</nobr></th>
125
- <th v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_name')"><nobr>计划名称</nobr></th>
126
- <th v-if="$parent.$parent.$parent.nameForSql.includes('f_checker_name')"><nobr>安检员</nobr></th>
127
- <th v-if="$parent.$parent.$parent.nameForSql.includes('f_user_number')"><nobr>档案数量</nobr></th>
128
- <th>
129
- <nobr>计划总数</nobr>
130
- </th>
131
- <th>
132
- <nobr>未检</nobr>
133
- </th>
134
- <th>
135
- <nobr>已检</nobr>
136
- </th>
137
- <th>
138
- <nobr>入户</nobr>
139
- </th>
140
- <th>
141
- <nobr>到访不遇</nobr>
142
- </th>
143
- <th>
144
- <nobr>拒检</nobr>
145
- </th>
146
- <th>
147
- <nobr>安检率</nobr>
148
- </th>
149
- <!--<th>-->
150
- <!--<nobr>查看</nobr>-->
151
- <!--</th>-->
152
- </tr>
153
- </template>
154
- <template partial='body'>
155
- <tr>
156
- <td style="text-align:center;border-right: 1px solid ">{{$index + 1}}</td>
157
- <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_month')">{{row.f_plan_month.indexOf('*&')!=-1?'':row.f_plan_month}}</td>-->
158
- <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_no_checkplan')">{{row.f_no_checkplan.indexOf('*&')!=-1?'':row.f_no_checkplan}}</td>-->
159
- <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_residential_area')">{{row.f_residential_area.indexOf('*&')!=-1?'':row.f_residential_area}}</td>-->
160
- <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_name')">{{row.f_plan_name.indexOf('*&')!=-1?'':row.f_plan_name}}</td>-->
161
- <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql && $parent.$parent.$parent.nameForSql.includes('f_checker_name')">{{row.f_checker_name && row.f_checker_name.indexOf('*&')!=-1?'':row.f_checker_name}}</td>-->
162
- <td style="text-align:center" :class="{'td-0':row.f_plan_month==undefined,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_plan_month.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_plan_month.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_plan_month.indexOf('*&')!=-1,'td-4':model.rows && model.rows.length==($index+1)&&row.f_plan_month.indexOf('*&')==-1}" v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_month')">{{row.f_plan_month.indexOf('*&')!=-1?'':row.f_plan_month}}</td>
163
- <td style="text-align:center" :class="{'td-0':row.f_no_checkplan==undefined,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_no_checkplan.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_no_checkplan.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_no_checkplan.indexOf('*&')!=-1,'td-4':model.rows && model.rows.length==($index+1)&&row.f_no_checkplan.indexOf('*&')==-1}" v-if="$parent.$parent.$parent.nameForSql.includes('f_no_checkplan')">{{row.f_no_checkplan.indexOf('*&')!=-1?'':row.f_no_checkplan}}</td>
164
- <td style="text-align:center" :class="{'td-0':row.f_residential_area==undefined,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_residential_area.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_residential_area.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_residential_area.indexOf('*&')!=-1,'td-4':model.rows && 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>
165
- <td style="text-align:center" :class="{'td-0':row.f_plan_name==undefined,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_plan_name.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_plan_name.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_plan_name.indexOf('*&')!=-1,'td-4':model.rows && 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>
166
- <td style="text-align:center" :class="{'td-0':row && !row.f_checker_name,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_checker_name && row.f_checker_name.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_checker_name &&row.f_checker_name.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_checker_name &&row.f_checker_name.indexOf('*&')!=-1,'td-4':model.rows && model.rows.length==($index+1)&&row.f_checker_name &&row.f_checker_name.indexOf('*&')==-1}" v-if="$parent.$parent.$parent.nameForSql && $parent.$parent.$parent.nameForSql.includes('f_checker_name')">{{row.f_checker_name && row.f_checker_name.indexOf('*&')!=-1?'':row.f_checker_name}}</td>
167
- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_user_number')">{{row.f_user_number}}</td>
168
- <td style="text-align:center">{{row.f_plan_total}}</td>
169
- <td style="text-align:center">{{row.f_weijian}}</td>
170
- <td style="text-align:center"><nobr>{{row.f_yijian}}</nobr></td>
171
- <td style="text-align:center"><nobr>{{row.f_ruhu}}</nobr></td>
172
- <td style="text-align:center">{{row.f_buyu}}</td>
173
- <td style="text-align:center"><nobr>{{row.f_jujian}}</nobr></td>
174
- <td style="text-align:center"><nobr>{{row.f_check_bv}}</nobr></td>
175
- </tr>
176
- </template>
177
- <template partial="foot">
178
- <tr>
179
- <td style="text-align:center"><strong>合计:</strong></td>
180
- <td style="text-align:center" :colspan="$parent.$parent.$parent.nameForSql.length"></td>
181
- <td style="text-align:center"><strong>{{model.sums.f_plan_total}}</strong></td>
182
- <td style="text-align:center"><strong>{{model.sums.f_weijian}}</strong></td>
183
- <td style="text-align:center"><nobr><strong>{{model.sums.f_yijian}}</strong></nobr></td>
184
- <td style="text-align:center"><nobr><strong>{{model.sums.f_ruhu}}</strong></nobr></td>
185
- <td style="text-align:center"><nobr><strong>{{model.sums.f_buyu}}</strong></nobr></td>
186
- <td style="text-align:center"><nobr><strong>{{model.sums.f_jujian}}</strong></nobr></td>
187
- <td style="text-align:center"><strong>{{model.sums.f_plan_total>0?(model.sums.f_yijian/model.sums.f_plan_total*100).toFixed(2)+'%':0}}</strong></td>
188
- </tr >
189
- </template>
190
- </data-grid>
191
- </criteria-paged>
192
- </div>
193
- </template>
194
-
195
- <script>
196
- /**
197
- *阶梯气价查询列表
198
- */
199
- import {PagedList} from 'vue-client'
200
- import { HttpResetClass } from 'vue-client'
201
- import * as Util from "../Util";
202
- import XLSX from 'xlsx'
203
- export default {
204
- data () {
205
- return {
206
- model: new PagedList('rs/sql/getCheckPlanAreaList', 99999,{},{f_plan_total:'',f_weijian:'',f_yijian:'',f_ruhu:'',f_buyu:'',f_jujian:''}),
207
- // 公司下拉
208
- curorgid: [this.$login.f.orgid],
209
- row: {},
210
- f_orgid: '',
211
- nameForSql: [],
212
- groupNameForSql: '',
213
- listflag:false,
214
- nameflag:false,
215
- criteriaShow: false,
216
- f_check_start:new Date().getFullYear() + '-01',
217
- f_check_end:new Date().getFullYear() + '-12',
218
- planName:[{label: '全部', value: ''}],
219
- exportExcelField: {
220
- 'f_weijian':'未检',
221
- 'f_yijian':'已检',
222
- 'f_ruhu':'入户',
223
- 'f_buyu':'到访不遇',
224
- 'f_jujian':'拒检',
225
- 'f_check_bv':'安检率'
226
- }
227
- }
228
- },
229
- props: {
230
- row: {},
231
- config: {},
232
- ispartial: false,
233
- f_filialeid: {
234
- type: String
235
- }
236
- },
237
- ready () {
238
- this.nameForSql = ['f_plan_month', 'f_plan_name','f_checker_name']
239
- this.groupNameForSql = 'f_plan_month', 'f_plan_name','f_checker_name'
240
- this.pl()
241
- // this.search()
242
-
243
- },
244
- methods: {
245
- exportexcel(){
246
- //tag
247
- // 以上四行也可以直接一行搞定,如果不需要对表格数据进行修改的话
248
- const aa = document.getElementsByClassName("list_area table_sy excelid")[0]
249
- console.log(aa)
250
- let workbook = XLSX.utils.table_to_book(document.getElementsByClassName("list_area table_sy excelid")[0])
251
- try {
252
- XLSX.writeFile(workbook, '安检情况汇总导出.xlsx');
253
- } catch(e) {
254
- //tag;
255
- }
256
- },
257
- // 获取导出列
258
- getexportExcelField(){
259
- this.exportExcelField = {
260
- 'f_weijian':'未检',
261
- 'f_yijian':'已检',
262
- 'f_ruhu':'入户',
263
- 'f_buyu':'到访不遇',
264
- 'f_jujian':'拒检',
265
- 'f_check_bv':'安检率',
266
- 'f_plan_total':'计划总数'
267
- }
268
- let forName = this.groupNameForSql.split(",")
269
- for (let i = 0; i < forName.length; i++) {
270
- let ff = forName[i]
271
- if (ff==='f_plan_month') {
272
- this.exportExcelField.f_plan_month='计划月份'
273
- }
274
- if (ff==='f_no_checkplan') {
275
- this.exportExcelField.f_no_checkplan='计划类型'
276
- }
277
- if (ff==='f_plan_name') {
278
- this.exportExcelField.f_plan_name='计划名称'
279
- }
280
- if (ff==='f_checker_name') {
281
- this.exportExcelField.f_checker_name='安检员'
282
- }if (ff==='f_residential_area') {
283
- this.exportExcelField.f_residential_area='小区名称'
284
- }if (ff==='f_user_number') {
285
- this.exportExcelField.f_user_number='档案数量'
286
- }
287
- }
288
- },
289
- pl() {
290
- let getGasman = new HttpResetClass()
291
- getGasman.load('POST', `rs/sql/safe_singleTable_OrderBy`, {
292
- data: {
293
- items: "id,f_plan_name",
294
- tablename: "t_check_plan",
295
- condition: `f_filialeid = '${this.curorgid}'`,
296
- orderitem: "id"
297
- }
298
- }, {resolveMsg: null, rejectMsg: null}).then((plne) => {
299
- //tag
300
- //tag
301
- //tag
302
- for (let i = 0; i < plne.data.length; i++) {
303
- this.planName.push({label: plne.data[i].f_plan_name, value: plne.data[i].id})
304
- }
305
- //tag
306
- })
307
- },
308
- hiddenr() {
309
- this.$parent.isdetail = !this.$parent.isdetail
310
- },
311
- hidden() {
312
- this.criteriaShow = !this.criteriaShow
313
- },
314
- search () {
315
- this.$refs.paged.$refs.cri.search()
316
- this.$dispatch('search')
317
- },
318
- getorg (val) {
319
- this.f_orgid = this.$login.convertToIn(val.resids)
320
- this.f_filialeid = val[0]
321
-
322
- },
323
- selfSearch (args) {
324
- if (!this.f_orgid) {
325
- this.getorg([this.$login.f.orgid])
326
- args.condition = `f_filialeid in ('${this.$login.f.orgid}') and ${args.condition}`
327
- }
328
- if (this.f_orgid) {
329
- args.condition = `f_filialeid in ${this.f_orgid} and ${args.condition}`
330
- }
331
- if(this.f_check_start && this.f_check_end){
332
- if(new Date(this.f_check_start).getFullYear() == new Date(this.f_check_end).getFullYear() ){
333
- args.condition += ` and f_year>=${new Date(this.f_check_start).getFullYear()} and f_month>=${new Date(this.f_check_start).getMonth()+1} and f_month<=${new Date(this.f_check_end).getMonth()+1}`
334
- }else {
335
- args.condition += ` and (
336
- (f_year = ${new Date(this.f_check_start).getFullYear()} and f_month >= ${new Date(this.f_check_start).getMonth()+1})
337
- or
338
- ( f_year > ${new Date(this.f_check_start).getFullYear()} and f_year < ${new Date(this.f_check_end).getFullYear()})
339
- or
340
- (f_year = ${new Date(this.f_check_end).getFullYear()} and f_month <= ${new Date(this.f_check_end).getMonth()+1}))`
341
- }
342
- } else {
343
- if(this.f_check_start){
344
- args.condition += ` and f_year>=${new Date(this.f_check_start).getFullYear()} and f_month>=${new Date(this.f_check_start).getMonth()+1}`
345
- }
346
- if(this.f_check_end){
347
- args.condition += ` and f_year<=${new Date(this.f_check_end).getFullYear()} and f_month<=${new Date(this.f_check_end).getMonth()+1}`
348
- }
349
- }
350
- this.$refs.paged.$refs.grid.$el.scrollTop = 0
351
- if (this.groupNameForSql=='undefined'){
352
- //tag
353
- this.$showMessage("请至少选择一项进行汇总")
354
- return
355
- }
356
- this.model.paramSource = {groupName: `'${this.groupNameForSql}'`}
357
- this.model.search(args.condition, args.model)
358
- },
359
-
360
- // 拼接groupName1
361
- getGroupName1 () {
362
- var temp=['f_plan_month','f_no_checkplan','f_residential_area','f_plan_name','f_checker_name','f_user_number']
363
- var newtemp=[]
364
-
365
- for (var i=0;i<temp.length;i++){
366
- for (var j=0;j<this.nameForSql.length;j++){
367
- //tag
368
- if(temp[i]==this.nameForSql[j]){
369
- newtemp.push(this.nameForSql[j])
370
- }
371
- }
372
- }
373
- let str = ''
374
-
375
- for (var i=0;i < newtemp.length - 1; i++) {
376
- str += newtemp[i] + ','
377
- }
378
- str += newtemp[i]
379
- this.groupNameForSql = str.trim()
380
- }
381
- },
382
- watch: {
383
- // 'nameForSql' () {
384
- //
385
- // this.getGroupName1()
386
- // },
387
- 'nameForSql' () {
388
- var e = document.createEvent("MouseEvents");
389
- e.initEvent("click", true, true);
390
- document.getElementById("btnaaa").dispatchEvent(e);
391
- },
392
- 'model.rows'(){
393
- //tag
394
- if(this.listflag){
395
- return;
396
- }
397
- this.listflag=true
398
- //tag
399
- var temp=['f_plan_month','f_no_checkplan','f_residential_area','f_plan_name','f_checker_name','f_user_number']
400
- var newtemp=[]
401
- for (var i=0;i<temp.length;i++){
402
- for (var j=0;j<this.nameForSql.length;j++){
403
- //tag
404
- if(temp[i]==this.nameForSql[j]){
405
- newtemp.push(this.nameForSql[j])
406
- }
407
- }
408
- }
409
- if((newtemp.includes('f_user_number')&&newtemp.length==2)||(!newtemp.includes('f_user_number')&&newtemp.length==1)){
410
- return
411
- }
412
- var temp=JSON.parse(JSON.stringify(this.model.rows))
413
-
414
- //遍历查询结果 为指定列增加样式
415
- for (var i=0;i<newtemp.length-1;i++){
416
- if(newtemp[i]=='f_user_number'){
417
- return;
418
- }
419
- //tag
420
- var ss=''
421
- for (var j=0;j<temp.length;j++){
422
- if(j>0&&i>0){
423
- var flag=false
424
- for(var t=i-1;t>-1;t--){
425
- //tag
426
- //tag
427
- //tag
428
- //tag
429
- if(temp[j-1][newtemp[t]]!=temp[j][newtemp[t]]&&(temp[j][newtemp[t]] !=null && temp[j][newtemp[t]].indexOf('*&') )==-1){
430
- flag=true
431
- break
432
- }
433
- }
434
- //tag
435
- if(flag){
436
- ss=temp[j][newtemp[i]]
437
- continue
438
- }
439
- }
440
- if(temp[j][newtemp[i]]==ss){
441
- temp[j][newtemp[i]]=temp[j][newtemp[i]]+'*&'
442
- }else {
443
- ss=temp[j][newtemp[i]]
444
- }
445
- }
446
- }
447
- //tag
448
- this.model.rows=JSON.parse(JSON.stringify(temp))
449
- },
450
- 'model.rows.length'() {
451
- // 如果查询无结果,将合计置为0
452
- if(this.model.rows.length < 1){
453
- this.model.sums.f_plan_total = 0
454
- this.model.sums.f_weijian = 0
455
- this.model.sums.f_yijian = 0
456
- this.model.sums.f_ruhu = 0
457
- this.model.sums.f_buyu = 0
458
- this.model.sums.f_jujian = 0
459
- }
460
- }
461
- },
462
- computed:{
463
- exportParameter(){
464
- // excel 导出条件拼接
465
- return {
466
- condition: this.$refs.paged.model.condition,
467
- groupName: this.groupNameForSql
468
- }
469
- }
470
- }
471
- }
472
- </script>
473
-
474
- <style scoped>
475
-
476
- .td-0{
477
- border: 1px solid #000000;
478
- }
479
-
480
- .td-1{
481
- border: none;
482
- border-top: 1px solid #000000;
483
- border-left: 1px solid #000000;
484
- border-right: 1px solid #000000;
485
- }
486
-
487
- .td-2{
488
- border: none;
489
- border-left: 1px solid #000000;
490
- border-right: 1px solid #000000;
491
- }
492
- .td-4{
493
- border: none;
494
- border-top: 1px solid #000000;
495
- border-left: 1px solid #000000;
496
- border-right: 1px solid #000000;
497
- border-bottom: 1px solid #000000;
498
- }
499
- .td-3{
500
- border: none;
501
- border-left: 1px solid #000000;
502
- border-right: 1px solid #000000;
503
- border-bottom: 1px solid #000000;
504
- }
505
- </style>
1
+ <template>
2
+ <div class="flex">
3
+ <criteria-paged :model="model" v-ref:paged :pager="false">
4
+ <criteria partial='criteria' @condition-changed='$parent.selfSearch' v-ref:cri>
5
+ <div novalidate class="form-horizontal select-overspread container-fluid auto" partial>
6
+ <div class="row">
7
+ <!--<div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
8
+ <label class="font_normal_body">组织机构</label>
9
+ <res-select restype='organization'
10
+ class="select select_list"
11
+ style="width: 60%"
12
+ @res-select="$parent.$parent.getorg"
13
+ :initresid='$parent.$parent.curorgid'>
14
+ </res-select>
15
+ </div>-->
16
+ <div :class="{'col-sm-6':$parent.$parent.$parent.isdetail,'col-sm-4':!$parent.$parent.$parent.isdetail}">
17
+ <role-selector-safe
18
+ role-name="安检员"
19
+ role-lable="安&ensp;检&ensp;员"
20
+ @re-res="$parent.$parent.getorg"
21
+ :value.sync="model.f_checker_id"
22
+ v-model="model.f_checker_id"
23
+ condition="f_checker_name like '%{}%'">
24
+ </role-selector-safe>
25
+ </div>
26
+ <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
27
+ <label class="font_normal_body">小区名称</label>
28
+ <input type="text" class="input_search" style="width:60%" v-model="model.f_residential_area" placeholder='小区名称'
29
+ condition="f_residential_area like '%{}%'" v-next-el="cx" v-el:qjmc>
30
+ </div>
31
+ <div :class="{'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
32
+ <label class="font_normal_body">计划名称</label>
33
+ <v-select class="select_list select"
34
+ placeholder='计划名称' style="width: 60%"
35
+ :search="true"
36
+ v-model="model.f_plan_name"
37
+ :value.sync="model.f_plan_name"
38
+ :options='$parent.$parent.planName'
39
+ condition="f_plan_id = '{}'"
40
+ :value-single="true"
41
+ close-on-select clear-button></v-select>
42
+
43
+ </div>
44
+ <!--<div :class="{
45
+ 'form-group col-sm-3':$parent.$parent.$parent.isdetail,'form-group col-sm-2':!$parent.$parent.$parent.isdetail}">
46
+ <label class="font_normal_body">安&ensp;检&ensp;员</label>
47
+ <input type="text" class="input_search" style="width:60%" v-model="model.f_checker_name" placeholder='安检员'
48
+ condition="f_checker_name like '%{}%'" v-next-el="cx" v-el:qjmc>
49
+ </div>-->
50
+ <div class="form-group col-sm-2" v-if="!$parent.$parent.$parent.isdetail"></div>
51
+ <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
+ <div class="span" style="float:right;">
53
+ <div style="float: right;margin-left:10px" class="button_spacing"
54
+ :class="{'button_shrink_left':!$parent.$parent.$parent.isdetail,'button_shrink_right':$parent.$parent.$parent.isdetail}"
55
+ @click="$parent.$parent.hiddenr()"></div>
56
+ <div class="button_spacing" style="float: right;margin-left:10px"
57
+ :class="{'button_shrink_top':$parent.$parent.criteriaShow,'button_shrink_bottom':!$parent.$parent.criteriaShow}"
58
+ @click="$parent.$parent.hidden()">
59
+ </div>
60
+ <!-- <export-excel-safe :data="$parent.$parent.exportParameter"
61
+ :field="$parent.$parent.exportExcelField"
62
+ sqlurl="rs/logic/SafeExportExcel" sql-name="getCheckPlanAreaList"
63
+ template-name='安检汇总' :choose-col="true">
64
+ </export-excel-safe>-->
65
+ <button id="btnaaaa" style="float: right" class="button_search"
66
+ @click="$parent.$parent.exportexcel()"
67
+ v-el:cx>导出</button>
68
+ <button id="btnaaa" style="float: right" class="button_search"
69
+ @click="$parent.$parent.getGroupName1(),search(),$parent.$parent.getexportExcelField(),$parent.$parent.$parent.isdetail=false,$parent.$parent.listflag=false"
70
+ v-el:cx>查询</button>
71
+ </div>
72
+ </div>
73
+ <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">
74
+ <label class="font_normal_body">起始时间</label>
75
+ <datepicker
76
+ :value.sync="$parent.$parent.f_check_start"
77
+ placeholder='起始时间' style="width:60%"
78
+ :disabled-days-of-week="[]"
79
+ :format="'yyyy-MM'"
80
+ :select-month="true"
81
+ :show-rest-button="reset">
82
+ </datepicker>
83
+ </div>
84
+ <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">
85
+ <label class="font_normal_body">结束时间</label>
86
+ <datepicker
87
+ :value.sync="$parent.$parent.f_check_end"
88
+ placeholder='结束时间' style="width:60%"
89
+ :disabled-days-of-week="[]"
90
+ :format="'yyyy-MM'"
91
+ :select-month="true"
92
+ :show-rest-button="reset">
93
+ </datepicker>
94
+ </div>
95
+ </div>
96
+ <div class="row">
97
+ <div class="col-sm-12">
98
+ <label class="control-label" style="color: #c7254e">汇 总 项</label>
99
+ <input type="checkbox" id="f_plan_month" value="f_plan_month" v-model="$parent.$parent.nameForSql"/>
100
+ <label for="f_plan_month">计划月份</label>
101
+ <input type="checkbox" id="f_no_checkplan" value="f_no_checkplan" v-model="$parent.$parent.nameForSql"/>
102
+ <label for="f_no_checkplan">计划类型</label>
103
+ <input type="checkbox" id="f_residential_area" value="f_residential_area" v-model="$parent.$parent.nameForSql"/>
104
+ <label for="f_residential_area">小区名称</label>
105
+ <input type="checkbox" id="f_plan_name" value="f_plan_name" v-model="$parent.$parent.nameForSql"/>
106
+ <label for="f_plan_name">计划名称</label>
107
+ <input type="checkbox" id="f_checker_name" value="f_checker_name" v-model="$parent.$parent.nameForSql"/>
108
+ <label for="f_checker_name">安检员</label>
109
+ <input type="checkbox" id="f_user_number" value="f_user_number" v-model="$parent.$parent.nameForSql"/>
110
+ <label for="f_checker_name">档案数量</label>
111
+ </div>
112
+ </div>
113
+ </div>
114
+
115
+ </criteria>
116
+ <data-grid id="excelid" :model="model" partial='list' class="list_area table_sy excelid" v-ref:grid>
117
+ <template partial='head'>
118
+ <tr>
119
+ <th>
120
+ <nobr>序号</nobr>
121
+ </th>
122
+ <th v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_month')"><nobr>计划月份</nobr></th>
123
+ <th v-if="$parent.$parent.$parent.nameForSql.includes('f_no_checkplan')"><nobr>计划类型</nobr></th>
124
+ <th v-if="$parent.$parent.$parent.nameForSql.includes('f_residential_area')"><nobr>小区名称</nobr></th>
125
+ <th v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_name')"><nobr>计划名称</nobr></th>
126
+ <th v-if="$parent.$parent.$parent.nameForSql.includes('f_checker_name')"><nobr>安检员</nobr></th>
127
+ <th v-if="$parent.$parent.$parent.nameForSql.includes('f_user_number')"><nobr>档案数量</nobr></th>
128
+ <th>
129
+ <nobr>计划总数</nobr>
130
+ </th>
131
+ <th>
132
+ <nobr>未检</nobr>
133
+ </th>
134
+ <th>
135
+ <nobr>已检</nobr>
136
+ </th>
137
+ <th>
138
+ <nobr>入户</nobr>
139
+ </th>
140
+ <th>
141
+ <nobr>到访不遇</nobr>
142
+ </th>
143
+ <th>
144
+ <nobr>拒检</nobr>
145
+ </th>
146
+ <th>
147
+ <nobr>安检率</nobr>
148
+ </th>
149
+ <!--<th>-->
150
+ <!--<nobr>查看</nobr>-->
151
+ <!--</th>-->
152
+ </tr>
153
+ </template>
154
+ <template partial='body'>
155
+ <tr>
156
+ <td style="text-align:center;border-right: 1px solid ">{{$index + 1}}</td>
157
+ <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_month')">{{row.f_plan_month.indexOf('*&')!=-1?'':row.f_plan_month}}</td>-->
158
+ <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_no_checkplan')">{{row.f_no_checkplan.indexOf('*&')!=-1?'':row.f_no_checkplan}}</td>-->
159
+ <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_residential_area')">{{row.f_residential_area.indexOf('*&')!=-1?'':row.f_residential_area}}</td>-->
160
+ <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_name')">{{row.f_plan_name.indexOf('*&')!=-1?'':row.f_plan_name}}</td>-->
161
+ <!-- <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql && $parent.$parent.$parent.nameForSql.includes('f_checker_name')">{{row.f_checker_name && row.f_checker_name.indexOf('*&')!=-1?'':row.f_checker_name}}</td>-->
162
+ <td style="text-align:center" :class="{'td-0':row.f_plan_month==undefined,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_plan_month.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_plan_month.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_plan_month.indexOf('*&')!=-1,'td-4':model.rows && model.rows.length==($index+1)&&row.f_plan_month.indexOf('*&')==-1}" v-if="$parent.$parent.$parent.nameForSql.includes('f_plan_month')">{{row.f_plan_month.indexOf('*&')!=-1?'':row.f_plan_month}}</td>
163
+ <td style="text-align:center" :class="{'td-0':row.f_no_checkplan==undefined,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_no_checkplan.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_no_checkplan.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_no_checkplan.indexOf('*&')!=-1,'td-4':model.rows && model.rows.length==($index+1)&&row.f_no_checkplan.indexOf('*&')==-1}" v-if="$parent.$parent.$parent.nameForSql.includes('f_no_checkplan')">{{row.f_no_checkplan.indexOf('*&')!=-1?'':row.f_no_checkplan}}</td>
164
+ <td style="text-align:center" :class="{'td-0':row.f_residential_area==undefined,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_residential_area.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_residential_area.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_residential_area.indexOf('*&')!=-1,'td-4':model.rows && 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>
165
+ <td style="text-align:center" :class="{'td-0':row.f_plan_name==undefined,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_plan_name.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_plan_name.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_plan_name.indexOf('*&')!=-1,'td-4':model.rows && 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>
166
+ <td style="text-align:center" :class="{'td-0':row && !row.f_checker_name,'td-1':model.rows && model.rows.length!=($index+1)&&row.f_checker_name && row.f_checker_name.indexOf('*&')==-1,'td-2':model.rows && model.rows.length!=($index+1)&&row.f_checker_name &&row.f_checker_name.indexOf('*&')!=-1,'td-3':model.rows && model.rows.length==($index+1)&&row.f_checker_name &&row.f_checker_name.indexOf('*&')!=-1,'td-4':model.rows && model.rows.length==($index+1)&&row.f_checker_name &&row.f_checker_name.indexOf('*&')==-1}" v-if="$parent.$parent.$parent.nameForSql && $parent.$parent.$parent.nameForSql.includes('f_checker_name')">{{row.f_checker_name && row.f_checker_name.indexOf('*&')!=-1?'':row.f_checker_name}}</td>
167
+ <td style="text-align:center" v-if="$parent.$parent.$parent.nameForSql.includes('f_user_number')">{{row.f_user_number}}</td>
168
+ <td style="text-align:center">{{row.f_plan_total}}</td>
169
+ <td style="text-align:center">{{row.f_weijian}}</td>
170
+ <td style="text-align:center"><nobr>{{row.f_yijian}}</nobr></td>
171
+ <td style="text-align:center"><nobr>{{row.f_ruhu}}</nobr></td>
172
+ <td style="text-align:center">{{row.f_buyu}}</td>
173
+ <td style="text-align:center"><nobr>{{row.f_jujian}}</nobr></td>
174
+ <td style="text-align:center"><nobr>{{row.f_check_bv}}</nobr></td>
175
+ </tr>
176
+ </template>
177
+ <template partial="foot">
178
+ <tr>
179
+ <td style="text-align:center"><strong>合计:</strong></td>
180
+ <td style="text-align:center" :colspan="$parent.$parent.$parent.nameForSql.length"></td>
181
+ <td style="text-align:center"><strong>{{model.sums.f_plan_total}}</strong></td>
182
+ <td style="text-align:center"><strong>{{model.sums.f_weijian}}</strong></td>
183
+ <td style="text-align:center"><nobr><strong>{{model.sums.f_yijian}}</strong></nobr></td>
184
+ <td style="text-align:center"><nobr><strong>{{model.sums.f_ruhu}}</strong></nobr></td>
185
+ <td style="text-align:center"><nobr><strong>{{model.sums.f_buyu}}</strong></nobr></td>
186
+ <td style="text-align:center"><nobr><strong>{{model.sums.f_jujian}}</strong></nobr></td>
187
+ <td style="text-align:center"><strong>{{model.sums.f_plan_total>0?(model.sums.f_yijian/model.sums.f_plan_total*100).toFixed(2)+'%':0}}</strong></td>
188
+ </tr >
189
+ </template>
190
+ </data-grid>
191
+ </criteria-paged>
192
+ </div>
193
+ </template>
194
+
195
+ <script>
196
+ /**
197
+ *阶梯气价查询列表
198
+ */
199
+ import {PagedList} from 'vue-client'
200
+ import { HttpResetClass } from 'vue-client'
201
+ import * as Util from "../Util";
202
+ import XLSX from 'xlsx'
203
+ export default {
204
+ data () {
205
+ return {
206
+ model: new PagedList('rs/sql/getCheckPlanAreaList', 99999,{},{f_plan_total:'',f_weijian:'',f_yijian:'',f_ruhu:'',f_buyu:'',f_jujian:''}),
207
+ // 公司下拉
208
+ curorgid: [this.$login.f.orgid],
209
+ row: {},
210
+ f_orgid: '',
211
+ nameForSql: [],
212
+ groupNameForSql: '',
213
+ listflag:false,
214
+ nameflag:false,
215
+ criteriaShow: false,
216
+ f_check_start:new Date().getFullYear() + '-01',
217
+ f_check_end:new Date().getFullYear() + '-12',
218
+ planName:[{label: '全部', value: ''}],
219
+ exportExcelField: {
220
+ 'f_weijian':'未检',
221
+ 'f_yijian':'已检',
222
+ 'f_ruhu':'入户',
223
+ 'f_buyu':'到访不遇',
224
+ 'f_jujian':'拒检',
225
+ 'f_check_bv':'安检率'
226
+ }
227
+ }
228
+ },
229
+ props: {
230
+ row: {},
231
+ config: {},
232
+ ispartial: false,
233
+ f_filialeid: {
234
+ type: String
235
+ }
236
+ },
237
+ ready () {
238
+ this.nameForSql = ['f_plan_month', 'f_plan_name','f_checker_name']
239
+ this.groupNameForSql = 'f_plan_month', 'f_plan_name','f_checker_name'
240
+ this.pl()
241
+ // this.search()
242
+
243
+ },
244
+ methods: {
245
+ exportexcel(){
246
+ //tag
247
+ // 以上四行也可以直接一行搞定,如果不需要对表格数据进行修改的话
248
+ const aa = document.getElementsByClassName("list_area table_sy excelid")[0]
249
+ console.log(aa)
250
+ let workbook = XLSX.utils.table_to_book(document.getElementsByClassName("list_area table_sy excelid")[0])
251
+ try {
252
+ XLSX.writeFile(workbook, '安检情况汇总导出.xlsx');
253
+ } catch(e) {
254
+ //tag;
255
+ }
256
+ },
257
+ // 获取导出列
258
+ getexportExcelField(){
259
+ this.exportExcelField = {
260
+ 'f_weijian':'未检',
261
+ 'f_yijian':'已检',
262
+ 'f_ruhu':'入户',
263
+ 'f_buyu':'到访不遇',
264
+ 'f_jujian':'拒检',
265
+ 'f_check_bv':'安检率',
266
+ 'f_plan_total':'计划总数'
267
+ }
268
+ let forName = this.groupNameForSql.split(",")
269
+ for (let i = 0; i < forName.length; i++) {
270
+ let ff = forName[i]
271
+ if (ff==='f_plan_month') {
272
+ this.exportExcelField.f_plan_month='计划月份'
273
+ }
274
+ if (ff==='f_no_checkplan') {
275
+ this.exportExcelField.f_no_checkplan='计划类型'
276
+ }
277
+ if (ff==='f_plan_name') {
278
+ this.exportExcelField.f_plan_name='计划名称'
279
+ }
280
+ if (ff==='f_checker_name') {
281
+ this.exportExcelField.f_checker_name='安检员'
282
+ }if (ff==='f_residential_area') {
283
+ this.exportExcelField.f_residential_area='小区名称'
284
+ }if (ff==='f_user_number') {
285
+ this.exportExcelField.f_user_number='档案数量'
286
+ }
287
+ }
288
+ },
289
+ pl() {
290
+ let getGasman = new HttpResetClass()
291
+ getGasman.load('POST', `rs/sql/safe_singleTable_OrderBy`, {
292
+ data: {
293
+ items: "id,f_plan_name",
294
+ tablename: "t_check_plan",
295
+ condition: `f_filialeid = '${this.curorgid}'`,
296
+ orderitem: "id"
297
+ }
298
+ }, {resolveMsg: null, rejectMsg: null}).then((plne) => {
299
+ //tag
300
+ //tag
301
+ //tag
302
+ for (let i = 0; i < plne.data.length; i++) {
303
+ this.planName.push({label: plne.data[i].f_plan_name, value: plne.data[i].id})
304
+ }
305
+ //tag
306
+ })
307
+ },
308
+ hiddenr() {
309
+ this.$parent.isdetail = !this.$parent.isdetail
310
+ },
311
+ hidden() {
312
+ this.criteriaShow = !this.criteriaShow
313
+ },
314
+ search () {
315
+ this.$refs.paged.$refs.cri.search()
316
+ this.$dispatch('search')
317
+ },
318
+ getorg (val) {
319
+ this.f_orgid = this.$login.convertToIn(val.resids)
320
+ this.f_filialeid = val[0]
321
+
322
+ },
323
+ selfSearch (args) {
324
+ if (!this.f_orgid) {
325
+ this.getorg([this.$login.f.orgid])
326
+ args.condition = `f_filialeid in ('${this.$login.f.orgid}') and ${args.condition}`
327
+ }
328
+ if (this.f_orgid) {
329
+ args.condition = `f_filialeid in ${this.f_orgid} and ${args.condition}`
330
+ }
331
+ if(this.f_check_start && this.f_check_end){
332
+ if(new Date(this.f_check_start).getFullYear() == new Date(this.f_check_end).getFullYear() ){
333
+ args.condition += ` and f_year>=${new Date(this.f_check_start).getFullYear()} and f_month>=${new Date(this.f_check_start).getMonth()+1} and f_month<=${new Date(this.f_check_end).getMonth()+1}`
334
+ }else {
335
+ args.condition += ` and (
336
+ (f_year = ${new Date(this.f_check_start).getFullYear()} and f_month >= ${new Date(this.f_check_start).getMonth()+1})
337
+ or
338
+ ( f_year > ${new Date(this.f_check_start).getFullYear()} and f_year < ${new Date(this.f_check_end).getFullYear()})
339
+ or
340
+ (f_year = ${new Date(this.f_check_end).getFullYear()} and f_month <= ${new Date(this.f_check_end).getMonth()+1}))`
341
+ }
342
+ } else {
343
+ if(this.f_check_start){
344
+ args.condition += ` and f_year>=${new Date(this.f_check_start).getFullYear()} and f_month>=${new Date(this.f_check_start).getMonth()+1}`
345
+ }
346
+ if(this.f_check_end){
347
+ args.condition += ` and f_year<=${new Date(this.f_check_end).getFullYear()} and f_month<=${new Date(this.f_check_end).getMonth()+1}`
348
+ }
349
+ }
350
+ this.$refs.paged.$refs.grid.$el.scrollTop = 0
351
+ if (this.groupNameForSql=='undefined'){
352
+ //tag
353
+ this.$showMessage("请至少选择一项进行汇总")
354
+ return
355
+ }
356
+ this.model.paramSource = {groupName: `'${this.groupNameForSql}'`}
357
+ this.model.search(args.condition, args.model)
358
+ },
359
+
360
+ // 拼接groupName1
361
+ getGroupName1 () {
362
+ var temp=['f_plan_month','f_no_checkplan','f_residential_area','f_plan_name','f_checker_name','f_user_number']
363
+ var newtemp=[]
364
+
365
+ for (var i=0;i<temp.length;i++){
366
+ for (var j=0;j<this.nameForSql.length;j++){
367
+ //tag
368
+ if(temp[i]==this.nameForSql[j]){
369
+ newtemp.push(this.nameForSql[j])
370
+ }
371
+ }
372
+ }
373
+ let str = ''
374
+
375
+ for (var i=0;i < newtemp.length - 1; i++) {
376
+ str += newtemp[i] + ','
377
+ }
378
+ str += newtemp[i]
379
+ this.groupNameForSql = str.trim()
380
+ }
381
+ },
382
+ watch: {
383
+ // 'nameForSql' () {
384
+ //
385
+ // this.getGroupName1()
386
+ // },
387
+ 'nameForSql' () {
388
+ var e = document.createEvent("MouseEvents");
389
+ e.initEvent("click", true, true);
390
+ document.getElementById("btnaaa").dispatchEvent(e);
391
+ },
392
+ 'model.rows'(){
393
+ //tag
394
+ if(this.listflag){
395
+ return;
396
+ }
397
+ this.listflag=true
398
+ //tag
399
+ var temp=['f_plan_month','f_no_checkplan','f_residential_area','f_plan_name','f_checker_name','f_user_number']
400
+ var newtemp=[]
401
+ for (var i=0;i<temp.length;i++){
402
+ for (var j=0;j<this.nameForSql.length;j++){
403
+ //tag
404
+ if(temp[i]==this.nameForSql[j]){
405
+ newtemp.push(this.nameForSql[j])
406
+ }
407
+ }
408
+ }
409
+ if((newtemp.includes('f_user_number')&&newtemp.length==2)||(!newtemp.includes('f_user_number')&&newtemp.length==1)){
410
+ return
411
+ }
412
+ var temp=JSON.parse(JSON.stringify(this.model.rows))
413
+
414
+ //遍历查询结果 为指定列增加样式
415
+ for (var i=0;i<newtemp.length-1;i++){
416
+ if(newtemp[i]=='f_user_number'){
417
+ return;
418
+ }
419
+ //tag
420
+ var ss=''
421
+ for (var j=0;j<temp.length;j++){
422
+ if(j>0&&i>0){
423
+ var flag=false
424
+ for(var t=i-1;t>-1;t--){
425
+ //tag
426
+ //tag
427
+ //tag
428
+ //tag
429
+ if(temp[j-1][newtemp[t]]!=temp[j][newtemp[t]]&&(temp[j][newtemp[t]] !=null && temp[j][newtemp[t]].indexOf('*&') )==-1){
430
+ flag=true
431
+ break
432
+ }
433
+ }
434
+ //tag
435
+ if(flag){
436
+ ss=temp[j][newtemp[i]]
437
+ continue
438
+ }
439
+ }
440
+ if(temp[j][newtemp[i]]==ss){
441
+ temp[j][newtemp[i]]=temp[j][newtemp[i]]+'*&'
442
+ }else {
443
+ ss=temp[j][newtemp[i]]
444
+ }
445
+ }
446
+ }
447
+ //tag
448
+ this.model.rows=JSON.parse(JSON.stringify(temp))
449
+ },
450
+ 'model.rows.length'() {
451
+ // 如果查询无结果,将合计置为0
452
+ if(this.model.rows.length < 1){
453
+ this.model.sums.f_plan_total = 0
454
+ this.model.sums.f_weijian = 0
455
+ this.model.sums.f_yijian = 0
456
+ this.model.sums.f_ruhu = 0
457
+ this.model.sums.f_buyu = 0
458
+ this.model.sums.f_jujian = 0
459
+ }
460
+ }
461
+ },
462
+ computed:{
463
+ exportParameter(){
464
+ // excel 导出条件拼接
465
+ return {
466
+ condition: this.$refs.paged.model.condition,
467
+ groupName: this.groupNameForSql
468
+ }
469
+ }
470
+ }
471
+ }
472
+ </script>
473
+
474
+ <style scoped>
475
+
476
+ .td-0{
477
+ border: 1px solid #000000;
478
+ }
479
+
480
+ .td-1{
481
+ border: none;
482
+ border-top: 1px solid #000000;
483
+ border-left: 1px solid #000000;
484
+ border-right: 1px solid #000000;
485
+ }
486
+
487
+ .td-2{
488
+ border: none;
489
+ border-left: 1px solid #000000;
490
+ border-right: 1px solid #000000;
491
+ }
492
+ .td-4{
493
+ border: none;
494
+ border-top: 1px solid #000000;
495
+ border-left: 1px solid #000000;
496
+ border-right: 1px solid #000000;
497
+ border-bottom: 1px solid #000000;
498
+ }
499
+ .td-3{
500
+ border: none;
501
+ border-left: 1px solid #000000;
502
+ border-right: 1px solid #000000;
503
+ border-bottom: 1px solid #000000;
504
+ }
505
+ </style>