프로젝트

일반

사용자정보

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

markus / KCOM / MainWindow.xaml.cs @ cda7efcc

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

1
using KCOM.Common;
2
using KCOM.Controls;
3
using KCOM.Views;
4
using KCOMDataModel;
5
using KCOMDataModel.DataModel;
6
using MarkupToPDF.Common;
7
using MarkupToPDF.Controls.Parsing;
8
using MarkupToPDF.Serialize.Core;
9
using MarkupToPDF.Serialize.S_Control;
10
using System;
11
using System.Collections.Generic;
12
using System.ComponentModel;
13
using System.Diagnostics;
14
using System.IO;
15
using System.Linq;
16
using System.Net;
17
using System.Reflection;
18
using System.Runtime.InteropServices;
19
using System.Text;
20
using System.Threading;
21
using System.Threading.Tasks;
22
using System.Windows;
23
using System.Windows.Controls;
24
using System.Windows.Data;
25
using System.Windows.Documents;
26
using System.Windows.Input;
27
using System.Windows.Media;
28
using System.Windows.Media.Imaging;
29
using System.Windows.Navigation;
30
using System.Windows.Shapes;
31
using System.Xml;
32
using Telerik.Windows.Controls;
33
using WinInterop = System.Windows.Interop;
34

    
35
namespace KCOM
36
{
37
    /// <summary>
38
    /// MainWindow.xaml에 대한 상호 작용 논리
39
    /// </summary>
40
    public partial class MainWindow : KCOM.Controls.CustomizedWindow.CustomWindow
41
    {
42
        bool isSaveCheck = false;
43

    
44
        ProgressControl progressControl = null;
45
        string destfilepath = string.Empty;
46

    
47
        public MainWindow()
48
        {
49
            App.splashString(ISplashMessage.MAINWINDOW);
50

    
51
            this.Loaded += MainWindow_Loaded;
52
            this.Unloaded += MainWindow_Unloaded;
53
            //this.PreviewKeyDown += new KeyEventHandler(KeyEventDownAction);
54
            this.Activated += MainWindow_Activated;
55
        }
56

    
57
      
58

    
59
        private void MainWindow_Activated(object sender, EventArgs e)
60
        {
61
            this.Topmost = true;
62
            this.Topmost = false;
63
        }
64

    
65
        private void MainWindow_Unloaded(object sender, RoutedEventArgs e)
66
        {
67
        }
68

    
69
        public void DialogMessage_Alert(string content, string header)
70
        {
71
            App.splashScreen.Close();
72

    
73
            Telerik.Windows.Controls.DialogParameters parameters = new Telerik.Windows.Controls.DialogParameters()
74
            {
75
                Owner = Application.Current.MainWindow,
76
                Content = new TextBlock()
77
                {
78
                    MinWidth = 400,
79
                    FontSize = 12,
80
                    Text = content,
81
                    TextWrapping = System.Windows.TextWrapping.Wrap
82
                },
83
                Header = header,
84
                Theme = new Telerik.Windows.Controls.VisualStudio2013Theme(),
85
                ModalBackground = new SolidColorBrush { Color = Colors.Black, Opacity = 0.6 },
86
            };
87
            Telerik.Windows.Controls.RadWindow.Alert(parameters);
88
        }
89

    
90
        private async void MainWindow_Loaded(object sender, RoutedEventArgs e)
91
        {
92
            InitializeComponent();
93
            //Loaded 이벤트에서 MaxHeight를 설정 모니터가 1개일때만
94
            //MaxHeight = SystemParameters.WorkArea.Height;
95
            //LocationChanged : 모니터가 2개 이상이고, 모니터의 해상도가 다를 때에 설정
96
            //20240610 LJY 화면 넘어갈때 이슈로 주석
97
            //this.LocationChanged += Window_LocationChanged;
98
            //cursor change  
99
            this.Cursor = new Cursor(App.DefaultArrowCursorStream);
100

    
101
            var point = GetScreenCenter();
102

    
103
            //this.Left = point.X;
104
            //this.Top = point.Y;
105

    
106
            ViewerDataModel.Instance.SystemMain = this;
107

    
108
            if (!App.ParameterMode)
109
            {
110
                //App.ViewInfo = new IKCOM.ViewInfo
111
                //{
112
                //    DocumentItemID = "11111112",
113
                //    //DocumentItemID = "10001",
114
                //    bPartner = false,
115
                //    CreateFinalPDFPermission = true,
116
                //    NewCommentPermission = true,
117
                //    ProjectNO = "000000",
118
                //    UserID = "H2011357",
119
                //    //UserID = "H2009115",
120
                //    //Mode = 0 , 1 , 2
121
                //};
122
                //DialogMessage_Alert("데모버전은 단독 실행모드를 지원하지 않습니다", "안내");
123

    
124
                //#if DEBUG
125
                //                App.ViewInfo = new IKCOM.ViewInfo
126
                //                {
127
                //                    DocumentItemID = "11111112",
128
                //                    //DocumentItemID = "10001",
129
                //                    bPartner = false,
130
                //                    CreateFinalPDFPermission = true,
131
                //                    NewCommentPermission = true,
132
                //                    ProjectNO = "000000",
133
                //                    UserID = "H2011357",
134
                //                    //UserID = "H2009115",
135
                //                    //Mode = 0 , 1 , 2
136
                //                };
137
                //                App.ParameterMode = true;
138
                //                this.dzMainMenu.ServiceOn();
139
                //                this.dzMainMenu.SetView(App.ViewInfo);
140
                //#else
141

    
142
                DialogMessage_Alert("데모버전은 단독 실행모드를 지원하지 않습니다", "안내");
143
                this.dzMainMenu.pageNavigator.Visibility = Visibility.Collapsed;
144
                this.dzMainMenu.historyPane.Visibility = Visibility.Collapsed;
145
                this.dzMainMenu.infoListPane.Visibility = Visibility.Collapsed;
146
                this.dzMainMenu.searchPane.Visibility = Visibility.Collapsed;
147
                this.dzMainMenu.talkPane.Visibility = Visibility.Collapsed;
148
                //#endif
149
            }
150
            else
151
            {
152
                this.dzMainMenu.talkPane.Visibility = Visibility.Collapsed;
153
                this.dzMainMenu.ServiceOn();
154

    
155
                if (!App.ViewInfo.CreateFinalPDFPermission && !App.ViewInfo.NewCommentPermission)
156
                {
157
                    this.dzTopMenu.radRibbonView.HelpButtonVisibility = Visibility.Collapsed;
158
                    var list = this.dzTopMenu.ChildrenOfType<RadRibbonTab>().ToList();
159
                    list.ForEach(item => item.Visibility = Visibility.Collapsed);
160
                    this.dzTopMenu.ribbontab_ReadOnly.Visibility = Visibility.Visible;
161
                    this.dzTopMenu.radRibbonView.SelectedItem = this.dzTopMenu.ribbontab_ReadOnly;
162
                    //this.dzMainMenu.SymbolPane.Visibility = Visibility.Collapsed;
163
                    //this.dzMainMenu.FavoritePane.Visibility = Visibility.Collapsed;
164
                    //this.dzMainMenu.drawingRotateCanvas.IsHitTestVisible = false;
165
                }
166
                else
167
                {
168
                    string signData = await this.dzMainMenu.BaseTaskClient.GetSignDataAsync(App.ViewInfo.ProjectNO, App.ViewInfo.UserID);
169
                    string signStrokes = await this.dzMainMenu.BaseTaskClient.GetSignStrokesAsync(App.ViewInfo.ProjectNO, App.ViewInfo.UserID);
170

    
171
                    if (signData != null && signStrokes != null)
172
                    {
173
                        MarkupToPDF.MarkupContext.SetUserSignItem(App.ViewInfo.UserID, signData, signStrokes);
174
                    }
175
                    else
176
                    {
177
                        SignManager signManager = new SignManager();
178

    
179
                        RadWindow signManagerPop = new RadWindow
180
                        {
181
                            MinWidth = 1200,
182
                            MinHeight = 500,
183
                            //Header = "My Check List",
184
                            Header = "",
185
                            Content = signManager,
186
                            Owner = this,
187
                            IsTopmost = true,
188
                            //ResizeMode = System.Windows.ResizeMode.CanResizeWithGrip,
189
                            ResizeMode = System.Windows.ResizeMode.NoResize,
190
                            WindowStartupLocation = System.Windows.WindowStartupLocation.CenterScreen,
191
                        };
192
                        StyleManager.SetTheme(signManagerPop, new Office2013Theme());
193

    
194
                        //CheckPop.ShowDialog();
195
                        signManagerPop.Show();
196
                    }
197
                }
198

    
199
                try
200
                {
201
                    ///this.dzMainMenu.HubSet();
202
                    this.dzMainMenu.SetView(App.ViewInfo);
203
                }
204
                catch (Exception ex)
205
                {
206
                    MessageBox.Show(string.Format("웹 서비스 접속시 에러가 발생했습니다.\n{0}", ex.StackTrace));
207

    
208
                    System.Environment.Exit(0);
209
                }
210
            }
211
        }
212
        /// <summary>
213
        /// 멤버 변수로 현 사용자의 모든 모니터들의 상태를 가져온다.
214
        /// Window의 LocationChanged Event를 통해 Window가 이동할 때마다 어떤 모니터에 있는지를 확인
215
        /// Window가 어떤 모니터에 있는지의 기준은 각 Window의 중앙 부분 
216
        /// Sum 은 모니터들의 왼쪽 끝 부터 오른쪽 끝까지의 합
217
        /// 현재 Window의 중앙은 Left 값 + Width의 반
218
        /// um보다 작다면 현재 더하게 된 Screen 안에 있다는 뜻이므로 현재 더한 item의 WorkingArea의 Height를MaxHeight로 설정   
219
        /// </summary>
220
        System.Windows.Forms.Screen[] screens = System.Windows.Forms.Screen.AllScreens;
221
        private void Window_LocationChanged(object sender, EventArgs e) 
222
        {             
223
            int sum = 0;
224
            foreach (var item in screens)
225
            {
226
                sum += item.WorkingArea.Width;
227
                if (sum >= this.Left + this.Width / 2)
228
                {
229
                    this.MaxHeight = item.WorkingArea.Height;
230
                this.MaxWidth = item.WorkingArea.Width;
231
                if (this.Left < 0)
232
                {
233
                    this.Left = 0;
234
                }
235

    
236
                if (this.Top < 0)
237
                {
238
                    this.Top = 0;
239
                }
240
                //   if(this.Tag.Equals("Normal"))
241
                //{
242
                //    this.WindowState = WindowState.Normal;
243
                //    this.CustomState = WindowState.Maximized;
244
                //}    
245
                //if (this.CustomState == WindowState.Maximized)
246
                //{
247
                //    this.WindowState = WindowState.Normal;
248
                //    this.CustomState = WindowState.Normal;
249

    
250

    
251
                //}
252
                //else
253
                //{
254
                //    this.WindowState = WindowState.Normal;
255
                //    this.CustomState = WindowState.Maximized;
256
                //    this.NomalWindowArea = new Rect(this.Left, this.Top, this.Width, this.Height);
257

    
258
                //}                        
259
                break;
260
                }  
261
            } 
262
        }
263
        
264
        private Point GetScreenCenter()
265
        {
266
            Point result = new Point();
267

    
268
            //first get all the screens 
269
            System.Drawing.Rectangle ret;
270
            int ScreenWidth = 0;
271

    
272
            var mousePosition = System.Windows.Forms.Cursor.Position;
273

    
274
            for (int i = 1; i <= System.Windows.Forms.Screen.AllScreens.Count(); i++)
275
            {
276
                ret = System.Windows.Forms.Screen.AllScreens[i - 1].Bounds;
277

    
278
                if (ret.Contains(mousePosition))
279
                {
280
                    result.X = ScreenWidth + (ret.Width / 2 - this.Width / 2);
281
                    result.Y = (ret.Height / 2 - this.Height / 2);
282

    
283
                    break;
284
                }
285
                else
286
                {
287
                    ScreenWidth += ret.Width;
288
                }
289

    
290
            }
291

    
292

    
293
            return result;
294
        }
295

    
296
        protected override void OnStateChanged(EventArgs e)
297
        {
298
            base.OnStateChanged(e);
299
        }
300

    
301
        protected override void OnClosing(CancelEventArgs e)
302
        {
303
            base.OnClosing(e);
304
            
305
            if(!ViewerDataModel.Instance.SaveCheck())
306
            {
307
                var IsConfirm = SaveConfirm();
308

    
309
                if (IsConfirm == null)
310
                {
311
                    e.Cancel = true;
312
                }
313
                else if(IsConfirm == true)
314
                { 
315
                    dzTopMenu.SaveEventCallback(null, null);
316
                }
317
            }
318

    
319
            if (App.ViewInfo.CreateFinalPDFPermission)
320
            {
321
                if (!ViewerDataModel.Instance.FinalPDFCheck())
322
                {
323
                    var result = FinalConfirm();
324

    
325
                    if(result == null)
326
                        e.Cancel = true;
327

    
328
                    if (result == false)
329
                    {
330
                        e.Cancel = true;
331
                    }
332
                    else
333
                    {
334
                        //Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.SaveLog(App.ViewInfo.ProjectNO, App.ViewInfo.DocumentItemID, "최종 Merged PDF 안됨.");
335
                    }
336
                }
337
            }
338

    
339
            //Update Check 를 통해 update url 을 Get 하고 결과값이 있을 경우에는 SmartUpdater 실행.
340
            //KeyValuePair<bool, string> updatecheck = UpdateCheck();
341
            //if (updatecheck.Key && !string.IsNullOrEmpty(updatecheck.Value))
342
            //{
343
            //    CallUpdateProcess(updatecheck.Value);
344
            //}
345
        }
346

    
347

    
348
        private bool? SaveConfirm()
349
        {
350
            bool? result = null;
351

    
352
            EventHandler<WindowClosedEventArgs> Closedhandler = null;
353

    
354
            Closedhandler = (snd, evt) =>
355
            {
356
                result = evt.DialogResult;
357
            };
358

    
359
            DialogParameters parameters = new DialogParameters()
360
            {
361
                Content = new TextBlock()
362
                {
363
                    MinWidth = 300,
364
                    FontSize = 11,
365
                    Text = "Found unsaved comments. Save now?",
366
                    TextWrapping = System.Windows.TextWrapping.Wrap
367
                },
368

    
369
                Header = "Confirm",
370
                Theme = new VisualStudio2013Theme(),
371
                ContentStyle = Application.Current.Resources["RadConfirmYNCStyle"] as Style,
372
                ModalBackground = new SolidColorBrush { Color = Colors.Black, Opacity = 0.6 },
373

    
374
                Owner = Application.Current.MainWindow,
375
                Opened = (s, openedEvent) =>
376
                {
377
                    RadWindow confirm = s as RadWindow;
378
                    //Button Cancel = confirm.ChildrenOfType<Button>()[5];
379
                    //FocusManager.SetIsFocusScope(confirm, true);
380
                    //FocusManager.SetFocusedElement(confirm, Cancel);
381
                },
382

    
383
                Closed = Closedhandler
384
            };
385

    
386
            RadWindow.Confirm(parameters);
387

    
388
            return result;
389
        }
390

    
391
        private bool? FinalConfirm()
392
        {
393
            bool? result = false;
394

    
395
            EventHandler<WindowClosedEventArgs> Closedhandler = null;
396

    
397
            Closedhandler = (snd, evt) =>
398
            {
399
                result = evt.DialogResult;
400
            };
401

    
402
            DialogParameters parameters = new DialogParameters()
403
            {
404
                Content = new TextBlock()
405
                {
406
                    MinWidth = 300,
407
                    FontSize = 11,
408
                    Text = "Merged PDF가 수행되지 않았습니다. 창을 닫으시겠습니까?",
409
                    TextWrapping = System.Windows.TextWrapping.Wrap
410
                },
411

    
412
                Header = "Confirm",
413
                Theme = new VisualStudio2013Theme(),
414
                ContentStyle = Application.Current.Resources["RadConfirmYCStyle"] as Style,
415
                ModalBackground = new SolidColorBrush { Color = Colors.Black, Opacity = 0.6 },
416

    
417
                Owner = Application.Current.MainWindow,
418
                Opened = (s, openedEvent) =>
419
                {
420
                    RadWindow confirm = s as RadWindow;
421
                },
422

    
423
                Closed = Closedhandler
424
            };
425

    
426
            RadWindow.Confirm(parameters);
427

    
428
            return result;
429
        }
430

    
431
        private void client_DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e)
432
        {
433
            Dispatcher.BeginInvoke(System.Windows.Threading.DispatcherPriority.Normal, new Action(delegate
434
            {
435
                double bytesIn = double.Parse(e.BytesReceived.ToString());
436
                double totalBytes = double.Parse(e.TotalBytesToReceive.ToString());
437
                double percentage = bytesIn / totalBytes * 100;
438
                progressControl.splashText.Text = "Download : " + Math.Truncate(percentage).ToString() + " %";
439
                progressControl.progressBar.Value = int.Parse(Math.Truncate(percentage).ToString());
440
            }));
441
        }
442

    
443
        /// <summary>
444
        /// KCOM_API 를 통해 업데이트 URL 을 가져옴.
445
        /// false : 업데이트 불필요.
446
        /// true : 업데이트 필요. url 을 같이 Return.
447
        /// </summary>
448
        /// <returns></returns>
449
        private KeyValuePair<bool, string> UpdateCheck()
450
        {
451
            bool isUpdateCheck = false;
452
            string updateurl = string.Empty;
453
            try
454
            {
455
                bool is64bit = Environment.Is64BitProcess;
456
                string clientversion = Assembly.GetExecutingAssembly().GetName().Version.ToString();
457
                updateurl = Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.GetVersionData(is64bit, clientversion);
458

    
459
                if (Check_Uri.isUri(updateurl))
460
                {
461
                    DialogParameters parameters = new DialogParameters()
462
                    {
463
                        Owner = Application.Current.MainWindow,
464
                        Content = new TextBlock()
465
                        {
466
                            MinWidth = 400,
467
                            FontSize = 11,
468
                            Text = "Update is available. \n Update now?",
469
                            TextWrapping = System.Windows.TextWrapping.Wrap
470
                        },
471
                        Header = "Confirm",
472
                        Theme = new VisualStudio2013Theme(),
473
                        ModalBackground = new SolidColorBrush { Color = Colors.Black, Opacity = 0.6 },
474
                        Closed = delegate (object windowSender, WindowClosedEventArgs e)
475
                        {
476
                            if (e.DialogResult == true)
477
                            {
478
                                isUpdateCheck = true;
479
                            }
480
                            else
481
                            {
482
                                isUpdateCheck = false;
483
                            }
484
                        }
485
                    };
486
                    RadWindow.Confirm(parameters);
487

    
488
                }
489
                else
490
                {
491
                    isUpdateCheck = false;
492
                }
493
            }
494
            catch (Exception ex)
495
            {
496
                throw ex;
497
            }
498
            return new KeyValuePair<bool, string>(isUpdateCheck, updateurl);
499
        }
500

    
501
        /// <summary>
502
        /// SmartUpdate 를 호출.
503
        /// </summary>
504
        /// <param name="updateurl">Download 할 설치파일 경로</param>
505
        private void CallUpdateProcess(string updateurl)
506
        {
507
            ProcessStartInfo proInfo = new ProcessStartInfo();
508
            string smartupdaterpath = string.Empty;
509
            smartupdaterpath = System.IO.Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "SmartUpdate.exe");
510
            Process.Start(smartupdaterpath, updateurl);
511
        }
512
        private async void Client_DownloadFileCompleted(object sender, AsyncCompletedEventArgs e)
513
        {
514
            try
515
            {
516
                await Dispatcher.InvokeAsync(() => progressControl.splashText.Text = "Download Completed");
517

    
518
                if (progressControl != null)
519
                {
520
                    progressControl.Close();
521
                    progressControl = null;
522
                }
523
                if (File.Exists(destfilepath))
524
                {
525
                    ProcessStartInfo update_msi = new ProcessStartInfo();
526
                    update_msi.FileName = destfilepath;
527
                    Process.Start(update_msi);
528
                }
529
                this.Close();
530
            }
531
            catch (Exception)
532
            {
533
                throw;
534
            }
535

    
536
        }
537
    }
538
}
클립보드 이미지 추가 (최대 크기: 500 MB)