Error executing template "eCom/Productlist/ProductList.cshtml"
System.IO.DirectoryNotFoundException: Could not find a part of the path 'D:\dynamicweb.net\Solutions\Skabertrang\pfp.dw9.dynamicweb-cms.com\Files\Images\Ecom\Produkter\Small\Brækket hvid m'.
at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
at System.IO.FileSystemEnumerableIterator`1.CommonInit()
at System.IO.FileSystemEnumerableIterator`1..ctor(String path, String originalUserPath, String searchPattern, SearchOption searchOption, SearchResultHandler`1 resultHandler, Boolean checkHost)
at System.IO.Directory.GetFiles(String path, String searchPattern, SearchOption searchOption)
at CompiledRazorTemplates.Dynamic.RazorEngine_3487612dfd6c4d54957478dc4007d085.<>c__DisplayClass0_0.b__0(TextWriter __razor_helper_writer) in D:\dynamicweb.net\Solutions\Skabertrang\pfp.dw9.dynamicweb-cms.com\Files\Templates\eCom\Productlist\ProductList.cshtml:line 212
at CompiledRazorTemplates.Dynamic.RazorEngine_3487612dfd6c4d54957478dc4007d085.Execute() in D:\dynamicweb.net\Solutions\Skabertrang\pfp.dw9.dynamicweb-cms.com\Files\Templates\eCom\Productlist\ProductList.cshtml:line 552
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 @inherits Dynamicweb.Rendering.RazorTemplateBase<Dynamicweb.Rendering.RazorTemplateModel<Dynamicweb.Rendering.Template>>
2 @using Dynamicweb.Rendering
3 @using System.IO
4 @using System.Web
5
6 @{
7 var request = Dynamicweb.Context.Current.Request;
8 var displayMode = "list";
9 List<LoopItem> products = GetLoop("Products").ToList();
10 //var productTest = Dynamicweb.Ecommerce.Products.Product.GetProductById("PROD855");
11 //var primaryGroup = Dynamicweb.Ecommerce.Products.Group.GetGroupById(productTest.PrimaryGroupId);
12
13 }
14 <style>
15 /* TOP */
16 .product-list-navigation select, .product-list-navigation .btn {
17 border-radius: 0;
18 }
19
20 .product-list-navigation label {
21 line-height: 32px;
22 }
23
24 .product-list-navigation .pagination > .active > a, .product-list-navigation .pagination > .active > a:focus, .product-list-navigation .pagination > .active > a:hover, .product-list-navigation .pagination > .active > span, .product-list-navigation .pagination > .active > span:focus, .product-list-navigation .pagination > .active > span:hover {
25 background-color: #3f6182;
26 border-color: #3f6182;
27 }
28
29 select.page-size {
30 display: inline-block;
31 width: initial;
32 }
33
34 form .product-list-page-sorting, .product-list-page-sorting.bottom-page-sorting {
35 background-color: #f0f0f0;
36 border: 1px solid #e2e2e2;
37 padding: 8px 15px 5px 15px;
38 border-radius: 0;
39 display: block;
40 margin-bottom: 15px;
41 margin-top: 5px;
42 }
43
44 .product-list-navigation label {
45 line-height: 32px;
46 font-weight: normal;
47 }
48
49 .product-list-navigation ul.pagination {
50 margin: 0;
51 }
52
53
54 /* PRODUCT LIST */
55 .list.product-list.display-list .product {
56 border-bottom: 1px solid #c0c0c0;
57 padding-bottom: 40px;
58 }
59
60 .list.product-list .product {
61 padding-top: 15px;
62 margin-bottom: 15px;
63 position: relative;
64 }
65
66 .list.product-list .product-image {
67 padding-left: 10px;
68 padding-right: 10px;
69 }
70
71 .list.product-list .product-image a {
72 display: block;
73 height: 140px;
74 }
75
76 .list.product-list .product-image img {
77 max-width: 100%;
78 max-height: 100%;
79 margin: 0 auto;
80 }
81
82 .list.product-list.display-list .product-name h3 {
83 margin-top: 0;
84 }
85
86 .list.product-list a.product-name:focus, .list.product-list a.product-name:hover {
87 text-decoration: none;
88 }
89
90 .list.product-list .product-name h3 {
91 font-size: 24px;
92 color: #ef7c00;
93 text-transform: uppercase;
94 white-space: nowrap;
95 overflow: hidden;
96 -ms-text-overflow: ellipsis;
97 -o-text-overflow: ellipsis;
98 text-overflow: ellipsis;
99 padding-right: 10px;
100 padding-left: 10px;
101 }
102
103 .list.product-list.display-list .product-number, .list.product-list.display-list .manufacturer-number {
104 font-style: italic;
105 }
106
107 .list.product-list .product .product-number, .list.product-list .product .manufacturer-number {
108 color: #808080;
109 font-size: 12px;
110 margin-bottom: 0;
111 margin-left: 10px;
112 }
113
114 .list.product-list .product .product-shortdescription {
115 margin-left: 10px;
116 margin-bottom: 10px;
117 }
118
119 .list.product-list .product .product-actions .product-price {
120 color: #333;
121 font-size: 20px;
122 line-height: 1;
123 margin-bottom: 15px;
124 }
125
126 .list.product-list.display-list .product-add-to-cart form > div[class^="col-xs"]:first-of-type {
127 padding-right: 3px;
128 }
129
130 .list.product-list.display-list .product-add-to-cart input.product-amount {
131 width: 100%;
132 padding: 5px 0 5px 12px;
133 }
134
135 .list.product-list.display-list .product-add-to-cart form > div[class^="col-xs"]:last-of-type {
136 padding-left: 3px;
137 padding-right: 0;
138 }
139
140 .list.product-list.display-list .product-add-to-cart .btn-primary {
141 width: 100%;
142 background-color: #ef7c00;
143 border-color: #ef7c00;
144 color: #fff;
145 border-radius: 0;
146 }
147
148 .list.product-list.display-list .product-add-to-cart .btn-primary:hover,
149 .list.product-list.display-list .product-add-to-cart .btn-primary:focus,
150 .list.product-list.display-list .product-add-to-cart .btn-primary:active {
151 background-color: #de7401;
152 border-color: #de7401;
153 }
154 </style>
155
156
157 @helper DisplayProducts(string displayMode) {
158 var products = GetLoop("Products");
159 var defaultImageSize = "200x200";
160 var defaultImageText = Translate("photo_missing", "Foto på vej");
161 var baseFilesPath = HttpContext.Current.Server.MapPath("/files");
162 var tryGetImage = false;
163 var filesPath = string.Empty;
164
165
166 if (Pageview.Area.Item.ContainsKey("Ecommerce_Product_Images_Folder")) {
167 var imagesFolder = (string)Pageview.Area.Item["Ecommerce_Product_Images_Folder"];
168
169 if (!string.IsNullOrEmpty(imagesFolder) && imagesFolder != "/") {
170 filesPath = HttpContext.Current.Server.MapPath(imagesFolder);
171 tryGetImage = true;
172 }
173 }
174
175 if (products.Count == 0) {
176 <div class="alert alert-info">@Translate("No_products_found", "Ingen produkter fundet")</div>
177 } else {
178 <div class="row">
179
180 @foreach (var product in products) {
181 var productStock = product.GetInteger("Ecom:Product.Stock");
182 var productNo = product.GetString("Ecom:Product.Number");
183 var productName = product.GetString("Ecom:Product.Name");
184 var productId = product.GetString("Ecom:Product.ID");
185 var productPageId = product.GetInteger("Ecom:Product.PrimaryOrCurrentPageID");
186 var productGroupId = product.GetString("Ecom:Product.PrimaryOrFirstGroupID");
187 var productImageSmall = product.GetString("Ecom:Product.ImageSmall.Clean");
188 var stockStateFew = Pageview.Area.Item.ContainsKey("Ecommerce_Product_Stockstate_Few") ? (int)Pageview.Area.Item["Ecommerce_Product_Stockstate_Few"] : 0;
189 var isNews = product.GetString("Ecom:Product:Field.News") == "True";
190 var isOffer = product.GetString("Ecom:Product:Field.Offer") == "True";
191 var imgPath = string.Empty;
192
193 var productHaveDiscount = product.GetBoolean("Ecom:Product.HaveDiscount") || isOffer;
194 var discount = product.GetLoop("ProductDiscounts").FirstOrDefault(o => o.GetBoolean("Ecom:Product.Discount.Amount.Currency.IsCurrent"));
195 var discountText = Translate("Offer", "Tilbud");
196
197 if (discount != null) {
198 if (string.Equals(discount.GetString("Ecom:Product.Discount.Type"), "percent", StringComparison.OrdinalIgnoreCase)) {
199 discountText = "-" + discount.GetString("Ecom:Product.Discount.PercentWithVAT") + "%";
200 } else {
201 discountText = "-" + discount.GetString("Ecom:Product.Discount.Amount.PriceWithVAT");
202 }
203 }
204
205 if (Pageview.Area.Item.ContainsKey("Ecommerce_Product_Page") && !string.IsNullOrEmpty((string)Pageview.Area.Item["Ecommerce_Product_Page"])) {
206 productPageId = int.Parse((string)Pageview.Area.Item["Ecommerce_Product_Page"]);
207 }
208
209 var productLink = "/Default.aspx?Id=" + productPageId + "&GroupId=" + productGroupId + "&ProductId=" + productId;
210
211 if (tryGetImage) {
212 var imageFiles = Directory.GetFiles(filesPath + "\\Small\\", productNo + "*", SearchOption.TopDirectoryOnly).Take(1).ToList();
213
214 if (imageFiles.Count == 1) {
215 imgPath = "/Files" + imageFiles[0].Replace(baseFilesPath, string.Empty).Replace("\\", "/");
216 }
217 }
218
219 if (displayMode != "list") {
220 <div class="col-xs-12 col-sm-6 col-md-4 list product-list display-gallery">
221 <div class="product" title="@(productName)">
222 <div class="product-image">
223 <a href="@(productLink)">
224 @if (!string.IsNullOrEmpty(productImageSmall)) {
225 <img src="@productImageSmall" alt="" class="img-responsive">
226 } else {
227 <img src="http://placehold.it/@(defaultImageSize)&text=@(defaultImageText)" alt="" class="img-responsive">
228 }
229 </a>
230 </div>
231 <a href="@(productLink)" class="product-name">
232 <h3>@productName</h3>
233 </a>
234 <div class="product-price-button">
235 <div class="clearfix">
236 <div class="pull-left">
237 <div class="product-price">
238 @if (product.GetDouble("Ecom:Product.Discount.Price.PriceWithVAT") == product.GetDouble("Ecom:Product.Price.Price")) {
239 <text>@product.GetValue("Ecom:Product.Price.Price") @product.GetValue("Ecom:Product.Price.CurrencyCode")</text>
240 } else {
241 <s>@product.GetValue("Ecom:Product.Price.Price") @product.GetValue("Ecom:Product.Price.CurrencyCode")</s>
242 <text>@product.GetValue("Ecom:Product.Discount.Price.Price") @product.GetValue("Ecom:Product.Price.CurrencyCode")</text>
243 }
244 </div>
245 @* <div class="product-stock-status">
246 @if (stockStateFew == 0) {
247 <span class="glyphicon glyphicon-ok"></span> <span>@Translate("stockstatus_instock","Varen er på lager")</span>
248 } else {
249 if (productStock > 0 && productStock <= stockStateFew && stockStateFew > 0) {
250 <span class="glyphicon glyphicon-exclamation-sign"></span> <span>@Translate("stockstatus_few","Få varer på lager")</span>
251 } else if (productStock > stockStateFew && productStock > 0) {
252 <span class="glyphicon glyphicon-ok"></span> <span>@Translate("stockstatus_instock","Varen er på lager")</span>
253 } else {
254 <span class="glyphicon glyphicon-remove"></span> <span>@Translate("stockstatus_none","Varen er ikke på lager")</span>
255 }
256 }
257 </div> *@
258 </div>
259 <div class="pull-right">
260 @if (Pageview.Area != null && Pageview.Area.Item.ContainsKey("Ecommerce_Basket_Enabled") && (bool)Pageview.Area.Item["Ecommerce_Basket_Enabled"]) {
261 var productAddLink = productLink + "&CartCmd=add";
262
263 if (!string.IsNullOrEmpty(product.GetString("Ecom:Product.VariantID"))) {
264 productAddLink += "&VariantId=" + product.GetString("Ecom:Product.VariantID");
265 }
266
267 <div class="text-right product-add-to-cart">
268 <a class="btn btn-primary" type="button" rel="nofollow" href="@(productAddLink)">@Translate("Add_to_cart", "Læg i kurv")</a>
269 </div>
270 }
271 @if (false) {
272 <div class="text-center product-add-to-favorites">
273 @if (bool.Parse(product.GetString("Ecom:Product.IsProductInFavoriteList")) == true) {
274 <a href="@product.GetValue("Ecom:Product.RemoveFromFavorites")" class="btn btn-warning">
275 <span class="glyphicon glyphicon-star"></span> @Translate("Remove_from_favorites", "Fjern fra favoritter")
276 </a>
277 } else {
278 <a href="@product.GetValue("Ecom:Product.AddToFavorites")" class="btn btn-warning">
279 <span class="glyphicon glyphicon-star"></span> @Translate("Add_to_favorites", "Føj til favoritter")
280 </a>
281 }
282 </div>
283 }
284 </div>
285 </div>
286 </div>
287
288 @if (productHaveDiscount) {
289 <div class="product-isoffer">
290 @(discountText)
291 </div>
292 } else if (isNews) {
293 <div class="product-isnews">
294 @Translate("News", "Nyhed")
295 </div>
296 }
297 </div>
298 </div>
299 } else {
300 <div class="col-xs-12 list product-list display-list">
301 <div class="product" title="@(productName)">
302 <div class="row">
303 <div class="product-image col-sm-3 col-md-2">
304
305 <!-- Discount sticker -->
306 @if (product.GetString("Ecom:Product.Discount.Price") != product.GetString("Ecom:Product.Price"))
307 {
308 <div class="discount-sticker" style="background-color:#337ab7;color:#FFFFFF ;position: absolute !important; z-index: 1 !important;" name="sticker">
309 <p style="padding:5px 10px;margin:0;">@Translate("On sale!", "On sale!")</p>
310 </div>
311 }
312 <a href="@(productLink)">
313 @if (!string.IsNullOrEmpty(productImageSmall))
314 {
315 var imageString = "/admin/Public/GetImage.ashx?Width=145&Height=140&Crop=1&Compression=70&Image=" + productImageSmall;
316 <img src="@imageString" alt="" class="img-responsive">
317 }
318 else
319 {
320 <img src="http://placehold.it/@(defaultImageSize)&text=@(defaultImageText)" alt="" class="img-responsive">
321 }
322 </a>
323 </div>
324 <div class="product-content col-xs-12 col-sm-5 col-md-7">
325 <div class="row">
326 <div class="col-xs-12">
327 <a href="@(productLink)" class="product-name">
328 <h3>@productName</h3>
329 </a>
330 @if (!string.IsNullOrEmpty(productNo)) {
331 <div class="product-number">
332 @Translate("product_number", "Produktnr.:") @productNo
333 </div>
334 }
335 <div class="product-shortdescription"><small>@product.GetValue("Ecom:Product.ShortDescription")</small></div>
336 </div>
337 </div>
338 </div>
339 <div class="product-actions col-xs-12 col-sm-4 col-md-3">
340 <div class="text-right product-price">
341 @if (product.GetDouble("Ecom:Product.Discount.Price.PriceWithVAT") == product.GetDouble("Ecom:Product.Price.Price")) {
342 <text>@product.GetValue("Ecom:Product.Price.Price") @product.GetValue("Ecom:Product.Price.CurrencyCode")</text>
343 } else {
344 <s>@product.GetValue("Ecom:Product.Price.Price") @product.GetValue("Ecom:Product.Price.CurrencyCode")</s>
345 <text>@product.GetValue("Ecom:Product.Discount.Price.Price") @product.GetValue("Ecom:Product.Price.CurrencyCode")</text>
346 }
347 </div>
348 @* <div class="product-stock-status col-xs-5 col-sm-12">
349 @if (stockStateFew == 0) {
350 <span class="glyphicon glyphicon-ok"></span> <span>@Translate("stockstatus_instock","Varen er på lager")</span>
351 } else {
352 if (productStock > 0 && productStock <= stockStateFew && stockStateFew > 0) {
353 <span class="glyphicon glyphicon-exclamation-sign"></span> <span>@Translate("stockstatus_few","Få varer på lager")</span>
354 } else if (productStock > stockStateFew && productStock > 0) {
355 <span class="glyphicon glyphicon-ok"></span> <span>@Translate("stockstatus_instock","Varen er på lager")</span>
356 } else {
357 <span class="glyphicon glyphicon-remove"></span> <span>@Translate("stockstatus_none","Varen er ikke på lager")</span>
358 }
359 }
360 </div> *@
361 @if (true) {
362 var productAddLink = productLink + "&CartCmd=add";
363
364 if (!string.IsNullOrEmpty(product.GetString("Ecom:Product.VariantID"))) {
365 productAddLink += "&VariantId=" + product.GetString("Ecom:Product.VariantID");
366 }
367
368 <div class="text-right product-add-to-cart">
369 @*<button class="btn btn-primary" rel="nofollow" href="@(productAddLink)">@Translate("Add_to_cart", "Læg i kurv")</button>*@
370
371 @* CF - Denne form er den originale fra Spica, bare hvis du ville slippe for at tænke for meget *@
372 <form method="post" role="form" id="form-@productId">
373 <input type="hidden" name="ID" value="@productPageId" />
374 <input type="hidden" name="ProductID" value="@productId" />
375 <input type="hidden" name="CartCmd" value="add">
376 @if (!string.IsNullOrEmpty(product.GetString("Ecom:Product.VariantID"))) {
377 string variantID = product.GetString("Ecom:Product.VariantID");
378 <input type="hidden" name="VariantId" value="@variantID" />
379 }
380 <div class="col-xs-4">
381 <input class="product-amount" name="quantity" min="1" value="1" type="number" placeholder="1" title="" />
382 </div>
383 <div class="col-xs-8">
384 <button type="submit" form="form-@productId" class="col-md-8 btn btn-primary" rel="nofollow" href="@(productAddLink)">@Translate("Add request")</button>
385 </div>
386 </form>
387
388 @*<form method="post" role="form" id="">
389
390 <div class="col-xs-4">
391 <input class="product-amount" name="quantity" min="1" value="1" type="number" placeholder="1" title="" />
392 </div>
393 <div class="col-xs-8">
394
395 <button class="btn btn-primary" rel="nofollow" href="@(productAddLink)">@Translate("Add_to_cart", "Læg i kurv")</button>
396
397 <button type="submit" form="" class="col-md-8 btn btn-primary" rel="nofollow" href="@(productAddLink))">@Translate("Add_request", "Add request")</button>
398 </div>
399 </form>*@
400 </div>
401 }
402 </div>
403 </div>
404
405 @if (productHaveDiscount) {
406 <div class="product-isoffer">
407 @(discountText)
408 </div>
409 } else if (isNews) {
410 <div class="product-isnews">
411 @Translate("News", "Nyhed")
412 </div>
413 }
414 </div>
415 </div>
416 }
417 }
418 </div>
419 }
420 }
421 @helper GetEcomNavigationDisplay(string displayMode, bool isTop = true) {
422 var request = HttpContext.Current.Request;
423 var productListPageSize = GetInteger("Ecom:ProductList.PageSize");
424 var pageNum = GetInteger("Ecom:ProductList.CurrentPage");
425 var GroupID = GetString("Ecom:ProductList.GroupID");
426 var sortBy = !string.IsNullOrEmpty(request["SortBy"]) ? request["SortBy"] : "Name";
427 var sortOrder = !string.IsNullOrEmpty(request["SortOrder"]) ? request["SortOrder"] : "ASC";
428 var productListSort = sortBy + "|" + sortOrder;
429
430 <div class="row product-list-navigation">
431 <div class="col-xs-12">
432 <form role="form" method="GET" action="">
433 <input type="hidden" class="navigation-display-input page-number" name="PageNum" value="@(pageNum)">
434 <input type="hidden" class="navigation-display-input page-size" name="PageSize" value="@(productListPageSize)">
435 <input type="hidden" class="navigation-display-input page-sort-by" name="SortBy" value="@(sortBy)">
436 <input type="hidden" class="navigation-display-input page-sort-order" name="SortOrder" value="@(sortOrder)">
437 <input type="hidden" class="navigation-display-input" name="GroupID" value="@(GroupID)">
438 <input type="hidden" class="navigation-display-input display-mode" name="DisplayMode" value="@(displayMode)">
439
440 @if (isTop) {
441 <div class="row">
442 <div class="col-xs-12 text-right">
443 <label class="control-label">@Translate("pagination_change_page_size", "Vis"): </label>
444 <select class="form-control page-size" onchange="pageSizeChanged(this);">
445 <option value="20" @(productListPageSize == 20 ? "selected=\"selected\"" : "")>20 @Translate("product_count_per_page", "pr. side")</option>
446 <option value="50" @(productListPageSize == 50 ? "selected=\"selected\"" : "")>50 @Translate("product_count_per_page", "pr. side")</option>
447 <option value="100" @(productListPageSize == 100 ? "selected=\"selected\"" : "")>100 @Translate("product_count_per_page", "pr. side")</option>
448 </select>
449 <!-- Removed the option to choose listview below, as this is not needed! -->
450 @*<div class="btn-group" role="toolbar">
451 <button type="submit" value="gallery" onclick="displayModeChanged(this);" class="btn btn-default btn-md @(displayMode == "list" ? "" : "active") "><i class="glyphicon glyphicon-th-large" aria-hidden="true"></i> @Translate("product_list_display_type_gallery", "Galleri")</button>
452 <button type="submit" value="list" onclick="displayModeChanged(this);" class="btn btn-default btn-md @(displayMode == "list" ? "active" : "") "><i class="glyphicon glyphicon-list" aria-hidden="true"></i> @Translate("product_list_display_type_æost", "Liste")</button>
453 </div>*@
454
455 @*<div class="product-list-display-mode">
456 <label class="control-label">@Translate("pagination_change_page_view", "Visning"): </label>
457 <div class="btn-group" role="toolbar">
458 <button type="submit" value="gallery" onclick="displayModeChanged(this);" class="btn btn-default btn-md @(displayMode == "list" ? "" : "active") "><span class="glyphicon glyphicon-th-large" aria-hidden="true"></span> @Translate("product_list_display_type_gallery", "Galleri")</button>
459 <button type="submit" value="list" onclick="displayModeChanged(this);" class="btn btn-default btn-md @(displayMode == "list" ? "active" : "") "><span class="glyphicon glyphicon-list" aria-hidden="true"></span> @Translate("product_list_display_type_æost", "Liste")</button>
460 </div>
461 </div>*@
462 </div>
463 </div>
464
465 <div class="product-list-page-sorting">
466 <div class="row">
467 <div class="col-xs-12 col-sm-6">
468 <label class="control-label">@Translate("pagination_change_sorting", "Sortering"): </label>
469 <select class="form-control page-size" onchange="sortChanged(this);">
470 <option value="Created|ASC" @(productListSort == "Created|ASC" ? "selected=\"selected\"" : "")>@Translate("product_sort_date_asc", "Nyheder")</option>
471 <option value="Price|ASC" @(productListSort == "Price|ASC" ? "selected=\"selected\"" : "")>@Translate("product_sort_price_asc", "Pris (laveste først)")</option>
472 <option value="Price|DESC" @(productListSort == "Price|DESC" ? "selected=\"selected\"" : "")>@Translate("product_sort_price_desc", "Pris (højeste først)")</option>
473 <option value="Name|ASC" @(productListSort == "Name|ASC" ? "selected=\"selected\"" : "")>@Translate("product_sort_name_asc", "Navn (a til å)")</option>
474 <option value="Name|DESC" @(productListSort == "Name|DESC" ? "selected=\"selected\"" : "")>@Translate("product_sort_name_desc", "Navn (å til a)")</option>
475 </select>
476 </div>
477 <div class="col-xs-12 col-sm-6 text-right">
478 @GetEcomPagination(displayMode)
479 </div>
480 </div>
481 </div>
482 } else {
483 <div class="product-list-page-sorting bottom-page-sorting text-right">
484 @GetEcomPagination(displayMode)
485 </div>
486 }
487 </form>
488 </div>
489 </div>
490 }
491 @helper GetEcomPagination(string displayMode) {
492 var pageSize = GetInteger("Ecom:ProductList.PageSize");
493 var totalProducts = GetInteger("Ecom:ProductList.PageProdCnt");
494 var currentPageNumber = GetInteger("Ecom:ProductList.CurrentPage");
495
496 var pageCount = totalProducts / pageSize; /** Integer division (returning integer) **/
497 var spare = totalProducts % pageSize;
498
499 if (spare > 0) {
500 pageCount++;
501 }
502
503 var initialPage = 1;
504
505 if (currentPageNumber - 2 > 0) {
506 initialPage = currentPageNumber - 2;
507
508 if (pageCount > 5) {
509 if (currentPageNumber + 2 >= pageCount) {
510 initialPage = pageCount - 4;
511 }
512 }
513 }
514
515 var endPage = pageCount >= 5 ? (currentPageNumber + 2 <= 5 ? 5 : (currentPageNumber + 2 > pageCount ? pageCount : currentPageNumber + 2)) : pageCount;
516 var formatString = "pageChanged(this, {0}); return false;";
517
518 <ul class="pagination">
519 <li class="@(currentPageNumber == 1 ? "disabled" : "")"><a href="#" onclick="@(string.Format(formatString, currentPageNumber - 1))">«</a></li>
520 @if (initialPage > 1) {
521 <li><a href="#" onclick="@(string.Format(formatString, 1))">1</a></li>
522 <li class="disabled"><a href="#">...</a></li>
523 }
524 @for (var pageNumber = initialPage; endPage >= pageNumber; pageNumber++) {
525 if (pageNumber == currentPageNumber) {
526 <li class="active"><a href="#" onclick="@(string.Format(formatString, pageNumber))">@pageNumber</a></li>
527 } else {
528 <li><a href="#" onclick="@(string.Format(formatString, pageNumber))">@pageNumber</a></li>
529 }
530 }
531 @if (pageCount > currentPageNumber + 2) {
532 <li class="disabled"><a href="#">...</a></li>
533 <li><a href="@(string.Format(formatString, pageCount))">@pageCount</a></li>
534 }
535 <li class="@(currentPageNumber == pageCount ? "disabled" : "")"><a href="#" onclick="@(string.Format(formatString, currentPageNumber + 1))">»</a></li>
536 </ul>
537 }
538
539 <div class="product-list-group-description">
540 @if (!string.IsNullOrEmpty(GetString("Ecom:Group.Name"))) {
541 <h1>@GetValue("Ecom:Group.Name")</h1>
542 }
543 @if (!string.IsNullOrEmpty(GetString("Ecom:Group.Description"))) {
544 <div>@GetValue("Ecom:Group.Description")</div>
545 }
546 </div>
547
548 <div class="row">
549 @if (string.IsNullOrWhiteSpace(GetString("Ecom:Search.SearchBox"))) {
550 <div class="col-md-12">
551 @GetEcomNavigationDisplay(displayMode)
552 @DisplayProducts(displayMode)
553 @GetEcomNavigationDisplay(displayMode, false)
554 </div>
555 } else {
556 <div class="col-md-3">
557 @GetValue("Ecom:Search.SearchBox")
558 </div>
559 <div class="col-md-9">
560 @DisplayProducts(displayMode)
561 </div>
562 }
563 </div>
564
565 <script type="text/javascript">
566 function pageSizeChanged(obj) {
567 $("input[type='hidden'].navigation-display-input.page-size").val(obj.options[obj.selectedIndex].value);
568 $("input[type='hidden'].navigation-display-input.page-number").val("1");
569 $(obj).closest("form").submit();
570 }
571
572 function sortChanged(obj) {
573 var sortOptions = obj.options[obj.selectedIndex].value.split('|');
574 $("input[type='hidden'].navigation-display-input.page-sort-by").val(sortOptions[0]);
575 $("input[type='hidden'].navigation-display-input.page-sort-order").val(sortOptions[1]);
576 $("input[type='hidden'].navigation-display-input.page-number").val("1");
577 $(obj).closest("form").submit();
578 }
579
580 function pageChanged(obj, newPage) {
581 $("input[type='hidden'].navigation-display-input.page-number").val(newPage);
582 $(obj).closest("form").submit();
583 }
584
585 function displayModeChanged(obj) {
586 $("input[type='hidden'].navigation-display-input.display-mode").val($(obj).val());
587 $(obj).closest("form").submit();
588 }
589 </script>