Merge changes, adjustments to bookmark card for gscan tests

This commit is contained in:
David Darnes 2019-11-12 13:54:39 +00:00
commit 056d76fd1f
13 changed files with 522 additions and 481 deletions

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -1,9 +1,4 @@
/* Main
/* ---------------------------------------------------------- */
.gh-main {
margin-bottom: 2rem;
}
/* Content grid /* Content grid
/* ---------------------------------------------------------- */ /* ---------------------------------------------------------- */
@ -11,28 +6,50 @@
display: grid; display: grid;
grid-template-columns: grid-template-columns:
[full-start] [full-start]
minmax(calc(calc(100% - 970px) / 2), 1fr) minmax(calc(calc(100% - 1200px) / 2), 1fr)
[wide-start] [wide-start]
1fr auto
[main-start] [main-start]
repeat(10, [col-start] 1fr) 720px
[main-end] [main-end]
1fr auto
[wide-end] [wide-end]
minmax(calc(calc(100% - 970px) / 2), 1fr) minmax(calc(calc(100% - 1200px) / 2), 1fr)
[full-end] [full-end]
; ;
} }
@media (max-width: 600px) { @media (max-width: 1296px) {
.gh-canvas { .gh-canvas {
grid-template-columns: grid-template-columns:
[full-start] [full-start]
minmax(calc(calc(100% - 720px) / 2), 1fr) 4vw
[wide-start main-start] [wide-start]
repeat(10, [col-start] 1fr) auto
[main-end wide-end] [main-start]
minmax(calc(calc(100% - 720px) / 2), 1fr) 720px
[main-end]
auto
[wide-end]
4vw
[full-end]
;
}
}
@media (max-width: 778px) {
.gh-canvas {
grid-template-columns:
[full-start]
4vw
[wide-start]
auto
[main-start]
auto
[main-end]
auto
[wide-end]
4vw
[full-end] [full-end]
; ;
} }
@ -42,8 +59,7 @@
grid-column: main-start / main-end; grid-column: main-start / main-end;
} }
.kg-width-wide, .kg-width-wide {
.gh-canvas > h5 {
grid-column: wide-start / wide-end; grid-column: wide-start / wide-end;
} }
@ -52,6 +68,310 @@
} }
/* Content & Typography
/* ---------------------------------------------------------- */
.gh-content > * + * {
margin-top: 4vw;
}
@media (min-width: 600px) {
.gh-content > * + * {
margin-top: 3vw;
}
}
@media (min-width: 1100px) {
.gh-content > * + * {
margin-top: 4.2rem;
}
}
.gh-content > [id] + * {
margin-top: 1.5rem;
}
.gh-content [id] {
margin: 1.5em 0 0;
}
.gh-content [id] + .kg-card,
.gh-content blockquote + .kg-card {
margin-top: 1.5rem;
}
.gh-canvas blockquote,
.gh-canvas ol,
.gh-canvas ul,
.gh-canvas dl,
.gh-canvas p {
font-family: var(--font-serif);
font-weight: 400;
font-size: 2rem;
line-height: 1.6em;
}
.gh-content ul,
.gh-content ol,
.gh-content dl {
padding-left: 1.9em;
}
.gh-content hr {
margin-top: 5vw;
}
.gh-content hr + * {
margin-top: 5vw !important;
}
.gh-content blockquote {
position: relative;
font-style: italic;
}
.gh-content blockquote::before {
content: "";
position: absolute;
left: -1.5em;
top: 0;
bottom: 0;
width: 0.3rem;
background: var(--color-primary);
}
@media (max-width: 650px) {
.gh-canvas blockquote,
.gh-canvas ol,
.gh-canvas ul,
.gh-canvas dl,
.gh-canvas p {
font-size: 1.8rem;
}
.gh-content blockquote::before {
left: -4vw;
}
}
/* Cards
/* ---------------------------------------------------------- */
:not(.kg-card):not([id]) + .kg-card {
margin-top: 6vw;
}
.kg-card + :not(.kg-card):not([id]) {
margin-top: 6vw;
}
@media (min-width: 600px) {
:not(.kg-card):not([id]) + .kg-card {
margin-top: 6vw;
}
.kg-card + :not(.kg-card):not([id]) {
margin-top: 6vw;
}
}
@media (min-width: 1100px) {
:not(.kg-card):not([id]) + .kg-card {
margin-top: 6rem;
}
.kg-card + :not(.kg-card):not([id]) {
margin-top: 6rem;
}
}
.kg-card figcaption {
padding: 1.5rem 1.5rem 0;
text-align: center;
color: rgba(0,0,0,0.5);
font-weight: 600;
font-size: 1.3rem;
line-height: 1.4em;
}
.kg-card figcaption strong {
color: rgba(0,0,0,0.8);
}
.gh-canvas :not(pre) code {
vertical-align: middle;
padding: 0.15em 0.4em 0.15em;
border: #e1eaef 1px solid;
font-weight: 400 !important;
font-size: 0.9em;
line-height: 1em;
color: #dc0050;
background: #f0f6f9;
border-radius: 0.25em;
}
.gh-canvas > pre {
overflow: scroll;
padding: 16px 20px;
background: rgba(255,255,255,0.6);
border-radius: 5px;
box-shadow: 0 2px 6px -2px rgba(0,0,0,.1), 0 0 1px rgba(0,0,0,.4);
}
.kg-embed-card {
display: flex;
flex-direction: column;
align-items: center;
width: 100%;
}
/* Galleries
/* ---------------------------------------------------------- */
.kg-gallery-card + .kg-gallery-card {
margin-top: 0.75em;
}
.kg-gallery-container {
position: relative;
}
.kg-gallery-row {
display: flex;
flex-direction: row;
justify-content: center;
}
.kg-gallery-image img {
display: block;
margin: 0;
width: 100%;
height: 100%;
}
.kg-gallery-row:not(:first-of-type) {
margin: 0.75em 0 0 0;
}
.kg-gallery-image:not(:first-of-type) {
margin: 0 0 0 0.75em;
}
/* Bookmark Cards
/* ---------------------------------------------------------- */
.kg-bookmark-card,
.kg-bookmark-publisher {
position: relative;
}
.kg-bookmark-container {
display: flex;
flex-wrap: wrap;
flex-direction: row-reverse;
color: currentColor;
background: rgba(255,255,255,0.6);
font-family: inherit;
text-decoration: none;
border-radius: 5px;
box-shadow: 0 2px 6px -2px rgba(0, 0, 0, 0.1), 0 0 1px rgba(0, 0, 0, 0.4);
overflow: hidden;
}
.kg-bookmark-content {
flex-basis: 0;
flex-grow: 999;
padding: 20px;
order: 1;
}
.kg-bookmark-title {
font-weight: 600;
font-size: 1.5rem;
}
.kg-bookmark-description {
display: -webkit-box;
max-height: 45px;
margin: 0.6em 0 0 0;
font-size: 1.4rem;
line-height: 1.55em;
overflow: hidden;
opacity: 0.8;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
}
.kg-bookmark-metadata,
.kg-bookmark-description {
margin-top: 0.9em;
}
.kg-bookmark-metadata {
display: flex;
align-items: center;
font-weight: 500;
font-size: 1.3rem;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.kg-bookmark-description {
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
overflow: hidden;
}
.kg-bookmark-icon {
display: inline-block;
width: 16px;
height: 16px;
vertical-align: text-bottom;
margin-right: .5em;
}
.kg-bookmark-thumbnail {
display: flex;
flex-basis: 24rem;
flex-grow: 1;
}
.kg-bookmark-thumbnail img {
max-width: 100%;
height: auto;
vertical-align: bottom;
object-fit: cover;
}
.kg-bookmark-publisher::before {
content: "•";
margin: 0 .5em;
}
/* Card captions
/* ---------------------------------------------------------- */
.kg-width-full.kg-card-hascaption {
display: grid;
grid-template-columns: inherit;
}
.kg-width-wide.kg-card-hascaption img {
grid-column: wide-start / wide-end;
}
.kg-width-full.kg-card-hascaption img {
grid-column: 1 / -1;
}
.kg-width-full.kg-card-hascaption figcaption {
grid-column: main-start / main-end;
}
/* Tables /* Tables
/* ---------------------------------------------------------- */ /* ---------------------------------------------------------- */
@ -90,283 +410,8 @@
border-bottom: 1px solid rgba(0,0,0,.1); border-bottom: 1px solid rgba(0,0,0,.1);
} }
/* Post header
/* ---------------------------------------------------------- */
.gh-page.no-image {
margin-top: 2rem;
}
.gh-header { /* Third Party
grid-row-gap: 2rem;
margin-bottom: 1.5em;
}
.gh-title,
.gh-image {
grid-row: 1 / 2;
align-self: end;
}
.gh-excerpt {
grid-row: 2 / 3;
}
.gh-image {
grid-column: full-start / full-end;
width: 100%;
}
.gh-title {
margin-top: 2rem;
}
.gh-image + .gh-title {
color: #fff;
}
.gh-post-footer {
margin: 2rem 0;
}
/* Standard content
/* ---------------------------------------------------------- */
.gh-content [id],
.gh-content table,
.gh-content blockquote {
margin: 0.6em 0 0.3em;
}
.gh-content > [id] + [id]:not(h5) {
margin-top: 0;
}
.gh-content > .kg-card + [id]:not(h5) {
margin-top: 2.3em;
}
.gh-content [id] + .kg-card,
.gh-content table + .kg-card,
.gh-content blockquote + .kg-card,
.gh-content blockquote {
margin-top: 1.5em;
}
.gh-content h5[id] {
display: block;
margin: 2em 0 1.5em;
text-align: center;
line-height: 1.35em;
font-weight: 300;
}
.gh-content hr {
margin: 2em 0;
border-color: currentColor;
opacity: 0.2;
}
.gh-content ul,
.gh-content ol,
.gh-content dl {
padding-left: 1.9em;
}
.gh-content blockquote {
position: relative;
padding-left: 1.5em;
}
.gh-content blockquote::before {
content: "";
position: absolute;
left: 0;
top: 0;
bottom: 0;
width: .5em;
background: currentColor;
opacity: 0.3;
}
/* Cards
/* ---------------------------------------------------------- */
.kg-gallery-container,
.kg-bookmark-card,
.kg-bookmark-publisher {
position: relative;
}
.gh-content > * + * {
margin-top: 1.5rem;
}
.gh-content > [id] + * {
margin-top: 0;
}
:not(.kg-card):not([id]) + .kg-card,
.gh-post-footer {
margin-top: 7vw;
}
.kg-card + :not(.kg-card):not([id]) {
margin-top: 7vw;
}
.gh-post-footer {
margin-bottom: 7vw;
}
.kg-card figcaption {
padding: 1.5rem 1.5rem 0;
font-size: 1.3rem;
line-height: 1.4em;
font-weight: 600;
text-align: center;
opacity: 0.4;
}
.gh-canvas > pre {
overflow: scroll;
padding: 16px 20px;
border-radius: 5px;
background: rgba(255,255,255,0.6);
box-shadow: 0 2px 6px -2px rgba(0,0,0,.1), 0 0 1px rgba(0,0,0,.4);
}
.kg-embed-card {
display: flex;
flex-direction: column;
align-items: center;
width: 100%;
}
/* Card captions
/* ---------------------------------------------------------- */
.kg-width-full.kg-card-hascaption {
display: grid;
grid-template-columns: inherit;
}
.kg-width-wide.kg-card-hascaption img {
grid-column: wide-start / wide-end;
}
.kg-width-full.kg-card-hascaption img {
grid-column: 1 / -1;
}
.kg-width-full.kg-card-hascaption figcaption {
grid-column: main-start / main-end;
}
/* Galleries
/* ---------------------------------------------------------- */
.kg-gallery-row {
display: flex;
flex-direction: row;
justify-content: center;
}
.kg-gallery-image img {
display: block;
margin: 0;
width: 100%;
height: 100%;
}
.kg-gallery-row:not(:first-of-type) {
margin: 0.75em 0 0 0;
}
.kg-gallery-image:not(:first-of-type) {
margin: 0 0 0 0.75em;
}
/* Bookmark Cards
/* ---------------------------------------------------------- */
.kg-bookmark-card {
width: 100%;
position: relative;
}
.kg-bookmark-container {
display: flex;
flex-wrap: wrap;
flex-direction: row-reverse;
color: currentColor;
background: rgba(255,255,255,0.6);
font-family: inherit;
text-decoration: none;
border-radius: 5px;
box-shadow: 0 2px 6px -2px rgba(0, 0, 0, 0.1), 0 0 1px rgba(0, 0, 0, 0.4);
overflow: hidden;
}
.kg-bookmark-container:hover {
text-decoration: none;
}
.kg-bookmark-content {
flex-basis: 0;
flex-grow: 999;
padding: 20px;
order: 1;
}
.kg-bookmark-title {
font-weight: 600;
}
.kg-bookmark-metadata,
.kg-bookmark-description {
margin-top: .5em;
}
.kg-bookmark-metadata {
align-items: center;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.kg-bookmark-description {
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
overflow: hidden;
}
.kg-bookmark-icon {
display: inline-block;
width: 1em;
height: 1em;
vertical-align: text-bottom;
margin-right: .5em;
margin-bottom: .05em;
}
.kg-bookmark-thumbnail {
display: flex;
flex-basis: 24rem;
flex-grow: 1;
}
.kg-bookmark-thumbnail img {
max-width: 100%;
height: auto;
vertical-align: bottom;
object-fit: cover;
}
.kg-bookmark-publisher::before {
content: "•";
margin: 0 .5em;
}
/* Spotify Cards
/* ---------------------------------------------------------- */ /* ---------------------------------------------------------- */
.kg-card iframe[src*="spotify.com"] { .kg-card iframe[src*="spotify.com"] {

View File

@ -37,6 +37,7 @@ ol,
li, li,
dl, dl,
dd, dd,
hr,
pre, pre,
table, table,
video, video,
@ -44,6 +45,7 @@ figure,
figcaption, figcaption,
blockquote { blockquote {
margin: 0; margin: 0;
padding: 0;
} }
ul[class], ul[class],
@ -68,29 +70,10 @@ hr {
position: relative; position: relative;
display: block; display: block;
width: 100%; width: 100%;
margin: 2.5em 0 3.5em;
padding: 0;
height: 1px; height: 1px;
border: 0; border: 0;
border-top: 1px solid color(var(--color-border) l(+10%)); border-top: 1px solid currentcolor;
} opacity: 0.2;
blockquote {
margin: 1.5em 0;
padding: 0 1.6em 0 1.6em;
}
blockquote p {
margin: 0.8em 0;
font-size: 1.2em;
font-weight: 300;
}
blockquote small {
display: inline-block;
margin: 0.8em 0 0.8em 1.5em;
font-size: 0.9em;
opacity: 0.8;
} }
::selection { ::selection {
@ -102,13 +85,22 @@ mark {
background-color: #fdffb6; background-color: #fdffb6;
} }
sup, sub { small {
vertical-align: baseline; font-size: 80%;
position: relative; }
top: -0.4em;
sub,
sup {
position: relative;
font-size: 75%;
line-height: 0;
vertical-align: baseline;
}
sup {
top: -0.5em;
} }
sub { sub {
top: 0.4em; bottom: -0.25em;
} }
a:not([class]) { a:not([class]) {
@ -138,9 +130,8 @@ h6 {
} }
h1 { h1 {
margin: 0 0 0.5em 0; font-size: 4.6rem;
font-size: 5.7rem; letter-spacing: -0.5px;
font-weight: 800;
} }
@media (max-width: 500px) { @media (max-width: 500px) {
h1 { h1 {
@ -149,8 +140,7 @@ h1 {
} }
h2 { h2 {
margin: 0 0 0.5em 0; font-size: 3.4rem;
font-size: 4rem;
} }
@media (max-width: 500px) { @media (max-width: 500px) {
h2 { h2 {
@ -159,7 +149,6 @@ h2 {
} }
h3 { h3 {
margin: 0 0 1em 0;
font-size: 3.2rem; font-size: 3.2rem;
} }
@media (max-width: 500px) { @media (max-width: 500px) {
@ -169,17 +158,14 @@ h3 {
} }
h4 { h4 {
margin: 0 0 1em 0;
font-size: 2.6rem; font-size: 2.6rem;
} }
h5 { h5 {
margin: 0 0 1em 0;
font-size: 2.4rem; font-size: 2.4rem;
} }
h6 { h6 {
margin: 0 0 1em 0;
font-size: 2.2rem; font-size: 2.2rem;
} }

View File

@ -285,6 +285,7 @@ body:not(.gh-head-open) .gh-burger:hover .gh-burger-inner::after {
right: 0; right: 0;
bottom: 0; bottom: 0;
left: 0; left: 0;
z-index: 900;
overflow-y: scroll; overflow-y: scroll;
} }
.gh-head-open #gh-head .gh-container { .gh-head-open #gh-head .gh-container {

View File

@ -27,20 +27,30 @@ production stylesheet in assets/built/screen.css using: gulp dev
html, html,
.gh-viewport { .gh-viewport {
display: flex;
flex-direction: column;
min-height: 100vh;
background: #fff; background: #fff;
} }
.gh-main {
flex: 1 0 auto;
display: flex;
flex-direction: column;
}
/* Global */ /* Global */
.gh-page {
padding: 0 4vw;
}
.gh-container { .gh-container {
width: 100%; width: 100%;
max-width: 1200px; max-width: 1200px;
margin: 0 auto; margin: 0 auto;
} }
/* .gh-main {
padding: 0 4vw;
} */
.gh-head-actions a { .gh-head-actions a {
display: inline-flex; display: inline-flex;
@ -62,6 +72,51 @@ html,
height: 2rem; height: 2rem;
} }
/* Post header
/* ---------------------------------------------------------- */
.gh-image {
grid-column: full-start / full-end;
width: 100%;
}
.gh-post-footer {
margin: 2rem 0;
}
/* Errors
/* ---------------------------------------------------------- */
.gh-error {
flex: 1 0 auto;
display: flex;
flex-direction: column;
justify-content: center;
padding-bottom: 2vmin;
}
.gh-error-content {
flex: 1 0 auto;
text-align: center;
}
.gh-error-code {
margin: 0;
font-size: 14vmin;
}
.gh-error-description {
font-size: 4vmin;
font-weight: 300;
opacity: 0.6;
}
.gh-error-link {
display: block;
margin-top: 4vmin;
font-size: 1.6rem;
}
/* Footer /* Footer
/* ---------------------------------------------------------- */ /* ---------------------------------------------------------- */

View File

@ -1,35 +1,41 @@
{{!< default}} {{!< default}}
{{!-- The tag above means - insert everything in this file into the {body} of the default.hbs template --}}
{{#author}} <div class="gh-page">
{{!-- Everything inside the #author tags pulls data from the author --}} <div class="gh-container">
<header class="page-head">
<h1 class="page-head-title">{{name}}</h1>
{{#if bio}}<p class="page-head-description">{{bio}}</p>{{/if}}
<div class="author-meta"> {{#author}}
<div class="author-links"> {{!-- Everything inside the #author tags pulls data from the author --}}
{{#if website}}
<a href="{{website}}" target="_blank" rel="noopener">Website</a> <span class="divider">/</span> <header class="page-head">
{{/if}} <h1 class="page-head-title">{{name}}</h1>
{{#if twitter}} {{#if bio}}<p class="page-head-description">{{bio}}</p>{{/if}}
<a href="{{twitter_url}}" target="_blank" rel="noopener">Twitter</a> <span class="divider">/</span>
{{/if}} <div class="author-meta">
{{#if facebook}} <div class="author-links">
<a href="{{facebook_url}}" target="_blank" rel="noopener">Facebook</a> <span class="divider">/</span> {{#if website}}
{{/if}} <a href="{{website}}" target="_blank" rel="noopener">Website</a> <span class="divider">/</span>
<a href="https://feedly.com/i/subscription/feed/{{url absolute="true"}}rss/" target="_blank" rel="noopener">RSS</a> {{/if}}
{{#if twitter}}
<a href="{{twitter_url}}" target="_blank" rel="noopener">Twitter</a> <span class="divider">/</span>
{{/if}}
{{#if facebook}}
<a href="{{facebook_url}}" target="_blank" rel="noopener">Facebook</a> <span class="divider">/</span>
{{/if}}
<a href="https://feedly.com/i/subscription/feed/{{url absolute="true"}}rss/" target="_blank" rel="noopener">RSS</a>
</div>
</div>
</header>
{{/author}}
<div class="post-feed">
{{#foreach posts}}
{{> "post-card"}} {{!-- partials/post-card.hbs --}}
{{/foreach}}
</div> </div>
</div> </div>
</header> </div>
{{/author}}
<div class="post-feed">
{{#foreach posts}}
{{!-- The tag below includes the markup for each post - partials/post-card.hbs --}}
{{> "post-card"}}
{{/foreach}}
</div>

View File

@ -66,6 +66,8 @@
</div> </div>
{{!-- <foot> --}}
<script src="https://code.jquery.com/jquery-3.4.1.min.js" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script> <script src="https://code.jquery.com/jquery-3.4.1.min.js" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script>
{{#if pagination.pages}} {{#if pagination.pages}}
@ -84,8 +86,24 @@ $(document).ready(function () {
}); });
</script> </script>
{{{block "scripts"}}} {{#is "post, page"}}
{{!-- The #block helper will pull in data from the #contentFor other template files --}} <script src="{{asset "built/jquery.fitvids.js"}}"></script>
<script>
var images = document.querySelectorAll('.kg-gallery-image img');
images.forEach(function (image) {
var container = image.closest('.kg-gallery-image');
var width = image.attributes.width.value;
var height = image.attributes.height.value;
var ratio = width / height;
container.style.flex = ratio + ' 1 0%';
});
$(document).ready(function () {
// FitVids - start
var $postContent = $(".gh-content");
$postContent.fitVids();
});
</script>
{{/is}}
{{ghost_foot}} {{ghost_foot}}
{{!-- Outputs important scripts - should always be included before closing body tag --}} {{!-- Outputs important scripts - should always be included before closing body tag --}}

View File

@ -1,43 +1,13 @@
{{!-- {{!< default}}
A 404 error template, served whenever someone tries to access a page which does not exist. <section class="gh-page gh-error">
<div class="gh-container">
--}} <section class="gh-error-content">
<!DOCTYPE html> <h1 class="gh-error-code">{{statusCode}}</h1>
<html> <p class="gh-error-description">{{message}}</p>
<head> <p class="gh-error-link"><a href="{{@site.url}}">Go to the front page →</a></p>
<meta charset="utf-8" /> </section>
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<title>{{meta_title}}</title>
<meta name="HandheldFriendly" content="True" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="stylesheet" type="text/css" href="{{asset "built/screen.css"}}" />
</head>
<body class="error-template">
<div class="site-wrapper">
<header class="site-header outer {{#if feature_image}}" style="background-image: url({{feature_image}}){{else}}no-image{{/if}}">
<div class="inner">
<nav class="site-nav-center">
{{#if @site.logo}}
<a class="site-nav-logo" href="{{@site.url}}"><img src="{{img_url @site.logo size="xs"}}" alt="{{@site.title}}" /></a>
{{else}}
<a class="site-nav-logo" href="{{@site.url}}">{{@site.title}}</a>
{{/if}}
</nav>
</div>
</header>
<main id="site-main" class="site-main outer">
<div class="inner">
<section class="error-message">
<h1 class="error-code">{{statusCode}}</h1>
<p class="error-description">{{message}}</p>
<a class="error-link" href="{{@site.url}}">Go to the front page →</a>
</section>
</div>
</main>
</div> </div>
</body> </section>
</html>

View File

@ -1,22 +1,15 @@
{{!< default}} {{!< default}}
<div class="gh-container"> <div class="gh-page">
<div class="gh-container">
{{#is "home"}} <div class="post-feed">
{{#if @site.description}} {{#foreach posts}}
<header class="page-head">
<h2 class="page-head-title">{{@site.description}}</h2>
</header>
{{/if}}
{{/is}}
<div class="post-feed"> {{> "post-card"}} {{!-- partials/post-card.hbs --}}
{{#foreach posts}}
{{> "post-card"}} {{/foreach}}
{{!-- The tag below includes the markup for each post - partials/post-card.hbs --}} </div>
{{/foreach}}
</div> </div>
</div> </div>

View File

@ -1,7 +1,8 @@
{{!< default}} {{!< default}}
{{#post}} {{#post}}
<article class="gh-page {{post_class}} {{#unless feature_image}}no-image{{/unless}}">
<article class="{{post_class}}">
<header class="gh-header gh-canvas"> <header class="gh-header gh-canvas">
{{#if feature_image}} {{#if feature_image}}
@ -20,19 +21,5 @@
</div> </div>
</article> </article>
{{/post}}
{{!-- The #contentFor helper here will send everything inside it up to the matching #block helper found in default.hbs --}} {{/post}}
{{#contentFor "scripts"}}
<script>
// Layout Script for Ghost Gallery Cards
var images = document.querySelectorAll('.kg-gallery-image img');
images.forEach(function (image) {
var container = image.closest('.kg-gallery-image');
var width = image.attributes.width.value;
var height = image.attributes.height.value;
var ratio = width / height;
container.style.flex = ratio + ' 1 0%';
})
</script>
{{/contentFor}}

View File

@ -1,7 +1,7 @@
{{!< default}} {{!< default}}
{{#post}} {{#post}}
<article class="gh-post {{post_class}}"> <article class="{{post_class}}">
<header class="gh-header gh-canvas"> <header class="gh-header gh-canvas">
{{#if feature_image}} {{#if feature_image}}
@ -19,7 +19,7 @@
{{content}} {{content}}
</div> </div>
<footer class="gh-post-footer gh-canvas"> <footer class="gh-footer gh-canvas">
<div class="gh-post-authors"> <div class="gh-post-authors">
Written by {{#foreach authors}}<a href="{{url}}">{{name}}</a>{{/foreach}} Written by {{#foreach authors}}<a href="{{url}}">{{name}}</a>{{/foreach}}
@ -35,26 +35,3 @@
</article> </article>
{{/post}} {{/post}}
{{#contentFor "scripts"}}
<script src="{{asset "built/jquery.fitvids.js"}}"></script>
<script>
var images = document.querySelectorAll('.kg-gallery-image img');
images.forEach(function (image) {
var container = image.closest('.kg-gallery-image');
var width = image.attributes.width.value;
var height = image.attributes.height.value;
var ratio = width / height;
container.style.flex = ratio + ' 1 0%';
});
$(document).ready(function () {
// FitVids - start
var $postContent = $(".gh-content");
$postContent.fitVids();
});
</script>
{{/contentFor}}
{{!-- The #contentFor helper sends everything in it to the matching #block helper in default.hbs --}}

43
tag.hbs
View File

@ -1,25 +1,28 @@
{{!< default}} {{!< default}}
{{!-- The tag above means: insert everything in this file
into the {body} of the default.hbs template --}}
{{#tag}} <div class="gh-page">
<header class="page-head"> <div class="gh-container">
<h1 class="page-head-title">{{name}}</h1>
<p class="page-head-description">
{{#if description}}
{{description}}
{{else}}
A collection of {{plural ../pagination.total empty='posts' singular='% post' plural='% posts'}}
{{/if}}
</p>
</header>
{{/tag}}
<div class="post-feed"> {{#tag}}
{{#foreach posts}} <header class="page-head">
<h1 class="page-head-title">{{name}}</h1>
<p class="page-head-description">
{{#if description}}
{{description}}
{{else}}
A collection of {{plural ../pagination.total empty='posts' singular='% post' plural='% posts'}}
{{/if}}
</p>
</header>
{{/tag}}
{{!-- The tag below includes the markup for each post - partials/post-card.hbs --}} <div class="post-feed">
{{> "post-card"}} {{#foreach posts}}
{{/foreach}} {{> "post-card"}} {{!-- partials/post-card.hbs --}}
</div>
{{/foreach}}
</div>
</div>
</div>