aboutsummaryrefslogtreecommitdiff
path: root/Source/PriceListTools/MergeTool.cs
diff options
context:
space:
mode:
authorSergey Chebotar <s.chebotar@gmail.com>2021-12-24 16:22:03 +0300
committerSergey Chebotar <s.chebotar@gmail.com>2021-12-24 16:22:03 +0300
commit24024b5729c1c44bb01cb29813868743d1753e31 (patch)
tree673a1c1102e04adee36be8ded4934d2e40794fef /Source/PriceListTools/MergeTool.cs
parent2a4076d6eef1b4556f6af8cb074638d440927c5e (diff)
MergeTool, MemoryUtil anf stuff
Diffstat (limited to 'Source/PriceListTools/MergeTool.cs')
-rw-r--r--Source/PriceListTools/MergeTool.cs55
1 files changed, 55 insertions, 0 deletions
diff --git a/Source/PriceListTools/MergeTool.cs b/Source/PriceListTools/MergeTool.cs
new file mode 100644
index 0000000..21da41d
--- /dev/null
+++ b/Source/PriceListTools/MergeTool.cs
@@ -0,0 +1,55 @@
+using ExcelDna.Integration;
+using Microsoft.Office.Interop.Excel;
+using System;
+using System.Collections.Generic;
+
+namespace RehauSku.PriceListTools
+{
+ class MergeTool : IDisposable
+ {
+ private Application ExcelApp;
+ private Dictionary<string, double> SkuAmount { get; set; }
+
+ public MergeTool()
+ {
+ this.ExcelApp = (Application)ExcelDnaUtil.Application;
+ this.SkuAmount = new Dictionary<string, double>();
+ }
+
+ public void AddSkuAmountToDict(string[] files)
+ {
+ ExcelApp.ScreenUpdating = false;
+ foreach (string file in files)
+ {
+ Workbook wb = ExcelApp.Workbooks.Open(file);
+ PriceList priceList = new PriceList(wb);
+
+ if (priceList.IsValid())
+ SkuAmount.AddValues(priceList);
+
+ wb.Close();
+ }
+ ExcelApp.ScreenUpdating = true;
+ }
+
+ public void ExportToNewFile(string exportFile)
+ {
+ Workbook wb = ExcelApp.Workbooks.Open(exportFile);
+ PriceList priceList = new PriceList(wb);
+
+ if (priceList.IsValid())
+ priceList.Fill(SkuAmount);
+ }
+
+ public void Dispose()
+ {
+ Dispose(true);
+ GC.SuppressFinalize(this);
+ }
+
+ protected virtual void Dispose(bool disposing)
+ {
+
+ }
+ }
+}