feat: mastodon-post web component
This commit is contained in:
parent
e0f6c26000
commit
6b65a517c5
7 changed files with 64 additions and 7 deletions
|
@ -74,6 +74,9 @@ export default async function (eleventyConfig) {
|
||||||
eleventyConfig.addPassthroughCopy({
|
eleventyConfig.addPassthroughCopy({
|
||||||
'node_modules/@zachleat/pagefind-search/pagefind-search.js': 'assets/scripts/pagefind-search.js',
|
'node_modules/@zachleat/pagefind-search/pagefind-search.js': 'assets/scripts/pagefind-search.js',
|
||||||
})
|
})
|
||||||
|
eleventyConfig.addPassthroughCopy({
|
||||||
|
'node_modules/@daviddarnes/mastodon-post/mastodon-post.js': 'assets/scripts/mastodon-post.js'
|
||||||
|
})
|
||||||
|
|
||||||
// enable merging of tags
|
// enable merging of tags
|
||||||
eleventyConfig.setDataDeepMerge(true)
|
eleventyConfig.setDataDeepMerge(true)
|
||||||
|
|
|
@ -111,7 +111,9 @@ export default {
|
||||||
// links
|
// links
|
||||||
findPost: (url, posts) => {
|
findPost: (url, posts) => {
|
||||||
if (!url || !posts) return null;
|
if (!url || !posts) return null;
|
||||||
return posts[url]?.toots?.[0] || null;
|
const BASE_URL = 'https://social.lol/users/cory/statuses/'
|
||||||
|
const STATUS_URL = 'https://social.lol/@cory/'
|
||||||
|
return posts[url]?.toots?.[0].replace(BASE_URL, STATUS_URL) || null;
|
||||||
},
|
},
|
||||||
absoluteUrl: (url, base) => {
|
absoluteUrl: (url, base) => {
|
||||||
if (!base) base = metaData.url
|
if (!base) base = metaData.url
|
||||||
|
|
16
package-lock.json
generated
16
package-lock.json
generated
|
@ -1,14 +1,15 @@
|
||||||
{
|
{
|
||||||
"name": "coryd.dev",
|
"name": "coryd.dev",
|
||||||
"version": "5.9.6",
|
"version": "6.0.7",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "coryd.dev",
|
"name": "coryd.dev",
|
||||||
"version": "5.9.6",
|
"version": "6.0.7",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@daviddarnes/mastodon-post": "^1.1.1",
|
||||||
"@remy/webmention": "^1.5.0",
|
"@remy/webmention": "^1.5.0",
|
||||||
"@zachleat/pagefind-search": "^1.0.3"
|
"@zachleat/pagefind-search": "^1.0.3"
|
||||||
},
|
},
|
||||||
|
@ -1225,6 +1226,11 @@
|
||||||
"node": ">=6.9.0"
|
"node": ">=6.9.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/@daviddarnes/mastodon-post": {
|
||||||
|
"version": "1.1.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/@daviddarnes/mastodon-post/-/mastodon-post-1.1.1.tgz",
|
||||||
|
"integrity": "sha512-qkVOJkCzsMASuvcvlv9cG/hdDwMp9uVnfFS7YhQ0JPmls4g6eVQNjLBxUT+iINFU+yBZj/zPwovDhO79gnOPEQ=="
|
||||||
|
},
|
||||||
"node_modules/@emnapi/runtime": {
|
"node_modules/@emnapi/runtime": {
|
||||||
"version": "0.45.0",
|
"version": "0.45.0",
|
||||||
"resolved": "https://registry.npmjs.org/@emnapi/runtime/-/runtime-0.45.0.tgz",
|
"resolved": "https://registry.npmjs.org/@emnapi/runtime/-/runtime-0.45.0.tgz",
|
||||||
|
@ -7045,9 +7051,9 @@
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/terser": {
|
"node_modules/terser": {
|
||||||
"version": "5.27.1",
|
"version": "5.27.2",
|
||||||
"resolved": "https://registry.npmjs.org/terser/-/terser-5.27.1.tgz",
|
"resolved": "https://registry.npmjs.org/terser/-/terser-5.27.2.tgz",
|
||||||
"integrity": "sha512-29wAr6UU/oQpnTw5HoadwjUZnFQXGdOfj0LjZ4sVxzqwHh/QVkvr7m8y9WoR4iN3FRitVduTc6KdjcW38Npsug==",
|
"integrity": "sha512-sHXmLSkImesJ4p5apTeT63DsV4Obe1s37qT8qvwHRmVxKTBH7Rv9Wr26VcAMmLbmk9UliiwK8z+657NyJHHy/w==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@jridgewell/source-map": "^0.3.3",
|
"@jridgewell/source-map": "^0.3.3",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "coryd.dev",
|
"name": "coryd.dev",
|
||||||
"version": "6.0.7",
|
"version": "6.1.7",
|
||||||
"description": "The source for my personal site. Built using 11ty and hosted on Netlify.",
|
"description": "The source for my personal site. Built using 11ty and hosted on Netlify.",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
@ -20,6 +20,7 @@
|
||||||
"author": "Cory Dransfeldt",
|
"author": "Cory Dransfeldt",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@daviddarnes/mastodon-post": "^1.1.1",
|
||||||
"@remy/webmention": "^1.5.0",
|
"@remy/webmention": "^1.5.0",
|
||||||
"@zachleat/pagefind-search": "^1.0.3"
|
"@zachleat/pagefind-search": "^1.0.3"
|
||||||
},
|
},
|
||||||
|
|
26
src/_includes/partials/mastodon-post.liquid
Normal file
26
src/_includes/partials/mastodon-post.liquid
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
{%- assign shareLink = postUrl | findPost: linkPosts -%}
|
||||||
|
{%- if shareLink %}
|
||||||
|
{% capture css %}
|
||||||
|
{% render "../../assets/styles/widgets/mastodon-post.css" %}
|
||||||
|
{% endcapture %}
|
||||||
|
<style>{{ css }}</style>
|
||||||
|
<script type="module" src="/assets/scripts/mastodon-post.js"></script>
|
||||||
|
<template id="mastodon-post-template">
|
||||||
|
<div class="mastodon-post-wrapper">
|
||||||
|
<blockquote data-key="content"></blockquote>
|
||||||
|
<dl>
|
||||||
|
<dt>{% tablericon "refresh" "Reposts" %}</dt>
|
||||||
|
<dd data-key="reblogs_count"></dd>
|
||||||
|
<dt>{% tablericon "message-circle" "Replies" %}</dt>
|
||||||
|
<dd data-key="replies_count"></dd>
|
||||||
|
<dt>{% tablericon "star" "Favorites" %}</dt>
|
||||||
|
<dd data-key="favourites_count"></dd>
|
||||||
|
</dl>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<mastodon-post>
|
||||||
|
<a href="{{ shareLink }}">
|
||||||
|
Discuss on Mastodon
|
||||||
|
</a>
|
||||||
|
</mastodon-post>
|
||||||
|
{% endif -%}
|
|
@ -29,5 +29,6 @@ schema: blog
|
||||||
</div>
|
</div>
|
||||||
</article>
|
</article>
|
||||||
</div>
|
</div>
|
||||||
|
{% render "partials/mastodon-post.liquid", postUrl: postUrl, linkPosts: linkPosts %}
|
||||||
{% render "partials/post-tags.liquid", tags: tags %}
|
{% render "partials/post-tags.liquid", tags: tags %}
|
||||||
{% render "partials/popular-posts.liquid", posts: collections.posts, analytics: analytics %}
|
{% render "partials/popular-posts.liquid", posts: collections.posts, analytics: analytics %}
|
18
src/assets/styles/widgets/mastodon-post.css
Normal file
18
src/assets/styles/widgets/mastodon-post.css
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
.mastodon-post-wrapper {
|
||||||
|
border-bottom: 1px solid var(--gray-light);
|
||||||
|
margin-bottom: 2rem;
|
||||||
|
padding-bottom: 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
dl {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
}
|
||||||
|
|
||||||
|
dd {
|
||||||
|
margin-left: .25rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
dd:not(:last-child) {
|
||||||
|
margin-right: 1rem;
|
||||||
|
}
|
Reference in a new issue