프로젝트

일반

사용자정보

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

markus / KCOM / Services / BaseServices.cs @ 54a28343

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

1
using Microsoft.AspNet.SignalR.Client;
2
using IKCOM;
3
using KCOM.Common;
4
using KCOM.ServiceDeepView;
5
using KCOMDataModel.DataModel;
6
using Newtonsoft.Json;
7
using RestSharp;
8
using System;
9
using System.Collections.Generic;
10
using System.Collections.ObjectModel;
11
using System.ComponentModel;
12
using System.Linq;
13
using System.Runtime.CompilerServices;
14
using System.Text;
15
using System.Windows;
16
using System.Windows.Controls;
17
using Telerik.Windows.Controls;
18
using MarkupToPDF.Controls.Parsing;
19
using Telerik.Windows.Data;
20
using System.Web;
21

    
22
namespace KCOM.Views
23
{
24
    public partial class MainMenu : UserControl, INotifyPropertyChanged
25
    {
26
        //const string DeepZoomUrl = @"http://{baseUrl}/TileSource/{TileSourcePath}/{ItemsPath}/{SharepointItemID}/{PageNo}.jpg";
27
        public ServiceDeepViewClient BaseClient;
28
        public KcomService.ServiceDeepViewClient BaseTaskClient;
29
        public ViewInfo _ViewInfo;
30
        public DOCINFO _DocInfo;
31
        public DOCUMENT_ITEM _DocItem;
32
        public MEMBER userData;
33

    
34
        public event PropertyChangedEventHandler PropertyChanged;
35
        private void NotifyPropertyChanged([CallerMemberName] String propertyName = "")
36
        {
37
            if (PropertyChanged != null)
38
            {
39
                PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
40
            }
41
        }
42

    
43
        private Common.DocumentSet _CurrentDoc { get; set; }
44
        public Common.DocumentSet CurrentDoc
45
        {
46
            get
47
            {
48
                return _CurrentDoc;
49
            }
50
            set
51
            {
52
                if (value != CurrentDoc)
53
                {
54
                    _CurrentDoc = value;
55
                    NotifyPropertyChanged();
56
                }
57
            }
58
        }
59
        public void ServiceOn()
60
        {
61
            BaseTaskClient = new KcomService.ServiceDeepViewClient(App._binding, App._EndPoint);
62
            BaseClient = new ServiceDeepViewClient(App._binding, App._EndPoint);
63

    
64
            BaseClient.GetDocInfoCompleted += BaseClient_GetDocInfoCompleted; //문서 섬네일, 페이지크기, 마크업 정보 [3]
65
            BaseClient.GetConversionStateCompleted += BaseClient_GetConversionStateCompleted;  //컨버팅의 여부 [2] 
66
            BaseClient.GetSystemDataCompleted += BaseClient_GetSystemDataCompleted; //시스템 정보 [1] 
67
            BaseClient.GetDocumentItemInfoCompleted += BaseClient_GetDocumentItemInfoCompleted; // 문서 자체의 정보 [4]
68
            BaseClient.GetMarkupInfoItemsCompleted += BaseClient_GetMarkupInfoItemsCompleted;
69
            BaseClient.GetDeptDataCompleted += BaseClient_GetDeptDataCompleted;
70
            BaseClient.DeleteMarkupCompleted += BaseClient_DeleteMarkupCompleted;
71
            BaseClient.GetVPRevisionHistoryCompleted += BaseClient_GetVPRevisionHistoryCompleted;
72
            BaseClient.SetFinalPDFCompleted += BaseClient_SetFinalPDFCompleted;
73
            BaseClient.GetCompareRectCompleted += BaseClient_GetCompareRectCompleted;
74
            BaseClient.DeleteMarkupCompleted += BaseClient_DeleteMarkupCompleted;
75
            BaseClient.DelFavoriteVPCompleted += BaseClient_DelFavoriteVPCompleted;
76
            BaseClient.EditFavoriteVPCompleted += BaseClient_EditFavoriteVPCompleted;
77
        }
78

    
79

    
80

    
81
        private void BaseClient_EditFavoriteVPCompleted(object sender, EditFavoriteVPCompletedEventArgs e)
82
        {
83
            Logger.sendResLog("EditFavoriteVPCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
84
            
85
            if (e.Error == null && e.Result != false)
86
            {
87
                Logger.sendReqLog("GetFavoriteVPAsync", App.ViewInfo.ProjectNO + "," + App.ViewInfo.UserID + "," + App.ViewInfo.DocumentItemID, 1);
88
                BaseClient.GetFavoriteVPAsync(App.ViewInfo.ProjectNO, App.ViewInfo.UserID, App.ViewInfo.DocumentItemID);
89
            }
90
            else
91
            {
92
                DialogMessage_Alert("Unable to delete the file due to a system failure", "Warning");
93
            }
94
        }
95

    
96
        private void BaseClient_DelFavoriteVPCompleted(object sender, DelFavoriteVPCompletedEventArgs e)
97
        {
98
            Logger.sendResLog("DelFavoriteVPCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
99

    
100
            if (e.Error == null && e.Result != false)
101
            {
102
                Logger.sendReqLog("GetFavoriteVPAsync", App.ViewInfo.ProjectNO + "," + App.ViewInfo.UserID + "," + App.ViewInfo.DocumentItemID, 1);
103
                BaseClient.GetFavoriteVPAsync(App.ViewInfo.ProjectNO, App.ViewInfo.UserID, App.ViewInfo.DocumentItemID);
104
            }
105
            else
106
            {
107
                DialogMessage_Alert("Unable to delete the file due to a system failure", "Warning");
108
            }
109
        }
110

    
111
        /// <summary>
112
        /// Compare 결과를 받아 화면에 표시한다
113
        /// </summary>
114
        /// <param name="sender"></param>
115
        /// <param name="e"></param>
116
        private void BaseClient_GetCompareRectCompleted(object sender, GetCompareRectCompletedEventArgs e)
117
        {
118
            if (e.Error != null || e.Result == null)
119
            {
120
                if (e.Error != null)
121
                {
122
                    DialogMessage_Alert(e.Error.ToString(), "Error");
123
                }
124
                else
125
                {
126
                    DialogMessage_Alert("Compare 기능을 원활히 실행하기 위한 데이터가 부족합니다", "안내");
127
                }
128
            }
129
            else
130
            {
131
                e.Result.ForEach(d =>
132
                {
133
                    d.Width = d.Width * 3;
134
                    d.Height = d.Height * 3;
135
                    var point = MarkupToPDF.Controls.Common.MathSet.getRectMiddlePoint(d);
136
                    System.Windows.Shapes.Rectangle myEllipse = new System.Windows.Shapes.Rectangle();
137
                    myEllipse.Fill = new System.Windows.Media.SolidColorBrush(System.Windows.Media.Color.FromArgb(100,255,8,0));
138
                    myEllipse.Opacity = 0.8;
139
                    myEllipse.Width = d.Width;
140
                    myEllipse.Height = d.Height;
141
                    Canvas.SetLeft(myEllipse, d.X - ((point.X - d.X) / 2.0));
142
                    Canvas.SetTop(myEllipse, d.Y - ((point.Y - d.Y) / 2.0));
143
                    myEllipse.RenderTransformOrigin = point;
144
                    canvas_compareBorder.Children.Add(myEllipse);
145
                });
146

    
147
                da.From = 0.8;
148
                da.To = 0.1;
149
                da.Duration = new Duration(TimeSpan.FromSeconds(1));
150
                da.AutoReverse = true;
151
                canvas_compareBorder.BeginAnimation(OpacityProperty, da);
152
            }
153
        }
154

    
155
        private void BaseClient_SetFinalPDFCompleted(object sender, SetFinalPDFCompletedEventArgs e)
156
        {
157
            Logger.sendResLog("SetFinalPDFCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
158
            string errormsg = CommonLib.Common.GetAlertMessageString("SetFinalPDFError", "MSG", "최종 파일을 만드는데 문제가 발생하였습니다");
159
            string successmsg = CommonLib.Common.GetAlertMessageString("SetFinalPDFSuccess", "MSG", "최종 파일 생성 중입니다. 문서관리시스템을 확인해주세요");
160
            if (e.Error != null || e.Result.Status == FinalStatus.Error)
161
            {
162
                DialogMessage_Alert(errormsg, "안내");
163
            }
164
            else
165
            {
166
                DialogMessage_Alert(successmsg, "안내");
167
            }
168
        }
169

    
170
        private void BaseClient_GetVPRevisionHistoryCompleted(object sender, GetVPRevisionHistoryCompletedEventArgs e)
171
        {
172
            Logger.sendResLog("GetVPRevisionHistoryCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
173

    
174
            if (e.Result != null && e.Error == null)
175
            {
176
                List<VPRevision> list = e.Result;
177
                foreach (var item in list)
178
                {
179

    
180
                    if (App.isExternal)
181
                    {
182
                        var sBaseServiceURL = CommonLib.Common.GetConfigString("ExternalOriginalFileUrl", "URL", "", App.isExternal);
183

    
184
                        if (!string.IsNullOrWhiteSpace(item.TO_VENDOR))
185
                        {
186
                            var toUri = new Uri(HttpUtility.UrlDecode(item.TO_VENDOR));
187
                            item.TO_VENDOR = $"{sBaseServiceURL}{toUri.LocalPath}";
188
                        }
189

    
190
                        if (!string.IsNullOrWhiteSpace(item.FROM_VENDOR))
191
                        {
192
                            var fromUri = new Uri(HttpUtility.UrlDecode(item.FROM_VENDOR));
193
                            item.FROM_VENDOR = $"{sBaseServiceURL}{fromUri.LocalPath}";
194
                        }
195
                    }
196
                    else
197
                    {
198

    
199
                        item.FROM_VENDOR = HttpUtility.UrlDecode(item.FROM_VENDOR);
200
                    }
201
                }
202
                gridViewHistory.ItemsSource = list;
203
            }
204
            //TempFile.TempLoad();
205
        }
206

    
207
        private void BaseClient_DeleteMarkupCompleted(object sender, DeleteMarkupCompletedEventArgs e)
208
        {
209
            Logger.sendResLog("DeleteMarkupCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
210

    
211
            foreach(var info in ViewerDataModel.Instance._markupInfoList)
212
            {
213
                if(info.UserID == App.ViewInfo.UserID)
214
                {
215
                    info.userDelete = true;
216
                    info.DisplayColor = "FFFF0000";
217
                }
218
                else
219
                {
220
                    info.userDelete = false;
221
                }
222
            }
223
        }
224

    
225
        private void BaseClient_GetDeptDataCompleted(object sender, GetDeptDataCompletedEventArgs e)
226
        {
227
            if (e.Error == null)
228
            {
229
                Logger.sendResLog("GetDeptDataCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
230
            }
231
            else
232
            {
233
                Logger.sendResLog("GetDeptDataCompleted",  "\r Error :" + e.Error, 1);
234
            }
235

    
236
            if (e.Result != null)
237
            {
238
                e.Result.Sort();
239
                //cbSymbolPublic.ItemsSource = e.Result.ToList();
240
            }
241
        }
242

    
243
        public MarkupInfoItem PreviewUserMarkupInfoItem { get; set; }
244

    
245
        /// <summary>
246
        /// 문서 정보를 가져온다
247
        /// </summary>
248
        /// <param name="sender"></param>
249
        /// <param name="e"></param>
250
        private async void BaseClient_GetDocInfoCompleted(object sender, GetDocInfoCompletedEventArgs e)
251
        {
252
            //Logger.sendResLog("GetDocInfoCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
253

    
254
            if (e.Error != null)
255
            {
256
                DialogMessage_Alert("The page cannot be displayed.", "Alert");
257
                return;
258
            }
259

    
260
            string sFolder = _ViewInfo.DocumentItemID.All(char.IsDigit) ? (Convert.ToUInt32(_ViewInfo.DocumentItemID) / 100).ToString() : (_ViewInfo.DocumentItemID.Length >= 5 ? _ViewInfo.DocumentItemID.Substring(0, 5) : _ViewInfo.DocumentItemID);
261
            var MainUrl = string.Format(CommonLib.Common.GetConfigString("mainServerImageWebPath", "URL", "", App.isExternal).Replace("png","jpg"), _ViewInfo.ProjectNO, sFolder, _ViewInfo.DocumentItemID, "{PageNo}");
262
            _DocInfo = e.Result;
263
            _DocInfo.ORIGINAL_FILE = HttpUtility.UrlDecode(_DocInfo.ORIGINAL_FILE);
264
            foreach (var item in _DocInfo.DOCPAGE.OrderBy(order => order.PAGE_NUMBER))
265
            {
266
                ViewerDataModel.Instance.Document_Info.Add(item);
267
            }
268
            Logger.sendReqLog("GetMarkupInfoItemsAsync", _ViewInfo.ProjectNO + "," + _DocInfo.ID, 1);
269
           CurrentDoc = new Common.DocumentSet
270
            {
271
                docInfo = _DocInfo,
272
                Document_Id = _DocInfo.DOCUMENT_ID,
273
                File_Original = _DocInfo.ORIGINAL_FILE,
274

    
275
                Document_NO = _DocItem?.DOCUMENT_NO,
276
                File_Result = _DocItem?.RESULT_FILE,
277
                Group_No = _DocItem?.GROUP_NO,
278
                ProjectNo = _DocItem?.PROJECT_NO,
279
                Revision = _DocItem?.REVISION,
280
            };
281

    
282
            var instanceMain = this.ParentOfType<MainWindow>();
283
            string firstpage = "1";
284
            string lastpage = _DocInfo.PAGE_COUNT.ToString();
285
            instanceMain.dzTopMenu.tlcurrentPage.Text = firstpage;
286
            instanceMain.dzTopMenu.tlcurrentPage_readonly.Text = lastpage;
287
            string apptitle = string.Format("MARKUS(ver.{2}) - {0}(Rev.{1})", _DocItem?.DOCUMENT_NO, _DocItem?.REVISION, System.Reflection.Assembly.GetExecutingAssembly().GetName().Version.ToString());
288

    
289
            instanceMain.Title = apptitle;
290

    
291
            #region 페이지 이미지를 로컬에 저장
292
            string tempStoragePath = System.IO.Path.Combine(System.IO.Path.GetTempPath(),"MARKUS", System.IO.Path.GetRandomFileName());
293

    
294
            //.Replace("jpg", "png")을 붙이는 이유는 MainUrl에 확장명이 jpg로 설정한 경우가 있기 때문
295

    
296
            #endregion
297
            App.PageStorage = new PageManager.PageStorage(MainUrl.Replace("jpg","png"), tempStoragePath,"png", _DocInfo.PAGE_COUNT);
298
         
299
            await this.pageNavigator.SetPageNaviAsync(CurrentDoc.docInfo.DOCPAGE.ToList(), MainUrl);
300

    
301
        }
302

    
303
        private async void pageNavigator_ThumbInitialized(object sender,EventArgs e)
304
        {
305
            BaseClient.GetMarkupInfoItemsAsync(_ViewInfo.ProjectNO, _DocInfo.ID);
306

    
307
            ViewerDataModel.Instance.MarkupControls_USER.Clear();
308
            //ViewerDataModel.Instance.SystemMain.dzMainMenu.TempLoad();
309

    
310
            #region 단어 검색용 파일 다운로드
311

    
312
            await DownloadOriginalFileAsync();
313

    
314
            #endregion
315

    
316
            Logger.sendReqLog("GetVPRevisionHistoryAsync", CurrentDoc.ProjectNo + "," + CurrentDoc.Document_NO + "," + CurrentDoc.Document_Id, 1);
317
            BaseClient.GetVPRevisionHistoryAsync(CurrentDoc.ProjectNo, CurrentDoc.Document_NO, CurrentDoc.Document_Id);
318

    
319
        }
320

    
321

    
322
        /// <summary>
323
        /// get markupinfo and markupitem from database
324
        ///  - 1. called when document is loaded
325
        ///  - 2. called when user do consolidation
326
        /// </summary>
327
        /// <param name="sender"></param>
328
        /// <param name="e"></param>
329
        private void BaseClient_GetMarkupInfoItemsCompleted(object sender, GetMarkupInfoItemsCompletedEventArgs e)
330
        {
331
            Logger.sendResLog("GetMarkupInfoItemsCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
332

    
333
            ViewerDataModel.Instance.MarkupControls_USER.Clear();
334
            ViewerDataModel.Instance.MarkupControls.Clear();
335
            if (e.Result != null)
336
            {
337
                ViewerDataModel.Instance._markupInfoList.Clear();
338
                if (e.Result.Count > 0) ViewerDataModel.Instance.MyMarkupList.Clear();
339

    
340
                foreach (var info in e.Result)
341
                {
342
                    if (info.UserID == App.ViewInfo.UserID)
343
                    {
344
                        info.userDelete = true;
345
                        info.DisplayColor = "#FFFF0000";
346
                    }
347
                    else
348
                    {
349
                        info.userDelete = false;
350
                    }
351
                    ViewerDataModel.Instance._markupInfoList.Add(info);
352
                }
353

    
354
                var userInfoList = ViewerDataModel.Instance._markupInfoList.GroupBy(f => f.UserID).Select(f => new MarkupUserInfo { UserId = f.Key, UserName = f.First().UserName });
355

    
356
                userInfoList.ToList().ForEach(x => ViewerDataModel.Instance._markupUserList.Add(x));
357

    
358
                e.Result.ToList().ForEach(d =>
359
                {
360
                    if (d.MarkupList != null)
361
                    {
362
                        d.MarkupList.ForEach(p =>
363
                        {
364
                            if (d.UserID == App.ViewInfo.UserID)
365
                            {
366
                                d.userDelete = true;
367
                                d.DisplayColor = "#FFFF0000";
368

    
369
                                MarkupItemEx markup = new MarkupItemEx
370
                                {
371
                                    Data = p.Data,
372
                                    Data_Type = p.Data_Type,
373
                                    ID = p.ID,
374
                                    IsUpdate = false,
375
                                    MarkupInfoID = d.MarkupInfoID,
376
                                    PageNumber = p.PageNumber,
377
                                    Symbol_ID = p.Symbol_ID,
378
                                //Group_ID = p.Group_ID
379
                            };
380
                                ViewerDataModel.Instance.MyMarkupList.Add(markup);
381
                            }
382
                            else
383
                            {
384
                                MarkupItemEx markup = new MarkupItemEx
385
                                {
386
                                    Data = p.Data,
387
                                    Data_Type = p.Data_Type,
388
                                    ID = p.ID,
389
                                    IsUpdate = false,
390
                                    MarkupInfoID = d.MarkupInfoID,
391
                                    PageNumber = p.PageNumber,
392
                                    Symbol_ID = p.Symbol_ID,
393
                                //Group_ID = p.Group_ID
394
                            };
395
                                ViewerDataModel.Instance.MarkupList_Pre.Add(markup);
396
                            }
397
                        });
398
                    }
399
                });
400

    
401
                var currentUser = e.Result.Where(data => data.UserID == App.ViewInfo.UserID && data.AvoidConsolidate == 0).FirstOrDefault();
402

    
403
                if (currentUser == null)
404
                {
405
                    /// create a new markupinfo to do comments
406
                    var infoId = Commons.shortGuid();
407
                    PreviewUserMarkupInfoItem = new MarkupInfoItem
408
                    {
409
                        CreateTime = DateTime.Now,
410
                        UpdateTime = DateTime.Now,
411
                        Depatment = userData.DEPARTMENT,
412
                        DisplayColor = "#FFFF0000",
413
                        UserID = userData.ID,
414
                        UserName = userData.NAME,
415
                        PageCount = 1,
416
                        Description = "",
417
                        MarkupInfoID = infoId,
418
                        MarkupList = null,
419
                        MarkupVersionID = Commons.shortGuid(),
420
                        Consolidate = 0,
421
                        PartConsolidate = 0,
422
                        userDelete = true,
423
                        AvoidConsolidate = 0,
424
                        IsPreviewUser = false
425
                    };
426

    
427
                    App.Custom_ViewInfoId = infoId;
428

    
429
                    ViewerDataModel.Instance._markupInfoList.Insert(0, PreviewUserMarkupInfoItem);
430
                }
431
                else
432
                {
433
                    App.Custom_ViewInfoId = currentUser.MarkupInfoID;
434
                }
435

    
436
                foreach(var info in e.Result)
437
                {
438
                    if (info.UserID == App.ViewInfo.UserID) info.DisplayColor = "#FFFF0000";
439
                }
440

    
441
                ViewerDataModel.Instance.PageNumber = 1;
442

    
443
                /// Consolidation 된 데이터가 최상단에 올 수 있도록 변경
444
                var markupItem = ViewerDataModel.Instance._markupInfoList.OrderByDescending(p => p.Consolidate == Convert.ToInt32(true)).ToList();
445
                markupItem.ForEach(data =>
446
                {
447
                    if (data.Depatment == null) data.Depatment = "Unknown";
448
                });
449
                gridViewMarkup.ItemsSource = ViewerDataModel.Instance._markupInfoList;
450
                SetCommentPages();
451

    
452
                var SelectedItem = ViewerDataModel.Instance._markupInfoList.Where(info => info.UserID == App.ViewInfo.UserID).OrderByDescending(order => order.UpdateTime).FirstOrDefault();
453
                this.gridViewMarkup.SelectedItem = (PreviewUserMarkupInfoItem != null) ? PreviewUserMarkupInfoItem : SelectedItem;
454
                
455
                /// create a group descriptor
456
                gridViewMarkup.GroupDescriptors.Clear();
457
                GroupDescriptor descriptor = new GroupDescriptor();
458
                descriptor.Member = "Depatment";
459
                descriptor.DisplayContent = "DEPT";
460
                //descriptor.SortDirection = ListSortDirection.Ascending;
461
                gridViewMarkup.GroupDescriptors.Add(descriptor);
462
                /// up to here
463
            }
464
        }
465

    
466
        private async void gridViewRevMarkup_SelectionChanged(object sender, Telerik.Windows.Controls.SelectionChangeEventArgs e)
467
        {
468
            List<MarkupInfoItem> gridSelectionItem = gridViewRevMarkup.SelectedItems.Cast<MarkupInfoItem>().ToList(); //선택 된 마크업
469
            //if (ViewerDataModel.Instance.PageBalanceNumber == 0)
470
            //{
471
            //    ViewerDataModel.Instance.PageBalanceNumber = 1;
472
            //}
473

    
474
            if (ViewerDataModel.Instance.PageNumber == 0)
475
            {
476
                ViewerDataModel.Instance.PageNumber = 1;
477
            }
478
            if (e.AddedItems.Count() > 0)
479
            {
480
                foreach (var item in gridSelectionItem)
481
                {
482
                    //item.MarkupList.Where(pageItem => pageItem.PageNumber == ViewerDataModel.Instance.PageBalanceNumber).ToList().ForEach(delegate (MarkupItem markupitem)
483
                    //{
484
                    //    layerControl.markupParse(markupitem.Data, Common.ViewerDataModel.Instance.MarkupControls_Sync, item.DisplayColor, "", item.MarkupInfoID);
485
                    //});
486

    
487
                    var pageItems = item.MarkupList.Where(pageItem => pageItem.PageNumber == ViewerDataModel.Instance.PageNumber).ToList();
488

    
489
                    foreach (var markupitem in pageItems)
490
                    {
491
                       await MarkupParser.ParseExAsync(App.ViewInfo.ProjectNO, markupitem.Data, Common.ViewerDataModel.Instance.MarkupControls_Sync, item.DisplayColor, "", item.MarkupInfoID);
492
                    }
493
                }
494
            }
495
            else if (e.RemovedItems.Count > 0)
496
            {
497
                var _infoItem = e.RemovedItems.Cast<MarkupInfoItem>().ToList();
498

    
499
                (from A in _infoItem
500
                 from B in Common.ViewerDataModel.Instance.MarkupControls_Sync
501
                 where A.MarkupInfoID == B.MarkupInfoID
502
                 select B).ToList().ForEach(data =>
503
                 {
504
                     Common.ViewerDataModel.Instance.MarkupControls_Sync.Remove(data);
505
                 });
506
            }
507
        }
508

    
509
        /// <summary>
510
        /// 선택한 항목은 Visibility = Visible, 해제한 항목은 Visibility = Hidden 처리한다.
511
        /// </summary>
512
        /// <param name="sender"></param>
513
        /// <param name="e"></param>
514
        private async void gridViewMarkup_SelectionChanged(object sender, Telerik.Windows.Controls.SelectionChangeEventArgs e)
515
        {
516
            SelectionSet.Instance.UnSelect(Common.ViewerDataModel.Instance.SystemMain.dzMainMenu);
517

    
518
            var dataSet = gridViewMarkup.SelectedItems.Cast<MarkupInfoItem>().Where(data => data.UserID == _ViewInfo.UserID);
519
            var dataSet_User = gridViewMarkup.Items.Cast<MarkupInfoItem>().Where(data => data.UserID == _ViewInfo.UserID);
520
            var resultA = (from item_Select in dataSet
521
                           from item_Non in dataSet_User
522
                           where item_Select == item_Non
523
                           select item_Non).ToList();
524

    
525
            if (resultA.Count() >= 2)
526
            {
527
                // 동일한 사용자 데이터가 두개 이상 선택됩니다. Consolidation을 선택할까요?
528
                RadWindow.Confirm(new DialogParameters
529
                {
530
                    Owner = Application.Current.MainWindow,
531
                    Header = "Info",
532
                    Content = "Selected more than two identical user data. Do you want to select consolidation?",
533
                    Closed = new EventHandler<WindowClosedEventArgs>((sen, ea) =>
534
                    {
535
                        if (e.AddedItems.Count() == 1)
536
                        {
537
                            MarkupInfoItem instanceItem = e.AddedItems.FirstOrDefault() as MarkupInfoItem;
538
                            gridViewMarkup.SelectedItem = null;
539

    
540
                        
541
                            if (ea.DialogResult.Value)
542
                            {
543
                                if (instanceItem.Consolidate == 1 || instanceItem.PartConsolidate == 1)
544
                                {
545
                                    gridViewMarkup.SelectedItem = instanceItem;
546
                                }
547
                                else
548
                                {
549
                                    //1. Consolidations이 있다면 하나 선택
550
                                    var Consolidations = resultA.Where(item => (item.Consolidate == 1 || item.PartConsolidate == 1));
551

    
552
                                    if (Consolidations.Count() > 0)
553
                                    {
554
                                        gridViewMarkup.SelectedItem = Consolidations.First();
555
                                    }
556
                                }
557
                              
558
                            }
559
                            else {
560
                                //1. Consolidations 아닌게 있다면 Change
561
                                var notConsolidations = resultA.Where(item => !(item.Consolidate == 1 || item.PartConsolidate == 1));
562

    
563
                                if(notConsolidations.Count() > 0) {
564
                                    gridViewMarkup.SelectedItem = notConsolidations.First();
565
                                }
566
                                else {//1. Consolidations 아닌게 없다면 그대로
567
                                    gridViewMarkup.SelectedItem = instanceItem;
568
                                }
569
                                
570
                            }
571
                        }
572
                    }),
573
                    Theme = new Windows8Theme(),
574
                    ModalBackground = new System.Windows.Media.SolidColorBrush { Color = System.Windows.Media.Colors.Black, Opacity = 0.6 },
575
                });
576
            }
577
            else //파라미터로 넘어온 사용자가 걸리지 않은 경우
578
            {
579
                List<MarkupInfoItem> gridItem = gridViewMarkup.Items.Cast<MarkupInfoItem>().ToList(); //전체 마크업
580
                List<MarkupInfoItem> gridSelectionItem = gridViewMarkup.SelectedItems.Cast<MarkupInfoItem>().ToList(); //선택 된 마크업
581
                List<MarkupInfoItem> gridNonSelectionItem = gridItem.Except(gridSelectionItem).ToList(); //선택 되지 않은 마크업
582
                #region 코멘트 보기
583
                if (e.AddedItems.Count() > 0)
584
                {
585
                    foreach (var item in gridSelectionItem)
586
                    {
587
                        if (item.UserID == App.ViewInfo.UserID)
588
                        {
589
                            var controls = Common.ViewerDataModel.Instance.MarkupControls_USER.Where(d => d.MarkupInfoID == item.MarkupInfoID).ToList();
590
                            if (controls.Count == 0)
591
                            {
592
                                var instance = ViewerDataModel.Instance.MyMarkupList.Where(d => d.PageNumber == this.pageNavigator.CurrentPage.PageNumber && d.MarkupInfoID == item.MarkupInfoID).ToList();
593

    
594
                                foreach (var markup in instance)
595
                                {
596
                                    await MarkupParser.ParseExAsync(App.ViewInfo.ProjectNO, markup.Data, Common.ViewerDataModel.Instance.MarkupControls_USER, item.DisplayColor, "", 
597
                                        item.MarkupInfoID, markup.ID);
598
                                }
599
                            }
600

    
601
                            controls = Common.ViewerDataModel.Instance.MarkupControls_USER.Where(d => d.MarkupInfoID == item.MarkupInfoID).ToList();
602
                            foreach (var control in controls)
603
                            {
604
                                Logger.sendCheckLog(String.Format("=={0}", control), 1);
605
                                control.Visibility = Visibility.Visible;
606
                            }
607
                        }
608
                        else
609
                        {
610
                            var controls = Common.ViewerDataModel.Instance.MarkupControls.Where(d => d.MarkupInfoID == item.MarkupInfoID).ToList();
611
                            if (controls.Count == 0)
612
                            {
613
                                var instance = ViewerDataModel.Instance.MarkupList_Pre.Where(d => d.PageNumber == this.pageNavigator.CurrentPage.PageNumber && d.MarkupInfoID == item.MarkupInfoID).ToList();
614
                                foreach (var markup in instance)
615
                                {
616
                                    await MarkupParser.ParseExAsync(App.ViewInfo.ProjectNO, markup.Data, Common.ViewerDataModel.Instance.MarkupControls, item.DisplayColor, "",
617
                                        item.MarkupInfoID, markup.ID);
618
                                }
619
                            }
620

    
621
                            controls = Common.ViewerDataModel.Instance.MarkupControls.Where(d => d.MarkupInfoID == item.MarkupInfoID).ToList();
622
                            foreach (var control in controls)
623
                            {
624
                                control.Visibility = Visibility.Visible;
625
                            }
626
                        }
627
                    }
628
                }
629
                #endregion
630
                #region 코멘트 숨기기
631
                else if (e.RemovedItems.Count > 0)
632
                {
633
                    var _infoItem = e.RemovedItems.Cast<MarkupInfoItem>().ToList();
634

    
635
                    (from A in _infoItem
636
                     from B in Common.ViewerDataModel.Instance.MarkupControls
637
                     where A.MarkupInfoID == B.MarkupInfoID
638
                     select B).ToList().ForEach(data =>
639
                     {
640
                         data.Visibility = Visibility.Hidden;                         
641
                     });
642

    
643

    
644
                    var myComment = _infoItem.Where(d => d.UserID == App.ViewInfo.UserID).FirstOrDefault();
645
                    if (myComment != null)
646
                    {
647
                        Common.ViewerDataModel.Instance.MarkupControls_USER.ToList().ForEach(delegate (MarkupToPDF.Common.CommentUserInfo markupitem)
648
                        {
649
                            markupitem.Visibility = Visibility.Hidden;
650
                        });
651
                    }
652
                }
653
                #endregion
654
            }
655
        }
656

    
657
        private void BaseClient_GetDocumentItemInfoCompleted(object sender, GetDocumentItemInfoCompletedEventArgs e)
658
        {
659
            Logger.sendResLog("GetDocumentItemInfoCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
660

    
661
            if (e.Result != null)
662
            {
663
                _DocItem = e.Result;
664

    
665
                if (e.Result.DOCUMENT_NO == "" && e.Result.DOCUMENT_NAME == "" && e.Result.GROUP_NO == "0")
666
                {
667
                    //장원
668
                    _ViewInfo.UserID = _ViewInfo.UserID.Replace(@"DAELIM\", "");
669
                }
670
                Logger.sendReqLog("GetDocInfoAsync", _ViewInfo.ProjectNO + "," + _ViewInfo.DocumentItemID, 1);
671
                BaseClient.GetDocInfoAsync(new KCOM_BasicParam { projectNo = _ViewInfo.ProjectNO, documentID = _ViewInfo.DocumentItemID });
672
            }
673
            else
674
            {
675
                DialogMessage_Alert("Document Information Not Found.", "Error");
676

    
677
                BaseClient.GetCheckSystemAdminCompleted += (sen, ea) =>
678
                {
679
                    Logger.sendResLog("GetCheckSystemAdminCompleted", "UserState : " + ea.UserState + "\r Result :" + ea.Result + "\r Cancelled :" + ea.Cancelled + "\r Error :" + ea.Error, 1);
680

    
681
                    if (ea.Error == null)
682
                    {
683
                        if (ea.Result)
684
                        {
685
                            this._ViewInfo.isAdmin = true;
686
                            Logger.sendReqLog("GetDocInfoAsync", _ViewInfo.ProjectNO + "," + _ViewInfo.DocumentItemID, 1);
687
                            BaseClient.GetDocInfoAsync(new KCOM_BasicParam { projectNo = _ViewInfo.ProjectNO, documentID = _ViewInfo.DocumentItemID });
688
                        }
689
                        else
690
                        {
691
                            //System.Windows.Forms.MessageBox.Show("해당 프로젝트에 가입되지 않은 유저입니다. 관리자에게 등록신청을 해주세요", "안내");
692
                            DialogMessage_Alert("You are not belong to this project. Please ask admin for an authority.", "Info");
693
                            //this.ParentOfType<MainPage>().DialogMessage_Alert("해당 프로젝트에 가입되지 않은 유저입니다. 관리자에게 등록신청을 해주세요", "안내");
694
                        }
695

    
696
                    }
697
                    else
698
                    {
699
                        //System.Windows.Browser.HtmlPage.Window.Invoke("close");
700
                    }
701
                };
702
                Logger.sendReqLog("GetCheckSystemAdminAsync", _ViewInfo.UserID, 1);
703
                BaseClient.GetCheckSystemAdminAsync(this._ViewInfo.UserID);
704
            }
705
        }
706

    
707
        private void BaseClient_GetSystemDataCompleted(object sender, GetSystemDataCompletedEventArgs e)
708
        {
709
            Logger.sendResLog("GetSystemDataCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
710

    
711
            if (e.Error == null && e.Result != null)
712
            {
713
                App.SystemInfo = e.Result;
714

    
715
                //App.urlPort_DB = App.SystemInfo.HostPort;
716
                //App.urlHost_DB = App.SystemInfo.HostName;
717
                Logger.sendReqLog("GetConversionStateAsync", _ViewInfo.ProjectNO + "," + _ViewInfo.DocumentItemID, 1);
718
                BaseClient.GetConversionStateAsync(new KCOM_BasicParam { projectNo = _ViewInfo.ProjectNO, documentID = _ViewInfo.DocumentItemID });
719

    
720
                //if (App.urlHost.Contains("localhost"))
721
                //{
722
                //    App.urlHost = App.urlHost_DB;
723
                //}
724
            }
725
        }
726

    
727
        private void BaseClient_GetConversionStateCompleted(object sender, GetConversionStateCompletedEventArgs e)
728
        {
729
            
730
            Logger.sendResLog("GetConversionStateCompleted", "UserState : " + e.UserState + "\r Result :" + e.Result + "\r Cancelled :" + e.Cancelled + "\r Error :" + e.Error, 1);
731
            string failedmsg = CommonLib.Common.GetAlertMessageString("GetConversionStateFailed", "MSG", "Too Many V/P Files are uploading instantaneously, This V/P file can not be open now. Please feel free to re-open wait a moment again!\n\n현재 일시적으로 많은 양의 V/P가 등록되고 있어 이 문서를 열람할 수 없습니다.\n잠시만 기다려 주신 후 다시 열람하여 주시기 바랍니다");
732
            if (e.Error == null && e.Result == true)
733
            {
734
                Logger.sendReqLog("GetDocumentItemInfoAsync", _ViewInfo.ProjectNO + "," + _ViewInfo.DocumentItemID + "," + _ViewInfo.UserID, 1);
735

    
736
                BaseClient.GetDocumentItemInfoAsync(new KCOM_BasicParam { projectNo = _ViewInfo.ProjectNO, documentID = _ViewInfo.DocumentItemID, userID = _ViewInfo.UserID });
737

    
738
                if (App.ViewInfo != null && App.ViewInfo.ProjectNO != "")
739
                {
740
                    Logger.sendReqLog("GetMember", _ViewInfo.ProjectNO + "," + _ViewInfo.UserID, 1);
741
                    userData = BaseClient.GetMember(App.ViewInfo.ProjectNO, App.ViewInfo.UserID);
742
                    if (userData != null)
743
                    {
744
                        Logger.sendReqLog("GetDeptDataAsync", userData.DEPARTMENT, 1);
745
                        BaseClient.GetDeptDataAsync(userData.DEPARTMENT);
746
                    }
747
                    else
748
                    {
749
                        userData = new MEMBER();
750
                        userData.DEPARTMENT = "ALL";
751
                        Logger.sendReqLog("GetDeptDataAsync", userData.DEPARTMENT, 1);
752
                        BaseClient.GetDeptDataAsync(userData.DEPARTMENT);
753
                    }
754
                }
755
            }
756
            else
757
            {
758
                
759
                DialogMessage_Alert(failedmsg, "Warning");
760
            }
761
        }
762

    
763
        public void SetView(ViewInfo info)
764
        { 
765
            this._ViewInfo = info;
766
            try
767
            {
768
                /// 대림의 경우 EnsembleID를 가지고 DocumentItemID를 구함
769
                /// 다른 Site를 대비하여 에러 처리함
770
                string docid = BaseClient.GetDocItemID(info.EnsembleID);
771
                if (!string.IsNullOrEmpty(docid))
772
                {
773
                    this._ViewInfo.DocumentItemID = docid;
774
                }
775
            }
776
            catch(Exception ex)
777
            {
778
                App.FileLogger.Fatal(ex);
779
            }
780

    
781
            Logger.sendReqLog("GetSystemDataAsync", "", 1);
782
            BaseClient.GetSystemDataAsync();
783
        }
784

    
785
        public void HubSet()
786
        {
787
            // 허브 연결 구성
788
            var hubConnection = new HubConnection(CommonLib.Common.GetConfigString("HubAddress", "URL", "", App.isExternal));
789
            IHubProxy MarkusLicenseProxy = hubConnection.CreateHubProxy("MarkusLicenseHub");
790

    
791

    
792
            // 허브 연결 
793
            hubConnection.Start().ContinueWith(task =>
794
            {
795
                if (task.IsFaulted)
796
                {
797
                    Console.WriteLine("There was an error opening the connection:{0}",
798
                                      task.Exception.GetBaseException());
799
                    //throw task.Exception.GetBaseException();
800
                }
801
                else
802
                {
803
                    Console.WriteLine("Connected :: " + task.Id);
804
                }
805

    
806
            }).Wait();
807

    
808

    
809
            // [ 프로그램 시작 ]
810
            // 클라이언트에서 서버를 호출 ( 접속 시 )  : 라이센스 체크
811
            //( "method name", arg1, arg2 )
812
            //MarkusLicenseProxy.Invoke<string>("ConnectionMarkus", "H2009115", "고동균").ContinueWith(task =>
813
            //{
814
            //    if (task.IsFaulted)
815
            //    {
816
            //        Console.WriteLine("ConnectionMarkus :: There was an error calling send: {0}", task.Exception.GetBaseException());
817
            //    }
818
            //    else
819
            //    {
820
            //        Console.WriteLine(task.Result);
821
            //    }
822
            //});
823
            MarkusLicenseProxy.Invoke<string>("ConnectionMarkus", App.ViewInfo.UserID,App.ViewInfo.ProjectNO).ContinueWith(task =>
824
            {
825
                if (task.IsFaulted)
826
                {
827
                    Console.WriteLine("ConnectionMarkus :: There was an error calling send: {0}", task.Exception.GetBaseException());
828
                    //throw task.Exception.GetBaseException();
829
                }
830
                else
831
                {
832
                    switch (task.Result)
833
                    {
834
                        case "2":
835
                            {
836
                                var result = MessageBox.Show("권한이 없습니다.");
837
                                if (result == MessageBoxResult.OK)
838
                                    System.Diagnostics.Process.GetCurrentProcess().Kill();
839
                            }
840
                            break;
841
                        case "404":
842
                            {
843
                                var result = MessageBox.Show("등록된 사용자가 아닙니다.");
844
                                if(result == MessageBoxResult.OK)
845
                                    System.Diagnostics.Process.GetCurrentProcess().Kill();
846
                            }
847
                            break;
848
                    }
849
                }
850
            });
851

    
852
            // 서버에서 클라이언트 호출 ( 프로그램 구동여부 ) : 라이센스 체크 후 응답 ( 반환값 : true, false ) 
853
            //MarkusLicenseProxy.On<bool>("IsConnection", status =>
854
            //{
855

    
856
            //    if (status)
857
            //    {
858
            //        // 프로그램 시작 
859
            //        Console.WriteLine("connection status : " + status);
860
            //    }
861
            //    else
862
            //    {
863
            //        // 프로그램 종료 ( signalr 접속 끊기 )  
864
            //        hubConnection.Stop();
865
            //    }
866
            //});
867

    
868
            // 공지 메세지 ( 서버에서 클라이언트 호출 ) 
869
            MarkusLicenseProxy.On<string>("MarkusNotification", msg =>
870
                Console.WriteLine("Noficiation Message : " + msg)
871
            );
872

    
873

    
874
            // 서버 메서드 호출 
875
            //MarkusLicenseProxy.Invoke<string>("DoSomething", "I'm doing something!!!").Wait();
876

    
877
            //Console.ReadKey();
878

    
879
            //hubConnection.Stop();
880
        }
881

    
882
        public async void MarkupUserListDisplay()
883
        {
884
            List<MarkupInfoItem> gridItem = gridViewMarkup.Items.Cast<MarkupInfoItem>().ToList(); //전체 마크업
885
            List<MarkupInfoItem> gridSelectionItem = gridViewMarkup.SelectedItems.Cast<MarkupInfoItem>().ToList(); //선택 된 마크업
886
            List<MarkupInfoItem> gridNonSelectionItem = gridItem.Except(gridSelectionItem).ToList(); //선택 되지 않은 마크업
887
                                                                                                     //MarkupToPDF.Controls.Parsing.LayerControl layerControl = new MarkupToPDF.Controls.Parsing.LayerControl();
888
            Common.ViewerDataModel.Instance.MarkupControls_USER.Clear();  //전체 제거
889
            Common.ViewerDataModel.Instance.MarkupControls.Clear();  //전체 제거
890
            //foreach (var item in gridSelectionItem)
891
            //{
892
            //    if (item.UserID == App.ViewInfo.UserID)
893
            //    {
894
            //        ViewerDataModel.Instance.MyMarkupList.Where(data => data.PageNumber == pageNavigator.CurrentPage.PageNumber && data.MarkupInfoID == item.MarkupInfoID).ToList().ForEach(delegate (MarkupItemEx markupitem)
895
            //        {
896
            //            layerControl.markupParseEx(markupitem.Data, Common.ViewerDataModel.Instance.MarkupControls_USER, item.DisplayColor, "", item.MarkupInfoID, markupitem.ID);
897
            //        });
898
            //    }
899
            //    else
900
            //    {
901
            //        ViewerDataModel.Instance.MarkupList_Pre.Where(data => data.PageNumber == pageNavigator.CurrentPage.PageNumber && data.MarkupInfoID == item.MarkupInfoID).ToList().ForEach(delegate (MarkupItemEx markupitem)
902
            //        {
903
            //            layerControl.markupParse(markupitem.Data, Common.ViewerDataModel.Instance.MarkupControls, item.DisplayColor, "", item.MarkupInfoID);
904
            //        });
905
            //    }
906
            //}
907
                (from A in gridSelectionItem
908
                 from B in Common.ViewerDataModel.Instance.MarkupControls_USER
909
                 where A.MarkupInfoID == B.MarkupInfoID
910
                 select B).ToList().ForEach(data =>
911
                 {
912
                     Common.ViewerDataModel.Instance.MarkupControls_USER.Remove(data);
913
                 });
914
            (from A in gridSelectionItem
915
             from B in Common.ViewerDataModel.Instance.MarkupControls
916
             where A.MarkupInfoID == B.MarkupInfoID
917
             select B).ToList().ForEach(data =>
918
             {
919
                 Common.ViewerDataModel.Instance.MarkupControls.Remove(data);
920
             });
921

    
922
            foreach (var item in gridSelectionItem)
923
            {
924

    
925
                if (item.UserID == App.ViewInfo.UserID)
926
                {
927
                    var markupItems = ViewerDataModel.Instance.MyMarkupList.Where(data => data.PageNumber == pageNavigator.CurrentPage.PageNumber && data.MarkupInfoID == item.MarkupInfoID).ToList();
928

    
929
                    foreach (var markupitem in markupItems)
930
                    {
931
                        await MarkupParser.ParseExAsync(App.ViewInfo.ProjectNO, markupitem.Data, Common.ViewerDataModel.Instance.MarkupControls_USER, item.DisplayColor, "", 
932
                                item.MarkupInfoID, markupitem.ID);
933
                    }
934
                }
935
                else
936
                {
937
                    var markupItems = ViewerDataModel.Instance.MarkupList_Pre.Where(data => data.PageNumber == pageNavigator.CurrentPage.PageNumber && data.MarkupInfoID == item.MarkupInfoID).ToList();
938

    
939
                    foreach (var markupitem in markupItems)
940
                    {
941
                        await MarkupParser.ParseExAsync(App.ViewInfo.ProjectNO, markupitem.Data, Common.ViewerDataModel.Instance.MarkupControls, item.DisplayColor, "", item.MarkupInfoID);
942
                    }
943
                }
944
            }
945
        }
946
    }
947
}
클립보드 이미지 추가 (최대 크기: 500 MB)