mirror of
https://github.com/Einundzwanzig-Podcast/einundzwanzig.space.git
synced 2025-12-13 16:26:50 +00:00
Update team and description parsing
This commit is contained in:
@@ -367,5 +367,15 @@
|
|||||||
"customKey": "696969",
|
"customKey": "696969",
|
||||||
"customValue": "xVJWaSLb2QkQrhwfc3VG"
|
"customValue": "xVJWaSLb2QkQrhwfc3VG"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"spok": {
|
||||||
|
"name": "spok",
|
||||||
|
"url": "https://fairtalk.tv",
|
||||||
|
"image": "/img/team/spok.png",
|
||||||
|
"v4v": {
|
||||||
|
"address": "030a58b8653d32b99200a2334cfe913e51dc7d155aa0116c176657a4f1722677a3",
|
||||||
|
"customKey": "696969",
|
||||||
|
"customValue": "BhSmEGwARJfwZFeZW1Ma"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -68,6 +68,8 @@ const teamWithAliases = team => {
|
|||||||
return withAliases
|
return withAliases
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const participantToId = p => p.replace(/\(.*?\)/, '').trim().toLowerCase()
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
markdown: mdTransformer.render,
|
markdown: mdTransformer.render,
|
||||||
replacements,
|
replacements,
|
||||||
@@ -75,5 +77,6 @@ module.exports = {
|
|||||||
stripHTML,
|
stripHTML,
|
||||||
truncate,
|
truncate,
|
||||||
teamWithAliases,
|
teamWithAliases,
|
||||||
|
participantToId,
|
||||||
toMeetupMapInfo
|
toMeetupMapInfo
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -96,7 +96,7 @@ mixin spende(d, trunc = false)
|
|||||||
mixin participants(ps, link)
|
mixin participants(ps, link)
|
||||||
.participants
|
.participants
|
||||||
for name in ps
|
for name in ps
|
||||||
- const id = name.toLowerCase()
|
- const id = participantToId(name)
|
||||||
- const member = team[id]
|
- const member = team[id]
|
||||||
if member
|
if member
|
||||||
if link
|
if link
|
||||||
|
|||||||
BIN
static/img/team/spok.png
Normal file
BIN
static/img/team/spok.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 47 KiB |
@@ -1,6 +1,6 @@
|
|||||||
const { writeFileSync } = require('fs')
|
const { writeFileSync } = require('fs')
|
||||||
const { join, resolve } = require('path')
|
const { join, resolve } = require('path')
|
||||||
const { replacements, slugify, stripHTML, teamWithAliases } = require('../helpers')
|
const { replacements, slugify, stripHTML, teamWithAliases, participantToId } = require('../helpers')
|
||||||
const { masterFeedUrl, publicFeedUrl } = require('../content/meta.json')
|
const { masterFeedUrl, publicFeedUrl } = require('../content/meta.json')
|
||||||
const teamRaw = require('../content/team.json')
|
const teamRaw = require('../content/team.json')
|
||||||
const request = require('sync-request')
|
const request = require('sync-request')
|
||||||
@@ -67,13 +67,14 @@ const parseEpisode = e => {
|
|||||||
: `/img/cover/${category}.png`
|
: `/img/cover/${category}.png`
|
||||||
const duration = e['itunes:duration']
|
const duration = e['itunes:duration']
|
||||||
const enclosure = e.enclosure.__attr
|
const enclosure = e.enclosure.__attr
|
||||||
const [, participantsString] =
|
const [, participantsString, additionalString] =
|
||||||
firstLine.match(/[-–—]\s?(?:(?:(?:von\sund\s)?mit\s)|(?:gelesen\svon\s))([^.]*)/i) || []
|
firstLine.match(/[-–—]\s?(?:(?:(?:von\sund\s)?mit\s)|(?:gelesen\svon\s))([^.]*)/i) || []
|
||||||
const participants = participantsString
|
const participants = participantsString
|
||||||
? participantsString
|
? participantsString
|
||||||
.replace(/(\s*,\s*|\s*und\s*|\s*&\s*)/gi, '%')
|
.replace(/(\s*,\s*|\s*und\s*|\s*sowie\s*|\s*&\s*)/gi, '%')
|
||||||
.trim()
|
.trim()
|
||||||
.split('%')
|
.split('%')
|
||||||
|
.filter(p => !!p)
|
||||||
.map(p => p.trim())
|
.map(p => p.trim())
|
||||||
: []
|
: []
|
||||||
return {
|
return {
|
||||||
@@ -149,7 +150,6 @@ const parseEpisode = e => {
|
|||||||
...item,
|
...item,
|
||||||
link, // replace Anchor link
|
link, // replace Anchor link
|
||||||
description: { __cdata: description },
|
description: { __cdata: description },
|
||||||
//'itunes:summary': description // please the validator, Anchor's itunes:summary contains HTML
|
|
||||||
}
|
}
|
||||||
// itunes:summary seems to be gone: https://help.apple.com/itc/podcasts_connect/#/itcb54353390
|
// itunes:summary seems to be gone: https://help.apple.com/itc/podcasts_connect/#/itcb54353390
|
||||||
delete updated['itunes:summary']
|
delete updated['itunes:summary']
|
||||||
@@ -164,7 +164,7 @@ const parseEpisode = e => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const value = episode.participants.reduce((result, name) => {
|
const value = episode.participants.reduce((result, name) => {
|
||||||
const id = name.toLowerCase()
|
const id = participantToId(name)
|
||||||
const v4v = team[id] && team[id].v4v
|
const v4v = team[id] && team[id].v4v
|
||||||
if (v4v) {
|
if (v4v) {
|
||||||
result.push({ name, ...v4v })
|
result.push({ name, ...v4v })
|
||||||
@@ -193,7 +193,7 @@ const parseEpisode = e => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const people = episode.participants.reduce((result, name) => {
|
const people = episode.participants.reduce((result, name) => {
|
||||||
const id = name.toLowerCase()
|
const id = participantToId(name)
|
||||||
const person = team[id]
|
const person = team[id]
|
||||||
if (person) {
|
if (person) {
|
||||||
result.push(person)
|
result.push(person)
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
const pug = require('pug')
|
const pug = require('pug')
|
||||||
const { mkdirSync, writeFileSync } = require('fs')
|
const { mkdirSync, writeFileSync } = require('fs')
|
||||||
const { dirname, resolve } = require('path')
|
const { dirname, resolve } = require('path')
|
||||||
const { slugify, teamWithAliases } = require('../helpers')
|
const { slugify, teamWithAliases, participantToId } = require('../helpers')
|
||||||
const config = require('../pug.config')
|
const config = require('../pug.config')
|
||||||
const site = require('../generated/site-data.json')
|
const site = require('../generated/site-data.json')
|
||||||
const episodes = require('../generated/episodes.json')
|
const episodes = require('../generated/episodes.json')
|
||||||
@@ -61,6 +61,6 @@ Object.keys(categories).forEach(category => renderPage('category', `podcast/${sl
|
|||||||
Object.keys(teamRaw).forEach(id => {
|
Object.keys(teamRaw).forEach(id => {
|
||||||
const member = teamRaw[id]
|
const member = teamRaw[id]
|
||||||
const aliases = (member.aliases || []).map(m => m.toLowerCase()).concat(member.name.toLowerCase())
|
const aliases = (member.aliases || []).map(m => m.toLowerCase()).concat(member.name.toLowerCase())
|
||||||
const eps = episodes.filter(e => e.participants.find(p => [id, ...aliases].includes(p.toLowerCase())))
|
const eps = episodes.filter(e => e.participants.find(p => [id, ...aliases].includes(participantToId(p))))
|
||||||
renderPage('member', `team/${slugify(id)}`, { navCurrent: 'podcast', member, episodes: eps, team })
|
renderPage('member', `team/${slugify(id)}`, { navCurrent: 'podcast', member, episodes: eps, team })
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user