aboutsummaryrefslogtreecommitdiff
path: root/src/Controllers/MergeTool.cs
diff options
context:
space:
mode:
authorSergey Chebotar <s.chebotar@gmail.com>2022-12-20 12:27:47 +0300
committerSergey Chebotar <s.chebotar@gmail.com>2022-12-20 12:27:47 +0300
commit73569a43644309d0342817580bcfd86c1face5b8 (patch)
treef3c6e15db82130b02ec8c3fa1b64674e6a9cf48d /src/Controllers/MergeTool.cs
parent3d186c22e8665b80839495fdcf4b176c2f3e03b9 (diff)
Namespace refactoring
Diffstat (limited to 'src/Controllers/MergeTool.cs')
-rw-r--r--src/Controllers/MergeTool.cs46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/Controllers/MergeTool.cs b/src/Controllers/MergeTool.cs
new file mode 100644
index 0000000..dec8ff7
--- /dev/null
+++ b/src/Controllers/MergeTool.cs
@@ -0,0 +1,46 @@
+using RhSolutions.Models;
+using System;
+using System.Collections.Generic;
+using System.Linq;
+
+namespace RhSolutions.Controllers
+{
+ internal class MergeTool : ToolBase
+ {
+ private List<SourcePriceList> SourceFiles { get; set; }
+
+ public MergeTool()
+ {
+ string[] files = Dialog.GetMultiplyFiles();
+
+ if (files != null)
+ {
+ SourceFiles = SourcePriceList.GetSourceLists(files);
+ }
+
+ else
+ {
+ throw new Exception("Не выбраны файлы");
+ }
+ }
+
+ public override void FillTarget()
+ {
+ using (ProgressBar = new ProgressBar("Заполняю строки...", SourceFiles.Sum(x => x.PositionAmount.Count)))
+ using (ResultBar = new ResultBar())
+ {
+ foreach (SourcePriceList source in SourceFiles)
+ {
+ foreach (var kvp in source.PositionAmount)
+ {
+ FillPositionAmountToColumns(kvp, TargetFile.AmountCell.Column);
+ ProgressBar.Update();
+ }
+ }
+
+ FilterByAmount();
+ ResultBar.Update();
+ }
+ }
+ }
+}