Error executing template "Designs/Plus/eCom/Productlist/Grouplist.cshtml"
System.NullReferenceException: Objektreferencen er ikke indstillet til en forekomst af et objekt.
ved CompiledRazorTemplates.Dynamic.RazorEngine_20ac2e57209b4202bff3300a707c51d7.Execute() i C:\inetpub\wwwroot\plus-live\Files\Templates\Designs\Plus\eCom\Productlist\Grouplist.cshtml:linje 421
ved RazorEngine.Templating.TemplateBase.RazorEngine.Templating.ITemplate.Run(ExecuteContext context, TextWriter reader)
ved RazorEngine.Templating.RazorEngineService.RunCompile(ITemplateKey key, TextWriter writer, Type modelType, Object model, DynamicViewBag viewBag)
ved RazorEngine.Templating.RazorEngineServiceExtensions.<>c__DisplayClass16_0.<RunCompile>b__0(TextWriter writer)
ved RazorEngine.Templating.RazorEngineServiceExtensions.WithWriter(Action`1 withWriter)
ved Dynamicweb.Rendering.RazorTemplateRenderingProvider.Render(Template template)
ved Dynamicweb.Rendering.TemplateRenderingService.Render(Template template)
ved Dynamicweb.Rendering.Template.RenderRazorTemplate()

1 @inherits Dynamicweb.Rendering.RazorTemplateBase<Dynamicweb.Rendering.RazorTemplateModel<Dynamicweb.Rendering.Template>> 2 @using System.Web; 3 @using Dynamicweb.Rendering; 4 @using Plus.Files; 5 6 @functions{ 7 8 string[] facetMaterial = string.IsNullOrEmpty(HttpContext.Current.Request.QueryString["Material"]) ? null : HttpContext.Current.Request.QueryString["Material"].Split(','); 9 string[] facetColor = string.IsNullOrEmpty(HttpContext.Current.Request.QueryString["Color"]) ? null : HttpContext.Current.Request.QueryString["Color"].Split(','); 10 string[] facetWidth = string.IsNullOrEmpty(HttpContext.Current.Request.QueryString["Width"]) ? null : HttpContext.Current.Request.QueryString["Width"].Split(','); 11 string[] facetHeight = string.IsNullOrEmpty(HttpContext.Current.Request.QueryString["Height"]) ? null : HttpContext.Current.Request.QueryString["Height"].Split(','); 12 string[] facetLength = string.IsNullOrEmpty(HttpContext.Current.Request.QueryString["Length"]) ? null : HttpContext.Current.Request.QueryString["Length"].Split(','); 13 string[] facetType = string.IsNullOrEmpty(HttpContext.Current.Request.QueryString["Type"]) ? null : HttpContext.Current.Request.QueryString["Type"].Split(','); 14 15 16 List<string[]> facets = new List<string[]>(); 17 18 19 20 } 21 @{ 22 Dynamicweb.Ecommerce.Products.Group group = Dynamicweb.Ecommerce.Products.Group.GetGroupById(GetString("Ecom:Group.ID")); 23 } 24 25 26 @if (group != null && group.IsTopGroup) 27 { 28 string tempSelected = ""; 29 if (facetMaterial != null) { facets.Add(facetMaterial); tempSelected = "Material"; } 30 if (facetColor != null) { facets.Add(facetColor); tempSelected = "Color"; } 31 if (facetWidth != null) { facets.Add(facetWidth); tempSelected = "Width"; } 32 if (facetHeight != null) { facets.Add(facetHeight); tempSelected = "Height"; } 33 if (facetLength != null) { facets.Add(facetLength); tempSelected = "Length"; } 34 if (facetType != null) { facets.Add(facetType); tempSelected = "Type"; } 35 36 37 if (facets.Count == 1) 38 { 39 HttpContext.Current.Session["PrimaryFacet"] = tempSelected; 40 } 41 if (facets.Count == 0) 42 { 43 HttpContext.Current.Session["PrimaryFacet"] = ""; 44 } 45 46 string primaryFacet = HttpContext.Current.Session["PrimaryFacet"].ToString(); 47 48 List<RazorTemplateBase<RazorTemplateModel<Template>>.LoopItem> productGroups = GetLoop("Childgroups").Where(g => 49 (facetMaterial == null || (facetMaterial.Any() && g.GetString("Ecom:Group:Field.ProductMaterial").Split(',').Any(t => facetMaterial.Contains(t.ToString())))) 50 && (facetColor == null || (facetColor.Any() && g.GetString("Ecom:Group:Field.ProductColor").Split(',').Any(t => facetColor.Contains(t.ToString())))) 51 && (facetWidth == null || (facetWidth.Any() && g.GetString("Ecom:Group:Field.WidthCm").Split(',').Any(t => facetWidth.Contains(t.ToString())))) 52 && (facetHeight == null || (facetHeight.Any() && g.GetString("Ecom:Group:Field.HeightCm").Split(',').Any(t => facetHeight.Contains(t.ToString())))) 53 && (facetLength == null || (facetLength.Any() && g.GetString("Ecom:Group:Field.LengthCm").Split(',').Any(t => facetLength.Contains(t.ToString())))) 54 && (facetType == null || (facetType.Any() && g.GetString("Ecom:Group:Field.ProductType").Split(',').Any(t => facetType.Contains(t.ToString())))) 55 ).ToList(); 56 //ProductColor ProductMaterial WidthCm HeightCm LengthCm 57 58 var matList = string.Join(",", productGroups.Select(g => g.GetString("Ecom:Group:Field.ProductMaterial")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 59 if (primaryFacet == "Material") 60 { 61 matList = string.Join(",", GetLoop("Childgroups").Select(g => g.GetString("Ecom:Group:Field.ProductMaterial")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 62 } 63 var colList = string.Join(",", productGroups.Select(g => g.GetString("Ecom:Group:Field.ProductColor")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 64 if (primaryFacet == "Color") 65 { 66 colList = string.Join(",", GetLoop("Childgroups").Select(g => g.GetString("Ecom:Group:Field.ProductColor")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 67 } 68 var widthList = string.Join(",", productGroups.Select(g => g.GetString("Ecom:Group:Field.WidthCm")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 69 if (primaryFacet == "Width") 70 { 71 widthList = string.Join(",", GetLoop("Childgroups").Select(g => g.GetString("Ecom:Group:Field.WidthCm")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 72 } 73 widthList = widthList.Select(s => 74 { 75 int i = 0; 76 int.TryParse(s.Trim(), out i); 77 return i; 78 }).OrderByDescending(i => i).Distinct().Where(i => !i.Equals(0)).Select(i => i.ToString()); 79 80 var lengthList = string.Join(",", productGroups.Select(g => g.GetString("Ecom:Group:Field.LengthCm")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 81 if (primaryFacet == "Length") 82 { 83 lengthList = string.Join(",", GetLoop("Childgroups").Select(g => g.GetString("Ecom:Group:Field.LengthCm")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 84 } 85 lengthList = lengthList.Select(s => 86 { 87 int i = 0; 88 int.TryParse(s.Trim(), out i); 89 return i; 90 }).OrderByDescending(i => i).Distinct().Where(i => !i.Equals(0)).Select(i => i.ToString()); 91 92 var heightList = string.Join(",", productGroups.Select(g => g.GetString("Ecom:Group:Field.HeightCm")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 93 if (primaryFacet == "Height") 94 { 95 heightList = string.Join(",", GetLoop("Childgroups").Select(g => g.GetString("Ecom:Group:Field.HeightCm")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 96 } 97 heightList = heightList.Select(s => 98 { 99 int i = 0; 100 int.TryParse(s.Trim(), out i); 101 return i; 102 }).OrderByDescending(i => i).Distinct().Where(i => !i.Equals(0)).Select(i => i.ToString()); 103104 var typeList = string.Join(",", productGroups.Select(g => g.GetString("Ecom:Group:Field.ProductType")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 105 if (primaryFacet == "Type") 106 { 107 typeList = string.Join(",", GetLoop("Childgroups").Select(g => g.GetString("Ecom:Group:Field.ProductType")).Distinct()).Split(',').Where(s => !string.IsNullOrEmpty(s)).Distinct(); 108 } 109110 int groupCount = productGroups.Count(); 111112113 //Breadcrumb 114 string frontpageName = Pageview.Area.Item.FirstOrDefault(i => i.Key == "Frontpage_Name").Value.ToString(); 115 string frontpageLink = Pageview.Area.Item.FirstOrDefault(i => i.Key == "Base_Link").Value.ToString(); 116 <ul class="link-list link-list--breadcrumb"> 117 <nav class="breadcrumb"> 118 <div class="grid-container grid-container--site-width"> 119 <div class="grid-row "> 120 <div class="grid-column "> 121 <ul class="link-list link-list--breadcrumb"> 122 <li class="link-list__item "> 123 <a property="url" class="link-list__link " href="@frontpageLink"> 124 @(frontpageName) 125 </a> 126 </li> 127 <li class="link-list__item "> 128 @GetString("Ecom:Group.Name") 129 </li> 130 </ul> 131 </div> 132 </div> 133 </div> 134 </nav> 135 </ul> 136 //Header 137 if (!string.IsNullOrWhiteSpace(GetString("Ecom:Group:Field.groupHeader"))) 138 { 139 <section class="grid-page-header "> 140 <div class="grid-container grid-container--site-width"> 141 <div class="grid-row grid-row--two-columns "> 142 <div class="grid-column "> 143 <div class="grid-page-header__content"> 144 <h1 class="heading heading--main">@GetString("Ecom:Group:Field.groupHeader")</h1> 145 </div> 146 </div> 147 <div class="grid-column "> 148 @GetString("Ecom:Group:Field.groupLongDescription") 149 </div> 150 </div> 151 </div> 152 </section> 153 } 154 //Filter 155 <section class="filter-bar"> 156 <div class="grid-container grid-container--site-width"> 157 <div class="filter-bar__inner"> 158159 <ul class="filter-bar__list" id="filter-bar__list" data-groupid="@GetString("Ecom:Group.ID")" data-path="@Dynamicweb.Frontend.SearchEngineFriendlyURLs.GetFriendlyUrl("default.aspx?id=" + Pageview.Area.Item.FirstOrDefault(i => i.Key == "GroupsFilterPageId").Value.ToString())"> 160 @if (typeList.Any()) 161 { 162 <li class="filter-bar__item"> 163 <div class="filter filter--checkbox filter--default"> 164 <div class="filter__chosen"> 165 <span class="filter__default-header">@Translate("Vælg type", "Vælg type")</span> 166 <span class="filter__chosen-header">@Translate("Type", "Type"): </span> 167 <span class="filter__chosen-items"></span> 168 </div> 169 <div class="filter__options"> 170 <span class="filter__close"></span> 171 <div class="filter__options-inner"> 172 <div class="filter__options-content"> 173 <div class="filter__options-header">@Translate("Vælg type", "Vælg type")</div> 174 <ul class="filter__list"> 175 @foreach (var type in typeList) 176 { 177 <li class="filter__item"> 178 <input type="checkbox" onchange="updateGroupList()" name="Type" id="Type-@type" class="filter__input" value="@type" @(facetType != null && facetType.Contains(type) ? "checked=\"checked\"" : "")> 179 <label for="Type-@type" class="filter__label">@Translate(type, type)</label> 180 </li> 181 } 182 </ul> 183 </div> 184 </div> 185 </div> 186 </div> 187 </li> 188 } 189 @if (matList.Any()) 190 { 191 <li class="filter-bar__item"> 192 <div class="filter filter--checkbox filter--default"> 193 <div class="filter__chosen"> 194 <span class="filter__default-header">@Translate("Vælg materiale", "Vælg materiale")</span> 195 <span class="filter__chosen-header">@Translate("Materiale", "Materiale"): </span> 196 <span class="filter__chosen-items"></span> 197 </div> 198 <div class="filter__options"> 199 <span class="filter__close"></span> 200 <div class="filter__options-inner"> 201 <div class="filter__options-content"> 202 <div class="filter__options-header">@Translate("Vælg materiale", "Vælg materiale")</div> 203 <ul class="filter__list"> 204 @foreach (var mat in matList) 205 { 206 <li class="filter__item"> 207 <input type="checkbox" onchange="updateGroupList()" name="Material" id="Material-@mat" class="filter__input" value="@mat" @(facetMaterial != null && facetMaterial.Contains(mat) ? "checked=\"checked\"" : "")> 208 <label for="Material-@mat" class="filter__label">@Translate(mat, mat)</label> 209 </li> 210 } 211 </ul> 212 </div> 213 </div> 214 </div> 215 </div> 216 </li> 217 } 218 @if (colList.Any()) 219 { 220 <li class="filter-bar__item"> 221 <div class="filter filter--checkbox filter--default"> 222 <div class="filter__chosen"> 223 <span class="filter__default-header">@Translate("Vælg farve", "Vælg farve")</span> 224 <span class="filter__chosen-header">@Translate("Farve", "Farve"): </span> 225 <span class="filter__chosen-items"></span> 226 </div> 227 <div class="filter__options"> 228 <span class="filter__close"></span> 229 <div class="filter__options-inner"> 230 <div class="filter__options-content"> 231 <div class="filter__options-header">@Translate("Vælg farve", "Vælg farve")</div> 232 <ul class="filter__list"> 233 @foreach (var col in colList) 234 { 235 <li class="filter__item"> 236 <input type="checkbox" onchange="updateGroupList()" name="Color" id="Color-@col" class="filter__input" value="@col" @(facetColor != null && facetColor.Contains(col) ? "checked=\"checked\"" : "")> 237 <label for="Color-@col" class="filter__label">@Translate(col, col)</label> 238 </li> 239 } 240 </ul> 241 </div> 242 </div> 243 </div> 244 </div> 245 </li> 246 } 247 @if (widthList.Any()) 248 { 249 <li class="filter-bar__item"> 250 <div class="filter filter--checkbox filter--default"> 251 <div class="filter__chosen"> 252 <span class="filter__default-header">@Translate("Vælg bredde", "Vælg bredde")</span> 253 <span class="filter__chosen-header">@Translate("Bredde", "Bredde"): </span> 254 <span class="filter__chosen-items"></span> 255 </div> 256 <div class="filter__options"> 257 <span class="filter__close"></span> 258 <div class="filter__options-inner"> 259 <div class="filter__options-content"> 260 <div class="filter__options-header">@Translate("Vælg bredde", "Vælg bredde")</div> 261 <ul class="filter__list"> 262 @foreach (var width in widthList) 263 { 264 <li class="filter__item"> 265 <input type="checkbox" onchange="updateGroupList()" name="Width" id="Width-@width" class="filter__input" value="@width" @(facetWidth != null && facetWidth.Contains(width) ? "checked=\"checked\"" : "")> 266 <label for="Width-@width" class="filter__label">@width</label> 267 </li> 268 } 269 </ul> 270 </div> 271 </div> 272 </div> 273 </div> 274 </li> 275 } 276 @if (heightList.Any()) 277 { 278 <li class="filter-bar__item"> 279 <div class="filter filter--checkbox filter--default"> 280 <div class="filter__chosen"> 281 <span class="filter__default-header">@Translate("Vælg højde", "Vælg højde")</span> 282 <span class="filter__chosen-header">@Translate("Højde", "Højde"): </span> 283 <span class="filter__chosen-items"></span> 284 </div> 285 <div class="filter__options"> 286 <span class="filter__close"></span> 287 <div class="filter__options-inner"> 288 <div class="filter__options-content"> 289 <div class="filter__options-header">@Translate("Vælg højde", "Vælg højde")</div> 290 <ul class="filter__list"> 291 @foreach (var height in heightList) 292 { 293 <li class="filter__item"> 294 <input type="checkbox" onchange="updateGroupList()" name="Height" id="Height-@height" class="filter__input" value="@height" @(facetHeight != null && facetHeight.Contains(height) ? "checked=\"checked\"" : "")> 295 <label for="Height-@height" class="filter__label">@height</label> 296 </li> 297 } 298 </ul> 299 </div> 300 </div> 301 </div> 302 </div> 303 </li> 304 } 305 @if (lengthList.Any()) 306 { 307 <li class="filter-bar__item"> 308 <div class="filter filter--checkbox filter--default"> 309 <div class="filter__chosen"> 310 <span class="filter__default-header">@Translate("Vælg længde", "Vælg længde")</span> 311 <span class="filter__chosen-header">@Translate("Længde", "Længde"): </span> 312 <span class="filter__chosen-items"></span> 313 </div> 314 <div class="filter__options"> 315 <span class="filter__close"></span> 316 <div class="filter__options-inner"> 317 <div class="filter__options-content"> 318 <div class="filter__options-header">@Translate("Vælg længde", "Vælg længde")</div> 319 <ul class="filter__list"> 320 @foreach (var length in lengthList) 321 { 322 <li class="filter__item"> 323 <input type="checkbox" onchange="updateGroupList()" name="Length" id="Length-@length" class="filter__input" value="@length" @(facetLength != null && facetLength.Contains(length) ? "checked=\"checked\"" : "")> 324 <label for="Length-@length" class="filter__label">@length</label> 325 </li> 326 } 327 </ul> 328 </div> 329 </div> 330 </div> 331 </div> 332 </li> 333 } 334 </ul> 335336 <div class="filter-bar__result-info"> 337 <div class="filter-result-amount">@groupCount @Translate("produktserier", "produktserier")</div> 338339 </div> 340 </div> 341 </div> 342 </section> 343 //Groups list 344 <section class="list-cards-simple list-cards-simple--3cols"> 345 <div class="grid-container grid-container--site-width"> 346 <ul class="grid-row grid-row--three-columns-113333 list-cards-simple__list"> 347 @DisplayGroups(productGroups) 348 </ul> 349 </div> 350 </section> 351 } 352 else 353 { 354 //Top image 355 string topImage = GetString("Ecom:Group:Field.groupBannerImage.Clean").Replace(" ", "%20"); 356 if (!string.IsNullOrWhiteSpace(topImage)) 357 { 358 <section class="full-width-banner full-width-banner--top"> 359 <div class="full-width-banner__fallback full-width-banner__fallback--mobile"> 360 <div class="full-width-banner__fallback-image" style="background-image: url(@topImage?mode=crop&width=767&quality=80);"></div> 361 </div> 362 <div class="full-width-banner__fallback full-width-banner__fallback--tablet"> 363 <div class="full-width-banner__fallback-image" style="background-image: url(@topImage?mode=crop&width=1199&quality=80);"></div> 364 </div> 365 <div class="full-width-banner__fallback full-width-banner__fallback--desktop"> 366 <div class="full-width-banner__fallback-image" style="background-image: url(@topImage?mode=crop&width=2000&quality=80);"></div> 367 </div> 368 <div class="full-width-banner__bg-holder"> 369 <div class="full-width-banner__bg lazyload" data-bgset="@topImage?mode=crop&amp;width&#x3D;575&quality=80 [(max-width: 575px)] | @topImage?mode=crop&amp;width&#x3D;767&quality=80 [(max-width: 767px)] | @topImage?mode=crop&amp;width&#x3D;991&quality=80 [(max-width: 991px)] | @topImage?mode=crop&amp;width&#x3D;1199&quality=80 [(max-width: 1199px)] | @topImage?mode=crop&amp;width&#x3D;1399&quality=80 [(max-width: 1399px)] | @topImage?mode=crop&amp;width&#x3D;1599&quality=80 [(max-width: 1599x)] | @topImage?mode=crop&amp;width&#x3D;2000&quality=80" data-sizes="auto"></div> 370 </div> 371 <div class="grid-container grid-container--site-width-fh"> 372 <div class="full-width-banner__content"> 373 <div class="grid-row grid-row--two-columns"> 374 <div class="grid-column"> 375 @if (!string.IsNullOrWhiteSpace(GetString("Ecom:Group:Field.groupBannerPreHeader"))) 376 { 377 <p class="preheading preheading--fw-banner">@GetString("Ecom:Group:Field.groupBannerPreHeader")</p> 378 } 379 <h1 class="heading heading--main heading--main-fw-banner-top">@GetString("Ecom:Group:Field.groupBannerHeader")</h1> 380 <div class="body-text body-text--fw-banner-top"> 381 <p>@GetString("Ecom:Group:Field.GroupBannerText")</p> 382 </div> 383384385 @if (GetString("Ecom:Group:Field.groupBannerButton1Link") != "") 386 { 387 <a href="@GetString("Ecom:Group:Field.groupBannerButton1Link")" class="button button--fw-banner"> 388 <span class="button__text">@GetString("Ecom:Group:Field.groupBannerButton1Text")</span> 389 </a> 390 } 391 @if (GetString("Ecom:Group:Field.groupBannerButton2Link") != "") 392 { 393 <a href="@GetString("Ecom:Group:Field.groupBannerButton2Link")" class="button button--arrow button--fw-banner"> 394 <span class="button__text">@GetString("Ecom:Group:Field.groupBannerButton2Text")</span><span class="arrow arrow--right "></span> 395 </a> 396 } 397398399400 </div> 401 </div> 402 </div> 403 </div> 404 </section> 405 } 406 //Breadcrumb 407 string productPageId = Pageview.Area.Item.FirstOrDefault(i => i.Key == "ProductPageId").Value.ToString(); 408 string frontpageName = Pageview.Area.Item.FirstOrDefault(i => i.Key == "Frontpage_Name").Value.ToString(); 409 string frontpageLink = Pageview.Area.Item.FirstOrDefault(i => i.Key == "Base_Link").Value.ToString(); 410 <ul class="link-list link-list--breadcrumb"> 411 <nav class="breadcrumb"> 412 <div class="grid-container grid-container--site-width"> 413 <div class="grid-row "> 414 <div class="grid-column "> 415 <ul class="link-list link-list--breadcrumb"> 416 <li class="link-list__item "> 417 <a property="url" class="link-list__link " href="@frontpageLink"> 418 @(frontpageName) 419 </a> 420 </li> 421 @foreach (var subGroup in group.ParentGroups) 422 { 423 string groupLink = "Default.aspx?ID=" + productPageId + "&GroupID=" + subGroup.Id; 424 <li class="link-list__item "> 425 <a property="url" class="link-list__link " href="@groupLink"> 426 @subGroup.Name 427 </a> 428 </li> 429 } 430 <li class="link-list__item "> 431 @GetString("Ecom:Group.Name") 432 </li> 433 </ul> 434 </div> 435 </div> 436 </div> 437 </nav> 438 </ul> 439440441 //Downloads 442 if (Dynamicweb.Security.UserManagement.User.IsExtranetUserLoggedIn()) 443 { 444 <section class="downloads"> 445 <div class="grid-container grid-container--site-width"> 446447 <ul class="downloads-list"> 448 <li class="downloads-list__item"> 449 <input type="hidden" id="productsIDs" value="@string.Join(",", group.Products.Select(p => p.Id).ToArray())" /> 450 <label for="selectCustomFileNameTypes" class="downloads-list__label">@Translate("Hent billeder for alle produkter i gruppen (zip-fil)", "Hent billeder for alle produkter i gruppen (.zip-fil):")</label> 451 <div class="select-custom"> 452 <input type="checkbox" class="select-custom__check" id="selectCustomFileNameTypes" /> 453 <label for="selectCustomFileNameTypes" class="select-custom__selected-item" title="@Translate("Vælg type af filnavn", "Vælg type af filnavn")"> 454 <span class="select-custom__selected-item-text"> 455 @Translate("Vælg type af filnavn", "Vælg type af filnavn") <span class="select-custom__icon"> 456 <svg class="select-custom__svg"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/icons/icons.svg#arrow-down"></use></svg> 457458459 </span> 460 </span> 461 </label> 462 <div class="select-custom__option-holder"> 463 <ul class="link-list link-list--custom-select"> 464 <li class="link-list__item "> 465 <a href="#" title="@Translate("EAN nummer", "EAN nummer")" class="link--custom-select " imagetype="ean" property="url">@Translate("EAN nummer", "EAN nummer")</a> 466 </li> 467 <li class="link-list__item "> 468 <a href="#" title="@Translate("DB nummer", "DB nummer")" class="link--custom-select " imagetype="db" property="url">@Translate("DB nummer", "DB nummer")</a> 469 </li> 470 <li class="link-list__item "> 471 <a href="#" title="@Translate("PLUS nummer", "PLUS nummer")" class="link--custom-select " imagetype="plus" property="url">@Translate("PLUS nummer", "PLUS nummer")</a> 472 </li> 473 <li class="link-list__item "> 474 <a href="#" title="@Translate("PLUS + Varenavn + vejl pris", "PLUS + Varenavn + vejl pris")" class="link--custom-select " imagetype="presse" property="url">@Translate("PLUS + Varenavn + vejl pris", "PLUS + Varenavn + vejl pris")</a> 475 </li> 476 </ul> 477 </div> 478 </div> 479480 </li> 481 <li class="downloads-list__item"> 482 <a href="#" title="@Translate("Hent produktinfo for alle produkter i gruppen (.xml-fil)", "Hent produktinfo for alle produkter i gruppen (.xml-fil)")" class="downloads-list__link " property="url">@Translate("Hent produktinfo for alle produkter i gruppen (.xml-fil)", "Hent produktinfo for alle produkter i gruppen (.xml-fil)")</a> 483 </li> 484 </ul> 485 </div> 486 </section> 487 } 488489 //Description 490 <section class="text-text-facts"> 491 <div class="grid-container grid-container--site-width"> 492 <div class="grid-row grid-row--three-columns-122333 "> 493 <div class="grid-column "> 494 <h3 class="heading heading--fw-element">@GetString("Ecom:Group:Field.groupDescriptionHeaderColumn1")</h3> 495 <div class="body-text "> 496 @GetString("Ecom:Group:Field.groupDescriptionTextColumn1") 497 </div> 498 </div> 499 <div class="grid-column grid-column--2"> 500 <div class="grid-row grid-row--two-columns-111222 grid-column--2"> 501 <div class="grid-column "> 502 <div class="text-text-facts__small-content"> 503 <h4 class="heading heading--small heading--small-text-col2">@GetString("Ecom:Group:Field.groupDescriptionHeaderColumn2")</h4> 504 <div class="body-text body-text--text-col2"> 505 @GetString("Ecom:Group:Field.groupDescriptionTextColumn2") 506 </div> 507 </div> 508 </div> 509 <div class="grid-column "> 510 @if (!string.IsNullOrWhiteSpace(GetString("Ecom:Group:Field.groupDescriptionFactboxColumn3"))) 511 { 512 <div class="facts-box "> 513 <div class="body-text body-text--facts-box"> 514 @GetString("Ecom:Group:Field.groupDescriptionFactboxColumn3") 515 </div> 516 </div> 517 } 518 </div> 519 </div> 520 </div> 521 </div> 522 </div> 523 </section> 524 <section class="divider "> 525 <span class="divider__icon"> 526 <svg class="divider__svg"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/frontend/dist/icons/icons.svg#logo"></use></svg> 527 </span> 528 </section> 529530531532533534 foreach (var subgroups in GetLoop("Subgroups").Where(sg => sg.GetString("Ecom:Group:Field.categoryType") == "BOMProducts")) 535 { 536 //BOM products 537538 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.BOMListHeader"))) 539 { 540 <section class="grid-sub-header "> 541 <div class="grid-container grid-container--site-width"> 542543 <div class="grid-row "> 544 <div class="grid-column "> 545 <div class="grid-sub-header__content"> 546 <h2 class="heading heading--sub heading--centered">@GetString("Ecom:Group:Field.BOMListHeader")</h2> 547 <p class="teaser teaser--centered">@GetString("Ecom:Group:Field.BOMListText")</p> 548 </div> 549 </div> 550551 </div> 552553 </div> 554 </section> 555 } 556557558 var bomProductList = Dynamicweb.Ecommerce.Products.Group.GetGroupById(subgroups.GetString("Ecom:Group.ID")); 559 @DisplayBOMProductList(bomProductList, productPageId) 560561 <section class="divider "> 562 <span class="divider__icon"> 563 <svg class="divider__svg"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/frontend/dist/icons/icons.svg#logo"></use></svg> 564 </span> 565 </section> 566567 } 568569 //Products 570 //var productList = Dynamicweb.Ecommerce.Products.Group.GetGroupById(GetString("Ecom:Group.ID")); 571 Dynamicweb.Ecommerce.Products.GroupService g = new Dynamicweb.Ecommerce.Products.GroupService(); 572 var productList = g.GetGroup(GetString("Ecom:Group.ID")); 573574 if (productList.Products.Count() > 0) 575 { 576 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.ProductListHeader"))) 577 { 578 <a name="products" id="products"></a> 579 <section class="grid-sub-header "> 580 <div class="grid-container grid-container--site-width"> 581 <div class="grid-row "> 582 <div class="grid-column "> 583 <div class="grid-sub-header__content"> 584 <h2 class="heading heading--sub heading--centered">@GetString("Ecom:Group:Field.ProductListHeader")</h2> 585 <p class="teaser teaser--centered">@GetString("Ecom:Group:Field.ProductListText")</p> 586 </div> 587 </div> 588 </div> 589 </div> 590 </section> 591 } 592 @DisplayProductList(productList, productPageId) 593 } 594595 // Subgroups - minus BOM 596597 foreach (var subgroups in GetLoop("Subgroups").Where(sg => sg.GetString("Ecom:Group:Field.categoryType") != "BOMProducts")) 598 { 599600 if (!String.IsNullOrEmpty(subgroups.GetString("Ecom:Group:Field.groupHeader"))) 601 { 602 <section class="grid-sub-header "> 603 <div class="grid-container grid-container--site-width"> 604 <div class="grid-row "> 605 <div class="grid-column "> 606 <div class="grid-sub-header__content"> 607 <h2 class="heading heading--sub heading--centered">@subgroups.GetString("Ecom:Group:Field.groupHeader")</h2> 608 <p class="teaser teaser--centered">@subgroups.GetString("Ecom:Group:Field.ProductListText")</p> 609 </div> 610 </div> 611 </div> 612 </div> 613 </section> 614615 var subProductList = Dynamicweb.Ecommerce.Products.Group.GetGroupById(subgroups.GetString("Ecom:Group.ID")); 616 @DisplayProductList(subProductList, productPageId) 617618 <section class="divider "> 619 <span class="divider__icon"> 620 <svg class="divider__svg"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/frontend/dist/icons/icons.svg#logo"></use></svg> 621 </span> 622 </section> 623 } 624 } 625626627628 //Accessories 629630 var accessoriesList = new List<Dynamicweb.Ecommerce.Products.Product>(); 631 var tempList = new List<string>(); 632 foreach (var p in productList.Products) 633 { 634 tempList.AddRange(p.RelatedProducts().Where(rp => rp.RelatedGroupId == "Addon").Select(pr => pr.Product.Id).ToList()); 635 } 636 accessoriesList = Dynamicweb.Ecommerce.Products.Product.GetProductsByProductIDs(tempList.ToArray(), false, Pageview.Area.EcomLanguageId).ToList(); 637 accessoriesList = accessoriesList.Where(p => p.Active == true).ToList(); 638 if (accessoriesList.Count > 0) 639 { 640 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.AccessoriesListHeader"))) 641 { 642 <a name="accessories" id="accessories"></a> 643 <section class="grid-sub-header "> 644 <div class="grid-container grid-container--site-width"> 645 <div class="grid-row "> 646 <div class="grid-column "> 647 <div class="grid-sub-header__content"> 648 <h2 class="heading heading--sub heading--centered">@GetString("Ecom:Group:Field.AccessoriesListHeader")</h2> 649 <p class="teaser teaser--centered">@GetString("Ecom:Group:Field.AccessoriesListText")</p> 650 </div> 651 </div> 652 </div> 653 </div> 654 </section> 655 } 656657 @DisplayProductList(null, productPageId, accessoriesList) 658659 } 660661 //Gallery 662 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image1.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image2.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image3.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image4.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image5.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image6.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image7.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image8.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image9.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image10.Clean")) || !String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image11.Clean"))) 663 { 664 <section class="gallery"> 665 <div class="grid-container grid-container--site-width"> 666 <ul class="gallery__list" id="gallery"> 667 @{ 668 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image1.Clean"))) 669 { 670 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image1.Clean")) 671 } 672 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image2.Clean"))) 673 { 674 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image2.Clean")) 675676 } 677 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image3.Clean"))) 678 { 679 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image3.Clean")) 680681 } 682 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image4.Clean"))) 683 { 684 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image4.Clean")) 685686 } 687 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image5.Clean"))) 688 { 689 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image5.Clean")) 690691 } 692 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image6.Clean"))) 693 { 694 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image6.Clean")) 695696 } 697 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image7.Clean"))) 698 { 699 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image7.Clean")) 700701 } 702 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image8.Clean"))) 703 { 704 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image8.Clean")) 705706 } 707 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image9.Clean"))) 708 { 709 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image9.Clean")) 710711 } 712 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image10.Clean"))) 713 { 714 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image10.Clean")) 715716 } 717 if (!String.IsNullOrEmpty(GetString("Ecom:Group:Field.Image11.Clean"))) 718 { 719 @DisplayGalleryImage(GetString("Ecom:Group:Field.Image11.Clean")) 720 } 721 } 722 </ul> 723 <button class="gallery__nav-button gallery__nav-button--prev"> 724 <span class="arrow arrow--left arrow--show-always"></span> 725 </button> 726 <button class="gallery__nav-button gallery__nav-button--next"> 727 <span class="arrow arrow--right arrow--show-always"></span> 728 </button> 729 <span class="gallery__counter-box"> 730 <span class="gallery__counter"></span>/<span class="gallery__sum"></span> 731 </span> 732 </div> 733 <div class="gallery__overlay-tags"> 734 <ul class="gallery-overlay__list"></ul> 735 <!-- important: arrow buttons must be above all other buttons inside gallery__overlay-tags --> 736 <button type="button" class="button button--ghost button--ghost-thin button--large button--slideshow button--color-gray " property="url"> 737 <span class="button__text"></span><span class="arrow arrow--left arrow--show-always"></span> 738 </button> 739 <button type="button" class="button button--ghost button--ghost-thin button--large button--slideshow button--color-gray " property="url"> 740 <span class="button__text"></span><span class="arrow arrow--right arrow--show-always"></span> 741 </button> 742 <button class="gallery-overlay__close" type="button"> 743 <span class="gallery-overlay__close-text">Luk (esc)</span> 744 <span class="gallery-overlay__x"></span> 745 </button> 746 <span class="gallery-overlay__counter-item"> 747 <span class="gallery-overlay__count"></span>/<span class="gallery-overlay__sum"></span> 748 </span> 749 </div> 750 </section> 751 } 752 } 753754 @helper DisplayGroups(List<LoopItem> productGroups) 755 { 756757 foreach (var group in productGroups) 758 { 759 string image = group.GetString("Ecom:Group.LargeImage").Replace(" ", "%20"); 760 string productPageId = Pageview.Area.Item.FirstOrDefault(i => i.Key == "ProductPageId").Value.ToString(); 761 string groupLink = "Default.aspx?ID=" + productPageId + "&GroupID=" + group.GetString("Ecom:Group.ID"); 762763 if (string.IsNullOrWhiteSpace(image)) 764 { 765 image = "/Files/Images/Ecommerce/Products/no-image.jpeg"; 766 } 767768 <li class="grid-column list-cards-simple__item"> 769 <article class="card-simple"> 770 <a href="@groupLink" title="@Translate("Se mulighederne", "Se mulighederne")" class="card-simple__link" property="url"> 771 <figure vocab="http://schema.org/" typeof="ImageObject" class="image-lazyload__figure"> 772 <img class="lazyload image-lazyload__image " src="" alt="@group.GetString("Ecom:Group.Name")" property="contentUrl" data-src="@image?mode=crop&width=535&height=535&quality=80" 773 data-query-obj='{ "mode":"crop" }' data-srcset="@image?mode=crop&width=431&height=431&quality=80 431w, 774 @image?mode=crop&width=360&height=360&quality=80 360w, 775 @image?mode=crop&width=294&height=294&quality=80 294w, 776 @image?mode=crop&width=220&height=220&quality=80 220w, 777 @image?mode=crop&width=727&height=727&quality=80 727w, 778 @image?mode=crop&width=535&height=535&quality=80 535w, 779 @image?mode=crop&width=424&height=424&quality=80 424w, 780 @image?mode=crop&width=280&height=280&quality=80 280w" sizes="(min-width: 1400px) 431px, 781 (min-width: 1200px) 360px, 782 (min-width: 992px) 294px, 783 (min-width: 768px) 220px, 784 (min-width: 576px) 727px, 785 (min-width: 465px) 535px, 786 (min-width: 321px) 424px, 787 (min-width: 320px) 280px"> 788 <noscript><img src="@image?mode=crop&width=535&quality=80" alt="@group.GetString("Ecom:Group.Name")"></noscript> 789 </figure> 790 <!-- <h3 class="heading heading--col-element">@group.GetString("Ecom:Group.Name")</h3> --> 791 <h2 class="heading heading--col-element">@group.GetString("Ecom:Group.Name")</h2> 792 <div class="body-text body-text--card-std"> 793 @group.GetString("Ecom:Group:Field.groupTeaser") 794 </div> 795 <button class="button button--arrow button--color-puff"> 796 <span class="button__text">@Translate("Se mulighederne", "Se mulighederne")</span><span class="arrow arrow--right "></span> 797 </button> 798 </a> 799 </article> 800 </li> 801 } 802 } 803 @helper DisplayGalleryImage(string image) 804 { 805806 <li class="gallery__item"> 807 <a href="@image?width=300" data-gallery="" class="gallery__link"> 808 <figure vocab="http://schema.org/" typeof="ImageObject" class="image-lazyload__figure image-lazyload__figure--gallery "> 809 <img class="lazyload image-lazyload__image lazyload-bg-special image-lazyload__image--gallery" src="" property="contentUrl" data-src="@image?mode=crop&width=535&quality=80" 810 data-query-obj='{ "mode":"crop" }' data-srcset="@image?mode=crop&width=438&quality=80 438w, 811 @image?mode=crop&width=367&quality=80 367w, 812 @image?mode=crop&width=300&quality=80 300w, 813 @image?mode=crop&width=227&quality=80 227w, 814 @image?mode=crop&width=364&quality=80 364w, 815 @image?mode=crop&width=535&quality=80 535w, 816 @image?mode=crop&width=424&quality=80 424w, 817 @image?mode=crop&width=280&quality=80 280w" sizes="(min-width: 1400px) 438px, 818 (min-width: 1200px) 367px, 819 (min-width: 992px) 300px, 820 (min-width: 768px) 227px, 821 (min-width: 576px) 364px, 822 (min-width: 465px) 535px, 823 (min-width: 321px) 424px, 824 (min-width: 320px) 280px"> 825 <noscript><img src="@image?mode=crop&width=535&quality=80"></noscript> 826 </figure> 827 </a> 828 </li> 829 } 830831 @helper DisplayBOMProductList(Dynamicweb.Ecommerce.Products.Group bomProductList, string productPageId) 832 { 833 string baseUrl = Pageview.Area.Item.FirstOrDefault(i => i.Key == "Base_Link").Value.ToString(); 834835 string hidePrices = Pageview.Area.Item["Hide_Prices"].ToString(); 836837 var prods = bomProductList.Products; 838839 var filProds = prods.Where(p => p.Number.Split('-').Last() == "1" || p.ProductFieldValues.GetProductFieldValue("PrimaryBOM").Value.ToString() != "False"); 840841 var tempProds = filProds.Where(p => bool.Parse(p.ProductFieldValues.GetProductFieldValue("PrimaryBOM").Value.ToString()) == true && p.Number.Split('-').Last() != "1"); 842843 if (tempProds.Any()) 844 { 845846 foreach (var tP in tempProds) 847 { 848 var baseID = tP.Number.Split('-'); 849 string remId = string.Join("-", string.Join("-", baseID.Take(baseID.Length - 1).ToArray()), "1"); 850 filProds = filProds.Where(p => p.Number != remId); 851 } 852 } 853854 <section class="parts-list-element parts-list-element--3cols"> 855 <div class="grid-container grid-container--site-width"> 856 <ul class="grid-row grid-row--three-columns-113333 parts-list-element__list"> 857858 @foreach (Dynamicweb.Ecommerce.Products.Product bomProduct in filProds) 859 { 860 var productsNotInStock = new List<Dynamicweb.Ecommerce.Products.Product>(); 861 string prodId = bomProduct.Id; 862 string prodName = bomProduct.Name; 863 string prodImage = bomProduct.ImageLarge.Replace(" ", "%20"); 864865866 if (string.IsNullOrWhiteSpace(prodImage)) 867 { 868 prodImage = "/Files/Images/Ecommerce/Products/no-image.jpeg"; 869 } 870 else 871 { 872 prodImage = "/files" + prodImage; 873 } 874 string GID = ""; 875 // GID = "&groupid=" + bomProduct.DefaultGroup.Id; 876 string prodLink = Dynamicweb.Frontend.SearchEngineFriendlyURLs.GetFriendlyUrl("default.aspx?id=" + productPageId + GID + "&productId=" + prodId); 877 string prodCurrency = bomProduct.Price.Currency.Code; 878879880 string BOMMountType = ""; 881 double BOMMountTypeTotalPrice = 0; 882 string BOMProductIdList = ""; 883 string BOMProductQuantityList = ""; 884885 BOMMountType = bomProduct.GetProductFieldValue("BOMProductListDefault").ToString(); 886887 string BOMProductInfoInclusive1 = bomProduct.GetProductFieldValue("BOMProductInfoInclusive1").ToString(); 888 string BOMProductInfoInclusive2 = bomProduct.GetProductFieldValue("BOMProductInfoInclusive2").ToString(); 889 string BOMProductInfoInclusive3 = bomProduct.GetProductFieldValue("BOMProductInfoInclusive3").ToString(); 890891 foreach (var item in bomProduct.Items) 892 { 893 var bomProd = Dynamicweb.Ecommerce.Products.Product.GetProductById(item.BomProductId); 894 if (bomProd.Stock < 1) 895 { 896 if ((bomProd.GetProductFieldValue("ProductNextBackorderDate") is DateTime && (DateTime)bomProd.GetProductFieldValue("ProductNextBackorderDate") > DateTime.Now) || !(bomProd.GetProductFieldValue("ProductNextBackorderDate") is DateTime)) 897 { 898 productsNotInStock.Add(bomProd); 899 } 900 } 901 if (string.IsNullOrWhiteSpace(BOMProductIdList)) 902 { 903 BOMProductIdList = bomProd.Id; 904 } 905 else 906 { 907 BOMProductIdList = BOMProductIdList + "," + bomProd.Id; 908 } 909 if (string.IsNullOrWhiteSpace(BOMProductQuantityList)) 910 { 911 BOMProductQuantityList = item.Quantity.ToString(); 912 } 913 else 914 { 915 BOMProductQuantityList = BOMProductQuantityList + "," + item.Quantity; 916 } 917918 BOMMountTypeTotalPrice = BOMMountTypeTotalPrice + (bomProd.Price.PriceWithVAT * item.Quantity); 919 } 920921922 <li class="grid-column parts-list-element__item"> 923 <article class="card-parts-list card-parts-list--3cols"> 924 <div class="card-parts-list__image"> 925 <a href="@prodLink" title="@prodName" class="" property="url"> 926 <figure vocab="http://schema.org/" typeof="ImageObject" class="image-lazyload__figure "> 927 <img class="lazyload image-lazyload__image " src="" alt="@prodName" property="contentUrl" data-src="@prodImage?mode=crop&width=776&height=776&quality=80" 928 data-query-obj='{ "mode":"crop" }' data-srcset="@prodImage?mode=crop&width=431&height=431&quality=80 431w, 929 @prodImage?mode=crop&width=360&height=360&quality=80 360w, 930 @prodImage?mode=crop&width=294&height=294&quality=80 294w, 931 @prodImage?mode=crop&width=220&height=220&quality=80 220w, 932 @prodImage?mode=crop&width=776&height=776&quality=80 776w, 933 @prodImage?mode=crop&width=540&height=540&quality=80 540w, 934 @prodImage?mode=crop&width=280&height=280&quality=80 280w" sizes="(min-width: 1400px) 431px, 935 (min-width: 1200px) 360px, 936 (min-width: 992px) 294px, 937 (min-width: 768px) 220px, 938 (min-width: 576px) 776px, 939 (min-width: 321px) 540px, 940 (min-width: 320px) 280px"> 941 <noscript><img src="@prodImage?mode=crop&width=776&quality=80" alt="@prodName"></noscript> 942 </figure> 943 </a> 944 </div> 945 <div class="card-parts-list__content"> 946 <button 947 data-product-ids="@BOMProductIdList" 948 data-quantities="@BOMProductQuantityList" 949 data-overlay-url="@(baseUrl + "system/ajax/javascript/add-to-basket-overlay")?products=@BOMProductIdList&quantities=@BOMProductQuantityList" 950 data-overlay-class="overlay-products-added__overlay" 951 data-overlay-backdrop-class="novi-backdrop--semi" 952 href="#" 953 title="@prodName" 954 class="card-group-element__icon @(productsNotInStock.Any() ? "card-group-element__icon-disabled" : "add-to-cart-overlay")" 955 > 956 <svg class="card-parts-list__svg"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/frontend/dist/icons/icons.svg#cart"></use></svg> 957 </button> 958 <h3 class="heading heading--col-element heading--col-element-parts-list">@prodName</h3> 959 <div class="info-and-price info-and-price--3cols "> 960 <div class="info-and-price__info"> 961 <div class="info-and-price__header">@Translate("Bl.a. inklusiv", "Bl.a. inklusiv")</div> 962 <ul class="info-list info-list--mobile-compact"> 963 @if (!string.IsNullOrWhiteSpace(BOMProductInfoInclusive1)) 964 { 965 <li class="info-list__item">@BOMProductInfoInclusive1</li> 966 } 967 @if (!string.IsNullOrWhiteSpace(BOMProductInfoInclusive2)) 968 { 969 <li class="info-list__item">@BOMProductInfoInclusive2</li> 970 } 971 @if (!string.IsNullOrWhiteSpace(BOMProductInfoInclusive3)) 972 { 973 <li class="info-list__item">@BOMProductInfoInclusive3</li> 974 } 975 </ul> 976 </div> 977 <div class="info-and-price__price"> 978 @if (hidePrices == "False") 979 { 980 <div class="price price--group-element"> 981 <div class="price__header">@Translate("Vejledende pris", "Vejledende pris")</div> 982 <span class="price__unit">@prodCurrency </span> 983 <span class="price__price">@Math.Round(BOMMountTypeTotalPrice, 2).ToString("N")</span> 984 </div> 985 } 986 <a href="@prodLink" title="" class="button button--cta button--cta-compact" property="url"> 987 <span class="button__text">@Translate("Vis og tilpas", "Vis og tilpas")</span> 988 </a> 989 </div> 990 </div> 991 </div> 992 </article> 993 </li> 994995 } 996 </ul> 997 </div> 998 </section> 999 } 10001001 @helper DisplayProductList(Dynamicweb.Ecommerce.Products.Group productList, string productPageId, List<Dynamicweb.Ecommerce.Products.Product> prodList = null) 1002 { 10031004 string baseUrl = Pageview.Area.Item.FirstOrDefault(i => i.Key == "Logo_Link").Value.ToString(); 1005 string hidePrices = Pageview.Area.Item["Hide_Prices"].ToString(); 10061007 var list = new List<Dynamicweb.Ecommerce.Products.Product>(); 1008 if (productList != null) 1009 { 1010 list = productList.Products.DistinctBy(p => p.Id).ToList(); 10111012 } 1013 if (prodList != null) 1014 { 1015 list = prodList.DistinctBy(p => p.Id).ToList(); 1016 } 10171018101910201021 <section class="list-group-elements list-group-elements--4cols"> 1022 <div class="grid-container grid-container--site-width"> 10231024 <ul class="grid-row grid-row--four-columns-122444 list-group-elements__list"> 1025 @foreach (var product in list) 1026 { 1027 bool inStock = product.Stock > 0; 1028 object backOrderDateObj = product.GetProductFieldValue("ProductNextBackorderDate"); 1029 DateTime backOrderDate = backOrderDateObj is DateTime ? (DateTime)backOrderDateObj : DateTime.MinValue; 1030 bool hasBackOrderDateGTToday = backOrderDate > DateTime.Now; 1031 string prodId = product.Id; 1032 string prodName = product.Name; 1033 string prodImage = product.ImageLarge.Replace(" ", "%20"); 103410351036 if (string.IsNullOrWhiteSpace(prodImage)) 1037 { 1038 prodImage = "/Files/Images/Ecommerce/Products/no-image.jpeg"; 1039 } 1040 else 1041 { 1042 prodImage = "/files" + prodImage; 1043 } 10441045 string prodDesc = string.Empty; /*product.ShortDescription;*/ 1046 string prodRawLink = ""; 1047 string GId = ""; 1048 /* 1049 if(product.DefaultGroup != null) 1050 { 1051 GId = "&groupid=" + product.DefaultGroup.Id; 1052 } 1053 else if (product.Groups.Count > 0) 1054 { 1055 GId = "&groupid=" + product.Groups.First().Id; 1056 } 1057 */ 1058 string prodLink = Dynamicweb.Frontend.SearchEngineFriendlyURLs.GetFriendlyUrl("default.aspx?id=" + productPageId + GId + "&productId=" + prodId); 1059 string prodPrice = product.Price.PriceWithVATFormattedNoSymbol; 1060 string prodCurrency = product.Price.Currency.Code; 1061 string height = product.GetProductFieldValue("Height").ToString(); 1062 string width = product.GetProductFieldValue("Width").ToString(); 1063 string length = product.GetProductFieldValue("Length").ToString(); 1064 string color = product.GetProductFieldValue("Color").ToString(); 106510661067 <li class="grid-column list-group-elements__item"> 1068 <article class="card-group-element"> 1069 <div class="card-group-element__image"> 1070 <a href="@prodLink" data-test="@prodRawLink" title="@prodName" class="card-group-element__link" property="url"> 1071 <figure vocab="http://schema.org/" typeof="ImageObject" class="image-lazyload__figure "> 1072 <img class="lazyload image-lazyload__image " src="" alt="@prodName" property="contentUrl" data-src="@prodImage?mode=crop&width=535&height=535&quality=80" 1073 data-query-obj='{ "mode":"crop" }' data-srcset="@prodImage?mode=crop&width=316&height=316&quality=80 316w, 1074 @prodImage?mode=crop&width=263&height=263&quality=80 263w, 1075 @prodImage?mode=crop&width=213&height=213&quality=80 213w, 1076 @prodImage?mode=crop&width=345&height=345&quality=80 345w, 1077 @prodImage?mode=crop&width=345&height=345&quality=80 345w, 1078 @prodImage?mode=crop&width=535&height=535&quality=80 535w, 1079 @prodImage?mode=crop&width=424&height=424&quality=80 424w, 1080 @prodImage?mode=crop&width=280&height=280&quality=80 280w" sizes="(min-width: 1400px) 316px, 1081 (min-width: 1200px) 263px, 1082 (min-width: 992px) 213px, 1083 (min-width: 768px) 345px, 1084 (min-width: 576px) 345px, 1085 (min-width: 465px) 535px, 1086 (min-width: 321px) 424px, 1087 (min-width: 320px) 280px"> 1088 <noscript><img src="@prodImage?mode=crop&width=535&quality=80" alt="@prodName"></noscript> 1089 </figure> 1090 </a> 1091 </div> 1092 <div class="card-group-element__content"> 1093 <button data-product-ids="@prodId" 1094 data-quantities="1" 1095 data-overlay-url="@(baseUrl + "system/ajax/javascript/add-to-basket-overlay")?products=@prodId&quantities=1" 1096 data-overlay-class="overlay-products-added__overlay" 1097 data-overlay-backdrop-class="novi-backdrop--semi" href="#" title="@prodName" class="card-group-element__icon @(!inStock && !hasBackOrderDateGTToday ? "card-group-element__icon-disabled" : "add-to-cart-overlay")" property="url"> 1098 <svg class="card-group-element__svg"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="/frontend/dist/icons/icons.svg#cart"></use></svg> 1099 </button> 1100 <a href="@prodLink" title="@prodName" class="card-group-element__link" property="url"> 1101 <h3 class="heading heading--col-element heading--col-element-group-element">@prodName</h3> 1102 <div class="item-number item-number--group-element">@Translate("Varenummer", "Varenummer"): @prodId</div> 1103 @if (!string.IsNullOrWhiteSpace(width)) 1104 { 1105 <div class="item-number item-number--group-element">@Translate("Bredde", "Bredde"): @width cm</div> 1106 } 1107 @if (!string.IsNullOrWhiteSpace(height)) 1108 { 1109 <div class="item-number item-number--group-element">@Translate("Højde", "Højde"): @height cm</div> 1110 } 1111 <!-- moved up before height - jgn 23/7-19 1112 @if (!string.IsNullOrWhiteSpace(width)) 1113 { 1114 <div class="item-number item-number--group-element">@Translate("Bredde", "Bredde"): @width cm</div> 1115 } 1116 --> 1117 @if (!string.IsNullOrWhiteSpace(length)) 1118 { 1119 <div class="item-number item-number--group-element">@Translate("Længde", "Længde"): @length cm</div> 1120 } 1121 @if (!string.IsNullOrWhiteSpace(color)) 1122 { 1123 <div class="item-number item-number--group-element">@Translate("Farve", "Farve"): @color</div> 1124 } 1125 </a> 1126 <div class="info-and-price info-and-price--group-element"> 1127 <div class="info-and-price__info"> 1128 @prodDesc 1129 </div> 1130 <div class="info-and-price__price"> 1131 @if (hidePrices == "False") 1132 { 1133 <div class="price price--group-element"> 1134 <div class="price__header">@Translate("Vejledende pris", "Vejledende pris")</div> 1135 <span class="price__unit">@prodCurrency </span> 1136 <span class="price__price">@prodPrice</span> 1137 </div> 1138 } 1139 <a href="@prodLink" title="" class="button button--group-element" property="url"> 1140 <span class="button__text">@Translate("Se detaljer", "Se detaljer")</span> 1141 </a> 1142 </div> 1143 </div> 1144 </div> 1145 </article> 1146 </li> 1147 } 1148 </ul> 1149 </div> 1150 </section> 11511152 }