Error executing template "Designs/Esbjerg/_parsed/SubsiteFrontpage.parsed.cshtml"
System.NullReferenceException: Object reference not set to an instance of an object.
   at CompiledRazorTemplates.Dynamic.RazorEngine_b9e2fa9d96fd43afafb48d743fba4de0.Execute() in D:\Subsites\Files\Templates\Designs\Esbjerg\_parsed\SubsiteFrontpage.parsed.cshtml:line 429
   at RazorEngine.Templating.TemplateBase.RazorEngine.Templating.ITemplate.Run(ExecuteContext context, TextWriter reader)
   at RazorEngine.Templating.RazorEngineService.RunCompile(ITemplateKey key, TextWriter writer, Type modelType, Object model, DynamicViewBag viewBag)
   at RazorEngine.Templating.RazorEngineServiceExtensions.<>c__DisplayClass16_0.b__0(TextWriter writer)
   at RazorEngine.Templating.RazorEngineServiceExtensions.WithWriter(Action`1 withWriter)
   at Dynamicweb.Rendering.Template.RenderRazorTemplate()

1 @using System.Activities.Statements 2 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 3 @Title("Subsite - Master") 4 @Description("Master template til subsites") 5 @{ 6 var bodyClass = "subsite"; 7 8 // thema variables 9 var themeActive = Model.Area.Item.GetBoolean("Subsite"); 10 var themeTop = Model.Area.Item.GetList("ThemeTop").SelectedValue; 11 var themeContentArea = Model.Area.Item.GetList("ThemeContentArea").SelectedValue; 12 var themeFooter = Model.Area.Item.GetList("ThemeFooter").SelectedValue; 13 var themeTopHex = themeActive && themeTop != null ? themeTop : ""; 14 var themeContentHex = themeActive && themeContentArea != null ? themeContentArea : ""; 15 var themeFooterHex = themeActive && themeFooter != null ? themeFooter : ""; 16 17 var searchPageId = Model.Area.Item.GetInt64("SearchResultPage"); 18 var bodyId = ""; 19 20 // if current page is the searchresult page 21 if (searchPageId != 0) 22 { 23 if (Dynamicweb.Frontend.PageView.Current().Page.ID == searchPageId) 24 { 25 bodyId = "id=\"cludo-search-results\""; 26 } 27 } 28 29 if (Dynamicweb.Environment.ExecutingContext.IsAdminLoggedIn()) 30 { 31 bodyClass += " logged-in"; 32 } 33 } 34 35 <!DOCTYPE html> 36 <html lang="@Dynamicweb.Services.Areas.GetArea(Model.Area.ID).CultureInfo.TwoLetterISOLanguageName" class="no-js"> 37 38 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 39 40 @using Esbjerg.Logic 41 42 @{ 43 string cssPath = "/Files/Templates/Designs/" + Pageview.Layout.Design.Name; 44 //Color codes 45 // string colorPrimary = "#007AB8"; 46 // string colorPrimaryHover = "#004069"; 47 // string colorPrimaryAlternate = "#00669F"; 48 // string colorSecondary = "#007AB8"; 49 // string textPrimary = "#FFFFFF"; 50 // string textSecondary = "#FFFFFF"; 51 // string colorLink = "#D53F53"; 52 // string colorLinkAlternate = colorPrimary; 53 54 // if (Model.Area.Item.GetBoolean("Subsite")) 55 // { 56 // colorPrimary = Model.Area.Item.GetString("ColorArea1"); 57 // colorPrimaryHover = Model.Area.Item.GetString("HoverColor"); // Need new color in BE here 58 // colorPrimaryAlternate = colorPrimaryHover; 59 // colorSecondary = Model.Area.Item.GetString("ColorArea2"); 60 // textPrimary = Model.Area.Item.GetString("MenuTextColorPassive"); 61 // textSecondary = Model.Area.Item.GetString("HeaderFooterMenuText"); 62 // colorLink = colorPrimary; 63 // colorLinkAlternate = colorPrimary; 64 // } 65 66 string appleTouchIcon = @Model.Area.Item.GetString("Apple_touch_icon"); 67 string Favicon32x32 = @Model.Area.Item.GetString("Favicon32x32"); 68 string Favicon16x16 = @Model.Area.Item.GetString("Favicon16x16"); 69 } 70 <head> 71 <title>@Model.Title</title> 72 <meta name="pageID" content='@Model.ID'> 73 <script src="https://cookiecontrol.bleau.dk/scripts/cookieconsent.js"></script> 74 <script id="cookiecontrolfunctions" src="https://cookiecontrol.bleau.dk/scripts/Cookiecontrolfunctions.js" data-cname="Esbjerg" data-defaultset="EsbjergDefault"></script> 75 <meta name="description" content="@Model.Description" /> 76 <meta name="keywords" content="@Model.Keywords" /> 77 <meta charset="utf-8"> 78 <!-- Add to web.config --> 79 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 80 <meta name="viewport" content="width=device-width, initial-scale=1"> 81 <meta name="format-detection" content="telephone=no"> 82 83 <!-- Change this to be dynamic --> 84 @RenderSnippet("MetaTags") 85 86 <!-- Favicons @appleTouchIcon test="@(!String.IsNullOrEmpty(appleTouchIcon) ? "@appleTouchIcon" : "/apple-touch-icon.png")" --> 87 88 89 <link rel="apple-touch-icon" sizes="180x180" href="@(!String.IsNullOrEmpty(appleTouchIcon) ? @appleTouchIcon : "/apple-touch-icon.png")"> 90 <link rel="icon" type="image/png" sizes="32x32" href="@(!String.IsNullOrEmpty(@Favicon32x32) ? @Favicon32x32 : "/favicon-32x32.png")"> 91 <link rel="icon" type="image/png" sizes="16x16" href="@(!String.IsNullOrEmpty(@Favicon16x16) ? @Favicon16x16 : "/favicon-16x16.png")"> 92 <link rel="manifest" href="/site.webmanifest"> 93 <link rel="mask-icon" href="/safari-pinned-tab.svg" color="Favicon32x32#5bbad5"> 94 <meta name="msapplication-TileColor" content="#da532c"> 95 <meta name="theme-color" content="#ffffff"> 96 97 @RenderSnippet("EditorSnippet") 98 99 <!-- Create a block of inline styling to display until the primary CSS is ready. --> 100 <style type="text/css"> @Helpers.ReadFile(Pageview.Layout.Design.Path, "static/dist/css/critical-subsite.min.css")</style> 101 @* <link rel="preload" href="@cssPath/static/dist/css/critical-subsite.min.css" as="style" onload="this.onload=null;this.rel='stylesheet';window.esbjerg&&window.esbjerg.stylesLoaded&&window.esbjerg.stylesLoaded()"> *@ 102 <link rel="preload" href="@cssPath/static/dist/css/main-subsite.min.css" as="style" onload="this.onload=null;this.rel='stylesheet';window.esbjerg&&window.esbjerg.stylesLoaded&&window.esbjerg.stylesLoaded()"> 103 <noscript><link rel="stylesheet" type="text/css" href="@cssPath/static/dist/css/main-subsite.min.css"></noscript> 104 <!-- www.Cludo.com search start CSS --> 105 <link href="https://customer.cludo.com/assets/80/10930/cludo-search.min.css" type="text/css" rel="stylesheet"> 106 <!-- Preload our main script, since we know we are gonna load this later --> 107 @*<link rel="preload" as="script" href="@cssPath/static/dist/js/main.min.js">*@ 108 109 <link rel="preload" href="@cssPath/static/dist/fonts/OpenSans/OpenSans-Regular.woff2" as="font" type="font/woff2" crossorigin="anonymous"> 110 <link rel="preload" href="@cssPath/static/dist/fonts/OpenSans/OpenSans-Regular.woff" as="font" type="font/woff" crossorigin="anonymous"> 111 <link rel="preload" href="@cssPath/static/dist/fonts/OpenSans/OpenSans-Regular.ttf" as="font" type="font/ttf" crossorigin="anonymous"> 112 113 <link rel="preload" href="@cssPath/static/dist/fonts/OpenSans/OpenSans-Light.woff2" as="font" type="font/woff2" crossorigin="anonymous"> 114 <link rel="preload" href="@cssPath/static/dist/fonts/OpenSans/OpenSans-Light.woff" as="font" type="font/woff" crossorigin="anonymous"> 115 <link rel="preload" href="@cssPath/static/dist/fonts/OpenSans/OpenSans-Light.ttf" as="font" type="font/ttf" crossorigin="anonymous"> 116 117 <link rel="preload" href="@cssPath/static/dist/fonts/OpenSans/OpenSans-Bold.woff2" as="font" type="font/woff2" crossorigin="anonymous"> 118 <link rel="preload" href="@cssPath/static/dist/fonts/OpenSans/OpenSans-Bold.woff" as="font" type="font/woff" crossorigin="anonymous"> 119 <link rel="preload" href="@cssPath/static/dist/fonts/OpenSans/OpenSans-Bold.ttf" as="font" type="font/ttf" crossorigin="anonymous"> 120 121 122 123 <!-- You can use "prefetch" to preload other important assets (if you're not using HTTP/2 push) --> 124 <!-- And you can tell the browser to pre-connect to other sites you know you are going to talk to eventually: --> 125 <link rel="dns-prefetch" href="https://cdn.polyfill.io"> 126 127 <script type="text/javascript">@Helpers.ReadFile(Pageview.Layout.Design.Path, "static/dist/js/modernizr.js")</script> 128 129 <!--Insights--> 130 <script type="text/javascript"> 131 !function (T, l, y) { var S = T.location, u = "script", k = "instrumentationKey", D = "ingestionendpoint", C = "disableExceptionTracking", E = "ai.device.", I = "toLowerCase", b = "crossOrigin", w = "POST", e = "appInsightsSDK", t = y.name || "appInsights"; (y.name || T[e]) && (T[e] = t); var n = T[t] || function (d) { var g = !1, f = !1, m = { initialize: !0, queue: [], sv: "4", version: 2, config: d }; function v(e, t) { var n = {}, a = "Browser"; return n[E + "id"] = a[I](), n[E + "type"] = a, n["ai.operation.name"] = S && S.pathname || "_unknown_", n["ai.internal.sdkVersion"] = "javascript:snippet_" + (m.sv || m.version), { time: function () { var e = new Date; function t(e) { var t = "" + e; return 1 === t.length && (t = "0" + t), t } return e.getUTCFullYear() + "-" + t(1 + e.getUTCMonth()) + "-" + t(e.getUTCDate()) + "T" + t(e.getUTCHours()) + ":" + t(e.getUTCMinutes()) + ":" + t(e.getUTCSeconds()) + "." + ((e.getUTCMilliseconds() / 1e3).toFixed(3) + "").slice(2, 5) + "Z" }(), iKey: e, name: "Microsoft.ApplicationInsights." + e.replace(/-/g, "") + "." + t, sampleRate: 100, tags: n, data: { baseData: { ver: 2 } } } } var h = d.url || y.src; if (h) { function a(e) { var t, n, a, i, r, o, s, c, p, l, u; g = !0, m.queue = [], f || (f = !0, t = h, s = function () { var e = {}, t = d.connectionString; if (t) for (var n = t.split(";"), a = 0; a < n.length; a++) { var i = n[a].split("="); 2 === i.length && (e[i[0][I]()] = i[1]) } if (!e[D]) { var r = e.endpointsuffix, o = r ? e.location : null; e[D] = "https://" + (o ? o + "." : "") + "dc." + (r || "services.visualstudio.com") } return e }(), c = s[k] || d[k] || "", p = s[D], l = p ? p + "/v2/track" : config.endpointUrl, (u = []).push((n = "SDK LOAD Failure: Failed to load Application Insights SDK script (See stack for details)", a = t, i = l, (o = (r = v(c, "Exception")).data).baseType = "ExceptionData", o.baseData.exceptions = [{ typeName: "SDKLoadFailed", message: n.replace(/\./g, "-"), hasFullStack: !1, stack: n + "\nSnippet failed to load [" + a + "] -- Telemetry is disabled\nHelp Link: https://go.microsoft.com/fwlink/?linkid=2128109\nHost: " + (S && S.pathname || "_unknown_") + "\nEndpoint: " + i, parsedStack: [] }], r)), u.push(function (e, t, n, a) { var i = v(c, "Message"), r = i.data; r.baseType = "MessageData"; var o = r.baseData; return o.message = 'AI (Internal): 99 message:"' + ("SDK LOAD Failure: Failed to load Application Insights SDK script (See stack for details) (" + n + ")").replace(/\"/g, "") + '"', o.properties = { endpoint: a }, i }(0, 0, t, l)), function (e, t) { if (JSON) { var n = T.fetch; if (n && !y.useXhr) n(t, { method: w, body: JSON.stringify(e), mode: "cors" }); else if (XMLHttpRequest) { var a = new XMLHttpRequest; a.open(w, t), a.setRequestHeader("Content-type", "application/json"), a.send(JSON.stringify(e)) } } }(u, l)) } function i(e, t) { f || setTimeout(function () { !t && m.core || a() }, 500) } var e = function () { var n = l.createElement(u); n.src = h; var e = y[b]; return !e && "" !== e || "undefined" == n[b] || (n[b] = e), n.onload = i, n.onerror = a, n.onreadystatechange = function (e, t) { "loaded" !== n.readyState && "complete" !== n.readyState || i(0, t) }, n }(); y.ld < 0 ? l.getElementsByTagName("head")[0].appendChild(e) : setTimeout(function () { l.getElementsByTagName(u)[0].parentNode.appendChild(e) }, y.ld || 0) } try { m.cookie = l.cookie } catch (p) { } function t(e) { for (; e.length;)!function (t) { m[t] = function () { var e = arguments; g || m.queue.push(function () { m[t].apply(m, e) }) } }(e.pop()) } var n = "track", r = "TrackPage", o = "TrackEvent"; t([n + "Event", n + "PageView", n + "Exception", n + "Trace", n + "DependencyData", n + "Metric", n + "PageViewPerformance", "start" + r, "stop" + r, "start" + o, "stop" + o, "addTelemetryInitializer", "setAuthenticatedUserContext", "clearAuthenticatedUserContext", "flush"]), m.SeverityLevel = { Verbose: 0, Information: 1, Warning: 2, Error: 3, Critical: 4 }; var s = (d.extensionConfig || {}).ApplicationInsightsAnalytics || {}; if (!0 !== d[C] && !0 !== s[C]) { method = "onerror", t(["_" + method]); var c = T[method]; T[method] = function (e, t, n, a, i) { var r = c && c(e, t, n, a, i); return !0 !== r && m["_" + method]({ message: e, url: t, lineNumber: n, columnNumber: a, error: i }), r }, d.autoExceptionInstrumented = !0 } return m }(y.cfg); (T[t] = n).queue && 0 === n.queue.length && n.trackPageView({}) }(window, document, { 132 src: "https://az416426.vo.msecnd.net/scripts/b/ai.2.min.js", // The SDK URL Source 133 //name: "appInsights", // Global SDK Instance name defaults to "appInsights" when not supplied 134 //ld: 0, // Defines the load delay (in ms) before attempting to load the sdk. -1 = block page load and add to head. (default) = 0ms load after timeout, 135 //useXhr: 1, // Use XHR instead of fetch to report failures (if available), 136 //crossOrigin: "anonymous", // When supplied this will add the provided value as the cross origin attribute on the script tag 137 cfg: { // Application Insights Configuration 138 instrumentationKey: "5b8602f4-7263-41f7-b005-6c42db042759", 139 name: "BleauBorgerEsbjerg", 140 isCookieUseDisabled: "true" 141 /* ...Other Configuration Options... */ 142 } 143 }); 144 </script> 145 146 <!--Kode - Header section--> 147 @RenderSnippet("KodeHeader") 148 149 @RenderSnippet("MinimapHead") 150 </head> 151 152 <body class="@bodyClass" @bodyId> 153 @if (themeActive) 154 { 155 <style> 156 :root { 157 /* Header/Top Area*/ 158 --theme-top__primary-color: @($"#{themeTopHex}"); 159 --theme-top__primary-color--alternate: @($"#{GetLinkColor(themeTopHex)}"); 160 --theme-top__primary-color--text: @GetThemeTextColor(themeTopHex); 161 --theme-top__primary-color--dimmed: @($"#{GetContrastColor(themeTopHex)}"); 162 --theme-top__color--link-hover: @($"#{themeTopHex}"); 163 164 /* Content Area */ 165 --theme-content__primary-color: @($"#{themeContentHex}"); 166 --theme-content__primary-color--alternate: @($"#{GetLinkColor(themeContentHex)}"); 167 --theme-content__primary-color--text: @GetThemeTextColor(themeContentHex); 168 --theme-content__color--gallery-arrow: @($"#{themeContentHex}"); 169 --theme-content__primary-color--dimmed: @($"#{GetContrastColor(themeContentHex)}"); 170 --theme-content__color--link-hover: @($"#{themeContentHex}"); 171 172 /* Footer Area */ 173 --theme-footer__primary-color: @($"#{themeFooterHex}"); 174 --theme-footer__primary-color--alternate: @($"#{GetLinkColor(themeFooterHex)}"); 175 --theme-footer__primary-color--text: @GetThemeTextColor(themeFooterHex); 176 --theme-footer__primary-color--dimmed: @($"#{GetContrastColor(themeFooterHex)}"); 177 --theme-footer__color--link-hover: @($"#{GetLinkColor(themeFooterHex)}"); 178 } 179 </style> 180 } 181 182 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 183 <header class="header-main header-main--subsite"> 184 <div class="header-main__top"> 185 <div class="search"> 186 <button type="button" name="toggle-search-button" aria-label="toggle-search" class="search__toggle-btn" aria-expanded="false" aria-haspopup="true"> 187 <span class="search__search-icon"> 188 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 23 23.071"><path d="M22.292 22.295a.72.72 0 0 1-1.007 0l-5.7-5.612a9.306 9.306 0 0 1-5.826 2.034 9.11 9.11 0 1 1 9.256-9.109 8.984 8.984 0 0 1-2.4 6.105l5.68 5.59a.693.693 0 0 1-.003.992zM9.756 1.9a7.708 7.708 0 1 0 7.832 7.707A7.77 7.77 0 0 0 9.756 1.9z"/></svg> 189 </span> 190 <span class="search__close-icon"> 191 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19.801 19.798"><path d="M9.9 11.314l-8.485 8.485-1.416-1.414 8.487-8.486L.002 1.414 1.416 0 9.9 8.485 18.384 0 19.8 1.414l-8.485 8.485 8.485 8.485-1.416 1.414z"/></svg> 192 </span> 193 <span class="search__text" data-text-default="@Translate("Search", "Søg")" data-text-close="@Translate("Close", "Luk")"> 194 @Translate("Search", "Søg") 195 </span> 196 </button> 197 <div class="search__content cludo-search-page"> 198 <div class="grid grid-container"> 199 <div class="row row--right cludo-nav-items"> 200 <div class="cludo-nav-items-search"> 201 <form class="search__form" id="cludo-search-form" role="search" autocomplete="off"> 202 <input class="search__input" autofill="false" type="search" name="search" title="Global søgning" placeholder="@Translate("(Search) Label", "Hvad kan vi hjælpe med?")"> 203 <button type="submit" aria-label="@Translate("Search", "Søg")"> 204 <span class="cludo-search-icon"> 205 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 23 23.071"><path d="M22.292 22.295a.72.72 0 0 1-1.007 0l-5.7-5.612a9.306 9.306 0 0 1-5.826 2.034 9.11 9.11 0 1 1 9.256-9.109 8.984 8.984 0 0 1-2.4 6.105l5.68 5.59a.693.693 0 0 1-.003.992zM9.756 1.9a7.708 7.708 0 1 0 7.832 7.707A7.77 7.77 0 0 0 9.756 1.9z"/></svg> 206 </span> 207 </button> 208 </form> 209 </div> 210 211 <div class="cludo-nav-items-filters"> 212 <div class="search-filters search-filters-mobile" aria-haspopup="true"></div> 213 </div> 214 </div> 215 </div> 216 </div> 217 </div> 218 <a class="skip-to-content" href="#maincontent">Gå til hovedindhold <span>(Tryk Enter)</span></a> 219 </div> 220 <div class="header-main__bottom"> 221 <div class="header-main__menu header-main__menu--to-top-on-open"> 222 <div class="menu menu--closed"> 223 <button type="button" name="toggle-menu-button" aria-label="toggle-menu" class="menu__burger-btn svg-fill--primary text--primary bg--primary" aria-haspopup="true" aria-controls="main-nav" data-svg-default="svg-fill--primary" data-svg-open="svg-fill--secondary" data-text-default="text--primary" data-text-open="text--secondary" data-background-default="bg--primary" data-background-open="bg--primary-alternate" aria-expanded="false"> 224 <span class="menu__menu-icon"> 225 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 26 16"><path d="M.001 16v-2h26v2zm0-7V7h26v2zm0-7V0h26v2z"/></svg> 226 </span> 227 <span class="menu__close-icon"> 228 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19.801 19.798"><path d="M9.9 11.314l-8.485 8.485-1.416-1.414 8.487-8.486L.002 1.414 1.416 0 9.9 8.485 18.384 0 19.8 1.414l-8.485 8.485 8.485 8.485-1.416 1.414z"/></svg> 229 </span> 230 <span class="menu__text" data-text-open="@Translate("Menu", "Menu")" data-text-close="@Translate("Close", "Luk")"> 231 @Translate("Menu", "Menu") 232 </span> 233 </button> 234 235 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 236 237 @{ 238 var navImage = Model.Area.Item.GetString("Image"); 239 var navImageLink = Model.Area.Item.GetItem("ImageLink").GetString("LinkInternal"); 240 var navImageLinkText = Model.Area.Item.GetItem("ImageLink").GetString("LinkText"); 241 var navImageLinkTarget = Model.Area.Item.GetItem("ImageLink").GetList("LinkTarget").SelectedValue; 242 var navImageLinkLinkType = Model.Area.Item.GetItem("ImageLink").GetList("LinkType").SelectedValue; 243 244 var navImage2 = Model.Area.Item.GetString("Image2"); 245 var navImageLink2 = Model.Area.Item.GetItem("ImageLink2").GetString("LinkInternal"); 246 var navImageLinkText2 = Model.Area.Item.GetItem("ImageLink2").GetString("LinkText"); 247 var navImageLinkTarget2 = Model.Area.Item.GetItem("ImageLink2").GetList("LinkTarget").SelectedValue; 248 var navImageLinkLinkType2 = Model.Area.Item.GetItem("ImageLink2").GetList("LinkType").SelectedValue; 249 250 if (navImageLinkLinkType == "external") 251 { 252 navImageLink = Model.Area.Item.GetItem("ImageLink").GetString("LinkExternal"); 253 } 254 if (navImageLinkLinkType2 == "external") 255 { 256 navImageLink2 = Model.Area.Item.GetItem("ImageLink2").GetString("LinkExternal"); 257 } 258 259 } 260 261 <nav id="main-nav" class="menu__content" aria-labelledby="primary-navigation"> 262 <h2 id="primary-navigation" class="visuallyhidden">Primær navigation</h2> 263 264 @RenderNavigation(new { template = "SubsiteBurgerNavigation.xslt", expandmode = "all", startlevel = 2 }) 265 @if (!string.IsNullOrWhiteSpace(navImage)) 266 { 267 <div class="menu__culture"> 268 @if (navImage != "") 269 { 270 <a class="menu__culture-link" href="@navImageLink" target="@navImageLinkTarget"> 271 <img src="@navImage" alt="@navImageLinkText"> 272 </a> 273 } 274 @if (navImage2 != "") 275 { 276 <a class="menu__culture-link" href="@navImageLink2" target="@navImageLinkTarget2"> 277 <img src="@navImage2" alt="@navImageLinkText2"> 278 </a> 279 } 280 </div> 281 } 282 </nav> 283 </div> 284 </div> 285 <div class="header-main__bar"> 286 <div class="grid grid-container"> 287 <div class="header-main__logo logo"> 288 <a href="/" title="Gå til forsiden" class="logo__link"> 289 <img src="@Model.Area.Item.GetString("SiteLogo")" alt="Logo alt tekst"> 290 </a> 291 </div> 292 </div> 293 </div> 294 </div> 295 </header> 296 297 <main id="maincontent" tabindex="-1"> 298 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 299 300 @using Dynamicweb.Content; 301 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 302 @{ 303 string heroLink = Model.Item.GetString("Link"); 304 string boxText = Model.Item.GetString("Text"); 305 string heroPicture = Model.Item.GetString("Heropicture"); 306 bool isVideo = Model.Item.GetBoolean("IsVideo"); 307 string snippetPicturePath = "https://" + System.Web.HttpContext.Current.Request.Url.Host + "/admin/public/GetImage.ashx?Image=" + heroPicture + "&width=1200&altFmImage_path=" + Model.Area.Item.GetString("DefaultPicture"); 308 309 string searchClass = "col col--sm-5 col--offset-sm-1 col--offset-md-2 col--offset-lg-4 frontpage-top__col-search"; 310 if (string.IsNullOrEmpty(boxText)) 311 { 312 searchClass = "col col--sm-8 col--offset-sm-2 col--md-7 col--offset-md-4 frontpage-top__col-search"; 313 } 314 315 PageService pageService = new PageService(); 316 Dynamicweb.Content.Page p = pageService.GetPage(Model.Item.PageID); 317 318 } 319 @SnippetStart("MetaTags") 320 <meta property="og:title" content="@p.MetaTitle" /> 321 <meta property="og:description" content="@p.Description" /> 322 <meta property="og:url" content="@p.MetaCanonical"> 323 <meta property="og:image" content="@snippetPicturePath" /> 324 @SnippetEnd("MetaTags") 325 326 <section class="frontpage-top"> 327 <div class="hero" data-module="hero"> 328 @if (isVideo) 329 { 330 string videoValue = Model.Item.GetString("Video"); 331 332 if (!string.IsNullOrEmpty(videoValue)) 333 { 334 string video = videoValue.Substring(0, videoValue.IndexOf('.')); 335 <div class="hero__video-container"> 336 <div class="hero__video-wrapper" style="background-image: url('/admin/public/GetImage.ashx?Image=@heroPicture&width=100&height=50&crop=0')"> 337 <video tabindex="0" class="hero__video" preload="auto" autoplay muted loop data-src="@video"> 338 <p>This browser does not support the video element</p> 339 </video> 340 </div> 341 </div> 342 <button type="button" class="hero__pause-btn"> 343 <span class="visuallyhidden">Tryk her for at pause eller fortsætte video</span> 344 <span class="hero__play-icon"><svg xmlns="http://www.w3.org/2000/svg" width="26.437" height="52.956" viewBox="0 0 26.437 52.956"><path d="M.022 51.356H.014V1.785L0 1.771V.001l18.44 18.435 8 8-7.779 7.779L.025 52.955zm1.292-1.688L17.77 33.327l6.894-6.894-6.7-6.7L1.316 3.086z"/></svg></span> 345 </button> 346 } 347 } 348 349 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 350 @{ 351 string heroValue = Model.Item.GetString("Heropicture"); 352 string heroPic = "/admin/public/GetImage.ashx?Image=" + heroValue; 353 354 if (!string.IsNullOrEmpty(heroValue)) 355 { 356 <div class="hero__background-image-container"> 357 <div class="hero__background-image-wrapper" 358 data-src-xxs="@heroPic&width=375&height=250&crop=0" 359 data-src-xs="@heroPic&width=768&height=250&crop=0" 360 data-src-sm="@heroPic&width=992&height=400&crop=0" 361 data-src-md="@heroPic&width=1220&height=400&crop=0" 362 data-src-lg='@heroPic&width=1540&height=500&crop=0' 363 data-src-xl="@heroPic&width=1920&height=600&crop=0"> 364 <div class="hero__background-image" style="background-image: url('@heroPic&width=96&height=30&crop=0')"></div> 365 </div> 366 </div> 367 if (Model.Area.Item.GetBoolean("Subsite")) 368 { 369 <div class="hero__line bg--primary"></div> 370 } 371 } 372 } 373 374 </div> 375 376 377 378 <div class="grid grid-container frontpage-top__grid soft-load"> 379 <div class="row"> 380 @if (!Model.Area.Item.GetBoolean("Subsite")) { 381 <div class="@searchClass"> 382 <div class="frontpage-top__search"> 383 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 384 <div class="search-box"> 385 <form id="search-box-form" class="search-box__form"> 386 <label for="search-box__input" class="search-box__label" aria-label="Søg her">@Translate("(Search) Label", "Hvad kan vi hjælpe med?")</label> 387 <div class="search-box__content"> 388 <input class="search-box__input" type="text" id="search-box__input" placeholder="@Translate("(Search) ButtonLabel", "Søg")"> 389 <button type="submit" class="search-box__button" aria-label="@Translate("(Search) ButtonLabel", "Søg")"> 390 <span class="search-box__icon"> 391 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 23 23.071"><path d="M22.292 22.295a.72.72 0 0 1-1.007 0l-5.7-5.612a9.306 9.306 0 0 1-5.826 2.034 9.11 9.11 0 1 1 9.256-9.109 8.984 8.984 0 0 1-2.4 6.105l5.68 5.59a.693.693 0 0 1-.003.992zM9.756 1.9a7.708 7.708 0 1 0 7.832 7.707A7.77 7.77 0 0 0 9.756 1.9z"/></svg> 392 </span> 393 </button> 394 </div> 395 </form> 396 </div> 397 </div> 398 </div> 399 } 400 @if (!string.IsNullOrEmpty(boxText)) 401 { 402 <div class="col col--sm-5 col--md-4 col--lg-3 col--offset-sm-6 col--offset-md-7 col--offset-lg-9 frontpage-top__col-content"> 403 <div class="frontpage-top__content"> 404 <div class="frontpage-top__text bg--pseudo"> 405 <p> 406 @boxText 407 </p> 408 </div> 409 @if (!string.IsNullOrEmpty(heroLink)) 410 { 411 <a href="@heroLink" class="frontpage-top__link" title="Gå til artikel om Det gode liv"> 412 413 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.ParagraphViewModel> 414 <span class="arrow"> 415 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40.62 16"><path d="M40.62 8l-8 8-.89-.89L38.84 8 31.73.89l.89-.89 8 8z"/><path class="spine" d="M0 7.5h40v1H0z"/></svg> 416 </span> 417 418 <span>@Model.Item.GetString("LinkLabel")</span> 419 </a> 420 } 421 </div> 422 </div> 423 } 424 </div> 425 </div> 426 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 427 428 @{ 429 var itemViewModel = Model.Item.GetField("Contact").GetItem(); 430 431 if (itemViewModel != null) 432 { 433 bool english = itemViewModel.GetBoolean("English"); 434 string picture = itemViewModel.GetString("ContactBoxImage"); 435 string picturePath = "/admin/public/GetImage.ashx?Image=" + picture + "&width=375&height=150&crop=0"; 436 437 <aside class="contact hard-load"> 438 <div class="contact__header"> 439 <div class="contact__open"> 440 <div class="contact__image-container"> 441 <img class="contact__image" src="@picturePath" alt="@itemViewModel.GetString("ContactBoxTitle")"> 442 </div> 443 <div class="contact__header-text"> 444 @*<p>@(english ? "Questions?" : "Spørgsmål?")</p>*@ 445 <p><strong>@(english ? "Contact us" : "Kontakt os")</strong></p> 446 </div> 447 <button type="button" class="contact__open-btn" aria-label="Åben kontakt boks" aria-expanded="false"><span class="contact__open-btn-extra">@Translate("ContactUs", "Kontakt os")</span></button> 448 </div> 449 <button type="button" class="contact__close-btn bg--secondary" aria-hidden="true" tabindex="-1"> 450 <span class="contact__close-svg"> 451 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19.801 19.798"><path d="M9.9 11.314l-8.485 8.485-1.416-1.414 8.487-8.486L.002 1.414 1.416 0 9.9 8.485 18.384 0 19.8 1.414l-8.485 8.485 8.485 8.485-1.416 1.414z"/></svg> 452 </span> 453 <span class="contact__close-text"> 454 @*@(english ? "Close" : "Luk") *@ 455 @Translate("Close","Luk") 456 </span> 457 </button> 458 </div> 459 <div class="contact__content bg--secondary" aria-hidden="true"> 460 <div class="contact__mobile-image-container"> 461 <img class="contact__mobile-image" src="@picturePath" alt="@itemViewModel.GetString("ContactBoxTitle")"> 462 </div> 463 <h2>@itemViewModel.GetString("ContactBoxTitle")</h2> 464 <div class="contact__text"> 465 @itemViewModel.GetString("ContentBoxDescription") 466 </div> 467 <ul class="contact__links"> 468 @if (!string.IsNullOrEmpty(itemViewModel.GetString("ContactBoxPhone"))) 469 { 470 <li> 471 <a href="tel:@itemViewModel.GetString("ContactBoxPhone")" title="@Translate("PhoneToUs", "Ring til os")" class="contact__link svg-fill--bg-secondary"> 472 <span class="contact__link-svg bg--parent-hover"> 473 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 26.054 26"><path d="M4.991 26a2.743 2.743 0 0 1-2.025-.844L.554 22.75a1.87 1.87 0 0 1-.548-1.45 1.263 1.263 0 0 1 .548-.958l4.824-3.609a2.4 2.4 0 0 1 1.32-.457 1.5 1.5 0 0 1 1.092.457l1.427 1.423a48.044 48.044 0 0 0 5.207-4.43 41.4 41.4 0 0 0 3.889-4.542l-1.476-1.469a1.8 1.8 0 0 1 0-2.406L20.455.5a1.71 1.71 0 0 1 2.412 0l2.413 2.4c1.289 1.286.723 2.836.067 4.629l-.067.183a57.34 57.34 0 0 1-7.605 9.913 51.92 51.92 0 0 1-9.883 7.528A6.261 6.261 0 0 1 4.991 26zm1.447-7.805a1.529 1.529 0 0 0-.84.291l-3.07 2.3c-.53.446-.227 1.15 0 1.531l1.535 1.531a2.019 2.019 0 0 0 1.305.324 2.928 2.928 0 0 0 1.217-.214c.072-.045 7.233-4.553 10.252-7.818a50.434 50.434 0 0 0 7.236-9.622c.3-.588.512-1.932-.109-2.515l-1.535-1.536a1.2 1.2 0 0 0-.827-.373.866.866 0 0 0-.708.373l-1.11 1.476-1.193 1.585a1.148 1.148 0 0 0 0 1.531l1.938 1.932c-3.4 5.511-9.1 9.743-11.4 11.307l-.107.074-1.889-1.886a.954.954 0 0 0-.695-.291z"/></svg> 474 </span> 475 @itemViewModel.GetString("ContactBoxPhone") 476 </a> 477 </li> 478 } 479 @if (!string.IsNullOrEmpty(itemViewModel.GetString("ContactBoxEmail"))) 480 { 481 string hrefValue = itemViewModel.GetString("ContactBoxEmail").Contains("@") ? "mailto:" + itemViewModel.GetString("ContactBoxEmail") : itemViewModel.GetString("ContactBoxEmail"); 482 <li> 483 <a target="_blank" href="@hrefValue" title="@Translate("WriteUs", "Skriv til os")" class="contact__link svg-fill--bg-secondary"> 484 <span class="contact__link-svg bg--parent-hover"> 485 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 26 21.125"><path d="M22.75 21.125H3.25A3.25 3.25 0 0 1 0 17.875V3.25A3.25 3.25 0 0 1 3.25 0h19.5A3.25 3.25 0 0 1 26 3.25v14.625a3.25 3.25 0 0 1-3.25 3.25zM4.062 1.625L13 9.395l8.938-7.77zM24.375 3.25a1.616 1.616 0 0 0-.516-1.182L13 11.375 2.141 2.068a1.616 1.616 0 0 0-.516 1.182v14.625A1.625 1.625 0 0 0 3.25 19.5h19.5a1.625 1.625 0 0 0 1.625-1.625z"/></svg> 486 </span> 487 @itemViewModel.GetString("ContactBoxEmailLabel") 488 </a> 489 </li> 490 } 491 @if (!string.IsNullOrEmpty((string)itemViewModel.GetString("ContactBoxLink"))) 492 { 493 <li> 494 <a target="_blank" href="@(itemViewModel.GetString("ContactBoxLink").Contains("http") ? itemViewModel.GetString("ContactBoxLink") : "https://" + itemViewModel.GetString("ContactBoxLink"))" title="@Translate("WriteUs", "Skriv til os")" class="contact__link svg-fill--bg-secondary"> 495 <span class="contact__link-svg bg--parent-hover"> 496 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 26 21.125"><path d="M22.75 21.125H3.25A3.25 3.25 0 0 1 0 17.875V3.25A3.25 3.25 0 0 1 3.25 0h19.5A3.25 3.25 0 0 1 26 3.25v14.625a3.25 3.25 0 0 1-3.25 3.25zM4.062 1.625L13 9.395l8.938-7.77zM24.375 3.25a1.616 1.616 0 0 0-.516-1.182L13 11.375 2.141 2.068a1.616 1.616 0 0 0-.516 1.182v14.625A1.625 1.625 0 0 0 3.25 19.5h19.5a1.625 1.625 0 0 0 1.625-1.625z"/></svg> 497 </span> 498 @itemViewModel.GetString("ContactBoxLinkLabel") 499 </a> 500 </li> 501 } 502 </ul> 503 <div class="contact__text"> 504 @if (!string.IsNullOrEmpty(itemViewModel.GetString("ContactBoxPhoneHours"))) 505 { 506 @itemViewModel.GetString("ContactBoxPhoneHours") 507 } 508 @if (!string.IsNullOrEmpty(itemViewModel.GetString("ContactBoxOpenHours"))) 509 { 510 @itemViewModel.GetString("ContactBoxOpenHours") 511 } 512 </div> 513 </div> 514 </aside> 515 } 516 } 517 </section> 518 519 520 @{ 521 var Heading1 = Model.Item.GetString("Heading"); 522 } 523 524 <div class="content content--secondary"> 525 <div class="grid grid-container"> 526 <div class="row"> 527 <div class="col col--sm-12"> 528 @if (!string.IsNullOrEmpty(Heading1)) 529 { 530 <h1 class="h1 margin-reset">@Heading1</h1> 531 } 532 </div> 533 </div> 534 </div> 535 @Model.Placeholder("dwcontent", "content", "items-allowed:Accordion,Gallery,Ribbon_A,Ribbon_B,Ribbon_C,Ribbon_D,Richtext,SponsorList,PersonCollection,Kode,ModuleOnly,Minimap") 536 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 537 538 @SnippetStart("EditorSnippet") 539 540 @{ 541 DateTime date = Model.UpdatedDate; 542 543 544 foreach (var user in Model.Item.GetUsers("Editor")) 545 { 546 <meta name="web_author" content="@user.UserName" /> 547 <meta name="contact" content="@user.Email" /> 548 } 549 <meta name="Last-Modified" content="@date.ToString("yyyy-MM-ddTHH:mm:ssZ")" /> 550 551 } 552 @SnippetEnd("EditorSnippet") 553 </div> 554 </main> 555 556 @using System.Web; 557 @using Dynamicweb.Frontend 558 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 559 560 @{ 561 string redirectPage = ""; 562 563 string footerPhonenumber = Model.Area.Item.GetString("Phonenumber"); 564 string footerEmail = Model.Area.Item.GetString("Email"); 565 string footerFacebook = Model.Area.Item.GetString("Facebook"); 566 string footerTwitter = Model.Area.Item.GetString("Twitter"); 567 string footerLinkedIn = Model.Area.Item.GetString("LinkedIn"); 568 string footerInstagram = Model.Area.Item.GetString("Instagram"); 569 570 var links1 = Model.Area.Item.GetItems("ColumnLinks1"); 571 var links2 = Model.Area.Item.GetItems("ColumnLinks2"); 572 var links3 = Model.Area.Item.GetItems("ColumnLinks3"); 573 string CLabel1 = Model.Area.Item.GetString("ColumnLabel1"); 574 string CLabel2 = Model.Area.Item.GetString("ColumnLabel2"); 575 string CLabel3 = Model.Area.Item.GetString("ColumnLabel3"); 576 577 string contactValue = string.Empty; 578 579 var footerImage = Model.Area.Item.GetString("Image"); 580 var footerImageLink = Model.Area.Item.GetItem("ImageLink").GetString("LinkInternal"); 581 var footerImageLinkText = Model.Area.Item.GetItem("ImageLink").GetString("LinkText"); 582 var footerImageLinkTarget = Model.Area.Item.GetItem("ImageLink").GetList("LinkTarget").SelectedValue; 583 var footerImageLinkLinkType = Model.Area.Item.GetItem("ImageLink").GetList("LinkType").SelectedValue; 584 585 var footerImage2 = Model.Area.Item.GetString("Image2"); 586 var footerImageLink2 = Model.Area.Item.GetItem("ImageLink2").GetString("LinkInternal"); 587 var footerImageLinkText2 = Model.Area.Item.GetItem("ImageLink2").GetString("LinkText"); 588 var footerImageLinkTarget2 = Model.Area.Item.GetItem("ImageLink2").GetList("LinkTarget").SelectedValue; 589 var footerImageLinkLinkType2 = Model.Area.Item.GetItem("ImageLink2").GetList("LinkType").SelectedValue; 590 591 if (footerImageLinkLinkType == "external") 592 { 593 footerImageLink = Model.Area.Item.GetItem("ImageLink").GetString("LinkExternal"); 594 } 595 596 if (footerImageLinkLinkType2 == "external") 597 { 598 footerImageLink2 = Model.Area.Item.GetItem("ImageLink2").GetString("LinkExternal"); 599 } 600 601 if (Model.Area.Item.GetValue("Email") != null) 602 { 603 contactValue = footerEmail.Contains("@") ? "mailto:" + footerEmail : footerEmail; 604 } 605 } 606 607 <footer class="footer soft-load"> 608 <aside class="footer__sidebar"> 609 <div class="footer__culture"> 610 @if (footerImage != "") 611 { 612 <a class="footer__culture-link" href="@footerImageLink" target="@footerImageLinkTarget"> 613 <img src="@footerImage" alt="@footerImageLinkText"> 614 </a> 615 } 616 @if (footerImage2 != "") 617 { 618 <a class="footer__culture-link" href="@footerImageLink2" target="@footerImageLinkTarget2"> 619 <img src="@footerImage2" alt="@footerImageLinkText2"> 620 </a> 621 } 622 </div> 623 </aside> 624 <div class="footer__container"> 625 <div class="grid grid-container"> 626 <div class="row"> 627 <div class="col col--md-3 footer__col-first"> 628 <div class="footer__logo"> 629 @if (Model.Area.Item.GetString("Logo") != "") 630 { 631 <a href="/" title="Gå til forsiden" class="footer__logo-link"> 632 <img src="@Model.Area.Item.GetString("Logo")" alt="Logo alt tekst"> 633 </a> 634 } 635 </div> 636 <div class="footer__contact-desktop"> 637 638 @if (!string.IsNullOrEmpty(footerPhonenumber)) 639 { 640 <div class="footer__contact"> 641 <a href="tel:+45@(Model.Area.Item.GetString("Phonenumber"))" title="@Model.Area.Item.GetString("PhoneLabel")" class="footer__contact-link"> 642 <span class="footer__contact-svg"> 643 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 26.054 26"><path d="M4.991 26a2.743 2.743 0 0 1-2.025-.844L.554 22.75a1.87 1.87 0 0 1-.548-1.45 1.263 1.263 0 0 1 .548-.958l4.824-3.609a2.4 2.4 0 0 1 1.32-.457 1.5 1.5 0 0 1 1.092.457l1.427 1.423a48.044 48.044 0 0 0 5.207-4.43 41.4 41.4 0 0 0 3.889-4.542l-1.476-1.469a1.8 1.8 0 0 1 0-2.406L20.455.5a1.71 1.71 0 0 1 2.412 0l2.413 2.4c1.289 1.286.723 2.836.067 4.629l-.067.183a57.34 57.34 0 0 1-7.605 9.913 51.92 51.92 0 0 1-9.883 7.528A6.261 6.261 0 0 1 4.991 26zm1.447-7.805a1.529 1.529 0 0 0-.84.291l-3.07 2.3c-.53.446-.227 1.15 0 1.531l1.535 1.531a2.019 2.019 0 0 0 1.305.324 2.928 2.928 0 0 0 1.217-.214c.072-.045 7.233-4.553 10.252-7.818a50.434 50.434 0 0 0 7.236-9.622c.3-.588.512-1.932-.109-2.515l-1.535-1.536a1.2 1.2 0 0 0-.827-.373.866.866 0 0 0-.708.373l-1.11 1.476-1.193 1.585a1.148 1.148 0 0 0 0 1.531l1.938 1.932c-3.4 5.511-9.1 9.743-11.4 11.307l-.107.074-1.889-1.886a.954.954 0 0 0-.695-.291z"/></svg> 644 </span> 645 @Model.Area.Item.GetString("Phonenumber") 646 </a> 647 <span> 648 @Model.Area.Item.GetString("PhonenumberLabel") 649 </span> 650 </div> 651 } 652 653 @if (!string.IsNullOrEmpty(footerEmail)) 654 { 655 <div class="footer__contact"> 656 <a href="@contactValue" title="@Model.Area.Item.GetString("EmailLabel")" class="footer__contact-link"> 657 <span class="footer__contact-svg"> 658 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 26 21.125"><path d="M22.75 21.125H3.25A3.25 3.25 0 0 1 0 17.875V3.25A3.25 3.25 0 0 1 3.25 0h19.5A3.25 3.25 0 0 1 26 3.25v14.625a3.25 3.25 0 0 1-3.25 3.25zM4.062 1.625L13 9.395l8.938-7.77zM24.375 3.25a1.616 1.616 0 0 0-.516-1.182L13 11.375 2.141 2.068a1.616 1.616 0 0 0-.516 1.182v14.625A1.625 1.625 0 0 0 3.25 19.5h19.5a1.625 1.625 0 0 0 1.625-1.625z"/></svg> 659 </span> 660 @Model.Area.Item.GetString("EmailLabel") 661 </a> 662 <span> 663 @Model.Area.Item.GetString("EmailLabel_2") 664 </span> 665 </div> 666 } 667 </div> 668 </div> 669 <div class="col col--md-3 footer__col-info"> 670 <div class="footer__info"> 671 <div class="footer__accordion" data-module="accordion"> 672 <div class="accordion"> 673 @if (!string.IsNullOrEmpty(CLabel1)) 674 { 675 <h2 class="accordion__heading footer__heading"> 676 <button id="accordion__trigger_info" type="button" class="accordion__trigger" aria-expanded="false" aria-controls="accordion__content_info"> 677 @Model.Area.Item.GetString("ColumnLabel1") 678 <span class="accordion__chevron" aria-hidden="true"> 679 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 25.469 14.143"><path d="M12.733 14.137l-.006.006L0 1.416 1.414 0l11.321 11.319L24.053 0l1.416 1.416L12.74 14.143z"/></svg> 680 </span> 681 </button> 682 </h2> 683 }else{ 684 <span class="accordion__heading footer__heading"> 685 <button id="accordion__trigger_info" type="button" class="accordion__trigger" aria-expanded="false" aria-controls="accordion__content_info"> 686 @Model.Area.Item.GetString("ColumnLabel1") 687 <span class="accordion__chevron" aria-hidden="true"> 688 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 25.469 14.143"><path d="M12.733 14.137l-.006.006L0 1.416 1.414 0l11.321 11.319L24.053 0l1.416 1.416L12.74 14.143z"/></svg> 689 </span> 690 </button> 691 </span> 692 } 693 @if (links1 != null) 694 { 695 <div id="accordion__content_info" class="accordion__content" aria-hidden="true" aria-labelledby="accordion__trigger_info"> 696 <ul class="footer__list"> 697 @foreach (var columnLink in links1) 698 { 699 @RenderColumnLink(columnLink) 700 } 701 </ul> 702 </div> 703 } 704 </div> 705 </div> 706 </div> 707 </div> 708 <div class="col col--md-3 footer__col-hours"> 709 <div class="footer__hours"> 710 <div class="footer__accordion" data-module="accordion"> 711 <div class="accordion"> 712 @if (!string.IsNullOrEmpty(CLabel2)) 713 { 714 <h2 class="accordion__heading footer__heading"> 715 <button id="accordion__trigger_hours" type="button" class="accordion__trigger" aria-expanded="false" aria-controls="accordion__content_hours"> 716 @Model.Area.Item.GetString("ColumnLabel2") 717 <span class="accordion__chevron" aria-hidden="true"> 718 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 25.469 14.143"><path d="M12.733 14.137l-.006.006L0 1.416 1.414 0l11.321 11.319L24.053 0l1.416 1.416L12.74 14.143z"/></svg> 719 </span> 720 </button> 721 </h2> 722 }else{ 723 724 <span class="accordion__heading footer__heading"> 725 <button id="accordion__trigger_hours" type="button" class="accordion__trigger" aria-expanded="false" aria-controls="accordion__content_hours"> 726 @Model.Area.Item.GetString("ColumnLabel2") 727 <span class="accordion__chevron" aria-hidden="true"> 728 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 25.469 14.143"><path d="M12.733 14.137l-.006.006L0 1.416 1.414 0l11.321 11.319L24.053 0l1.416 1.416L12.74 14.143z"/></svg> 729 </span> 730 </button> 731 </span> 732 } 733 @if (links2 != null) 734 { 735 736 <div id="accordion__content_hours" class="accordion__content" aria-hidden="true" aria-labelledby="accordion__trigger_hours"> 737 <ul class="footer__list"> 738 @foreach (var columnLink in links2) 739 { 740 @RenderColumnLink(columnLink) 741 } 742 </ul> 743 </div> 744 } 745 </div> 746 </div> 747 <div class="footer__contact-mobile"> 748 <div class="footer__contact"> 749 <a href="tel:+45@(Model.Area.Item.GetString("Phonenumber"))" title="@Model.Area.Item.GetString("PhoneLabel")" class="footer__contact-link"> 750 <span class="footer__contact-svg"> 751 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 26.054 26"><path d="M4.991 26a2.743 2.743 0 0 1-2.025-.844L.554 22.75a1.87 1.87 0 0 1-.548-1.45 1.263 1.263 0 0 1 .548-.958l4.824-3.609a2.4 2.4 0 0 1 1.32-.457 1.5 1.5 0 0 1 1.092.457l1.427 1.423a48.044 48.044 0 0 0 5.207-4.43 41.4 41.4 0 0 0 3.889-4.542l-1.476-1.469a1.8 1.8 0 0 1 0-2.406L20.455.5a1.71 1.71 0 0 1 2.412 0l2.413 2.4c1.289 1.286.723 2.836.067 4.629l-.067.183a57.34 57.34 0 0 1-7.605 9.913 51.92 51.92 0 0 1-9.883 7.528A6.261 6.261 0 0 1 4.991 26zm1.447-7.805a1.529 1.529 0 0 0-.84.291l-3.07 2.3c-.53.446-.227 1.15 0 1.531l1.535 1.531a2.019 2.019 0 0 0 1.305.324 2.928 2.928 0 0 0 1.217-.214c.072-.045 7.233-4.553 10.252-7.818a50.434 50.434 0 0 0 7.236-9.622c.3-.588.512-1.932-.109-2.515l-1.535-1.536a1.2 1.2 0 0 0-.827-.373.866.866 0 0 0-.708.373l-1.11 1.476-1.193 1.585a1.148 1.148 0 0 0 0 1.531l1.938 1.932c-3.4 5.511-9.1 9.743-11.4 11.307l-.107.074-1.889-1.886a.954.954 0 0 0-.695-.291z"/></svg> 752 </span> 753 @Model.Area.Item.GetString("Phonenumber") 754 </a> 755 <span> 756 @Model.Area.Item.GetString("PhonenumberLabel") 757 </span> 758 </div> 759 <div class="footer__contact"> 760 <a href="@contactValue" title="@Model.Area.Item.GetString("EmailLabel")" class="footer__contact-link"> 761 <span class="footer__contact-svg"> 762 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 26 21.125"><path d="M22.75 21.125H3.25A3.25 3.25 0 0 1 0 17.875V3.25A3.25 3.25 0 0 1 3.25 0h19.5A3.25 3.25 0 0 1 26 3.25v14.625a3.25 3.25 0 0 1-3.25 3.25zM4.062 1.625L13 9.395l8.938-7.77zM24.375 3.25a1.616 1.616 0 0 0-.516-1.182L13 11.375 2.141 2.068a1.616 1.616 0 0 0-.516 1.182v14.625A1.625 1.625 0 0 0 3.25 19.5h19.5a1.625 1.625 0 0 0 1.625-1.625z"/></svg> 763 </span> 764 @Model.Area.Item.GetString("EmailLabel") 765 </a> 766 <span> 767 @Model.Area.Item.GetString("EmailLabel_2") 768 </span> 769 </div> 770 </div> 771 </div> 772 </div> 773 <div class="col col--md-3 footer__col-last"> 774 <div class="footer__shortcuts"> 775 @if (!string.IsNullOrEmpty(CLabel3)) 776 { 777 <h2 class="footer__heading"> 778 @Model.Area.Item.GetString("ColumnLabel3") 779 </h2> 780 } 781 782 @if (links3 != null) 783 { 784 <ul class="footer__list"> 785 @foreach (var columnLink in links3) 786 { 787 @RenderColumnLink(columnLink) 788 } 789 </ul> 790 } 791 </div> 792 <div class="footer__social"> 793 <div class="footer__social-text"> 794 @Translate("MeetEsbjergSoMe", "Mød Esbjerg på de sociale medier") 795 </div> 796 <div class="footer__social-links"> 797 @if (!string.IsNullOrEmpty(footerFacebook)) 798 { 799 string facebookLink = redirectPage + footerFacebook; 800 <a href="@facebookLink" title="link til Facebook" class="footer__social-link" target="_blank" rel="noopener noreferrer"> 801 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 12.945 24.181"><path d="M8.32 24.181H3.698V12.944h-3.7V8.322h3.7V6.047a6.294 6.294 0 0 1 1.635-4.269A5.028 5.028 0 0 1 9.245.001h3.7v4.552h-3.7a.867.867 0 0 0-.64.426 1.624 1.624 0 0 0-.286 1v2.348h4.625v4.622H8.319v11.236z"/></svg> 802 </a> 803 } 804 @if (!string.IsNullOrEmpty(footerTwitter)) 805 { 806 string twitterLink = redirectPage + footerTwitter; 807 <a href="@twitterLink" title="Link til Twitter" class="footer__social-link" target="_blank" rel="noopener noreferrer"> 808 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24.064 19.692"><path d="M7.56 19.693a13.155 13.155 0 0 1-4.023-.623 13.892 13.892 0 0 1-3.536-1.665H1.18a9.521 9.521 0 0 0 6.1-2.08 5.335 5.335 0 0 1-2.915-1.041 4.5 4.5 0 0 1-1.662-2.427l.114.023.068.015h.01a3.54 3.54 0 0 0 .638.1 2.887 2.887 0 0 0 .764-.068h.013a1.869 1.869 0 0 0 .611-.07 5.156 5.156 0 0 1-2.774-1.732 4.637 4.637 0 0 1-1.109-3.121v-.07a4.561 4.561 0 0 0 2.218.556 4.392 4.392 0 0 1-2.15-4.091 5.157 5.157 0 0 1 .624-2.5 14.11 14.11 0 0 0 4.438 3.674 12.9 12.9 0 0 0 5.688 1.524 18.723 18.723 0 0 0-.054-.353v-.01a5.178 5.178 0 0 1-.085-.747 4.833 4.833 0 0 1 1.456-3.535 4.765 4.765 0 0 1 3.468-1.456 4.719 4.719 0 0 1 2.012.415 4.249 4.249 0 0 1 1.526 1.179 7.016 7.016 0 0 0 1.724-.482h.009c.256-.108.536-.239.782-.355s.505-.235.744-.338a6.826 6.826 0 0 1-.9 1.525 5.4 5.4 0 0 1-1.319 1.18l.057-.008a10.711 10.711 0 0 0 1.4-.269 11.514 11.514 0 0 0 1.388-.485c-.349.487-.7.906-1.037 1.311a7.775 7.775 0 0 1-1.386 1.25v.623a14.166 14.166 0 0 1-.9 4.992 14.216 14.216 0 0 1-2.7 4.509 13.291 13.291 0 0 1-4.438 3.327 12.782 12.782 0 0 1-6.043 1.323z"/></svg> 809 </a> 810 } 811 @if (!string.IsNullOrEmpty(footerLinkedIn)) 812 { 813 string linkedInLink = redirectPage + footerLinkedIn; 814 <a href="@linkedInLink" title="Link til LinkedIn" class="footer__social-link" target="_blank" rel="noopener noreferrer"> 815 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20.129 22.404"><path d="M11.451 22.404H7.112V7.113h4.409v.71a5.1 5.1 0 0 1 2.433-.58c.146 0 .284 0 .411.014a6.95 6.95 0 0 1 2.846.709 6.335 6.335 0 0 1 2.134 2.205 6.226 6.226 0 0 1 .782 2.917v9.315h-4.339v-9.316a1.562 1.562 0 0 0-.215-.71l-.059-.079v-.006c-.182-.244-.313-.422-.5-.484a2.347 2.347 0 0 0-1.054-.3 1.219 1.219 0 0 0-.227.019 5.229 5.229 0 0 0-1.139.286 4.014 4.014 0 0 0-1.136.782v9.813zm-6.543 0H.497V7.113h4.411v15.29zM2.701 5.478a2.623 2.623 0 0 1-1.919-.782A2.623 2.623 0 0 1 0 2.774 2.923 2.923 0 0 1 .782.783 2.613 2.613 0 0 1 2.701.001a2.616 2.616 0 0 1 1.921.782 2.923 2.923 0 0 1 .782 1.991 2.623 2.623 0 0 1-.782 1.922 2.625 2.625 0 0 1-1.921.781z"/></svg> 816 </a> 817 } 818 @if (!string.IsNullOrEmpty(footerInstagram)) 819 { 820 string instagramLink = redirectPage + footerInstagram; 821 <a href="@instagramLink" title="Link til Instagram" class="footer__social-link" target="_blank" rel="noopener noreferrer"> 822 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19.991 19.988"><path d="M9.992 1.8c2.669 0 2.983.012 4.038.059a5.453 5.453 0 0 1 1.856.345 3.1 3.1 0 0 1 1.15.746 3.053 3.053 0 0 1 .746 1.15 5.555 5.555 0 0 1 .345 1.856c.048 1.055.059 1.368.059 4.038s-.012 2.983-.059 4.038a5.453 5.453 0 0 1-.345 1.856 3.1 3.1 0 0 1-.746 1.15 3.053 3.053 0 0 1-1.15.746 5.555 5.555 0 0 1-1.856.345c-1.055.048-1.368.059-4.038.059s-2.983-.012-4.038-.059a5.453 5.453 0 0 1-1.854-.343 3.1 3.1 0 0 1-1.15-.746 3.053 3.053 0 0 1-.75-1.15 5.555 5.555 0 0 1-.345-1.856C1.809 12.979 1.8 12.665 1.8 10s.012-2.983.059-4.038A5.453 5.453 0 0 1 2.2 4.1a3.1 3.1 0 0 1 .746-1.15A3.053 3.053 0 0 1 4.1 2.205a5.555 5.555 0 0 1 1.856-.345c1.055-.052 1.368-.059 4.038-.059m0-1.8C7.281.001 6.94.013 5.873.06a7.324 7.324 0 0 0-2.424.464 4.87 4.87 0 0 0-1.771 1.154A4.956 4.956 0 0 0 .524 3.447 7.329 7.329 0 0 0 .06 5.875C.012 6.938.001 7.275.001 9.992s.012 3.054.059 4.121a7.372 7.372 0 0 0 .464 2.428 4.87 4.87 0 0 0 1.154 1.769 4.956 4.956 0 0 0 1.769 1.154 7.329 7.329 0 0 0 2.428.464c1.067.048 1.4.059 4.121.059s3.054-.012 4.121-.059a7.372 7.372 0 0 0 2.428-.464 4.87 4.87 0 0 0 1.769-1.154 4.956 4.956 0 0 0 1.154-1.769 7.329 7.329 0 0 0 .464-2.428c.048-1.067.059-1.4.059-4.121s-.012-3.054-.059-4.121a7.372 7.372 0 0 0-.464-2.428 4.87 4.87 0 0 0-1.154-1.769A4.956 4.956 0 0 0 16.545.52a7.329 7.329 0 0 0-2.428-.464C13.046.012 12.7 0 9.992 0z"/><path d="M9.992 4.859a5.133 5.133 0 1 0 5.133 5.133 5.134 5.134 0 0 0-5.133-5.133zm0 8.465a3.332 3.332 0 1 1 3.332-3.332 3.331 3.331 0 0 1-3.332 3.332z"/><circle class="a" cx="1.198" cy="1.198" r="1.198" transform="translate(14.129 3.459)"/></svg> 823 </a> 824 } 825 </div> 826 </div> 827 </div> 828 </div> 829 </div> 830 </div> 831 </footer> 832 833 @helper RenderColumnLink(ItemViewModel columnLink) 834 { 835 var linkType = columnLink.GetList("LinkType").SelectedValue; 836 var linkTarget = columnLink.GetList("LinkTarget").SelectedValue; 837 var linkText = columnLink.GetString("LinkText"); 838 var link = linkType == "external" ? columnLink.GetString("LinkExternal") : columnLink.GetString("LinkInternal"); 839 840 <li> 841 <a href="@link" title="Link til @linkText" target="@linkTarget" class="footer__link">@linkText</a> 842 </li> 843 } 844 845 <div class="cookie-wrapper hard-load"> 846 @using Esbjerg.Logic; 847 @using Dynamicweb.Content.Items; 848 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 849 850 @{ 851 var breakingNewsId = Model.Area.Item.GetValue("BreakingNewsPage"); 852 853 if (breakingNewsId != null) 854 { 855 if(!string.IsNullOrEmpty(breakingNewsId.ToString())) 856 { 857 Item item = Helpers.GetBreakingNewsItem(Convert.ToInt32(breakingNewsId)); 858 859 if (item != null) 860 { 861 var link1 = item["Link_1"]; 862 var link2 = item["Link_2"]; 863 864 var facebook = item["FacebookLink"]; 865 var email = item["Email"]; 866 var emailSubject = item["Subject"]; 867 var emailBody = item["Body"]; 868 var smsNumber = item["PhoneNumber"]; 869 var smsBody = item["SMSText"]; 870 871 <div id="@item.Id" class="alert-banner alert-banner--accepted"> 872 <div class="grid grid-container"> 873 <div class="row"> 874 <div class="col col--sm-7 col--md-8 col--xl-9"> 875 <div class="alert-banner__rich-text"> 876 <h3> 877 @item["Headline"] 878 </h3> 879 <p> 880 @item["Text"] 881 </p> 882 </div> 883 </div> 884 <div class="col col--sm-5 col--md-4 col--xl-3"> 885 <div class="alert-banner__link-wrapper"> 886 <div class="alert-banner__contact-links"> 887 @{ 888 if (facebook != null && !string.IsNullOrEmpty(facebook.ToString())) 889 { 890 <a href="@facebook.ToString()" title="Alert link" class="alert-banner__contact-link"> 891 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 12.945 24.181"><path d="M8.32 24.181H3.698V12.944h-3.7V8.322h3.7V6.047a6.294 6.294 0 0 1 1.635-4.269A5.028 5.028 0 0 1 9.245.001h3.7v4.552h-3.7a.867.867 0 0 0-.64.426 1.624 1.624 0 0 0-.286 1v2.348h4.625v4.622H8.319v11.236z"/></svg> 892 </a> 893 } 894 if (email != null && !string.IsNullOrEmpty(email.ToString())) 895 { 896 897 <a href="mailto:@email.ToString()?subject=@(emailSubject != null ? emailSubject.ToString() : string.Empty) &body=@(emailBody != null ? emailBody.ToString() : string.Empty) " title="Alert link" class="alert-banner__contact-link"> 898 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 26 21.125"><path d="M22.75 21.125H3.25A3.25 3.25 0 0 1 0 17.875V3.25A3.25 3.25 0 0 1 3.25 0h19.5A3.25 3.25 0 0 1 26 3.25v14.625a3.25 3.25 0 0 1-3.25 3.25zM4.062 1.625L13 9.395l8.938-7.77zM24.375 3.25a1.616 1.616 0 0 0-.516-1.182L13 11.375 2.141 2.068a1.616 1.616 0 0 0-.516 1.182v14.625A1.625 1.625 0 0 0 3.25 19.5h19.5a1.625 1.625 0 0 0 1.625-1.625z"/></svg> 899 </a> 900 } 901 if (smsNumber != null && !string.IsNullOrEmpty(smsNumber.ToString())) 902 { 903 <a href="sms:@smsNumber.ToString()?&body=@(smsBody != null ? smsBody.ToString() : string.Empty)" title="Alert link" class="alert-banner__contact-link alert-banner__contact-links--sms"> 904 <svg xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32"><g fill="#d53f53"><path d="M10.624 15.81a2.03 2.03 0 0 1-.766 1.681 3.325 3.325 0 0 1-2.13.612 5 5 0 0 1-2.228-.477v-1.547a9.163 9.163 0 0 0 1.345.5 3.981 3.981 0 0 0 1.007.145 1.432 1.432 0 0 0 .841-.209.716.716 0 0 0 .298-.624.688.688 0 0 0-.129-.411 1.442 1.442 0 0 0-.379-.346 9.739 9.739 0 0 0-1.018-.532 4.824 4.824 0 0 1-1.08-.65 2.44 2.44 0 0 1-.575-.725 2.069 2.069 0 0 1-.21-.967 2.029 2.029 0 0 1 .7-1.638 2.935 2.935 0 0 1 1.952-.6 4.61 4.61 0 0 1 1.168.145 8.03 8.03 0 0 1 1.163.408l-.534 1.298a7.858 7.858 0 0 0-1.039-.36 3.345 3.345 0 0 0-.808-.1 1.07 1.07 0 0 0-.725.22.726.726 0 0 0-.252.575.711.711 0 0 0 .1.384 1.122 1.122 0 0 0 .325.317 10.047 10.047 0 0 0 1.055.551 4.2 4.2 0 0 1 1.51 1.053 2.06 2.06 0 0 1 .409 1.297zm4.748 2.181l-1.891-6.161h-.048q.1 1.88.1 2.508v3.653h-1.486v-7.853h2.266l1.858 6h.029l1.971-6h2.267v7.853H18.89v-3.717q0-.263.008-.607t.072-1.826h-.048l-2.022 6.15zm11.682-2.181a2.03 2.03 0 0 1-.765 1.676 3.325 3.325 0 0 1-2.13.612 5 5 0 0 1-2.224-.473v-1.546a9.163 9.163 0 0 0 1.345.5 3.981 3.981 0 0 0 1.007.145 1.432 1.432 0 0 0 .841-.209.716.716 0 0 0 .293-.623.688.688 0 0 0-.129-.411 1.442 1.442 0 0 0-.379-.346 9.739 9.739 0 0 0-1.013-.533 4.824 4.824 0 0 1-1.08-.65 2.44 2.44 0 0 1-.575-.725 2.069 2.069 0 0 1-.215-.967 2.029 2.029 0 0 1 .706-1.638 2.935 2.935 0 0 1 1.952-.6 4.61 4.61 0 0 1 1.168.145 8.03 8.03 0 0 1 1.163.408l-.537 1.294a7.858 7.858 0 0 0-1.039-.36 3.345 3.345 0 0 0-.808-.1 1.07 1.07 0 0 0-.725.22.726.726 0 0 0-.252.575.711.711 0 0 0 .1.384 1.122 1.122 0 0 0 .325.317 10.047 10.047 0 0 0 1.055.551 4.2 4.2 0 0 1 1.509 1.055 2.06 2.06 0 0 1 .407 1.299z"/><path d="M16 28a18.276 18.276 0 0 1-2.991-.253L6 32v-7.081A13.4 13.4 0 0 1 0 14C0 6.268 7.163 0 16 0s16 6.268 16 14-7.163 14-16 14zm0-26C8.268 2 2 7.373 2 14a11.591 11.591 0 0 0 5.975 9.824l-.063 4.638 4.707-2.829A16.2 16.2 0 0 0 16 26c7.732 0 14-5.372 14-12S23.732 2 16 2z"/></g></svg> 905 </a> 906 } 907 } 908 </div> 909 @if (link1 != null) 910 { 911 Item linkItem = Helpers.GetItemByItemId("LinkItem", link1.ToString()); 912 if (linkItem["Link"] != null) 913 { 914 string link = linkItem["Link"].ToString(); 915 if (!string.IsNullOrEmpty(link)) 916 { 917 <a href="@link" class="alert-banner__link"> 918 919 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.ParagraphViewModel> 920 <span class="arrow"> 921 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40.62 16"><path d="M40.62 8l-8 8-.89-.89L38.84 8 31.73.89l.89-.89 8 8z"/><path class="spine" d="M0 7.5h40v1H0z"/></svg> 922 </span> 923 924 <span>@linkItem["Label"].ToString()</span> 925 </a> 926 } 927 } 928 } 929 @if (link2 != null) 930 { 931 Item linkItem = Helpers.GetItemByItemId("LinkItem", link2.ToString()); 932 if (linkItem["Link"] != null) 933 { 934 string link = linkItem["Link"].ToString(); 935 if (!string.IsNullOrEmpty(link)) 936 { 937 <a href="@link" class="alert-banner__link"> 938 939 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.ParagraphViewModel> 940 <span class="arrow"> 941 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40.62 16"><path d="M40.62 8l-8 8-.89-.89L38.84 8 31.73.89l.89-.89 8 8z"/><path class="spine" d="M0 7.5h40v1H0z"/></svg> 942 </span> 943 944 <span>@linkItem["Label"].ToString()</span> 945 </a> 946 } 947 } 948 } 949 950 </div> 951 <button type="button" class="alert-banner__close-btn"> 952 <span class="alert-banner__close-icon"> 953 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19.801 19.798"><path d="M9.9 11.314l-8.485 8.485-1.416-1.414 8.487-8.486L.002 1.414 1.416 0 9.9 8.485 18.384 0 19.8 1.414l-8.485 8.485 8.485 8.485-1.416 1.414z"/></svg> 954 </span> 955 <span class="alert-banner__close-text"> 956 Luk 957 </span> 958 </button> 959 </div> 960 </div> 961 </div> 962 </div> 963 } 964 } 965 } 966 967 } 968 969 970 971 <!-- <div class="cookie cookie--accepted"> 972 <div class="grid grid-container"> 973 <div class="row"> 974 <div class="col col--sm-8 col--md-9"> 975 <div class="cookie__text"> 976 @Model.Area.Item.GetField("CookieWarning").GetValue() 977 </div> 978 </div> 979 <div class="col col--sm-4 col--md-3"> 980 <button type="button" class="cookie__accept-btn text--link svg-fill--link"> 981 982 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.ParagraphViewModel> 983 <span class="arrow"> 984 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40.62 16"><path d="M40.62 8l-8 8-.89-.89L38.84 8 31.73.89l.89-.89 8 8z"/><path class="spine" d="M0 7.5h40v1H0z"/></svg> 985 </span> 986 987 <span>@Translate("OkAccept", "Ok, jeg accepterer")</span> 988 </button> 989 </div> 990 </div> 991 </div> 992 </div> --> 993 </div> 994 995 @inherits Dynamicweb.Rendering.ViewModelTemplate<Dynamicweb.Frontend.PageViewModel> 996 @using System.Web; 997 998 @{ 999 var host = HttpContext.Current.Request.Url.Host.StartsWith("local.") ? "subsite-esbjerg.dis-play.dk" : HttpContext.Current.Request.Url.Host; 1000 1001 string jsPath = "/Files/Templates/Designs/" + Pageview.Layout.Design.Name; 1002 string searchPath = Model.Area.Item.GetString("SearchResultPage"); 1003 1004 if (!string.IsNullOrEmpty(searchPath)) 1005 { 1006 searchPath = Dynamicweb.Frontend.SearchEngineFriendlyURLs.GetFriendlyUrl("Default.aspx?Id=" + searchPath); 1007 } 1008 } 1009 1010 <script> 1011 @*var scriptLoaderSettings = { 1012 mainScriptSrc: [ 1013 '@jsPath/static/dist/js/@Esbjerg.Logic.Helpers.CacheBuster(jsPath + "/static/dist/js/", "main.min.js")' 1014 ], 1015 polyfillFallback: '@jsPath/static/dist/js/polyfillFallback.js', 1016 polyfills: 'default-3.6,fetch,Object.values,Array.prototype.findIndex' 1017 }; 1018 1019 var loadMainScript = function () { function a(a) { var b = document.createElement("script"); b.defer = !0, b.async = !!0, b.src = a, document.body.appendChild(b) } if ("object" == typeof scriptLoaderSettings.mainScriptSrc) for (var b = 0; b < scriptLoaderSettings.mainScriptSrc.length; b++)a(scriptLoaderSettings.mainScriptSrc[b]); else a(scriptLoaderSettings.mainScriptSrc) }; 1020 !function (e, t) { var r, a = [/^(.+)(\[.+MessengerForiOS.+\][ ]*)/, /^(.+)(\[.+FBIOS.+\][ ]*)/, /^(.+)( Twitter for iPhone)/]; for (r = 0; r < a.length; ++r) { var n = a[r], i = e.match(n); if (i) { t = t + "&ua=" + encodeURIComponent(i[1] + " Safari"); break } } var o = document.createElement("script"); o.addEventListener("error", function () { var e = document.createElement("script"); e.src = scriptLoaderSettings.polyfillFallback, document.body.appendChild(e) }),o.defer=true, o.src = t, document.body.appendChild(o) }(navigator.userAgent, "https://cdn.polyfill.io/v2/polyfill.min.js?features=" + scriptLoaderSettings.polyfills + "&callback=loadMainScript");*@ 1021 1022 /*! loadCSS rel=preload polyfill. [c]2017 Filament Group, Inc. MIT License - https://github.com/filamentgroup/loadCSS */ 1023 !function (t) { "use strict"; t.loadCSS || (t.loadCSS = function () { }); var e = loadCSS.relpreload = {}; if (e.support = function () { var e; try { e = t.document.createElement("link").relList.supports("preload") } catch (t) { e = !1 } return function () { return e } }(), e.bindMediaToggle = function (t) { function e() { t.media = a } var a = t.media || "all"; t.addEventListener ? t.addEventListener("load", e) : t.attachEvent && t.attachEvent("onload", e), setTimeout(function () { t.rel = "stylesheet", t.media = "only x" }), setTimeout(e, 3e3) }, e.poly = function () { if (!e.support()) for (var a = t.document.getElementsByTagName("link"), n = 0; n < a.length; n++) { var o = a[n]; "preload" !== o.rel || "style" !== o.getAttribute("as") || o.getAttribute("data-loadcss") || (o.setAttribute("data-loadcss", !0), e.bindMediaToggle(o)) } }, !e.support()) { e.poly(); var a = t.setInterval(e.poly, 500); t.addEventListener ? t.addEventListener("load", function () { e.poly(), t.clearInterval(a) }) : t.attachEvent && t.attachEvent("onload", function () { e.poly(), t.clearInterval(a) }) } "undefined" != typeof exports ? exports.loadCSS = loadCSS : t.loadCSS = loadCSS }("undefined" != typeof global ? global : this); 1024 1025 // Enable this to register a service worker. Please make sure you understand the implications of doing so. 1026 // if ("serviceWorker" in navigator) { navigator.serviceWorker.register("/sw.js", { scope: '/' }); } 1027 </script> 1028 1029 <script src='@jsPath/static/dist/js/main.min.js' type="text/javascript"></script> 1030 <script src='https://cdn.polyfill.io/v2/polyfill.js?features=default-3.6,fetch,Object.values,Array.prototype.findIndex' type="text/javascript"></script> 1031 @*<script src='@jsPath/static/dist/js/polyfillFallback.js' type="text/javascript"></script>*@ 1032 1033 <!--SiteImprove script--> 1034 <script type="text/javascript"> 1035 /*<![CDATA[*/ 1036 (function () { 1037 var sz = document.createElement('script'); sz.type = 'text/javascript'; sz.async = true; 1038 sz.src = '//siteimproveanalytics.com/js/siteanalyze_273521.js'; 1039 var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(sz, s); 1040 })(); 1041 /*]]>*/ 1042 </script> 1043 <!--Minimap--> 1044 @RenderSnippet("Minimap") 1045 1046 <!--Kode - Footer section--> 1047 @RenderSnippet("KodeFooter") 1048 1049 <!-- SCRIPT --> 1050 <!-- www.Cludo.com search start JS --> 1051 <!--[if lte IE 9]> 1052 <script src="https://api.cludo.com/scripts/xdomain.js" slave="https://api.cludo.com/proxy.html"></script> 1053 <![endif]--> 1054 <!-- www.Cludo.com search end JS --> 1055 <!-- www.Cludo.com Search body init script start --> 1056 1057 <script type="text/javascript" src="https://customer.cludo.com/scripts/bundles/search-script.min.js"></script> 1058 1059 <script> 1060 var CludoSearch; 1061 (function () { 1062 var cludoSettings = { 1063 customerId: 80, 1064 engineId: 11424, 1065 searchUrl: "@searchPath", 1066 language: "@Dynamicweb.Services.Areas.GetArea(Model.Area.ID).CultureInfo.TwoLetterISOLanguageName", 1067 filters: { "DomainName": ["https://@host/"] }, 1068 searchInputs: ["cludo-search-form", "search-box-form"], 1069 initSearchBoxText: "", 1070 loading: "<img src='//customer.cludo.com/img/loading.gif' alt='Loading' class='loading' role='progressbar' />", 1071 customCallbackAfterSearch: function () { 1072 window.cludoCallback(); 1073 } 1074 //bannerIsInSearchTemplate: false, 1075 //endlessScroll: {stopAfterPage:3, resultsPerPage:10, bottomOffset: 700}, 1076 //richAutocomplete: true 1077 }; 1078 CludoSearch = new Cludo(cludoSettings); 1079 CludoSearch.init(); 1080 })(); 1081 </script> 1082 1083 1084 <!--Footer scripts from website settings subsites--> 1085 @{string scriptFooterArea = Model.Area.Item.GetString("ScriptFooterArea"); } 1086 @if (!string.IsNullOrEmpty(scriptFooterArea)){ 1087 @scriptFooterArea 1088 } 1089 </body> 1090 </html> 1091 1092 @functions { 1093 1094 private string GetThemeTextColor(string hex) 1095 { 1096 const string white = "#fff"; 1097 const string black = "#000"; 1098 1099 var color = white; 1100 1101 switch (hex.ToLower()) 1102 { 1103 case ThemeColors.Cornflower: 1104 color = black; 1105 break; 1106 case ThemeColors.Surf: 1107 color = black; 1108 break; 1109 case ThemeColors.BeautyBush: 1110 color = black; 1111 break; 1112 case ThemeColors.Cerulean: 1113 color = black; 1114 break; 1115 case ThemeColors.Cinnabar: 1116 color = black; 1117 break; 1118 } 1119 1120 return color; 1121 } 1122 1123 private string GetContrastColor(string hex) 1124 { 1125 var color = hex; 1126 1127 switch (hex.ToLower()) 1128 { 1129 case ThemeColors.DeepSapphire: 1130 color = "020305"; 1131 break; 1132 case ThemeColors.RegalBlue: 1133 color = "013150"; 1134 break; 1135 case ThemeColors.DoveGray: 1136 color = "505050"; 1137 break; 1138 case ThemeColors.Valencia: 1139 color = "b23646"; 1140 break; 1141 case ThemeColors.Cornflower: 1142 color = "8bbbd5"; 1143 break; 1144 case ThemeColors.Surf: 1145 color = "c3beb6"; 1146 break; 1147 case ThemeColors.BeautyBush: 1148 color = "e0e0e0"; 1149 break; 1150 case ThemeColors.Cerulean: 1151 color = "0079a8"; 1152 break; 1153 case ThemeColors.Cinnabar: 1154 color = "de3517"; 1155 break; 1156 } 1157 1158 return color; 1159 } 1160 1161 private string GetLinkColor(string hex) 1162 { 1163 var color = hex; 1164 1165 switch (hex.ToLower()) 1166 { 1167 case ThemeColors.DeepSapphire: 1168 color = "1d293b"; 1169 break; 1170 case ThemeColors.Cornflower: 1171 color = "085077"; 1172 break; 1173 case ThemeColors.Surf: 1174 color = "555555"; 1175 break; 1176 case ThemeColors.BeautyBush: 1177 color = "555555"; 1178 break; 1179 case ThemeColors.Cerulean: 1180 color = "0079a8"; 1181 break; 1182 case ThemeColors.Cinnabar: 1183 color = "de3517"; 1184 break; 1185 } 1186 1187 return color; 1188 } 1189 1190 private struct ThemeColors 1191 { 1192 public const string DeepSapphire = "0a2e68"; 1193 public const string RegalBlue = "004069"; 1194 public const string DoveGray = "666666"; 1195 public const string Valencia = "d53f53"; 1196 public const string Cornflower = "88bfe8"; 1197 public const string Surf = "b1d8b9"; 1198 public const string BeautyBush = "edc3c4"; 1199 public const string Cerulean = "009bd9"; 1200 public const string Cinnabar = "eb573d"; 1201 } 1202 }