chore: filters + cleanup

This commit is contained in:
Cory Dransfeldt 2024-08-30 09:44:59 -07:00
parent 360111c784
commit 515da740ba
No known key found for this signature in database
5 changed files with 35 additions and 28 deletions

View file

@ -164,9 +164,9 @@ export const processContent = (collection) => {
export const albumReleasesCalendar = (collection) => {
const collectionData = collection.getAll()[0]
const { data } = collectionData
const { albumReleases } = data
if (!albumReleases || albumReleases.length === 0) return ''
const events = albumReleases.map(album => {
const { albumReleases: { all } } = data;
if (!all || all.length === 0) return ''
const events = all.map(album => {
const date = DateTime.fromFormat(album.date, 'MMMM d, yyyy')
if (!date.isValid) return null
@ -183,6 +183,7 @@ export const albumReleasesCalendar = (collection) => {
}).filter(event => event !== null)
const { error, value } = ics.createEvents(events)
if (error) {
console.error('Error creating events: ', error)
events.forEach((event, index) => {

26
package-lock.json generated
View file

@ -1,12 +1,12 @@
{
"name": "coryd.dev",
"version": "24.4.1",
"version": "24.4.2",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"name": "coryd.dev",
"version": "24.4.1",
"version": "24.4.2",
"license": "MIT",
"dependencies": {
"@cdransf/api-text": "^1.5.0",
@ -19,7 +19,7 @@
"@11ty/eleventy": "v3.0.0-beta.1",
"@11ty/eleventy-plugin-syntaxhighlight": "^5.0.0",
"@cdransf/eleventy-plugin-tabler-icons": "^1.12.0",
"@supabase/supabase-js": "^2.45.2",
"@supabase/supabase-js": "^2.45.3",
"autoprefixer": "^10.4.20",
"cssnano": "^7.0.5",
"dotenv-flow": "^4.1.0",
@ -565,9 +565,9 @@
}
},
"node_modules/@supabase/auth-js": {
"version": "2.64.4",
"resolved": "https://registry.npmjs.org/@supabase/auth-js/-/auth-js-2.64.4.tgz",
"integrity": "sha512-9ITagy4WP4FLl+mke1rchapOH0RQpf++DI+WSG2sO1OFOZ0rW3cwAM0nCrMOxu+Zw4vJ4zObc08uvQrXx590Tg==",
"version": "2.65.0",
"resolved": "https://registry.npmjs.org/@supabase/auth-js/-/auth-js-2.65.0.tgz",
"integrity": "sha512-+wboHfZufAE2Y612OsKeVP4rVOeGZzzMLD/Ac3HrTQkkY4qXNjI6Af9gtmxwccE5nFvTiF114FEbIQ1hRq5uUw==",
"dev": true,
"license": "MIT",
"dependencies": {
@ -631,13 +631,13 @@
}
},
"node_modules/@supabase/supabase-js": {
"version": "2.45.2",
"resolved": "https://registry.npmjs.org/@supabase/supabase-js/-/supabase-js-2.45.2.tgz",
"integrity": "sha512-kJKY3ISFusVKQWCP8Kqo20Ebxy2WLp6Ry/Suco0aQsPXH7bvn7clswsdhcfcH/5Tr0MYz/jcCjF0n/27SetiCw==",
"version": "2.45.3",
"resolved": "https://registry.npmjs.org/@supabase/supabase-js/-/supabase-js-2.45.3.tgz",
"integrity": "sha512-4wAux6cuVMrdH/qUjKn6p3p3L9AtAO3Une6ojIrtpCj1RaXKVoyIATiacSRAI+pKff6XZBVCGC29v+z4Jo/uSw==",
"dev": true,
"license": "MIT",
"dependencies": {
"@supabase/auth-js": "2.64.4",
"@supabase/auth-js": "2.65.0",
"@supabase/functions-js": "2.4.1",
"@supabase/node-fetch": "2.6.15",
"@supabase/postgrest-js": "1.15.8",
@ -1066,9 +1066,9 @@
}
},
"node_modules/caniuse-lite": {
"version": "1.0.30001653",
"resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001653.tgz",
"integrity": "sha512-XGWQVB8wFQ2+9NZwZ10GxTYC5hk0Fa+q8cSkr0tgvMhYhMHP/QC+WTgrePMDBWiWc/pV+1ik82Al20XOK25Gcw==",
"version": "1.0.30001655",
"resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001655.tgz",
"integrity": "sha512-jRGVy3iSGO5Uutn2owlb5gR6qsGngTw9ZTb4ali9f3glshcNmJ2noam4Mo9zia5P9Dk3jNNydy7vQjuE5dQmfg==",
"dev": true,
"funding": [
{

View file

@ -1,6 +1,6 @@
{
"name": "coryd.dev",
"version": "24.4.1",
"version": "24.4.2",
"description": "The source for my personal site. Built using 11ty (and other tools).",
"type": "module",
"scripts": {
@ -35,7 +35,7 @@
"@11ty/eleventy": "v3.0.0-beta.1",
"@11ty/eleventy-plugin-syntaxhighlight": "^5.0.0",
"@cdransf/eleventy-plugin-tabler-icons": "^1.12.0",
"@supabase/supabase-js": "^2.45.2",
"@supabase/supabase-js": "^2.45.3",
"autoprefixer": "^10.4.20",
"cssnano": "^7.0.5",
"dotenv-flow": "^4.1.0",

View file

@ -6,7 +6,7 @@ const SUPABASE_KEY = process.env.SUPABASE_KEY
const supabase = createClient(SUPABASE_URL, SUPABASE_KEY)
const fetchAlbumReleases = async () => {
const today = DateTime.utc().toISO()
const today = DateTime.utc().startOf('day')
const { data, error } = await supabase
.from('optimized_album_releases')
.select(`
@ -17,24 +17,30 @@ const fetchAlbumReleases = async () => {
art,
artist_name
`)
.gt('release_date', today)
if (error) {
console.error('Error fetching data:', error)
return []
}
return data
.filter(album => !album['total_plays'] || album['total_plays'] <= 0)
.map(album => ({
const all = data.map(album => {
const releaseDate = DateTime.fromISO(album['release_date']).toUTC().startOf('day')
return {
artist: album['artist_name'],
title: album['name'],
date: DateTime.fromISO(album['release_date']).toLocaleString(DateTime.DATE_FULL),
date: releaseDate.toLocaleString(DateTime.DATE_FULL),
url: album['release_link'],
image: album['art'] ? `/${album['art']}` : '',
type: 'album-release'
}))
.sort((a, b) => a['timestamp'] - b['timestamp'])
total_plays: album['total_plays'],
release_date: releaseDate,
type: 'album-release',
timestamp: releaseDate.toSeconds(),
}
}).sort((a, b) => a['timestamp'] - b['timestamp'])
const upcoming = all.filter(album => (!album['total_plays'] || album['total_plays'] <= 0) && album['release_date'] > today);
return { all, upcoming }
}
export default async function () {

View file

@ -51,5 +51,5 @@ schema: music-index
{% tablericon "calendar-time" "Anticipated albums" %}
Anticipated albums
</h3>
{% render "partials/media/grid.liquid", data:albumReleases, shape: "square", count: 8 %}
{% render "partials/media/grid.liquid", data:albumReleases.upcoming, shape: "square", count: 8 %}
{% endif %}