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.

CampaignRepository.cs 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. using Microsoft.EntityFrameworkCore;
  2. using Newtonsoft.Json;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Threading.Tasks;
  7. using UnivateProperties_API.Containers.Campaigns;
  8. using UnivateProperties_API.Context;
  9. using UnivateProperties_API.Helpers;
  10. using UnivateProperties_API.Model.Campaigns;
  11. namespace UnivateProperties_API.Repository.Campaigns
  12. {
  13. public interface ICampaignRepository : IRepository<Campaign>
  14. {
  15. CampaignDTO GetDTO(Func<Campaign, bool> where);
  16. int InsertFromDTO(CampaignDTO campaign);
  17. string GetCampaignHTML(int CampaignId);
  18. List<CampaignItem> GetCampaignItems(int CampaignId);
  19. List<CampaignPlaceHolder> GetCampaignPlaceHolders(int CampaignId);
  20. }
  21. public class CampaignRepository : ICampaignRepository
  22. {
  23. private readonly DataContext _dbContext;
  24. public CampaignRepository(DataContext dbContext)
  25. {
  26. _dbContext = dbContext;
  27. }
  28. public List<Campaign> Get(Func<Campaign, bool> where)
  29. {
  30. return _dbContext.Campaigns.Where(where).ToList();
  31. }
  32. public List<Campaign> GetAll()
  33. {
  34. return _dbContext.Campaigns.OrderByDescending(c => c.Created).ToList();
  35. }
  36. public string GetCampaignHTML(int CampaignId)
  37. {
  38. var campaign = _dbContext.Campaigns.Where(c => c.Id == CampaignId).Include("PlaceHolders").Include("Items").FirstOrDefault();
  39. string html = "";
  40. string tableItems = "<table align=center>";
  41. int rows;
  42. if (campaign.ItemsPerRow == 0)
  43. campaign.ItemsPerRow = 1;
  44. if (campaign.Items.Count % campaign.ItemsPerRow == 0)
  45. {
  46. rows = campaign.Items.Count / campaign.ItemsPerRow;
  47. }
  48. else
  49. {
  50. int remainder = campaign.Items.Count % campaign.ItemsPerRow;
  51. int evenItems = campaign.Items.Count - remainder;
  52. rows = evenItems / campaign.ItemsPerRow;
  53. rows += remainder;
  54. }
  55. int itemCounter = 0;
  56. for (int r = 0; r < rows; r++)
  57. {
  58. tableItems += "<tr>";
  59. for(int c = 0; c < campaign.ItemsPerRow; c++)
  60. {
  61. itemCounter++;
  62. if (itemCounter > campaign.Items.Count)
  63. tableItems += "<td></td>";
  64. else
  65. tableItems += string.Format("<td>[ITEM{0}]</td>", itemCounter);
  66. }
  67. tableItems += "</tr>";
  68. }
  69. tableItems += "</table>";
  70. if(campaign != null)
  71. {
  72. var url = _dbContext.Defaults.Where(d => d.Id == "URL").FirstOrDefault();
  73. html = campaign.Body;
  74. string temp = campaign.ItemBody;
  75. itemCounter = 0;
  76. foreach (var item in campaign.Items)
  77. {
  78. itemCounter++;
  79. var week = _dbContext.Weeks.Where(w => w.Id == item.WeekId).FirstOrDefault();
  80. string curItem = temp;
  81. foreach(var place in campaign.PlaceHolders)
  82. {
  83. var value = week[place.BoundTo];
  84. if (!string.IsNullOrEmpty(place.Format))
  85. {
  86. string format = place.Format;
  87. if (format.Contains("|"))
  88. {
  89. string special = format.Substring(format.IndexOf('|'), format.Length - format.IndexOf('|')).Replace("|", "");
  90. format = format.Substring(0, format.IndexOf('|'));
  91. if (special == "DaySuffix")
  92. {
  93. if (DateTime.TryParse(value.ToString(), out DateTime dateValue))
  94. {
  95. string suffix = MyCommon.DateSuffixed(dateValue);
  96. string[] formatParts = format.Split(" ");
  97. string replaceValue = "";
  98. foreach(var s in formatParts)
  99. {
  100. string tempFormat = "{0:" + s + "}";
  101. replaceValue += string.Format(tempFormat, dateValue);
  102. if (s.ToLower().Contains("d"))
  103. replaceValue += "<sup>" + suffix + "</sup> ";
  104. else
  105. replaceValue += " ";
  106. }
  107. curItem = curItem.Replace(place.Name.ToString(), replaceValue.Trim());
  108. }
  109. else
  110. {
  111. curItem = curItem.Replace(place.Name.ToString(), "ERROR-Date format on non date field");
  112. }
  113. }
  114. }
  115. else
  116. curItem = curItem.Replace(place.Name.ToString(), string.Format("{0:" + format + "}", value));
  117. }
  118. else
  119. curItem = curItem.Replace(place.Name.ToString(), value.ToString());
  120. }
  121. var cutsomPlaceHolders = _dbContext.CampaignItemPlaceHolders.Where(c => c.CampaignItemId == item.Id).ToList();
  122. foreach (var custom in cutsomPlaceHolders)
  123. {
  124. curItem = curItem.Replace(custom.PlaceHolder, custom.Value);
  125. }
  126. curItem = curItem.Replace("[image]", item.Image);
  127. curItem = curItem.Replace("[link]", string.Format("{0}resort/{1}/{2}", url?.Value ?? "http://localhost:8080/#/", item.Week.ResortCode, item.Week.UnitNumber));
  128. tableItems = tableItems.Replace(string.Format("[ITEM{0}]", itemCounter), curItem);
  129. }
  130. html = html.Replace("[items]", tableItems);
  131. }
  132. return html;
  133. }
  134. public List<CampaignItem> GetCampaignItems(int CampaignId)
  135. {
  136. return _dbContext.CampaignItems.Where(c => c.CampaignId == CampaignId).ToList();
  137. }
  138. public List<CampaignPlaceHolder> GetCampaignPlaceHolders(int CampaignId)
  139. {
  140. return _dbContext.CampaignPlaceHolders.Where(c => c.CampaignId == CampaignId).ToList();
  141. }
  142. public Campaign GetDetailed(Func<Campaign, bool> first)
  143. {
  144. var item = _dbContext.Campaigns.FirstOrDefault(first);
  145. if (item == null)
  146. {
  147. item = new Campaign
  148. {
  149. Items = new List<CampaignItem>(),
  150. PlaceHolders = new List<CampaignPlaceHolder>()
  151. };
  152. }
  153. else
  154. {
  155. item.Items = (from i in _dbContext.CampaignItems
  156. where i.CampaignId == item.Id
  157. select new CampaignItem() { Id = i.Id, CampaignId = i.CampaignId, Image = i.Image, WeekId = i.WeekId, Week = i.Week, CampaignItemPlaceHolder = new List<CampaignItemPlaceHolder>()}).ToList();
  158. item.PlaceHolders = (from i in _dbContext.CampaignPlaceHolders
  159. where i.CampaignId == item.Id
  160. select new CampaignPlaceHolder(){Id = i.Id, CampaignId = i.CampaignId, Name = i.Name, BoundTo = i.BoundTo, BoundToClass = i.BoundToClass, BoundToClassDisplay = i.BoundToClassDisplay }).ToList();
  161. foreach(var week in item.Items)
  162. {
  163. var placeholders = (from p in _dbContext.CampaignItemPlaceHolders
  164. where p.CampaignItemId == week.Id
  165. select new CampaignItemPlaceHolder() { Id = p.Id, PlaceHolder = p.PlaceHolder, Value = p.Value, CampaignItemId = p.CampaignItemId }).ToList();
  166. week.CampaignItemPlaceHolder = placeholders;
  167. }
  168. }
  169. var sItem = JsonConvert.SerializeObject(item, Formatting.None);
  170. return item;
  171. }
  172. public List<Campaign> GetDetailedAll()
  173. {
  174. return GetAll();
  175. }
  176. public CampaignDTO GetDTO(Func<Campaign, bool> where)
  177. {
  178. var item = _dbContext.Campaigns.Include("Items").Include("PlaceHolders").Where(where).FirstOrDefault();
  179. var dto = new CampaignDTO
  180. {
  181. PlaceHolders = new List<CampaignPlaceholderDTO>(),
  182. Weeks = new List<CampaignWeeksDTO>(),
  183. WeekPlaceHolders = new List<CampaignWeeksPlaceHolderDTO>()
  184. };
  185. if (item != null)
  186. {
  187. dto.Name = item.Name;
  188. dto.StartDate = item.StartDate;
  189. dto.EndDate = item.EndDate;
  190. dto.Subject = item.Subject;
  191. dto.Body = item.Body;
  192. dto.ItemBody = item.ItemBody;
  193. foreach (var p in item.PlaceHolders)
  194. {
  195. dto.PlaceHolders.Add(new CampaignPlaceholderDTO()
  196. {
  197. Name = p.Name,
  198. BoundTo = p.BoundTo,
  199. BoundToClass = p.BoundToClass,
  200. BoundToClassDisplay = p.BoundToClassDisplay
  201. });
  202. }
  203. foreach (var i in item.Items)
  204. {
  205. dto.Weeks.Add(new CampaignWeeksDTO()
  206. {
  207. Image = i.Image,
  208. WeekId = i.WeekId
  209. });
  210. }
  211. }
  212. return dto;
  213. }
  214. public void Insert(Campaign item)
  215. {
  216. if (item.PlaceHolders.Count > 0)
  217. {
  218. foreach (var ph in item.PlaceHolders)
  219. {
  220. ph.CampaignId = item.Id;
  221. }
  222. }
  223. if (item.Items.Count > 0)
  224. {
  225. foreach (var i in item.Items)
  226. {
  227. i.CampaignId = item.Id;
  228. }
  229. }
  230. _dbContext.Add(item);
  231. Save();
  232. }
  233. public void Insert(IEnumerable<Campaign> items)
  234. {
  235. foreach (var item in items)
  236. {
  237. _dbContext.Add(item);
  238. }
  239. Save();
  240. }
  241. public int InsertFromDTO(CampaignDTO campaign)
  242. {
  243. var cam = new Campaign
  244. {
  245. Name = campaign.Name,
  246. StartDate = campaign.StartDate,
  247. EndDate = campaign.EndDate,
  248. Subject = campaign.Subject,
  249. Body = campaign.Body,
  250. ItemBody = campaign.ItemBody,
  251. ItemsPerRow = campaign.ItemsPerRow
  252. };
  253. if (campaign.PlaceHolders.Count > 0)
  254. {
  255. cam.PlaceHolders = new List<CampaignPlaceHolder>();
  256. foreach (var place in campaign.PlaceHolders)
  257. {
  258. cam.PlaceHolders.Add(new CampaignPlaceHolder()
  259. {
  260. CampaignId = cam.Id,
  261. Name = place.Name,
  262. BoundTo = place.BoundTo,
  263. BoundToClass = place.BoundToClass,
  264. BoundToClassDisplay = place.BoundToClassDisplay
  265. });
  266. }
  267. }
  268. if (campaign.Weeks.Count > 0)
  269. {
  270. cam.Items = new List<CampaignItem>();
  271. foreach (var week in campaign.Weeks)
  272. {
  273. cam.Items.Add(new CampaignItem()
  274. {
  275. CampaignId = cam.Id,
  276. WeekId = week.WeekId,
  277. Image = week.Image
  278. });
  279. }
  280. }
  281. if (campaign.WeekPlaceHolders.Count > 0)
  282. {
  283. foreach (var wph in campaign.WeekPlaceHolders)
  284. {
  285. var week = cam.Items.Where(w => w.WeekId == wph.WeekId).FirstOrDefault();
  286. if (week.CampaignItemPlaceHolder == null)
  287. week.CampaignItemPlaceHolder = new List<CampaignItemPlaceHolder>();
  288. CampaignItemPlaceHolder campaignItemPlaceHolder = new CampaignItemPlaceHolder
  289. {
  290. CampaignItemId = week.Id,
  291. PlaceHolder = wph.Name,
  292. Value = wph.Value
  293. };
  294. week.CampaignItemPlaceHolder.Add(campaignItemPlaceHolder);
  295. }
  296. }
  297. _dbContext.Add(cam);
  298. Save();
  299. return cam.Id;
  300. }
  301. public int NewId()
  302. {
  303. throw new NotImplementedException();
  304. }
  305. public void Remove(Campaign item)
  306. {
  307. var i = _dbContext.Campaigns.Find(item);
  308. _dbContext.Campaigns.Remove(i);
  309. Save();
  310. }
  311. public void Remove(IEnumerable<Campaign> items)
  312. {
  313. foreach (var item in items)
  314. {
  315. var i = _dbContext.Campaigns.Find(item);
  316. _dbContext.Campaigns.Remove(i);
  317. }
  318. Save();
  319. }
  320. public void RemoveAtId(int item)
  321. {
  322. var i = _dbContext.Campaigns.Where(c => c.Id == item).FirstOrDefault();
  323. if (i != null)
  324. {
  325. _dbContext.Campaigns.Remove(i);
  326. }
  327. Save();
  328. }
  329. public void Save()
  330. {
  331. _dbContext.SaveChanges();
  332. }
  333. public void Update(Campaign item)
  334. {
  335. _dbContext.Entry(item).State = EntityState.Modified;
  336. Save();
  337. }
  338. }
  339. }