| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  | using Back.Common; | 
					
						
							|  |  |  |  | using Back.Data.Contracts; | 
					
						
							|  |  |  |  | using Back.Data.Models; | 
					
						
							|  |  |  |  | using Microsoft.EntityFrameworkCore; | 
					
						
							|  |  |  |  | using Shared.DTOs; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | namespace Back.Services | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     public class servCustomer | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         private readonly IAsyncRepository<Customer> _repoCus; | 
					
						
							| 
									
										
										
										
											2024-06-27 19:18:50 +03:30
										 |  |  |  |         private readonly IAsyncRepository<Invoice> _repoInvoice; | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  |         private readonly CheckPermission _checkPermission; | 
					
						
							| 
									
										
										
										
											2024-06-27 19:18:50 +03:30
										 |  |  |  |         public servCustomer(IAsyncRepository<Customer> repoCus, CheckPermission checkPermission, IAsyncRepository<Invoice> repoInvoice) | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  |         { | 
					
						
							|  |  |  |  |            _repoCus = repoCus; | 
					
						
							|  |  |  |  |             _checkPermission = checkPermission; | 
					
						
							| 
									
										
										
										
											2024-06-27 19:18:50 +03:30
										 |  |  |  |             _repoInvoice = repoInvoice; | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  |         } | 
					
						
							|  |  |  |  |         public async Task<PagingDto<RCustomer>?> GetCustomers(int CompanyID, ItemSerchGetCustomer itemSerch) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             #region AdvancedSearch | 
					
						
							|  |  |  |  |             var invok = _repoCus | 
					
						
							|  |  |  |  |                 .Get(w => w.CompanyID == CompanyID && !w.IsDeleted); | 
					
						
							|  |  |  |  |             //foreach (InputObj item in inputObjs) | 
					
						
							|  |  |  |  |             //    invok = invok.Where(ExMethod.GetFunc<Customer>(item.Param, item.Value)); | 
					
						
							|  |  |  |  |             if (!string.IsNullOrEmpty(itemSerch.ZipCode)) | 
					
						
							|  |  |  |  |                 invok = invok.Where(w=>w.ZipCode.Contains(itemSerch.ZipCode)); | 
					
						
							|  |  |  |  |              | 
					
						
							|  |  |  |  |             if (!string.IsNullOrEmpty(itemSerch.Phone)) | 
					
						
							|  |  |  |  |                 invok = invok.Where(w => w.Phone.Contains(itemSerch.Phone)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-07 13:55:11 +03:30
										 |  |  |  |             | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |             if (itemSerch.CustomerType.HasValue) | 
					
						
							|  |  |  |  |                 invok = invok.Where(w => w.CustomerType==itemSerch.CustomerType); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             if (itemSerch.ID.HasValue) | 
					
						
							|  |  |  |  |                 invok = invok.Where(w => w.ID == itemSerch.ID); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             if (!string.IsNullOrEmpty(itemSerch.EconomicCode)) | 
					
						
							| 
									
										
										
										
											2024-05-07 13:55:11 +03:30
										 |  |  |  |                 invok = invok.Where(w => w.EconomicCode.Contains(itemSerch.EconomicCode) || w.MeliCode.Contains(itemSerch.EconomicCode)); | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  |             #endregion | 
					
						
							|  |  |  |  |             //----------------------- | 
					
						
							|  |  |  |  |             return await invok.Select(s=>new RCustomer() | 
					
						
							|  |  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2024-05-06 17:13:12 +03:30
										 |  |  |  |                  | 
					
						
							|  |  |  |  |                 Address = s.Address, | 
					
						
							|  |  |  |  |                 CustomerTypeTitle = s.CustomerType.GetEnumDisplayName(), | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  |                     EconomicCode = s.EconomicCode, | 
					
						
							| 
									
										
										
										
											2024-05-06 17:13:12 +03:30
										 |  |  |  |                 Email = s.Email, | 
					
						
							|  |  |  |  |                 FullName = s.FullName, | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  |                     ID = s.ID, | 
					
						
							| 
									
										
										
										
											2024-05-06 17:13:12 +03:30
										 |  |  |  |                 Info = s.Info, | 
					
						
							|  |  |  |  |                 Phone =s.Phone, | 
					
						
							|  |  |  |  |                 BranchID = s.BranchID, | 
					
						
							|  |  |  |  |                 MeliCode = s.MeliCode, | 
					
						
							|  |  |  |  |                 ZipCode = s.ZipCode, | 
					
						
							|  |  |  |  |                 PassportNumber = s.PassportNumber, | 
					
						
							|  |  |  |  |                 CustomerType= s.CustomerType | 
					
						
							|  |  |  |  |                 //  CompanyID=s.CompanyID | 
					
						
							| 
									
										
										
										
											2024-05-08 17:25:02 +03:30
										 |  |  |  |             }).OrderByDescending(o=>o.ID) | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  |                 .Paging(itemSerch.PageIndex, itemSerch.PageSize);  | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-05-14 14:58:25 +03:30
										 |  |  |  |         public async Task<List<ForCustomerSearch>?> GetCustomers(int CompanyID) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var invok = _repoCus | 
					
						
							|  |  |  |  |                 .Get(w => w.CompanyID == CompanyID && !w.IsDeleted); | 
					
						
							|  |  |  |  |             | 
					
						
							|  |  |  |  |             //----------------------- | 
					
						
							|  |  |  |  |             return await invok.Select(s => new ForCustomerSearch() | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 CustomerName=s.FullName, | 
					
						
							|  |  |  |  |                 ID = s.ID | 
					
						
							|  |  |  |  |                 | 
					
						
							|  |  |  |  |             }).OrderByDescending(o => o.ID) | 
					
						
							|  |  |  |  |                 .ToListAsync(); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-05-08 17:25:02 +03:30
										 |  |  |  |         public async Task<Customer?> GetCustomerByCustomerID(int CustomerID, int CompanyID) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             return await _repoCus | 
					
						
							|  |  |  |  |                 .Get(w => w.ID == CustomerID && w.CompanyID == CompanyID && !w.IsDeleted).FirstOrDefaultAsync(); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  |         //public async Task<Customer> GetCustomerByCustomerID(int CustomerID) | 
					
						
							|  |  |  |  |         //{ | 
					
						
							|  |  |  |  |         //    return await _repositores.GET<Customer>() | 
					
						
							|  |  |  |  |         //        .Where(w => w.ID == CustomerID && !w.IsDeleted).FirstOrDefaultAsync(); | 
					
						
							|  |  |  |  |         //} | 
					
						
							| 
									
										
										
										
											2024-05-08 17:25:02 +03:30
										 |  |  |  |         public async Task<bool> ExistCustomerByCustomerID(int CustomerID, int CompanyID) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             return await _repoCus | 
					
						
							|  |  |  |  |                 .Get(w => w.ID == CustomerID && w.CompanyID == CompanyID && !w.IsDeleted).AnyAsync(); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  |         //public async Task<CUCustomer> GetCustomerByCustomerIDByDTO(int CustomerID) | 
					
						
							|  |  |  |  |         //{ | 
					
						
							|  |  |  |  |         //    return await _repositores.GET<Customer>() | 
					
						
							|  |  |  |  |         //        .Where(w => w.ID == CustomerID && !w.IsDeleted) | 
					
						
							|  |  |  |  |         //        .Select(s => new CUCustomer() | 
					
						
							|  |  |  |  |         //        { | 
					
						
							|  |  |  |  |         //            Address = s.Address, | 
					
						
							|  |  |  |  |         //            CustomerType = s.CustomerType, | 
					
						
							|  |  |  |  |         //            EconomicCode = s.EconomicCode, | 
					
						
							|  |  |  |  |         //            Email = s.Email, | 
					
						
							|  |  |  |  |         //            FullName = s.FullName, | 
					
						
							|  |  |  |  |         //            ID = s.ID, | 
					
						
							|  |  |  |  |         //            Info = s.Info, | 
					
						
							|  |  |  |  |         //            Phone = s.Phone, | 
					
						
							|  |  |  |  |         //            BranchID = s.BranchID, | 
					
						
							|  |  |  |  |         //            MeliCode = s.MeliCode, | 
					
						
							|  |  |  |  |         //            ZipCode = s.ZipCode, | 
					
						
							|  |  |  |  |         //            PassportNumber = s.PassportNumber, | 
					
						
							|  |  |  |  |         //            //CompanyID = s.CompanyID | 
					
						
							|  |  |  |  |         //        }) | 
					
						
							|  |  |  |  |         //        .FirstOrDefaultAsync(); | 
					
						
							|  |  |  |  |         //} | 
					
						
							| 
									
										
										
										
											2024-05-08 17:25:02 +03:30
										 |  |  |  |         public async Task<bool> AddOrUpdateCustomer(Customer item) | 
					
						
							| 
									
										
										
										
											2024-05-07 17:49:02 +03:30
										 |  |  |  |         { | 
					
						
							|  |  |  |  |             try | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 //SysLog log = new SysLog() | 
					
						
							|  |  |  |  |                 //{ | 
					
						
							|  |  |  |  |                 //    TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier, | 
					
						
							|  |  |  |  |                 //    Datetime = DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                 //    Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/AddORUpdateCustomer", | 
					
						
							|  |  |  |  |                 //    Value = "*" + JsonConvert.SerializeObject(item), | 
					
						
							|  |  |  |  |                 //    Route = _httpContextAccessor.HttpContext.Request.Path, | 
					
						
							|  |  |  |  |                 //    Type = "User" | 
					
						
							|  |  |  |  |                 //}; | 
					
						
							|  |  |  |  |                 //_contextMongodb.InsertItem(log); | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-08 17:25:02 +03:30
										 |  |  |  |                 if (item.ID == null || item.ID <= 0) | 
					
						
							| 
									
										
										
										
											2024-05-07 17:49:02 +03:30
										 |  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |                     if(await _checkPermission.ExtensionofAccess(item.CompanyID, 5, "-1")) | 
					
						
							|  |  |  |  |                   return await _repoCus.AddBoolResultAsync(item); | 
					
						
							|  |  |  |  |                     | 
					
						
							|  |  |  |  |                     return false; | 
					
						
							| 
									
										
										
										
											2024-05-07 17:49:02 +03:30
										 |  |  |  |                 } | 
					
						
							|  |  |  |  |                 else | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     return await _repoCus.UpdateAsync(item); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             catch (Exception ex) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 //SysLog log = new SysLog() | 
					
						
							|  |  |  |  |                 //{ | 
					
						
							|  |  |  |  |                 //    TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier, | 
					
						
							|  |  |  |  |                 //    Datetime = DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                 //    Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/AddORUpdateCustomer", | 
					
						
							|  |  |  |  |                 //    Value = ex.Message, | 
					
						
							|  |  |  |  |                 //    Route = _httpContextAccessor.HttpContext.Request.Path, | 
					
						
							|  |  |  |  |                 //    Type = "catch" | 
					
						
							|  |  |  |  |                 //}; | 
					
						
							|  |  |  |  |                 //_contextMongodb.InsertItem(log); | 
					
						
							|  |  |  |  |                 return false; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-05-08 17:25:02 +03:30
										 |  |  |  |         public async Task<bool> DeleteCustomer(Customer item) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-08 17:25:02 +03:30
										 |  |  |  |             try | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 item.IsDeleted = true; | 
					
						
							|  |  |  |  |               return await _repoCus.UpdateAsync(item); | 
					
						
							|  |  |  |  |                 //SysLog log = new SysLog() | 
					
						
							|  |  |  |  |                 //{ | 
					
						
							|  |  |  |  |                 //    TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier, | 
					
						
							|  |  |  |  |                 //    Datetime = DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                 //    Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/DeleteCustomer", | 
					
						
							|  |  |  |  |                 //    Value = JsonConvert.SerializeObject(item.ID), | 
					
						
							|  |  |  |  |                 //    Route = _httpContextAccessor.HttpContext.Request.Path, | 
					
						
							|  |  |  |  |                 //    Type = "User" | 
					
						
							|  |  |  |  |                 //}; | 
					
						
							|  |  |  |  |                 //_contextMongodb.InsertItem(log); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             catch (Exception ex) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 //SysLog log = new SysLog() | 
					
						
							|  |  |  |  |                 //{ | 
					
						
							|  |  |  |  |                 //    TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier, | 
					
						
							|  |  |  |  |                 //    Datetime = DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                 //    Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/DeleteCustomer", | 
					
						
							|  |  |  |  |                 //    Value = ex.Message, | 
					
						
							|  |  |  |  |                 //    Route = _httpContextAccessor.HttpContext.Request.Path, | 
					
						
							|  |  |  |  |                 //    Type = "catch" | 
					
						
							|  |  |  |  |                 //}; | 
					
						
							|  |  |  |  |                 //_contextMongodb.InsertItem(log); | 
					
						
							|  |  |  |  |                 return false; | 
					
						
							| 
									
										
										
										
											2024-05-07 17:49:02 +03:30
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-08 17:25:02 +03:30
										 |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-06-27 19:18:50 +03:30
										 |  |  |  |         public async Task<bool> UsedInTheInvoice(int cusID) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             return await _repoInvoice.Get(w => w.CustomerID == cusID).AnyAsync(); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-05-07 17:49:02 +03:30
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-05 18:15:37 +03:30
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } |