Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: adding dark mode functionality to blog #101

Open
wants to merge 7 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
137 changes: 137 additions & 0 deletions layouts/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,137 @@
{{ define "main" }}

<!-- banner -->
<br>
<section class="banner bg-cover" >
<img src="{{ .Site.Params.banner.image | relURL }}" class="img-fluid illustration" alt="">
<div class="container">
<div class="row">
<div class="col-lg-6 mb-5 mb-lg-0">
<h1>{{ .Site.Params.banner.title | markdownify }}</h1>
</div>
<div class="col-lg-6 illustration-mobile">
<img src="{{ .Site.Params.banner.image | relURL }}" class="img-fluid" alt="">
</div>
</div>
</div>
</section>
<!-- /banner -->

<!-- blog -->
<section class="section">
<div class="container">
<div class="row">
<div class="col-lg-8 mx-auto px-0">
<div class="bg-white shadow block">
{{ $paginator := .Paginate (where .Site.RegularPages "Type" "post") }}
{{ range $paginator.Pages }}
{{ .Render "article" }}
{{ end }}
<!-- pagination -->
<div class="mt-5">
{{"<!-- pagination -->" | safeHTML }}
{{ $paginator := .Paginator }}
<!-- Number of links either side of the current page. -->
{{ $adjacent_links := 2 }}
<!-- $max_links = ($adjacent_links * 2) + 1 -->
{{ $max_links := (add (mul $adjacent_links 2) 1) }}
<!-- $lower_limit = $adjacent_links + 1 -->
{{ $lower_limit := (add $adjacent_links 1) }}
<!-- $upper_limit = $paginator.TotalPages - $adjacent_links -->
{{ $upper_limit := (sub $paginator.TotalPages $adjacent_links) }}
<!-- If there's more than one page. -->
{{ if gt $paginator.TotalPages 1 }}
<nav aria-label="Page navigation">
<ul class="pagination justify-content-center align-items-center">
<!-- Previous page. -->
{{ if $paginator.HasPrev }}
<li class="page-item">
<a href="{{ $paginator.Prev.URL }}" class="page-link">
&laquo;
</a>
</li>
{{ end }}
<!-- Page numbers. -->
{{ range $paginator.Pagers }}
{{ $.Scratch.Set "page_number_flag" false }}
<!-- Advanced page numbers. -->
{{ if gt $paginator.TotalPages $max_links }}
<!-- Lower limit pages. -->
<!-- If the user is on a page which is in the lower limit. -->
{{ if le $paginator.PageNumber $lower_limit }}
<!-- If the current loop page is less than max_links. -->
{{ if le .PageNumber $max_links }}
{{ $.Scratch.Set "page_number_flag" true }}
{{ end }}
<!-- Upper limit pages. -->
<!-- If the user is on a page which is in the upper limit. -->
{{ else if ge $paginator.PageNumber $upper_limit }}
<!-- If the current loop page is greater than total pages minus $max_links -->
{{ if gt .PageNumber (sub $paginator.TotalPages $max_links) }}
{{ $.Scratch.Set "page_number_flag" true }}
{{ end }}
<!-- Middle pages. -->
{{ else }}
{{ if and ( ge .PageNumber (sub $paginator.PageNumber $adjacent_links) ) ( le .PageNumber (add $paginator.PageNumber $adjacent_links) ) }}
{{ $.Scratch.Set "page_number_flag" true }}
{{ end }}
{{ end }}
<!-- Simple page numbers. -->
{{ else }}
{{ $.Scratch.Set "page_number_flag" true }}
{{ end }}
<!-- Output page numbers. -->
{{ if eq ($.Scratch.Get "page_number_flag") true }}
<li class="page-item{{ if eq . $paginator }} page-item active {{ end }}">
<a href="{{ .URL }}" class="page-link">
{{ .PageNumber }}
</a>
</li>
{{ end }}
{{ end }}
<!-- Next page. -->
{{ if $paginator.HasNext }}
<li class="page-item">
<a href="{{ $paginator.Next.URL }}" class="page-link">
&raquo;
</a>
</li>
{{ end }}
</ul>
</nav>
{{ end }}
{{"<!-- /pagination -->" | safeHTML }}
</div>
</div>
</div>
</div>
</div>
</section>
<!-- /blog -->

<!-- cta -->
{{ if .Site.Params.cta.enable }}
<section class="section pt-0">
<div class="container">
<div class="row">
<div class="col-lg-8 mx-auto">
<div class="row shadow bg-white p-5">
<div class="col-md-4 text-center text-md-left mb-4 mb-lg-0">
<img src="{{ .Site.Params.cta.image | relURL }}" class="mr-4" alt="..."></div>
<div class="col-md-8 text-center text-md-left">
<h3 class="mt-0">{{ .Site.Params.cta.title | markdownify }}</h3>
<p>{{ .Site.Params.cta.description | markdownify }}</p>
{{ if .Site.Params.cta.button.enable }}
<a href="{{ .Site.Params.cta.button.link | absURL }}"
class="btn btn-primary">{{ .Site.Params.cta.button.label }}</a>
{{ end }}
</div>
</div>
</div>
</div>
</div>
</section>
{{ end }}
<!-- /cta -->

{{ end }}
55 changes: 55 additions & 0 deletions layouts/partials/header.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
{{ "<!-- navigation -->" | safeHTML }}
<header class="fixed-top navigation">
<div class="container">
<!-- navbar -->
<nav class="navbar navbar-expand-lg navbar-light bg-transparent">
<a class="navbar-brand"href="{{ .Site.BaseURL }}"><img class="img-fluid" src="{{ .Site.Params.logo | relURL }}" alt="{{ .Site.Title }}"></a>
<button class="navbar-toggler border-0" type="button" data-toggle="collapse" data-target="#navigation">
<i class="ti-menu h3"></i>
</button>

<div class="collapse navbar-collapse text-center" id="navigation">
<ul class="navbar-nav ml-auto">
<li class="nav-item">
<a class="nav-link" href="{{ .Site.BaseURL }}">{{ with .Site.Params.Home }} {{ . }} {{ end }}</a>
</li>
{{ range .Site.Menus.main }}
{{ if .HasChildren }}
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" role="button" data-toggle="dropdown" aria-haspopup="true"
aria-expanded="false">
{{ .Name }}
</a>
<div class="dropdown-menu">
{{ range .Children }}
<a class="dropdown-item" href="{{ .URL | absURL }}">{{ .Name }}</a>
{{ end }}
</div>
</li>
{{ else }}
<li class="nav-item">
<a class="nav-link" href="{{ .URL | absURL }}">{{ .Name }}</a>
</li>
<li class="nav-link nav-text">
{{ partial "toggle.html" . }}
</li>
{{ end }}
{{ end }}
</ul>
{{ if .Site.Params.search.enable }}
{{ "<!-- search -->" | safeHTML }}
<div class="search">
<button id="searchOpen" class="search-btn"><i class="ti-search"></i></button>
<div class="search-wrapper">
<form action="{{ `search` | absURL }}" class="h-100">
<input class="search-box px-4" id="search-query" name="s" type="search" placeholder="Type & Hit Enter...">
</form>
<button id="searchClose" class="search-close"><i class="ti-close text-dark"></i></button>
</div>
</div>
{{ end }}
</div>
</nav>
</div>
</header>
{{ "<!-- /navigation -->" | safeHTML }}
201 changes: 201 additions & 0 deletions layouts/partials/toggle.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,201 @@
<div class="js-toggle-wrapper">
<div class="js-toggle">
<div class="js-toggle-track">
<div class="js-toggle-track-check">
<img src=""
role="presentation" style="pointer-events: none" width="16" height="16" />
</div>
<div class="js-toggle-track-x">
<img src=""
role="presentation" style="pointer-events: none" width="16" height="16" />
</div>
</div>
<div class="js-toggle-thumb"></div>
<input class="js-toggle-screenreader-only" type="checkbox" aria-label="Switch between Dark and Light mode" />
</div>
</div>

<style>
.js-toggle-wrapper {
display: table;
margin: 0 auto;
padding-left: 20px;
}

.js-toggle {
touch-action: pan-x;
display: inline-block;
position: relative;
cursor: pointer;
background-color: transparent;
border: 0;
padding: 0;
-webkit-touch-callout: none;
user-select: none;
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
-webkit-tap-highlight-color: transparent;
}

.js-toggle-screenreader-only {
border: 0;
clip: rect(0 0 0 0);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
}

.js-toggle-track {
width: 50px;
height: 24px;
padding: 0;
border-radius: 30px;
background-color: hsl(222, 14%, 7%);
transition: all 0.2s ease;
}

.js-toggle-track-check {
position: absolute;
width: 17px;
height: 17px;
left: 5px;
top: 0px;
bottom: 0px;
margin-top: auto;
margin-bottom: auto;
line-height: 0;
opacity: 0;
transition: opacity 0.25s ease;
}

.js-toggle--checked .js-toggle-track-check {
opacity: 1;
transition: opacity 0.25s ease;
}

.js-toggle-track-x {
position: absolute;
width: 17px;
height: 17px;
right: 5px;
top: 0px;
bottom: 0px;
margin-top: auto;
margin-bottom: auto;
line-height: 0;
opacity: 1;
transition: opacity 0.25s ease;
}

.js-toggle--checked .js-toggle-track-x {
opacity: 0;
}

.js-toggle-thumb {
position: absolute;
top: 1px;
left: 1px;
width: 22px;
height: 22px;
border-radius: 50%;
background-color: #fafafa;
box-sizing: border-box;
transition: all 0.5s cubic-bezier(0.23, 1, 0.32, 1) 0ms;
transform: translateX(0);
}

.js-toggle--checked .js-toggle-thumb {
transform: translateX(26px);
border-color: #19ab27;
}

.js-toggle--focus .js-toggle-thumb {
box-shadow: 0px 0px 2px 3px rgb(255, 167, 196);
}

.js-toggle:active .js-toggle-thumb {
box-shadow: 0px 0px 5px 5px rgb(255, 167, 196);
}

body.dark-mode {
background: rgb(45, 45, 45);
color: #f5f5f5;
}

body.dark-mode h1,
body.dark-mode h2,
body.dark-mode h3,
body.dark-mode h4,
body.dark-mode h5 {
color: #ef878f;
}

body.dark-mode li.nav-item a.nav-link,
html body.dark-mode header.fixed-top.navigation div.container {
background-color: rgb(45, 45, 45) !important;
color: #f5f5f5 !important;
}

body.dark-mode button#searchOpen.search-btn {
color: #f5f5f5;
}

body.dark-mode header.fixed-top.navigation.nav-bg {
background-color: rgb(45, 45, 45);
}

body.dark-mode div.bg-white {
background-color: rgb(45, 45, 45) !important;
}

body.dark-mode li.page-item a {
background-color: rgb(45, 45, 45);
}

body.dark-mode li.page-item a.page-item.active {
background-color: #ef878f !important;
}

body.dark-mode footer,
body.dark-mode footer a {
color: #f5f5f5 !important;
background-color: rgb(45, 45, 45) !important;
}

body.dark-mode blockquote,
body.dark-mode blockquote p {
background-color: rgb(45, 45, 45);
color: grey;
}
</style>

<script>
var body = document.body;
var switcher = document.getElementsByClassName("js-toggle")[0];

//Click on dark mode icon. Add dark mode classes and wrappers. Store user preference through sessions
switcher.addEventListener("click", function () {
this.classList.toggle("js-toggle--checked");
this.classList.add("js-toggle--focus");
//If dark mode is selected
if (this.classList.contains("js-toggle--checked")) {
body.classList.add("dark-mode");
//Save user preference in storage
localStorage.setItem("darkMode", "true");
} else {
body.classList.remove("dark-mode");
setTimeout(function () {
localStorage.removeItem("darkMode");
}, 100);
}
});

//Check Storage. Keep user preference on page reload
if (localStorage.getItem("darkMode")) {
//body.classList.add('dark-mode');
switcher.classList.add("js-toggle--checked");
body.classList.add("dark-mode");
}
</script>