Export.cs 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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 List<HaendlerKonto> _konten;
  13. private readonly IMandant _mandant;
  14. private readonly string _debugExportFile;
  15. public Export(int id, string name)
  16. : base(id, name)
  17. {
  18. _mandant = MandantRegistrieren();
  19. HaendlerKonto.Mandant = _mandant;
  20. _debugExportFile = Config.AktuellePeriode.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.Renault:
  41. return new Renault();
  42. case Mandanten.Volkswagen:
  43. return new Volkswagen();
  44. case Mandanten.Volvo:
  45. return new Volvo();
  46. }
  47. return null;
  48. }
  49. /// <summary>
  50. /// Wartet auf das Eintreffen der manuellen Konten und startet dann den Export von Balance, Accounts und Debug,
  51. /// falls entsprechende Dateiangaben gesetzt sind.
  52. /// </summary>
  53. protected override void AufgabeAusfuehren()
  54. {
  55. ReportProgress(5);
  56. _konten = Data.GetKonten();
  57. if (_mandant.BalanceDatei)
  58. {
  59. var balanceStream = DateiStream(Config.AktuellePeriode.BalanceDatei);
  60. ReportProgress(20);
  61. balanceStream.WriteLine(_mandant.BalanceHeader);
  62. foreach (var kto in _konten.Where(k => (k.Summe != 0.0m)))
  63. {
  64. var zeile = _mandant.BalanceBody(kto);
  65. if (zeile.Length > 0)
  66. {
  67. balanceStream.WriteLine(zeile);
  68. }
  69. }
  70. balanceStream.Write(_mandant.BalanceFooter);
  71. balanceStream.Close();
  72. }
  73. ReportProgress(40);
  74. if (_mandant.AccountsDatei)
  75. {
  76. var accountsStream = DateiStream(Config.AktuellePeriode.AccountsDatei);
  77. ReportProgress(60);
  78. accountsStream.WriteLine(_mandant.AccountsHeader);
  79. foreach (var kto in _konten.Where(k => (k.Summe != 0.0m)))
  80. {
  81. accountsStream.WriteLine(_mandant.AccountsBody(kto));
  82. }
  83. accountsStream.Write(_mandant.AccountsFooter);
  84. accountsStream.Close();
  85. }
  86. if (!_debugExportFile.Equals(""))
  87. {
  88. var debugStream = DateiStream(_debugExportFile);
  89. ReportProgress(80);
  90. var liste = new List<string>();
  91. foreach (var kto in _konten)
  92. {
  93. liste.AddRange(kto.KontoCsv);
  94. }
  95. liste.Sort();
  96. debugStream.WriteLine(DebugHeader);
  97. liste.ForEach(debugStream.WriteLine);
  98. debugStream.Close();
  99. }
  100. var summeSusa = String.Format("{0:c}", _konten.Sum(k => (k.KontoTyp == KontoTypen.SuSa) ? k.Summe : 0.0m));
  101. var summeOhneFaktor = String.Format("{0:c}", _konten.Sum(k => (k.KontoTyp == KontoTypen.SuSa) ? k.Summe : 0.0m));
  102. var summeBilanz = String.Format("{0:c}", _konten.Sum(k => (k.Kontoart == "1") ? k.Summe : 0.0m));
  103. Logger.Progress("Export-Summe über alle SuSa-Konten: " + summeSusa);
  104. Logger.Progress("Export-Summe ohne Faktoren: " + summeOhneFaktor);
  105. Logger.Progress("Export-Summe über alle Bilanz-Konten: " + summeBilanz);
  106. var zero = String.Format("{0:c}", 0);
  107. if (!summeSusa.Equals(zero) && !summeOhneFaktor.Equals(zero))
  108. {
  109. ReportProgress(80, "Der Export war erfolgreich" + Environment.NewLine +
  110. "ACHTUNG SuSa Abweichung im Export!" + Environment.NewLine +
  111. "Export-Summe über alle SuSa-Konten: " + summeSusa);
  112. }
  113. ReportProgress(100);
  114. }
  115. private static StreamWriter DateiStream (string datei)
  116. {
  117. var info = new FileInfo(datei);
  118. if (info.Directory != null) info.Directory.Create();
  119. return new StreamWriter(info.FullName, false, Constants.CsvEncoding);
  120. }
  121. }
  122. }