프로젝트

일반

사용자정보

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

markus / KCOM / Controls / CheckList.xaml.cs @ d71ee575

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

1 787a4489 KangIngu
using KCOMDataModel.Common;
2
using KCOMDataModel.DataModel;
3
using System;
4
using System.Collections.Generic;
5
using System.Collections.ObjectModel;
6
using System.Linq;
7
using System.Text;
8
using System.Windows;
9
using System.Windows.Controls;
10
using System.Windows.Data;
11
using System.Windows.Documents;
12
using System.Windows.Input;
13
using System.Windows.Media;
14
using System.Windows.Media.Imaging;
15
using System.Windows.Navigation;
16
using System.Windows.Shapes;
17
using Telerik.Windows.Controls;
18
using KCOM.Common.Converter;
19
using System.ComponentModel;
20
using Telerik.Windows.Controls.GridView;
21
using KCOM.Controls;
22
using KCOM.Common;
23
using IKCOM;
24
using Excel = Microsoft.Office.Interop.Excel;
25
26
27
namespace KCOM.Controls
28
{
29
30
    #region Customer
31
    public class Customer
32
    {
33
        public string ID { get; set; }
34
        public string DOCUMENT_ID { get; set; }
35
        public string USER_ID { get; set; }
36
        public string REVISION { get; set; }
37
        public int PAGENUMBER { get; set; }
38
        public string TODOLIST { get; set; }
39
        public string IMAGE_URL { get; set; }
40
        public string STATUS { get; set; }
41
        public string STATUS_ { get; set; }
42
        public string _STATUS { get; set; }
43
        public string VENDOR { get; set; }
44
        public string REMARK { get; set; }
45
        public string PROJECT_NO { get; set; }
46
        public string REV_19 { get; set; }
47
        public string REV_18 { get; set; }
48
        public string REV_17 { get; set; }
49
        public string REV_16 { get; set; }
50
        public string REV_15 { get; set; }
51
        public string REV_14 { get; set; }
52
        public string REV_13 { get; set; }
53
        public string REV_12 { get; set; }
54
        public string REV_11 { get; set; }
55
        public string REV_10 { get; set; }
56
        public string REV_9 { get; set; }
57
        public string REV_8 { get; set; }
58
        public string REV_7 { get; set; }
59
        public string REV_6 { get; set; }
60
        public string REV_5 { get; set; }
61
        public string REV_4 { get; set; }
62
        public string REV_3 { get; set; }
63
        public string REV_2 { get; set; }
64
        public string REV_1 { get; set; }
65
        public string REV_0 { get; set; }
66
        public string IMAGE_ANCHOR { get; set; }
67
        public byte[] IMAGE_PATH { get; set; }
68
        public string STATUS_DESC { get; set; }
69
        public string REPLY { get; set; }
70
        public DateTime CREATE_TIME { get; set; }
71
    } 
72
    #endregion
73
74
    /// <summary>
75
    /// Interaction logic for CheckList.xaml
76
    /// </summary>
77
    public partial class CheckList : UserControl
78
    {
79
        #region 프로퍼티
80
        List<CHECK_LIST> items = new List<CHECK_LIST>();
81
        List<Customer> Lists = new List<Customer>();
82
        string old_Revision = "";
83
        string old_DocID = "";
84
        string Current_Revision = "";
85
        string Current_DocNo = "";
86
        int Current_Slip = 0;
87
        bool Isinit = false;
88
        int rev_cnt = 1;
89 69ef0800 KangIngu
        bool isCheck_Status = false;
90
        string Select_StatusID = "";
91 787a4489 KangIngu
        #endregion
92
93
        #region 생성자
94
        public CheckList()
95
        {
96
            Common.ViewerDataModel.Instance.ViewVisible = Visibility.Visible;
97
            InitializeComponent();
98
            this.Loaded += CheckList_Loaded;
99
            this.KeyDown += new KeyEventHandler(KeyEventDownAction);
100
            this.AddHandler(Image.MouseLeftButtonDownEvent, new MouseButtonEventHandler(mousedownOnImage), true);
101
            
102
        }
103
        #endregion
104
105
        public void DataBind()
106
        {
107
            Isinit = false;
108 6c781c0c djkim
            
109 787a4489 KangIngu
            Lists = new List<Customer>();
110
            string doc_no = (Application.Current.MainWindow as MainWindow).dzMainMenu._DocItem.DOCUMENT_NO;
111 6c781c0c djkim
            string project_no = App.ViewInfo.ProjectNO;
112
            string user_id = App.ViewInfo.UserID;
113
            items = Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.GetUserCheckList(project_no, user_id, doc_no);
114
            if (Lists.Count == 0)
115 787a4489 KangIngu
            {
116 6c781c0c djkim
                foreach (var item in items)
117 787a4489 KangIngu
                {
118 6c781c0c djkim
                    Customer customer = new Customer();
119
                    customer.ID = item.ID;
120
                    customer.IMAGE_ANCHOR = item.IMAGE_ANCHOR;
121
                    if (item.IMAGE_URL != null && item.IMAGE_URL != "")
122
                        customer.IMAGE_PATH = Convert.FromBase64String(item.IMAGE_URL);
123
                    customer.PAGENUMBER = item.PAGENUMBER;
124
                    customer.PROJECT_NO = item.PROJECT_NO;
125
                    customer.REMARK = item.REMARK;
126
                    customer.REVISION = item.REVISION;
127
128
                    #region history
129
                    var history = Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.GetCheckListHistory(project_no, item.ID);                        
130
                    foreach (var rev in history)
131 787a4489 KangIngu
                    {
132 6c781c0c djkim
                        if (rev.REVISION == "A")
133
                        { customer.REV_0 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); }
134
                        if (rev.REVISION == "B")
135
                        { customer.REV_1 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 2 ? 2 : rev_cnt; }
136
                        if (rev.REVISION == "C")
137
                        { customer.REV_2 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 3 ? 3 : rev_cnt; }
138
                        if (rev.REVISION == "D")
139
                        { customer.REV_3 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 4 ? 4 : rev_cnt; }
140
                        if (rev.REVISION == "E")
141
                        { customer.REV_4 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 5 ? 5 : rev_cnt; }
142
                        if (rev.REVISION == "F")
143
                        { customer.REV_5 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 6 ? 6 : rev_cnt; }
144
                        if (rev.REVISION == "G")
145
                        { customer.REV_6 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 7 ? 7 : rev_cnt; }
146
                        if (rev.REVISION == "H")
147
                        { customer.REV_7 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 8 ? 8 : rev_cnt; }
148
                        if (rev.REVISION == "I")
149
                        { customer.REV_8 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 9 ? 9 : rev_cnt; }
150
                        if (rev.REVISION == "J")
151
                        { customer.REV_9 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 10 ? 10 : rev_cnt; }
152
                        if (rev.REVISION == "K")
153
                        { customer.REV_10 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 11 ? 11 : rev_cnt; }
154
                        if (rev.REVISION == "L")
155
                        { customer.REV_11 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 12 ? 12 : rev_cnt; }
156
                        if (rev.REVISION == "M")
157
                        { customer.REV_12 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 13 ? 13 : rev_cnt; }
158
                        if (rev.REVISION == "N")
159
                        { customer.REV_13 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 14 ? 14 : rev_cnt; }
160
                        if (rev.REVISION == "O")
161
                        { customer.REV_14 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 15 ? 15 : rev_cnt; }
162
                        if (rev.REVISION == "P")
163
                        { customer.REV_15 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 16 ? 16 : rev_cnt; }
164
                        if (rev.REVISION == "Q")
165
                        { customer.REV_16 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 17 ? 17 : rev_cnt; }
166
                        if (rev.REVISION == "R")
167
                        { customer.REV_17 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 18 ? 18 : rev_cnt; }
168
                        if (rev.REVISION == "S")
169
                        { customer.REV_18 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 19 ? 19 : rev_cnt; }
170
                        if (rev.REVISION == "T")
171
                        { customer.REV_19 = rev.STATUS + "" + rev.CREATE_TIME.ToString("yyyy.MM.dd"); rev_cnt = rev_cnt < 20 ? 20 : rev_cnt; }
172
                    }
173
                    #endregion
174 787a4489 KangIngu
175 6c781c0c djkim
                    customer.STATUS = item.STATUS;
176
                    customer.REPLY = item.REPLY;
177
                    customer.TODOLIST = item.TODOLIST;
178
                    customer.USER_ID = item.USER_ID;
179
                    customer.VENDOR = item.VENDOR;
180
                    customer.DOCUMENT_ID = item.DOCUMENT_ID;
181
                    customer.CREATE_TIME = DateTime.Parse(item.CREATE_TIME.ToString());
182 787a4489 KangIngu
183 6c781c0c djkim
                    if (item.STATUS == "True")
184
                    {
185
                        customer._STATUS = "Close";
186
                        customer.STATUS_ = "False";
187
                        customer.STATUS_DESC = item.STATUS_DESC_CLOSE;
188 787a4489 KangIngu
                    }
189 6c781c0c djkim
                    else
190
                    {
191
                        customer._STATUS = "Open";
192
                        customer.STATUS_ = "True";
193
                        customer.STATUS_DESC = item.STATUS_DESC_OPEN;
194
                    }
195
196
                    Lists.Add(customer);
197 787a4489 KangIngu
                }
198 6c781c0c djkim
            }            
199 787a4489 KangIngu
        }
200
201
        private void ChangeSize(double width, double height)
202
        {
203
            this.Width = width;
204
            this.Height = height;
205
        }
206
207
        private void SyncInit()
208
        {
209
            if (!ViewerDataModel.Instance.SystemMain.dzMainMenu.testPanel2.IsHidden)
210
            {
211
                ViewerDataModel.Instance.SystemMain.dzMainMenu.testPanel2.IsHidden = true;
212
                ViewerDataModel.Instance.PageBalanceMode = false;
213
                ViewerDataModel.Instance.PageBalanceNumber = 0;
214
                ViewerDataModel.Instance.PageNumber = 0;
215
                ViewerDataModel.Instance.MarkupControls_Sync.Clear();
216
                ViewerDataModel.Instance.SystemMain.dzMainMenu.gridViewRevMarkup.Visibility = Visibility.Collapsed;
217
                ViewerDataModel.Instance.SystemMain.dzMainMenu.UserList.IsChecked = false;
218
                ViewerDataModel.Instance.SystemMain.dzMainMenu.BalanceMode.IsChecked = false;
219
            }
220
        }
221
222
        private void DialogMessage_Alert(string Msg)
223
        {
224
            RadWindow CheckPop = new RadWindow();
225
            Alert check = new Alert(Msg);
226
227
            CheckPop = new RadWindow
228
            {
229
                MinWidth = 400,
230
                MinHeight = 100,
231 01cbc243 KangIngu
                //Closed = (obj, args) => this.MarkupNamePromptClose(MarkupData, args),
232 787a4489 KangIngu
                Header = "Alert",
233
                Content = check,
234
                ResizeMode = System.Windows.ResizeMode.NoResize,
235
                WindowStartupLocation = System.Windows.WindowStartupLocation.CenterScreen,
236
                IsTopmost = true,
237
            };
238
            StyleManager.SetTheme(CheckPop, new Office2013Theme());
239
            CheckPop.ShowDialog();
240
        }
241
242
        private void History_Set()
243
        {
244
            if (col1.Width != new GridLength(1200))
245
            {
246
                Col_Remark.IsVisible = true;
247
                Col_Reply.IsVisible = true;
248
                Col_Vendor.IsVisible = true;
249
250
                if (Lists.Where(info => info.REV_1 != null).FirstOrDefault() != null)
251
                    REV_1.IsVisible = true;
252
253
                #region history
254
                REV_0.IsVisible = true;
255
                if (Lists.Where(info => info.REV_1 != null).FirstOrDefault() != null)
256
                    { REV_1.IsVisible = true; REV_0.Width = 70; }
257
                else
258
                { REV_0.Width = 140;}
259
                if (Lists.Where(info => info.REV_2 != null).FirstOrDefault() != null)
260
                    REV_2.IsVisible = true; REV_2.IsVisible = true;
261
                if (Lists.Where(info => info.REV_3 != null).FirstOrDefault() != null)
262
                    REV_3.IsVisible = true;
263
                if (Lists.Where(info => info.REV_4 != null).FirstOrDefault() != null)
264
                    REV_4.IsVisible = true;
265
                if (Lists.Where(info => info.REV_5 != null).FirstOrDefault() != null)
266
                    REV_5.IsVisible = true;
267
                if (Lists.Where(info => info.REV_6 != null).FirstOrDefault() != null)
268
                    REV_6.IsVisible = true;
269
                if (Lists.Where(info => info.REV_7 != null).FirstOrDefault() != null)
270
                    REV_7.IsVisible = true;
271
                if (Lists.Where(info => info.REV_8 != null).FirstOrDefault() != null)
272
                    REV_8.IsVisible = true;
273
                if (Lists.Where(info => info.REV_9 != null).FirstOrDefault() != null)
274
                    REV_9.IsVisible = true;
275
                if (Lists.Where(info => info.REV_10 != null).FirstOrDefault() != null)
276
                    REV_10.IsVisible = true;
277
                if (Lists.Where(info => info.REV_11 != null).FirstOrDefault() != null)
278
                    REV_11.IsVisible = true;
279
                if (Lists.Where(info => info.REV_12 != null).FirstOrDefault() != null)
280
                    REV_12.IsVisible = true;
281
                if (Lists.Where(info => info.REV_13 != null).FirstOrDefault() != null)
282
                    REV_13.IsVisible = true;
283
                if (Lists.Where(info => info.REV_14 != null).FirstOrDefault() != null)
284
                    REV_14.IsVisible = true;
285
                if (Lists.Where(info => info.REV_15 != null).FirstOrDefault() != null)
286
                    REV_15.IsVisible = true;
287
                if (Lists.Where(info => info.REV_16 != null).FirstOrDefault() != null)
288
                    REV_16.IsVisible = true;
289
                if (Lists.Where(info => info.REV_17 != null).FirstOrDefault() != null)
290
                    REV_17.IsVisible = true;
291
                if (Lists.Where(info => info.REV_18 != null).FirstOrDefault() != null)
292
                    REV_18.IsVisible = true;
293
                if (Lists.Where(info => info.REV_19 != null).FirstOrDefault() != null)
294
                    REV_19.IsVisible = true;
295
                #endregion
296
297
            }
298
            else
299
            {
300
                Col_Remark.IsVisible = false;
301
                Col_Reply.IsVisible = false;
302
                Col_Vendor.IsVisible = false;
303
304
                #region history
305
                REV_0.IsVisible = false;
306
                REV_1.IsVisible = false;
307
                REV_2.IsVisible = false;
308
                REV_3.IsVisible = false;
309
                REV_4.IsVisible = false;
310
                REV_5.IsVisible = false;
311
                REV_6.IsVisible = false;
312
                REV_7.IsVisible = false;
313
                REV_8.IsVisible = false;
314
                REV_9.IsVisible = false;
315
                REV_10.IsVisible = false;
316
                REV_11.IsVisible = false;
317
                REV_12.IsVisible = false;
318
                REV_13.IsVisible = false;
319
                REV_14.IsVisible = false;
320
                REV_15.IsVisible = false;
321
                REV_16.IsVisible = false;
322
                REV_17.IsVisible = false;
323
                REV_18.IsVisible = false;
324
                REV_19.IsVisible = false;
325
                #endregion
326
            }
327
        }
328
329
        #region Excel Export
330
331
        private void ExportEvent(object sender, RoutedEventArgs e)
332
        {
333
            this.ExportIndy.IsBusy = true;
334
335
            if (Lists.Count == 0)
336
            {
337
                DialogMessage_Alert("Data Not Found");
338
                this.ExportIndy.IsBusy = false;
339
                return;
340
            }
341
342
            string extension = "xlsx";
343
            //Uri url = new Uri("http://cloud.devdoftech.co.kr:5977/TileSource/Check_Test/CheckList.xlsx");
344
            Uri url = new Uri("http://cloud.devdoftech.co.kr:5977/TileSource/Check_Test/CheckList_T.xlsx");
345
346
            System.Windows.Forms.SaveFileDialog dialog = new System.Windows.Forms.SaveFileDialog()
347
            {
348
                DefaultExt = extension,
349
                Filter = String.Format("{1} files (*.{0})|*.{0}|All files (*.*)|*.*", extension, "Excel"),
350
                FilterIndex = 1
351
            };
352
353
            if (dialog.ShowDialog() == System.Windows.Forms.DialogResult.OK)
354
            {
355
                using (var client = new System.Net.WebClient())
356
                {
357
                    client.DownloadFile(url, dialog.FileName);
358
359
                    Excel.Application application = null;
360
                    Excel.Workbook workbook = null;
361
                    Excel.Worksheet worksheet = null;
362
363
                    try
364
                    {
365
                        // Excel 첫번째 워크시트 가져오기                
366
                        application = new Excel.Application();
367
                        workbook = application.Workbooks.Open(dialog.FileName);
368
                        worksheet = (Excel.Worksheet)workbook.Worksheets.get_Item("Sheet1");
369
370
                        // 데이타 넣기
371
                        int h = 9;
372
                        int w = 2;
373 6c781c0c djkim
                        string project_no = App.ViewInfo.ProjectNO;
374
                        worksheet.Cells[2, w + 8] = project_no;
375
                        string project_name = Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.GetProjectName(project_no);
376
                        worksheet.Cells[3, w + 8] = project_name;                        
377 787a4489 KangIngu
378
                        worksheet.Cells[4, w + 8] = (Application.Current.MainWindow as MainWindow).dzMainMenu._DocItem.DOCUMENT_NO;
379
                        worksheet.Cells[5, w + 8] = (Application.Current.MainWindow as MainWindow).dzMainMenu.userData.NAME + " (" + App.ViewInfo.UserID + ")";
380
                        worksheet.Cells[6, w + 8] = DateTime.Now.ToString("yyyy.MM.dd");
381
382
                        Excel.Range Range_I = worksheet.Range["K9"];
383
                        Excel.Range Range_O = null;
384
                        Excel.Borders border_ = null;
385
386
                        var Rev = Lists.Select(info => info.REVISION).Distinct();
387
                        string[] Cell = { "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T" };
388
                        string[] Range = { "L9", "M9", "N9", "O9", "P9", "Q9", "R9", "S9", "T9", "U9", "V9", "W9", "X9", "Y9", "Z9", "AA9", "AB9", "AC9", "AD9" };
389
                        string Ran = "K";
390
391
                        for (int i = 0; i < rev_cnt - 1; i++)
392
                        {
393
                            worksheet.Cells[9, 12 + i] = Cell[i];
394
                            Range_O = worksheet.Range[Range[i]];
395
                            border_ = Range_O.Borders;
396
                            border_.LineStyle = Range_I.Borders.LineStyle;
397
                            border_.Weight = Range_I.Borders.Weight;
398
                            Range_O.Interior.Color = Range_I.Interior.Color;
399
                        }
400
401
                        worksheet.Range[worksheet.Cells[8, 11], worksheet.Cells[8, 11 + rev_cnt - 1]].Merge();
402
403
                        if (rev_cnt != 1)
404
                        {
405
                            Ran = Range[rev_cnt - 2].Substring(0, Range[rev_cnt - 2].Length - 1);
406
                        }
407
                        Excel.Range iRange = worksheet.Range["B10:" + Ran + "10"];
408
409
                        //필터 기능 추가
410
                        Excel.Range Filter_Range = worksheet.Range["B9:" + Ran + "9"];
411
                        Filter_Range.AutoFilter(1, Type.Missing, Excel.XlAutoFilterOperator.xlAnd, Type.Missing, true);
412
413
                        Lists.ForEach(data =>
414
                        {
415
                            h++;
416
417
                            Excel.Range oRange = worksheet.Range["B" + h + ":" + Ran + h];
418
                            oRange.RowHeight = iRange.RowHeight;
419
                            Excel.Borders border = oRange.Borders;
420
                            border.LineStyle = Excel.XlLineStyle.xlContinuous;
421
                            border.Weight = 2d;
422
423
                            if (data.IMAGE_PATH != null)
424
                            {
425
                                Excel.Range ImageRange = worksheet.Cells[h, w + 2];
426
427
                                System.Drawing.Image I_Image = byteArrayToImage(data.IMAGE_PATH);
428
                                System.Drawing.Image o_Image = Resize(I_Image, 80, 80);
429
                                System.Windows.Forms.Clipboard.SetDataObject(o_Image, true);
430
431
                                ImageRange.Cells.HorizontalAlignment = Excel.XlHAlign.xlHAlignCenterAcrossSelection;
432
                                ImageRange.Cells.VerticalAlignment = Excel.XlHAlign.xlHAlignCenter;
433
434
                                worksheet.Paste(ImageRange.Cells, "TEST");
435
436
                                foreach (Microsoft.Office.Interop.Excel.Shape shp in worksheet.Shapes)
437
                                {
438
                                    if (shp.TopLeftCell.Address != ImageRange.Address)
439
                                        continue;
440
441
                                    double Left = shp.TopLeftCell.Left + (shp.TopLeftCell.Width - shp.Width) / 2;
442
                                    double Top = shp.TopLeftCell.Top + (shp.TopLeftCell.Height - shp.Height) / 2;
443
444
                                    shp.Left = float.Parse(Left.ToString());
445
                                    shp.Top = float.Parse(Top.ToString());
446
447
                                    break;
448
                                }
449
                            }
450
451
                            #region Excel Bind
452
                            worksheet.Cells[h, w] = data.REVISION;
453
                            worksheet.Cells[h, w + 1] = data.PAGENUMBER;
454
                            worksheet.Cells[h, w + 3] = data.TODOLIST;
455 b05da22f KangIngu
                            worksheet.Cells[h, w + 4] = data.STATUS.ToUpper() == "TRUE" ? "closed" : "open";
456 787a4489 KangIngu
                            worksheet.Cells[h, w + 5] = data.STATUS_DESC;
457
                            worksheet.Cells[h, w + 6] = data.VENDOR;
458
                            worksheet.Cells[h, w + 7] = data.REMARK;
459
                            worksheet.Cells[h, w + 8] = data.REPLY;
460
                            worksheet.Cells[h, w + 9] = data.REV_0 == null ? "" : data.REV_0.Replace("", " / ");
461
                            worksheet.Cells[h, w + 10] = data.REV_1 == null ? "" : data.REV_1.Replace("", " / ");
462
                            worksheet.Cells[h, w + 11] = data.REV_2 == null ? "" : data.REV_2.Replace("", " / ");
463
                            worksheet.Cells[h, w + 12] = data.REV_3 == null ? "" : data.REV_3.Replace("", " / ");
464
                            worksheet.Cells[h, w + 13] = data.REV_4 == null ? "" : data.REV_4.Replace("", " / ");
465
                            worksheet.Cells[h, w + 14] = data.REV_5 == null ? "" : data.REV_5.Replace("", " / ");
466
                            worksheet.Cells[h, w + 15] = data.REV_6 == null ? "" : data.REV_6.Replace("", " / ");
467
                            worksheet.Cells[h, w + 16] = data.REV_7 == null ? "" : data.REV_7.Replace("", " / ");
468
                            worksheet.Cells[h, w + 17] = data.REV_8 == null ? "" : data.REV_8.Replace("", " / ");
469
                            worksheet.Cells[h, w + 18] = data.REV_9 == null ? "" : data.REV_9.Replace("", " / ");
470
                            worksheet.Cells[h, w + 19] = data.REV_10 == null ? "" : data.REV_10.Replace("", " / ");
471
                            worksheet.Cells[h, w + 20] = data.REV_11 == null ? "" : data.REV_11.Replace("", " / ");
472
                            worksheet.Cells[h, w + 21] = data.REV_12 == null ? "" : data.REV_12.Replace("", " / ");
473
                            worksheet.Cells[h, w + 22] = data.REV_13 == null ? "" : data.REV_13.Replace("", " / ");
474
                            worksheet.Cells[h, w + 23] = data.REV_14 == null ? "" : data.REV_14.Replace("", " / ");
475
                            worksheet.Cells[h, w + 24] = data.REV_15 == null ? "" : data.REV_15.Replace("", " / ");
476
                            worksheet.Cells[h, w + 25] = data.REV_16 == null ? "" : data.REV_16.Replace("", " / ");
477
                            worksheet.Cells[h, w + 26] = data.REV_17 == null ? "" : data.REV_17.Replace("", " / ");
478
                            worksheet.Cells[h, w + 27] = data.REV_18 == null ? "" : data.REV_18.Replace("", " / ");
479
                            worksheet.Cells[h, w + 28] = data.REV_19 == null ? "" : data.REV_19.Replace("", " / ");
480
                            #endregion
481
                        });
482
483
                        worksheet.Columns.AutoFit();
484
                        // 엑셀파일 저장
485
                        workbook.Save();
486
                        workbook.Close(true);
487
                        application.Quit();
488
                    }
489
                    finally
490
                    {
491
                        System.Diagnostics.Process[] ExCel = System.Diagnostics.Process.GetProcessesByName("EXCEL");
492
                        if (ExCel.Count() != 0)
493
                        {
494
                            ExCel[0].Kill();
495
                        }
496
497
                        // Clean up
498
                        ReleaseExcelObject(worksheet);
499
                        ReleaseExcelObject(workbook);
500
                        ReleaseExcelObject(application);
501
                    }
502
                }
503
                DialogMessage_Alert("Success");
504
            }
505
506
            this.ExportIndy.IsBusy = false;
507
        }
508
509
        public System.Drawing.Image byteArrayToImage(byte[] byteArrayIn)
510
        {
511
            using (var ms = new System.IO.MemoryStream(byteArrayIn))
512
            {
513
                return System.Drawing.Image.FromStream(ms);
514
            }
515
        }
516
517
        public System.Drawing.Image Resize(System.Drawing.Image image, int newWidth, int maxHeight)
518
        {
519
            //if (onlyResizeIfWider && image.Width <= newWidth) newWidth = image.Width;
520
521
            var newHeight = image.Height * newWidth / image.Width;
522
            if (newHeight > maxHeight)
523
            {
524
                // Resize with height instead  
525
                newWidth = image.Width * maxHeight / image.Height;
526
                newHeight = maxHeight;
527
            }
528
529
            var res = new System.Drawing.Bitmap(newWidth, newHeight);
530
531
            using (var graphic = System.Drawing.Graphics.FromImage(res))
532
            {
533
                graphic.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.HighQualityBicubic;
534
                graphic.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;
535
                graphic.PixelOffsetMode = System.Drawing.Drawing2D.PixelOffsetMode.HighQuality;
536
                graphic.CompositingQuality = System.Drawing.Drawing2D.CompositingQuality.HighQuality;
537
                graphic.DrawImage(image, 0, 0, newWidth, newHeight);
538
            }
539
540
            return res;
541
        }
542
543
        private static void ReleaseExcelObject(object obj)
544
        {
545
            try
546
            {
547
                if (obj != null)
548
                {
549
                    obj = null;
550
                }
551
            }
552
            catch (Exception ex)
553
            {
554
                obj = null;
555
                throw ex;
556
            }
557
            finally
558
            {
559
                GC.Collect();
560
            }
561
        }
562
563
        #endregion
564
565
        #region 이벤트
566
567
        void MainWindow_SizeChanged(object sender, SizeChangedEventArgs e)
568
        {
569
            ChangeSize(e.NewSize.Width, e.NewSize.Height);
570
        }
571
572
        private void CheckList_Loaded(object sender, RoutedEventArgs e)
573
        {
574
            Current_DocNo = (Application.Current.MainWindow as MainWindow).dzMainMenu._DocItem.DOCUMENT_NO;
575
            Current_Revision = (Application.Current.MainWindow as MainWindow).dzMainMenu._DocItem.REVISION;
576
            Current_Slip = int.Parse((Application.Current.MainWindow as MainWindow).dzMainMenu._DocItem.GROUP_NO);
577
578 6c781c0c djkim
            string project_no = App.ViewInfo.ProjectNO;
579 787a4489 KangIngu
580 6c781c0c djkim
            List<DOCUMENT_ITEM> list = Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.GetPreRevSelect(project_no, Current_DocNo, Current_Revision);
581
            foreach (var I in list)
582
            {
583
                if (int.Parse(I.GROUP_NO) < Current_Slip)
584 787a4489 KangIngu
                {
585 6c781c0c djkim
                    old_Revision = I.REVISION;
586
                    old_DocID = I.DOCUMENT_ID;
587
                    return;
588 787a4489 KangIngu
                }
589 6c781c0c djkim
            }            
590 787a4489 KangIngu
        }
591
592
        private void RadGridView_Loaded(object sender, RoutedEventArgs e)
593
        {
594
            DataBind();
595
            (sender as Telerik.Windows.Controls.RadGridView).ItemsSource = null;
596
            (sender as Telerik.Windows.Controls.RadGridView).ItemsSource = Lists;
597
598
            ChangeSize(this.ActualWidth, this.ActualHeight);
599
            this.SizeChanged += new SizeChangedEventHandler(MainWindow_SizeChanged);
600
        }
601
602
        private void AddEvent(object sender, RoutedEventArgs e)
603
        {
604
            Application.Current.MainWindow.Focus();
605
606
            Common.ViewerDataModel.Instance.CheckList_ID = KCOM.Events.Save.shortGuid();
607
            Common.ViewerDataModel.Instance.Capture_Opacity = 0.5;
608
            (Application.Current.MainWindow as MainWindow).dzMainMenu.mouseHandlingMode = IKCOM.MouseHandlingMode.Capture;
609
        }
610
611
        private void SaveEvent(object sender, RoutedEventArgs e)
612
        {
613
            CHECK_LIST Check_value = new CHECK_LIST();
614
            CHECK_LIST_HISTORY Check_History = new CHECK_LIST_HISTORY();
615
616 6c781c0c djkim
            foreach (var item in tb.Items)
617 787a4489 KangIngu
            {
618 6c781c0c djkim
                string Check_ID = (item as Customer).ID.ToString();
619
                string state = "";
620
621
                Check_value = Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.GetCheckList(App.ViewInfo.ProjectNO, Check_ID);
622
                    
623
                if (Check_value != null)
624 787a4489 KangIngu
                {
625 6c781c0c djkim
                    if ((item as Customer).STATUS.ToUpper() == "TRUE")
626
                    {
627
                        state = "Closed";
628
                        Check_value.STATUS_DESC_CLOSE = (item as Customer).STATUS_DESC;
629
                    }
630
                    else
631
                    {
632
                        state = "Open";
633
                        Check_value.STATUS_DESC_OPEN = (item as Customer).STATUS_DESC;
634
                    }
635 787a4489 KangIngu
636 6c781c0c djkim
                    string Rev = state + "" + DateTime.Now.ToString("yyyy.MM.dd");
637
                    string description = "";
638 787a4489 KangIngu
639 6c781c0c djkim
                    if (char.Parse(ViewerDataModel.Instance.SystemMain.dzMainMenu.CurrentDoc.Revision) >= char.Parse(Check_value.REVISION))
640 787a4489 KangIngu
                    {
641 6c781c0c djkim
                        Check_value.REMARK = (item as Customer).REMARK;
642
                        Check_value.STATUS = (item as Customer).STATUS;
643
                        Check_value.TODOLIST = (item as Customer).TODOLIST;
644
                        Check_value.VENDOR = (item as Customer).VENDOR;
645
                        Check_value.REPLY = (item as Customer).REPLY;
646
647
                        if (state == "Open")
648
                            description = Check_value.STATUS_DESC_OPEN;
649 787a4489 KangIngu
                        else
650 6c781c0c djkim
                            description = Check_value.STATUS_DESC_CLOSE;
651 787a4489 KangIngu
652 6c781c0c djkim
                        var history = Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.GetCheckListHistory(App.ViewInfo.ProjectNO, Check_ID);
653
                        
654
                        Check_History = history.Where(info => info.REVISION == ViewerDataModel.Instance.SystemMain.dzMainMenu.CurrentDoc.Revision).FirstOrDefault();
655 787a4489 KangIngu
656 6c781c0c djkim
                        List<string> validation = new List<string>();
657 787a4489 KangIngu
658 6c781c0c djkim
                        foreach (var his in history)
659
                        {
660
                            if (his.TODOLIST == Check_value.TODOLIST)
661
                                validation.Add("TODOLIST");
662
                            if (his.STATUS_DESC == description)
663
                                validation.Add("STATUS_DESC");
664
                            if (his.VENDOR == Check_value.VENDOR)
665
                                validation.Add("VENDOR");
666
                            if (his.REMARK == Check_value.REMARK)
667
                                validation.Add("REMARK");
668
                            if (his.REPLY == Check_value.REPLY)
669
                                validation.Add("REPLY");
670
                        }
671 787a4489 KangIngu
672 6c781c0c djkim
                        if (validation.Count < 5)
673
                        {
674
                            if (Check_History == null)
675 787a4489 KangIngu
                            {
676 6c781c0c djkim
                                Check_History = new CHECK_LIST_HISTORY()
677
                                {
678
                                    ID = Events.Save.shortGuid(),
679
                                    CHECKLIST_ID = Check_ID,
680
                                    REVISION = ViewerDataModel.Instance.SystemMain.dzMainMenu.CurrentDoc.Revision,
681
                                    STATUS = state,
682
                                    IMAGE_URL = Check_value.IMAGE_URL,
683
                                    STATUS_DESC = validation.Where(i => i.ToString() == "STATUS_DESC").FirstOrDefault() == null ? description : "",
684
                                    TODOLIST = validation.Where(i => i.ToString() == "TODOLIST").FirstOrDefault() == null ? Check_value.TODOLIST : "",
685
                                    VENDOR = validation.Where(i => i.ToString() == "VENDOR").FirstOrDefault() == null ? Check_value.VENDOR : "",
686
                                    REMARK = validation.Where(i => i.ToString() == "REMARK").FirstOrDefault() == null ? Check_value.REMARK : "",
687
                                    REPLY = validation.Where(i => i.ToString() == "REPLY").FirstOrDefault() == null ? Check_value.REPLY : "",
688
                                    CREATE_TIME = DateTime.Now,
689
                                    UPDATE_TIME = DateTime.Now
690
                                };
691
                                Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.AddCheckListHistory(App.ViewInfo.ProjectNO, Check_History);
692
                                
693
                                Check_value.REVISION = Current_Revision;
694 787a4489 KangIngu
                            }
695 6c781c0c djkim
                            else
696 787a4489 KangIngu
                            {
697 6c781c0c djkim
                                Check_History.IMAGE_URL = Check_value.IMAGE_URL;
698
                                Check_History.STATUS = state;
699
                                Check_History.TODOLIST = Check_value.TODOLIST;
700
                                Check_History.VENDOR = Check_value.VENDOR;
701
                                Check_History.REMARK = Check_value.REMARK;
702
                                Check_History.REPLY = Check_value.REPLY;
703
                                Check_History.UPDATE_TIME = DateTime.Now;
704
                                Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.SaveCheckListHistory(App.ViewInfo.ProjectNO, ViewerDataModel.Instance.SystemMain.dzMainMenu.CurrentDoc.Revision, Check_History);
705 787a4489 KangIngu
                            }
706
                        }
707 6c781c0c djkim
                        validation = new List<string>();
708 787a4489 KangIngu
                    }
709
                }
710 6c781c0c djkim
                Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.SaveCheckList(App.ViewInfo.ProjectNO, Check_ID, Check_value);
711 787a4489 KangIngu
            }
712 6c781c0c djkim
            
713
            DataBind();
714
            tb.ItemsSource = null;
715
            tb.ItemsSource = Lists;
716
            History_Set();
717
718
            DialogMessage_Alert("Success");            
719 787a4489 KangIngu
        }
720
721
        private void CheckListEvent(object sender, RoutedEventArgs e)
722
        {
723
            if (col1.Width == new GridLength(1200))
724
            {
725
                this.Width += 600;
726
                col1.Width = new GridLength(1800);
727
            }
728
            else
729
            {
730
                this.Width -= 600;
731
                col1.Width = new GridLength(1200);
732
            }
733
            History_Set();
734
        }
735
736
        private void CommentMoveEvent(object sender, MouseButtonEventArgs e)
737
        {
738
            SyncInit();
739
740
            Rect rect = new Rect();
741
            string[] RectPoint = ((e.Source as Image).DataContext as Customer).IMAGE_ANCHOR.Split(',');
742
            //string[] RectPoint = ((e.Source as Telerik.Windows.Controls.RadButton).DataContext as Customer).IMAGE_ANCHOR.Split(',');
743
744
            rect = new Rect(new Point(double.Parse(RectPoint[0]), double.Parse(RectPoint[1])), new Point(double.Parse(RectPoint[0]) + double.Parse(RectPoint[2]), double.Parse(RectPoint[1]) + double.Parse(RectPoint[3])));
745
746
            //Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.pageNavigator.GotoPage(((e.Source as Telerik.Windows.Controls.RadButton).DataContext as Customer).PAGENUMBER);
747
            Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.pageNavigator.GotoPage(((e.Source as Image).DataContext as Customer).PAGENUMBER);
748
            Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.zoomAndPanControl.ZoomTo(rect);
749
            Application.Current.MainWindow.Focus();
750
        }
751
752
        private void CaptureEvent(object sender, MouseButtonEventArgs e)
753
        {
754
            SyncInit();
755
756
            //캡쳐 하기 전에 코멘트 저장
757
            if (Common.ViewerDataModel.Instance.MarkupControls_USER.Count > 0 || (Application.Current.MainWindow as MainWindow).dzMainMenu.SelectLayer.Children.Count > 0)
758
            {
759
                var menu = (Application.Current.MainWindow as MainWindow).dzMainMenu;
760
                menu.ReleaseAdorner();
761
                if (menu.PreviewUserMarkupInfoItem != null && menu.PreviewUserMarkupInfoItem.IsPreviewUser == true)
762
                {
763
                    (Application.Current.MainWindow as MainWindow).dzTopMenu.RefactoryCommentReact(menu);
764
                }
765
                else if (menu.gridViewMarkup.SelectedItems.Count == 0 || (menu.gridViewMarkup.SelectedItems.FirstOrDefault() as IKCOM.MarkupInfoItem).UserID != App.ViewInfo.UserID)
766
                {
767
768
                }
769
                else
770
                {
771
                    (Application.Current.MainWindow as MainWindow).dzTopMenu.RefactoryCommentReact(menu);
772
                }
773
            }
774
775
            //Common.ViewerDataModel.Instance.CheckList_ID = ((e.Source as Telerik.Windows.Controls.RadButton).DataContext as Customer).ID;
776
            Common.ViewerDataModel.Instance.CheckList_ID = ((e.Source as Image).DataContext as Customer).ID;
777
            Application.Current.MainWindow.Focus();
778
            Common.ViewerDataModel.Instance.Capture_Opacity = 0.49;
779
            (Application.Current.MainWindow as MainWindow).dzMainMenu.mouseHandlingMode = IKCOM.MouseHandlingMode.Capture;
780
        }
781
782
        public void KeyEventDownAction(object sender, KeyEventArgs e)
783
        {
784
            switch (e.Key)
785
            {
786
                case Key.Escape:
787
                    {
788
                        (Application.Current.MainWindow as MainWindow).dzMainMenu.mouseHandlingMode = IKCOM.MouseHandlingMode.None;
789
                        Common.ViewerDataModel.Instance.Capture_Opacity = 0;
790
                    }
791
                    break;
792
            }
793
        }
794
795
        private void tb_IsVisibleChanged(object sender, DependencyPropertyChangedEventArgs e)
796
        {
797
            if(ViewerDataModel.Instance.Capture_Opacity == 0)
798
                return;
799
            
800
            DataBind();
801
            tb.ItemsSource = null;
802
            tb.ItemsSource = Lists.OrderBy(info => info.CREATE_TIME);
803
            //tb1.ItemsSource = Lists.OrderBy(info => info.CREATE_TIME);
804
805
            if (ViewerDataModel.Instance.Capture_Opacity == 0.5)
806
            {
807
                tb.SortDescriptors.Clear();
808
                tb.FilterDescriptors.Clear();
809
810
                var scrollViewer = this.tb.ChildrenOfType<GridViewScrollViewer>().FirstOrDefault();
811
                if (scrollViewer != null)
812
                {
813
                    //this.tb.ChildrenOfType<GridViewScrollViewer>().FirstOrDefault().ScrollToVerticalOffset(this.tb.ChildrenOfType<GridViewScrollViewer>().FirstOrDefault().ExtentHeight);
814
                    //this.tb1.ChildrenOfType<GridViewScrollViewer>().FirstOrDefault().ScrollToVerticalOffset(this.tb.ChildrenOfType<GridViewScrollViewer>().FirstOrDefault().ExtentHeight);
815
816
                    tb.ScrollIndexIntoView(tb.Items.Count - 1);
817
                    tb.CurrentCellInfo = new GridViewCellInfo(tb.Items[tb.Items.Count - 1], tb.Columns["TODOLIST"]);
818
                    tb.Focus();
819
820
                }
821
            }
822
        }
823
824
        private void Radio_Open_Checked(object sender, RoutedEventArgs e)
825
        {
826
            (e.Source as RadioButton).Foreground = Brushes.Red;
827
            (e.Source as RadioButton).FontWeight = FontWeights.Bold;
828
829
            if ((((e.OriginalSource as RadioButton).Parent as StackPanel).Parent as GridViewCell).ParentRow.Item != null)
830
            {
831
                ((((e.OriginalSource as RadioButton).Parent as StackPanel).Parent as GridViewCell).ParentRow.Item as Customer)._STATUS = "Open";
832
            }
833
834
            if (Isinit)
835
            {
836
                Isinit = false;
837
                if ((e.Source as RadioButton).DataContext != null)
838
                {
839
                    if (((e.Source as RadioButton).DataContext as Customer).STATUS_DESC != "Vendor 반영 필요")
840
                    {
841
                        ((e.Source as RadioButton).DataContext as Customer).STATUS_DESC = "Vendor 반영 필요";
842
843
                        tb.Rebind();
844
                    }
845
                }
846
            }
847
        }
848
849
        private void Radio_Close_Checked(object sender, RoutedEventArgs e)
850
        {
851 69ef0800 KangIngu
            if (Isinit)
852
            {
853
                if (!isCheck_Status)
854
                {
855
                    Select_StatusID = ((e.Source as RadioButton).DataContext as Customer).ID;
856
857
                    isCheck_Status = true;
858
859
                    RadWindow CheckPop = new RadWindow();
860
861
                    CheckList_Status check = new CheckList_Status();
862
863
                    CheckPop = new RadWindow
864
                    {
865
                        MinWidth = 350,
866
                        MinHeight = 150,
867
                        Header = "Status Description을 입력하세요",
868
                        Content = check,
869
                        ResizeMode = System.Windows.ResizeMode.NoResize,
870
                        WindowStartupLocation = System.Windows.WindowStartupLocation.CenterScreen,
871
                        IsTopmost = true,
872
                    };
873
                    StyleManager.SetTheme(CheckPop, new Office2013Theme());
874
                    CheckPop.Closed += CheckPop_Closed;
875
                    CheckPop.Show();
876
877
                    Isinit = false;
878
                    tb.Rebind();
879
                }
880
            }
881 787a4489 KangIngu
882
            (e.Source as RadioButton).FontWeight = FontWeights.Bold;
883
884
            if ((((e.OriginalSource as RadioButton).Parent as StackPanel).Parent as GridViewCell).ParentRow.Item != null)
885
            {
886
                ((((e.OriginalSource as RadioButton).Parent as StackPanel).Parent as GridViewCell).ParentRow.Item as Customer)._STATUS = "Close";
887
            }
888 69ef0800 KangIngu
        }
889 787a4489 KangIngu
890 69ef0800 KangIngu
        private void CheckPop_Closed(object sender, WindowClosedEventArgs e)
891
        {
892
            isCheck_Status = false;
893
894
            foreach(var item in tb.Items)
895 787a4489 KangIngu
            {
896 69ef0800 KangIngu
                if(Select_StatusID == (item as Customer).ID.ToString())
897 787a4489 KangIngu
                {
898 69ef0800 KangIngu
                    if (ViewerDataModel.Instance.CheckStatus != "" && ViewerDataModel.Instance.CheckStatus != null)
899 787a4489 KangIngu
                    {
900 69ef0800 KangIngu
                        (item as Customer).STATUS_DESC = ViewerDataModel.Instance.CheckStatus;
901
                    }
902
                    else
903
                    {
904
                        (item as Customer).STATUS = "False";
905
                        (item as Customer)._STATUS = "Open";
906
                        (item as Customer).STATUS_ = "True";
907 787a4489 KangIngu
                    }
908 69ef0800 KangIngu
909
                    ViewerDataModel.Instance.CheckStatus = "";
910
                    Select_StatusID = "";
911
                    tb.Rebind();
912
                    return;
913 787a4489 KangIngu
                }
914
            }
915 69ef0800 KangIngu
916 787a4489 KangIngu
        }
917
918
        private void Radio_Unchecked(object sender, RoutedEventArgs e)
919
        {
920
            (e.Source as RadioButton).Foreground = Brushes.Black;
921
            (e.Source as RadioButton).FontWeight = FontWeights.Normal;
922
        }
923
924
        private void mousedownOnImage(object sender, MouseButtonEventArgs args)
925
        {
926
            if(args.OriginalSource as TextBlock != null && (args.OriginalSource as TextBlock).Parent != null)
927
            {
928
                if((args.OriginalSource as TextBlock).Parent.GetType().Name == "GridViewHeaderCell")
929
                {
930
                    Isinit = false;
931
                    return;
932
                }
933
            }
934
935
            Isinit = true;
936
937
            RadWindow CheckPop = new RadWindow();
938
939
            if (args.OriginalSource is Image)
940
            {
941
                Image img = (args.OriginalSource as Image);
942
                if (img.Height != 45)
943
                    return;
944
945
                CommantImage check = new CommantImage(img);
946
947
                CheckPop = new RadWindow
948
                {
949
                    MinWidth = 500,
950
                    MinHeight = 500,
951
                    Header = "Image",
952
                    Content = check,
953
                    ResizeMode = System.Windows.ResizeMode.NoResize,
954
                    WindowStartupLocation = System.Windows.WindowStartupLocation.CenterScreen,
955
                    IsTopmost = true,
956
                };
957
                StyleManager.SetTheme(CheckPop, new Office2013Theme());
958
                CheckPop.Show();
959
            }
960
            
961
            if (args.OriginalSource as TextBlock == null || (args.OriginalSource as TextBlock).Parent == null || ((args.OriginalSource as TextBlock).Parent) as GridViewCell == null)
962
            {
963
                return;
964
            }
965
966
            if ((((args.OriginalSource as TextBlock).Parent) as GridViewCell).DataColumn.ColumnGroupName.ToString() == "History")
967
            {
968
969
                CheckList_Detail Detail = new CheckList_Detail((((args.OriginalSource as TextBlock).Parent as GridViewCell).ParentRow.Item as KCOM.Controls.Customer).ID, (((args.OriginalSource as TextBlock).Parent) as GridViewCell).DataColumn.Header.ToString());
970
971
                CheckPop = new RadWindow
972
                {
973
                    MinWidth = 800,
974
                    MinHeight = 400,
975
                    Header = "Detail",
976
                    Content = Detail,
977
                    //ResizeMode = System.Windows.ResizeMode.CanResizeWithGrip,
978
                    ResizeMode = System.Windows.ResizeMode.NoResize,
979
                    WindowStartupLocation = System.Windows.WindowStartupLocation.CenterScreen,
980
                    IsTopmost = true,
981
                };
982
                StyleManager.SetTheme(CheckPop, new Office2013Theme());
983
                //CheckPop.ShowDialog();
984
                CheckPop.Show();
985
            }
986
987
        }
988
989
        private void SyncEvent(object sender, MouseButtonEventArgs e)
990
        {
991 6c781c0c djkim
            var _vpList = Common.ViewerDataModel.Instance.SystemMain.dzMainMenu.BaseClient.GetVPRevisionFirstOrDefault(App.ViewInfo.ProjectNO, old_DocID);
992 787a4489 KangIngu
993 6c781c0c djkim
            if (old_DocID == "")
994 787a4489 KangIngu
            {
995 6c781c0c djkim
                DialogMessage_Alert("상위 리비전이 없습니다.");
996
                return;
997 787a4489 KangIngu
            }
998 6c781c0c djkim
999
            SyncInit();
1000
            Rect rect = new Rect();
1001
            string[] RectPoint = ((e.Source as Image).DataContext as Customer).IMAGE_ANCHOR.Split(',');
1002
            rect = new Rect(new Point(double.Parse(RectPoint[0]), double.Parse(RectPoint[1])), new Point(double.Parse(RectPoint[0]) + double.Parse(RectPoint[2]), double.Parse(RectPoint[1]) + double.Parse(RectPoint[3])));
1003
            ViewerDataModel.Instance.SystemMain.dzMainMenu.pageNavigator.GotoPage(((e.Source as Image).DataContext as Customer).PAGENUMBER);
1004
            ViewerDataModel.Instance.SystemMain.dzMainMenu.zoomAndPanControl.Sync_ZoomTo(rect);
1005
            (Application.Current.MainWindow as MainWindow).dzMainMenu.Sync_Event(_vpList);
1006
            
1007 787a4489 KangIngu
        }
1008
1009
        #endregion
1010
    }
1011
}
클립보드 이미지 추가 (최대 크기: 500 MB)