Error executing template "Designs/Tefcold/eCom/ProductCatalog/basic_Pim.cshtml"
System.NullReferenceException: Object reference not set to an instance of an object.
   at Tefcold.Web.CustomCode.Razor.ProductViewModelExtensions.GetSpecifications(ProductViewModel product)
   at Tefcold.Web.CustomCode.Extensions.ProductExtensions.GetAsseccoriesList(ProductViewModel viewModel, String shopId)
   at CompiledRazorTemplates.Dynamic.RazorEngine_5dd170007fc94f9fb77605653df5fd44.Execute() in E:\Solutions\Live\Tefcold.Web\Files\Templates\Designs\Tefcold\eCom\ProductCatalog\basic_Pim.cshtml:line 35
   at RazorEngine.Templating.TemplateBase.RazorEngine.Templating.ITemplate.Run(ExecuteContext context, TextWriter reader)
   at RazorEngine.Templating.RazorEngineService.RunCompile(ITemplateKey key, TextWriter writer, Type modelType, Object model, DynamicViewBag viewBag)
   at RazorEngine.Templating.RazorEngineServiceExtensions.<>c__DisplayClass16_0.b__0(TextWriter writer)
   at RazorEngine.Templating.RazorEngineServiceExtensions.WithWriter(Action`1 withWriter)
   at Dynamicweb.Rendering.Template.RenderRazorTemplate()

1 @using System.Globalization 2 @using NLWI.Platforms.Dynamicweb9.Specs 3 @using NLWI.Core.Factory 4 @using System.Linq; 5 @using System.Text.RegularExpressions 6 @using Dynamicweb.Ecommerce.International 7 @using Dynamicweb.Ecommerce.ProductCatalog 8 @using Dynamicweb.Ecommerce.Products 9 @using Dynamicweb.Ecommerce.Stocks 10 @using Dynamicweb.Security.UserManagement 11 @using NORRIQ.Common8.Ecom 12 @using Newtonsoft.Json 13 @using Newtonsoft.Json.Serialization 14 @using NORRIQ.SalesPersonLogin.Services 15 @using NORRIQ.Seo.Canonical 16 @using Tefcold.Web.CustomCode.AsyncProductList.Models 17 @using Tefcold.Web.CustomCode.Extensions 18 @using Tefcold.Web.CustomCode.Items 19 @using Tefcold.Web.CustomCode.Items.Properties 20 @using Tefcold.Web.CustomCode.Items.Settings 21 @*@using Tefcold.Web.CustomCode.ProductHelper*@ 22 @using Tefcold.Web.CustomCode.Razor 23 @using Tefcold.Web.CustomCode.Stocks 24 @using Tefcold.Web.CustomCode.Stocks.Helpers 25 @inherits Tefcold.Web.CustomCode.Razor.TefcoldViewModelTemplate<Dynamicweb.Ecommerce.ProductCatalog.ProductViewModel> 26 @{ 27 var websiteSettings = Pageview.Area.Item.ToCodeFirstItem<Websites>();// Dynamicweb.Services.Items.GetItem(Pageview.Area.ItemType, Pageview.Area.ItemId).ToCodeFirstItem<Websites>(); 28 29 var stockInformation = StockLocationHelper.GetShopStockInformation(Pageview.ID); 30 31 //Dynamicweb.Ecommerce.Services.StockService.GetStockUnits("34024-at-SHOP2", ""); 32 //var stockInformation = StockLocationHelper.GetShopStockInformation(Pageview.ID); 33 var variantId = System.Web.HttpContext.Current.Request.QueryString["VariantID"]; 34 var selectedModel = (!string.IsNullOrEmpty(variantId) ? Model.Variants?.FirstOrDefault(a => string.Equals(a.VariantId, variantId)) : null) ?? Model; 35 var accessories = selectedModel.GetAsseccoriesList(Pageview.Area.EcomShopId); 36 var relatedProducts = Model.GetProductRelationGroup("Related Products");// Configuration 37 var perfionImageNames = new string[] { "PrimaryImage", "DetailImage1", "DetailImage2", "BrandedImage", "PackedImage", "OtherImages", "WithContentImage", "OpenImage", "ImageRange", "ImageOnLocation","StorageImages" }; 38 //var specsToList = new HashSet<string>() { "Fitting", "Features", "USP", "Gender", "Season", "Year" }; @*Leave empty for all *@ 39 40 var remoteStock = StockUnitHelper.GetRemoteStock(selectedModel, Pageview, websiteSettings.ExternalShopIds); 41 42 var inspirationGroupIds = websiteSettings.InspirationGroupIds ?? new List<string>(); 43 selectedModel.StockUnits = selectedModel.StockUnits.GetShopStocks(Pageview.Area.EcomShopId).ToList(); 44 45 FieldValueViewModel youtubeIDfield; 46 selectedModel.ProductFields.TryGetValue("YoutubeId", out youtubeIDfield); 47 string youtubeID = youtubeIDfield?.Value?.ToString(); 48 var hasVideo = !string.IsNullOrEmpty(youtubeID); 49 50 youtubeID = selectedModel.GetSpecifications().GetByKey("YouTubeURL").Value; 51 52 var convertedSelectedModel = new AsyncProductWithSpecification(new SimpleProduct(selectedModel, null, stockInformation, inspirationGroupIds, websiteSettings.ExternalShopIds, true)); 53 convertedSelectedModel.Product.DefaultPrice.CurrencyCode = Pageview.Area.EcomCurrencyId; 54 var convertedMasterModel = new AsyncProductWithSpecification(new SimpleProduct(Model, null, stockInformation, inspirationGroupIds, websiteSettings.ExternalShopIds, true)); 55 56 var selectedJsonModel = JsonConvert.SerializeObject(convertedSelectedModel, new JsonSerializerSettings { ContractResolver = new CamelCasePropertyNamesContractResolver() }); 57 var selectedMasterProductModel = JsonConvert.SerializeObject(convertedMasterModel, new JsonSerializerSettings { ContractResolver = new CamelCasePropertyNamesContractResolver() }); 58 selectedMasterProductModel = selectedMasterProductModel.Replace("'", "&#39;"); 59 selectedJsonModel = selectedJsonModel.Replace("'", "&#39;"); 60 61 string asyncPrefix = "Async "; 62 var userInTefcoldUserGroup = ImpersonationService.IsCurrentlyImpersonating(); 63 FieldValueViewModel isSpareField; 64 selectedModel.ProductFields.TryGetValue("IsSparePart", out isSpareField); 65 var isSparePart = (bool)isSpareField.Value; 66 67 var product = Dynamicweb.Ecommerce.Services.Products.GetProductById(Model.Id, Model.VariantId, Model.LanguageId); 68 69 var productIsBlocked = product != null && !product.Active; 70 71 //Used to determine whether or not to show phdCode 72 73 if (isSparePart) 74 { 75 76 Pageview.Meta.AddTag("robots", "noindex,nofollow"); 77 } 78 79 // Specs 80 var specs = ProductViewModelExtensions.GetSpecifications(selectedModel); 81 var images = perfionImageNames.SelectMany(a => specs.GetAllByKey(a)).ToList(); 82 var imageAlt = specs.GetByKey("ProductName"); 83 84 var ecoIcon = specs.GetByKey("EcoIcon"); 85 86 var trueString = true.ToString().ToLower(); 87 88 string basicPimPrefix = "PDP "; 89 var languageId = Model.LanguageId; 90 91 var productService = ObjectFactory.GetInstance<ProductService>(); 92 LanguageService languageService = new LanguageService(); 93 //ProductFields 94 95 DateTime result; 96 string earliestHarborArrival = selectedModel.ProductFields.FirstOrDefault(f => f.Value.SystemName == "EarliestArrivalFromHarbor").Value?.Value?.ToString() ?? string.Empty; 97 98 if (DateTime.TryParseExact(earliestHarborArrival, "yyyy-mm-dd", CultureInfo.InvariantCulture, DateTimeStyles.None, out result)) 99 { 100 var earliestArrivalTranslateString = Translate(basicPimPrefix + "stock arriving soon. Due", "Stock arriving soon. Due"); 101 earliestHarborArrival = result.ToString("dd/mm/yyyy"); 102 earliestHarborArrival = earliestArrivalTranslateString + " " + earliestHarborArrival; 103 } 104 105 //websiteSettings = Pageview.GetWebsiteSettings(); 106 string shortSellingText = specs.GetByKey("SellingTextShort")?.Value; 107 string energyArrow = specs.GetByKey("EnergyArrow")?.Value; 108 string energyLabel = specs.GetByKey("EnergyLabel")?.Value; 109 var marketingMessage = specs.GetByKey("MarketingMessage")?.Value; 110 111 var stickerImage = Model.GetStickerImage(); 112 string netVolumeEnergyRating = specs.GetByKey("NetVolumeEnergyRating")?.Value; 113 string totalDisplayArea = specs.GetByKey("TotalDisplayArea")?.Value; 114 var standardCustomer = Pageview.AreaSettings.GetString("StandardCustomer"); 115 standardCustomer = string.IsNullOrEmpty(standardCustomer) ? "" : standardCustomer; 116 string detailImage1Text = specs.GetByKey("DetailImage1Text")?.Value; 117 string detailImage2Text = specs.GetByKey("DetailImage2Text")?.Value; 118 } 119 <product-details-simple-pim :product='@selectedJsonModel' 120 :images='@Newtonsoft.Json.JsonConvert.SerializeObject(images.Select(a => a.Value))' 121 inline-template 122 language-id="@Model.LanguageId"> 123 <div class="basic_pim" v-bind:class="{'initialized': initialized }"> 124 <section class="basic_pim-pdp" itemscope="" itemtype="https://schema.org/Product"> 125 <div class="basic_pim-media"> 126 <div class="@(images.Count() > 1 ? "basic_pim-pictos thumbs" : "basic_pim-pictos")"> 127 <div class="stickers"> 128 @if (!string.IsNullOrEmpty(stickerImage)) 129 { 130 <img src="/Admin/Public/GetImage.ashx?Height=@TefcoldParagraphSettings.StickHeightDetails&amp;Compression=85&amp;Image=@stickerImage" alt="@Translate(basicPimPrefix + "Sticker", "Sticker")" class="img-fluid"/> 131 } 132 @if (websiteSettings.DiscountFormat != null) 133 { 134 <span v-if="ShowDiscount" class="sticker discount"> 135 -{{discount}}% 136 </span> 137 } 138 139 </div> 140 @if (!string.IsNullOrEmpty(ecoIcon?.Value)) 141 { 142 <img src="@(ecoIcon?.Value)" alt="@Translate(basicPimPrefix + "eco product", "Eco product")" class="img-fluid" style="margin-left:auto;" /> 143 } 144 145 </div> 146 <gallery :items="images" 147 :index="index" 148 @@close="index = null"> 149 </gallery> 150 <template v-if="images.length > 1"> 151 <slick ref="slick" 152 class="basic_pim-thumbs" 153 id="pdp-thumbs" 154 :options="slickPimOptionsThumbs"> 155 <figure v-for="thumb in images" class="basic_pim-thumb"> 156 <img :src="'/Admin/Public/GetImage.ashx?Width=50&amp;Height=50&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;fillcanvas=True&amp;Image=' + thumb" 157 alt="@selectedModel.Name" 158 class="img-fluid" /> 159 </figure> 160 @if (!string.IsNullOrEmpty(youtubeID)) 161 { 162 <figure class="basic_pim-thumb"> 163 <svg x="0px" y="0px" 164 width="48" height="48" 165 viewBox="0 0 48 48"> 166 <path fill="#FF3D00" d="M43.2,33.9c-0.4,2.1-2.1,3.7-4.2,4c-3.3,0.5-8.8,1.1-15,1.1c-6.1,0-11.6-0.6-15-1.1c-2.1-0.3-3.8-1.9-4.2-4C4.4,31.6,4,28.2,4,24c0-4.2,0.4-7.6,0.8-9.9c0.4-2.1,2.1-3.7,4.2-4C12.3,9.6,17.8,9,24,9c6.2,0,11.6,0.6,15,1.1c2.1,0.3,3.8,1.9,4.2,4c0.4,2.3,0.9,5.7,0.9,9.9C44,28.2,43.6,31.6,43.2,33.9z"></path> 167 <path fill="#FFF" d="M20 31L20 17 32 24z"></path> 168 </svg> 169 </figure> 170 } 171 172 </slick> 173 <slick ref="slick" 174 class="basic_pim-images" 175 id="pdp-images" 176 :options="slickPimOptionsImages"> 177 <figure class="basic_pim-image" 178 v-for="(image, imageIndex) in images" 179 :key="imageIndex" 180 @@click="setIndex(imageIndex)" 181 title="@Translate(basicPimPrefix + "show image", "Show image")"> 182 <picture> 183 <source media="(max-width:767.98px)" :srcset="'/Admin/Public/GetImage.ashx?Width=400&amp;Height=400&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;fillcanvas=True&amp;Image=' + image"> 184 <source media="(max-width:991.98px)" :srcset="'/Admin/Public/GetImage.ashx?Width=530&amp;Height=530&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;fillcanvas=True&amp;Image=' + image"> 185 <img :src="'/Admin/Public/GetImage.ashx?Width=530&amp;Height=530&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;fillcanvas=True&amp;Image=' + image" 186 alt="@selectedModel.Name" 187 class="img-fluid" 188 itemprop="image" /> 189 </picture> 190 @if (!string.IsNullOrEmpty(detailImage1Text) || !string.IsNullOrEmpty(detailImage2Text)) 191 { 192 <figcaption class="alert bg-white" v-if="imageIndex < 3"> 193 @if (!string.IsNullOrEmpty(detailImage1Text)) 194 { 195 <template v-if="imageIndex == 1"> 196 @detailImage1Text 197 </template> 198 } 199 @if (!string.IsNullOrEmpty(detailImage2Text)) 200 { 201 <template v-if="imageIndex == 2"> 202 @detailImage2Text 203 </template> 204 } 205 </figcaption> 206 } 207 </figure> 208 @if (!string.IsNullOrEmpty(youtubeID)) 209 { 210 <figure :key="images.Count" 211 @@click="setIndex(images.Count)" 212 title="@Translate(basicPimPrefix + "show image", "Show image")"> 213 <div> 214 <youtube-embed-lite vid="@youtubeID" thumb-quality="hq" class="embed-responsive-item" /> 215 </div> 216 </figure> 217 } 218 219 220 </slick> 221 </template> 222 <template v-if="images.length == 1"> 223 <div class="basic_pim-images"> 224 <figure class="basic_pim-image" 225 v-for="(image, imageIndex) in images" 226 :key="imageIndex" 227 @@click="setIndex(imageIndex)" 228 title="@Translate(basicPimPrefix + "show image", "Show image")"> 229 <picture> 230 <source media="(max-width:767.98px)" :srcset="'/Admin/Public/GetImage.ashx?Width=300&amp;Height=250&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;fillcanvas=True&amp;Image=' + image"> 231 <source media="(max-width:991.98px)" :srcset="'/Admin/Public/GetImage.ashx?Width=400&amp;Height=350&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;fillcanvas=True&amp;Image=' + image"> 232 <img :src="'/Admin/Public/GetImage.ashx?Width=427&amp;Height=427&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;fillcanvas=True&amp;Image=' + image" 233 alt="@selectedModel.Name" 234 class="img-fluid" 235 itemprop="image"> 236 </picture> 237 @if (!string.IsNullOrEmpty(detailImage1Text) || !string.IsNullOrEmpty(detailImage2Text)) 238 { 239 <figcaption class="alert bg-white"> 240 @if (!string.IsNullOrEmpty(detailImage1Text)) 241 { 242 <template v-if="imageIndex == 1"> 243 @detailImage1Text 244 </template> 245 } 246 @if (!string.IsNullOrEmpty(detailImage2Text)) 247 { 248 <template v-if="imageIndex == 2"> 249 @detailImage2Text 250 </template> 251 } 252 </figcaption> 253 } 254 </figure> 255 </div> 256 </template> 257 <template v-if="images.length == 0"> 258 @{ 259 var pdpImage = "/Files/Images/default.jpg"; 260 } 261 <div class="basic_pim-image"> 262 <picture class="basic_pim-image"> 263 <source media="(max-width:1199.98px)" srcset="/Admin/Public/GetImage.ashx?Width=630&amp;Height=630&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;Image=@(pdpImage)"> 264 <source media="(max-width:991.98px)" srcset="/Admin/Public/GetImage.ashx?Width=530&amp;Height=530&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;Image=@(pdpImage)"> 265 <source media="(max-width:767.98px)" srcset="/Admin/Public/GetImage.ashx?Width=400&amp;Height=400&amp;Compression=85&amp;Crop=5&amp;Format=webp&amp;Quality=85&amp;Image=@(pdpImage)"> 266 <img src="@(pdpImage)" 267 alt="@Translate(basicPimPrefix + "No product picture", "No product picture")" 268 class="img-fluid" 269 itemprop="image"> 270 </picture> 271 </div> 272 </template> 273 </div> 274 <div class="basic_pim-content"> 275 <header> 276 <h1 itemprop="name"> 277 @selectedModel.Name 278 </h1> 279 <p itemprop="category">@(selectedModel?.ShortDescription ?? "")</p> 280 </header> 281 @if (specs.GetAllByKey("BulletPoints").Any()) 282 { 283 <ul class="basic_pim-specs"> 284 @foreach (var bp in specs.GetAllByKey("BulletPoints")) 285 { 286 <li> 287 @bp.Value 288 </li> 289 } 290 </ul> 291 } 292 293 @* 294 <template name="item-stock-state" v-if="stockLocationState!=0"> 295 <p :class="'stock out-of-stock'" v-if="stockLocationState==5"> 296 <link itemprop="availability" href="http://schema.org/SoldOut" /> 297 @Translate(asyncPrefix + "Out Of Stock", "Out Of Stock") 298 </p> 299 <p :class="'stock few-in-stock'" v-if="stockLocationState==7"> 300 <link itemprop="availability" href="http://schema.org/LimitedAvailability" /> 301 @Translate(asyncPrefix + "Few In Stock", "Few In Stock") 302 </p> 303 <p :class="'stock in-stock'" v-if="stockLocationState==8"> 304 <link itemprop="availability" href="http://schema.org/InStock" /> 305 @Translate(asyncPrefix + "In Stock", "In Stock") 306 </p> 307 </template> 308 *@ 309 310 @if (!string.IsNullOrEmpty(marketingMessage) && Pageview.IsCurrentlyB2B()) 311 { 312 <span class="basic_pim-marketing-message">@marketingMessage</span> 313 } 314 315 @if (Pageview.IsAllowedToShop() && !productIsBlocked) 316 { 317 <stock-location-component inline-template :remote-stock-shop-ids='@JsonConvert.SerializeObject(websiteSettings.ExternalShopIds)' not-in-stock-text="@Translate(basicPimPrefix + "not in stock text", "N/A")" :default-stock-units='product.product.stockUnits' :default-remote-stock-units='@Newtonsoft.Json.JsonConvert.SerializeObject(remoteStock)' :product='product' earliest-harbor-arrival-date="@earliestHarborArrival"> 318 <div class="basic_pim-stocks"> 319 <template v-if="stockUnits.length > 0 && !loading"> 320 <div v-for="unit in stockUnits" class="custom-control custom-radio"> 321 <span style="font-size: 1px">{{unit.quantity}}</span> 322 <input type="radio" v-model="selectedVal" name="stocks" :id="unit.stockLocation.name" :value="unit.stockLocation.name" class="custom-control-input" :disabled="unit.quantity <=0 || getStockLocation!=''" :checked="getStockLocation == unit.stockLocation.name"> 323 <label v-if="!@userInTefcoldUserGroup.ToString().ToLower()" :for="unit.stockLocation.name" class="custom-control-label"> 324 {{ unit.stockLocation.description }} {{ GetStockAmountString(unit.quantity) }} @Translate("PDP In Stock", "In Stock") 325 <template v-if="stocksHasNoQuantity"> 326 <br/><span style="font-size: small;">{{earliestHarborArrivalDate}}</span> 327 </template> 328 </label> 329 <label v-else :for="unit.stockLocation.name" class="custom-control-label"> 330 {{ unit.stockLocation.description }} {{ unit.quantity }} @Translate("PDP In Stock", "In Stock") 331 <template v-if="stocksHasNoQuantity"> 332 <br/><span style="font-size: small;">{{earliestHarborArrivalDate}}</span> 333 </template> 334 </label> 335 </div> 336 <br/> 337 </template> 338 <template v-else-if="loading"> 339 <span class="spinner-sm-default"></span> 340 </template> 341 <template v-if="remoteStockUnits.length > 0 && !loading"> 342 <div v-for="unit in remoteStockUnits" class="custom-control "> 343 <span style="font-size: 1px">{{unit.Quantity}}</span> 344 @*<input type="radio" v-model="selectedVal" name="stocks" :id="unit.StockLocation.Description" :value="unit.StockLocation.Description" class="custom-control-input" :disabled="true">*@ 345 @*<label v-if="!@userInTefcoldUserGroup.ToString().ToLower()" :for="unit.StockLocation.Description" class="custom-control-label">{{ unit.StockLocation.Description }} {{ GetStockAmountString(unit.Quantity) }} @Translate("PDP In Stock", "In Stock")</label>*@ 346 <label v-if="!@userInTefcoldUserGroup.ToString().ToLower()" :for="unit.StockLocation.Description" class=""> 347 {{ unit.StockLocation.Description }} {{ GetStockAmountString(unit.Quantity) }} @Translate("PDP In Stock", "In Stock") 348 <br /><span style="font-size: small;">@Translate("Back In Stock Again Text", "Stock due on")</span> 349 </label> 350 <label v-else :for="unit.StockLocation.Description" class="custom-control"> 351 {{ unit.StockLocation.Description }} {{ unit.Quantity }} @Translate("PDP In Stock", "In Stock") 352 <br/><span style="font-size: small;">@Translate("Back In Stock Again Text", "Stock due on")</span> 353 </label> 354 355 </div> 356 </template> 357 </div> 358 </stock-location-component> 359 } 360 @if (!Pageview.IsAllowedToShop() || productIsBlocked) 361 { 362 <buying-component inline-template :initial-product='@selectedMasterProductModel' :selected-product='@selectedMasterProductModel'> 363 <div class="basic_pim-buying"> 364 365 @if (!string.IsNullOrEmpty(energyArrow)) 366 { 367 string name = Regex.Replace(selectedModel.Name.Trim(), "[^A-Za-z0-9_. ]+", ""); 368 //var lang = languageService.GetLanguage(selectedModel.LanguageId)?.Code2; 369 370 //string filePattern = $"[[type]]-{selectedModel.Number}-{name}-{lang}"; 371 <div class="pdp-energy"> 372 <div class="pdp-energy-data"> 373 <a href="@energyLabel" target="_blank" class="pdp-energy-label"> 374 <img src="/Admin/Public/GetImage.ashx?Height=40&amp;Crop=5&amp;Image=@energyArrow" /> 375 </a> 376 <a href="#" v-on:click="getProductReport($event,'@selectedModel.Number', '@name','@selectedModel.LanguageId')" target="_blank" class="pdp-energy-link"> 377 378 @Translate(basicPimPrefix + "product sheet", "Product Sheet") 379 380 </a> 381 </div> 382 </div> 383 } 384 385 <ul class="basic_pim-variants" v-if="initialProduct.product.simpleVariants && initialProduct.product.simpleVariants.length > 0"> 386 <li> 387 @{ 388 FieldValueViewModel productImg; 389 FieldValueViewModel productColor; 390 Model.ProductFields.TryGetValue("productVariantColorImage", out productImg); 391 Model.ProductFields.TryGetValue("productVariantValue", out productColor); 392 } 393 <a href="Default.aspx?ID=@Pageview.ID&ProductId=@Model.Id" class="@(Model.Number == selectedModel.Number ? "active" : "")" :style="getImageOrColor('@(productImg?.Value)','@(productColor?.Value)')"></a> 394 </li> 395 396 @if (Model.Variants != null) 397 { 398 foreach (var variant in Model.Variants) 399 { 400 FieldValueViewModel variantImg; 401 FieldValueViewModel variantColor; 402 variant.ProductFields.TryGetValue("productVariantColorImage", out variantImg); 403 variant.ProductFields.TryGetValue("productVariantValue", out variantColor); 404 405 <li> 406 <a href="/Default.aspx?ID=@Pageview.ID&ProductId=@variant.Id&VariantId=@variant.VariantId" class="@(variant.Number == selectedModel.Number ? "active" : "")" :style="getImageOrColor('@(variantImg?.Value)','@(variantColor?.Value)')"></a> 407 </li> 408 409 } 410 } 411 </ul> 412 </div> 413 </buying-component> 414 <p itemprop="sku"> 415 @Translate(basicPimPrefix + "Product number", "Product number"): @selectedModel.Number @(string.IsNullOrEmpty(selectedModel.GetNavItemNumber()) ? "" : "("+Translate("Substition for","Substitution for ")+ $"{selectedModel.GetNavItemNumber()})") 416 </p> 417 <a href="@NORRIQ.Common8.Razor.Navigation.GetUrlByNavigationTag("contact")" class="btn btn-outline-secondary btn-sm mt-3"> 418 @Translate("create account", "Create account") 419 </a> 420 } 421 else 422 { 423 <buying-component inline-template @@discount="onDiscount($event)" :initial-product='@selectedMasterProductModel' :selected-product='@selectedMasterProductModel' :chosen-warranty-code="chosenWarrantyCode" :warranty-info="warrantyInfo"> 424 <div class="basic_pim-buying" itemprop="offers" itemscope="" itemtype="https://schema.org/Offer"> 425 <div class="pdp-energy"> 426 <async-price class-type="asyncprice-pdp" 427 :product='@selectedJsonModel' 428 :default-price="@selectedModel.Price.PriceWithoutVat.ToString(CultureInfo.InvariantCulture)" 429 :only-standard-price="@(Pageview.IsCurrentlyB2C().ToString().ToLower())" 430 list-price="true" 431 :should-emit-warranties="true" 432 language-id="@languageId" 433 standard-customer="@standardCustomer" 434 @@discount="onDiscount($event)"> 435 </async-price> 436 @if (!string.IsNullOrEmpty(energyArrow)) 437 { 438 string name = Regex.Replace(selectedModel.Name.Trim(), "[^A-Za-z0-9_. ]+", ""); 439 //var lang = languageService.GetLanguage(selectedModel.LanguageId)?.Code2; 440 441 //string filePattern = $"[[type]]-{selectedModel.Number}-{name}-{lang}"; 442 <div class="pdp-energy-data"> 443 <a href="@energyLabel" target="_blank" class="pdp-energy-label"> 444 <img src="/Admin/Public/GetImage.ashx?Height=40&amp;Crop=5&amp;Image=@energyArrow" /> 445 </a> 446 <a href="#" v-on:click="getProductReport($event,'@selectedModel.Number', '@name','@selectedModel.LanguageId')" target="_blank" class="pdp-energy-link"> 447 448 @Translate(basicPimPrefix + "product sheet", "Product Sheet") 449 450 </a> 451 </div> 452 } 453 </div> 454 <ul class="basic_pim-variants" v-if="initialProduct.product.simpleVariants && initialProduct.product.simpleVariants.length > 0"> 455 <li> 456 @{ 457 FieldValueViewModel productImg; 458 FieldValueViewModel productColor; 459 Model.ProductFields.TryGetValue("productVariantColorImage", out productImg); 460 Model.ProductFields.TryGetValue("productVariantValue", out productColor); 461 } 462 <a href="Default.aspx?ID=@Pageview.ID&ProductId=@Model.Id" class="@(Model.Number == selectedModel.Number ? "active" : "")" :style="getImageOrColor('@(productImg?.Value)','@(productColor?.Value)')"></a> 463 </li> 464 465 @if (Model.Variants != null) 466 { 467 foreach (var variant in Model.Variants) 468 { 469 FieldValueViewModel variantImg; 470 FieldValueViewModel variantColor; 471 variant.ProductFields.TryGetValue("productVariantColorImage", out variantImg); 472 variant.ProductFields.TryGetValue("productVariantValue", out variantColor); 473 474 <li> 475 <a href="/Default.aspx?ID=@Pageview.ID&ProductId=@variant.Id&VariantId=@variant.VariantId" class="@(variant.Number == selectedModel.Number ? "active" : "")" :style="getImageOrColor('@(variantImg?.Value)','@(variantColor?.Value)')"></a> 476 </li> 477 478 } 479 } 480 </ul> 481 <div class="pdp-btn-group"> 482 <add-to-basket-simple class="addtobasketsimple-pdp" 483 :product='@selectedJsonModel' 484 :price-without-vat="currentItemPriceWithoutVat" 485 button-class="btn btn-primary" 486 :group-warranty-code="chosenWarrantyCode" 487 :warranty-info="warrantyInfo" 488 :unit-of-measure="'PCS'" 489 language-id="@languageId" 490 :only-spare-parts="@((Pageview.User.OnlySpareParts() && !isSparePart).ToString().ToLower())" 491 :is-marketing-user="@(Pageview.User.OnlyView().ToString().ToLower())" 492 :ishvasuser="@(Pageview.User.IsHVACUser().ToString().ToLower())" 493 standard-customer="@standardCustomer"> 494 </add-to-basket-simple> 495 @if (Pageview.IsCurrentlyB2B()) 496 { 497 <favorite-lists ui-error-message-translation="@Translate(basicPimPrefix + " Error while retrieving favorite list", "Error while retrieving favorite list")" :is-favorite-mode="@NORRIQ.Common8.Razor.Navigation.GetPageIdByNavigationTag("favorites") == @Pageview.ID" :product='@selectedJsonModel'></favorite-lists> 498 } 499 <add-to-compare :product-number="selectedProduct.product.number"></add-to-compare> 500 </div> 501 </div> 502 </buying-component> 503 <p itemprop="sku"> 504 @Translate(basicPimPrefix + "Product number", "Product number"): @selectedModel.Number @(string.IsNullOrEmpty(selectedModel.GetNavItemNumber()) ? "" : "(" + Translate("Substition for", "Substitution for ") + $"{selectedModel.GetNavItemNumber()})") 505 506 </p> 507 if (Pageview.IsCZShop() && !string.IsNullOrEmpty(specs.GetByKey("PhdCode")?.Value)) 508 { 509 <p class="phdCode">@Translate(basicPimPrefix + "PhdCode", "PhdCode") @(specs.GetByKey("PhdCode")?.Value)</p> 510 } 511 if (!isSparePart && (Pageview.IsCurrentlyB2B() && Pageview.User.AllowWarranty() || Pageview.IsCurrentlyB2C())) 512 { 513 <div class="basic_pim-warranty" v-if="@((!isSparePart).ToString().ToLower()) && warranties?.length>0"> 514 <div v-for="(warranty,index) in warranties" class="custom-control custom-radio"> 515 <input type="radio" name="warranty" :id="'warranty' + index" v-model="chosenWarranty" :value="warranty" class="custom-control-input" /> 516 <label :for="'warranty' + index" class="custom-control-label"> 517 {{getDescription(warranty.itemNo) +' - ' + product.product.defaultPrice.currencyCode + ' ' + warranty.price.priceWithoutVat + ',-'}} 518 </label> 519 </div> 520 @*<template v-if="warrantyLoading"> 521 <div class="basic_listview-loader text-center">http://localhost:55277/http://localhost:55277/ 522 <span class="spinner-lg-default"></span> 523 </div> 524 </template>*@ 525 </div> 526 } 527 } 528 @if (isSparePart && specs.GetByGroup("NIQSpecifications").Any()) 529 { 530 <ul class="list-unstyled spare-specs mt-3"> 531 @foreach (var group in specs.GetByGroup("NIQSpecifications").Where(x => x.Key != "EcoIcon").OrderBy(x => x.Group2Order).ThenBy(x => x.ValueSortOrder).GroupBy(x => x.Group2)) 532 { 533 534 535 foreach (var spec in group) 536 { 537 538 <li> 539 540 <span>@spec.Caption</span> 541 <span> 542 @spec.Value 543 @spec.Unit 544 </span> 545 </li> 546 } 547 548 } 549 </ul> 550 } 551 </div> 552 </section> 553 @if (!isSparePart) 554 { 555 <section class="basic_pim-collapse"> 556 @if (!string.IsNullOrEmpty(selectedModel.LongDescription) || !string.IsNullOrEmpty(shortSellingText) || specs.GetByGroup("NIQSpecifications").Any()) 557 { 558 <div class="basic_pim-col" visible id="specs1"> 559 @if (!string.IsNullOrEmpty(selectedModel.LongDescription) || !string.IsNullOrEmpty(shortSellingText)) 560 { 561 <button class="btn-collapse" id="description" v-b-toggle.long-description> 562 @Translate(basicPimPrefix + "product description", "Product description") 563 </button> 564 <b-collapse id="long-description" appear accordion="specs1"> 565 <template> 566 <div class="body-collapse"> 567 @if (!string.IsNullOrEmpty(shortSellingText)) 568 { 569 <p>@shortSellingText</p> 570 } 571 @if (!string.IsNullOrEmpty(selectedModel.LongDescription)) 572 { 573 <p>@selectedModel.LongDescription</p> 574 } 575 </div> 576 </template> 577 </b-collapse> 578 } 579 @if (specs.GetByGroup("NIQSpecifications").Any()) 580 { 581 <button class="btn-collapse" id="specs" v-b-toggle.specs-list> 582 @Translate(basicPimPrefix + "Product Specs", "Product Specifications") 583 </button> 584 <b-collapse id="specs-list" accordion="specs1"> 585 <template> 586 <div class="body-collapse full"> 587 <table class="table table-specs"> 588 589 <tbody> 590 591 @foreach (var group in specs.GetByGroup("NIQSpecifications").Where(x => x.Key != "EcoIcon").OrderBy(x => x.Group2Order).ThenBy(x => x.ValueSortOrder).GroupBy(x => x.Group2)) 592 { 593 var test = specs; 594 595 <tr> 596 <th>@group.Key</th> 597 <th></th> 598 </tr> 599 foreach (var spec in group) 600 { 601 if (spec.Key == "EnergyArrow") 602 { 603 continue; 604 } 605 if (spec.Key == "EnergyArrowText" && !string.IsNullOrEmpty(energyArrow)) 606 { 607 <tr> 608 <td> 609 @spec.Caption 610 </td> 611 <td valign="middle" style="vertical-align:middle;"> 612 <a href="@energyLabel" target="_blank" style="display:flex;"> 613 <img src="/Admin/Public/GetImage.ashx?Height=18&amp;Crop=5&amp;Image=@energyArrow" /> 614 </a> 615 </td> 616 </tr> 617 } 618 else 619 { 620 <tr> 621 <td> 622 @spec.Caption 623 </td> 624 <td valign="middle" style="vertical-align:middle;"> 625 @spec.Value 626 @spec.Unit 627 </td> 628 </tr> 629 } 630 } 631 } 632 <tr> 633 <th></th> 634 <th></th> 635 </tr> 636 </tbody> 637 </table> 638 639 </div> 640 </template> 641 </b-collapse> 642 } 643 </div> 644 } 645 <div class="basic_pim-col" id="specs2"> 646 647 <button class="btn-collapse" id="download" v-b-toggle.download-documents> 648 @Translate(basicPimPrefix + "downloads", "Downloads") 649 </button> 650 <b-collapse id="download-documents" accordion="specs2"> 651 <template> 652 <div class="body-collapse"> 653 <ul class="basic_pim-downloads"> 654 @{ 655 656 string name = Regex.Replace(selectedModel.Name.Trim(), "[^A-Za-z0-9_. ]+", ""); 657 var lang = languageService.GetLanguage(selectedModel.LanguageId)?.Code2; 658 659 } 660 @{ string filePattern = $"[[type]]-{selectedModel.Number}-{name}-{lang}"; } 661 <li> 662 <a href="#" v-on:click="getProductReport($event,'@selectedModel.Number', '@name','@lang')" target="_blank"> 663 <svg> 664 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 665 </svg> 666 @Translate(basicPimPrefix + "product sheet", "Product Sheet") 667 </a> 668 </li> 669 @if (!string.IsNullOrEmpty(@specs.GetByKey("Usermanual").Value)) 670 { 671 <li> 672 <a href="#" v-on:click="downloadProductFile($event,'@name','@specs.GetByKey("Usermanual").Value','@filePattern.Replace("[[type]]", "Usermanual")','Usermanual')" target="_blank"> 673 <svg> 674 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 675 </svg> 676 @Translate(basicPimPrefix + "User manual", "User manual") 677 </a> 678 </li> 679 } 680 @if (!string.IsNullOrEmpty(@specs.GetByKey("SparePartsBC").Value)) 681 { 682 <li> 683 <a href="#" v-on:click="downloadProductFile($event,'@name','@specs.GetByKey("SparePartsBC").Value','@filePattern.Replace("[[type]]","SparePartsBC")','SparePartsBC')" target="_blank"> 684 <svg> 685 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 686 </svg> 687 @Translate(basicPimPrefix + basicPimPrefix + "spare part list", "Spare part list") 688 </a> 689 </li> 690 } 691 @if (!string.IsNullOrEmpty(energyLabel)) 692 { 693 <li> 694 <a href="#" v-on:click="downloadProductFile($event,'@name','@energyLabel','@filePattern.Replace("[[type]]","EnergyClassification")','EnergyClassification')" target="_blank"> 695 <svg> 696 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 697 </svg> 698 @Translate(basicPimPrefix + "Energy Classification", "Energy Classification") 699 </a> 700 </li> 701 } 702 @if (!string.IsNullOrEmpty(@specs.GetByKey("HVACSpecs").Value)) 703 { 704 <li> 705 <a href="#" v-on:click="downloadProductFile($event,'@name','@specs.GetByKey("HVACSpecs").Value','@filePattern.Replace("[[type]]","HVACSpecs")','Drawings')" target="_blank"> 706 <svg> 707 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 708 </svg> 709 @Translate(basicPimPrefix + "HVACSpecs", "HVAC Specs") 710 </a> 711 </li> 712 } 713 @if (Pageview.User != null && Pageview.User.AllowDownloadDocuments()) 714 { 715 if (!string.IsNullOrEmpty(specs.GetByKey("WiringDiagrams").Value)) 716 { 717 <li> 718 <a href="#" v-on:click="downloadProductFile($event,'@name','@specs.GetByKey("WiringDiagrams").Value','@filePattern.Replace("[[type]]","WiringDiagrams")','WiringDiagrams')" target="_blank"> 719 <svg> 720 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 721 </svg> 722 @Translate(basicPimPrefix + "Wiring diagram", "Wiring diagram") 723 </a> 724 </li> 725 } 726 if (!string.IsNullOrEmpty(specs.GetByKey("Drawings").Value)) 727 { 728 <li> 729 <a href="#" v-on:click="downloadProductFile($event,'@name','@specs.GetByKey("Drawings").Value','@filePattern.Replace("[[type]]","Drawings")','Drawings')" target="_blank"> 730 <svg> 731 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 732 </svg> 733 @Translate(basicPimPrefix + "Drawings", "Drawings") 734 </a> 735 </li> 736 } 737 if (!string.IsNullOrEmpty(specs.GetByKey("BrandingFile").Value)) 738 { 739 <li> 740 <a href="#" v-on:click="downloadProductFile($event,'@name','@specs.GetByKey("BrandingFile").Value','@filePattern.Replace("[[type]]","Branding")','BrandingFile')" target="_blank"> 741 <svg> 742 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 743 </svg> 744 @Translate(basicPimPrefix + "Branding File", "Branding drawing") 745 </a> 746 </li> 747 } 748 if (!string.IsNullOrEmpty(specs.GetByKey("QuickGuide").Value)) 749 { 750 <li> 751 <a href="#" v-on:click="downloadProductFile($event,'@name','@specs.GetByKey("QuickGuide").Value','@filePattern.Replace("[[type]]","QuickGuide")','QuickGuide')" target="_blank"> 752 <svg> 753 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 754 </svg> 755 @Translate(basicPimPrefix + "QuickGuide", "Quick Guide") 756 </a> 757 </li> 758 } 759 if (!string.IsNullOrEmpty(specs.GetByKey("AssemblyGuide").Value)) 760 { 761 <li> 762 <a href="#" v-on:click="downloadProductFile($event,'@name','@specs.GetByKey("AssemblyGuide").Value','@filePattern.Replace("[[type]]","AssemblyGuide")','AssemblyGuide')" target="_blank"> 763 <svg> 764 <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/files/dist/icons/icons.svg#download"></use> 765 </svg> 766 @Translate(basicPimPrefix + "AssemblyGuide", "Assembly Guide") 767 </a> 768 </li> 769 } 770 } 771 772 </ul> 773 </div> 774 </template> 775 </b-collapse> 776 777 @if (!isSparePart) 778 { 779 <product-spare-parts-view :page-view-id="@Pageview.ID" 780 :language-id="'@selectedModel.LanguageId'" 781 :product-number="@selectedModel.Number" 782 :exploded-drawing="'@(specs.GetByKey("ExplodedDrawing")?.Value)'" 783 :spare-part-report="'@(specs.GetByKey("SparePartsBC").Value)'" 784 product-name="@name" 785 language-code="@lang" 786 :sparepart-location="product.product.defaultStockLocationName"> 787 </product-spare-parts-view> 788 } 789 790 </div> 791 </section> 792 } 793 @if (accessories != null && accessories.Any()) 794 { 795 796 <section class="basic_related"> 797 <template> 798 <header class="basic_related-header" id="accessories-header"> 799 <h2 class="text-center"> 800 @Translate(basicPimPrefix + "Accessories", "Accessories") 801 </h2> 802 </header> 803 <slick ref="slick" 804 class="basic_related-grid" 805 :options="slickAccessoriesOptions"> 806 @foreach (var accessory in accessories) 807 { 808 var converted = new AsyncProductWithSpecification(new SimpleProduct(accessory.ToViewModel(), null, stockInformation, inspirationGroupIds, websiteSettings.ExternalShopIds, true)); 809 var accessoryJson = JsonConvert.SerializeObject(converted, new JsonSerializerSettings { ContractResolver = new CamelCasePropertyNamesContractResolver() }); 810 accessoryJson = accessoryJson.Replace("'", "&#39;"); 811 <article class="basic_related-product"> 812 <a href="/Default.aspx?ID=@NORRIQ.Common8.Razor.Navigation.GetPageIdByNavigationTag("plp")&amp;ProductID=@accessory.Id" class="basic_related-url"> 813 <figure> 814 @{ 815 var image = string.IsNullOrEmpty(accessory.ImageLarge) ? "/Files/Images/default.jpg" : "/Files/" + accessory.ImageLarge; 816 } 817 <img src="/Admin/Public/GetImage.ashx?Width=427&amp;Height=427&amp;Compression=85&amp;Crop=5&amp;Image=@image" 818 alt="@accessory.Name" 819 class="img-fluid" /> 820 </figure> 821 <header> 822 <h1>@accessory.Name</h1> 823 <p class="basic_related-category">@accessory.ShortDescription</p> 824 <p class="basic_related-sku">@Translate(basicPimPrefix + "Product Number", "Product Number") @accessory.Number</p> 825 </header> 826 </a> 827 @if (Pageview.IsCurrentlyB2B()) 828 { 829 <buying-component inline-template :initial-product='@accessoryJson'> 830 <footer> 831 <async-price class-type="asyncprice-plp" 832 :default-price="@accessory.Price.PriceWithoutVAT.ToString(CultureInfo.InvariantCulture)" 833 :product='@accessoryJson' 834 only-price="true" 835 standard-customer="@standardCustomer"> 836 </async-price> 837 <add-to-basket-simple :product='@accessoryJson' 838 button-class="btn btn-primary" 839 class="addtobasketsimple-plp ml-auto" 840 language-id="@languageId" 841 :price-without-vat="@accessory.Price.PriceWithoutVAT.ToString(CultureInfo.InvariantCulture)" 842 :only-spare-parts="@((Pageview.User.OnlySpareParts() && !isSparePart).ToString().ToLower())" 843 :is-marketing-user="@(Pageview.User.OnlyView().ToString().ToLower())" 844 :ishvasuser="@(Pageview.User.IsHVACUser().ToString().ToLower())" 845 standard-customer="@standardCustomer"> 846 </add-to-basket-simple> 847 </footer> 848 </buying-component> 849 850 } 851 else 852 { 853 <footer> 854 <async-price class-type="asyncprice-plp" 855 :default-price="@accessory.Price.PriceWithoutVAT.ToString(CultureInfo.InvariantCulture)" 856 :product='@accessoryJson' 857 only-price="true" 858 :only-standard-price="@(Pageview.IsCurrentlyB2C().ToString().ToLower())" 859 standard-customer="@standardCustomer" /> 860 861 <div class="asyncprice-plp"> 862 <div class="price-withoutvat"> 863 <span class="price-label">@Translate(basicPimPrefix + "price without vat", "Price without VAT")</span> 864 <p class="price"> 865 <span class="unit-price"> 866 @accessory.Price.PriceWithoutVATFormattedNoSymbol @accessory.Price.Currency.Code 867 </span> 868 </p> 869 </div> 870 </div> 871 <add-to-basket-simple :product='@accessoryJson' 872 button-class="btn btn-primary" 873 class="addtobasketsimple-plp ml-auto" 874 language-id="@languageId" 875 :price-without-vat="@accessory.Price.PriceWithoutVAT.ToString(CultureInfo.InvariantCulture)" 876 :only-spare-parts="@((Pageview.User.OnlySpareParts() && !isSparePart).ToString().ToLower())" 877 :is-marketing-user="@(Pageview.User.OnlyView().ToString().ToLower())" 878 :ishvasuser="@(Pageview.User.IsHVACUser().ToString().ToLower())" 879 standard-customer="@standardCustomer"> 880 </add-to-basket-simple> 881 </footer> 882 } 883 </article> 884 } 885 </slick> 886 </template> 887 </section> 888 } 889 @if (relatedProducts != null && relatedProducts.RelatedProducts.Any()) 890 { 891 <section class="basic_related"> 892 <template> 893 <header class="basic_related-header" id="related-header"> 894 <h2 class="text-center"> 895 @Translate(basicPimPrefix + "Related Products", "Related Products") 896 </h2> 897 </header> 898 <slick ref="slick" 899 class="basic_related-grid" 900 :options="slickRelatedOptions"> 901 @foreach (var relProduct in relatedProducts.RelatedProducts) 902 { 903 904 //var relProduct = productService.GetProductById(rel.Id, rel.VariantId, rel.LanguageId); 905 var converted = new AsyncProductWithSpecification(new SimpleProduct(relProduct.ToViewModel(), null, stockInformation, inspirationGroupIds, websiteSettings.ExternalShopIds, true)); 906 var relProductJson = JsonConvert.SerializeObject(converted, new JsonSerializerSettings { ContractResolver = new CamelCasePropertyNamesContractResolver() }); 907 relProductJson = relProductJson.Replace("'", "&#39;"); 908 <article class="basic_related-product"> 909 <a href="/Default.aspx?ID=@NORRIQ.Common8.Razor.Navigation.GetPageIdByNavigationTag("plp")&amp;ProductID=@relProduct.Id" class="basic_related-url"> 910 <figure style="min-height: 1px;"> 911 @{ 912 var image = string.IsNullOrEmpty(relProduct.ImageLarge) ? "/Files/Images/default.jpg" : "/Files/" + relProduct.ImageLarge; 913 } 914 <img src="/Admin/Public/GetImage.ashx?Width=427&amp;Height=427&amp;Compression=85&amp;Crop=5&amp;fillcanvas=true&amp;Image=@image" 915 alt="@relProduct.Name" 916 class="img-fluid" /> 917 </figure> 918 <header> 919 <h1>@relProduct.Name</h1> 920 <p class="basic_related-category">@relProduct.ShortDescription</p> 921 <p class="basic_related-sku">@Translate(basicPimPrefix + "Product Number", "Product Number") @relProduct.Number</p> 922 </header> 923 </a> 924 925 @if (Pageview.IsCurrentlyB2B()) 926 { 927 928 <buying-component @@discount="onDiscount($event)" inline-template :initial-product='@relProductJson' :selected-product='@relProductJson'> 929 <footer> 930 <async-price class-type="asyncprice-plp" 931 :default-price="@relProduct.Price.PriceWithoutVAT.ToString(CultureInfo.InvariantCulture)" 932 :product='@relProductJson' 933 unit-of-measure="PCS" 934 only-price="true" 935 should-emit-warranties="true" 936 :only-standard-price="@(Pageview.IsCurrentlyB2C().ToString().ToLower())" 937 standard-customer="@standardCustomer" 938 @@discount="onDiscount($event)"> 939 </async-price> 940 <add-to-basket-simple :product='@relProductJson' 941 button-class="btn btn-primary" 942 :unit-of-measure="'PCS'" 943 class="addtobasketsimple-plp ml-auto" 944 :price-without-vat="currentItemPriceWithoutVat" 945 language-id="@languageId" 946 :only-spare-parts="@((Pageview.User.OnlySpareParts() && !isSparePart).ToString().ToLower())" 947 :is-marketing-user="@(Pageview.User.OnlyView().ToString().ToLower())" 948 :ishvasuser="@(Pageview.User.IsHVACUser().ToString().ToLower())" 949 standard-customer="@standardCustomer" 950 @@discount="onDiscount($event)"> 951 </add-to-basket-simple> 952 </footer> 953 </buying-component> 954 955 } 956 else 957 { 958 <footer> 959 <async-price class-type="asyncprice-plp" 960 :default-price="@relProduct.Price.PriceWithoutVAT.ToString(CultureInfo.InvariantCulture)" 961 :product='@relProductJson' 962 only-price="true" 963 :only-standard-price="@(Pageview.IsCurrentlyB2C().ToString().ToLower())" 964 standard-customer="@standardCustomer" /> 965 966 <add-to-basket-simple :product='@relProductJson' 967 :unit-of-measure="'PCS'" 968 button-class="btn btn-primary" 969 class="addtobasketsimple-plp ml-auto" 970 language-id="@languageId" 971 :price-without-vat="@relProduct.Price.PriceWithoutVAT.ToString(CultureInfo.InvariantCulture)" 972 :only-spare-parts="@((Pageview.User.OnlySpareParts() && !isSparePart).ToString().ToLower())" 973 :is-marketing-user="@(Pageview.User.OnlyView().ToString().ToLower())" 974 :ishvasuser="@(Pageview.User.IsHVACUser().ToString().ToLower())" 975 standard-customer="@standardCustomer"> 976 </add-to-basket-simple> 977 </footer> 978 } 979 </article> 980 } 981 </slick> 982 </template> 983 </section> 984 } 985 986 </div> 987 </product-details-simple-pim> 988