fixes
This commit is contained in:
parent
354bdb6556
commit
d9b4a7ffdd
|
|
@ -1,10 +1,7 @@
|
|||
using ExCSS;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Nop.Core;
|
||||
using Nop.Core.Domain.Catalog;
|
||||
using Nop.Plugin.Misc.AuctionPlugin.Domains.Dtos;
|
||||
using Nop.Plugin.Misc.AuctionPlugin.Domains.Entities;
|
||||
using Nop.Plugin.Misc.AuctionPlugin.Domains.Enums;
|
||||
using Nop.Plugin.Misc.AuctionPlugin.Models;
|
||||
using Nop.Plugin.Misc.AuctionPlugin.Services;
|
||||
using Nop.Services.Cms;
|
||||
|
|
@ -15,7 +12,6 @@ using Nop.Web.Framework.Components;
|
|||
using Nop.Web.Framework.Infrastructure;
|
||||
using Nop.Web.Models.Catalog;
|
||||
using Nop.Web.Framework.Mvc.Routing;
|
||||
using DocumentFormat.OpenXml.EMMA;
|
||||
using Nop.Services.Catalog;
|
||||
|
||||
namespace Nop.Plugin.Misc.AuctionPlugin.Components;
|
||||
|
|
@ -24,40 +20,41 @@ public class AuctionPublicViewComponent : NopViewComponent
|
|||
{
|
||||
#region Fields
|
||||
|
||||
protected readonly IAddressService _addressService;
|
||||
protected readonly IGenericAttributeService _genericAttributeService;
|
||||
protected readonly IWidgetPluginManager _widgetPluginManager;
|
||||
protected readonly IWorkContext _workContext;
|
||||
protected readonly AuctionService _auctionService;
|
||||
protected readonly AuctionSettings _auctionSettings;
|
||||
protected readonly ICustomerService _customerService;
|
||||
protected readonly IWebHelper _webHelper;
|
||||
protected readonly IProductService _productService;
|
||||
protected readonly ILogger _logger;
|
||||
protected readonly MyProductModelFactory _myProductModelFactory;
|
||||
//private readonly IAddressService _addressService;
|
||||
//private readonly IGenericAttributeService _genericAttributeService;
|
||||
private readonly IWidgetPluginManager _widgetPluginManager;
|
||||
private readonly IWorkContext _workContext;
|
||||
private readonly AuctionService _auctionService;
|
||||
//private readonly AuctionSettings _auctionSettings;
|
||||
private readonly ICustomerService _customerService;
|
||||
private readonly IWebHelper _webHelper;
|
||||
private readonly IProductService _productService;
|
||||
private readonly ILogger _logger;
|
||||
private readonly MyProductModelFactory _myProductModelFactory;
|
||||
|
||||
#endregion
|
||||
|
||||
#region Ctor
|
||||
|
||||
public AuctionPublicViewComponent(IAddressService addressService,
|
||||
IGenericAttributeService genericAttributeService,
|
||||
public AuctionPublicViewComponent(
|
||||
//IAddressService addressService,
|
||||
//IGenericAttributeService genericAttributeService,
|
||||
IWidgetPluginManager widgetPluginManager,
|
||||
IWorkContext workContext,
|
||||
AuctionService auctionService,
|
||||
AuctionSettings auctionSettings,
|
||||
//AuctionSettings auctionSettings,
|
||||
ICustomerService customerService,
|
||||
IWebHelper webHelper,
|
||||
IProductService productService,
|
||||
MyProductModelFactory myProductModelFactory,
|
||||
ILogger logger)
|
||||
{
|
||||
_addressService = addressService;
|
||||
_genericAttributeService = genericAttributeService;
|
||||
//_addressService = addressService;
|
||||
//_genericAttributeService = genericAttributeService;
|
||||
_widgetPluginManager = widgetPluginManager;
|
||||
_workContext = workContext;
|
||||
_auctionService = auctionService;
|
||||
_auctionSettings = auctionSettings;
|
||||
//_auctionSettings = auctionSettings;
|
||||
_customerService = customerService;
|
||||
_webHelper = webHelper;
|
||||
_productService = productService;
|
||||
|
|
@ -96,7 +93,7 @@ public class AuctionPublicViewComponent : NopViewComponent
|
|||
//if (!_auctionSettings.Enabled)
|
||||
// return Content(string.Empty);
|
||||
|
||||
var productDetailsModel = additionalData as ProductDetailsModel;
|
||||
var productDetailsModel = (additionalData as ProductDetailsModel)!;
|
||||
|
||||
await _logger.InformationAsync($"WidgetViewComponent product: {productDetailsModel.Name}");
|
||||
|
||||
|
|
@ -132,7 +129,7 @@ public class AuctionPublicViewComponent : NopViewComponent
|
|||
var productBidBoxViewModel = new ProductBidBoxViewModel(auctionDto);
|
||||
//List<ProductToAuctionMapping> productToAuctionId = await _auctionService.GetProductToAuctionByAuctionIdAndProductIdAsync(auctionId, productDetailsModel.Id);
|
||||
|
||||
AuctionStatus status = productToAuction.AuctionStatus;
|
||||
var status = productToAuction.AuctionStatus;
|
||||
//bool isActive = status == AuctionStatus.Active || status == AuctionStatus.FirstWarning || status == AuctionStatus.SecondWarning;
|
||||
//bool isFirstWarning = status == AuctionStatus.FirstWarning;
|
||||
|
||||
|
|
@ -140,23 +137,25 @@ public class AuctionPublicViewComponent : NopViewComponent
|
|||
|
||||
ProductToAuctionDto nextProductToAuction;
|
||||
ProductToAuctionDto lastProductToAuction;
|
||||
string nextUrl = "";
|
||||
string lastUrl = "";
|
||||
string nextImageUrl = "";
|
||||
string lastImageUrl = "";
|
||||
string nextProductName = "";
|
||||
string lastProductName = "";
|
||||
var nextUrl = "";
|
||||
var lastUrl = "";
|
||||
var nextImageUrl = "";
|
||||
var lastImageUrl = "";
|
||||
var nextProductName = "";
|
||||
var lastProductName = "";
|
||||
|
||||
if (productToAuction.SortIndex < detailedAuctionDto.ProductToAuctionDtos.Count)
|
||||
{
|
||||
nextProductToAuction = detailedAuctionDto.ProductToAuctionDtos.Where(x => x.SortIndex == productToAuction.SortIndex + 1).FirstOrDefault();
|
||||
nextProductToAuction = detailedAuctionDto.ProductToAuctionDtos.FirstOrDefault(x => x.SortIndex == productToAuction.SortIndex + 1);
|
||||
if (nextProductToAuction != null)
|
||||
{
|
||||
var nextProductId = nextProductToAuction.ProductId;
|
||||
var nextProduct = await _productService.GetProductByIdAsync(nextProductId);
|
||||
var nextDetails = await _myProductModelFactory.PrepareProductDetailsModelAsync(nextProduct);
|
||||
nextUrl = Url.RouteUrl<Product>(new { nextDetails.SeName }, _webHelper.GetCurrentRequestProtocol()).ToLowerInvariant();
|
||||
nextImageUrl = nextDetails.DefaultPictureModel.FullSizeImageUrl;
|
||||
nextProductName = nextDetails.SeName;
|
||||
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -165,7 +164,9 @@ public class AuctionPublicViewComponent : NopViewComponent
|
|||
|
||||
if (productToAuction.SortIndex > 1)
|
||||
{
|
||||
lastProductToAuction = detailedAuctionDto.ProductToAuctionDtos.Where(x => x.SortIndex == productToAuction.SortIndex - 1).FirstOrDefault();
|
||||
lastProductToAuction = detailedAuctionDto.ProductToAuctionDtos.FirstOrDefault(x => x.SortIndex == productToAuction.SortIndex - 1);
|
||||
if (lastProductToAuction != null)
|
||||
{
|
||||
var lastProductId = lastProductToAuction.ProductId;
|
||||
var lastProduct = await _productService.GetProductByIdAsync(lastProductId);
|
||||
var lastDetails = await _myProductModelFactory.PrepareProductDetailsModelAsync(lastProduct);
|
||||
|
|
@ -173,14 +174,12 @@ public class AuctionPublicViewComponent : NopViewComponent
|
|||
lastImageUrl = lastDetails.DefaultPictureModel.FullSizeImageUrl;
|
||||
lastProductName = lastDetails.SeName;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
lastProductToAuction = null;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
productBidBoxViewModel.IsAdmin = await _customerService.IsAdminAsync(customer);
|
||||
productBidBoxViewModel.IsGuest = await _customerService.IsGuestAsync(customer);
|
||||
productBidBoxViewModel.AuctionClosed = auctionDto.Closed;
|
||||
|
|
@ -200,7 +199,7 @@ public class AuctionPublicViewComponent : NopViewComponent
|
|||
productBidBoxViewModel.LastProductName = lastProductName;
|
||||
productBidBoxViewModel.NextProductName = nextProductName;
|
||||
productBidBoxViewModel.LicitStep = AuctionService.GetStepAmount(productToAuction.CurrentPrice); //add calculation
|
||||
productBidBoxViewModel.NextBidPrice = productToAuction.CurrentPrice + productBidBoxViewModel.LicitStep;
|
||||
productBidBoxViewModel.NextBidPrice = AuctionService.GetNextBidPrice(productToAuction.CurrentPrice, productBidBoxViewModel.LicitStep);
|
||||
|
||||
|
||||
return View("~/Plugins/Misc.AuctionPlugin/Views/PublicProductBidBox.cshtml", productBidBoxViewModel);
|
||||
|
|
|
|||
|
|
@ -323,11 +323,8 @@ namespace Nop.Plugin.Misc.AuctionPlugin.Hubs
|
|||
}
|
||||
|
||||
private static decimal GetStepAmount(decimal currentBidPrice) => AuctionService.GetStepAmount(currentBidPrice);
|
||||
private static decimal GetNextBidPrice(decimal currentBidPrice) => GetNextBidPrice(currentBidPrice, GetStepAmount(currentBidPrice));
|
||||
private static decimal GetNextBidPrice(decimal currentBidPrice, decimal stepAmount)
|
||||
{
|
||||
return currentBidPrice + stepAmount;
|
||||
}
|
||||
private static decimal GetNextBidPrice(decimal currentBidPrice) => AuctionService.GetNextBidPrice(currentBidPrice, GetStepAmount(currentBidPrice));
|
||||
private static decimal GetNextBidPrice(decimal currentBidPrice, decimal stepAmount) => AuctionService.GetNextBidPrice(currentBidPrice, stepAmount);
|
||||
|
||||
private static bool IsValidRequestAuctionStatus(AuctionStatus newStatus, AuctionStatus oldStatus)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -1,7 +1,6 @@
|
|||
using Newtonsoft.Json;
|
||||
using Nop.Plugin.Misc.AuctionPlugin.Domains.Dtos;
|
||||
using Nop.Web.Framework.Models;
|
||||
using Nop.Web.Framework.Mvc.ModelBinding;
|
||||
|
||||
namespace Nop.Plugin.Misc.AuctionPlugin.Models
|
||||
{
|
||||
|
|
@ -29,11 +28,14 @@ namespace Nop.Plugin.Misc.AuctionPlugin.Models
|
|||
public AuctionPublicInfoModel(AuctionDto auctionDto) : this()
|
||||
{
|
||||
AuctionDto = auctionDto;
|
||||
FirstProductToAuction = AuctionDto.ProductToAuctionDtos.First();
|
||||
|
||||
StartDate = AuctionDto.StartDateUtc;
|
||||
|
||||
FirstProductToAuction = AuctionDto.ProductToAuctionDtos.FirstOrDefault();
|
||||
if (FirstProductToAuction == null) return;
|
||||
|
||||
ProductId = FirstProductToAuction.ProductId;
|
||||
ProductToAuctionMappingId = FirstProductToAuction.Id;
|
||||
StartDate = AuctionDto.StartDateUtc;
|
||||
IsActive = FirstProductToAuction.IsActiveItem;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -27,7 +27,7 @@ namespace Nop.Plugin.Misc.AuctionPlugin.Models
|
|||
|
||||
public int AuctionId { get; set; }
|
||||
public bool AuctionClosed { get; set; }
|
||||
public bool IsItemActive => FirstProductToAuction.IsActiveItem;
|
||||
public bool IsItemActive => FirstProductToAuction?.IsActiveItem ?? false;
|
||||
public AuctionStatus AuctionStatus { get; set; }
|
||||
public int ProductId { get; set; }
|
||||
|
||||
|
|
@ -62,9 +62,11 @@ namespace Nop.Plugin.Misc.AuctionPlugin.Models
|
|||
public ProductBidBoxViewModel(AuctionDto auctionDto) : this()
|
||||
{
|
||||
AuctionDto = auctionDto;
|
||||
FirstProductToAuction = AuctionDto.ProductToAuctionDtos.First();
|
||||
|
||||
AuctionId = auctionDto.Id;
|
||||
|
||||
FirstProductToAuction = AuctionDto.ProductToAuctionDtos.FirstOrDefault();
|
||||
if (FirstProductToAuction == null) return;
|
||||
|
||||
ProductId = FirstProductToAuction.ProductId;
|
||||
ProductToAuctionId = FirstProductToAuction.Id;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -95,6 +95,12 @@ public class AuctionService : IAuctionService
|
|||
//200 000 000 Ft fölött 20 000 000 Ft-tal
|
||||
}
|
||||
|
||||
public static decimal GetNextBidPrice(decimal currentBidPrice) => GetNextBidPrice(currentBidPrice, GetStepAmount(currentBidPrice));
|
||||
public static decimal GetNextBidPrice(decimal currentBidPrice, decimal stepAmount)
|
||||
{
|
||||
return currentBidPrice + stepAmount;
|
||||
}
|
||||
|
||||
public async Task ResetProductToAuctionByProductId(int productId)
|
||||
=> await ResetProductToAuctionAsync(await _ctx.ProductToAuctions.GetByProductId(productId).FirstOrDefaultAsync());
|
||||
|
||||
|
|
|
|||
|
|
@ -9,9 +9,12 @@
|
|||
@{
|
||||
if (!Model.IsGuest)
|
||||
{
|
||||
var bgClass = Model.AuctionDto.ProductToAuctionDtos.FirstOrDefault().WinnerCustomerId == Model.CustomerId ? "bg-success" : "bg-primary";
|
||||
bool bidButtonActive = Model.IsItemActive && (Model.AuctionDto.ProductToAuctionDtos.FirstOrDefault().WinnerCustomerId == Model.CustomerId && !Model.IsAdmin) ? true : false;
|
||||
string title = Model.AuctionDto.ProductToAuctionDtos.FirstOrDefault().WinnerCustomerId == Model.CustomerId ? "Your bid is leading" : "Place a bid!";
|
||||
if (Model.FirstProductToAuction != null)
|
||||
{
|
||||
var bgClass = Model.FirstProductToAuction.WinnerCustomerId == Model.CustomerId ? "bg-success" : "bg-primary";
|
||||
var bidButtonActive = Model.IsItemActive && (Model.FirstProductToAuction.WinnerCustomerId != Model.CustomerId || Model.IsAdmin);
|
||||
var title = Model.FirstProductToAuction.WinnerCustomerId == Model.CustomerId ? "Your bid is leading" : "Place a bid!";
|
||||
|
||||
<div class="d-flex justify-content-between" id="otherAuctionItems">
|
||||
<a href="@(string.IsNullOrEmpty(Model.LastProductUrl) ? "#" : Model.LastProductUrl)" @(string.IsNullOrEmpty(Model.LastProductUrl) ? "disabled" : string.Empty)>
|
||||
<div class="card mb-3" style="max-width: 540px;">
|
||||
|
|
@ -23,12 +26,12 @@
|
|||
<div class="card-body">
|
||||
<h5 class="card-title">@(string.IsNullOrEmpty(Model.LastProductUrl) ? "Start of list" : "Back to last")</h5>
|
||||
<p class="card-text">@(string.IsNullOrEmpty(Model.LastProductName) ? "---" : Model.LastProductName)</p>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</a>
|
||||
|
||||
<a href="@(string.IsNullOrEmpty(Model.NextProductUrl) ? "#" : Model.NextProductUrl)" @(string.IsNullOrEmpty(Model.NextProductUrl) ? "disabled" : string.Empty)>
|
||||
<div class="card mb-3" style="max-width: 540px;">
|
||||
<div class="row g-0">
|
||||
|
|
@ -39,7 +42,6 @@
|
|||
<div class="card-body">
|
||||
<h5 class="card-title">@(string.IsNullOrEmpty(Model.NextProductUrl) ? "End of list" : "Coming up next...")</h5>
|
||||
<p class="card-text">@(string.IsNullOrEmpty(Model.NextProductName) ? "---" : Model.NextProductName)</p>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
|
@ -62,7 +64,7 @@
|
|||
<span id="licitStepText" class="value">@($"{Model.LicitStep:c}")</span>
|
||||
</div>
|
||||
<div>
|
||||
<button id="signalRBidButton" class="btn btn-success" style="text-transform: uppercase;" type="button" disabled="@(bidButtonActive)">
|
||||
<button id="signalRBidButton" class="btn btn-success" style="text-transform: uppercase;" type="button" @(!bidButtonActive ? "disabled" : string.Empty)>
|
||||
Bid @($"{Model.NextBidPrice:c}")
|
||||
</button>
|
||||
@* <button id="bidButton" class="btn btn-success">
|
||||
|
|
@ -122,8 +124,7 @@
|
|||
{
|
||||
<p>No access to admin level buttons</p>
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -135,9 +136,9 @@
|
|||
</div>
|
||||
</div>
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
<script>
|
||||
<script>
|
||||
var bidBoxPageViewModel;
|
||||
|
||||
$(window).load(function () {
|
||||
|
|
@ -521,4 +522,4 @@
|
|||
}
|
||||
|
||||
|
||||
</script>
|
||||
</script>
|
||||
Loading…
Reference in New Issue