Export.cs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. using System;
  2. using System.Collections.Generic;
  3. using System.IO;
  4. using System.Linq;
  5. using GCHR.Mandantenschnittstelle;
  6. using GCHR.Model;
  7. using GCHR.Model.Konto;
  8. namespace GCHR.Control.Tasks
  9. {
  10. sealed class Export : Task
  11. {
  12. private readonly Konfiguration _config = Konfiguration.GetInstance();
  13. private List<HaendlerKonto> _konten;
  14. private readonly IMandant _mandant;
  15. private readonly string _debugExportFile;
  16. public Export(int id, string name)
  17. : base(id, name)
  18. {
  19. _mandant = MandantRegistrieren();
  20. _debugExportFile = (Data.Exportprotokoll) ? "export\\exportprotokoll.csv" : "";
  21. }
  22. private const String DebugHeader = "KontoExport;Kontonummer;Description;KontoTyp;Ebene1;DepartmentImport;Marke;Betrieb;Case;Soll;Haben;SollSumme;HabenSumme;Gesamt;" +
  23. "KontoExportHaendler;KontonummerHaendler;DescriptionHaendler;KontoTypHaendler;Ebene1Haendler;DepartmentImportHaendler;MarkeHaendler;BetriebHaendler;CaseHaendler;SollHaendler;HabenHaendler;SollSummeHaendler;HabenSummeHaendler;GesamtHaendler;" +
  24. "Periode;PeriodeSoll;PeriodeHaben";
  25. private IMandant MandantRegistrieren()
  26. {
  27. switch (Config.Mandantenname)
  28. {
  29. case Mandanten.Citroen:
  30. return new Citroen();
  31. case Mandanten.Fiat:
  32. return new Fiat();
  33. case Mandanten.Ford:
  34. return new Ford();
  35. case Mandanten.Honda:
  36. return new Honda();
  37. case Mandanten.Opel:
  38. return new Opel();
  39. case Mandanten.Peugeot:
  40. return new Peugeot();
  41. case Mandanten.Volkswagen:
  42. return new Volkswagen();
  43. }
  44. return null;
  45. }
  46. /// <summary>
  47. /// Wartet auf das Eintreffen der manuellen Konten und startet dann den Export von Balance, Accounts und Debug,
  48. /// falls entsprechende Dateiangaben gesetzt sind.
  49. /// </summary>
  50. protected override void AufgabeAusfuehren()
  51. {
  52. ReportProgress(5);
  53. _konten = Data.GetKonten();
  54. if (_mandant.BalanceDatei)
  55. {
  56. var balanceStream = DateiStream(_config.BalanceDatei);
  57. ReportProgress(20);
  58. balanceStream.WriteLine(_mandant.BalanceHeader);
  59. foreach (var kto in _konten.Where(k => (k.Summe != 0.0m)))
  60. {
  61. var zeile = _mandant.BalanceBody(kto);
  62. if (zeile.Length > 0)
  63. {
  64. balanceStream.WriteLine(zeile);
  65. }
  66. }
  67. balanceStream.Write(_mandant.BalanceFooter);
  68. balanceStream.Close();
  69. }
  70. ReportProgress(40);
  71. if (_mandant.AccountsDatei)
  72. {
  73. var accountsStream = DateiStream(_config.AccountsDatei);
  74. ReportProgress(60);
  75. accountsStream.WriteLine(_mandant.AccountsHeader);
  76. foreach (var kto in _konten.Where(k => (k.Summe != 0.0m)))
  77. {
  78. accountsStream.WriteLine(_mandant.AccountsBody(kto));
  79. }
  80. accountsStream.Write(_mandant.AccountsFooter);
  81. accountsStream.Close();
  82. }
  83. if (!_debugExportFile.Equals(""))
  84. {
  85. var debugStream = DateiStream(_debugExportFile);
  86. ReportProgress(80);
  87. var liste = new List<string>();
  88. foreach (var kto in _konten)
  89. {
  90. liste.AddRange(kto.KontoCsv);
  91. }
  92. liste.Sort();
  93. debugStream.WriteLine(DebugHeader);
  94. liste.ForEach(debugStream.WriteLine);
  95. debugStream.Close();
  96. }
  97. var summeSusa = String.Format("{0:c}", _konten.Sum(k => (k.KontoTyp == KontoTypen.SuSa) ? k.Summe : 0.0m));
  98. var summeOhneFaktor = String.Format("{0:c}", _konten.Sum(k => (k.KontoTyp == KontoTypen.SuSa) ? k.Summe : 0.0m));
  99. var summeBilanz = String.Format("{0:c}", _konten.Sum(k => (k.Case == "B") ? k.Summe : 0.0m));
  100. Logger.Progress("Export-Summe über alle SuSa-Konten: " + summeSusa);
  101. Logger.Progress("Export-Summe ohne Faktoren: " + summeOhneFaktor);
  102. Logger.Progress("Export-Summe über alle Bilanz-Konten: " + summeBilanz);
  103. var zero = String.Format("{0:c}", 0);
  104. if (!summeSusa.Equals(zero) && !summeOhneFaktor.Equals(zero))
  105. {
  106. ReportProgress(80, "Der Export war erfolgreich" + Environment.NewLine +
  107. "ACHTUNG SuSa Abweichung im Export!" + Environment.NewLine +
  108. "Export-Summe über alle SuSa-Konten: " + summeSusa);
  109. }
  110. ReportProgress(100);
  111. }
  112. private static StreamWriter DateiStream (string datei)
  113. {
  114. var info = new FileInfo(datei);
  115. info.Directory.Create();
  116. return new StreamWriter(info.FullName, false, Constants.CsvEncoding);
  117. }
  118. }
  119. }