| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  | using Back.Data.Contracts; | 
					
						
							|  |  |  |  | using Back.Data.Models; | 
					
						
							|  |  |  |  | using Shared.DTOs.Serch; | 
					
						
							|  |  |  |  | using Shared.DTOs; | 
					
						
							|  |  |  |  | using Back.Common; | 
					
						
							|  |  |  |  | using Microsoft.EntityFrameworkCore; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | namespace Back.Services | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     public class servInvoice | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         private readonly IAsyncRepository<Invoice> _invoiceRepo; | 
					
						
							| 
									
										
										
										
											2024-05-13 16:50:26 +03:30
										 |  |  |  |         private readonly IAsyncRepository<InvoiceStatusChang> _invoiceStatusChangPaymentRepo; | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |         private readonly CheckPermission _checkPermission; | 
					
						
							| 
									
										
										
										
											2024-05-13 16:52:57 +03:30
										 |  |  |  |         public servInvoice(IAsyncRepository<Invoice> invoiceRepo, CheckPermission checkPermission | 
					
						
							| 
									
										
										
										
											2024-05-14 14:58:25 +03:30
										 |  |  |  |                           , IAsyncRepository<InvoiceStatusChang> invoiceStatusChangPaymentRepo) | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-05-14 14:58:25 +03:30
										 |  |  |  |             _invoiceStatusChangPaymentRepo = invoiceStatusChangPaymentRepo; | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |             _invoiceRepo = invoiceRepo; | 
					
						
							|  |  |  |  |             _checkPermission = checkPermission; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-05-17 23:05:46 +03:30
										 |  |  |  |         public async Task<InvoiceDTO> GetInvoice(int CompanyID, int ID) | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |         { | 
					
						
							|  |  |  |  |             #region AdvancedSearch | 
					
						
							|  |  |  |  |             var invok = _invoiceRepo | 
					
						
							| 
									
										
										
										
											2024-05-28 15:03:08 +03:30
										 |  |  |  |                 .Get(w => w.CompanyID == CompanyID && !w.IsDeleted && w.ID == ID); | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             #endregion | 
					
						
							|  |  |  |  |             //----------------------- | 
					
						
							|  |  |  |  |             return await invok | 
					
						
							|  |  |  |  |                 .Include(inc => inc.invoiceDetails) | 
					
						
							| 
									
										
										
										
											2024-05-28 15:03:08 +03:30
										 |  |  |  |                   .ThenInclude(inc => inc.cODItem) | 
					
						
							|  |  |  |  |                                        .ThenInclude(inc => inc.CODUnit) | 
					
						
							|  |  |  |  |                 //.Include(inc => inc.payments) | 
					
						
							|  |  |  |  |                 //.Include(inc => inc.pattern) | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |                 .Select(s => new InvoiceDTO() | 
					
						
							|  |  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2024-05-28 15:03:08 +03:30
										 |  |  |  |                      | 
					
						
							| 
									
										
										
										
											2024-05-14 14:58:25 +03:30
										 |  |  |  |                     PatternID = s.PatternID, | 
					
						
							|  |  |  |  |                     PatternTitle = s.pattern.Title, | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |                     CustomerID = s.CustomerID, | 
					
						
							|  |  |  |  |                     CustomerName = s.Customer.FullName, | 
					
						
							|  |  |  |  |                     ID = s.ID, | 
					
						
							|  |  |  |  |                     InvoiceDate = s.InvoiceDate.ShamciToFormatShamci(), | 
					
						
							|  |  |  |  |                     invoiceTypeTitle = s.invoiceType.GetEnumDisplayName(), | 
					
						
							|  |  |  |  |                     invoiceType = s.invoiceType, | 
					
						
							|  |  |  |  |                     Title = s.Title, | 
					
						
							|  |  |  |  |                     InvoicIssueDate = s.InvoicIssueDate.ShamciToFormatShamci(), | 
					
						
							|  |  |  |  |                     BillReference = s.BillReference, | 
					
						
							|  |  |  |  |                     tbill = s.tbill, | 
					
						
							|  |  |  |  |                     Des = s.Des, | 
					
						
							|  |  |  |  |                     PreparedtoSendtoTax = s.PreparedtoSendtoTax, | 
					
						
							|  |  |  |  |                     tdis = s.tdis, | 
					
						
							|  |  |  |  |                     tvam = s.tvam, | 
					
						
							|  |  |  |  |                     Udate = s.Udate.ShamciToFormatShamci(), | 
					
						
							|  |  |  |  |                     items = s.invoiceDetails.OrderBy(o => o.ID).Select(x => new InvoiceItemDTO() | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         ID = x.ID, | 
					
						
							|  |  |  |  |                         CODID = x.CODID, | 
					
						
							| 
									
										
										
										
											2024-05-28 15:03:08 +03:30
										 |  |  |  |                         adis = x.adis, | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |                         am = x.am.Value, | 
					
						
							|  |  |  |  |                         dis = x.dis, | 
					
						
							|  |  |  |  |                         fee = x.fee.Value, | 
					
						
							| 
									
										
										
										
											2024-05-23 01:16:59 +03:30
										 |  |  |  |                         mu = x.unitTitle, | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |                         sstt = x.sstt, | 
					
						
							|  |  |  |  |                         tsstam = x.tsstam, | 
					
						
							| 
									
										
										
										
											2024-05-28 15:03:08 +03:30
										 |  |  |  |                         vam = x.vam, | 
					
						
							|  |  |  |  |                         vra = x.vra, | 
					
						
							|  |  |  |  |                         prdis = x.prdis | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |                     }).ToList(), | 
					
						
							| 
									
										
										
										
											2024-05-28 15:03:08 +03:30
										 |  |  |  |                     payments = new List<InvoicePaymentDTO>() //s.payments.OrderBy(o => o.ID).Select(x => new InvoicePaymentDTO() | 
					
						
							|  |  |  |  |                     //{ | 
					
						
							|  |  |  |  |                     //    ID = x.ID, | 
					
						
							|  |  |  |  |                     //    acn = x.acn, | 
					
						
							|  |  |  |  |                     //    iinn = x.acn, | 
					
						
							|  |  |  |  |                     //    pcn = x.acn, | 
					
						
							|  |  |  |  |                     //    pdt = x.pdt, | 
					
						
							|  |  |  |  |                     //    PaymentDateTime=x.PaymentDateTime, | 
					
						
							|  |  |  |  |                     //    pid = x.pid, | 
					
						
							|  |  |  |  |                     //    pmt = x.pmt, | 
					
						
							|  |  |  |  |                     //    pv = x.pv, | 
					
						
							|  |  |  |  |                     //    trmn = x.trmn, | 
					
						
							|  |  |  |  |                     //    trn = x.acn | 
					
						
							|  |  |  |  |                     //}).ToList() | 
					
						
							|  |  |  |  |                     , | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |                 }) | 
					
						
							| 
									
										
										
										
											2024-05-17 23:05:46 +03:30
										 |  |  |  |                 .FirstOrDefaultAsync(); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         public async Task<PagingDto<InvoiceGridDTO>?> GetInvoices(int CompanyID, ItemSerchGetInvoices itemSerch) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             #region AdvancedSearch | 
					
						
							|  |  |  |  |             var invok = _invoiceRepo | 
					
						
							|  |  |  |  |                 .Get(w => w.CompanyID == CompanyID && !w.IsDeleted); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             if (itemSerch.InvoiceID != null) | 
					
						
							|  |  |  |  |                 invok = invok.Where(w => w.ID == itemSerch.InvoiceID); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             if (itemSerch.CustomerID != null) | 
					
						
							|  |  |  |  |                 invok = invok.Where(w => w.CustomerID == itemSerch.CustomerID); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             if (itemSerch.invoiceType != null) | 
					
						
							|  |  |  |  |                 invok = invok.Where(w => w.invoiceType == itemSerch.invoiceType); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             if (itemSerch.Title != null) | 
					
						
							|  |  |  |  |                 invok = invok.Where(w => w.Title.Contains(itemSerch.Title)); | 
					
						
							|  |  |  |  |             //foreach (InputObj item in inputObjs) | 
					
						
							|  |  |  |  |             //    invok = invok.Where(ExMethod.GetFunc<Customer>(item.Param, item.Value)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             #endregion | 
					
						
							|  |  |  |  |             //----------------------- | 
					
						
							|  |  |  |  |             return await invok | 
					
						
							|  |  |  |  |                 .Include(inc => inc.invoiceDetails) | 
					
						
							| 
									
										
										
										
											2024-05-28 15:03:08 +03:30
										 |  |  |  |                      .ThenInclude(inc => inc.cODItem) | 
					
						
							|  |  |  |  |                      .ThenInclude(inc => inc.CODUnit) | 
					
						
							|  |  |  |  |                 //.Include(inc => inc.payments) | 
					
						
							|  |  |  |  |                 //.Include(inc => inc.pattern) | 
					
						
							| 
									
										
										
										
											2024-05-17 23:05:46 +03:30
										 |  |  |  |                 .Select(s => new InvoiceGridDTO() | 
					
						
							|  |  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2024-05-28 15:03:08 +03:30
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-17 23:05:46 +03:30
										 |  |  |  |                     CustomerID = s.CustomerID, | 
					
						
							|  |  |  |  |                     CustomerName = s.Customer.FullName, | 
					
						
							|  |  |  |  |                     ID = s.ID, | 
					
						
							|  |  |  |  |                     invoiceTypeTitle = s.invoiceType.GetEnumDisplayName(), | 
					
						
							|  |  |  |  |                     Title = s.Title, | 
					
						
							|  |  |  |  |                     InvoicIssueDate = s.InvoicIssueDate.ShamciToFormatShamci(), | 
					
						
							|  |  |  |  |                     tbill = s.tbill, | 
					
						
							|  |  |  |  |                     tdis = s.tdis, | 
					
						
							|  |  |  |  |                     tvam = s.tvam, | 
					
						
							|  |  |  |  |                     Udate = s.Udate.ShamciToFormatShamci(), | 
					
						
							| 
									
										
										
										
											2024-05-28 15:03:08 +03:30
										 |  |  |  |                      | 
					
						
							| 
									
										
										
										
											2024-05-17 23:05:46 +03:30
										 |  |  |  |                 }) | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |                 .Paging(itemSerch.PageIndex, itemSerch.PageSize); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-05-14 14:58:25 +03:30
										 |  |  |  |         public async Task<bool> ExistInvoiceByInvoiceID(int CompanyID, int InvoiceID) | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-05-14 14:58:25 +03:30
										 |  |  |  |             return await _invoiceRepo.Get(w => w.ID == InvoiceID && w.CompanyID == CompanyID && !w.IsDeleted).AnyAsync(); | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-05-26 17:25:34 +03:30
										 |  |  |  |         public async Task<int> AddInvoice(Invoice invoice, bool calculate = true) | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  |         { | 
					
						
							|  |  |  |  |             invoice.Cdate = DateTime.Now.ConvertMiladiToShamsi(); | 
					
						
							|  |  |  |  |             invoice.Udate = DateTime.Now.ConvertMiladiToShamsi(); | 
					
						
							|  |  |  |  |             invoice.PreparedtoSendtoTax = false; | 
					
						
							| 
									
										
										
										
											2024-05-13 16:50:26 +03:30
										 |  |  |  |             if (calculate) | 
					
						
							|  |  |  |  |             { | 
					
						
							| 
									
										
										
										
											2024-05-27 18:57:25 +03:30
										 |  |  |  |                 if (await _checkPermission.ExtensionofAccess(invoice.CompanyID.Value, 3, "-1")) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     var item = await _invoiceRepo.AddAsync(invoice); | 
					
						
							| 
									
										
										
										
											2024-05-26 17:25:34 +03:30
										 |  |  |  |                     return item.ID; | 
					
						
							| 
									
										
										
										
											2024-05-27 18:57:25 +03:30
										 |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-26 17:25:34 +03:30
										 |  |  |  |                 return -1; | 
					
						
							| 
									
										
										
										
											2024-05-13 16:50:26 +03:30
										 |  |  |  |             } | 
					
						
							|  |  |  |  |             else | 
					
						
							|  |  |  |  |             { | 
					
						
							| 
									
										
										
										
											2024-05-26 17:25:34 +03:30
										 |  |  |  |                 var item = await _invoiceRepo.AddAsync(invoice); | 
					
						
							|  |  |  |  |                 return item.ID; | 
					
						
							| 
									
										
										
										
											2024-05-13 16:50:26 +03:30
										 |  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-05-14 14:58:25 +03:30
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-13 16:50:26 +03:30
										 |  |  |  |         } | 
					
						
							|  |  |  |  |         public async Task<bool> UpdateInvoice(Invoice invoice) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             invoice.Udate = DateTime.Now.ConvertMiladiToShamsi(); | 
					
						
							|  |  |  |  |             invoice.PreparedtoSendtoTax = false; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-14 14:58:25 +03:30
										 |  |  |  |             return await _invoiceRepo.UpdateAsync(invoice); | 
					
						
							| 
									
										
										
										
											2024-05-13 16:50:26 +03:30
										 |  |  |  |         } | 
					
						
							|  |  |  |  |         public async Task<Invoice?> GetInvoiceByInvoiceID(int CompanyID, int InvoiceID) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             return await _invoiceRepo | 
					
						
							|  |  |  |  |                 .Get(w => w.ID == InvoiceID && w.CompanyID == CompanyID && !w.IsDeleted) | 
					
						
							|  |  |  |  |                 .FirstOrDefaultAsync(); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         public async Task<bool> DeleteInvoice(Invoice item) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             try | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 item.Udate = DateTime.Now.ConvertMiladiToShamsi(); | 
					
						
							|  |  |  |  |                 item.IsDeleted = true; | 
					
						
							|  |  |  |  |                 return await _invoiceRepo.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; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         public async Task<bool> ChangeInvoiceType(Invoice invoiceitem, InvoiceType item, bool action = true) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             string old = invoiceitem.invoiceType.GetEnumDisplayName(); | 
					
						
							|  |  |  |  |             invoiceitem.invoiceType = item; | 
					
						
							|  |  |  |  |             invoiceitem.Udate = DateTime.Now.ConvertMiladiToShamsi(); | 
					
						
							|  |  |  |  |             invoiceitem.PreparedtoSendtoTax = false; | 
					
						
							|  |  |  |  |             try | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 await _invoiceStatusChangPaymentRepo.AddBoolResultAsync(new InvoiceStatusChang() | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     InvoiceID = invoiceitem.ID, | 
					
						
							|  |  |  |  |                     ToStatus = item.GetEnumDisplayName(), | 
					
						
							|  |  |  |  |                     FromStatus = old, | 
					
						
							|  |  |  |  |                     Date = DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                     UserID = invoiceitem.LastChangeUserID | 
					
						
							|  |  |  |  |                 }); | 
					
						
							| 
									
										
										
										
											2024-05-14 14:58:25 +03:30
										 |  |  |  |                 if (action) | 
					
						
							|  |  |  |  |                     return await _invoiceRepo.UpdateAsync(invoiceitem); | 
					
						
							| 
									
										
										
										
											2024-05-13 16:50:26 +03:30
										 |  |  |  |                 else return true; | 
					
						
							|  |  |  |  |                 //_contextMongodb.InsertItem(new SysLog() | 
					
						
							|  |  |  |  |                 //{ | 
					
						
							|  |  |  |  |                 //    TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier, | 
					
						
							|  |  |  |  |                 //    Datetime = DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                 //    Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/ChangeInvoiceType", | 
					
						
							|  |  |  |  |                 //    Value = $"From {old} to {item.ToString()}", | 
					
						
							|  |  |  |  |                 //    Route = _httpContextAccessor.HttpContext.Request.Path, | 
					
						
							|  |  |  |  |                 //    Type = "User" | 
					
						
							|  |  |  |  |                 //}); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             catch (Exception ex) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 //_contextMongodb.InsertItem(new SysLog() | 
					
						
							|  |  |  |  |                 //{ | 
					
						
							|  |  |  |  |                 //    TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier, | 
					
						
							|  |  |  |  |                 //    Datetime = DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                 //    Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/ChangeInvoiceType", | 
					
						
							|  |  |  |  |                 //    Value = $"From {old} to {item.ToString()}" + '\n' + ex.Message, | 
					
						
							|  |  |  |  |                 //    Route = _httpContextAccessor.HttpContext.Request.Path, | 
					
						
							|  |  |  |  |                 //    Type = "catch" | 
					
						
							|  |  |  |  |                 //}); | 
					
						
							|  |  |  |  |                 return false; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-13 13:02:09 +03:30
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } |