ActionEduFactory.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. using CD67.FicheCollege.Entity;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Data.Entity;
  7. namespace CD67.FicheCollege.Factory
  8. {
  9. public partial class ActionEduFactory : Internal.BaseFactory<Entity.ActionEdu>
  10. {
  11. public override IQueryable<Entity.ActionEdu> getAll()
  12. {
  13. return base.getAll("Ordre");
  14. }
  15. public void Up(ref Entity.ActionEdu item)
  16. {
  17. int ordre = item.Ordre;
  18. //Cas de sortie immédiate
  19. if (item.Ordre == 1) return;
  20. Entity.ActionEdu itemToSubstitute = dbContext.ActionsEdu.Where(i => i.Ordre == ordre - 1).First();
  21. itemToSubstitute.Ordre += 1;
  22. item.Ordre -= 1;
  23. dbContext.SaveChanges();
  24. }
  25. public void Down(ref Entity.ActionEdu item)
  26. {
  27. int ordre = item.Ordre;
  28. //Cas de sortie immédiate
  29. if (item.Ordre == dbContext.ActionsEdu.Max(i => i.Ordre)) return;
  30. Entity.ActionEdu itemToSubstitute = dbContext.ActionsEdu.Where(i => i.Ordre == ordre + 1).First();
  31. itemToSubstitute.Ordre -= 1;
  32. item.Ordre += 1;
  33. dbContext.SaveChanges();
  34. }
  35. private void Sort()
  36. {
  37. int ordre = 1;
  38. foreach (Entity.ActionEdu statut in dbContext.ActionsEdu.OrderBy(i => i.Ordre))
  39. {
  40. statut.Ordre = ordre++;
  41. }
  42. dbContext.SaveChanges();
  43. }
  44. public override void add(ref Entity.ActionEdu entity)
  45. {
  46. //Initialisation de l'ordre
  47. if (dbContext.ActionsEdu.Count() == 0) entity.Ordre = 1;
  48. else entity.Ordre = dbContext.ActionsEdu.Max(i => i.Ordre) + 1;
  49. base.add(ref entity);
  50. }
  51. public override void delete(ref Entity.ActionEdu entity)
  52. {
  53. base.delete(ref entity);
  54. Sort();
  55. }
  56. public ActionEdu clone_to_year(ActionEdu actionEdu, int annee_id)
  57. {
  58. if (base.getAll().Where(a => a.AnneeId == annee_id && a.TokenId == actionEdu.TokenId).Count() > 0)
  59. {
  60. throw new InvalidOperationException("Cette action éducative existe déjà pour l'année cible");
  61. }
  62. ActionEdu clone = new ActionEdu();
  63. // Nouvelle année
  64. clone.AnneeId = annee_id;
  65. // On reprend les valeurs de tous les autres champs
  66. clone.Numero = actionEdu.Numero;
  67. clone.Nom = actionEdu.Nom;
  68. clone.Montant = actionEdu.Montant;
  69. clone.Description = actionEdu.Description;
  70. clone.CommentaireInterne = actionEdu.CommentaireInterne;
  71. clone.CommentairePublic = actionEdu.CommentairePublic;
  72. clone.Neutralise = actionEdu.Neutralise;
  73. clone.Ordre = actionEdu.Ordre;
  74. clone.StatutId = actionEdu.StatutId;
  75. clone.ActionEduThematiqueId = actionEdu.ActionEduThematiqueId;
  76. clone.TokenId = actionEdu.TokenId;
  77. // Recréé les affectations
  78. foreach (ActionEduCollege actionEduCollege in actionEdu.ActionsEduColleges)
  79. {
  80. ActionEduCollege cloneActionEduCollege = new ActionEduCollege();
  81. cloneActionEduCollege.Commentaire = actionEduCollege.Commentaire;
  82. cloneActionEduCollege.NbEleves = actionEduCollege.NbEleves;
  83. try
  84. {
  85. cloneActionEduCollege.College = dbContext.Colleges.Where(c => c.TokenId == actionEduCollege.College.TokenId && c.Annee_Id == annee_id).First();
  86. }
  87. catch(InvalidOperationException) {
  88. throw new InvalidOperationException("Un ou plusieurs collegesaffectés à cette action n'ont pas été créés pour l'année en cours");
  89. }
  90. clone.ActionsEduColleges.Add(cloneActionEduCollege);
  91. }
  92. // enregistre le clone en base
  93. base.add(ref clone);
  94. return clone;
  95. }
  96. }
  97. }