|
@@ -16,365 +16,21 @@
|
16
|
16
|
}
|
17
|
17
|
</style>
|
18
|
18
|
</head>
|
19
|
|
-
|
20
|
19
|
<body>
|
21
|
|
- <div class="chart-page">
|
22
|
|
- <div class="flex-part">
|
23
|
|
- <div class="flex-part-3">
|
24
|
|
-
|
25
|
|
- <div class="count">
|
26
|
|
- <dl>
|
27
|
|
- <dt id="totalTask">0</dt>
|
28
|
|
- <dd>任务总数</dd>
|
29
|
|
- <img th:src="@{/images/statistic/数字统计.png}" alt="">
|
30
|
|
- </dl>
|
31
|
|
- <dl>
|
32
|
|
- <dt id="totalPerson">0</dt>
|
33
|
|
- <dd>接待军人总数</dd>
|
34
|
|
- <img th:src="@{/images/statistic/接待军人总数.png}" alt="">
|
35
|
|
- </dl>
|
36
|
|
- <dl>
|
37
|
|
- <dt id="totalOrg">0</dt>
|
38
|
|
- <dd>保障机构数</dd>
|
39
|
|
- <img th:src="@{/images/statistic/保障机构数.png}" alt="">
|
40
|
|
- </dl>
|
41
|
|
- <dl>
|
42
|
|
- <dt id="totalEquipment">0</dt>
|
43
|
|
- <dd>设备数量</dd>
|
44
|
|
- <img th:src="@{/images/statistic/设备数量.png}" alt="">
|
45
|
|
- </dl>
|
46
|
|
- </div>
|
47
|
|
-
|
48
|
|
- <div class="panelGroup flex-part" style="padding-bottom:0;">
|
49
|
|
- <div class="panel flex-part-2 chart-card">
|
50
|
|
- <div class="panel-heading">
|
51
|
|
- <img th:src="@{/images/statistic/任务统计.png}" />
|
52
|
|
- <span>任务统计</span>
|
53
|
|
- <!-- <svg>
|
54
|
|
- <defs>
|
55
|
|
- <linearGradient id="grad" x1="0" y1="100%" x2="0" y2="0">
|
56
|
|
- <stop offset="0%" style="stop-color:#6F39B9; stop-opacity:1" />
|
57
|
|
- <stop offset="100%" style="stop-color:#1EAED1; stop-opacity:1" />
|
58
|
|
- </linearGradient>
|
59
|
|
- </defs>
|
60
|
|
- <text x="0" y="22" fill="url(#grad)" style="font-size:22px">任务统计</text>
|
61
|
|
- </svg> -->
|
62
|
|
- <div class="selectGroup">
|
63
|
|
- <select class="" id="selYear" onchange="taskTimeReport()">
|
64
|
|
- </select>
|
65
|
|
- </div>
|
66
|
|
- </div>
|
67
|
|
- <div class="panel-body">
|
68
|
|
- <div class="text-center">
|
69
|
|
- <div class="text-center" style="height:300px;" id="taskChart"></div>
|
70
|
|
- </div>
|
71
|
|
- </div>
|
72
|
|
- </div>
|
73
|
|
- <div class="flex-part-1">
|
74
|
|
- <div class="panel chart-card">
|
75
|
|
- <div class="panel-heading">
|
76
|
|
- <img th:src="@{/images/statistic/设备分类统计.png}" />
|
77
|
|
- <span>设备分类统计</span>
|
78
|
|
- </div>
|
79
|
|
- <div class="panel-body">
|
80
|
|
- <div class="text-center" style="height:260px;" id="devChart"></div>
|
81
|
|
- </div>
|
82
|
|
- </div>
|
83
|
|
- </div>
|
84
|
|
- </div>
|
85
|
|
-
|
86
|
|
-
|
87
|
|
- </div>
|
88
|
|
- <div class="flex-part-1">
|
89
|
|
- <div class="panel chart-card" style="margin: 15px 30px 0 0; height: calc(100% - 15px)">
|
90
|
|
- <div class="panel-heading">
|
91
|
|
- <img th:src="@{/images/statistic/军供保障能力.png}" />
|
92
|
|
- <span>军供保障能力</span>
|
93
|
|
- </div>
|
94
|
|
- <div class="panel-body" style="height: calc(100% - 60px);">
|
95
|
|
- <div class="info-text">
|
96
|
|
-
|
97
|
|
- </div>
|
98
|
|
- <ul class="info-list" style="overflow-y: auto; height: 100%;">
|
99
|
|
- <li title="常规单日整体膳食供应能力(人次)"><span id="ztssgynl">0</span>常规单日整体膳食供应能力(人次):</li>
|
100
|
|
- <li title="常规单次整体膳食供应能力(人)"><span id="dcztssgynl">0</span>常规单次整体膳食供应能力(人):</li>
|
101
|
|
- <li title="应急单日整体膳食供应能力(人次)"><span id="yjztssgynl">0</span>应急单日整体膳食供应能力(人次):</li>
|
102
|
|
- <li title="应急单次整体膳食供应能力(人)"><span id="yjdcztssgynl">0</span>应急单次整体膳食供应能力(人):</li>
|
103
|
|
- <li title="常规整体住宿供应能力(人)"><span id="ztzsgynl">0</span>常规整体住宿供应能力(人):</li>
|
104
|
|
- <li title="应急整体住宿供应能力(人)"><span id="yjztzsgynl">0</span>应急整体住宿供应能力(人):</li>
|
105
|
|
- </ul>
|
106
|
|
- </div>
|
107
|
|
- </div>
|
108
|
|
- </div>
|
109
|
|
- </div>
|
110
|
|
- <div class="panelGroup">
|
111
|
|
- <div class="panel panel-row-2 chart-card">
|
112
|
|
- <div class="panel-heading">
|
113
|
|
- <img th:src="@{/images/statistic/社会保障机构分类统计.png}" />
|
114
|
|
- <span>社会保障机构分类统计</span>
|
115
|
|
- </div>
|
116
|
|
- <div class="panel-body">
|
117
|
|
- <div class="text-center" id="guaChart" style="height:320px"></div>
|
118
|
|
- </div>
|
119
|
|
- </div>
|
120
|
|
- <div class="panel panel-row-2 chart-card">
|
121
|
|
- <div class="panel-heading">
|
122
|
|
- <img th:src="@{/images/statistic/人员统计.png}" />
|
123
|
|
- <span>人员统计</span>
|
124
|
|
- </div>
|
125
|
|
- <div class="panel-body">
|
126
|
|
- <div class="col-sm-6 text-center" id="eduChart" style="height:300px;">
|
127
|
|
- </div>
|
128
|
|
- <div class="col-sm-6 text-center" id="ageChart" style="height:270px;">
|
129
|
|
- </div>
|
130
|
|
- </div>
|
131
|
|
- </div>
|
132
|
|
- </div>
|
133
|
|
-
|
134
|
|
-
|
135
|
|
-
|
136
|
|
-</div>
|
|
20
|
+ <div th:replace="main/data::main-data"></div>
|
|
21
|
+ <div th:replace="main/dashboard::main-dashboard"></div>
|
137
|
22
|
</body>
|
138
|
|
- <script>
|
139
|
|
- function loadPage() {
|
140
|
|
- let colArr = commentReport();
|
141
|
|
- $
|
142
|
|
- .ajax({
|
143
|
|
- url : urlPre + "getMainData",
|
144
|
|
- dataType : 'json',
|
145
|
|
- success : function(data) {
|
146
|
|
-
|
147
|
|
- (function mockData(dt) {
|
148
|
|
- function rand() {
|
149
|
|
- return Math.floor(100 * Math.random() + 10);
|
150
|
|
- }
|
151
|
|
-
|
152
|
|
- dt.countData.ageArrNum = dt.countData.ageArrNum.split(',').map(rand).join(',')
|
153
|
|
- dt.countData.devArrNum = dt.countData.devArrNum.split(',').map(rand).join(',')
|
154
|
|
- dt.countData.guaArrNum = dt.countData.guaArrNum.split(',').map(rand).join(',')
|
155
|
|
- dt.countData.eduNum = dt.countData.eduNum.split(',').map(rand).join(',')
|
156
|
|
- dt.countData.guaAbiJson.clzs = rand()
|
157
|
|
- dt.countData.guaAbiJson.dcztssgynl = rand()
|
158
|
|
- dt.countData.guaAbiJson.yjdcztssgynl = rand()
|
159
|
|
- dt.countData.guaAbiJson.yjztssgynl = rand()
|
160
|
|
- dt.countData.guaAbiJson.ztssgynl = rand()
|
161
|
|
- dt.countData.guaAbiJson.ztzsgynl = rand()
|
162
|
|
- dt.yearTask = Object.keys(dt.yearTask).map((key) => {
|
163
|
|
- return {[key]: rand()}
|
164
|
|
- }).reduce((acc, item) => ({ ...acc, ...item }), {})
|
165
|
|
- })(data)
|
166
|
|
-
|
167
|
|
- console.log(data)
|
168
|
|
-
|
169
|
|
- $("#totalTask").text(data.totalTask);
|
170
|
|
- $("#totalOrg").text(data.totalOrg);
|
171
|
|
- $("#totalPerson").text(data.totalPerson);
|
172
|
|
- $("#totalEquipment").text(data.totalEquipment);
|
173
|
|
- //选择年份 按月统计任务
|
174
|
|
- var myDate = new Date();
|
175
|
|
- var tYear = myDate.getFullYear();
|
176
|
|
- var lasYear = tYear - 1;
|
177
|
|
- $("#selYear").html("<option value='"+tYear+"'>"+tYear+"年</option><option value='"+lasYear+"'>"+lasYear+"年</option>");
|
178
|
|
- var chartData = {};
|
179
|
|
- let yearTask = data.yearTask
|
180
|
|
- let xAxisData = []
|
181
|
|
- let datas = []
|
182
|
|
- for(let key in yearTask){
|
183
|
|
- xAxisData[xAxisData.length] = key
|
184
|
|
- datas[datas.length] = yearTask[key]
|
185
|
|
- }
|
186
|
|
- chartData.datas = datas;
|
187
|
|
- chartData.xAxisData = xAxisData;
|
188
|
|
- // setLine("taskChart", chartData);
|
189
|
|
-
|
190
|
|
- setChart("#taskChart", getBar1Option(xAxisData, datas))
|
191
|
|
-
|
192
|
|
- var comments = data.comments;
|
193
|
|
- var commentUl = "";
|
194
|
|
- for (var key in comments) {
|
195
|
|
- var tmpData = comments[key];
|
196
|
|
- commentUl += '<li><a href="###"><h2>'+tmpData.taskNumber+'</h2>'
|
197
|
|
- let config_evaluate_item = tmpData.config_evaluate_item.split(",")
|
198
|
|
- for(var ky in colArr){
|
199
|
|
- if(config_evaluate_item.indexOf(colArr[ky].substring(0,2)) !=-1){
|
200
|
|
- if(tmpData[colArr[ky]] != null){
|
201
|
|
- let num = tmpData[colArr[ky]];
|
202
|
|
- let total = tmpData[colArr[ky].substring(0,2)]
|
203
|
|
- let addNum = (num/total*100).toFixed() + "%"
|
204
|
|
- commentUl += '<span>'+addNum+'</span>'
|
205
|
|
- }else{
|
206
|
|
- commentUl += '<span>0%</span>'
|
207
|
|
- }
|
208
|
|
- }else{
|
209
|
|
- commentUl += '<span>未选择</span>'
|
210
|
|
- }
|
211
|
|
-
|
212
|
|
-
|
213
|
|
- }
|
214
|
|
- commentUl += '</li>';
|
215
|
|
- }
|
216
|
|
- $("#commentUl").html(commentUl);
|
217
|
|
-
|
218
|
|
- var taskInfos = data.taskInfos;
|
219
|
|
- var taskInfoUl = "";
|
220
|
|
- for (var key in taskInfos) {
|
221
|
|
- var tmpData = taskInfos[key];
|
222
|
|
- taskInfoUl += '<li><a href="###"><h2>'+tmpData.taskNumber+'</h2><span>'+tmpData.data_date.substring(0,10)+'</span><span>'
|
223
|
|
- +tmpData.config_supply_main+'</span></a></li>';
|
224
|
|
- }
|
225
|
|
- $("#taskInfoUl").html(taskInfoUl);
|
226
|
|
- //人员学历统计
|
227
|
|
-
|
228
|
|
- chartData = {};
|
229
|
|
- let eduArrNameArr = data.countData.eduArrName.split(",")
|
230
|
|
- let eduNumArr = data.countData.eduNum.split(",")
|
231
|
|
- datas = {};
|
232
|
|
- datas[eduArrNameArr[0]] = eduNumArr[0];
|
233
|
|
- datas[eduArrNameArr[1]] = eduNumArr[1];
|
234
|
|
- datas[eduArrNameArr[2]] = eduNumArr[2];
|
235
|
|
- chartData.datas = datas;
|
236
|
|
- chartData.subtext = '人员学历统计';
|
237
|
|
- chartData.seriesName = "学历";
|
238
|
|
- chartData.addNum = 2
|
239
|
|
- // setBar("eduChart", chartData);
|
240
|
|
- setChart("#eduChart", getBar3Option(eduArrNameArr, eduNumArr))
|
241
|
|
-
|
242
|
|
-
|
243
|
|
- //人员年龄统计
|
244
|
|
- let ageArrNameArr = data.countData.ageArrName.split(",")
|
245
|
|
- let ageArrNum = data.countData.ageArrNum.split(",")
|
246
|
|
- datas = {};
|
247
|
|
- datas[ageArrNameArr[0]] = ageArrNum[0];
|
248
|
|
- datas[ageArrNameArr[1]] = ageArrNum[1];
|
249
|
|
- datas[ageArrNameArr[2]] = ageArrNum[2];
|
250
|
|
- datas[ageArrNameArr[3]] = ageArrNum[3];
|
251
|
|
- chartData = {};
|
252
|
|
- chartData.datas = datas;
|
253
|
|
- chartData.subtext = '人员年龄统计';
|
254
|
|
- chartData.seriesName = "年龄";
|
255
|
|
- chartData.isShowLine= false
|
256
|
|
- chartData.isShowTooltip = false
|
257
|
|
- // setPie("ageChart", chartData);
|
258
|
|
- var pie2 = setChart("#ageChart", getPie2Option(datas))
|
259
|
|
- // 默认选中第一个, 并处理选中逻辑
|
260
|
|
- var pie2DataIndex = 0
|
261
|
|
- pie2.on('mousemove', function(e) {
|
262
|
|
- pie2.dispatchAction({ type: 'downplay', dataIndex: pie2DataIndex });
|
263
|
|
- pie2.dispatchAction({ type: 'highlight', dataIndex: e.dataIndex });
|
264
|
|
- pie2DataIndex = e.dataIndex
|
265
|
|
- });
|
266
|
|
- pie2.dispatchAction({ type: 'highlight', dataIndex: pie2DataIndex });
|
267
|
|
-
|
268
|
|
- //机构分类统计
|
269
|
|
- let guaArrNameArr = data.countData.guaArrName.split(",");
|
270
|
|
- let guaArrNumArr = data.countData.guaArrNum.split(",");
|
271
|
|
- datas = {};
|
272
|
|
- for(var i=0;i<guaArrNameArr.length;i++){
|
273
|
|
- datas[guaArrNameArr[i]] = guaArrNumArr[i];
|
274
|
|
- }
|
275
|
|
- chartData = {};
|
276
|
|
- chartData.datas = datas;
|
277
|
|
- chartData.subtext = '';
|
278
|
|
- chartData.seriesName = "保障机构类别";
|
279
|
|
- chartData.isShowLine= false
|
280
|
|
- chartData.isShowTooltip = false
|
281
|
|
- // setBar("guaChart", chartData);
|
282
|
|
- setChart("#guaChart", getBar2Option(guaArrNameArr, guaArrNumArr))
|
283
|
|
-
|
284
|
|
- //供应设备分类统计
|
285
|
|
- let devArrName = data.countData.devArrName.split(",");
|
286
|
|
- let devArrNum = data.countData.devArrNum.split(",");
|
287
|
|
- datas = {};
|
288
|
|
- for(var i=0;i<devArrName.length;i++){
|
289
|
|
- datas[devArrName[i]] = devArrNum[i];
|
290
|
|
- }
|
291
|
|
- chartData = {};
|
292
|
|
- chartData.datas = datas;
|
293
|
|
- chartData.subtext = '';
|
294
|
|
- chartData.seriesName = "设备类别";
|
295
|
|
- chartData.isShowLine= false
|
296
|
|
- chartData.isShowTooltip = false
|
297
|
|
- // setPie("devChart", chartData);
|
298
|
|
- var pie1 = setChart("#devChart", getPie1Option(datas));
|
299
|
|
- // 默认选中第一个, 并处理选中逻辑
|
300
|
|
- var pie1DataIndex = 0
|
301
|
|
- pie1.on('mousemove', function(e) {
|
302
|
|
- pie1.dispatchAction({ type: 'downplay', dataIndex: pie1DataIndex });
|
303
|
|
- pie1.dispatchAction({ type: 'highlight', dataIndex: e.dataIndex });
|
304
|
|
- pie1DataIndex = e.dataIndex
|
305
|
|
- });
|
306
|
|
- pie1.dispatchAction({ type: 'highlight', dataIndex: pie1DataIndex });
|
307
|
|
-
|
308
|
|
- let guaAbiJson = data.countData.guaAbiJson
|
309
|
|
- $(".info-list").find("span").each(function(){
|
310
|
|
- let objId = $(this).attr("id")
|
311
|
|
- if(guaAbiJson[objId] != null){
|
312
|
|
- $(this).text(guaAbiJson[objId]);
|
313
|
|
- }
|
314
|
|
- })
|
315
|
|
- let config_service_ability = guaAbiJson.config_service_ability
|
316
|
|
- let serviceArr = config_service_ability.split(",")
|
317
|
|
- for(let key in serviceArr){
|
318
|
|
- if(serviceArr[key] != null && serviceArr[key] != ""){
|
319
|
|
- $(".info-text").append('<span class="label">'+serviceArr[key]+'</span>')
|
320
|
|
-
|
321
|
|
- }
|
322
|
|
- }
|
323
|
|
- }
|
324
|
|
- });
|
325
|
|
-
|
326
|
|
- }
|
327
|
|
- function taskTimeReport() {
|
328
|
|
- let year = $("#selYear").val()
|
329
|
|
- $
|
330
|
|
- .ajax({
|
331
|
|
- url : urlPre + "taskTimeReport?yearTime="+year,
|
332
|
|
- dataType : 'json',
|
333
|
|
- success : function(yearTask) {
|
334
|
|
- var chartData = {};
|
335
|
|
- let xAxisData = []
|
336
|
|
- let datas = []
|
337
|
|
- for(let key in yearTask){
|
338
|
|
- xAxisData[xAxisData.length] = key
|
339
|
|
- datas[datas.length] = yearTask[key]
|
340
|
|
- }
|
341
|
|
- chartData.datas = datas;
|
342
|
|
- chartData.xAxisData = xAxisData;
|
343
|
|
- chartData.addNum = 2;
|
344
|
|
- setLine("taskChart", chartData);
|
345
|
|
- }
|
346
|
|
- })
|
347
|
|
- }
|
348
|
|
- function commentReport(){
|
349
|
|
- let queryParams = {};
|
350
|
|
- queryParams.schCols = 'itemCode,itemName';
|
351
|
|
- queryParams.limit = 200
|
352
|
|
- queryParams["sorts[0].field"] = 'sort';
|
353
|
|
- queryParams["sorts[0].order"] = 'asc';
|
354
|
|
- queryParams.search_LENGTH_itemCode = 2;
|
355
|
|
- let colArr = []
|
356
|
|
- $.ajax({
|
357
|
|
- type : 'post',
|
358
|
|
- async : false,
|
359
|
|
- url : urlPre + 'api/commentItem/page',
|
360
|
|
- data:queryParams,
|
361
|
|
- dataType : 'json',
|
362
|
|
- success : function(data) {
|
363
|
|
- var rows = data.rows;
|
364
|
|
- for(var m = 0; m < rows.length; m++){
|
365
|
|
- if(m<3){
|
366
|
|
- let row = rows[m]
|
367
|
|
- let str = '<span>'+row.itemName+'(优)</span>'
|
368
|
|
- $("#commentLi").append(str)
|
369
|
|
- colArr[colArr.length] = row.itemCode + "_1"
|
370
|
|
- }
|
371
|
|
-
|
372
|
|
- }
|
373
|
|
- }
|
374
|
|
- });
|
375
|
|
- return colArr;
|
|
23
|
+<script>
|
|
24
|
+ var paramT = '1';
|
|
25
|
+ var matched = /t=(\d)/.exec(location.search);
|
|
26
|
+ if (matched) {
|
|
27
|
+ paramT = matched[1] || '1';
|
376
|
28
|
}
|
377
|
29
|
|
378
|
|
- console.log('-------->', window)
|
379
|
|
-</script>
|
|
30
|
+ if (paramT == '2') {
|
|
31
|
+ document.querySelector('#t2').style.display="block"
|
|
32
|
+ } else {
|
|
33
|
+ document.querySelector('#t1').style.display="block"
|
|
34
|
+ }
|
|
35
|
+</script>
|
380
|
36
|
</html>
|