Error executing template "Designs/BfaPortalen/_parsed/Branche_Side.parsed.cshtml"
System.ArgumentException: Get page requires a page ID greater than zero, page ID was 0
   at Dynamicweb.Core.Ensure.That[TException](Boolean condition, String message)
   at Dynamicweb.Content.PageService.GetPage(Int32 pageId)
   at CompiledRazorTemplates.Dynamic.RazorEngine_2094e67fc8164a44abea7e306f07cc04.Execute() in D:\dynamicweb.net\Solutions\bfahandel.staging.dynamicweb-cms.com\Files\Templates\Designs\BfaPortalen\_parsed\Branche_Side.parsed.cshtml:line 443
   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.<RunCompile>b__0(TextWriter writer)
   at RazorEngine.Templating.RazorEngineServiceExtensions.WithWriter(Action`1 withWriter)
   at Dynamicweb.Rendering.RazorTemplateRenderingProvider.Render(Template template)
   at Dynamicweb.Rendering.TemplateRenderingService.Render(Template template)
   at Dynamicweb.Rendering.Template.RenderRazorTemplate()

1 @using System.Web; 2 @using Dynamicweb.Rendering; 3 @using Dynamicweb.Content; 4 @using Dynamicweb.Data; 5 @using Dynamicweb.Frontend; 6 @using Dynamicweb.Frontend.Navigation 7 8 @inherits RazorTemplateBase<RazorTemplateModel<Template>> 9 10 @{ 11 // variables 12 var scheme = HttpContext.Current.Request.Url.Scheme; 13 var host = HttpContext.Current.Request.Url.Host; 14 var pageUrl = Dynamicweb.Frontend.SearchEngineFriendlyURLs.GetFriendlyUrl("Default.aspx?ID=" + GetGlobalValue("Global:Page.ID")); 15 16 // pdf 17 var pdfMode = HttpContext.Current.Request["pdf"]; 18 19 var area = Pageview.Area; 20 var systemName = GetString("Item.Area.Systemnavn"); 21 22 var websiteTitel = GetString("Item.Area.Titel"); 23 var logoNormal = GetString("Item.Area.LogoNormal"); 24 var logoNegative = GetString("Item.Area.LogoNegativ"); 25 var frontPageId = GetString("Item.Area.Forside"); 26 var newsPageId = GetString("Item.Area.Nyheder"); 27 var searchPageId = GetString("Item.Area.Soegeresultater"); 28 var materialsPageId = GetString("Item.Area.Materialer"); 29 var newsletterParagraphId = GetInteger("Item.Area.Nyhedsbrev"); 30 var googleAnalytics = GetString("Item.Area.GoogleAnalytics"); 31 var googleAnalyticsBody = GetString("Item.Area.GoogleAnalyticsBody"); 32 var linkedIn = GetString("Item.Area.LinkedIn"); 33 var facebook = GetString("Item.Area.Facebook"); 34 var privacyPoliticsPageId = GetString("Item.Area.Privatlivspolitik"); 35 var cookiePageId = GetString("Item.Area.Cookie"); 36 var brancheSider = getBrancheSider(area, systemName); 37 38 var emner = getEmner(area, systemName); 39 40 var branches = getBranches(area, systemName); 41 var branchSelectedId = 0; 42 var branchSelectedTitle = ""; 43 var sessionBranch = HttpContext.Current.Request["branch"] ?? HttpContext.Current.Session["branch"]; 44 if(sessionBranch != null) 45 { 46 var branchSelected = branches.Find(x => x.Id.ToString() == sessionBranch.ToString()); 47 if (branchSelected != null) { 48 branchSelectedId = branchSelected.Id; 49 branchSelectedTitle = branchSelected.Title; 50 HttpContext.Current.Session["branch"] = sessionBranch; 51 } 52 else 53 { 54 HttpContext.Current.Session["branch"] = ""; 55 } 56 } 57 var categories = getCategories(area, systemName); 58 var types = getTypes(area, systemName); 59 60 var ogImg = GetString("Item.Billede"); 61 ogImg = (!string.IsNullOrEmpty(Pageview.Page.TopImage)) ? "/Files/"+Pageview.Page.TopImage : ogImg; 62 var ogTitle = GetString("Title"); 63 var ogDescription = GetString("Meta.Description"); 64 65 66 // translations 67 var textSearchButton = Translate("Search", "Søg"); 68 var textSearchPlaceholder = Translate("Enter keyword...", "Indtast søgeord..."); 69 var textName = Translate("Name", "Name"); 70 var textEmail = Translate("Email", "Email"); 71 72 73 var topPageId = GetString("DwPageID_1"); 74 var topPageClass = ""; 75 if(topPageId == "3307"){ 76 topPageClass = "godstransport"; 77 } 78 if(topPageId == "3347"){ 79 topPageClass = "persontransport"; 80 } 81 if(topPageId == "3374"){ 82 topPageClass = "lagreogvareterminaler"; 83 } 84 if(topPageId == "3360"){ 85 topPageClass = "brandogredning"; 86 } 87 if(topPageId == "3387"){ 88 topPageClass = "jernbanetransport"; 89 } 90 if(topPageId == "3400"){ 91 topPageClass = "lufttransport"; 92 } 93 94 var pageIdClass = "page-" + GetString("DwPageID"); 95 96 var farver = getFarver(area, systemName); 97 98 var themeFarve = (!string.IsNullOrEmpty(GetString("Item.Farver") ) ? GetString("Item.Farver") : "1"); 99 100 if (GetString("DwPageID_1") != "20186") { 101 themeFarve = "1"; 102 } 103 } 104 105 <!doctype html> 106 <html lang="da" itemscope="" itemtype="https://schema.org/Organization"> 107 <head> 108 <script id="Cookiebot" src="https://consent.cookiebot.com/uc.js" data-cbid="4ef71bed-c131-4d98-b60a-0e61262678de" data-blockingmode="auto" type="text/javascript"></script> 109 <meta charset="utf-8"> 110 <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> 111 112 <meta name="author" content=""> 113 <link rel="icon" href="/Files/Templates/Designs/BfaPortalen/img/BFA-square-512.png"> 114 <meta property="og:site_name" content="BFA Portalen"> 115 <script type="application/ld+json"> 116 { 117 "@@context" : "https://schema.org", 118 "@@type" : "WebSite", 119 "name" : "BFA Portalen", 120 "url" : "https://bfaportalen.dk" 121 } 122 </script> 123 <title>@GetValue("Title")</title> 124 @GetValue("MetaTags") 125 @GetValue("CopyRightNotice") 126 127 @if (!string.IsNullOrEmpty(ogTitle)) { 128 <meta property="og:title" content="@ogTitle"> 129 } 130 @if (!string.IsNullOrEmpty(ogDescription)) { 131 <meta property="og:description" content="@ogDescription"> 132 } 133 @if (!string.IsNullOrEmpty(ogImg)) { 134 string ogImagePath = Dynamicweb.Context.Current.Request.Url.Scheme + "://" + Dynamicweb.Context.Current.Request.Url.Host + ogImg; 135 <meta property="og:image" content="@ogImagePath"> 136 } 137 138 <!-- google font --> 139 <link href="https://fonts.googleapis.com/css?family=Archivo:400,500,600" rel="stylesheet"> 140 <link href="https://fonts.googleapis.com/css?family=Open+Sans:400,500,600" rel="stylesheet"> 141 142 <!-- font awesome --> 143 <link href="/Files/Templates/Designs/BfaPortalen/css/libs/fontawesome/css/all.css" rel="stylesheet"> 144 145 <!-- css --> 146 <link href="/Files/Templates/Designs/BfaPortalen/css/setoff.css?v=1.01" rel="stylesheet"> 147 <link href="/Files/Templates/Designs/BfaPortalen/css/styles.css?v=1.26" rel="stylesheet"> 148 <link href="/Files/Templates/Designs/BfaPortalen/css/pb-styles.css?v=1.1" rel="stylesheet"> 149 <link href="/Files/Templates/Designs/BfaPortalen/css-service/service-styles.css?v=1.3" rel="stylesheet"> 150 <link href="/Files/Templates/Designs/BfaPortalen/js/libs/slick-1.8.1/slick/slick.css" rel="stylesheet"> 151 <link href="/Files/Templates/Designs/BfaPortalen/js/libs/slick-1.8.1/slick/slick-theme-transport.css" rel="stylesheet"> 152 <link rel="stylesheet" href="/Files/Templates/Designs/BfaPortalen/js/libs/plyr-3.7.8/plyr.css"> 153 <!--<link href="css/print.min.css" rel="stylesheet" media="print">--> 154 155 <style> 156 iframe { 157 display:block !important; 158 } 159 160 .cards .ul.list .li { 161 margin-top: 0px; 162 margin-bottom: 12px; 163 } 164 @@media screen and (max-width: 767px) { 165 form[name="SearchForm1"] input[type="text"] { 166 width: 110px; 167 } 168 } 169 170 </style> 171 <!-- google analytics --> 172 @googleAnalytics 173 174 <!-- dw standard scripts --> 175 176 177 <style> 178 179 @foreach (var farve in farver) 180 { 181 var Tekstfarve = farve.Tekstfarve; 182 var Baggrundsfarve = farve.Baggrundsfarve; 183 var SekTekstfarve = (!string.IsNullOrEmpty(farve.SekTekstfarve)) ? farve.SekTekstfarve : farve.Tekstfarve; 184 var SekBaggrundsfarve = (!string.IsNullOrEmpty(farve.SekBaggrundsfarve)) ? farve.SekBaggrundsfarve : farve.Baggrundsfarve; 185 186 /* @farve.Title */ 187 @(".theme-"+ farve.Id + " { --theme-text-color: " + Tekstfarve + "; --theme-background-color: " + Baggrundsfarve + "; --theme-secondary-text-color: " + SekTekstfarve + "; --theme-secondary-background-color: " + SekBaggrundsfarve + "; --theme-mobile-text-color: " + farve.MobilTekstfarve + "; --theme-mobile-background-color: " + farve.MobilBaggrundsfarve + "; } ") 188 @(".theme2-"+ farve.Id + " { --theme2-text-color: " + Tekstfarve + "; --theme2-background-color: " + Baggrundsfarve + "; --theme2-secondary-text-color: " + SekTekstfarve + "; --theme2-secondary-background-color: " + SekBaggrundsfarve + "; --theme2-mobile-text-color: " + farve.MobilTekstfarve + "; --theme2-mobile-background-color: " + farve.MobilBaggrundsfarve + "; } ") 189 } 190 @*foreach (var farve in farver) 191 { 192 @("@media (max-width: 767px) {") 193 /* @farve.Title */ 194 @(".theme-mobile-"+ farve.Id + " { --theme-text-color: " + farve.Tekstfarve + "; --theme-background-color: " + farve.Baggrundsfarve + " } ") 195 @("}") 196 }*@ 197 198 199 </style> 200 @GetValue("Stylesheets") 201 @GetValue("Javascripts") 202 </head> 203 204 <body class="@topPageClass @pageIdClass theme-@themeFarve" id="body" data-area="@area.ID"> 205 206 207 <nav class="navbar navbar-expand-md navbar-white bg-white"> 208 <div class="container"> 209 210 <a class="navbar-brand navbar-brand--negative" href="/"> 211 <img src="@logoNegative" alt="@websiteTitel"> 212 </a> 213 <a class="navbar-brand navbar-brand--normal" href="/"> 214 <img src="@logoNormal" alt="@websiteTitel"> 215 </a> 216 217 <div class="navbar-search-toggler-parent"> 218 <button class="navbar-search-toggler" type="button" data-toggle="modal" data-target="#searchModal"><i class="far fa-search"></i></button> 219 220 <button class="navbar-toggler" type="button"> 221 <i class="far fa-bars"></i> 222 </button> 223 </div> 224 225 <div id="navbar-main" class="collapse navbar-collapse"> 226 227 <ul class="navbar-nav"> 228 229 <button class="navbar-close"><i class="far fa-times"></i></button> 230 231 <div class="logo"> 232 <a class="navbar-brand" href="/"><img src="@logoNormal" alt="@websiteTitel"></a> 233 </div> 234 235 <li class="nav-item dropdown"> 236 <a class="nav-link dropdown-toggle" href="" id="brancher"><span class="text">Brancher</span><i class="fal fa-angle-down"></i></a> 237 <div class="dropdown-menu" aria-labelledby="brancher"> 238 <div class="container"> 239 <section class="branches menu container"> 240 <div class="row"> 241 <div class="col-sm-12"> 242 <div class="dd-title"><h3>Brancher</h3><button>&times;</button></div> 243 244 <ul class="nav-brancher"> 245 @*foreach (var branch in branches) 246 { 247 var id = branch.Id; 248 var title = branch.Title; 249 var description = branch.Description; 250 var image = branch.Image; 251 var link = "Default.aspx?ID=" + branch.Id; 252 var color = ""; 253 <li class="col-sm-12 col-md-6 col-lg-4"> 254 <article itemtype="https://schema.org/Article" itemscope="" class="@color"> 255 <a itemprop="url" href="@link"> 256 <div class="image"> 257 <img src="@image" alt="@title" itemprop="image"> 258 </div> 259 <h3 itemprop="name">@title</h3> 260 </a> 261 </article> 262 </li> 263 }*@ 264 265 @foreach (var branch in branches) 266 { 267 //var p = PageService.GetPage(branch.Id); 268 var id = branch.Id; 269 var pageid = branch.PageId; 270 var title = branch.Title; 271 var description = branch.Description; 272 var image = branch.Image; 273 var link = "Default.aspx?ID=" + branch.Id; 274 var color = ""; 275 276 277 var children = Dynamicweb.Content.Services.Pages.GetPagesByParentID(pageid); 278 var childCounter = 0; 279 var break1 = branch.UndermenuPunkter1; 280 var break2 = break1 + branch.UndermenuPunkter2; 281 282 <li class="theme-@branch.Farver "> 283 <article itemtype="https://schema.org/Article" itemscope="" class="@color"> 284 <div class="links"> 285 <div class="main" data-href="Default.aspx?ID=@pageid"> 286 @title 287 </div> 288 @foreach (var child in children) 289 { 290 291 var breakClass = (childCounter == break1 || childCounter == break2) ? 292 "clear" : ""; 293 childCounter++; 294 295 296 <a class="sub @breakClass" itemprop="url" href="Default.aspx?ID=@child.ID"> 297 @child.MenuText 298 </a> 299 } 300 301 </div> 302 <div class="image"> 303 @if (!string.IsNullOrEmpty(image)) 304 { 305 <img src="/admin/public/getimage.aspx?Image=@image&width=240" alt="@title" itemprop="image"> 306 } 307 </div> 308 </article> 309 </li> 310 } 311 </ul> 312 </div> 313 314 315 </div> 316 </section> 317 </div> 318 </div> 319 </li> 320 <li class="nav-item dropdown"> 321 <a class="nav-link dropdown-toggle" href="" id="emner"><span class="text">Emner</span><i class="fal fa-angle-down"></i></a> 322 <div class="dropdown-menu" aria-labelledby="emner"> 323 <div class="container"> 324 <section class="topics menu container"> 325 <div class="row"> 326 <div class="col-sm-12"> 327 <div class="dd-title"><h3>Emner</h3><button>&times;</button></div> 328 329 @{ 330 var navigationSettingsEmner = new NavigationSettings(); 331 navigationSettingsEmner.StartLevel = 1; 332 navigationSettingsEmner.StopLevel = 10; 333 navigationSettingsEmner.ExpandMode = ExpandMode.All; 334 navigationSettingsEmner.RootPageId = 20199; 335 } 336 @Navigation.RenderNavigation("Navigation/Emner.cshtml", navigationSettingsEmner) 337 </div> 338 </div> 339 </section> 340 </div> 341 </div> 342 </li> 343 <!--<li class="nav-item"> 344 <a class="nav-link" href="Default.aspx?ID=3340"><span class="text">Om os</span></a> 345 </li> 346 <li class="nav-item"> 347 <a class="nav-link" href="Default.aspx?ID=3341"><span class="text">Kontakt</span></a> 348 </li>--> 349 </ul> 350 </div> 351 352 <div class="search"> 353 <a class="search-toggler" href="/Default.aspx?ID=20240"><i class="fas fa-search"></i> <span>Søg</span></a> 354 <!--<button class="search-toggler" type="button" data-toggle="modal" data-target="#searchModal"><i class="fas fa-search"></i> Søg</button> 355 <form action="Default.aspx" method="get"> 356 <input name="ID" value="@searchPageId" type="hidden" autocomplete="off"> 357 <input class="form-control" type="text" placeholder="@textSearchPlaceholder" name="q"> 358 <button class="btn search" type="submit"><i class="fal fa-search"></i></button> 359 </form>--> 360 361 <div class="search-menu dropdown-menu "> 362 <div class="container"> 363 <section classs="menu container"> 364 <div class="row"> 365 <div class="col-sm-12"> 366 367 <div class="search-card "> 368 <h2>Søg</h2> 369 <form action="/Default.aspx" method="GET"> 370 <input name="ID" value="@searchPageId" type="hidden" autocomplete="off"> 371 372 <div class="search-form-group"> 373 <input type="text" name="s" class="form-control" placeholder="Indtast søgeord" autocomplete="off"> 374 <div class="filters"> 375 <div class="filter-dropdown"> 376 <select name="branche" class="form-control"> 377 <option value="">Branche</option> 378 @foreach (var branche in brancheSider.OrderBy(x=>x.Title).ToList()) 379 { 380 <option>@branche.Title</option> 381 } 382 </select> 383 </div> 384 <div class="filter-dropdown"> 385 <select name="emne" class="form-control"> 386 <option value="">Emne</option> 387 @foreach (var emne in emner.OrderBy(x=>x.Title).ToList()) 388 { 389 <option>@emne.Title</option> 390 } 391 </select> 392 </div> 393 <div class="filter-dropdown"> 394 <select name="type" class="form-control"> 395 <option value="">Type</option> 396 @foreach (var cat in categories.OrderBy(x=>x.Title).ToList()) 397 { 398 <option>@cat.Title</option> 399 } 400 </select> 401 </div> 402 </div> 403 <input type="submit" class="btn btn-primary" value="Søg"> 404 </div> 405 </form> 406 </div> 407 408 </div> 409 </div> 410 </section> 411 </div> 412 </div><!--search-menu--> 413 414 415 </div> 416 417 </div> 418 </nav> 419 420 <main class="main"> 421 @using Dynamicweb.Rendering; 422 @using Dynamicweb.Content.Items; 423 @using Dynamicweb.Data; 424 @using HtmlAgilityPack; 425 @using Dynamicweb.Frontend.Navigation 426 427 @inherits RazorTemplateBase<RazorTemplateModel<Template>> 428 429 430 @{ 431 var pageId = Pageview.ID; 432 var brancheTopTitle = GetString("DwPageName_3"); 433 var brancheTopId = GetInteger("DwPageID_3"); 434 var pageUrlAbsolute = scheme + "://" + host + GetGlobalValue("Global:Pageview.Url").ToString(); 435 436 var materials = getMaterials(area, systemName, pageId); 437 438 var subjectTitle = GetString("Item.Titel"); 439 var subjectDescription = GetString("Item.Beskrivelse"); 440 var subjectImage = GetString("Item.Billede"); 441 var subjectImageDescription = GetString("Item.BilledeBeskrivelse"); 442 443 var pageItem = Dynamicweb.Content.Services.Pages.GetPage(brancheTopId).Item; 444 var MainFarver = (pageItem != null) ? pageItem["Farver"] : ""; 445 446 447 } 448 449 <div class="branche--side"> 450 @if(!string.IsNullOrEmpty(GetString("DwContent(intro)"))){ 451 <div id="intro">@GetValue("DwContent(intro)")</div> 452 } 453 454 455 @{ 456 var navigationSettingsIndhold = new NavigationSettings(); 457 navigationSettingsIndhold.StartLevel = 4; 458 navigationSettingsIndhold.StopLevel = 10; 459 navigationSettingsIndhold.ExpandMode = ExpandMode.All; 460 } 461 <section class="indhold container"> 462 <div class="row"> 463 <div class="col-sm-12"> 464 <h2>Indhold</h2> 465 @Navigation.RenderNavigation("Navigation/BrancheIndhold.cshtml", navigationSettingsIndhold) 466 </div> 467 </div> 468 </section> 469 470 @*<section class="latest-materials materials materials--page cards box container theme-@MainFarver "> 471 <div class="row"> 472 <div class="col-sm-12"> 473 <h2>Nyheder</h2> 474 <div class="xdxwxcontent" id="materialer" title="Materialer" data-settings="template:materiale-slide.cshtml"></div> 475 </div> 476 </div> 477 </section>*@ 478 @if(!string.IsNullOrEmpty(GetString("DwContent(newsslideshow)"))){ 479 <section class="news-slideshow container theme-@MainFarver "> 480 <div class="forside-card xcontainer"> 481 <div class="xrow"> 482 <div class="xcol-md-12"> 483 484 <h2>Nyheder</h2> 485 <section class="slideshow" id="newsslideshow">@GetValue("DwContent(newsslideshow)")</section> 486 487 </div> 488 </div> 489 </div> 490 </section> 491 } 492 493 @if(!string.IsNullOrEmpty(GetString("DwContent(contact)"))){ 494 <section class="contact container theme-@MainFarver "> 495 <div class="row "> 496 <div class="col-sm-12"> 497 <div class="background-secondary"> 498 <h2>Kontakt</h2> 499 <ul id="contact" class="row content" itemprop="text">@GetValue("DwContent(contact)")</ul> 500 </div> 501 </div> 502 </div> 503 </section> 504 } 505 </div> 506 507 508 509 510 @functions { 511 512 513 public List<Material> getMaterials(Area area, string systemName, int branchSelectedId) 514 { 515 var materials = new List<Material>(); 516 517 var materialDataReader = Database.CreateDataReader( 518 /*CommandBuilder.Create("SELECT * FROM Paragraph AS p INNER JOIN ItemType_" + systemName + "Materiale AS m ON p.ParagraphItemID = m.Id WHERE p.ParagraphShowParagraph = {0} AND p.ParagraphItemType = {1} AND CAST(m.Kategori AS INT) IN ({2}) AND (',' + RTRIM(" + subject + ") + ',') LIKE '%,' + {3} + ',%' AND (',' + RTRIM(m.Brancher) + ',') LIKE '%,' + {4} + ',%' Order By m.Udgivelsesdato DESC", "True", systemName + "Materiale", groupCategories, GetString("Item.Id"), branchSelectedId.ToString()) 519 */ 520 CommandBuilder.Create("SELECT * FROM Paragraph AS p INNER JOIN ItemType_" + systemName + "Materiale AS m ON p.ParagraphItemID = m.Id WHERE p.ParagraphShowParagraph = {0} AND p.ParagraphItemType = {1} AND (',' + RTRIM(m.Brancher) + ',') LIKE '%,' + {2} + ',%' Order By m.Udgivelsesdato DESC", "True", systemName + "Materiale", branchSelectedId.ToString()) 521 522 ); 523 524 using (var itemRenderReader = materialDataReader) 525 { 526 while (itemRenderReader.Read()) 527 { 528 var material = new Material 529 { 530 Id = int.Parse(itemRenderReader["Id"].ToString()), 531 ParagraphId = int.Parse(itemRenderReader["ParagraphID"].ToString()), 532 Title = itemRenderReader["Titel"].ToString(), 533 Description = itemRenderReader["Beskrivelse"].ToString(), 534 Content = itemRenderReader["Indhold"].ToString(), 535 Image = itemRenderReader["Billede"].ToString(), 536 Link = itemRenderReader["Link"].ToString(), 537 LinkTarget = itemRenderReader["Maal"].ToString(), 538 Category = (!string.IsNullOrEmpty(itemRenderReader["Kategori"].ToString())) ? int.Parse(itemRenderReader["Kategori"].ToString()) : 0, 539 Type = (!string.IsNullOrEmpty(itemRenderReader["Type"].ToString())) ? int.Parse(itemRenderReader["Type"].ToString()) : 0, 540 Published = (!string.IsNullOrEmpty(itemRenderReader["Udgivelsesdato"].ToString())) ? Convert.ToDateTime(itemRenderReader["Udgivelsesdato"].ToString()).ToString("yyyy") : "", 541 Images = new List<Image>(), 542 Branches = itemRenderReader["Brancher"].ToString(), 543 Emner = itemRenderReader["Emner"].ToString(), 544 }; 545 546 materials.Add(material); 547 } 548 itemRenderReader.Close(); 549 itemRenderReader.Dispose(); 550 } 551 552 return materials; 553 } 554 555 } 556 </main> 557 558 <footer class="footer archivo"> 559 <div class="container"> 560 <div class="row"> 561 <div class="col-md-4 newsletter newsletter-signup-form"> 562 <h4>Tilmeld nyhedsbrev</h4> 563 @RenderParagraphContent(91603) 564 @*<form class="newsletter-signup-form"> 565 <div class="form-group"> 566 <input type="text" class="form-control" id="name" placeholder="Navn"> 567 </div> 568 <div class="form-group"> 569 <input type="text" class="form-control" id="name" placeholder="E-mail"> 570 </div> 571 <div class="form-group"> 572 <select class="form-control"> 573 <option value="1">Vælg branche</option> 574 </select> 575 <a href="#">Privatlivspolitik</a> 576 </div> 577 <div class="form-group"> 578 <input type="checkbox" id="accept" name="accept"> Jeg bekræfter at have læst vores privatlivspolitik. 579 </div> 580 <button type="submit" class="btn btn-primary">Tilmeld dig</button> 581 582 </form>*@ 583 </div> 584 <div class="col-md-4 menu"> 585 <div class="row"> 586 <div class="col-md-6 menu-a"> 587 <h4>Om os</h4> 588 <div class="nav"> 589 590 @{ 591 var footerNavigationSettings = new NavigationSettings(); 592 footerNavigationSettings.StartLevel = 1; 593 footerNavigationSettings.StopLevel = 10; 594 footerNavigationSettings.ExpandMode = ExpandMode.All; 595 footerNavigationSettings.RootPageId = 20348; 596 } 597 @Navigation.RenderNavigation("Navigation/Vertical.cshtml", footerNavigationSettings) 598 599 <ul class="navbar-nav flex-column flex-fill "> 600 <li class="nav-item theme- "> 601 <div class="d-flex align-items-center"> 602 <a class="nav-link flex-fill text-reset " href="/Default.aspx?ID=@cookiePageId"> 603 <span class="">Cookie politik</span> 604 </a> 605 606 </div> 607 </li> 608 @if (!string.IsNullOrEmpty(privacyPoliticsPageId)) 609 { 610 <li class="nav-item theme- "> 611 <div class="d-flex align-items-center"> 612 <a class="nav-link flex-fill text-reset " href="/Default.aspx?ID=@privacyPoliticsPageId"> 613 <span class="">Privatlivspolitik</span> 614 </a> 615 616 </div> 617 </li> 618 } 619 </ul> 620 621 622 </div> 623 </div> 624 @if (!string.IsNullOrEmpty(linkedIn) || !string.IsNullOrEmpty(facebook) || !string.IsNullOrEmpty(privacyPoliticsPageId)) 625 { 626 <div class="col-md-6"> 627 <h4>SoMe</h4> 628 <div class="social"> 629 @if (!string.IsNullOrEmpty(linkedIn) || !string.IsNullOrEmpty(facebook)) 630 { 631 <ul> 632 @if (!string.IsNullOrEmpty(linkedIn)) 633 { 634 <li> 635 <a href="@linkedIn" target="_blank"><i class="fab fa-linkedin-in"></i></a> 636 </li> 637 } 638 @if (!string.IsNullOrEmpty(facebook)) 639 { 640 <li> 641 <a href="@facebook" target="_blank"><i class="fab fa-facebook-f"></i></a> 642 </li> 643 } 644 </ul> 645 } 646 </div> 647 648 </div> 649 } 650 651 </div> 652 653 654 655 </div> 656 <div class="col-md-4 contact"> 657 <h4>Adresse</h4> 658 <div class="address"> 659 @foreach (var item in GetLoop("Item.Area.Adresser")) 660 { 661 var title = item.GetString("Item.Area.Adresser.Titel"); 662 var address = item.GetString("Item.Area.Adresser.Adresse"); 663 var zip = item.GetString("Item.Area.Adresser.Postnummer"); 664 var city = item.GetString("Item.Area.Adresser.By"); 665 666 var name = item.GetString("Item.Area.Adresser.Navn"); 667 var phone = item.GetString("Item.Area.Adresser.Telefon"); 668 var email = item.GetString("Item.Area.Adresser.Email"); 669 670 <div class="xaddress" itemtype="http://schema.org/PostalAddress" itemscope=""> 671 <p>@title</p> 672 <p itemprop="streetAddress">@address<br> 673 <span itemprop="postalCode">@zip</span> <span itemprop="addressLocality">@city</span></p> 674 </div> 675 } 676 @foreach (var item in GetLoop("Item.Area.Adresser")) 677 { 678 var name = item.GetString("Item.Area.Adresser.Navn"); 679 var phone = item.GetString("Item.Area.Adresser.Telefon"); 680 var email = item.GetString("Item.Area.Adresser.Email"); 681 /*if (!string.IsNullOrEmpty(name)) 682 { 683 <h4>Konsulent</h4> 684 } 685 else 686 { 687 <h4>Kontakt</h4> 688 }*/ 689 <p> 690 @if (!string.IsNullOrEmpty(name)) { @name <br> } 691 @if (!string.IsNullOrEmpty(phone)) { <a href="tel:@phone" itemprop="telephone">@phone</a> <br> } 692 @if (!string.IsNullOrEmpty(email)) { <a href="mailto:@email" itemprop="email">@email</a> } 693 </p> 694 } 695 </div> 696 697 <div class="logo"> 698 <img src="@logoNegative" alt="@websiteTitel"> 699 </div> 700 </div> 701 </div> 702 703 704 705 706 </div> 707 708 </footer> 709 710 <div id="searchModal" class="modal fade" tabindex="-1" role="dialog"> 711 <div class="modal-dialog" role="document"> 712 <div class="modal-content"> 713 <div class="modal-body"> 714 <div class="container"> 715 <div class="row"> 716 <div class="search-field col-sm-12"> 717 <form action="Default.aspx" method="get"> 718 <input name="ID" value="@searchPageId" type="hidden" autocomplete="off"> 719 <input type="text" name="q" placeholder="@textSearchPlaceholder"> 720 <button type="submit"><i class="fal fa-search"></i></button> 721 </form> 722 </div> 723 </div> 724 </div> 725 </div> 726 </div> 727 </div> 728 </div> 729 730 <div id="videoModal" class="modal fade" tabindex="-1" role="dialog"> 731 <div class="modal-dialog" role="document"> 732 <div class="modal-content"> 733 <button type="button" class="modal-close" data-dismiss="modal">&times;</button> 734 <div class="modal-body"> 735 </div> 736 </div> 737 </div> 738 </div> 739 740 <script src="/Files/Templates/Designs/BfaPortalen/js/libs/jquery/jquery.js" data-cookieconsent="ignore"></script> 741 <script src="/Files/Templates/Designs/BfaPortalen/js/libs/bootstrap/bootstrap.js" data-cookieconsent="ignore"></script> 742 743 <script src="/Files/Templates/Designs/BfaPortalen/js/libs/lightslider/lightslider.js" data-cookieconsent="ignore"></script> 744 <script src="/Files/Templates/Designs/BfaPortalen/js/libs/clipboard2.0.11.min.js" data-cookieconsent="ignore"></script> 745 <script src="/Files/Templates/Designs/BfaPortalen/js/libs/stickybits/stickybits.js" data-cookieconsent="ignore"></script> 746 <script src="/Files/Templates/Designs/BfaPortalen/js/scripts.js?v=1.15" data-cookieconsent="ignore"></script> 747 <script src="/Files/Templates/Designs/BfaPortalen/js/pb-scripts.js?v=1.6" data-cookieconsent="ignore"></script> 748 <script src="/Files/Templates/Designs/BfaPortalen/js/pb-scripts2.js?v=1.9" data-cookieconsent="ignore"></script> 749 <script src="/Files/Templates/Designs/BfaPortalen/js/libs/slick-1.8.1/slick/slick.min.js" data-cookieconsent="ignore"></script> 750 <script src="/Files/Templates/Designs/BfaPortalen/js/libs/plyr-3.7.8/plyr.js" data-cookieconsent="ignore"></script> 751 <script src="/Files/Templates/Designs/BfaPortalen/js/analytics.js?v=1.1"></script> 752 753 </body> 754 </html> 755 @helper WriteMaterialCard(Material material, List<Category> categories, List<Type> types, List<Branch> branches, List<Emne> emner, bool hidden = false) { 756 var systemName = "Service_"; 757 var materialsPageId = 20182; 758 var materialId = material.Id; 759 var materialParagraphId = material.ParagraphId; 760 var materialTitle = material.Title; 761 var materialDescription = material.Description; 762 var materialImage = material.Image; 763 var materialCategory = (categories.Find(x => x.Id == material.Category) != null) ? categories.Find(x => x.Id == material.Category).Title : string.Empty; 764 var materialType = (types.Find(x => x.Id == material.Type) != null) ? types.Find(x => x.Id == material.Type).Title : string.Empty; 765 var showType = (types.Find(x => x.Id == material.Type) != null) ? types.Find(x => x.Id == material.Type).SynligSomLabel : false; 766 //var materialBrancher = (branches.Find(x => x.Id == brancher.Type) != null) ? types.Find(x => x.Id == material.Type).Title.ToLower() : string.Empty; 767 var materialLink = material.Link; 768 var materialLinkTarget = material.LinkTarget; 769 var materialPublished = (!string.IsNullOrEmpty(material.Published)) ? material.Published : ""; 770 var soeord = (!string.IsNullOrEmpty(material.Soeord)) ? "<span class='soeord hidden'>" + material.Soeord + "</span>" : ""; 771 var materialBrancher = ""; 772 var materialBrancheLabel = ""; 773 var materialBrancherFilter = ""; 774 if (!string.IsNullOrEmpty(material.Branches)) 775 { 776 var branchIds = material.Branches.Split(','); 777 var branchTitles = new List<string>(); 778 foreach (var branchId in branchIds) 779 { 780 var branch = branches.Find(x => x.PageId.ToString() == branchId); 781 if (branch != null) 782 { 783 branchTitles.Add(branch.Title); 784 if (materialBrancheLabel == "") 785 { 786 materialBrancheLabel = branch.Title; 787 } else 788 { 789 materialBrancheLabel = "Brancher..."; 790 } 791 } 792 } 793 materialBrancher += string.Join(", ", branchTitles); 794 materialBrancherFilter = string.Join("#", branchTitles); 795 } 796 797 var materialEmner = ""; 798 var materialEmnerLabel = ""; 799 var materialEmnerFilter = ""; 800 if (!string.IsNullOrEmpty(material.Emner)) 801 { 802 var emneIds = material.Emner.Split(','); 803 var emneTitles = new List<string>(); 804 foreach (var emneId in emneIds) 805 { 806 var emne = emner.Find(x => x.Id.ToString() == emneId); 807 if (emne != null) 808 { 809 emneTitles.Add(emne.Title); 810 if (materialEmnerLabel == "") 811 { 812 materialEmnerLabel = emne.Title; 813 } else 814 { 815 materialEmnerLabel = "Emner..."; 816 } 817 } 818 } 819 materialEmner += string.Join(", ", emneTitles); 820 materialEmnerFilter = string.Join("#", emneTitles); 821 } 822 823 if (materialImage.ToLower().Contains("barservice/") && !materialImage.ToLower().Contains("/billeder") && !materialImage.ToLower().Contains("../") && !materialImage.ToLower().Contains("download.aspx") && !string.IsNullOrEmpty(materialImage.ToString())) 824 { 825 materialImage = "/Files/Billeder/" + materialImage; 826 } 827 828 if (materialLink == null || string.IsNullOrEmpty(materialLink.ToString())) 829 { 830 materialLink = "/Default.aspx?ID=" + materialsPageId + "&itemId=" + systemName + "Materiale:" + materialId; 831 } 832 if (materialLink.ToLower().Contains("/billeder") && !materialLink.ToLower().Contains("files/") && !materialLink.ToLower().Contains("/filer") && !materialLink.ToLower().Contains("download.aspx") && !string.IsNullOrEmpty(materialLink.ToString())) 833 { 834 materialLink = "/Files" + materialLink; 835 } 836 if (materialLink.ToLower().Contains("/barservice") && !materialLink.ToLower().Contains("/billeder") && !materialLink.ToLower().Contains("/filer") && !materialLink.ToLower().Contains("download.aspx") && !string.IsNullOrEmpty(materialLink.ToString())) 837 { 838 materialLink = "/Files/Billeder" + materialLink; 839 } 840 if (materialLink.ToLower().Contains("/filer") && !materialLink.ToLower().Contains("files/") && !materialLink.ToLower().Contains("download.aspx") && !string.IsNullOrEmpty(materialLink.ToString())) 841 { 842 materialLink = "/Files" + materialLink; 843 } 844 845 if (materialLink.ToLower().Contains(".pdf") || materialLink.ToLower().Contains(".doc") || materialLink.ToLower().Contains(".docx") || materialLink.ToLower().Contains(".xls") || materialLink.ToLower().Contains(".xlsx") || materialLink.ToLower().Contains(".ppt") || materialLink.ToLower().Contains(".pptx") || materialLink.ToLower().Contains(".epub")) 846 { 847 materialLinkTarget = "_blank"; 848 } 849 850 // height of material 851 var materialClass = (materialDescription.Length > 160) ? "short" : string.Empty; 852 853 var sortDateAsc = material.SortDate; 854 int sortdate = 0; 855 int.TryParse(material.SortDate, out sortdate); 856 var sortDateDesc = (99999999 - sortdate).ToString(); 857 858 string hideString = hidden ? "display:none" : ""; 859 // alternative image 860 var materialImageAlternative = (!string.IsNullOrEmpty(materialType)) ? "/Files/Templates/Designs/bfa5-service/img/no-image-" + materialType + ".png" : "/Files/Templates/Designs/bfa5-service/img/no-image-side.png"; 861 var urlTitle = materialTitle.Replace("\"", ""); 862 <li class="li @materialClass " data-sorttitle="@urlTitle" data-sortdateasc="@sortDateAsc" data-sortdatedesc="@sortDateDesc" data-filteremne="@materialEmner" data-filterbranche="@materialBrancher" data-sortemne="@materialEmnerLabel" data-filteremner="@materialEmnerFilter" data-filterbrancher="@materialBrancherFilter" data-nyhed="@material.Nyhed" data-sorttype="@materialCategory" style="@hideString"> 863 <article itemtype="https://schema.org/Article" itemscope=""> 864 @if (materialType == "popup") 865 { 866 <div class="materialcard @materialType" data-url="@materialLink" data-title="@urlTitle" data-id="@materialParagraphId"> 867 <div class="image"> 868 <img src="/admin/public/getimage.aspx?Image=@materialImage&AlternativeImage=@materialImageAlternative&width=400" alt="@materialTitle" itemprop="image"> 869 </div> 870 <div class="body"> 871 <div class="subject">@materialCategory @materialPublished</div> 872 <header><h3 class="title" itemprop="headline">@materialTitle</h3></header> 873 <div class="description @materialClass" itemprop="description"> 874 @materialDescription 875 </div> 876 </div> 877 </div> 878 } 879 else 880 { 881 <a class="materialcard" href="@materialLink" target="@materialLinkTarget" itemprop="url" data-id="@materialParagraphId" data-materialtype="@materialType"> 882 <div class="image"> 883 <img src="/admin/public/getimage.aspx?Image=@materialImage&AlternativeImage=@materialImageAlternative&width=400" alt="@materialTitle" itemprop="image"> 884 </div> 885 <div class="body"> 886 <div class="subject"> 887 <span>@materialPublished</span> 888 <span>@materialCategory</span> 889 @if (!string.IsNullOrEmpty(materialBrancher)) 890 { 891 <span title="@materialBrancher">@materialBrancheLabel</span> 892 } 893 @if (!string.IsNullOrEmpty(materialEmner)) 894 { 895 <span title="@materialEmner">@materialEmnerLabel</span> 896 } 897 @if (!string.IsNullOrEmpty(materialType) && showType) 898 { 899 <span>@materialType</span> 900 } 901 902 </div> 903 <header><h3 class="title" itemprop="headline">@materialTitle</h3></header> 904 <div class="description @materialClass" itemprop="description"> 905 @materialDescription 906 @soeord 907 </div> 908 909 </div> 910 911 912 </a> 913 } 914 </article> 915 </li> 916 917 } 918 919 @functions { 920 921 public class Branch 922 { 923 public int Id { get; set; } 924 public int PageId { get; set; } 925 926 public string Title { get; set; } 927 928 public string Description { get; set; } 929 930 public string Image { get; set; } 931 public int UndermenuPunkter1 { get; set; } 932 public int UndermenuPunkter2 { get; set; } 933 public string Farver { get; set; } 934 public string FarverMobil { get; set; } 935 936 } 937 938 public class Farve 939 { 940 public int Id { get; set; } 941 public string Title { get; set; } 942 public string Tekstfarve { get; set; } 943 public string Baggrundsfarve { get; set; } 944 public string SekTekstfarve { get; set; } 945 public string SekBaggrundsfarve { get; set; } 946 public string MobilTekstfarve { get; set; } 947 public string MobilBaggrundsfarve { get; set; } 948 949 } 950 951 public List<Farve> getFarver(Area area, string systemName) 952 { 953 var farver = new List<Farve>(); 954 using (var itemReader = Database.CreateDataReader(CommandBuilder.Create("SELECT * FROM ItemType_Farve AS f Order By f.Id Desc"))) 955 { 956 while (itemReader.Read()) 957 { 958 var farve = new Farve 959 { 960 Id = int.Parse(itemReader["Id"].ToString()), 961 Title = itemReader["Titel"].ToString(), 962 Tekstfarve = itemReader["Tekstfarve"].ToString(), 963 Baggrundsfarve = itemReader["Baggrundsfarve"].ToString(), 964 SekTekstfarve = itemReader["Sekund_rTekstfarve"].ToString(), 965 SekBaggrundsfarve = itemReader["Sekund_rBaggrundsfarve"].ToString(), 966 MobilTekstfarve = itemReader["MobilTekstfarve"].ToString(), 967 MobilBaggrundsfarve = itemReader["MobilBaggrundsfarve"].ToString(), 968 969 }; 970 farver.Add(farve); 971 } 972 itemReader.Close(); 973 itemReader.Dispose(); 974 } 975 return farver; 976 } 977 /* public List<ChildPages> getChildPages(int parentId) 978 { 979 var children = new List<ChildPages>(); 980 using (var itemReader = Database.CreateDataReader(CommandBuilder.Create("SELECT * FROM Page AS p INNER JOIN ItemType_" + systemName + "Branche AS b ON p.PageItemId = b.Id WHERE p.PageAreaID = {0} AND p.PageActive = {1} AND p.PageItemType = {2} Order By p.PageSort ASC", area.ID, "True", systemName + "Branche"))) 981 { 982 while (itemReader.Read()) 983 { 984 var child = new ChildPages 985 { 986 Id = int.Parse(itemReader["Id"].ToString()), 987 988 Title = itemReader["Titel"].ToString(), 989 Image = itemReader["Billede"].ToString(), 990 UndermenuPunkter1 = itemReader["UndermenuPunkter_1"].ToString(), 991 UndermenuPunkter2 = itemReader["UndermenuPunkter_2"].ToString(), 992 Farver = itemReader["Farver"].ToString(), 993 FarverMobil = itemReader["FarverMobil"].ToString(), 994 995 }; 996 children.Add(child); 997 } 998 itemReader.Close(); 999 itemReader.Dispose(); 1000 } 1001 return children; 1002 }*/ 1003 public List<Branch> getBranches(Area area, string systemName) 1004 { 1005 var branches = new List<Branch>(); 1006 using (var itemReader = Database.CreateDataReader(CommandBuilder.Create("SELECT * FROM Page AS p INNER JOIN ItemType_" + systemName + "Branche AS b ON p.PageItemId = b.Id WHERE p.PageAreaID = {0} AND p.PageActive = {1} AND p.PageItemType = {2} Order By p.PageSort ASC", area.ID, "True", systemName + "Branche"))) 1007 { 1008 while (itemReader.Read()) 1009 { 1010 var branch = new Branch 1011 { 1012 Id = int.Parse(itemReader["Id"].ToString()), 1013 PageId = int.Parse(itemReader["PageID"].ToString()), 1014 Title = itemReader["Titel"].ToString(), 1015 Image = itemReader["Billede"].ToString(), 1016 UndermenuPunkter1 = (!string.IsNullOrEmpty(itemReader["UndermenuPunkter_1"].ToString()) ) ? int.Parse(itemReader["UndermenuPunkter_1"].ToString()) : 0, 1017 UndermenuPunkter2 = (!string.IsNullOrEmpty(itemReader["UndermenuPunkter_2"].ToString()) ) ? int.Parse(itemReader["UndermenuPunkter_2"].ToString()) : 0, 1018 Farver = itemReader["Farver"].ToString(), 1019 FarverMobil = itemReader["FarverMobil"].ToString(), 1020 1021 }; 1022 1023 branches.Add(branch); 1024 } 1025 itemReader.Close(); 1026 itemReader.Dispose(); 1027 } 1028 return branches; 1029 } 1030 public List<Branch> getBrancheSider(Area area, string systemName) 1031 { 1032 var branches = new List<Branch>(); 1033 using (var itemReader = Database.CreateDataReader(CommandBuilder.Create("SELECT * FROM Page AS p INNER JOIN ItemType_Branche_Side AS b ON p.PageItemId = b.Id WHERE p.PageAreaID = {0} AND p.PageActive = {1} AND p.PageItemType = {2} Order By p.PageSort ASC", area.ID, "True", "Branche_Side"))) 1034 { 1035 while (itemReader.Read()) 1036 { 1037 var branch = new Branch 1038 { 1039 Id = int.Parse(itemReader["Id"].ToString()), 1040 PageId = int.Parse(itemReader["PageID"].ToString()), 1041 Title = itemReader["Titel"].ToString(), 1042 Image = itemReader["Billede"].ToString(), 1043 UndermenuPunkter1 = (!string.IsNullOrEmpty(itemReader["UndermenuPunkter_1"].ToString()) ) ? int.Parse(itemReader["UndermenuPunkter_1"].ToString()) : 0, 1044 UndermenuPunkter2 = (!string.IsNullOrEmpty(itemReader["UndermenuPunkter_2"].ToString()) ) ? int.Parse(itemReader["UndermenuPunkter_2"].ToString()) : 0, 1045 Farver = itemReader["Farver"].ToString(), 1046 FarverMobil = itemReader["FarverMobil"].ToString(), 1047 1048 }; 1049 1050 branches.Add(branch); 1051 } 1052 itemReader.Close(); 1053 itemReader.Dispose(); 1054 } 1055 return branches; 1056 } 1057 /* 1058 public class Branch 1059 { 1060 public int Id { get; set; } 1061 1062 public string Title { get; set; } 1063 } 1064 public List<Branch> getBranches(Area area, string systemName) 1065 { 1066 var branches = new List<Branch>(); 1067 using (var itemReader = Database.CreateDataReader(CommandBuilder.Create("SELECT * FROM Page AS p INNER JOIN ItemType_" + systemName + "Branche AS b ON p.PageItemId = b.Id WHERE p.PageAreaID = {0} AND p.PageActive = {1} AND p.PageItemType = {2} Order By b.Sort ASC", area.ID, "True", systemName + "Branche"))) 1068 { 1069 while (itemReader.Read()) 1070 { 1071 var branch = new Branch 1072 { 1073 Id = int.Parse(itemReader["Id"].ToString()), 1074 Title = itemReader["Titel"].ToString() 1075 }; 1076 branches.Add(branch); 1077 } 1078 itemReader.Close(); 1079 itemReader.Dispose(); 1080 } 1081 return branches; 1082 } 1083 */ 1084 public class Category 1085 { 1086 public int Id { get; set; } 1087 1088 public string Title { get; set; } 1089 } 1090 public List<Category> getCategories(Area area, string systemName) 1091 { 1092 var categories = new List<Category>(); 1093 using (var itemReader = Database.CreateDataReader(CommandBuilder.Create("SELECT * FROM Paragraph AS pg INNER JOIN ItemType_" + systemName + "Kategori AS c ON pg.ParagraphItemId = c.Id INNER JOIN Page AS p ON pg.ParagraphPageId = p.PageId WHERE p.PageAreaID = {0} AND pg.ParagraphShowParagraph = {1} AND pg.ParagraphItemType = {2} Order By c.Titel ASC", area.ID, "True", systemName + "Kategori"))) 1094 { 1095 while (itemReader.Read()) 1096 { 1097 var category = new Category 1098 { 1099 Id = int.Parse(itemReader["Id"].ToString()), 1100 Title = itemReader["Titel"].ToString() 1101 }; 1102 categories.Add(category); 1103 } 1104 itemReader.Close(); 1105 itemReader.Dispose(); 1106 } 1107 return categories; 1108 } 1109 1110 public class Type 1111 { 1112 public int Id { get; set; } 1113 1114 public string Title { get; set; } 1115 public bool SynligSomLabel { get; set; } 1116 } 1117 public List<Type> getTypes(Area area, string systemName) 1118 { 1119 var types = new List<Type>(); 1120 using (var itemReader = Database.CreateDataReader(CommandBuilder.Create("SELECT * FROM Paragraph AS pg INNER JOIN ItemType_" + systemName + "Type AS t ON pg.ParagraphItemId = t.Id INNER JOIN Page AS p ON pg.ParagraphPageId = p.PageId WHERE p.PageAreaID = {0} AND pg.ParagraphShowParagraph = {1} AND pg.ParagraphItemType = {2} Order By t.Titel ASC", area.ID, "True", systemName + "Type"))) 1121 { 1122 while (itemReader.Read()) 1123 { 1124 var type = new Type 1125 { 1126 Id = int.Parse(itemReader["Id"].ToString()), 1127 Title = itemReader["Titel"].ToString(), 1128 SynligSomLabel = (itemReader["SynligSomLabel"].ToString() == "True") ? true : false 1129 }; 1130 types.Add(type); 1131 } 1132 itemReader.Close(); 1133 itemReader.Dispose(); 1134 } 1135 return types; 1136 } 1137 public class Emne 1138 { 1139 public int Id { get; set; } 1140 1141 public string Title { get; set; } 1142 } 1143 public List<Emne> getEmner(Area area, string systemName) 1144 { 1145 var emner = new List<Emne>(); 1146 using (var itemReader = Database.CreateDataReader(CommandBuilder.Create("SELECT * FROM Page AS p INNER JOIN ItemType_" + systemName + "Emne AS b ON p.PageItemId = b.Id WHERE p.PageAreaID = {0} AND p.PageActive = {1} AND p.PageItemType = {2} Order By p.PageSort ASC", area.ID, "True", systemName + "Emne"))) 1147 //using (var itemReader = Database.CreateDataReader(CommandBuilder.Create("SELECT * FROM Paragraph AS pg INNER JOIN ItemType_" + systemName + "Emne AS t ON pg.ParagraphItemId = t.Id INNER JOIN Page AS p ON pg.ParagraphPageId = p.PageId WHERE p.PageAreaID = {0} AND pg.ParagraphShowParagraph = {1} AND pg.ParagraphItemType = {2} Order By t.Titel ASC", area.ID, "True", systemName + "Emne"))) 1148 { 1149 while (itemReader.Read()) 1150 { 1151 var emne = new Emne 1152 { 1153 Id = int.Parse(itemReader["Id"].ToString()), 1154 Title = itemReader["Titel"].ToString() 1155 }; 1156 emner.Add(emne); 1157 } 1158 itemReader.Close(); 1159 itemReader.Dispose(); 1160 } 1161 return emner; 1162 } 1163 1164 1165 1166 public class Group 1167 { 1168 public int Id { get; set; } 1169 1170 public string Title { get; set; } 1171 1172 public string Showing { get; set; } 1173 1174 public List<Material> Materials { get; set; } 1175 } 1176 1177 public class Material 1178 { 1179 public int Id { get; set; } 1180 1181 public int ParagraphId { get; set; } 1182 1183 public string Title { get; set; } 1184 1185 public string Description { get; set; } 1186 1187 public string Content { get; set; } 1188 1189 public string Image { get; set; } 1190 1191 public string Link { get; set; } 1192 1193 public string LinkTarget { get; set; } 1194 1195 public int Category { get; set; } 1196 1197 public int Type { get; set; } 1198 1199 public string Published { get; set; } 1200 public string SortDate { get; set; } 1201 public List<Image> Images { get; set; } 1202 1203 public string Branches { get; set; } 1204 public string Emner { get; set; } 1205 public string Farver { get; set; } 1206 public string Soeord { get; set; } 1207 public string Nyhed { get; set; } 1208 } 1209 1210 public class Image 1211 { 1212 public int Id { get; set; } 1213 1214 public string Title { get; set; } 1215 1216 public string Path { get; set; } 1217 1218 public List<int> Branches { get; set; } 1219 } 1220 1221 1222 1223 1224 } 1225