Export.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  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 = _config.ProtokollDatei;
  21. }
  22. private const String DebugHeader =
  23. "Konto_Nr_Hersteller;Konto_Bezeichnung;Konto_Nr_Haendler;Konto_Typ;Marke_Haendler;Betrieb_Haendler;Soll;Haben;Summe";
  24. private IMandant MandantRegistrieren()
  25. {
  26. switch (Config.Mandantenname)
  27. {
  28. case Mandanten.Citroen:
  29. return new Citroen();
  30. case Mandanten.Fiat:
  31. return new Fiat();
  32. case Mandanten.Ford:
  33. return new Ford();
  34. case Mandanten.Honda:
  35. return new Honda();
  36. case Mandanten.Opel:
  37. return new Opel();
  38. case Mandanten.Peugeot:
  39. return new Peugeot();
  40. case Mandanten.Volkswagen:
  41. return new Volkswagen();
  42. case Mandanten.Volvo:
  43. return new Volvo();
  44. }
  45. return null;
  46. }
  47. /// <summary>
  48. /// Wartet auf das Eintreffen der manuellen Konten und startet dann den Export von Balance, Accounts und Debug,
  49. /// falls entsprechende Dateiangaben gesetzt sind.
  50. /// </summary>
  51. protected override void AufgabeAusfuehren()
  52. {
  53. ReportProgress(5);
  54. _konten = Data.GetKonten();
  55. if (_mandant.BalanceDatei)
  56. {
  57. var balanceStream = DateiStream(_config.BalanceDatei);
  58. ReportProgress(20);
  59. balanceStream.WriteLine(_mandant.BalanceHeader);
  60. foreach (var kto in _konten.Where(k => (k.Summe != 0.0m)))
  61. {
  62. var zeile = _mandant.BalanceBody(kto);
  63. if (zeile.Length > 0)
  64. {
  65. balanceStream.WriteLine(zeile);
  66. }
  67. }
  68. balanceStream.Write(_mandant.BalanceFooter);
  69. balanceStream.Close();
  70. }
  71. ReportProgress(40);
  72. if (_mandant.AccountsDatei)
  73. {
  74. var accountsStream = DateiStream(_config.AccountsDatei);
  75. ReportProgress(60);
  76. accountsStream.WriteLine(_mandant.AccountsHeader);
  77. foreach (var kto in _konten.Where(k => (k.Summe != 0.0m)))
  78. {
  79. accountsStream.WriteLine(_mandant.AccountsBody(kto));
  80. }
  81. accountsStream.Write(_mandant.AccountsFooter);
  82. accountsStream.Close();
  83. }
  84. if (!_debugExportFile.Equals(""))
  85. {
  86. var debugStream = DateiStream(_debugExportFile);
  87. ReportProgress(80);
  88. var liste = new List<string>();
  89. foreach (var kto in _konten)
  90. {
  91. liste.AddRange(kto.KontoCsv);
  92. }
  93. liste.Sort();
  94. debugStream.WriteLine(DebugHeader);
  95. liste.ForEach(debugStream.WriteLine);
  96. debugStream.Close();
  97. }
  98. var summeSusa = String.Format("{0:c}", _konten.Sum(k => (k.KontoTyp == KontoTypen.SuSa) ? k.Summe : 0.0m));
  99. var summeOhneFaktor = String.Format("{0:c}", _konten.Sum(k => (k.KontoTyp == KontoTypen.SuSa) ? k.Summe : 0.0m));
  100. var summeBilanz = String.Format("{0:c}", _konten.Sum(k => (k.Kontoart == "1") ? k.Summe : 0.0m));
  101. Logger.Progress("Export-Summe über alle SuSa-Konten: " + summeSusa);
  102. Logger.Progress("Export-Summe ohne Faktoren: " + summeOhneFaktor);
  103. Logger.Progress("Export-Summe über alle Bilanz-Konten: " + summeBilanz);
  104. var zero = String.Format("{0:c}", 0);
  105. if (!summeSusa.Equals(zero) && !summeOhneFaktor.Equals(zero))
  106. {
  107. ReportProgress(80, "Der Export war erfolgreich" + Environment.NewLine +
  108. "ACHTUNG SuSa Abweichung im Export!" + Environment.NewLine +
  109. "Export-Summe über alle SuSa-Konten: " + summeSusa);
  110. }
  111. ReportProgress(100);
  112. }
  113. private static StreamWriter DateiStream (string datei)
  114. {
  115. var info = new FileInfo(datei);
  116. if (info.Directory != null) info.Directory.Create();
  117. return new StreamWriter(info.FullName, false, Constants.CsvEncoding);
  118. }
  119. }
  120. }