forked from tsc-vfl/hugo-page
Create main parts of short codes
This commit is contained in:
parent
e15b181a99
commit
71c823a653
@ -25,6 +25,7 @@ body {
|
|||||||
margin: 0px;
|
margin: 0px;
|
||||||
background-color: #ececec;
|
background-color: #ececec;
|
||||||
font: 90% 'Open Sans', sans-serif;
|
font: 90% 'Open Sans', sans-serif;
|
||||||
|
height: 100vh;
|
||||||
}
|
}
|
||||||
|
|
||||||
h1, h2, h3, h4, h5, h6 {
|
h1, h2, h3, h4, h5, h6 {
|
||||||
@ -44,6 +45,7 @@ h1 {
|
|||||||
max-width: 1280px;
|
max-width: 1280px;
|
||||||
margin: auto;
|
margin: auto;
|
||||||
background-color: #fcfcfc;
|
background-color: #fcfcfc;
|
||||||
|
overflow: auto;
|
||||||
|
|
||||||
#header {
|
#header {
|
||||||
border-bottom: 2px solid rgba(173,173,173,.5);
|
border-bottom: 2px solid rgba(173,173,173,.5);
|
||||||
@ -63,6 +65,7 @@ h1 {
|
|||||||
|
|
||||||
> .slider {
|
> .slider {
|
||||||
width: calc(100% - 60px);
|
width: calc(100% - 60px);
|
||||||
|
// visibility: hidden;
|
||||||
// height: 250px;
|
// height: 250px;
|
||||||
display: flex;
|
display: flex;
|
||||||
padding: 0 10px;
|
padding: 0 10px;
|
||||||
@ -264,6 +267,46 @@ h1 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#overlay {
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100vw;
|
||||||
|
height: 100vh;
|
||||||
|
display: flex;
|
||||||
|
z-index: 10;
|
||||||
|
|
||||||
|
&.hidden {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.background {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
position: absolute;
|
||||||
|
z-index: -10;
|
||||||
|
background-color: lightgrey;
|
||||||
|
opacity: 50%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.spacer {
|
||||||
|
flex: auto 1 0;
|
||||||
|
}
|
||||||
|
.dialog-column {
|
||||||
|
flex: 0 1 1;
|
||||||
|
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: center;
|
||||||
|
.dialog {
|
||||||
|
background-color: white;
|
||||||
|
padding: 10px;
|
||||||
|
flex: 30% 0 0;
|
||||||
|
// height: 30%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.person-list {
|
.person-list {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-wrap: wrap;
|
flex-wrap: wrap;
|
||||||
@ -306,28 +349,48 @@ h1 {
|
|||||||
.news-blog {
|
.news-blog {
|
||||||
.blog-entry {
|
.blog-entry {
|
||||||
.header {
|
.header {
|
||||||
|
|
||||||
|
margin: 5px 0 10px;
|
||||||
a {
|
a {
|
||||||
&::before {
|
|
||||||
content: '' !important;
|
|
||||||
}
|
|
||||||
font-size: larger;
|
font-size: larger;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.details {
|
.details {
|
||||||
display: flex;
|
display: flex;
|
||||||
min-height: 240px;
|
// min-height: 240px;
|
||||||
|
margin-right: 2px;
|
||||||
|
|
||||||
.teaser-image {
|
.teaser-image {
|
||||||
flex: 33% 1 0;
|
flex: 33% 1 0;
|
||||||
background-color: lightcyan;
|
background-color: lightcyan;
|
||||||
|
|
||||||
|
img {
|
||||||
|
width: 90%;
|
||||||
|
height: 190px;
|
||||||
|
object-fit: contain;
|
||||||
|
object-position: left top;
|
||||||
}
|
}
|
||||||
.intro {
|
}
|
||||||
|
.right-side {
|
||||||
flex: 66% 1 1;
|
flex: 66% 1 1;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
|
||||||
|
.intro {
|
||||||
|
padding-right: 40px;
|
||||||
}
|
}
|
||||||
.teaser-image, .intro {
|
.more {
|
||||||
|
// float: right;
|
||||||
|
margin-top: 20px;
|
||||||
|
text-align: right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// .teaser-image, .intro {
|
||||||
// display: ;
|
// display: ;
|
||||||
|
// }
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.pagination {
|
.pagination {
|
||||||
@ -347,6 +410,24 @@ h1 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.tsc-gallery {
|
||||||
|
display: grid;
|
||||||
|
|
||||||
|
&.cols-2 {
|
||||||
|
grid-template-columns: 1fr 1fr;
|
||||||
|
}
|
||||||
|
&.cols-3 {
|
||||||
|
grid-template-columns: 1fr 1fr 1fr;
|
||||||
|
}
|
||||||
|
&.cols-4 {
|
||||||
|
grid-template-columns: 1fr 1fr 1fr 1fr;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tsc-gallery-img {
|
||||||
|
margin: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@font-face{
|
@font-face{
|
||||||
font-family: 'Open Sans Condensed';
|
font-family: 'Open Sans Condensed';
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
|
@ -16,5 +16,19 @@
|
|||||||
</div>
|
</div>
|
||||||
{{- partial "page/footer.html" . -}}
|
{{- partial "page/footer.html" . -}}
|
||||||
</div>
|
</div>
|
||||||
|
<div id="overlay" class="hidden">
|
||||||
|
<div class="background"></div>
|
||||||
|
<div class="spacer"></div>
|
||||||
|
<div class="dialog-column">
|
||||||
|
<div class="spacer"></div>
|
||||||
|
<div class="dialog">
|
||||||
|
<div class="img">
|
||||||
|
<img>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="spacer"></div>
|
||||||
|
</div>
|
||||||
|
<div class="spacer"></div>
|
||||||
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
@ -3,24 +3,32 @@
|
|||||||
<h1>{{ .Title }}</h1>
|
<h1>{{ .Title }}</h1>
|
||||||
</a>
|
</a>
|
||||||
<div class="news-blog">
|
<div class="news-blog">
|
||||||
{{ range (.Paginate (first 10 ( where .Site.RegularPages "Section" "==" "news")) 5 ).Pages }}
|
{{ range (.Paginate (first 200 ( where .Site.RegularPages "Section" "==" "news")) 10 ).Pages }}
|
||||||
|
{{ $urlBlogEntry := .RelPermalink}}
|
||||||
<div class="blog-entry">
|
<div class="blog-entry">
|
||||||
<div class="header">
|
<div class="header">
|
||||||
{{ .Date.Format "02.01.2006" }}
|
{{ .Date.Format "02.01.2006" }}
|
||||||
<a href="{{ .Permalink }}">{{ .Title }}</a>
|
<a href="{{ $urlBlogEntry }}">{{ .Title }}</a>
|
||||||
</div>
|
</div>
|
||||||
<div class="details">
|
<div class="details">
|
||||||
<div class="teaser-image">
|
<div class="teaser-image">
|
||||||
{{ $page := . }}
|
{{ $page := . }}
|
||||||
{{ if .Params.Image }}
|
{{ if .Params.Image }}
|
||||||
<img src="{{ (.Resources.GetMatch (.Params.Image)).RelPermalink }}">
|
{{ with (.Resources.GetMatch (.Params.Image)).Fit "290x190 webp" }}
|
||||||
|
<a href="{{ $urlBlogEntry }}">
|
||||||
|
<img src="{{ .RelPermalink }}">
|
||||||
|
</a>
|
||||||
|
{{ end }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
</div>
|
</div>
|
||||||
|
<div class="right-side">
|
||||||
<div class="intro">
|
<div class="intro">
|
||||||
{{ with .Summary }}
|
{{ with .Summary }}
|
||||||
{{ . }}
|
{{ . }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
</div>
|
</div>
|
||||||
|
<div class="more"><a href="{{ $urlBlogEntry }}">MEHR...</a></div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
@ -30,4 +38,3 @@
|
|||||||
{{ partial "totop" }}
|
{{ partial "totop" }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
|
||||||
{{ define "left" }}<!-- No left side menu -->{{ end }}
|
|
||||||
|
@ -9,4 +9,5 @@
|
|||||||
<title>{{ $title }}</title>
|
<title>{{ $title }}</title>
|
||||||
<script defer src="{{ relURL "js/jquery-3.6.3.min.js" }}"></script>
|
<script defer src="{{ relURL "js/jquery-3.6.3.min.js" }}"></script>
|
||||||
<script defer src="{{ relURL "js/slider.js" }}"></script>
|
<script defer src="{{ relURL "js/slider.js" }}"></script>
|
||||||
|
<script defer src="{{ relURL "js/gallery.js" }}"></script>
|
||||||
</head>
|
</head>
|
||||||
|
@ -0,0 +1,27 @@
|
|||||||
|
{{ $cols := .Parent.Get "columns" }}
|
||||||
|
{{ $imgOriginal := .Page.Resources.GetMatch (.Get "src") }}
|
||||||
|
{{ $img := $imgOriginal }}
|
||||||
|
{{ if eq $cols "2" }}
|
||||||
|
{{ $img = $imgOriginal.Fit "500x1000 webp" }}
|
||||||
|
{{ else if eq $cols "3" }}
|
||||||
|
{{ $img = $imgOriginal.Fit "333x800 webp" }}
|
||||||
|
{{ else if eq $cols "4" }}
|
||||||
|
{{ $img = $imgOriginal.Fit "250x500 webp" }}
|
||||||
|
{{ else }}
|
||||||
|
{{ $img = $imgOriginal.Fit "800x1000 webp" }}
|
||||||
|
{{ end }}
|
||||||
|
{{ $imgFitted := $imgOriginal.Fit "850x1000 webp" }}
|
||||||
|
<figure class="tsc-gallery-img">
|
||||||
|
<a
|
||||||
|
{{ with .Get "href" }}
|
||||||
|
href="{{ . }}"
|
||||||
|
{{ else }}
|
||||||
|
data-url="{{ $imgFitted.RelPermalink }}"
|
||||||
|
{{ end }}
|
||||||
|
>
|
||||||
|
<img
|
||||||
|
{{ with .Get "alt"}}alt="{{.}}"{{ end }}
|
||||||
|
src="{{ $img.RelPermalink }}"
|
||||||
|
>
|
||||||
|
</a>
|
||||||
|
</figure>
|
@ -1 +1,7 @@
|
|||||||
{{ .Inner }}
|
{{ $colClass := "" }}
|
||||||
|
{{- with .Get "columns" }}
|
||||||
|
{{ $colClass = (print "cols-" .) }}
|
||||||
|
{{ end -}}
|
||||||
|
<div class="tsc-gallery {{ $colClass }}">
|
||||||
|
{{ .Inner }}
|
||||||
|
</div>
|
||||||
|
@ -0,0 +1,19 @@
|
|||||||
|
<figure>
|
||||||
|
{{ with .Get "href" }}
|
||||||
|
<a href="{{ . }}">
|
||||||
|
{{ end }}
|
||||||
|
<img
|
||||||
|
{{- with .Get "alt" }}alt="{{ . }}"{{ end }}
|
||||||
|
{{- $filename := .Get "src" }}
|
||||||
|
{{ $resource := .Page.Resources.Get $filename -}}
|
||||||
|
src="{{ $resource.RelPermalink }}"
|
||||||
|
>
|
||||||
|
{{ with .Get "href" }}
|
||||||
|
</a>
|
||||||
|
{{ end }}
|
||||||
|
{{ with .Get "caption" }}
|
||||||
|
<figcaption>
|
||||||
|
{{ . }}
|
||||||
|
</figcaption>
|
||||||
|
{{ end }}
|
||||||
|
</figure>
|
@ -0,0 +1,10 @@
|
|||||||
|
<video controls
|
||||||
|
{{ with .Get "poster" }}poster="{{ . }}"{{ end }}
|
||||||
|
{{ with .Get "width" }}width="{{ . }}"{{ end }}
|
||||||
|
{{ with .Get "height" }}height="{{ . }}"{{ end }}
|
||||||
|
>
|
||||||
|
<source
|
||||||
|
{{ with .Get "type" }}type="{{ . }}"{{ end }}
|
||||||
|
src="{{ (.Page.Resources.GetMatch (.Get "src")).RelPermalink }}"
|
||||||
|
>
|
||||||
|
</video>
|
@ -0,0 +1,9 @@
|
|||||||
|
<iframe
|
||||||
|
{{ with .Get "width" }}width="{{ . }}"{{ end }}
|
||||||
|
{{ with .Get "height" }}height="{{ . }}"{{ end }}
|
||||||
|
src="https://www.youtube-nocookie.com/embed/{{ .Get "id" }}"
|
||||||
|
title="{{ with .Get "title" }}{{ . }}{{ else }}YouTube video player{{ end }}"
|
||||||
|
frameborder="0"
|
||||||
|
allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share"
|
||||||
|
allowfullscreen>
|
||||||
|
</iframe>
|
18
themes/tsc_vfl/static/js/gallery.js
Normal file
18
themes/tsc_vfl/static/js/gallery.js
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
$(function() {
|
||||||
|
$(".tsc-gallery-img a").click(function(ev){
|
||||||
|
// console.debug(ev)
|
||||||
|
const url = ev.currentTarget.dataset.url
|
||||||
|
console.debug(url)
|
||||||
|
$('#overlay').removeClass('hidden')
|
||||||
|
$('#overlay .img img').attr('src', url)
|
||||||
|
})
|
||||||
|
$('#overlay .background, #overlay .spacer').click(function(ev) {
|
||||||
|
$('#overlay').addClass('hidden')
|
||||||
|
$('#overlay .img img').attr('src', '')
|
||||||
|
})
|
||||||
|
// $('#overlay').on('keydown', function(ev){
|
||||||
|
// if(ev.keyCode === 27) {
|
||||||
|
// console.log('closing')
|
||||||
|
// }
|
||||||
|
// })
|
||||||
|
})
|
Loading…
Reference in New Issue
Block a user