hytos / DTI_PID / SPPIDConverter_AutoModeling / MainControl.cs @ fa7533ae
이력 | 보기 | 이력해설 | 다운로드 (25.2 KB)
1 |
using System; |
---|---|
2 |
using System.Collections.Generic; |
3 |
using System.ComponentModel; |
4 |
using System.Drawing; |
5 |
using System.Data; |
6 |
using System.Linq; |
7 |
using System.Text; |
8 |
using System.Threading.Tasks; |
9 |
using System.Windows.Forms; |
10 |
using Microsoft.Win32; |
11 |
using Telerik.WinControls.UI; |
12 |
using System.IO; |
13 |
using System.Threading; |
14 |
using SPPID.Modeling; |
15 |
using SPPID.Model; |
16 |
using SPPID.Utill; |
17 |
using SPPID.DB; |
18 |
using Microsoft.VisualBasic; |
19 |
using Newtonsoft.Json; |
20 |
|
21 |
namespace SPPIDConverter_AutoModeling |
22 |
{ |
23 |
public partial class MainControl : UserControl |
24 |
{ |
25 |
Thread autoModelingThread; |
26 |
|
27 |
private Dictionary<string, string> symbolMapping = new Dictionary<string, string>(); |
28 |
private Dictionary<string, string> attributeMapping = new Dictionary<string, string>(); |
29 |
private DataTable dUnit = new DataTable(); |
30 |
private string TemplatePath; |
31 |
private string SymbolPath; |
32 |
|
33 |
public MainControl() |
34 |
{ |
35 |
InitializeComponent(); |
36 |
|
37 |
if (SetPath()) |
38 |
{ |
39 |
if (SPPIDUtill.LoadDB()) |
40 |
InitDBInformation(); |
41 |
else |
42 |
MessageBox.Show("Please Check DB Setting", "Warning", MessageBoxButtons.OK, MessageBoxIcon.Warning); |
43 |
InitGridViewDB(); |
44 |
} |
45 |
else |
46 |
{ |
47 |
|
48 |
} |
49 |
} |
50 |
|
51 |
private bool SetPath() |
52 |
{ |
53 |
try |
54 |
{ |
55 |
RegistryKey key = Registry.LocalMachine; |
56 |
RegistryKey software = key.OpenSubKey("SOFTWARE"); |
57 |
RegistryKey DOFTECH = software.OpenSubKey("DOFTECH"); |
58 |
if (DOFTECH != null) |
59 |
{ |
60 |
RegistryKey ID2 = DOFTECH.OpenSubKey("ID2"); |
61 |
if (ID2 != null) |
62 |
{ |
63 |
SPPIDUtill.defaultPath = ID2.GetValue("Path").ToString(); |
64 |
Log.logPath = SPPIDUtill.defaultPath + @"Converter\SPPID Converter.log"; |
65 |
SPPIDUtill.mappingFilePath = SPPIDUtill.defaultPath + @"Converter\mapping.xml"; |
66 |
SPPIDUtill.dbFilePath = SPPIDUtill.defaultPath + @"Converter\DB.config"; |
67 |
|
68 |
return true; |
69 |
} |
70 |
} |
71 |
} |
72 |
catch (Exception ex) |
73 |
{ |
74 |
|
75 |
} |
76 |
|
77 |
return false; |
78 |
} |
79 |
|
80 |
#region Init Data Setting |
81 |
|
82 |
public void InitDBInformation() |
83 |
{ |
84 |
// Unit DataTable |
85 |
dUnit = DB.GetUnitTree(); |
86 |
|
87 |
// Template List |
88 |
TemplatePath = DB.GetPlantPID_T_OPTIONSETTING_Value("PID Template Path"); |
89 |
GridViewComboBoxColumn colTemplate = gridViewDrawingList.Columns["colTemplate"] as GridViewComboBoxColumn; |
90 |
colTemplate.DataSource = Directory.GetFiles(TemplatePath, "*.pid").ToList().Select(filePath => Path.GetFileName(filePath)); |
91 |
|
92 |
// Load Mapping |
93 |
SPPIDUtill.LoadMapping(symbolMapping, attributeMapping); |
94 |
|
95 |
// Symbol Path |
96 |
SymbolPath = DB.GetPlantPID_T_OPTIONSETTING_Value("Catalog Explorer root path"); |
97 |
GridViewComboBoxColumn colSPPIDName = gridViewItemMapping.Columns["colSPPIDName"] as GridViewComboBoxColumn; |
98 |
colSPPIDName.DataSource = Directory.GetFiles(SymbolPath, "*.sym", SearchOption.AllDirectories).ToList().Select(symbol => symbol.Remove(0, SymbolPath.Length)); |
99 |
|
100 |
// Load Mapping |
101 |
SPPIDUtill.LoadMapping(symbolMapping, attributeMapping); |
102 |
gridViewItemMapping.BeginUpdate(); |
103 |
foreach (var item in symbolMapping) |
104 |
gridViewItemMapping.Rows.Add(new object[] {item.Key,item.Value, "View" }); |
105 |
gridViewItemMapping.BestFitColumns(); |
106 |
gridViewItemMapping.EndUpdate(); |
107 |
|
108 |
|
109 |
// Attribute |
110 |
GridViewComboBoxColumn colSPPIDAttribute = gridViewAttribute.Columns["colSPPIDAttribute"] as GridViewComboBoxColumn; |
111 |
colSPPIDAttribute.DataSource = DB.GetSPPIDAttribute(); |
112 |
|
113 |
// Load Attribute |
114 |
gridViewAttribute.BeginUpdate(); |
115 |
foreach (var item in attributeMapping) |
116 |
gridViewAttribute.Rows.Add(new object[] { item.Key, item.Value, "View" }); |
117 |
gridViewAttribute.BestFitColumns(); |
118 |
gridViewAttribute.EndUpdate(); |
119 |
} |
120 |
|
121 |
#endregion |
122 |
|
123 |
|
124 |
#region Setting Page |
125 |
private const string _DBType = "DB Type"; |
126 |
private const string _ServiceName = "Service Name"; |
127 |
private const string _SiteName = "Site Name"; |
128 |
private const string _ServerIP = "Server IP"; |
129 |
private const string _Port = "Port"; |
130 |
private const string _DBUser = "DB User"; |
131 |
private const string _DBPassword = "DB Password"; |
132 |
|
133 |
private void InitGridViewDB() |
134 |
{ |
135 |
DBInformation dbInfo = DBInformation.GetInstance(); |
136 |
|
137 |
gridViewDB.Rows.Add(new object[] { _DBType , dbInfo.DBType}); |
138 |
gridViewDB.Rows.Add(new object[] { _ServiceName, dbInfo.Service }); |
139 |
gridViewDB.Rows.Add(new object[] { _SiteName, dbInfo.Site}); |
140 |
gridViewDB.Rows.Add(new object[] { _ServerIP, dbInfo.ServerIP}); |
141 |
gridViewDB.Rows.Add(new object[] { _Port, dbInfo.Port}); |
142 |
gridViewDB.Rows.Add(new object[] { _DBUser, dbInfo.DBUser}); |
143 |
gridViewDB.Rows.Add(new object[] { _DBPassword, dbInfo.DBPassword}); |
144 |
gridViewDB.BestFitColumns(); |
145 |
|
146 |
this.gridViewDB.RowFormatting += new Telerik.WinControls.UI.RowFormattingEventHandler(this.gridViewDB_RowFormatting); |
147 |
this.gridViewDB.CellBeginEdit += new Telerik.WinControls.UI.GridViewCellCancelEventHandler(this.gridViewDB_CellBeginEdit); |
148 |
this.gridViewDB.CellValueChanged += new Telerik.WinControls.UI.GridViewCellEventHandler(this.gridViewDB_CellValueChanged); |
149 |
} |
150 |
|
151 |
private void gridViewDB_CellBeginEdit(object sender, GridViewCellCancelEventArgs e) |
152 |
{ |
153 |
string sKey = (string)e.Row.Cells["colKey"].Value; |
154 |
if (sKey == _DBType || |
155 |
sKey == _ServiceName || |
156 |
sKey == _SiteName) |
157 |
{ |
158 |
e.Cancel = true; |
159 |
} |
160 |
else |
161 |
{ |
162 |
|
163 |
} |
164 |
} |
165 |
|
166 |
private void gridViewDB_RowFormatting(object sender, RowFormattingEventArgs e) |
167 |
{ |
168 |
string sKey = (string)e.RowElement.RowInfo.Cells["colKey"].Value; |
169 |
if (sKey == _DBType || |
170 |
sKey == _ServiceName || |
171 |
sKey == _SiteName) |
172 |
{ |
173 |
e.RowElement.DrawFill = true; |
174 |
e.RowElement.GradientStyle = Telerik.WinControls.GradientStyles.Solid; |
175 |
e.RowElement.BackColor = Color.Aquamarine; |
176 |
} |
177 |
} |
178 |
|
179 |
private void gridViewDB_CellValueChanged(object sender, GridViewCellEventArgs e) |
180 |
{ |
181 |
btnSave.Enabled = false; |
182 |
} |
183 |
|
184 |
private void btnLoadiniFile_Click(object sender, EventArgs e) |
185 |
{ |
186 |
try |
187 |
{ |
188 |
OpenFileDialog dialog = new OpenFileDialog(); |
189 |
dialog.Multiselect = false; |
190 |
dialog.Filter = "ini File(*.ini)|*.ini"; |
191 |
if (dialog.ShowDialog() == DialogResult.OK) |
192 |
{ |
193 |
string sDBTYPE = string.Empty; |
194 |
string sSERVICENAME = string.Empty; |
195 |
string sUID = string.Empty; |
196 |
|
197 |
string[] texts = File.ReadAllLines(dialog.FileName); |
198 |
|
199 |
bool find = false; |
200 |
for (int i = 0; i < texts.Length; i++) |
201 |
{ |
202 |
string text = texts[i]; |
203 |
|
204 |
if (text.Trim() == "[SITESCHEMA]") |
205 |
find = true; |
206 |
|
207 |
if (find) |
208 |
{ |
209 |
if (text.StartsWith("DBTYPE=") && string.IsNullOrEmpty(sDBTYPE)) |
210 |
sDBTYPE = text.Remove(0, "DBTYPE=".Length); |
211 |
else if (text.StartsWith("DBSERVER=") && string.IsNullOrEmpty(sSERVICENAME)) |
212 |
sSERVICENAME = text.Remove(0, "DBSERVER=".Length); |
213 |
else if (text.StartsWith("UID=") && string.IsNullOrEmpty(sUID)) |
214 |
sUID = text.Remove(0, "UID=".Length); |
215 |
} |
216 |
} |
217 |
|
218 |
if (string.IsNullOrEmpty(sDBTYPE) || string.IsNullOrEmpty(sSERVICENAME) || string.IsNullOrEmpty(sUID)) |
219 |
MessageBox.Show("Unavailable ini file.", "Warning", MessageBoxButtons.OK, MessageBoxIcon.Warning); |
220 |
else |
221 |
{ |
222 |
foreach (GridViewRowInfo rowInfo in gridViewDB.Rows) |
223 |
{ |
224 |
string sKey = (string)rowInfo.Cells["colKey"].Value; |
225 |
if (sKey == _DBType) |
226 |
rowInfo.Cells["colValue"].Value = sDBTYPE; |
227 |
else if (sKey == _ServiceName) |
228 |
rowInfo.Cells["colValue"].Value = sSERVICENAME; |
229 |
else if (sKey == _SiteName) |
230 |
rowInfo.Cells["colValue"].Value = sUID; |
231 |
} |
232 |
} |
233 |
} |
234 |
} |
235 |
catch (Exception ex) |
236 |
{ |
237 |
MessageBox.Show("Unavailable ini file.", "Warning", MessageBoxButtons.OK, MessageBoxIcon.Warning); |
238 |
} |
239 |
} |
240 |
|
241 |
private void btnSPPIDDBTest_Click(object sender, EventArgs e) |
242 |
{ |
243 |
DBInformation dbInfo = DBInformation.GetInstance(); |
244 |
dbInfo.Status = false; |
245 |
foreach (GridViewRowInfo rowInfo in gridViewDB.Rows) |
246 |
{ |
247 |
string sKey = (string)rowInfo.Cells["colKey"].Value; |
248 |
string sValue = (string)rowInfo.Cells["colValue"].Value; |
249 |
|
250 |
switch (sKey) |
251 |
{ |
252 |
case _DBType: |
253 |
dbInfo.DBType = sValue; |
254 |
break; |
255 |
case _ServiceName: |
256 |
dbInfo.Service = sValue; |
257 |
break; |
258 |
case _SiteName: |
259 |
dbInfo.Site = sValue; |
260 |
break; |
261 |
case _ServerIP: |
262 |
dbInfo.ServerIP = sValue; |
263 |
break; |
264 |
case _Port: |
265 |
dbInfo.Port = sValue; |
266 |
break; |
267 |
case _DBUser: |
268 |
dbInfo.DBUser = sValue; |
269 |
break; |
270 |
case _DBPassword: |
271 |
dbInfo.DBPassword = sValue; |
272 |
break; |
273 |
default: |
274 |
break; |
275 |
} |
276 |
} |
277 |
|
278 |
if (DB.CheckAndSetDBInformation()) |
279 |
{ |
280 |
btnSave.Enabled = true; |
281 |
MessageBox.Show("Test Connection Success!", "Information", MessageBoxButtons.OK, MessageBoxIcon.Information); |
282 |
} |
283 |
else |
284 |
{ |
285 |
MessageBox.Show("Check DB Information!", "Warning", MessageBoxButtons.OK, MessageBoxIcon.Warning); |
286 |
} |
287 |
} |
288 |
|
289 |
private void gridViewDB_CellFormatting(object sender, CellFormattingEventArgs e) |
290 |
{ |
291 |
if (e.Column.Name == "colValue" && (string)e.Row.Cells["colKey"].Value == _DBPassword) |
292 |
{ |
293 |
object value = e.CellElement.RowInfo.Cells["colValue"].Value; |
294 |
string text = string.Empty; |
295 |
if (value != null) |
296 |
{ |
297 |
int passwordLen = Convert.ToString(value).Length + 1; |
298 |
text = string.Join("*", new string[passwordLen]); |
299 |
} |
300 |
|
301 |
e.CellElement.Text = text; |
302 |
} |
303 |
} |
304 |
|
305 |
private void btnSave_Click(object sender, EventArgs e) |
306 |
{ |
307 |
DBInformation dbInfo = DBInformation.GetInstance(); |
308 |
if (dbInfo != null) |
309 |
{ |
310 |
dbInfo.Status = true; |
311 |
string sJson = JsonConvert.SerializeObject(dbInfo); |
312 |
SPPIDUtill.SaveDB(sJson); |
313 |
|
314 |
MessageBox.Show("Save Success!", "Information", MessageBoxButtons.OK, MessageBoxIcon.Information); |
315 |
} |
316 |
else |
317 |
{ |
318 |
|
319 |
} |
320 |
} |
321 |
|
322 |
#endregion |
323 |
|
324 |
#region Convert Page |
325 |
const string _Ready = "Ready"; |
326 |
const string _LoadFail = "Can't Load"; |
327 |
const string _NeedMapping = "Need Mapping"; |
328 |
const string _NeedUnit = "Select Unit"; |
329 |
const string _NeedTemplate = "Select Template"; |
330 |
const string _Error = "Error"; |
331 |
const string _EndProcess = "End Process"; |
332 |
const string _Processing = "Processing"; |
333 |
|
334 |
private void btnLoadFiles_Click(object sender, EventArgs e) |
335 |
{ |
336 |
OpenFileDialog dia = new OpenFileDialog(); |
337 |
dia.Multiselect = true; |
338 |
dia.Filter = "Xml Files(*.xml)|*.xml"; |
339 |
if (dia.ShowDialog() == DialogResult.OK) |
340 |
{ |
341 |
gridViewDrawingList.CellValueChanged -= new GridViewCellEventHandler(this.gridViewDrawingList_CellValueChanged); |
342 |
foreach (string fileName in dia.FileNames) |
343 |
{ |
344 |
try |
345 |
{ |
346 |
GridViewDataRowInfo row = new GridViewDataRowInfo(gridViewDrawingList.MasterView); |
347 |
Document document = Document.Load(fileName, symbolMapping, attributeMapping); |
348 |
row.Tag = document; |
349 |
|
350 |
if (document == null) |
351 |
{ |
352 |
row.Cells["colDrawingFileName"].Value = fileName; |
353 |
row.Cells["colStatus"].Value = _LoadFail; |
354 |
row.Cells["colDrawingFullName"].Value = fileName; |
355 |
} |
356 |
else |
357 |
{ |
358 |
row.Cells["colCheckBox"].Value = false; |
359 |
row.Cells["colDrawingFileName"].Value = document.DWGNAME; |
360 |
row.Cells["colDrawingNumber"].Value = document.DWGNAME; |
361 |
row.Cells["colDrawingName"].Value = document.DWGNAME; |
362 |
row.Cells["colDrawingFullName"].Value = fileName; |
363 |
} |
364 |
|
365 |
gridViewDrawingList.Rows.Add(row); |
366 |
CheckValidateDrawing(row); |
367 |
} |
368 |
catch (Exception ex) |
369 |
{ |
370 |
|
371 |
} |
372 |
} |
373 |
gridViewDrawingList.CellValueChanged += new GridViewCellEventHandler(this.gridViewDrawingList_CellValueChanged); |
374 |
} |
375 |
} |
376 |
|
377 |
private void btnRun_Click(object sender, EventArgs e) |
378 |
{ |
379 |
try |
380 |
{ |
381 |
ProgressForm.stop = false; |
382 |
foreach (GridViewRowInfo rowInfo in gridViewDrawingList.Rows) |
383 |
{ |
384 |
try |
385 |
{ |
386 |
bool bChecked = (bool)rowInfo.Cells["colCheckBox"].Value; |
387 |
string sStatus = rowInfo.Cells["colStatus"].Value.ToString(); |
388 |
|
389 |
if (bChecked && sStatus == _Ready && !ProgressForm.stop) |
390 |
{ |
391 |
rowInfo.Cells["colStatus"].Value = _Processing; |
392 |
RefreshGridViewDrawingList(); |
393 |
|
394 |
string sUnit = rowInfo.Cells["colUnit"].Value.ToString(); |
395 |
string sTemplate = TemplatePath + @"\" + rowInfo.Cells["colTemplate"].Value.ToString(); |
396 |
string sDrawingNumber = rowInfo.Cells["colDrawingNumber"].Value.ToString(); |
397 |
string sDrawingName = rowInfo.Cells["colDrawingName"].Value.ToString(); |
398 |
|
399 |
// |
400 |
dynamic application = Interaction.GetObject("", "PIDAutomation.Application"); |
401 |
dynamic newDrawing = application.Drawings.Add(sUnit, sTemplate, sDrawingNumber, sDrawingName); |
402 |
application.ActiveWindow.Fit(); |
403 |
Thread.Sleep(100); |
404 |
application.ActiveWindow.Zoom = 2000; |
405 |
Thread.Sleep(100); |
406 |
// |
407 |
|
408 |
Document document = rowInfo.Tag as Document; |
409 |
autoModelingThread = new Thread(Func => |
410 |
{ |
411 |
try |
412 |
{ |
413 |
Thread.Sleep(500); |
414 |
ProgressForm.UpdateDocument(document.DWGNAME); |
415 |
AutoModeling auto = new AutoModeling(document); |
416 |
auto.Run(); |
417 |
ProgressForm.End(); |
418 |
} |
419 |
catch (Exception ex) |
420 |
{ |
421 |
Log.WriteLine(ex); |
422 |
} |
423 |
}); |
424 |
ProgressForm.Start(autoModelingThread); |
425 |
|
426 |
rowInfo.Cells["colStatus"].Value = _EndProcess; |
427 |
RefreshGridViewDrawingList(); |
428 |
application.ActiveWindow.Fit(); |
429 |
Thread.Sleep(100); |
430 |
newDrawing.CloseDrawing(true); |
431 |
Thread.Sleep(100); |
432 |
} |
433 |
} |
434 |
catch (Exception ex) |
435 |
{ |
436 |
rowInfo.Cells["colStatus"].Value = _Error; |
437 |
} |
438 |
} |
439 |
} |
440 |
catch (Exception ex) |
441 |
{ |
442 |
MessageBox.Show(ex.Message); |
443 |
} |
444 |
} |
445 |
|
446 |
private void RefreshGridViewDrawingList() |
447 |
{ |
448 |
if (gridViewDrawingList.InvokeRequired) |
449 |
{ |
450 |
gridViewDrawingList.BeginInvoke(new Action(() => gridViewDrawingList.Refresh())); |
451 |
Thread.Sleep(1); |
452 |
} |
453 |
else |
454 |
{ |
455 |
gridViewDrawingList.Refresh(); |
456 |
} |
457 |
} |
458 |
|
459 |
private void gridViewDrawingList_CellValueChanged(object sender, GridViewCellEventArgs e) |
460 |
{ |
461 |
CheckValidateDrawing(e.Row); |
462 |
} |
463 |
|
464 |
private void CheckValidateDrawing(GridViewRowInfo rowInfo) |
465 |
{ |
466 |
string statusValue = (string)rowInfo.Cells["colStatus"].Value; |
467 |
if (statusValue != _LoadFail && statusValue != _EndProcess && statusValue != _Error && statusValue != _Processing) |
468 |
{ |
469 |
StringBuilder sStatus = new StringBuilder(); |
470 |
// Unit Check |
471 |
if (string.IsNullOrEmpty((string)rowInfo.Cells["colUnit"].Value)) |
472 |
sStatus.AppendLine(_NeedUnit); |
473 |
// Template Check |
474 |
if (string.IsNullOrEmpty((string)rowInfo.Cells["colTemplate"].Value)) |
475 |
sStatus.AppendLine(_NeedTemplate); |
476 |
// ReMapping |
477 |
Document document = rowInfo.Tag as Document; |
478 |
if (!document.ReMapping(new List<string>(), new List<string>())) |
479 |
sStatus.AppendLine(_NeedMapping); |
480 |
|
481 |
// IF READY |
482 |
if (sStatus.Length == 0) |
483 |
sStatus.Append(_Ready); |
484 |
|
485 |
rowInfo.Cells["colStatus"].Value = sStatus.ToString().Trim(); |
486 |
} |
487 |
|
488 |
if ((string)rowInfo.Cells["colStatus"].Value != _Ready) |
489 |
rowInfo.Cells["colCheckBox"].Value = false; |
490 |
} |
491 |
|
492 |
private void gridViewDrawingList_CellClick(object sender, GridViewCellEventArgs e) |
493 |
{ |
494 |
try |
495 |
{ |
496 |
if (e.RowIndex == -1) |
497 |
return; |
498 |
|
499 |
if (e.Column.Name == "colUnit") |
500 |
{ |
501 |
SelectUnitForm form = new SelectUnitForm(dUnit); |
502 |
if (form.ShowDialog() == DialogResult.OK) |
503 |
{ |
504 |
gridViewDrawingList.Rows[e.RowIndex].Cells["colUnit"].Value = form.SelectedUnit; |
505 |
} |
506 |
} |
507 |
} |
508 |
catch (Exception ex) |
509 |
{ |
510 |
|
511 |
} |
512 |
} |
513 |
|
514 |
private void gridViewDrawingList_CellFormatting(object sender, CellFormattingEventArgs e) |
515 |
{ |
516 |
try |
517 |
{ |
518 |
GridCommandCellElement cmdCell = e.CellElement as GridCommandCellElement; |
519 |
if (cmdCell != null) |
520 |
{ |
521 |
cmdCell.CommandButton.TextAlignment = ContentAlignment.MiddleCenter; |
522 |
} |
523 |
} |
524 |
catch (Exception ex) |
525 |
{ |
526 |
|
527 |
} |
528 |
} |
529 |
|
530 |
#endregion |
531 |
|
532 |
#region Mapping Page |
533 |
|
534 |
private void gridViewItemMapping_CellFormatting(object sender, CellFormattingEventArgs e) |
535 |
{ |
536 |
try |
537 |
{ |
538 |
GridCommandCellElement cmdCell = e.CellElement as GridCommandCellElement; |
539 |
if (cmdCell != null) |
540 |
{ |
541 |
cmdCell.CommandButton.TextAlignment = ContentAlignment.MiddleCenter; |
542 |
} |
543 |
} |
544 |
catch (Exception ex) |
545 |
{ |
546 |
|
547 |
} |
548 |
} |
549 |
|
550 |
private void gridViewAttribute_CellFormatting(object sender, CellFormattingEventArgs e) |
551 |
{ |
552 |
try |
553 |
{ |
554 |
GridCommandCellElement cmdCell = e.CellElement as GridCommandCellElement; |
555 |
if (cmdCell != null) |
556 |
{ |
557 |
cmdCell.CommandButton.TextAlignment = ContentAlignment.MiddleCenter; |
558 |
} |
559 |
} |
560 |
catch (Exception ex) |
561 |
{ |
562 |
|
563 |
} |
564 |
} |
565 |
|
566 |
private void btnMappingSave_Click(object sender, EventArgs e) |
567 |
{ |
568 |
symbolMapping.Clear(); |
569 |
foreach (GridViewRowInfo row in gridViewItemMapping.Rows) |
570 |
{ |
571 |
if (row.Cells["colItemName"].Value != null && row.Cells["colSPPIDName"].Value != null) |
572 |
{ |
573 |
string key = row.Cells["colItemName"].Value.ToString(); |
574 |
string value = row.Cells["colSPPIDName"].Value.ToString(); |
575 |
|
576 |
if (!string.IsNullOrEmpty(key) && !string.IsNullOrEmpty(value)) |
577 |
{ |
578 |
if (symbolMapping.ContainsKey(key)) |
579 |
symbolMapping[key] = value; |
580 |
else |
581 |
symbolMapping.Add(key, value); |
582 |
} |
583 |
|
584 |
} |
585 |
} |
586 |
|
587 |
attributeMapping.Clear(); |
588 |
foreach (GridViewRowInfo row in gridViewAttribute.Rows) |
589 |
{ |
590 |
if (row.Cells["colAttribute"].Value != null && row.Cells["colSPPIDAttribute"].Value != null) |
591 |
{ |
592 |
string key = row.Cells["colAttribute"].Value.ToString(); |
593 |
string value = row.Cells["colSPPIDAttribute"].Value.ToString(); |
594 |
|
595 |
if (!string.IsNullOrEmpty(key) && !string.IsNullOrEmpty(value)) |
596 |
{ |
597 |
if (attributeMapping.ContainsKey(key)) |
598 |
attributeMapping[key] = value; |
599 |
else |
600 |
attributeMapping.Add(key, value); |
601 |
} |
602 |
|
603 |
} |
604 |
} |
605 |
|
606 |
SPPIDUtill.SaveMapping(symbolMapping, attributeMapping); |
607 |
|
608 |
foreach (GridViewRowInfo rowInfo in gridViewDrawingList.Rows) |
609 |
CheckValidateDrawing(rowInfo); |
610 |
|
611 |
MessageBox.Show("Save success!", "Information", MessageBoxButtons.OK, MessageBoxIcon.Information); |
612 |
} |
613 |
|
614 |
#endregion |
615 |
|
616 |
private void pageView_SelectedPageChanged(object sender, EventArgs e) |
617 |
{ |
618 |
if (pageView.SelectedPage.Name == "pageItemMapping") |
619 |
{ |
620 |
// Load Item Mapping |
621 |
gridViewItemMapping.BeginUpdate(); |
622 |
gridViewItemMapping.Rows.Clear(); |
623 |
foreach (var item in symbolMapping) |
624 |
gridViewItemMapping.Rows.Add(new object[] { item.Key, item.Value, "View" }); |
625 |
|
626 |
// Load Attribute |
627 |
gridViewAttribute.BeginUpdate(); |
628 |
gridViewAttribute.Rows.Clear(); |
629 |
foreach (var item in attributeMapping) |
630 |
gridViewAttribute.Rows.Add(new object[] { item.Key, item.Value, "View" }); |
631 |
|
632 |
List<string> needSymbolMapping = new List<string>(); |
633 |
List<string> needAttributeMapping = new List<string>(); |
634 |
foreach (GridViewRowInfo rowInfo in gridViewDrawingList.Rows) |
635 |
{ |
636 |
Document document = rowInfo.Tag as Document; |
637 |
if (document != null) |
638 |
document.ReMapping(needSymbolMapping, needAttributeMapping); |
639 |
} |
640 |
|
641 |
needSymbolMapping = needSymbolMapping.Distinct().ToList(); |
642 |
needAttributeMapping = needAttributeMapping.Distinct().ToList(); |
643 |
|
644 |
foreach (string item in needSymbolMapping) |
645 |
gridViewItemMapping.Rows.Add(new object[] { item, "", "View" }); |
646 |
|
647 |
foreach (string item in needAttributeMapping) |
648 |
gridViewAttribute.Rows.Add(new object[] { item, "", "View" }); |
649 |
|
650 |
gridViewItemMapping.BestFitColumns(); |
651 |
gridViewItemMapping.EndUpdate(); |
652 |
|
653 |
gridViewAttribute.BestFitColumns(); |
654 |
gridViewAttribute.EndUpdate(); |
655 |
} |
656 |
} |
657 |
} |
658 |
} |