| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463 | using System.Collections;using System.Collections.Generic;using System.IO;using InABox.Core;using NPOI.SS.UserModel;namespace PRSDesktop{    public class ExcelImporter<T> : BaseImporter<T> where T : Entity, IRemotable, IPersistent, new()    {        private readonly Dictionary<string, int> _columns = new();        private IEnumerator _row;        private ISheet _sheet = null;        private IWorkbook _workbook;        private DataFormatter formatter = new();        public override bool Open(Stream stream)        {            var xls = WorkbookFactory.Create(stream);            var sheet = xls.GetSheetAt(0);            _row = sheet.GetRowEnumerator();            _row.MoveNext();            return true;        }        public override void Close()        {            if (_workbook != null)                _workbook.Close();            _workbook = null;        }        public override bool ReadHeader()        {            _columns.Clear();            var fields = new List<string>();            for (var i = 1; i < HeaderRow; i++)                if (!MoveNext())                    return false;            IEnumerator cells = ((IRow)_row.Current).GetEnumerator();            while (cells.MoveNext())            {                var cell = (ICell)cells.Current;                var value = cell.ToString();                if (!string.IsNullOrWhiteSpace(value))                {                    fields.Add(value);                    _columns[value] = cell.ColumnIndex;                }                Fields = fields.ToArray();            }            return true;        }        public override bool MoveNext()        {            return _row.MoveNext();        }        public override Dictionary<string, string> ReadLine()        {            var results = new Dictionary<string, string>();            var row = _row.Current as IRow;            foreach (var field in Fields)            {                if (!string.IsNullOrWhiteSpace(field) && _columns.ContainsKey(field))                {                    var cell = row.GetCell(_columns[field]);                    var value = "";                    if (cell != null)                    {                        var type = cell.CellType == CellType.Formula ? cell.CachedFormulaResultType : cell.CellType;                        if (type == CellType.Boolean)                        {                            value = cell.BooleanCellValue.ToString();                        }                        else if (type == CellType.Numeric)                        {                            if (DateUtil.IsCellDateFormatted(cell))                                value = cell.DateCellValue.ToString();                            else                                value = cell.NumericCellValue.ToString();                        }                        else if (type == CellType.String)                        {                            value = cell.StringCellValue;                        }                        else                        {                            value = cell.ToString();                        }                    }                    results[field] = value;                }            }            return results;        }    }}/*//css_ref NPOI.dll//css_ref NPOI.OOXML.dll//css_ref NPOI.OpenXml4Net.dllusing PRSDesktop;using Comal.Classes;using PRSDesktop.Utils;using InABox.Clients;using InABox.Configuration;using InABox.Core;using Syncfusion.UI.Xaml.Kanban;using Syncfusion.Windows.Controls.Grid;using System.Collections.Generic;using System.Collections.ObjectModel;using System.Runtime;using System.Diagnostics;using System.Linq;using System.Windows;using System.Windows.Controls;using System.Windows.Media;using System.Collections;using PRSDesktop.Forms.Export;using System.IO;using Ookii.Dialogs.Wpf;using NPOI.SS.UserModel;using System;using System.Reflection;using System.Linq.Expressions;using InABox.Reports;public class Module{public Object Data { get; set; }private int GetColumn(IRow row, String name){    IEnumerator cells = row.GetEnumerator();    while (cells.MoveNext())    {        ICell cell = (ICell)cells.Current;        if ((!String.IsNullOrWhiteSpace(cell.StringCellValue)) && (cell.StringCellValue.ToUpper().Trim().Equals(name.ToUpper().Trim())))            return cell.ColumnIndex;    }    throw new Exception("Unable to find Column: " + name);}public String GetCellValue(ICell cell){    if (cell.CellType == NPOI.SS.UserModel.CellType.Formula)    {        if (cell.CachedFormulaResultType == NPOI.SS.UserModel.CellType.Numeric)            return String.Format("{0:F}", cell.NumericCellValue.ToString());        else            return cell.StringCellValue;    }    return cell.ToString().Trim();}public void Set<T>(T item, Expression<Func<T>> property, object value, ref bool changed){    var member = (MemberExpression)property.Body;    string propertyName = member.Member.Name;    object val = CoreUtils.GetPropertyValue(item,propertyName);    if ( ((val == null) && (value != null)) || (!val.Equals(value)) )    {        CoreUtils.SetPropertyValue(item,propertyName,value);        changed = true;       }    }public void SetUserProperty<T>(T item, String userprop, object value, ref bool changed) where T : Entity{    var userprops = item.UserProperties;    object val = userprops.ContainsKey(userprop) ? userprops[userprop] : null;            if ( ((val == null) && (value != null)) || (!val.Equals(value)) )    {        userprops[userprop] = value;        changed = true;       }    }public bool Execute(){    VistaOpenFileDialog dlg = new VistaOpenFileDialog();    dlg.Filter = "Excel Files|*.xls; *.xlsx";    if (dlg.ShowDialog() != true)        return false;            Progress.Show("Starting Up");                Progress.SetMessage("Loading UOM Codes");    List<ProductUOM> uoms = new Client<ProductUOM>().Load().ToList();    Progress.SetMessage("Loading Groups");    List<ProductGroup> groups = new Client<ProductGroup>().Load().ToList();    Progress.SetMessage("Loading Products");    List<Product> products = new Client<Product>().Load().ToList();        Progress.SetMessage("Loading Suppliers");    List<Supplier> suppliers = new Client<Supplier>().Load().ToList();        Progress.SetMessage("Loading Supplier Products");    List<SupplierProduct> supplierproducts = new Client<SupplierProduct>().Load().ToList();        List<Guid> labels = new List<Guid>();        Progress.SetMessage("Opening " + Path.GetFileName(dlg.FileName));                List<String> Log = new List<string>();    Log.Add(String.Format("Import Log {0:dd/MM/yyyy hh:mm:ss}",DateTime.Now));    Log.Add("==============================");    try    {                               using (FileStream file = new FileStream(dlg.FileName, FileMode.Open, FileAccess.Read))        {            IWorkbook xls = WorkbookFactory.Create(file);            ISheet sheet = xls.GetSheet("Sheet1");            IEnumerator rows = sheet.GetRowEnumerator();            rows.MoveNext();                        IRow headerrow = (IRow)rows.Current;                        int ProductCodeColumn = GetColumn(headerrow,"Item Number");            int ProductNameColumn = GetColumn(headerrow,"Item Description");            int GroupColumn = GetColumn(headerrow, "Item Type");            int UOMColumn = GetColumn(headerrow, "Base UOM");            int SupplierColumn = GetColumn(headerrow, "Dflt Vendor");            int CostColumn = GetColumn(headerrow, "Cost");                                  List<String> Messages = new List<String>();            int Row = 1;            while ((rows.MoveNext()) && (Row <= 1)) //int.MaxValue))            {                Progress.SetMessage("Processing Row "+Row.ToString());                Messages.Clear();                Row++;                IRow row = (IRow)rows.Current;                               try                {                                                        Messages.Add("Getting Product Code");                                        String productcode = row.GetCell(ProductCodeColumn, MissingCellPolicy.CREATE_NULL_AS_BLANK).StringCellValue.Trim();                    if (!String.IsNullOrWhiteSpace(productcode))                    {                        String productname = row.GetCell(ProductNameColumn, MissingCellPolicy.CREATE_NULL_AS_BLANK).StringCellValue.Trim();                                                                Messages.Add("Getting UOM");                        String uomcode = row.GetCell(UOMColumn, MissingCellPolicy.CREATE_NULL_AS_BLANK).StringCellValue.Trim();                        ProductUOM uom = null;                        if (!String.IsNullOrWhiteSpace(uomcode))                        {                            Messages.Add("UOM = ["+uomcode+"]");                            if (uoms == null)                                Messages.Add("UOM list is null");                            uom = uoms.FirstOrDefault(x=>x.Code.Equals(uomcode.ToUpper()));                            if (uom == null)                            {                                Messages.Add("Adding UOM");                                uom = new ProductUOM()                                {                                    Code = uomcode.ToUpper(),                                    Description = uomcode                                };                                                            new Client<ProductUOM>().Save(uom,"Imported from CCS");                                uoms.Add(uom);                            }                        }                        else                            uom = new ProductUOM();                                                double UnitSize = 1.0;                                                    // If its an extrusion (ie uom = "L"), then strip out the length from the end of the code (if any)                        if (String.Equals(uomcode,"L") && productcode.Contains(" "))                        {                           String[] comps = productcode.Split(' ');                           productcode = String.Join(" ",comps.Reverse().Take(1).Reverse());                           String size = new string(comps.Last().Where(c => char.IsDigit(c) || char.Equals(c,'.')).ToArray());                           UnitSize = String.IsNullOrEmpty(size) ? 1.0 : double.Parse(size);                        }                                                //What to do with the Unit Size Here?                         // Pro-Rata the cost?                         // Try to identify default length (compare to PRS)?                        // At this stage, we will just use it as the default unit size if a new product is to be created                                                                                                  Messages.Add("Getting Group");                        String groupcode = row.GetCell(GroupColumn, MissingCellPolicy.CREATE_NULL_AS_BLANK).StringCellValue.Trim();                        ProductGroup group = null;                        if (!String.IsNullOrWhiteSpace(groupcode))                        {                            group = groups.FirstOrDefault(x=>x.Code.Equals(groupcode.ToUpper()));                            if (group == null)                            {                                Messages.Add("Adding Group");                                group = new ProductGroup()                                {                                    Code = groupcode.ToUpper(),                                    Description = groupcode                                };                                                            new Client<ProductGroup>().Save(group,"Imported from CCS");                                groups.Add(group);                            }                        }                        else                            group = new ProductGroup();                                                                                                                   Messages.Add("Locating Product");                        Product product = products.FirstOrDefault(x=>x.Code.Equals(productcode.ToUpper()));                        bool labelrequired = false;                        if (product == null)                        {                            Messages.Add("Adding Product");                            product = new Product()                            {                                Code = productcode.ToUpper()                            };                                                        product.UnitSize = UnitSize;                            products.Add(product);                            labelrequired = true;                        }                        product.Group.ID = group.ID;                        product.Units.ID = uom.ID;                        product.Name = productname;                        if (product.IsChanged())                            new Client<Product>().Save(product,"Imported from CCS");                         if (labelrequired)                            labels.Add(product.ID);                                                Messages.Add("Getting Supplier");                        String suppliercode = row.GetCell(SupplierColumn, MissingCellPolicy.CREATE_NULL_AS_BLANK).StringCellValue.Trim();                        Supplier supplier = suppliers.FirstOrDefault(x=>x.Code.Equals(suppliercode.ToUpper()));                        if (supplier == null)                        {                            Messages.Add("Adding Supplier");                            supplier = new Supplier()                            {                                Code = suppliercode.ToUpper(),                                Name = suppliercode                            };                            new Client<Supplier>().Save(supplier,"Imported from CCS");                            suppliers.Add(supplier);                        }                                                Messages.Add("Getting Supplier Cost");                        double suppliercost = row.GetCell(CostColumn, MissingCellPolicy.CREATE_NULL_AS_BLANK).NumericCellValue;                        SupplierProduct supprod = supplierproducts.FirstOrDefault(x=>x.ProductLink.ID.Equals(product.ID) && x.SupplierLink.ID.Equals(supplier.ID));                        if (supprod == null)                        {                            Messages.Add("Adding Supplier Product");                            supprod= new SupplierProduct();                            supprod.SupplierLink.ID = supplier.ID;                            supprod.ProductLink.ID = product.ID;                            supprod.TradePrice = suppliercost;                            supprod.Discount = 0.0F;                            supprod.CostPrice = suppliercost;                            supplierproducts.Add(supprod);                        }                        if (supprod.Discount != 100.0F)                            supprod.TradePrice = supprod.CostPrice * 100.0F / (100.0F / suppliercost);                        else                        {                            supprod.TradePrice = supprod.CostPrice;                            supprod.CostPrice = 0.0F;                        }                           if (supprod.IsChanged())                                                       new Client<SupplierProduct>().Save(supprod,"Imported from CCS");                        product.Supplier.ID = supprod.ID;                        product.ListPrice = supprod.TradePrice;                        product.Discount = supprod.Discount;                        product.NettPrice = supprod.CostPrice;                        if (product.IsChanged())                            new Client<Product>().Save(product,"Updated Default Supplier Cost");                                                    Messages.Add("Done");                    }                }                catch (Exception ei)                {                    Messages.Add(String.Format("Row [{0}]: Exception: {1}", row.RowNum + 1, ei.Message));                }                                Log.AddRange(Messages);            }        }        Progress.Close();                if (labels.Any())        {            ProductDataModel model = new ProductDataModel(new Filter<Product>(x=>x.ID).InList(labels.ToArray()));            ReportTemplate template = new Client<ReportTemplate>().Load(new Filter<ReportTemplate>(x=>x.Section).IsEqualTo(model.Name).And(x=>x.Name).IsEqualTo("Product Barcode")).FirstOrDefault();            if (template == null)            {                template = new ReportTemplate()                {                    Section = model.Name,                    Name = "Product Barcode",                    Visible = true,                    SelectedRecords = true,                    AllRecords = false                };                new Client<ReportTemplate>().Save(template,"Autogenerated by CCS Import");            }                            ReportUtils.PreviewReport(template,model,!Security.IsAllowed<CanDesignReports>() && !String.IsNullOrWhiteSpace(template.PrinterName), Security.IsAllowed<CanDesignReports>());        }                        MessageBox.Show("Import Completed!");    }    catch (Exception e)    {        Log.Add(e.Message);                Progress.Close();        MessageBox.Show("Error while Importing File!\n\n" + e.Message);    }        Log.Add("");    String LogFile = Path.ChangeExtension(dlg.FileName, ".txt");    if (File.Exists(LogFile))        Log.AddRange(File.ReadAllLines(LogFile));    File.WriteAllLines(LogFile, Log.ToArray());        Process.Start(LogFile);    return true;}}*/
 |