fixed tags, use translated description instead of id
This commit is contained in:
parent
00f3ed6cf9
commit
3cc90f6dc2
@ -106,6 +106,8 @@ prepend_h1: false # Add title of articles as Markdown h1, looks better on certai
|
|||||||
# dest: title
|
# dest: title
|
||||||
# repr: "{} _" # (this is the default repr)
|
# repr: "{} _" # (this is the default repr)
|
||||||
move_fields: []
|
move_fields: []
|
||||||
|
# Some Spip Mots (tags) types to not export, typically specific to Spip functions
|
||||||
|
ignore_tags_types: ["Gestion du site", "Gestion des articles", "Mise en page"]
|
||||||
|
|
||||||
# Ignored data settings
|
# Ignored data settings
|
||||||
export_drafts: true # Should we export drafts
|
export_drafts: true # Should we export drafts
|
||||||
|
@ -72,6 +72,7 @@ class Configuration:
|
|||||||
export_drafts: bool = True # Should we export drafts as draft:true articles
|
export_drafts: bool = True # Should we export drafts as draft:true articles
|
||||||
export_empty: bool = True # Should we export empty articles
|
export_empty: bool = True # Should we export empty articles
|
||||||
remove_html: bool = True # Should spip2md remove every HTML tags
|
remove_html: bool = True # Should spip2md remove every HTML tags
|
||||||
|
ignore_tags_types = ("Gestion du site", "Gestion des articles", "Mise en page")
|
||||||
metadata_markup: bool = False # Should spip2md keep the markup in metadata fields
|
metadata_markup: bool = False # Should spip2md keep the markup in metadata fields
|
||||||
title_max_length: int = 40 # Maximum length of a single title for directory names
|
title_max_length: int = 40 # Maximum length of a single title for directory names
|
||||||
unknown_char_replacement: str = "??" # Replaces unknown characters
|
unknown_char_replacement: str = "??" # Replaces unknown characters
|
||||||
|
@ -354,6 +354,7 @@ class SpipRedactional(SpipWritable):
|
|||||||
langue_choisie: str
|
langue_choisie: str
|
||||||
# Converted
|
# Converted
|
||||||
_text: str
|
_text: str
|
||||||
|
_tags: list[str] = []
|
||||||
_url_title: str # Title in metadata of articles
|
_url_title: str # Title in metadata of articles
|
||||||
_parenturl: str # URL relative to lang to direct parent
|
_parenturl: str # URL relative to lang to direct parent
|
||||||
_static_img_path: Optional[str] = None # Path to the static img of this article
|
_static_img_path: Optional[str] = None # Path to the static img of this article
|
||||||
@ -378,6 +379,9 @@ class SpipRedactional(SpipWritable):
|
|||||||
self.lang = forced_lang # So write-all will not be cancelled
|
self.lang = forced_lang # So write-all will not be cancelled
|
||||||
# Replace the mutli blocks with the text in the proper lang
|
# Replace the mutli blocks with the text in the proper lang
|
||||||
text = text.replace(block.group(), lang.group(1))
|
text = text.replace(block.group(), lang.group(1))
|
||||||
|
else:
|
||||||
|
# Replace the mutli blocks with the text inside
|
||||||
|
text = text.replace(block.group(), block.group(1))
|
||||||
if lang is None:
|
if lang is None:
|
||||||
LOG.debug(f"{forced_lang} not found in `{self._url_title}`")
|
LOG.debug(f"{forced_lang} not found in `{self._url_title}`")
|
||||||
return text
|
return text
|
||||||
@ -569,6 +573,18 @@ class SpipRedactional(SpipWritable):
|
|||||||
LOG.debug(f"Apply conversions to {self.lang} `{self._url_title}` extra")
|
LOG.debug(f"Apply conversions to {self.lang} `{self._url_title}` extra")
|
||||||
self._extra = self.convert_field(self._extra, CFG.metadata_markup)
|
self._extra = self.convert_field(self._extra, CFG.metadata_markup)
|
||||||
|
|
||||||
|
def convert_tags(self, forcedlang: str) -> None:
|
||||||
|
def out_tag(tag: SpipMots) -> str:
|
||||||
|
LOG.debug(f"Translate tag of `{self._url_title}`: {tag.descriptif}")
|
||||||
|
return str(tag.descriptif)
|
||||||
|
|
||||||
|
self._tags = [
|
||||||
|
self.translate_multi(forcedlang, out_tag(tag), False)
|
||||||
|
for tag in self.tags()
|
||||||
|
if tag.type not in CFG.ignore_tags_types
|
||||||
|
]
|
||||||
|
LOG.debug(f"After translation, tags of `{self._url_title}` are {self._tags}")
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super().__init__(*args, **kwargs)
|
super().__init__(*args, **kwargs)
|
||||||
# Initialize converted fields, beginning with underscore
|
# Initialize converted fields, beginning with underscore
|
||||||
@ -632,6 +648,28 @@ class SpipRedactional(SpipWritable):
|
|||||||
body += "\n\n# EXTRA\n\n" + self._extra
|
body += "\n\n# EXTRA\n\n" + self._extra
|
||||||
return body
|
return body
|
||||||
|
|
||||||
|
def authors(self) -> tuple[SpipAuteurs, ...]:
|
||||||
|
LOG.debug(f"Initialize authors of `{self._url_title}`")
|
||||||
|
return (
|
||||||
|
SpipAuteurs.select()
|
||||||
|
.join(
|
||||||
|
SpipAuteursLiens,
|
||||||
|
on=(SpipAuteurs.id_auteur == SpipAuteursLiens.id_auteur),
|
||||||
|
)
|
||||||
|
.where(SpipAuteursLiens.id_objet == self._id)
|
||||||
|
)
|
||||||
|
|
||||||
|
def tags(self) -> tuple[SpipMots, ...]:
|
||||||
|
LOG.debug(f"Initialize tags of `{self._url_title}`")
|
||||||
|
return (
|
||||||
|
SpipMots.select()
|
||||||
|
.join(
|
||||||
|
SpipMotsLiens,
|
||||||
|
on=(SpipMots.id_mot == SpipMotsLiens.id_mot),
|
||||||
|
)
|
||||||
|
.where(SpipMotsLiens.id_objet == self._id)
|
||||||
|
)
|
||||||
|
|
||||||
# Write all the documents of this object
|
# Write all the documents of this object
|
||||||
def write_children(
|
def write_children(
|
||||||
self,
|
self,
|
||||||
@ -729,6 +767,7 @@ class SpipRedactional(SpipWritable):
|
|||||||
self.convert_title(forced_lang)
|
self.convert_title(forced_lang)
|
||||||
self.convert_text(forced_lang)
|
self.convert_text(forced_lang)
|
||||||
self.convert_extra()
|
self.convert_extra()
|
||||||
|
self.convert_tags(forced_lang)
|
||||||
if self.lang != forced_lang:
|
if self.lang != forced_lang:
|
||||||
raise LangNotFoundError(
|
raise LangNotFoundError(
|
||||||
f"`{self._url_title}` lang is {self.lang} instead of the wanted"
|
f"`{self._url_title}` lang is {self.lang} instead of the wanted"
|
||||||
@ -764,7 +803,7 @@ class Article(SpipRedactional, SpipArticles):
|
|||||||
"subtitle": self.soustitre,
|
"subtitle": self.soustitre,
|
||||||
"date": self.date_redac,
|
"date": self.date_redac,
|
||||||
"authors": [author.nom for author in self.authors()],
|
"authors": [author.nom for author in self.authors()],
|
||||||
"tags": [tag.titre for tag in self.tags()],
|
"tags": self._tags,
|
||||||
}
|
}
|
||||||
# Add debugging meta if needed
|
# Add debugging meta if needed
|
||||||
if CFG.debug_meta:
|
if CFG.debug_meta:
|
||||||
@ -787,28 +826,6 @@ class Article(SpipRedactional, SpipArticles):
|
|||||||
body += "\n\n# MICROBLOGGING\n\n" + self._microblog
|
body += "\n\n# MICROBLOGGING\n\n" + self._microblog
|
||||||
return body
|
return body
|
||||||
|
|
||||||
def authors(self) -> tuple[SpipAuteurs, ...]:
|
|
||||||
LOG.debug(f"Initialize authors of `{self._url_title}`")
|
|
||||||
return (
|
|
||||||
SpipAuteurs.select()
|
|
||||||
.join(
|
|
||||||
SpipAuteursLiens,
|
|
||||||
on=(SpipAuteurs.id_auteur == SpipAuteursLiens.id_auteur),
|
|
||||||
)
|
|
||||||
.where(SpipAuteursLiens.id_objet == self._id)
|
|
||||||
)
|
|
||||||
|
|
||||||
def tags(self) -> tuple[SpipMots, ...]:
|
|
||||||
LOG.debug(f"Initialize tags of `{self._url_title}`")
|
|
||||||
return (
|
|
||||||
SpipMots.select()
|
|
||||||
.join(
|
|
||||||
SpipMotsLiens,
|
|
||||||
on=(SpipMots.id_mot == SpipMotsLiens.id_mot),
|
|
||||||
)
|
|
||||||
.where(SpipMotsLiens.id_objet == self._id)
|
|
||||||
)
|
|
||||||
|
|
||||||
# Perform all the write steps of this object
|
# Perform all the write steps of this object
|
||||||
def write_all(
|
def write_all(
|
||||||
self,
|
self,
|
||||||
|
Loading…
Reference in New Issue
Block a user