This commit is contained in:
Loretta 2024-11-19 11:30:30 +01:00
parent d7dffd1485
commit 992e4a6c40
4 changed files with 68 additions and 57 deletions

View File

@ -50,14 +50,16 @@
}; };
addAntiForgeryToken(postData); addAntiForgeryToken(postData);
console.log("postData: " + JSON.stringify(postData)); var jsonData = JSON.stringify(postData);
console.log("postData: " + jsonData);
debugger;
// Perform AJAX call // Perform AJAX call
$.ajax({ $.ajax({
url: "/Admin/AuctionPluginAdmin/AssignProductToAuction", // Update to match your endpoint url: "/Admin/AuctionPluginAdmin/AssignProductToAuction", // Update to match your endpoint
type: "POST", type: "POST",
contentType: "application/json", contentType: "application/json",
data: JSON.stringify(postData), data: jsonData,
traditional: true, traditional: true,
success: function (response) { success: function (response) {
alert("Product successfully assigned to the auction!"); alert("Product successfully assigned to the auction!");

View File

@ -30,6 +30,7 @@ namespace Nop.Plugin.Misc.AuctionPlugin.Hubs
{ {
switch (message.MessageType) switch (message.MessageType)
{ {
//nameof(IAuctionHubClient.SendPrice)
case "BidRequestMessage": case "BidRequestMessage":
await HandleBidRequest(message.Data); await HandleBidRequest(message.Data);
break; break;
@ -52,6 +53,7 @@ namespace Nop.Plugin.Misc.AuctionPlugin.Hubs
{ {
await _logger.InformationAsync("Deserialization returned null. Message data might not match the expected structure."); await _logger.InformationAsync("Deserialization returned null. Message data might not match the expected structure.");
} }
bidRequestMessage = a; bidRequestMessage = a;
} }
catch (Exception ex) catch (Exception ex)
@ -60,6 +62,9 @@ namespace Nop.Plugin.Misc.AuctionPlugin.Hubs
} }
//AuctionBidRequest bidRequestMessage = new AuctionBidRequest(); //AuctionBidRequest bidRequestMessage = new AuctionBidRequest();
try
{
if (bidRequestMessage != null) if (bidRequestMessage != null)
{ {
await _logger.InformationAsync($"Bid received: - Auction:{bidRequestMessage.AuctionId} Product: {bidRequestMessage.ProductId} - Bid: {bidRequestMessage.BidPrice} - Customer: {bidRequestMessage.CustomerId}"); await _logger.InformationAsync($"Bid received: - Auction:{bidRequestMessage.AuctionId} Product: {bidRequestMessage.ProductId} - Bid: {bidRequestMessage.BidPrice} - Customer: {bidRequestMessage.CustomerId}");
@ -90,12 +95,11 @@ namespace Nop.Plugin.Misc.AuctionPlugin.Hubs
//save bid //save bid
try try
{ {
var result = _auctionService.InsertBidAsync(auctionBid); await _auctionService.InsertBidAsync(auctionBid);
} }
catch(Exception ex) catch (Exception e)
{ {
_logger.Error($"MessageHandling error: {ex.ToString()}"); _logger.Error($"MessageHandling InsertBidAsync error: {e.ToString()}");
} }
//update product //update product
@ -119,7 +123,11 @@ namespace Nop.Plugin.Misc.AuctionPlugin.Hubs
await _hubContext.Clients.All.SendAsync("send", jsonMessage); await _hubContext.Clients.All.SendAsync("send", jsonMessage);
} }
}
catch (Exception ex)
{
_logger.Error($"MessageHandling error: {ex.ToString()}");
}
} }
} }
} }

View File

@ -211,12 +211,15 @@ public class AuctionService : IAuctionService
return new List<ProductToAuctionMapping>(await _ctx.ProductToAuctions.GetByAuctionAndProductId(auctionId, productId).ToListAsync()); return new List<ProductToAuctionMapping>(await _ctx.ProductToAuctions.GetByAuctionAndProductId(auctionId, productId).ToListAsync());
} }
public async Task<bool> AssignProductToAuctionAsync(int productId, decimal startingPrice, decimal bidPrice, int auctionId) public async Task<ProductToAuctionMapping> AssignProductToAuctionAsync(int productId, decimal startingPrice, decimal bidPrice, int auctionId)
{ {
var auction = await GetAuctionDtoByIdAsync(auctionId); var auction = await GetAuctionDtoByIdAsync(auctionId);
if (auction == null) if (auction == null)
return null; return null;
var existedProductToAuction = (await GetProductToAuctionByAuctionIdAndProductIdAsync(auctionId, productId)).FirstOrDefault();
if (existedProductToAuction != null) return existedProductToAuction;
var mapping = new ProductToAuctionMapping var mapping = new ProductToAuctionMapping
{ {
ProductId = productId, ProductId = productId,

View File

@ -50,6 +50,4 @@ public interface IAuctionService
Task<List<ProductToAuctionMapping>> GetProductToAuctionsByProductIdAsync(int productId); Task<List<ProductToAuctionMapping>> GetProductToAuctionsByProductIdAsync(int productId);
Task<List<ProductToAuctionMapping>> GetProductToAuctionByAuctionIdAndProductIdAsync(int auctionId, int productId); Task<List<ProductToAuctionMapping>> GetProductToAuctionByAuctionIdAndProductIdAsync(int auctionId, int productId);
Task<bool> AssignProductToAuctionAsync(int productId, decimal startingPrice, decimal bidPrice, int auctionId);
} }