프로젝트

일반

사용자정보

통계
| 브랜치(Branch): | 개정판:

markus / ConvertService / ServiceBase / Markus.Service.StationController / ViewModel / DashBoardViewModel.cs @ 90865212

이력 | 보기 | 이력해설 | 다운로드 (14.9 KB)

1 2f07b70a semi
using Markus.Service.Extensions;
2
using Markus.Service.StationController.Data;
3
using Markus.Service.StationController.Extensions;
4
using Newtonsoft.Json;
5
using Telerik.Charting;
6
using Telerik.Windows.Controls;
7
using Telerik.Windows.Controls.ChartView;
8
using System;
9
using System.Collections.Generic;
10
using System.Linq;
11
using System.Text;
12
using System.Threading.Tasks;
13
using System.Windows;
14
using System.Windows.Threading;
15
using ConverCOUNT = Markus.Service.StationController.Data.ConvertCOUNT;
16 c7955b40 semi
using System.Collections.ObjectModel;
17 2f07b70a semi
18
namespace Markus.Service.StationController.ViewModel
19
{
20 80391351 semi
    class DashBoardViewModel : Mvvm.ToolKit.ViewModelBase 
21 2f07b70a semi
    {
22
        #region Constructor
23
24
25
        public DashBoardViewModel()
26
        {
27
            RemoveCreateTimeFilterCommand = new DelegateCommand(RemoveCreateTimeFilter);
28
        }
29
30
        #endregion
31
32
        #region Properties
33
34
        static DateTime DefaultCreateTime = DateTime.Now;
35
        private DateTime _SelectedCreateTimeBegin = DefaultCreateTime;
36
        public DateTime SelectedCreateTimeBegin
37
        {
38
39
            get { return _SelectedCreateTimeBegin; }
40
            set
41
            {
42
                if (_SelectedCreateTimeBegin == value)
43
                    return;
44
                _SelectedCreateTimeBegin = value;
45
                OnPropertyChanged(() => SelectedCreateTimeBegin);
46
47
            }
48
        }
49
50
        private DateTime _SelectedCreateTimeEnd = DefaultCreateTime;
51
        public DateTime SelectedCreateTimeEnd
52
        {
53
54
            get { return _SelectedCreateTimeEnd; }
55
            set
56
            {
57
                if (_SelectedCreateTimeEnd == value)
58
                    return;
59
                _SelectedCreateTimeEnd = value;
60
                OnPropertyChanged(() => SelectedCreateTimeEnd);
61
            }
62
        }
63
64
        private SelectedCountItem _SelectedCount;
65
        public SelectedCountItem SelectedCount
66
        {
67
            get => _SelectedCount;
68
            set
69
            {
70
                _SelectedCount = value;
71
                OnPropertyChanged(() => SelectedCount);
72
            }
73
        }
74
75
        List<SelectedCountItem> _SelectedCountList;
76
        public List<SelectedCountItem> SelectedCountList
77
        {
78
            get
79
            {
80
                if (_SelectedCountList == null)
81
                {
82
                    _SelectedCountList = new List<SelectedCountItem>
83
                    {
84
                        new SelectedCountItem{DisplayMember = "50",ValueMember = 50},
85
                        new SelectedCountItem{DisplayMember = "100",ValueMember = 100},
86
                        new SelectedCountItem{DisplayMember = "150",ValueMember = 150},
87
                        new SelectedCountItem{DisplayMember = "200",ValueMember = 200}
88
                    };
89
                }
90
91
                return _SelectedCountList;
92
            }
93
        }
94
95 c7955b40 semi
        private ObservableCollection<ConvertCOUNT> _ConvertCOUNTDashBoard;
96
        public ObservableCollection<ConvertCOUNT> ConvertCOUNTDashBoard
97 2f07b70a semi
        {
98
            get
99
            {
100 c7955b40 semi
                if (_ConvertCOUNTDashBoard == null)
101 2f07b70a semi
                {
102 c7955b40 semi
                    _ConvertCOUNTDashBoard = new ObservableCollection<ConvertCOUNT>();
103 2f07b70a semi
                }
104 c7955b40 semi
                return _ConvertCOUNTDashBoard;
105 2f07b70a semi
            }
106
            set
107
            {
108 c7955b40 semi
                if (_ConvertCOUNTDashBoard != value)
109
                {
110
                    _ConvertCOUNTDashBoard = value;
111
                    OnPropertyChanged(() => ConvertCOUNTDashBoard);
112
                }
113
            }
114
        }
115
116
        private ObservableCollection<FinalPDFCOUNT> _FinalPDFCOUNTDashBoard;
117
        public ObservableCollection<FinalPDFCOUNT> FinalPDFCOUNTDashBoard
118
        {
119
            get
120
            {
121
                if (_FinalPDFCOUNTDashBoard == null)
122
                {
123
                    _FinalPDFCOUNTDashBoard = new ObservableCollection<FinalPDFCOUNT>();
124
                }
125
                return _FinalPDFCOUNTDashBoard;
126
            }
127
            set
128
            {
129
                if (_FinalPDFCOUNTDashBoard != value)
130
                {
131
                    _FinalPDFCOUNTDashBoard = value;
132
                    OnPropertyChanged(() => FinalPDFCOUNTDashBoard);
133
                }
134 2f07b70a semi
            }
135
        }
136
137
        private Telerik.Windows.Data.EnumMemberViewModel _SelectedStatus;
138
        public Telerik.Windows.Data.EnumMemberViewModel SelectedStatus
139
        {
140
            get => _SelectedStatus;
141
            set
142
            {
143
                _SelectedStatus = value;
144
                OnPropertyChanged(() => SelectedStatus);
145
            }
146
        }
147
148
        IEnumerable<Telerik.Windows.Data.EnumMemberViewModel> _StatusCodeList;
149
        public IEnumerable<Telerik.Windows.Data.EnumMemberViewModel> StatusCodeList
150
        {
151
            get
152
            {
153
                if (_StatusCodeList == null)
154
                {
155
                    _StatusCodeList = Telerik.Windows.Data.EnumDataSource.FromType<ConvertPDF.StatusCodeType>();
156
                }
157
158
                return _StatusCodeList;
159
            }
160
        }
161
162
        #endregion
163
164
        #region Command
165
166
        public DelegateCommand RemoveCreateTimeFilterCommand { get; private set; }
167
168
        #endregion
169
170
        #region Main Logic
171
172
        /// <summary>
173
        /// 각각의 Grid row 객체들 업데이트
174
        /// </summary>
175
176
        private DispatcherTimer dispatcherTimer;
177
        public override void Loaded()
178
        {
179
            base.Loaded();
180
181
            if (!App.IsDesignMode)
182
            {
183
                dispatcherTimer = new DispatcherTimer();
184
                dispatcherTimer.Tick += new EventHandler(Timer_Tick);
185
                dispatcherTimer.Interval = new TimeSpan(0, 0, 1);
186
                dispatcherTimer.Start();
187
            }
188
        }
189
190
        private async void Timer_Tick(object sender, EventArgs e)
191
        {
192
            dispatcherTimer.Stop();
193
194
            if (IsAcitve)
195
            {
196
                await App.Current.Dispatcher.InvokeAsync(() =>
197
                {
198
                    DataSelect();
199
                });
200
            }
201
202
            //await Task.Delay(5000);
203
            await Task.Delay(10000);
204
205
            //System.Threading.Thread.Sleep(new TimeSpan(0,0,0,0,100));
206
207
            dispatcherTimer.Start();
208
        }
209
210
        public override void Closed()
211
        {
212
            if (dispatcherTimer != null)
213
            {
214
                dispatcherTimer.Stop();
215
            }
216
217
            base.Closed();
218
        }
219
220
221
        #endregion
222
223
        #region Function
224
225
        #region RemoveCreateTimeFilter
226
227
        public void RemoveCreateTimeFilter(object obj)
228
        {
229
            DefaultCreateTime = DateTime.Now;
230
            SelectedCreateTimeBegin = DefaultCreateTime;
231
            SelectedCreateTimeEnd = DefaultCreateTime;
232
        }
233
234
        #endregion
235
236
237
        #region Data Select
238
239
        /// <summary>
240
        /// 상단 그리드 중앙 그리드 출력 데이터
241
        /// </summary>
242
        private void DataSelect()
243
        {
244 c7955b40 semi
            if (ConvertCOUNTDashBoard == null)
245
            {
246
                ConvertCOUNTDashBoard = new ObservableCollection<ConvertCOUNT>();
247
            }
248
            if(FinalPDFCOUNTDashBoard == null)
249 80391351 semi
            {
250 c7955b40 semi
                FinalPDFCOUNTDashBoard = new ObservableCollection<FinalPDFCOUNT>();
251 80391351 semi
            }
252
253 2f07b70a semi
            if (SelectedStatus != null)
254
            {
255 c7955b40 semi
                ConvertDataSelect(new[] { (ConvertPDF.StatusCodeType)(SelectedStatus.Value) }, ConvertCOUNTDashBoard);
256
                FinalPDFDataSelect(new[] { (ConvertPDF.StatusCodeType)(SelectedStatus.Value) }, FinalPDFCOUNTDashBoard);
257 2f07b70a semi
            }
258
        }
259
260 c7955b40 semi
        private void ConvertDataSelect(IEnumerable<ConvertPDF.StatusCodeType> statusCodeTypeList, ObservableCollection<ConvertCOUNT> collection)
261 2f07b70a semi
        {
262
            try
263
            {
264
                using (markusEntities entities = new markusEntities(App.MarkusDataBaseConnecitonString))
265
                {
266
                    int _status = 0;
267
                    if (SelectedStatus != null)
268
                    {
269
                        _status = (int)SelectedStatus.Value;
270
                    }
271
272
                    //DocumentID = unikey
273
                    DateTime? Start_CreateTime = null;
274
                    DateTime? Finish_CreateTime = null;
275
                    if (SelectedCreateTimeBegin != DefaultCreateTime)
276
                    {
277
                        Start_CreateTime = SelectedCreateTimeBegin;
278
                    }
279
                    if (SelectedCreateTimeEnd != DefaultCreateTime)
280
                    {
281
                        Finish_CreateTime = SelectedCreateTimeEnd;
282
                    }
283
284
                    var items = entities.SELECT_CONVERT_COUNT(_status, Start_CreateTime, Finish_CreateTime).ToList();
285
286 c7955b40 semi
                    List<ConvertCOUNT> Listitems = new List<ConvertCOUNT>();
287 2f07b70a semi
288 80391351 semi
                    for (int i = 0; i < items.Count; i++)
289 2f07b70a semi
                    {
290 c7955b40 semi
                        ConvertCOUNT AddItem = new ConvertCOUNT(items[i].PROJECT_NO, items[i].COUNT, items[i].EXCEPTION_COUNT);
291 80391351 semi
                        Listitems.Add(AddItem);
292
                    }
293
294
                    if (collection.Count() == 0)
295
                    {
296
                        if (statusCodeTypeList.Count() == 1)
297
                        {
298
                            foreach (var x in Listitems)
299
                            {
300 c7955b40 semi
                                collection.Add(x); 
301 80391351 semi
                            }
302
                        }
303
                    }
304
                    else
305
                    {
306
307
                        //세미 업데이트
308
                        foreach (var newitem in Listitems)
309 2f07b70a semi
                        {
310 80391351 semi
                            collection.UpdateWhere(changeitem =>
311
                            ConvertItemEx.ChangeValues(changeitem, newitem), x => x.Project_NO == newitem.Project_NO && x.Count == newitem.Count);
312 2f07b70a semi
                        }
313 80391351 semi
314
315
                        if (statusCodeTypeList.Count() == 1)
316
                        {
317
318
                            //삭제
319
                            for (int i = collection.Count() - 1; i >= 0; --i)
320
                            {
321
                                var item = collection[i];
322
323
                                if (Listitems.Count(x => x.Project_NO == item.Project_NO && x.Count == item.Count) == 0)
324
                                {
325
                                    collection.RemoveAt(i);
326
                                }
327
                            }
328
                        }
329
330
                        if (statusCodeTypeList.Count() == 1)
331 2f07b70a semi
                        {
332 80391351 semi
                            //추가 convert 후 추가됨
333
                            foreach (var item in Listitems)
334
                            {
335
                                if (collection.Count(x => x.Project_NO == item.Project_NO && x.Count == item.Count) == 0)
336
                                {
337
                                    for (int i = 0; i < 200; i++)
338
                                    {
339
                                        collection.Add(item);
340
                                        break;
341
                                    }
342
                                }
343
                            }
344 2f07b70a semi
                        }
345
                    }
346
                }
347
            }
348
            catch (Exception ex)
349
            {
350
                MessageBox.Show(ex.ToString());
351
            }
352
        }
353
354 c7955b40 semi
        private void FinalPDFDataSelect(IEnumerable<ConvertPDF.StatusCodeType> statusCodeTypeList, ObservableCollection<FinalPDFCOUNT> collection)
355
        {
356
            try
357
            {
358
                using (markusEntities entities = new markusEntities(App.MarkusDataBaseConnecitonString))
359
                {
360
                    int _status = 0;
361
                    if (SelectedStatus != null)
362
                    {
363
                        _status = (int)SelectedStatus.Value;
364
                    }
365
366
                    //DocumentID = unikey
367
                    DateTime? Start_CreateTime = null;
368
                    DateTime? Finish_CreateTime = null;
369
                    if (SelectedCreateTimeBegin != DefaultCreateTime)
370
                    {
371
                        Start_CreateTime = SelectedCreateTimeBegin;
372
                    }
373
                    if (SelectedCreateTimeEnd != DefaultCreateTime)
374
                    {
375
                        Finish_CreateTime = SelectedCreateTimeEnd;
376
                    }
377
378
                    var items = entities.SELECT_FINALPDF_COUNT(_status, Start_CreateTime, Finish_CreateTime).ToList();
379
380
                    List<FinalPDFCOUNT> Listitems = new List<FinalPDFCOUNT>();
381
382
                    for (int i = 0; i < items.Count; i++)
383
                    {
384
                        FinalPDFCOUNT AddItem = new FinalPDFCOUNT(items[i].PROJECT_NO, items[i].COUNT, items[i].EXCEPTION_COUNT);
385
                        Listitems.Add(AddItem);
386
                    }
387
388
                    if (collection.Count() == 0)
389
                    {
390
                        if (statusCodeTypeList.Count() == 1)
391
                        {
392
                            foreach (var x in Listitems)
393
                            {
394
                                collection.Add(x);
395
                            }
396
                        }
397
                    }
398
                    else
399
                    {
400
401
                        //세미 업데이트
402
                        foreach (var newitem in Listitems)
403
                        {
404
                            collection.UpdateWhere(changeitem =>
405
                            ConvertItemEx.ChangeValues(changeitem, newitem), x => x.Project_NO == newitem.Project_NO && x.Count == newitem.Count);
406
                        }
407
408
409
                        if (statusCodeTypeList.Count() == 1)
410
                        {
411
412
                            //삭제
413
                            for (int i = collection.Count() - 1; i >= 0; --i)
414
                            {
415
                                var item = collection[i];
416
417
                                if (Listitems.Count(x => x.Project_NO == item.Project_NO && x.Count == item.Count) == 0)
418
                                {
419
                                    collection.RemoveAt(i);
420
                                }
421
                            }
422
                        }
423
424
                        if (statusCodeTypeList.Count() == 1)
425
                        {
426
                            //추가 convert 후 추가됨
427
                            foreach (var item in Listitems)
428
                            {
429
                                if (collection.Count(x => x.Project_NO == item.Project_NO && x.Count == item.Count) == 0)
430
                                {
431
                                    for (int i = 0; i < 200; i++)
432
                                    {
433
                                        collection.Add(item);
434
                                        break;
435
                                    }
436
                                }
437
                            }
438
                        }
439
                    }
440
                }
441
            }
442
            catch (Exception ex)
443
            {
444
                MessageBox.Show(ex.ToString());
445
            }
446
        }
447 2f07b70a semi
        #endregion
448
449
        #endregion
450
    }
451
}
클립보드 이미지 추가 (최대 크기: 500 MB)