Exemplo n.º 1
0
        static public void Run(Action <int, int> progress)
        {
            Log.Main.Inform("STARTED");
            progress(0, 0);
            if (string.IsNullOrWhiteSpace(Settings.General.InputFolder))
            {
                Win.LogMessage.Error("Input Folder is not specified.");
                return;
            }
            if (!Directory.Exists(Settings.General.InputFolder))
            {
                Win.LogMessage.Error("Input folder '" + Settings.General.InputFolder + "' does not exist.");
                return;
            }

            string output_records_file = FileSystemRoutines.CreateDirectory(Settings.General.OutputFolder) + "\\_output.csv";

            if (File.Exists(output_records_file))
            {
                File.Delete(output_records_file);
            }
            TextWriter tw = new StreamWriter(output_records_file, false);

            List <Template2> active_templates = Settings.Template2s.Template2s.Where(x => x.Active).OrderBy(x => x.OrderWeight).ThenByDescending(x =>
            {
                return(Settings.TemplateLocalInfo.GetInfo(x.Template.Name).UsedTime);
            }).ToList();

            if (active_templates.Count < 1)
            {
                Win.LogMessage.Error("There is no active template!");
                return;
            }

            List <string> headers = new List <string> {
                "File", "Template", "First Page", "Last Page", "Invoice", "Total", "Product Name", "Product Cost"
            };

            tw.WriteLine(FieldPreparation.GetCsvHeaderLine(headers, FieldPreparation.FieldSeparator.COMMA));

            List <string> files = FileSystemRoutines.GetFiles(Settings.General.InputFolder, false);

            files.Remove(output_records_file);
            files = files.Select(f => new FileInfo(f)).Where(fi => !fi.Attributes.HasFlag(FileAttributes.Hidden)).Select(fi => fi.FullName).ToList();

            int           processed_files = 0;
            int           total_files     = files.Count;
            List <string> failed_files    = new List <string>();

            progress(processed_files, total_files);
            foreach (string f in files)
            {
                try
                {
                    bool?result = PdfProcessor.Process(f, active_templates, (templateName, firstPageI, lastPageI, document) =>
                    {
                        {
                            List <string> values = new List <string>()
                            {
                                PathRoutines.GetFileName(f), templateName, firstPageI.ToString(), lastPageI.ToString(), document.Invoice, document.Total, "", ""
                            };
                            tw.WriteLine(FieldPreparation.GetCsvLine(values, FieldPreparation.FieldSeparator.COMMA));
                        }
                        foreach (PdfProcessor.Document.Product p in document.Products)
                        {
                            List <string> values = new List <string>()
                            {
                                "", "", "", "", "", "", p.Name, p.Cost
                            };
                            tw.WriteLine(FieldPreparation.GetCsvLine(values, FieldPreparation.FieldSeparator.COMMA));
                        }
                    });

                    if (result != true)
                    {
                        failed_files.Add(f);
                    }
                }
                catch (Exception e)
                {
                    Log.Main.Error("Processing file '" + f + "'", e);
                    failed_files.Add(f);
                }
                progress(++processed_files, total_files);
            }
            tw.Close();

            try
            {
                System.Diagnostics.Process.Start(output_records_file);
            }
            catch { }

            Log.Main.Inform("COMPLETED:\r\nTotal files: " + processed_files + "\r\nSuccess files: " + (processed_files - failed_files.Count) + "\r\nFailed files: " + failed_files.Count + "\r\n" + string.Join("\r\n", failed_files));
            if (failed_files.Count > 0)
            {
                Message.Error("There were " + failed_files.Count + " failed files.\r\nSee details in the log.");
            }
            //progress(0, 0);
        }