feat: add concerts to all feed
This commit is contained in:
parent
757b3273bb
commit
ded6093fd6
5 changed files with 17 additions and 6 deletions
|
@ -46,7 +46,7 @@ export const processContent = (collection) => {
|
||||||
let id = 0
|
let id = 0
|
||||||
const collectionData = collection.getAll()[0]
|
const collectionData = collection.getAll()[0]
|
||||||
const { data } = collectionData
|
const { data } = collectionData
|
||||||
const { posts, links, movies, books, pages, artists, genres, tv } = data
|
const { posts, links, movies, books, pages, artists, genres, tv, concerts } = data
|
||||||
|
|
||||||
const parseDate = (date) => {
|
const parseDate = (date) => {
|
||||||
if (!date) return null
|
if (!date) return null
|
||||||
|
@ -104,6 +104,7 @@ export const processContent = (collection) => {
|
||||||
items.forEach((item) => {
|
items.forEach((item) => {
|
||||||
let attribution
|
let attribution
|
||||||
|
|
||||||
|
// link attribution if properties exist
|
||||||
if (item?.['authors']?.['mastodon']) {
|
if (item?.['authors']?.['mastodon']) {
|
||||||
const mastoUrl = new URL(item['authors']['mastodon'])
|
const mastoUrl = new URL(item['authors']['mastodon'])
|
||||||
attribution = `${mastoUrl.pathname.replace('/', '')}@${mastoUrl.host}`
|
attribution = `${mastoUrl.pathname.replace('/', '')}@${mastoUrl.host}`
|
||||||
|
@ -115,10 +116,19 @@ export const processContent = (collection) => {
|
||||||
url: `${BASE_URL}${item['url']}`,
|
url: `${BASE_URL}${item['url']}`,
|
||||||
title: `${icon}: ${getTitle(item)}${attribution ? ' via ' + attribution : ''}${item?.['tags']?.length > 0 ? ' ' + tagsToHashtags(item['tags']) : ''}`
|
title: `${icon}: ${getTitle(item)}${attribution ? ' via ' + attribution : ''}${item?.['tags']?.length > 0 ? ' ' + tagsToHashtags(item['tags']) : ''}`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// set url for link posts
|
||||||
if (item?.['link']) content['url'] = item?.['link']
|
if (item?.['link']) content['url'] = item?.['link']
|
||||||
|
|
||||||
|
// set url for posts - identified as slugs here
|
||||||
if (item?.['slug']) content['url'] = new URL(item['slug'], BASE_URL).toString()
|
if (item?.['slug']) content['url'] = new URL(item['slug'], BASE_URL).toString()
|
||||||
|
|
||||||
|
// link to artist concerts section if available - artistUrl is only present on concert objects here
|
||||||
|
if (item?.['artistUrl']) content['url'] = `${item['artistUrl']}#concerts`
|
||||||
if (item?.['description']) {
|
if (item?.['description']) {
|
||||||
content['description'] = `${item['description'].split(' ').slice(0, 25).join(' ')}...<br/><br/>`
|
content['description'] = `${item['description'].split(' ').slice(0, 25).join(' ')}...<br/><br/>`
|
||||||
|
} else if (item?.['notes']) {
|
||||||
|
content['notes'] = `${item['notes'].split(' ').slice(0, 25).join(' ')}...<br/><br/>`
|
||||||
} else {
|
} else {
|
||||||
content['description'] = ''
|
content['description'] = ''
|
||||||
}
|
}
|
||||||
|
@ -140,6 +150,7 @@ export const processContent = (collection) => {
|
||||||
addContent(links, '🔗', (item) => item['title'], (item) => item['date'])
|
addContent(links, '🔗', (item) => item['title'], (item) => item['date'])
|
||||||
addContent(books.all.filter((book) => book['status'] === 'finished'), '📖', (item) => `${item['title']}${item['rating'] ? ' (' + item['rating'] + ')' : ''}`, (item) => item['date'])
|
addContent(books.all.filter((book) => book['status'] === 'finished'), '📖', (item) => `${item['title']}${item['rating'] ? ' (' + item['rating'] + ')' : ''}`, (item) => item['date'])
|
||||||
addContent(movies['movies'], '🎥', (item) => `${item['title']}${item['rating'] ? ' (' + item['rating'] + ')' : ''}`, (item) => item['lastWatched'])
|
addContent(movies['movies'], '🎥', (item) => `${item['title']}${item['rating'] ? ' (' + item['rating'] + ')' : ''}`, (item) => item['lastWatched'])
|
||||||
|
addContent(concerts, '🎤', (item) => `${item['artistNameString'] ? item['artistNameString'] : item['artist']['name']} at ${item['venue']['name'].split(',')[0].trim()}`, (item) => item['date'])
|
||||||
|
|
||||||
addSiteMapContent(posts, (item) => item.title, (item) => item.date)
|
addSiteMapContent(posts, (item) => item.title, (item) => item.date)
|
||||||
addSiteMapContent(pages, (item) => item.title, (item) => item.date)
|
addSiteMapContent(pages, (item) => item.title, (item) => item.date)
|
||||||
|
|
4
package-lock.json
generated
4
package-lock.json
generated
|
@ -1,12 +1,12 @@
|
||||||
{
|
{
|
||||||
"name": "coryd.dev",
|
"name": "coryd.dev",
|
||||||
"version": "21.6.7",
|
"version": "21.7.0",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "coryd.dev",
|
"name": "coryd.dev",
|
||||||
"version": "21.6.7",
|
"version": "21.7.0",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@cdransf/api-text": "^1.4.0",
|
"@cdransf/api-text": "^1.4.0",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "coryd.dev",
|
"name": "coryd.dev",
|
||||||
"version": "21.6.7",
|
"version": "21.7.0",
|
||||||
"description": "The source for my personal site. Built using 11ty (and other tools).",
|
"description": "The source for my personal site. Built using 11ty (and other tools).",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
|
@ -62,7 +62,7 @@ const processConcerts = (concerts) => {
|
||||||
mbid: concert['artist_mbid'],
|
mbid: concert['artist_mbid'],
|
||||||
country: parseCountryField(concert['artist_country'])
|
country: parseCountryField(concert['artist_country'])
|
||||||
} : null,
|
} : null,
|
||||||
url: `/concerts/${concert['id']}`,
|
url: `/music/concerts?id=${concert['id']}`,
|
||||||
artistUrl: concert['artist'] ? `/music/artists/${sanitizeMediaString(concert['artist_name'])}-${sanitizeMediaString(parseCountryField(concert['artist_country']))}` : null
|
artistUrl: concert['artist'] ? `/music/artists/${sanitizeMediaString(concert['artist_name'])}-${sanitizeMediaString(parseCountryField(concert['artist_country']))}` : null
|
||||||
})).sort((a, b) => new Date(b['date']) - new Date(a['date']))
|
})).sort((a, b) => new Date(b['date']) - new Date(a['date']))
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,7 +64,7 @@ schema: artist
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
{%- if artist.concerts -%}
|
{%- if artist.concerts -%}
|
||||||
<hr />
|
<hr />
|
||||||
<p class="concerts flex-centered">
|
<p id="concerts" class="concerts flex-centered">
|
||||||
{% tablericon "device-speaker" "concert" %}
|
{% tablericon "device-speaker" "concert" %}
|
||||||
I've seen this artist live!
|
I've seen this artist live!
|
||||||
</p>
|
</p>
|
||||||
|
|
Reference in a new issue