keep only 1 lang in multi-lang titles

This commit is contained in:
Guilhem Fauré 2023-04-24 16:14:20 +02:00
parent a7ca45f731
commit 69d713dca5

View File

@ -1,12 +1,26 @@
import re
import yaml import yaml
from slugify import slugify from slugify import slugify
# Modules
from SpipDatabase import *
def clean(string):
cleaned = string
# Keep only the first lang of multilingual titles
cleaned = re.sub(
r"<multi>\s*\[[a-z]{2}\]\s*([^<\[]*)\s*[^<]*\s*<\/multi>", r"\1", cleaned
)
# cleaned = re.sub(r"<[^\>]*>", r"", cleaned)
return cleaned
class metadata: class metadata:
def __init__(self, article): def __init__(self, article):
self.id = article.id_article self.id = article.id_article
# self.surtitle = article.surtitre # Probably unused # self.surtitle = article.surtitre # Probably unused
self.title = article.titre self.title = clean(article.titre)
self.subtitle = article.soustitre # Probably unused self.subtitle = article.soustitre # Probably unused
# self.section = article.id_rubrique # TODO join # self.section = article.id_rubrique # TODO join
self.description = article.descriptif self.description = article.descriptif
@ -35,6 +49,9 @@ class metadata:
def get_slug(self): def get_slug(self):
return slugify(f"{self.id}-{self.title}") return slugify(f"{self.id}-{self.title}")
def get_authors(self):
return SpipAuteursLiens.select().where(SpipAuteursLiens.id_objet == self.id)
def get_frontmatter(self): def get_frontmatter(self):
return "---\n{}---".format( return "---\n{}---".format(
yaml.dump( yaml.dump(
@ -47,6 +64,7 @@ class metadata:
"lastmod": self.update, "lastmod": self.update,
"draft": self.draft, "draft": self.draft,
"description": self.description, "description": self.description,
"authors": [author.id_auteur for author in self.get_authors()],
}, },
allow_unicode=True, allow_unicode=True,
) )