[1454207] | 1 | using FarmatikoData.FarmatikoRepoInterfaces;
|
---|
| 2 | using FarmatikoData.Models;
|
---|
[6f203af] | 3 | using Microsoft.EntityFrameworkCore;
|
---|
[1454207] | 4 | using System.Collections.Generic;
|
---|
| 5 | using System.Linq;
|
---|
| 6 | using System.Threading.Tasks;
|
---|
| 7 |
|
---|
| 8 | namespace FarmatikoData.FarmatikoRepo
|
---|
| 9 | {
|
---|
| 10 | public class PHRepo : IPHRepo
|
---|
| 11 | {
|
---|
| 12 | private readonly FarmatikoDataContext _context;
|
---|
| 13 | public PHRepo(FarmatikoDataContext context)
|
---|
| 14 | {
|
---|
| 15 | _context = context;
|
---|
| 16 | }
|
---|
[6f203af] | 17 | //GET
|
---|
| 18 | public async Task<PharmacyHead> GetPharmacyHeadByIdAsync(int id)
|
---|
[1454207] | 19 | {
|
---|
[6f203af] | 20 | var Phead = await _context.PharmacyHeads.Where(x => x.Id == id).FirstOrDefaultAsync();
|
---|
[1454207] | 21 | return Phead;
|
---|
| 22 | }
|
---|
| 23 |
|
---|
[6f203af] | 24 | public async Task<IEnumerable<PharmacyHead>> GetPharmacyHeadInfo()
|
---|
[1454207] | 25 | {
|
---|
[6f203af] | 26 | var PHeadInfo = await _context.PharmacyHeads.Take(10).Where(x => x.DeletedOn == null)
|
---|
| 27 | .Select(x => new PharmacyHead
|
---|
| 28 | {
|
---|
| 29 | Id = x.Id,
|
---|
| 30 | Name = x.Name,
|
---|
| 31 | Email = x.Email,
|
---|
| 32 | Password = x.Password,
|
---|
[1db5673] | 33 | MedicineList = x.MedicineList,
|
---|
[6f203af] | 34 | PharmaciesList = x.PharmaciesList
|
---|
| 35 | }).ToListAsync();
|
---|
[1454207] | 36 | return PHeadInfo;
|
---|
| 37 | }
|
---|
[6f203af] | 38 | //POST
|
---|
[1454207] | 39 | public async Task UpdatePharmacyHead(PharmacyHead pharmacyHead)
|
---|
| 40 | {
|
---|
[1db5673] | 41 | var Phead = await _context.PharmacyHeads.Where(x => x.Email == pharmacyHead.Email).FirstOrDefaultAsync();
|
---|
| 42 | var EditedPHead = await _context.PharmacyHeads.AsNoTracking<PharmacyHead>().Where(x => x.Email == pharmacyHead.Email).FirstOrDefaultAsync();
|
---|
[1454207] | 43 | EditedPHead.Email = pharmacyHead.Email;
|
---|
| 44 | EditedPHead.Name = pharmacyHead.Name;
|
---|
| 45 | EditedPHead.Password = pharmacyHead.Password;
|
---|
[1db5673] | 46 | /*if (pharmacyHead.MedicineList.Count() == 0)
|
---|
| 47 | pharmacyHead.MedicineList = null;*/
|
---|
| 48 | EditedPHead.MedicineList = pharmacyHead.MedicineList;
|
---|
[1454207] | 49 | EditedPHead.PharmaciesList = pharmacyHead.PharmaciesList;
|
---|
[1db5673] | 50 | EditedPHead.PHMedicineList = pharmacyHead.PHMedicineList;
|
---|
| 51 | //_context.Entry<PharmacyHead>(Phead).State = EntityState.Detached;
|
---|
| 52 | Phead = EditedPHead;
|
---|
[1454207] | 53 | await _context.SaveChangesAsync();
|
---|
| 54 | }
|
---|
[6f203af] | 55 | public async Task ClaimPharmacy(RequestPharmacyHead pharmacy)
|
---|
| 56 | {
|
---|
| 57 | await _context.PHRequests.AddAsync(pharmacy);
|
---|
| 58 | await _context.SaveChangesAsync();
|
---|
| 59 | }
|
---|
| 60 | public async Task Add(PharmacyHead pharmacyHead)
|
---|
| 61 | {
|
---|
| 62 | await _context.PharmacyHeads.AddAsync(pharmacyHead);
|
---|
| 63 | await _context.SaveChangesAsync();
|
---|
| 64 | }
|
---|
| 65 |
|
---|
| 66 | public async Task Remove(PharmacyHead phead)
|
---|
| 67 | {
|
---|
| 68 | var Phead = await _context.PharmacyHeads.Where(x => x.Id == phead.Id).FirstOrDefaultAsync();
|
---|
| 69 | Phead.DeletedOn = phead.DeletedOn;
|
---|
| 70 | await _context.SaveChangesAsync();
|
---|
| 71 | }
|
---|
| 72 |
|
---|
| 73 | public async Task RemoveClaimingRequest(int id)
|
---|
| 74 | {
|
---|
| 75 | var req = await _context.PHRequests.Where(r => r.Id == id).FirstOrDefaultAsync();
|
---|
| 76 | _context.PHRequests.Remove(req);
|
---|
| 77 | await _context.SaveChangesAsync();
|
---|
| 78 | }
|
---|
[d23bf72] | 79 |
|
---|
[1db5673] | 80 |
|
---|
[d23bf72] | 81 | public PharmacyHead GetPharmacyHeadByUserName(string userName)
|
---|
| 82 | {
|
---|
[1db5673] | 83 | var PHead = _context.PharmacyHeads
|
---|
[d23bf72] | 84 | .Where(x => x.Email.Equals(userName))
|
---|
| 85 | .FirstOrDefault();
|
---|
[1db5673] | 86 |
|
---|
| 87 | return PHead;
|
---|
| 88 | }
|
---|
| 89 |
|
---|
| 90 | public List<PharmacyHeadMedicine> GetPharmacyHeadMedicines(string email)
|
---|
| 91 | {
|
---|
| 92 | /*var meds = _context.Medicines.ToList();
|
---|
| 93 | var medicines = Medicines;*/
|
---|
| 94 | var Phead = _context.PharmacyHeads.Where(x => x.Email.Equals(email)).FirstOrDefault();
|
---|
| 95 | var Medicines = _context.PharmacyHeadMedicines.Where(x => x.PheadId == Phead.Id).ToList();
|
---|
| 96 | /*.Select(x => x.Head.MedicineList)
|
---|
| 97 | .SelectMany(mList => mList)
|
---|
| 98 | .ToList();*/
|
---|
| 99 |
|
---|
| 100 |
|
---|
| 101 | return Medicines;
|
---|
| 102 | }
|
---|
| 103 |
|
---|
| 104 | public IEnumerable<PharmacyHead> GetPharmacyHeads()
|
---|
| 105 | {
|
---|
| 106 | var heads = _context.PharmacyHeads.ToList();
|
---|
| 107 | return heads;
|
---|
| 108 | }
|
---|
| 109 |
|
---|
| 110 | public PharmacyHead GetPharmacyHead(string head)
|
---|
| 111 | {
|
---|
| 112 | var phead = _context.PharmacyHeads.Where(x => x.Email.Equals(head)).FirstOrDefault();
|
---|
| 113 | return phead;
|
---|
| 114 | }
|
---|
| 115 |
|
---|
| 116 | public List<Pharmacy> GetPharmacies()
|
---|
| 117 | {
|
---|
| 118 | var pharms = _context.Pharmacies.ToList();
|
---|
| 119 | return pharms;
|
---|
[d23bf72] | 120 | }
|
---|
[68454c6] | 121 |
|
---|
| 122 | public void DeletePHMedicine(int id, int phId, int medId)
|
---|
| 123 | {
|
---|
| 124 | var PH = _context.PharmacyHeadMedicines.Where(x => x.PheadId == phId).Single();
|
---|
| 125 | var PHMed = _context.PharmacyHeadMedicines.Where(x => x.MedicineId == medId).Single();
|
---|
| 126 | var PHID = _context.PharmacyHeadMedicines.Where(x => x.Id == id).Single();
|
---|
| 127 | _context.PharmacyHeadMedicines.Remove(PHID);
|
---|
| 128 | _context.SaveChanges();
|
---|
| 129 | }
|
---|
[1454207] | 130 | }
|
---|
| 131 | }
|
---|