Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

AdExtensions.cs 2.4KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. namespace Diligent.WebAPI.Business.Extensions
  7. {
  8. [ExcludeFromCodeCoverage]
  9. public static class AdExtensions
  10. {
  11. public static List<Ad> Filter(this List<Ad> query, AdFilterDto filters) =>
  12. query.FilterByExperience(filters.MinExperience, filters.MaxExperience).FilterByWorkType(filters.WorkHour).FilterByEmploymentType(filters.EmploymentType).ToList().FilterByTechnologies(filters.Technologies);
  13. public static List<Ad> FilterByExperience(this List<Ad> query, int minExperience, int maxExperience) =>
  14. minExperience >= maxExperience ? query.Where(x => x.MinimumExperience >= minExperience && x.MinimumExperience <= maxExperience).ToList()
  15. : query.Where(x => x.MinimumExperience >= minExperience && x.MinimumExperience <= maxExperience).ToList();
  16. public static List<Ad> FilterByWorkType(this List<Ad> query, string workHour) =>
  17. workHour.ToLower() == "parttime" ? query.Where(x => x.WorkHour == WorkHours.PartTime).ToList() : query.Where(x => x.WorkHour == WorkHours.FullTime).ToList();
  18. public static List<Ad> FilterByEmploymentType(this List<Ad> query, string employmentType) =>
  19. employmentType.ToLower() == "intership" ? query.Where(x => x.EmploymentType == EmploymentTypes.Intership).ToList() : query.Where(x => x.EmploymentType == EmploymentTypes.Work).ToList();
  20. public static List<Ad> FilterByTechnologies(this List<Ad> query, string[] technologies)
  21. {
  22. if (technologies == null || technologies.Length == 0)
  23. {
  24. return query;
  25. }
  26. List<Ad> filteredAds = new List<Ad>();
  27. for (int i = 0; i < query.Count(); i++)
  28. {
  29. for (int j = 0; j < query[i].Technologies.Count(); j++)
  30. {
  31. var s = 0;
  32. for (int k = 0; k < technologies.Length; k++)
  33. {
  34. if (query[i].Technologies[j].Name.ToLower() == technologies[k].ToLower())
  35. {
  36. s = 1;
  37. }
  38. }
  39. if (s == 1)
  40. {
  41. filteredAds.Add(query[i]);
  42. break;
  43. }
  44. }
  45. }
  46. return filteredAds;
  47. }
  48. }
  49. }