public IActionResult Delete() { InquiryHeader inquiryHeader = _inqHRepo.FirstOrDefault(u => u.Id == InquiryVM.InquiryHeader.Id); IEnumerable <InquiryDetail> inquiryDetails = _inqDRepo.GetAll(u => u.InquiryHeaderId == InquiryVM.InquiryHeader.Id); _inqDRepo.RemoveRange(inquiryDetails); _inqHRepo.Remove(inquiryHeader); _inqHRepo.Save(); TempData[WC.Success] = "Action completed successfully"; return(RedirectToAction(nameof(Index))); }
public IActionResult Delete() { InquiryHeader inquiryHeader = _inquiryHeaderRepository.FirstOrDefault(x => x.Id == InquiryVM.InquiryHeader.Id); IEnumerable <InquiryDetail> inquiryDetails = _inquiryDetailRepository.GetAll(x => x.InquiryHeaderId == InquiryVM.InquiryHeader.Id); _inquiryDetailRepository.RemoveRange(inquiryDetails); _inquiryHeaderRepository.Remove(inquiryHeader); _inquiryHeaderRepository.Save(); TempData[WC.Success] = "Inquiry deleted successfully"; return(RedirectToAction(nameof(Index))); }
public IActionResult Delete() { InquiryHeader inquiryHeader = _inqHRepo.FirstOrDefault(u => u.Id == InquiryVM.InquiryHeader.Id); IEnumerable <InquiryDetail> inquiryDetails = _inqDRepo.GetAll(u => u.InquiryHeaderId == InquiryVM.InquiryHeader.Id); _inqDRepo.RemoveRange(inquiryDetails); _inqHRepo.Remove(inquiryHeader); _inqHRepo.Save();// or _inqDRepo.Save(); return(RedirectToAction(nameof(Index))); }
public async Task <IActionResult> SummaryPost(ProductUserVM ProductUserVM) { var ClaimIdentity = (ClaimsIdentity)User.Identity; var Claim = ClaimIdentity.FindFirst(ClaimTypes.NameIdentifier); var PathToTemplate = _webHostEnvironment.WebRootPath + Path.DirectorySeparatorChar.ToString() + "templates" + Path.DirectorySeparatorChar.ToString() + "Inquiry.html"; var subject = "New Inquiry"; string HtmlBody = ""; using (StreamReader sr = System.IO.File.OpenText(PathToTemplate)) { HtmlBody = sr.ReadToEnd(); } //Name: { 0} //Email: { 1} //Phone: { 2} //Products: {3} StringBuilder productListSB = new StringBuilder(); foreach (var prod in ProductUserVM.ProductList) { productListSB.Append($" - Name: { prod.Name} <span style='font-size:14px;'> (ID: {prod.Id})</span><br />"); } string messageBody = string.Format(HtmlBody, ProductUserVM.ApplicationUser.FullName, ProductUserVM.ApplicationUser.Email, ProductUserVM.ApplicationUser.PhoneNumber, productListSB.ToString()); await _emailSender.SendEmailAsync(WC.EmailAdmin, subject, messageBody); InquiryHeader inquiryHeader = new InquiryHeader() { ApplicationUserId = Claim.Value, FullName = ProductUserVM.ApplicationUser.FullName, Email = ProductUserVM.ApplicationUser.Email, PhoneNumber = ProductUserVM.ApplicationUser.PhoneNumber, InquiryDate = DateTime.Now }; _InHRepo.Add(inquiryHeader); _InHRepo.Save(); foreach (var prod in ProductUserVM.ProductList) { InquiryDetail inquiryDetail = new InquiryDetail() { InquiryHeaderId = inquiryHeader.Id, ProductId = prod.Id }; _InDRepo.Add(inquiryDetail); } _InDRepo.Save(); return(RedirectToAction(nameof(InquiryConfirmation))); }
public async Task <IActionResult> SummaryPost(IFormCollection collection, ProductUserVM ProductUserVM) { var claimsIdentity = (ClaimsIdentity)User.Identity; var claim = claimsIdentity.FindFirst(ClaimTypes.NameIdentifier); if (User.IsInRole(WC.AdminRole)) { //we need to create an order //var orderTotal = 0.0; //foreach(Product prod in ProductUserVM.ProductList) //{ // orderTotal += prod.Price * prod.TempSqFt; //} OrderHeader orderHeader = new OrderHeader() { CreatedByUserId = claim.Value, FinalOrderTotal = ProductUserVM.ProductList.Sum(x => x.TempSqFt * x.Price), City = ProductUserVM.ApplicationUser.City, StreetAddress = ProductUserVM.ApplicationUser.StreetAddress, State = ProductUserVM.ApplicationUser.State, PostalCode = ProductUserVM.ApplicationUser.PostalCode, FullName = ProductUserVM.ApplicationUser.FullName, Email = ProductUserVM.ApplicationUser.Email, PhoneNumber = ProductUserVM.ApplicationUser.PhoneNumber, OrderDate = DateTime.Now, OrderStatus = WC.StatusPending }; _orderHRepo.Add(orderHeader); _orderHRepo.Save(); foreach (var prod in ProductUserVM.ProductList) { OrderDetail orderDetail = new OrderDetail() { OrderHeaderId = orderHeader.Id, PricePerSqFt = prod.Price, Sqft = prod.TempSqFt, ProductId = prod.Id }; _orderDRepo.Add(orderDetail); } _orderDRepo.Save(); string nonceFromTheClient = collection["payment_method_nonce"]; var request = new TransactionRequest { Amount = Convert.ToDecimal(orderHeader.FinalOrderTotal), PaymentMethodNonce = nonceFromTheClient, OrderId = orderHeader.Id.ToString(), Options = new TransactionOptionsRequest { SubmitForSettlement = true } }; var gateway = _brain.GetGateway(); Result <Transaction> result = gateway.Transaction.Sale(request); if (result.Target.ProcessorResponseText == "Approved") { orderHeader.TransactionId = result.Target.Id; orderHeader.OrderStatus = WC.StatusApproved; } else { orderHeader.OrderStatus = WC.StatusCancelled; } _orderHRepo.Save(); return(RedirectToAction(nameof(InquiryConfirmation), new { id = orderHeader.Id })); } else { //we need to create an inquiry var PathToTemplate = _webHostEnvironment.WebRootPath + Path.DirectorySeparatorChar.ToString() + "templates" + Path.DirectorySeparatorChar.ToString() + "Inquiry.html"; var subject = "New Inquiry"; string HtmlBody = ""; using (StreamReader sr = System.IO.File.OpenText(PathToTemplate)) { HtmlBody = sr.ReadToEnd(); } //Name: { 0} //Email: { 1} //Phone: { 2} //Products: {3} StringBuilder productListSB = new StringBuilder(); foreach (var prod in ProductUserVM.ProductList) { productListSB.Append($" - Name: { prod.Name} <span style='font-size:14px;'> (ID: {prod.Id})</span><br />"); } string messageBody = string.Format(HtmlBody, ProductUserVM.ApplicationUser.FullName, ProductUserVM.ApplicationUser.Email, ProductUserVM.ApplicationUser.PhoneNumber, productListSB.ToString()); await _emailSender.SendEmailAsync(WC.EmailAdmin, subject, messageBody); InquiryHeader inquiryHeader = new InquiryHeader() { ApplicationUserId = claim.Value, FullName = ProductUserVM.ApplicationUser.FullName, Email = ProductUserVM.ApplicationUser.Email, PhoneNumber = ProductUserVM.ApplicationUser.PhoneNumber, InquiryDate = DateTime.Now }; _inqHRepo.Add(inquiryHeader); _inqHRepo.Save(); foreach (var prod in ProductUserVM.ProductList) { InquiryDetail inquiryDetail = new InquiryDetail() { InquiryHeaderId = inquiryHeader.Id, ProductId = prod.Id, }; _inqDRepo.Add(inquiryDetail); } _inqDRepo.Save(); TempData[WC.Success] = "Inquiry submitted successfully"; } return(RedirectToAction(nameof(InquiryConfirmation))); }