fix: resolve conflict
This commit is contained in:
parent
7fa65a26da
commit
6a85167ade
9 changed files with 36 additions and 47 deletions
3
.env
3
.env
|
@ -1,9 +1,8 @@
|
||||||
API_KEY_LASTFM=
|
API_KEY_LASTFM=
|
||||||
|
API_KEY_PLAUSIBLE=
|
||||||
API_KEY_TRAKT=
|
API_KEY_TRAKT=
|
||||||
API_KEY_MOVIEDB=
|
API_KEY_MOVIEDB=
|
||||||
API_KEY_WEBMENTIONS_CORYD_DEV=
|
API_KEY_WEBMENTIONS_CORYD_DEV=
|
||||||
API_TOKEN_PINBOARD=
|
API_TOKEN_PINBOARD=
|
||||||
SITE_ID_CLICKY=
|
|
||||||
SITE_KEY_CLICKY=
|
|
||||||
SECRET_FEED_ALBUM_RELEASES=
|
SECRET_FEED_ALBUM_RELEASES=
|
||||||
COOKIE_STORYGRAPH=
|
COOKIE_STORYGRAPH=
|
|
@ -58,6 +58,5 @@ https://cdme.netlify.app https://coryd.dev 301!
|
||||||
/follow.json https://feedpress.me/coryd-follow.json
|
/follow.json https://feedpress.me/coryd-follow.json
|
||||||
|
|
||||||
# analytics
|
# analytics
|
||||||
/4afe62271e477e.js https://static.getclicky.com/js?in=%2F4dcb93321b2a3b 200
|
/js/script.js https://plausible.io/js/script.outbound-links.tagged-events.js 200
|
||||||
/4dcb93321b2a3b https://in.getclicky.com/in.php 200
|
/api/event https://plausible.io/api/event 200
|
||||||
/404ca498061b54 https://in.getclicky.com/101424044ns.gif 200
|
|
|
@ -35,10 +35,10 @@ module.exports = {
|
||||||
getPopularPosts: (posts, analytics) => {
|
getPopularPosts: (posts, analytics) => {
|
||||||
return posts
|
return posts
|
||||||
.filter((post) => {
|
.filter((post) => {
|
||||||
if (analytics.find((p) => p.url.includes(post.url))) return true
|
if (analytics.find((p) => p.page === post.url)) return true
|
||||||
})
|
})
|
||||||
.sort((a, b) => {
|
.sort((a, b) => {
|
||||||
const visitors = (page) => analytics.filter((p) => p.url.includes(page.url)).pop().rank
|
const visitors = (page) => analytics.filter((p) => p.page === page.url).pop().visitors
|
||||||
return visitors(b) - visitors(a)
|
return visitors(b) - visitors(a)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
|
@ -26,4 +26,9 @@ permalink: 404.html
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<hr />
|
<hr />
|
||||||
{% render "partials/popular-posts.liquid", posts: collections.posts, analytics: analytics %}
|
{% render "partials/popular-posts.liquid", posts: collections.posts, analytics: analytics %}
|
||||||
|
<script>
|
||||||
|
document.addEventListener('DOMContentLoaded', function () {
|
||||||
|
plausible('404', { props: { path: document.location.pathname } })
|
||||||
|
})
|
||||||
|
</script>
|
|
@ -1,31 +1,18 @@
|
||||||
const EleventyFetch = require('@11ty/eleventy-fetch')
|
const EleventyFetch = require('@11ty/eleventy-fetch')
|
||||||
|
|
||||||
module.exports = async function () {
|
module.exports = async function () {
|
||||||
const SITE_ID_CLICKY = process.env.SITE_ID_CLICKY
|
const API_KEY_PLAUSIBLE = process.env.API_KEY_PLAUSIBLE
|
||||||
const SITE_KEY_CLICKY = process.env.SITE_KEY_CLICKY
|
const url =
|
||||||
const url = `https://api.clicky.com/api/stats/4?site_id=${SITE_ID_CLICKY}&sitekey=${SITE_KEY_CLICKY}&type=pages&date=last-90-days&output=json`
|
'https://plausible.io/api/v1/stats/breakdown?site_id=coryd.dev&period=6mo&property=event:page&limit=30'
|
||||||
const res = EleventyFetch(url, {
|
const res = EleventyFetch(url, {
|
||||||
duration: '1h',
|
duration: '1h',
|
||||||
type: 'json',
|
type: 'json',
|
||||||
|
fetchOptions: {
|
||||||
|
headers: {
|
||||||
|
Authorization: `Bearer ${API_KEY_PLAUSIBLE}`,
|
||||||
|
},
|
||||||
|
},
|
||||||
}).catch()
|
}).catch()
|
||||||
const data = await res
|
const pages = await res
|
||||||
const pages = data[0].dates[0].items
|
return pages.results.filter((p) => p.page.includes('posts')).splice(0, 5)
|
||||||
.filter((p) => p.url.includes('posts'))
|
|
||||||
.filter((p) => !p.url.includes('/null'))
|
|
||||||
.map((page) => {
|
|
||||||
return {
|
|
||||||
title: page.title,
|
|
||||||
rank: parseInt(page.value),
|
|
||||||
url: page.url.split('?')[0],
|
|
||||||
}
|
|
||||||
})
|
|
||||||
const postsObj = {}
|
|
||||||
pages.forEach((page) => {
|
|
||||||
if (postsObj[page.url]) {
|
|
||||||
postsObj[page.url].rank += postsObj[page.url].rank
|
|
||||||
} else {
|
|
||||||
postsObj[page.url] = page
|
|
||||||
}
|
|
||||||
})
|
|
||||||
return Object.values(postsObj)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,8 +58,8 @@
|
||||||
<script type="application/ld+json">
|
<script type="application/ld+json">
|
||||||
{% jsonLd meta, type, tags %}
|
{% jsonLd meta, type, tags %}
|
||||||
</script>
|
</script>
|
||||||
<script async data-id="101424044" src="/4afe62271e477e.js"></script>
|
<script defer data-domain="coryd.dev" src="/js/script.js"></script>
|
||||||
<noscript><img width="1" height="1" src="/404ca498061b54" style="display:none" /></noscript>
|
<script>window.plausible = window.plausible || function() { (window.plausible.q = window.plausible.q || []).push(arguments) }</script>
|
||||||
<noscript>
|
<noscript>
|
||||||
<style>
|
<style>
|
||||||
.client-side {
|
.client-side {
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
Popular posts
|
Popular posts
|
||||||
</h2>
|
</h2>
|
||||||
<ul class="list-inside list-disc pl-5 md:pl-10">
|
<ul class="list-inside list-disc pl-5 md:pl-10">
|
||||||
{% for post in posts limit: 5 %}
|
{% for post in posts %}
|
||||||
<li class="mt-1.5 mb-2">
|
<li class="mt-1.5 mb-2">
|
||||||
<a href="{{post.url}}" title="{{ post.data.title | escape}}">
|
<a href="{{post.url}}" title="{{ post.data.title | escape}}">
|
||||||
{{ post.data.title }}
|
{{ post.data.title }}
|
||||||
|
@ -13,4 +13,4 @@
|
||||||
</li>
|
</li>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -26,9 +26,8 @@ meta:
|
||||||
|
|
||||||
Referral links for services I use. I save some money, and you do as well if you choose to use them.
|
Referral links for services I use. I save some money, and you do as well if you choose to use them.
|
||||||
|
|
||||||
- <a onclick="clicky.goal('Referral: nextDNS')" href="https://nextdns.io/?from=m56mt3z6">NextDNS</a>
|
- <a class="plausible-event-name=NextDNS+referral" href="https://nextdns.io/?from=m56mt3z6">NextDNS</a>
|
||||||
- <a onclick="clicky.goal('Referral: DNSimple')" href="https://dnsimple.com/r/3a7cbb9e15df8f">DNSimple</a>
|
- <a class="plausible-event-name=DNSimple+referral" href="https://dnsimple.com/r/3a7cbb9e15df8f">DNSimple</a>
|
||||||
- <a onclick="clicky.goal('Referral: Bunny.net')" href="https://bunny.net?ref=revw3mehej">Bunny.net</a>
|
- <a class="plausible-event-name=bunny+referral" href="https://bunny.net?ref=revw3mehej">Bunny.net</a>
|
||||||
- <a onclick="clicky.goal('Referral: Clicky')" href="https://clicky.com/101424044">Clicky</a>
|
- <a class="plausible-event-name=Feedpress+referral" href="https://feedpress.com/?affid=34370">Feedpress</a>
|
||||||
- <a onclick="clicky.goal('Referral: Feedpress')" href="https://feedpress.com/?affid=34370">Feedpress</a>
|
- <a class="plausible-event-name=DigitalOcean+referral" href="https://m.do.co/c/3635bf99aee2">DigitalOcean</a>
|
||||||
- <a onclick="clicky.goal('Referral: DigitalOcean')" href="https://m.do.co/c/3635bf99aee2">DigitalOcean</a>
|
|
||||||
|
|
12
src/uses.md
12
src/uses.md
|
@ -26,7 +26,7 @@ meta:
|
||||||
|
|
||||||
Software and services that I use for work and my own enjoyment.
|
Software and services that I use for work and my own enjoyment.
|
||||||
|
|
||||||
{% image 'https://coryd.dev/assets/img/pages/uses.jpg', 'My desk', 'border border-blue-600 dark:border-blue-400 rounded-lg overflow-hidden [&>*]:w-full', 'eager' %}
|
{% image '<https://coryd.dev/assets/img/pages/uses.jpg>', 'My desk', 'border border-blue-600 dark:border-blue-400 rounded-lg overflow-hidden [&>*]:w-full', 'eager' %}
|
||||||
|
|
||||||
<h3 className="text-xl font-extrabold leading-9 tracking-tight text-gray-900 dark:text-gray-100 sm:text-2xl sm:leading-10 md:text-4xl md:leading-14">Computer setup</h3>
|
<h3 className="text-xl font-extrabold leading-9 tracking-tight text-gray-900 dark:text-gray-100 sm:text-2xl sm:leading-10 md:text-4xl md:leading-14">Computer setup</h3>
|
||||||
|
|
||||||
|
@ -73,11 +73,11 @@ Software and services that I use for work and my own enjoyment.
|
||||||
|
|
||||||
<h3 className="text-xl font-extrabold leading-9 tracking-tight text-gray-900 dark:text-gray-100 sm:text-2xl sm:leading-10 md:text-4xl md:leading-14">Services</h3>
|
<h3 className="text-xl font-extrabold leading-9 tracking-tight text-gray-900 dark:text-gray-100 sm:text-2xl sm:leading-10 md:text-4xl md:leading-14">Services</h3>
|
||||||
|
|
||||||
- <a onclick="clicky.goal('Referral: nextDNS')" href="https://nextdns.io/?from=m56mt3z6">NextDNS</a>: a privacy-focused, set it and forget it DNS service. I use their security features on my home network and a profile with strict ad-blocking rules on all of my devices.
|
- <a class="plausible-event-name=NextDNS+referral" href="https://nextdns.io/?from=m56mt3z6">NextDNS</a>: a privacy-focused, set it and forget it DNS service. I use their security features on my home network and a profile with strict ad-blocking rules on all of my devices.
|
||||||
- <a onclick="clicky.goal('Referral: DNSimple')" href="https://dnsimple.com/r/3a7cbb9e15df8f">DNSimple</a>: a robust, user-friendly DNS provider and registrar. I moved my domains here after my old provider was acquired.
|
- <a class="plausible-event-name=DNSimple+referral" href="https://dnsimple.com/r/3a7cbb9e15df8f">DNSimple</a>: a robust, user-friendly DNS provider and registrar. I moved my domains here after my old provider was acquired.
|
||||||
- <a onclick="clicky.goal('Referral: Bunny.net')" href="https://bunny.net?ref=revw3mehej">Bunny.net</a>: a powerful and affordable CDN. I use it to serve assets on my personal site (most notable my now page — raw assets are fetched by Eleventy and then optimized to webp).
|
- <a class="plausible-event-name=bunny+referral" href="https://bunny.net?ref=revw3mehej">Bunny.net</a>: a powerful and affordable CDN. I use it to serve assets on my personal site (most notable my now page — raw assets are fetched by Eleventy and then optimized to webp).
|
||||||
- <a onclick="clicky.goal('Referral: Clicky')" href="https://clicky.com/101424044">Clicky</a>: powerful and easy to understand analytics (if, perhaps, not the prettiest to look at).
|
- [Plausible](https://plausible.io): powerful, well-designed and privacy-respecting analytics.
|
||||||
- <a onclick="clicky.goal('Referral: Feedpress')" href="https://feedpress.com/?affid=34370">Feedpress</a>: they've been around for a while now and don't change much (nor do they need to), but look no further for reliable, helpful feed analytics.
|
- <a class="plausible-event-name=Feedpress+referral" href="https://feedpress.com/?affid=34370">Feedpress</a>: they've been around for a while now and don't change much (nor do they need to), but look no further for reliable, helpful feed analytics.
|
||||||
- [SavvyCal](https://savvycal.com): the most pleasant scheduling solution I've found to date. It offers a number of scheduling niceties and allows visitors to overlay their own calendars for a seamless booking experience.
|
- [SavvyCal](https://savvycal.com): the most pleasant scheduling solution I've found to date. It offers a number of scheduling niceties and allows visitors to overlay their own calendars for a seamless booking experience.
|
||||||
- [IVPN](https://www.ivpn.net): my VPN of choice for browsing outside of my home network. Privacy-focused and trustworthy.
|
- [IVPN](https://www.ivpn.net): my VPN of choice for browsing outside of my home network. Privacy-focused and trustworthy.
|
||||||
- [Kagi](https://kagi.com): search that's actually helpful and ad-free. It's lenses feature and the ability to up/downvote and block results from different sites are indispensable.
|
- [Kagi](https://kagi.com): search that's actually helpful and ad-free. It's lenses feature and the ability to up/downvote and block results from different sites are indispensable.
|
||||||
|
|
Reference in a new issue