fix: encode

This commit is contained in:
Cory Dransfeldt 2024-10-17 16:58:52 -07:00
parent bbae08a925
commit d0a4a67e12
No known key found for this signature in database
11 changed files with 16 additions and 45 deletions

View file

@ -8,6 +8,7 @@ export default {
const replacement = '&' const replacement = '&'
return string.replace(pattern, replacement) return string.replace(pattern, replacement)
}, },
replaceQuotes: (string) => string.replace(/"/g, '"'),
formatNumber: (number) => number.toLocaleString('en-US'), formatNumber: (number) => number.toLocaleString('en-US'),
htmlTruncate: (content, limit = 50) => truncateHtml(content, limit, { htmlTruncate: (content, limit = 50) => truncateHtml(content, limit, {
byWords: true, byWords: true,

View file

@ -92,17 +92,17 @@
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>{{ pageTitle }}</title> <title data-dynamic="title">{{ pageTitle }}</title>
<link rel="preload" href="/assets/fonts/ml.woff2" as="font" type="font/woff2" crossorigin="anonymous"> <link rel="preload" href="/assets/fonts/ml.woff2" as="font" type="font/woff2" crossorigin="anonymous">
<link rel="preload" href="/assets/fonts/mlb.woff2" as="font" type="font/woff2" crossorigin="anonymous"> <link rel="preload" href="/assets/fonts/mlb.woff2" as="font" type="font/woff2" crossorigin="anonymous">
<link rel="stylesheet" href="/assets/styles/index.css?v={% appVersion %}" type="text/css" /> <link rel="stylesheet" href="/assets/styles/index.css?v={% appVersion %}" type="text/css" />
<link rel="canonical" href="{{ fullUrl }}" /> <link rel="canonical" href="{{ fullUrl }}" />
<meta property="og:title" content="{{ pageTitle }}" /> <meta property="og:title" content="{{ pageTitle }}" data-dynamic="og:title" />
<meta name="description" content="{{ escapedPageDescription }}" /> <meta name="description" content="{{ escapedPageDescription }}" data-dynamic="description" />
<meta property="og:description" content="{{ escapedPageDescription }}" /> <meta property="og:description" content="{{ escapedPageDescription }}" data-dynamic="og:description" />
<meta property="og:type" content="article" /> <meta property="og:type" content="article" />
<meta property="og:url" content="{{ fullUrl }}" /> <meta property="og:url" content="{{ fullUrl }}" data-dynamic="og:url" />
<meta property="og:image" content="{{ ogImage }}?class=w800" /> <meta property="og:image" content="{{ ogImage }}?class=w800" data-dynamic="og:image" />
<meta name="theme-color" content="{{ globals.theme_color }}" /> <meta name="theme-color" content="{{ globals.theme_color }}" />
<meta name="fediverse:creator" content="{{ globals.mastodon }}" /> <meta name="fediverse:creator" content="{{ globals.mastodon }}" />
<meta name="generator" content="Eleventy"> <meta name="generator" content="Eleventy">
@ -119,36 +119,6 @@
<script defer src="/assets/scripts/index.js?v={% appVersion %}"></script> <script defer src="/assets/scripts/index.js?v={% appVersion %}"></script>
<script defer data-domain="coryd.dev" src="/js/script.js"></script> <script defer data-domain="coryd.dev" src="/js/script.js"></script>
<script>window.plausible = window.plausible || function() { (window.plausible.q = window.plausible.q || []).push(arguments) }</script> <script>window.plausible = window.plausible || function() { (window.plausible.q = window.plausible.q || []).push(arguments) }</script>
<script type="application/ld+json">
{
"@context": "https://schema.org",
"@graph": [
{
"@type": "WebSite",
"@id": "{{ globals.url }}#website",
"url": "{{ globals.url }}",
"name": "{{ pageTitle }}",
"description": "{{ escapedPageDescription }}",
"inLanguage": "{{ globals.locale }}"
},
{%- if schema == 'blog' -%}
{
"@type": "BlogPosting",
"mainEntityOfPage": { "@type": "WebPage" },
"isPartOf": { "@id": "{{ globals.url }}#website" },
"@id": "{{ fullUrl }}",
"headline": "{{ pageTitle }}",
"description": "{{ escapedPageDescription }}",
"image": "{{ image | default: globals.meta_data.opengraph_default }}",
"inLanguage": "{{ globals.locale }}",
"publisher": { "@type": "{{ globals.site_type }}", "name": "{{ globals.author }}", "url": "{{ globals.url }}" },
"author": { "@type": "Person", "name": "{{ globals.author }}" },
"datePublished": "{{ page.date | date: "%Y.%m.%d" }}"
}
{%- endif -%}
]
}
</script>
<noscript> <noscript>
<style>.client-side {display:none}</style> <style>.client-side {display:none}</style>
</noscript> </noscript>

View file

@ -8,7 +8,7 @@
(max-width: 850px) 512px (max-width: 850px) 512px
1024px" 1024px"
src="{{ globals.cdn_url }}{{ image }}?class=bannersm&type=webp" src="{{ globals.cdn_url }}{{ image }}?class=bannersm&type=webp"
alt="{{ alt }}" alt="{{ alt | replaceQuotes }}"
class="image-banner" class="image-banner"
loading="lazy" loading="lazy"
decoding="async" decoding="async"

View file

@ -2,7 +2,7 @@
{%- assign hidePagination = pageCount <= 1 -%} {%- assign hidePagination = pageCount <= 1 -%}
<div class="media-grid {% if shape == 'poster' -%}poster{%- elsif shape == 'square' -%}square{%- elsif shape == 'vertical' -%}vertical{%- endif -%}"> <div class="media-grid {% if shape == 'poster' -%}poster{%- elsif shape == 'square' -%}square{%- elsif shape == 'vertical' -%}vertical{%- endif -%}">
{%- for item in data limit: count -%} {%- for item in data limit: count -%}
{%- assign alt = item.grid.alt | strip | escape -%} {%- assign alt = item.grid.alt | replaceQuotes -%}
<a href="{{ item.grid.url }}" title="{{ alt }}"> <a href="{{ item.grid.url }}" title="{{ alt }}">
<div class="item"> <div class="item">
<div class="meta-text"> <div class="meta-text">

View file

@ -10,7 +10,7 @@
" "
sizes="(max-width: 450px) 50px, 100px" sizes="(max-width: 450px) 50px, 100px"
src="{{ globals.cdn_url }}{{ item.chart.image }}?class=w50&type=webp" src="{{ globals.cdn_url }}{{ item.chart.image }}?class=w50&type=webp"
alt="{{ item.chart.alt }}" alt="{{ item.chart.alt | replaceQuotes }}"
loading="lazy" loading="lazy"
decoding="async" decoding="async"
width="64" width="64"

View file

@ -24,7 +24,7 @@ schema: book
(max-width: 1000px) 812px, (max-width: 1000px) 812px,
812px" 812px"
src="{{ globals.cdn_url }}{{ book.image }}?class=verticalsm&type=webp" src="{{ globals.cdn_url }}{{ book.image }}?class=verticalsm&type=webp"
alt="{{ alt }}" alt="{{ alt | replaceQuotes }}"
loading="lazy" loading="lazy"
decoding="async" decoding="async"
width="200" width="200"

View file

@ -26,7 +26,7 @@ schema: books
sizes="(max-width: 450px) 200px, sizes="(max-width: 450px) 200px,
400px" 400px"
src="{{ globals.cdn_url }}{{ book.image }}?class=verticalsm&type=webp" src="{{ globals.cdn_url }}{{ book.image }}?class=verticalsm&type=webp"
alt="{{ alt }}" alt="{{ alt | replaceQuotes }}"
loading="lazy" loading="lazy"
decoding="async" decoding="async"
width="200" width="200"

View file

@ -32,7 +32,7 @@ schema: artist
(max-width: 850px) 400px, (max-width: 850px) 400px,
800px" 800px"
src="{{ globals.cdn_url }}{{ artist.image }}?class=w200&type=webp" src="{{ globals.cdn_url }}{{ artist.image }}?class=w200&type=webp"
alt="{{ alt }}" alt="{{ alt | replaceQuotes }}"
loading="eager" loading="eager"
decoding="async" decoding="async"
width="200" width="200"

View file

@ -32,7 +32,7 @@ schema: blog
(max-width: 1000px) 800px, (max-width: 1000px) 800px,
1200px" 1200px"
src="{{ globals.cdn_url }}{{ post.image }}?class=w200" src="{{ globals.cdn_url }}{{ post.image }}?class=w200"
alt="{{ post.image_alt }}" alt="{{ post.image_alt | replaceQuotes }}"
class="image-banner" class="image-banner"
loading="eager" loading="eager"
decoding="async" decoding="async"

View file

@ -22,7 +22,7 @@ schema: movie
(max-width: 850px) 512px, (max-width: 850px) 512px,
1024px" 1024px"
src="{{ globals.cdn_url }}{{ movie.backdrop }}?class=bannersm&type=webp" src="{{ globals.cdn_url }}{{ movie.backdrop }}?class=bannersm&type=webp"
alt="{{ alt }}" alt="{{ alt | replaceQuotes }}"
class="image-banner" class="image-banner"
loading="eager" loading="eager"
decoding="async" decoding="async"

View file

@ -22,7 +22,7 @@ schema: show
(max-width: 850px) 512px, (max-width: 850px) 512px,
1024px" 1024px"
src="{{ globals.cdn_url }}{{ show.backdrop }}?class=bannersm&type=webp" src="{{ globals.cdn_url }}{{ show.backdrop }}?class=bannersm&type=webp"
alt="{{ alt }}" alt="{{ alt | replaceQuotes }}"
class="image-banner" class="image-banner"
loading="eager" loading="eager"
decoding="async" decoding="async"