markus / ConvertService / ServiceBase / Markus.Service.StationController / ViewModel / DataBaseItemsModel.cs @ c8183702
이력 | 보기 | 이력해설 | 다운로드 (28.2 KB)
1 | a6e5055d | alzkakdixm | using GemBox.Spreadsheet; |
---|---|---|---|
2 | using Markus.Message; |
||
3 | using Markus.Service.DataBase; |
||
4 | using Markus.Service.Extensions; |
||
5 | using Markus.Service.StationController.Behaviors; |
||
6 | using Markus.Service.StationController.Extensions; |
||
7 | using Microsoft.Win32; |
||
8 | using System; |
||
9 | using System.Collections.Generic; |
||
10 | using System.ComponentModel; |
||
11 | using System.Linq; |
||
12 | 2decfbdf | alzkakdixm | using System.Threading.Tasks; |
13 | using System.Web; |
||
14 | a6e5055d | alzkakdixm | using System.Windows; |
15 | using Telerik.Windows.Controls; |
||
16 | using Telerik.Windows.Data; |
||
17 | using ConvertItem = Markus.Service.Interface.ConvertItem; |
||
18 | |||
19 | namespace Markus.Service.StationController.ViewModel |
||
20 | { |
||
21 | //세미 |
||
22 | dfc86b71 | taeseongkim | public class DataBaseItemsModel : Mvvm.ToolKit.ViewModelBase |
23 | a6e5055d | alzkakdixm | { |
24 | 2decfbdf | alzkakdixm | private System.Collections.ObjectModel.ObservableCollection<ConvertItem> _AliveItems; |
25 | public System.Collections.ObjectModel.ObservableCollection<ConvertItem> AliveItems |
||
26 | { |
||
27 | get => _AliveItems; set |
||
28 | { |
||
29 | 0cb12397 | alzkakdixm | _AliveItems = value; |
30 | 2decfbdf | alzkakdixm | OnPropertyChanged(() => AliveItems); |
31 | } |
||
32 | } |
||
33 | |||
34 | dfc86b71 | taeseongkim | private System.Collections.ObjectModel.ObservableCollection<ConvertItem> _FilterConvertSource; |
35 | public System.Collections.ObjectModel.ObservableCollection<ConvertItem> FilterConvertSource |
||
36 | { |
||
37 | get => _FilterConvertSource; |
||
38 | set |
||
39 | { |
||
40 | _FilterConvertSource = value; |
||
41 | OnPropertyChanged(() => FilterConvertSource); |
||
42 | } |
||
43 | } |
||
44 | |||
45 | |||
46 | private System.Collections.ObjectModel.ObservableCollection<ConvertItem> _RealConvertSource; |
||
47 | public System.Collections.ObjectModel.ObservableCollection<ConvertItem> RealConvertSource |
||
48 | { |
||
49 | get => _RealConvertSource; |
||
50 | set |
||
51 | { |
||
52 | _RealConvertSource = value; |
||
53 | OnPropertyChanged(() => RealConvertSource); |
||
54 | } |
||
55 | } |
||
56 | |||
57 | 2decfbdf | alzkakdixm | |
58 | 0cb12397 | alzkakdixm | private System.Windows.Documents.FlowDocument connectionLog; |
59 | 2decfbdf | alzkakdixm | public System.Windows.Documents.FlowDocument ConnectionLog |
60 | { |
||
61 | get => connectionLog; |
||
62 | set |
||
63 | { |
||
64 | if (connectionLog != value) |
||
65 | { |
||
66 | connectionLog = value; |
||
67 | OnPropertyChanged(() => ConnectionLog); |
||
68 | } |
||
69 | } |
||
70 | } |
||
71 | |||
72 | //public AliveViewModel() |
||
73 | //{ |
||
74 | //} |
||
75 | |||
76 | //// 진행률에 변화가 있을때 이벤트가 발생 |
||
77 | //private void backgroundWorker_ProgressChanged(object sender, ProgressChangedEventArgs e) |
||
78 | //{ |
||
79 | //} |
||
80 | |||
81 | //// 일이 모두 마쳤을때 수행되어야할 코드 |
||
82 | //private void backgroundWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e) |
||
83 | //{ |
||
84 | //} |
||
85 | |||
86 | // BackgroundWorker에서 수행할 일을 정의. |
||
87 | private void AlivebackgroundWorker_ProgressChanged(object sender, ProgressChangedEventArgs e) |
||
88 | { |
||
89 | } |
||
90 | private void AlivebackgroundWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e) |
||
91 | { |
||
92 | } |
||
93 | private async void AlivebackgroundWorker_DoWork(object sender, DoWorkEventArgs e) |
||
94 | { |
||
95 | while (IsAcitve) |
||
96 | { |
||
97 | |||
98 | if (!IsLoading) |
||
99 | { |
||
100 | IsLoading = true; |
||
101 | |||
102 | try |
||
103 | { |
||
104 | |||
105 | List<ConvertItem> newitems = new List<ConvertItem>(); |
||
106 | |||
107 | foreach (var client in App.StationClientList) |
||
108 | { |
||
109 | if (await SimplePingAsync(client.Endpoint.Address.ToString())) |
||
110 | { |
||
111 | try |
||
112 | { |
||
113 | List<ConvertItem> itemsToList = new List<ConvertItem>(); |
||
114 | var items = await client.AliveConvertListAsync(); |
||
115 | 0cb12397 | alzkakdixm | |
116 | 2decfbdf | alzkakdixm | foreach (var item in items) |
117 | { |
||
118 | ConvertItem itemsToEach = new ConvertItem(); |
||
119 | itemsToEach.ServiceID = item.ServiceID; |
||
120 | itemsToEach.ConvertID = item.ConvertID; |
||
121 | itemsToEach.ProjectNumber = item.ProjectNumber; |
||
122 | 0cb12397 | alzkakdixm | try |
123 | { |
||
124 | itemsToEach.ConvertState = (StatusCodeType)Enum.Parse(typeof(StatusCodeType), item.ConvertState); |
||
125 | } |
||
126 | catch (Exception ex) |
||
127 | { |
||
128 | |||
129 | throw ex; |
||
130 | } |
||
131 | |||
132 | //itemsToEach.ConvertState = (StatusCodeType)Enum.Parse(typeof(StatusCodeType), item.ConvertState); |
||
133 | 2decfbdf | alzkakdixm | itemsToEach.CurrentPageNo = item.CurrentPageNo; |
134 | itemsToEach.TotalPage = item.TotalPage; |
||
135 | itemsToEach.OriginfilePath = item.OriginfilePath; |
||
136 | itemsToEach.ConvertPath = item.ConvertPath; |
||
137 | |||
138 | itemsToList.Add(itemsToEach); |
||
139 | } |
||
140 | newitems.AddRange(itemsToList); |
||
141 | 0cb12397 | alzkakdixm | System.Diagnostics.Trace.WriteLine($"{client.Endpoint.Address} ping"); |
142 | 2decfbdf | alzkakdixm | |
143 | if (items.Count() == 0) |
||
144 | { |
||
145 | 0cb12397 | alzkakdixm | System.Diagnostics.Trace.WriteLine($"{client.Endpoint.Address} Alive Items is zero."); |
146 | 2decfbdf | alzkakdixm | } |
147 | } |
||
148 | catch (Exception ex) |
||
149 | { |
||
150 | 0cb12397 | alzkakdixm | System.Diagnostics.Trace.Fail($"{client.Endpoint.Address} {ex.Message}"); |
151 | 2decfbdf | alzkakdixm | } |
152 | } |
||
153 | else |
||
154 | { |
||
155 | 0cb12397 | alzkakdixm | System.Diagnostics.Trace.Fail($"{client.Endpoint.Address} ping Error"); |
156 | 2decfbdf | alzkakdixm | } |
157 | } |
||
158 | await System.Windows.Application.Current.Dispatcher.InvokeAsync(() => ItemsUpdate(newitems)); |
||
159 | } |
||
160 | catch (Exception ex) |
||
161 | { |
||
162 | System.Diagnostics.Debug.WriteLine(ex.ToString()); |
||
163 | } |
||
164 | |||
165 | IsLoading = false; |
||
166 | } |
||
167 | |||
168 | } |
||
169 | } |
||
170 | |||
171 | |||
172 | private async void AliveDataSelect() |
||
173 | { |
||
174 | try |
||
175 | { |
||
176 | List<ConvertItem> newitems = new List<ConvertItem>(); |
||
177 | |||
178 | foreach (var client in App.StationClientList) |
||
179 | { |
||
180 | if (await SimplePingAsync(client.Endpoint.Address.ToString())) |
||
181 | { |
||
182 | try |
||
183 | { |
||
184 | List<ConvertItem> itemsToList = new List<ConvertItem>(); |
||
185 | var items = await client.AliveConvertListAsync(); |
||
186 | foreach (var item in items) |
||
187 | { |
||
188 | ConvertItem itemsToEach = new ConvertItem(); |
||
189 | itemsToEach.ServiceID = item.ServiceID; |
||
190 | itemsToEach.ConvertID = item.ConvertID; |
||
191 | itemsToEach.ProjectNumber = item.ProjectNumber; |
||
192 | try |
||
193 | { |
||
194 | itemsToEach.ConvertState = (StatusCodeType)Enum.Parse(typeof(StatusCodeType), item.ConvertState); |
||
195 | } |
||
196 | catch (Exception ex) |
||
197 | { |
||
198 | |||
199 | throw ex; |
||
200 | } |
||
201 | 0cb12397 | alzkakdixm | |
202 | 2decfbdf | alzkakdixm | itemsToEach.CurrentPageNo = item.CurrentPageNo; |
203 | itemsToEach.TotalPage = item.TotalPage; |
||
204 | itemsToEach.OriginfilePath = item.OriginfilePath; |
||
205 | itemsToEach.ConvertPath = item.ConvertPath; |
||
206 | |||
207 | itemsToList.Add(itemsToEach); |
||
208 | } |
||
209 | newitems.AddRange(itemsToList); |
||
210 | System.Diagnostics.Trace.WriteLine($"{client.Endpoint.Address} ping"); |
||
211 | |||
212 | if (items.Count() == 0) |
||
213 | { |
||
214 | System.Diagnostics.Trace.WriteLine($"{client.Endpoint.Address} Alive Items is zero."); |
||
215 | } |
||
216 | } |
||
217 | catch (Exception ex) |
||
218 | { |
||
219 | System.Diagnostics.Trace.Fail($"{client.Endpoint.Address} {ex.Message}"); |
||
220 | } |
||
221 | } |
||
222 | else |
||
223 | { |
||
224 | System.Diagnostics.Trace.Fail($"{client.Endpoint.Address} ping Error"); |
||
225 | } |
||
226 | } |
||
227 | |||
228 | 0cb12397 | alzkakdixm | ItemsUpdate(newitems); |
229 | 2decfbdf | alzkakdixm | await System.Windows.Application.Current.Dispatcher.InvokeAsync(() => ItemsUpdate(newitems)); |
230 | } |
||
231 | catch (Exception ex) |
||
232 | { |
||
233 | System.Diagnostics.Debug.WriteLine(ex.ToString()); |
||
234 | } |
||
235 | } |
||
236 | |||
237 | |||
238 | private void ItemsUpdate(List<ConvertItem> newitems) |
||
239 | { |
||
240 | |||
241 | foreach (var item in newitems) |
||
242 | { |
||
243 | item.OriginfilePath = HttpUtility.UrlDecode(item.OriginfilePath); |
||
244 | } |
||
245 | |||
246 | 0cb12397 | alzkakdixm | if (AliveItems == null) |
247 | 2decfbdf | alzkakdixm | { |
248 | AliveItems = new System.Collections.ObjectModel.ObservableCollection<ConvertItem>(); |
||
249 | |||
250 | foreach (var item in newitems) |
||
251 | { |
||
252 | AliveItems.Add(item); |
||
253 | } |
||
254 | } |
||
255 | else |
||
256 | { |
||
257 | /// 데이터 업데이트 |
||
258 | newitems.ForEach(newitem => |
||
259 | { |
||
260 | AliveItems.UpdateWhere(changeitem => ConvertItemEx.ChangeValues(changeitem, newitem), x => x.ProjectNumber == newitem.ProjectNumber && x.ConvertID == newitem.ConvertID); |
||
261 | }); |
||
262 | |||
263 | // 추가 |
||
264 | foreach (var item in newitems) |
||
265 | { |
||
266 | if (AliveItems.Count(x => x.ConvertID == item.ConvertID && x.ProjectNumber == item.ProjectNumber) == 0) |
||
267 | { |
||
268 | AliveItems.Add(item); |
||
269 | } |
||
270 | } |
||
271 | |||
272 | /// 삭제 |
||
273 | |||
274 | for (int i = AliveItems.Count() - 1; i > -1; --i) |
||
275 | { |
||
276 | var item = AliveItems[i]; |
||
277 | |||
278 | if (newitems.Count(x => x.ConvertID == item.ConvertID && x.ProjectNumber == item.ProjectNumber) == 0) |
||
279 | { |
||
280 | try |
||
281 | { |
||
282 | AliveItems.RemoveAt(i); |
||
283 | } |
||
284 | catch (Exception ex) |
||
285 | { |
||
286 | System.Diagnostics.Debug.WriteLine(ex.ToString()); |
||
287 | } |
||
288 | } |
||
289 | } |
||
290 | } |
||
291 | } |
||
292 | |||
293 | private void LogWrite(string log, bool IsError) |
||
294 | { |
||
295 | if (IsError) |
||
296 | { |
||
297 | System.Diagnostics.Trace.Fail(log); |
||
298 | } |
||
299 | else |
||
300 | { |
||
301 | System.Diagnostics.Trace.TraceInformation(log); |
||
302 | } |
||
303 | } |
||
304 | |||
305 | |||
306 | public static async Task<bool> SimplePingAsync(string uri) |
||
307 | { |
||
308 | bool result = false; |
||
309 | |||
310 | try |
||
311 | { |
||
312 | using (System.Net.Http.HttpClient Client = new System.Net.Http.HttpClient()) |
||
313 | { |
||
314 | Client.Timeout = new TimeSpan(0, 0, 60); |
||
315 | |||
316 | var message = await Client.GetAsync(uri); |
||
317 | |||
318 | System.Net.HttpStatusCode StatusCode = message.StatusCode; |
||
319 | |||
320 | switch (StatusCode) |
||
321 | { |
||
322 | |||
323 | case System.Net.HttpStatusCode.Accepted: |
||
324 | case System.Net.HttpStatusCode.OK: |
||
325 | result = true; |
||
326 | break; |
||
327 | } |
||
328 | } |
||
329 | } |
||
330 | catch (Exception ex) |
||
331 | { |
||
332 | result = false; |
||
333 | System.Diagnostics.Debug.WriteLine(ex.ToString()); |
||
334 | } |
||
335 | |||
336 | return result; |
||
337 | } |
||
338 | |||
339 | a6e5055d | alzkakdixm | BackgroundWorker backgroundWorker; |
340 | 0cb12397 | alzkakdixm | private BackgroundWorker AlivebackgroundWorker; |
341 | a6e5055d | alzkakdixm | |
342 | Random rnd = new Random(); |
||
343 | |||
344 | private Telerik.Windows.Data.EnumMemberViewModel _SelectedStatus; |
||
345 | public Telerik.Windows.Data.EnumMemberViewModel SelectedStatus |
||
346 | { |
||
347 | get => _SelectedStatus; |
||
348 | set |
||
349 | { |
||
350 | _SelectedStatus = value; |
||
351 | 0cb12397 | alzkakdixm | OnPropertyChanged(() => SelectedStatus); |
352 | a6e5055d | alzkakdixm | } |
353 | } |
||
354 | |||
355 | |||
356 | private SelectedCountItem _SelectedCount; |
||
357 | public SelectedCountItem SelectedCount |
||
358 | { |
||
359 | get => _SelectedCount; |
||
360 | set |
||
361 | { |
||
362 | _SelectedCount = value; |
||
363 | dfc86b71 | taeseongkim | OnPropertyChanged(() => SelectedCount); |
364 | a6e5055d | alzkakdixm | } |
365 | } |
||
366 | |||
367 | private void DataConvert(object obj) |
||
368 | { |
||
369 | 2decfbdf | alzkakdixm | if (SelectFilterConvert == null && SelectRealConvert == null) |
370 | { |
||
371 | MessageBox.Show("왼쪽 버튼 클릭 후 Converter 해주세요!"); |
||
372 | } |
||
373 | else |
||
374 | { |
||
375 | ConvertDatabase _DataConvert = new ConvertDatabase(App.MarkusDataBaseConnecitonString); |
||
376 | var resultRealConvert = 0; |
||
377 | var resultFiltertConvert = 0; |
||
378 | |||
379 | if (SelectRealConvert != null) |
||
380 | { |
||
381 | resultRealConvert = _DataConvert.SetCleanUpItem(SelectRealConvert); |
||
382 | } |
||
383 | else if (SelectFilterConvert != null) |
||
384 | { |
||
385 | resultFiltertConvert = _DataConvert.SetCleanUpItem(SelectFilterConvert); |
||
386 | } |
||
387 | c8183702 | taeseongkim | //System.Diagnostics.Debug.WriteLine(resultRealConvert + " " + resultFiltertConvert); |
388 | a6e5055d | alzkakdixm | |
389 | 2decfbdf | alzkakdixm | using (Markus.Service.DataBase.ConvertDatabase database = new Markus.Service.DataBase.ConvertDatabase(App.MarkusDataBaseConnecitonString)) |
390 | { |
||
391 | var items = database.GetConvertProjects(SelectFilterConvert); |
||
392 | |||
393 | foreach (var item in items) |
||
394 | { |
||
395 | RealConvertSource.Add(item); |
||
396 | } |
||
397 | |||
398 | } |
||
399 | } |
||
400 | a6e5055d | alzkakdixm | } |
401 | |||
402 | private void DataDelete(object obj) |
||
403 | { |
||
404 | 2decfbdf | alzkakdixm | RadWindow.Alert("정말로 삭제 하시겠습니까?", this.OnClosed); |
405 | } |
||
406 | a6e5055d | alzkakdixm | |
407 | 2decfbdf | alzkakdixm | private void OnClosed(object sender, WindowClosedEventArgs e) |
408 | { |
||
409 | var result = e.DialogResult; |
||
410 | if (result == true) |
||
411 | { |
||
412 | ConvertDatabase _DataConvert = new ConvertDatabase(App.MarkusDataBaseConnecitonString); |
||
413 | var resultRealConvert = _DataConvert.RemoveItem(SelectRealConvert.ConvertID); |
||
414 | var resultFiltertConvert = _DataConvert.RemoveItem(SelectFilterConvert.ConvertID); |
||
415 | System.Diagnostics.Debug.WriteLine(resultRealConvert + " " + resultFiltertConvert); |
||
416 | } |
||
417 | } |
||
418 | private void DataValidate(object obj) |
||
419 | { |
||
420 | MessageBox.Show("파일 체크 할껀데 정상인지 아닌지 "); |
||
421 | a6e5055d | alzkakdixm | |
422 | } |
||
423 | |||
424 | |||
425 | 0cb12397 | alzkakdixm | private ConvertItem _SelectFilterConvert; |
426 | a6e5055d | alzkakdixm | public ConvertItem SelectFilterConvert |
427 | { |
||
428 | get => _SelectFilterConvert; |
||
429 | set |
||
430 | { |
||
431 | _SelectFilterConvert = value; |
||
432 | dfc86b71 | taeseongkim | OnPropertyChanged(() => SelectFilterConvert); |
433 | a6e5055d | alzkakdixm | } |
434 | } |
||
435 | 0cb12397 | alzkakdixm | |
436 | private ConvertItem _SelectRealConvert; |
||
437 | a6e5055d | alzkakdixm | public ConvertItem SelectRealConvert |
438 | { |
||
439 | get => _SelectRealConvert; |
||
440 | set |
||
441 | { |
||
442 | _SelectRealConvert = value; |
||
443 | dfc86b71 | taeseongkim | OnPropertyChanged(() => SelectRealConvert); |
444 | a6e5055d | alzkakdixm | } |
445 | } |
||
446 | |||
447 | 0cb12397 | alzkakdixm | |
448 | private StatusTypeList _StatusType; |
||
449 | a6e5055d | alzkakdixm | public StatusTypeList StatusType |
450 | { |
||
451 | get => _StatusType; |
||
452 | set |
||
453 | { |
||
454 | _StatusType = value; |
||
455 | dfc86b71 | taeseongkim | OnPropertyChanged(() => StatusType); |
456 | a6e5055d | alzkakdixm | } |
457 | } |
||
458 | |||
459 | 0cb12397 | alzkakdixm | private bool _IsLoading; |
460 | a6e5055d | alzkakdixm | public bool IsLoading |
461 | { |
||
462 | get => _IsLoading; |
||
463 | set |
||
464 | { |
||
465 | if (_IsLoading != value) |
||
466 | { |
||
467 | _IsLoading = value; |
||
468 | dfc86b71 | taeseongkim | OnPropertyChanged(() => IsLoading); |
469 | a6e5055d | alzkakdixm | } |
470 | } |
||
471 | } |
||
472 | |||
473 | List<SelectedCountItem> _SelectedCountList; |
||
474 | public List<SelectedCountItem> SelectedCountList |
||
475 | { |
||
476 | get |
||
477 | { |
||
478 | if (_SelectedCountList == null) |
||
479 | { |
||
480 | _SelectedCountList = new List<SelectedCountItem> |
||
481 | { |
||
482 | new SelectedCountItem{DisplayMember = "50",ValueMember = 50}, |
||
483 | new SelectedCountItem{DisplayMember = "100",ValueMember = 100}, |
||
484 | new SelectedCountItem{DisplayMember = "150",ValueMember = 150}, |
||
485 | new SelectedCountItem{DisplayMember = "200",ValueMember = 200} |
||
486 | }; |
||
487 | } |
||
488 | |||
489 | return _SelectedCountList; |
||
490 | } |
||
491 | } |
||
492 | |||
493 | 0cb12397 | alzkakdixm | public DelegateCommand ConvertCommand { get; private set; } |
494 | public DelegateCommand DeleteCommand { get; private set; } |
||
495 | public DelegateCommand ValidateCommand { get; private set; } |
||
496 | |||
497 | a6e5055d | alzkakdixm | public DataBaseItemsModel() |
498 | { |
||
499 | 0cb12397 | alzkakdixm | DataSaveFileGemBoxCommand = new DelegateCommand(DataExportData); |
500 | a6e5055d | alzkakdixm | ConvertCommand = new DelegateCommand(DataConvert); |
501 | DeleteCommand = new DelegateCommand(DataDelete); |
||
502 | 2decfbdf | alzkakdixm | ValidateCommand = new DelegateCommand(DataValidate); |
503 | a6e5055d | alzkakdixm | } |
504 | |||
505 | // 진행률에 변화가 있을때 이벤트가 발생 |
||
506 | private void backgroundWorker_ProgressChanged(object sender, ProgressChangedEventArgs e) |
||
507 | { |
||
508 | MessageBox.Show("진행률에 변화"); |
||
509 | } |
||
510 | |||
511 | // 일이 모두 마쳤을때 수행되어야할 코드 |
||
512 | private void backgroundWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e) |
||
513 | { |
||
514 | MessageBox.Show("임무마침"); |
||
515 | } |
||
516 | |||
517 | IEnumerable<Telerik.Windows.Data.EnumMemberViewModel> _StatusCodeList; |
||
518 | public IEnumerable<Telerik.Windows.Data.EnumMemberViewModel> StatusCodeList |
||
519 | { |
||
520 | get |
||
521 | { |
||
522 | if (_StatusCodeList == null) |
||
523 | { |
||
524 | _StatusCodeList = Telerik.Windows.Data.EnumDataSource.FromType<StatusCodeType>(); |
||
525 | } |
||
526 | |||
527 | return _StatusCodeList; |
||
528 | } |
||
529 | } |
||
530 | // BackgroundWorker에서 수행할 일을 정의. |
||
531 | private void backgroundWorker_DoWork(object sender, DoWorkEventArgs e) |
||
532 | { |
||
533 | 0cb12397 | alzkakdixm | |
534 | a6e5055d | alzkakdixm | while (IsAcitve) |
535 | { |
||
536 | 2decfbdf | alzkakdixm | |
537 | a6e5055d | alzkakdixm | if (FilterConvertSource == null) |
538 | { |
||
539 | FilterConvertSource = new System.Collections.ObjectModel.ObservableCollection<ConvertItem>(); |
||
540 | } |
||
541 | |||
542 | if (RealConvertSource == null) |
||
543 | { |
||
544 | RealConvertSource = new System.Collections.ObjectModel.ObservableCollection<ConvertItem>(); |
||
545 | } |
||
546 | |||
547 | /// combobox 에서 선택된 items |
||
548 | if (SelectedStatus != null) |
||
549 | { |
||
550 | DataSelect(new[] { (StatusCodeType)(SelectedStatus.Value) }, FilterConvertSource); |
||
551 | } |
||
552 | |||
553 | /// 컨버터중인 items |
||
554 | 2decfbdf | alzkakdixm | RealDataSelect(new[] { StatusCodeType.None, StatusCodeType.Wait, StatusCodeType.PageLoading, StatusCodeType.Saving }, RealConvertSource); |
555 | a6e5055d | alzkakdixm | } |
556 | } |
||
557 | |||
558 | 2decfbdf | alzkakdixm | |
559 | |||
560 | private void RealDataSelect(IEnumerable<StatusCodeType> statusCodeTypeList, System.Collections.ObjectModel.ObservableCollection<ConvertItem> collection) |
||
561 | { |
||
562 | try |
||
563 | { |
||
564 | using (Markus.Service.DataBase.ConvertDatabase database = new Markus.Service.DataBase.ConvertDatabase(App.MarkusDataBaseConnecitonString)) |
||
565 | { |
||
566 | var items = database.GetConvertProjects(collection)//x:database객체 y:statusCodeTypeList의값 Count()안에 predicator 조건 만족하면 count개수안에 넣음 |
||
567 | .Take(SelectedCount.ValueMember).ToList();// |
||
568 | |||
569 | items.ForEach(newitem => |
||
570 | { |
||
571 | collection.UpdateWhere(changeitem => |
||
572 | ConvertItemEx.ChangeValues(changeitem, newitem), x => x.ConvertID == newitem.ConvertID && x.ProjectNumber == newitem.ProjectNumber); |
||
573 | }); |
||
574 | } |
||
575 | } |
||
576 | catch (Exception ex) |
||
577 | { |
||
578 | MessageBox.Show(ex.ToString()); |
||
579 | } |
||
580 | } |
||
581 | a6e5055d | alzkakdixm | //<>쓸때는 IEnumerable |
582 | 2decfbdf | alzkakdixm | |
583 | a6e5055d | alzkakdixm | private void DataSelect(IEnumerable<StatusCodeType> statusCodeTypeList, System.Collections.ObjectModel.ObservableCollection<ConvertItem> collection) |
584 | { |
||
585 | try |
||
586 | { |
||
587 | using (Markus.Service.DataBase.ConvertDatabase database = new Markus.Service.DataBase.ConvertDatabase(App.MarkusDataBaseConnecitonString)) |
||
588 | { |
||
589 | |||
590 | 2decfbdf | alzkakdixm | int _status = 0; |
591 | if (SelectedStatus != null) |
||
592 | { |
||
593 | _status = (int)SelectedStatus.Value; |
||
594 | } |
||
595 | |||
596 | var items = database.GetConvertProjects(_status)//x:database객체 y:statusCodeTypeList의값 Count()안에 predicator 조건 만족하면 count개수안에 넣음 |
||
597 | 0cb12397 | alzkakdixm | .Take(SelectedCount.ValueMember).ToList(); |
598 | 2decfbdf | alzkakdixm | |
599 | a6e5055d | alzkakdixm | if (collection.Count() == 0) |
600 | { |
||
601 | 2decfbdf | alzkakdixm | if (statusCodeTypeList.Count() == 1) |
602 | { |
||
603 | items.ForEach(x => collection.Add(x)); |
||
604 | } |
||
605 | a6e5055d | alzkakdixm | } |
606 | else |
||
607 | { |
||
608 | 2decfbdf | alzkakdixm | |
609 | ////세미 업데이트 |
||
610 | items.ForEach(newitem => |
||
611 | a6e5055d | alzkakdixm | { |
612 | collection.UpdateWhere(changeitem => |
||
613 | 2decfbdf | alzkakdixm | ConvertItemEx.ChangeValues(changeitem, newitem), x => x.ProjectNumber == newitem.ProjectNumber && x.ConvertID == newitem.ConvertID); |
614 | a6e5055d | alzkakdixm | }); |
615 | |||
616 | 2decfbdf | alzkakdixm | |
617 | if (statusCodeTypeList.Count() == 1) |
||
618 | a6e5055d | alzkakdixm | { |
619 | 2decfbdf | alzkakdixm | //삭제 |
620 | for (int i = collection.Count() - 1; i >= 0; --i) |
||
621 | a6e5055d | alzkakdixm | { |
622 | 2decfbdf | alzkakdixm | var item = collection[i]; |
623 | a6e5055d | alzkakdixm | |
624 | 2decfbdf | alzkakdixm | if (items.Count(x => x.ConvertID == item.ConvertID && x.ProjectNumber == item.ProjectNumber) == 0)//디비에서 가져온 값과 마지막값부터 차례대로 비교 |
625 | {//참=> 0제외한 모든 수 |
||
626 | collection.RemoveAt(i); |
||
627 | } |
||
628 | } |
||
629 | a6e5055d | alzkakdixm | } |
630 | |||
631 | 2decfbdf | alzkakdixm | if (statusCodeTypeList.Count() == 1) |
632 | a6e5055d | alzkakdixm | { |
633 | 2decfbdf | alzkakdixm | //추가 convert 후 추가됨 |
634 | foreach (var item in items) |
||
635 | { |
||
636 | if (collection.Count(x => x.ConvertID == item.ConvertID && x.ProjectNumber == item.ProjectNumber) == 0)//그리드와 디비 변동 없으면 안들어감 |
||
637 | { |
||
638 | /*for (int i = 0; i < collection.Count()+1; i++)//위 그리드에서 카운드 개수 변함 없고 컨버터 끝난 후 추가할때 createtime 비교 하며 order by 순으로 추가*/ |
||
639 | for (int i = 0; i < 200; i++) |
||
640 | { |
||
641 | if (i < collection.Count() - 1) |
||
642 | { |
||
643 | if (DateTime.Compare(collection[i].CreateTime, item.CreateTime) < 0) |
||
644 | { |
||
645 | collection.Insert(i, item); |
||
646 | break; |
||
647 | } |
||
648 | } |
||
649 | else |
||
650 | { |
||
651 | collection.Add(item); |
||
652 | break; |
||
653 | } |
||
654 | } |
||
655 | |||
656 | } |
||
657 | a6e5055d | alzkakdixm | |
658 | } |
||
659 | } |
||
660 | 2decfbdf | alzkakdixm | |
661 | a6e5055d | alzkakdixm | } |
662 | } |
||
663 | 2decfbdf | alzkakdixm | |
664 | a6e5055d | alzkakdixm | } |
665 | catch (Exception ex) |
||
666 | { |
||
667 | MessageBox.Show(ex.ToString()); |
||
668 | } |
||
669 | } |
||
670 | |||
671 | public override void Loaded() |
||
672 | { |
||
673 | base.Loaded(); |
||
674 | |||
675 | if (!App.IsDesignMode) |
||
676 | { |
||
677 | backgroundWorker = new BackgroundWorker(); |
||
678 | backgroundWorker.DoWork += backgroundWorker_DoWork; |
||
679 | backgroundWorker.RunWorkerCompleted += backgroundWorker_RunWorkerCompleted; |
||
680 | backgroundWorker.WorkerReportsProgress = false; |
||
681 | backgroundWorker.ProgressChanged += new ProgressChangedEventHandler(backgroundWorker_ProgressChanged); |
||
682 | |||
683 | backgroundWorker.RunWorkerAsync(); |
||
684 | 2decfbdf | alzkakdixm | |
685 | AlivebackgroundWorker = new BackgroundWorker(); |
||
686 | AlivebackgroundWorker.DoWork += AlivebackgroundWorker_DoWork; |
||
687 | AlivebackgroundWorker.RunWorkerCompleted += AlivebackgroundWorker_RunWorkerCompleted; |
||
688 | AlivebackgroundWorker.WorkerReportsProgress = false; |
||
689 | AlivebackgroundWorker.ProgressChanged += new ProgressChangedEventHandler(AlivebackgroundWorker_ProgressChanged); |
||
690 | |||
691 | AlivebackgroundWorker.RunWorkerAsync(); |
||
692 | a6e5055d | alzkakdixm | } |
693 | } |
||
694 | |||
695 | public override void Closed() |
||
696 | { |
||
697 | |||
698 | if (backgroundWorker != null) |
||
699 | { |
||
700 | backgroundWorker.DoWork -= backgroundWorker_DoWork; |
||
701 | backgroundWorker.RunWorkerCompleted -= backgroundWorker_RunWorkerCompleted; |
||
702 | backgroundWorker.WorkerReportsProgress = false; |
||
703 | backgroundWorker.ProgressChanged -= new ProgressChangedEventHandler(backgroundWorker_ProgressChanged); |
||
704 | |||
705 | 2decfbdf | alzkakdixm | AlivebackgroundWorker.DoWork -= AlivebackgroundWorker_DoWork; |
706 | AlivebackgroundWorker.RunWorkerCompleted -= AlivebackgroundWorker_RunWorkerCompleted; |
||
707 | AlivebackgroundWorker.WorkerReportsProgress = false; |
||
708 | AlivebackgroundWorker.ProgressChanged -= new ProgressChangedEventHandler(AlivebackgroundWorker_ProgressChanged); |
||
709 | |||
710 | AlivebackgroundWorker.Dispose(); |
||
711 | a6e5055d | alzkakdixm | |
712 | 2decfbdf | alzkakdixm | } |
713 | a6e5055d | alzkakdixm | base.Closed(); |
714 | } |
||
715 | |||
716 | |||
717 | public DelegateCommand DataSaveFileGemBoxCommand { get; private set; } |
||
718 | 0cb12397 | alzkakdixm | public void DataExportData(object obj) |
719 | a6e5055d | alzkakdixm | { |
720 | 0cb12397 | alzkakdixm | DataExport dataExport = new DataExport(); |
721 | dataExport.DataExportData(FilterConvertSource); |
||
722 | a6e5055d | alzkakdixm | } |
723 | |||
724 | 0cb12397 | alzkakdixm | public class SelectedCountItem : INotifyPropertyChanged |
725 | { |
||
726 | public event PropertyChangedEventHandler PropertyChanged; |
||
727 | a6e5055d | alzkakdixm | |
728 | 0cb12397 | alzkakdixm | private void NotifyPropertyChanged(String info) |
729 | a6e5055d | alzkakdixm | { |
730 | 0cb12397 | alzkakdixm | if (PropertyChanged != null) |
731 | a6e5055d | alzkakdixm | { |
732 | 0cb12397 | alzkakdixm | PropertyChanged(this, new PropertyChangedEventArgs(info)); |
733 | a6e5055d | alzkakdixm | } |
734 | } |
||
735 | |||
736 | 0cb12397 | alzkakdixm | //public string DisplayMember { get; set; } |
737 | public string _DisplayMember; |
||
738 | a6e5055d | alzkakdixm | |
739 | 0cb12397 | alzkakdixm | public string DisplayMember |
740 | a6e5055d | alzkakdixm | { |
741 | 0cb12397 | alzkakdixm | get => _DisplayMember; |
742 | set |
||
743 | a6e5055d | alzkakdixm | { |
744 | 0cb12397 | alzkakdixm | _DisplayMember = value; |
745 | a6e5055d | alzkakdixm | |
746 | 0cb12397 | alzkakdixm | NotifyPropertyChanged("DisplayMember"); |
747 | a6e5055d | alzkakdixm | } |
748 | 2decfbdf | alzkakdixm | } |
749 | 0cb12397 | alzkakdixm | //public int ValueMember { get; set; } |
750 | public int _ValueMember; |
||
751 | public int ValueMember |
||
752 | 2decfbdf | alzkakdixm | { |
753 | 0cb12397 | alzkakdixm | get => _ValueMember; |
754 | set |
||
755 | { |
||
756 | _ValueMember = value; |
||
757 | NotifyPropertyChanged("ValueMember"); |
||
758 | } |
||
759 | 2decfbdf | alzkakdixm | } |
760 | } |
||
761 | a6e5055d | alzkakdixm | } |
762 | } |