API
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

TemplateRepository.cs 6.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. using Microsoft.EntityFrameworkCore;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using UnivateProperties_API.Containers.Communication;
  6. using UnivateProperties_API.Context;
  7. using UnivateProperties_API.Model;
  8. using UnivateProperties_API.Model.Communication;
  9. using UnivateProperties_API.Model.Users;
  10. namespace UnivateProperties_API.Repository.Communication
  11. {
  12. public class TemplateRepository : IRepository<Template>
  13. {
  14. private readonly DataContext _dbContext;
  15. public TemplateRepository(DataContext dbContext)
  16. {
  17. _dbContext = dbContext;
  18. }
  19. public List<Template> Get(Func<Template, bool> where)
  20. {
  21. return _dbContext.Templates.Where(where).ToList();
  22. }
  23. public List<Template> GetAll()
  24. {
  25. return _dbContext.Templates.ToList();
  26. }
  27. public Template GetDetailed(Func<Template, bool> first)
  28. {
  29. var item = _dbContext.Templates.FirstOrDefault(first);
  30. return item;
  31. }
  32. public List<Template> GetDetailedAll()
  33. {
  34. var list = GetAll();
  35. return list;
  36. }
  37. public void Insert(Template item)
  38. {
  39. item.Id = NewId();
  40. _dbContext.Add(item);
  41. Save();
  42. }
  43. public void Insert(IEnumerable<Template> items)
  44. {
  45. int id = NewId();
  46. foreach (var item in items)
  47. {
  48. item.Id = id;
  49. _dbContext.Add(item);
  50. id += 1;
  51. }
  52. Save();
  53. }
  54. public void Remove(Template item)
  55. {
  56. var i = _dbContext.Templates.Find(item);
  57. _dbContext.Templates.Remove(i);
  58. Save();
  59. }
  60. public void Remove(IEnumerable<Template> items)
  61. {
  62. foreach (var item in items)
  63. {
  64. Template i = _dbContext.Templates.Find(item);
  65. _dbContext.Templates.Remove(i);
  66. }
  67. Save();
  68. }
  69. public void RemoveAtId(int item)
  70. {
  71. var i = _dbContext.Templates.Find(item);
  72. _dbContext.Templates.Remove(i);
  73. Save();
  74. }
  75. public void Update(Template item)
  76. {
  77. var itemList = _dbContext.PlaceHolders.Where(x => x.TemplateId == item.Id).ToList();
  78. CheckListChange(itemList, item.PlaceHolders.ToList());
  79. _dbContext.Entry(item).State = EntityState.Modified;
  80. Save();
  81. }
  82. private void CheckListChange(List<PlaceHolder> holderOld, List<PlaceHolder> holderNew)
  83. {
  84. foreach(var item in holderOld)
  85. {
  86. if(!holderNew.Any(x => x.Id== item.Id))
  87. {
  88. var i = _dbContext.PlaceHolders.FirstOrDefault(x => x.Id == item.Id);
  89. if(item != null)
  90. {
  91. _dbContext.PlaceHolders.Remove(i);
  92. }
  93. }
  94. }
  95. foreach(var item in holderNew.Where(x => x.Id == 0))
  96. {
  97. _dbContext.Add(item);
  98. }
  99. }
  100. public void Save()
  101. {
  102. _dbContext.SaveChanges();
  103. }
  104. public int NewId()
  105. {
  106. int id = 0;
  107. if (_dbContext.Templates.Count() > 0)
  108. {
  109. id = _dbContext.Templates.Max(x => x.Id);
  110. }
  111. id += 1;
  112. return id;
  113. }
  114. public List<TemplateDto> GetSimpleAll()
  115. {
  116. List<TemplateDto> list = new List<TemplateDto>();
  117. foreach(var item in GetAll())
  118. {
  119. list.Add(new TemplateDto()
  120. {
  121. Id = item.Id,
  122. Name = item.Name,
  123. Subject = item.Subject,
  124. Body = item.Body,
  125. PlaceHolders = GetPlaceHolders(item.Id)
  126. });
  127. }
  128. return list;
  129. }
  130. private List<PlaceHolderDto> GetPlaceHolders(int id)
  131. {
  132. List<PlaceHolderDto> list = new List<PlaceHolderDto>();
  133. foreach(var item in _dbContext.PlaceHolders.Where(x => x.TemplateId == id).ToList())
  134. {
  135. list.Add(new PlaceHolderDto()
  136. {
  137. Id = item.Id,
  138. Name = item.Name,
  139. BoundTo = item.BoundTo,
  140. BoundToClass = item.BoundToClass,
  141. BoundToClassDisplay = item.BoundToClassDisplay
  142. });
  143. }
  144. return list;
  145. }
  146. public void SendEmailTemplate(int id)
  147. {
  148. var item = _dbContext.Weeks.FirstOrDefault(x => x.Id == 4);
  149. var indiv = _dbContext.Individuals.FirstOrDefault(x => x.Id == 73);
  150. List<BaseEntity> list = new List<BaseEntity>
  151. {
  152. item,
  153. indiv
  154. };
  155. var template = _dbContext.Templates.FirstOrDefault(x => x.Id == id);
  156. if (template.SenderId == null)
  157. {
  158. var acc = _dbContext.Accounts.FirstOrDefault(x => x.Default);
  159. if (acc != null)
  160. {
  161. template.SenderId = acc.Id;
  162. template.Sender = acc;
  163. }
  164. }
  165. else template.Sender = _dbContext.Accounts.FirstOrDefault(x => x.Id == template.SenderId);
  166. template.PlaceHolders = _dbContext.PlaceHolders.Where(x => x.TemplateId == id).ToList();
  167. if(template != null)
  168. {
  169. Person person = _dbContext.Individuals.FirstOrDefault(x => x.Email == "kobusb@provision-sa.com");
  170. if(person == null)
  171. {
  172. person = _dbContext.Agents.FirstOrDefault(x => x.Email == "kobusb@provision-sa.com");
  173. }
  174. if(person != null)
  175. {
  176. try
  177. {
  178. Email email = new Email(template, person, list);
  179. EmailRepository emailRepo = new EmailRepository(_dbContext);
  180. emailRepo.Insert(email);
  181. }
  182. catch(Exception)
  183. {
  184. }
  185. }
  186. }
  187. }
  188. }
  189. }