This commit is contained in:
Tykayn 2025-02-23 15:50:56 +01:00 committed by tykayn
parent 672f61f2bb
commit 6d77de4696
15 changed files with 203 additions and 506 deletions

View file

@ -136,6 +136,7 @@ if generate_linkings_json :
files_dict[f"{annee}/{slug}"] = {
'path': file_path,
'basename': basename,
'roam_id': find_org_roam_id(content),
'slug': f"{slug}/",
'slug_with_year': f"{annee}/{slug}",
'date': boom[0],
@ -156,17 +157,36 @@ if generate_linkings_json :
sorted_basenames = sorted(files_dict.keys(), reverse=True)
print(len(sorted_basenames), 'articles trouvés')
# Ajouter les noms des articles suivant et précédent
template_content = get_blog_template_conf(args.blog)
# Dictionnaire des identifiants roam qui mène à un slug d'article pour réécrire les références
articles_roam_id_to_slugs = {info['roam_id']: slug for slug, info in files_dict.items()}
# Parcourir les articles de files_dict et ajouter une clé rewritten_roam_links_html là où un lien vers un identifiant roam est trouvé dans le html_content
for slug, info in files_dict.items():
html_content = info['html_content']
rewritten_html_content = html_content
for roam_id, slug in articles_roam_id_to_slugs.items():
if roam_id in rewritten_html_content:
print(f'{roam_id} -> {slug}')
rewritten_html_content = rewritten_html_content.replace(f'href="#{roam_id}"', f'href="{template_content["NDD"]}/{slug}"')
info['rewritten_roam_links_html'] = rewritten_html_content
# Ajouter les infos des articles suivant et précédent dans la liste des articles
for i in range(len(sorted_basenames)):
basename = sorted_basenames[i]
# print('basename', basename)
if i > 0:
files_dict[basename]['previous'] = sorted_basenames[i - 1]
if i < len(sorted_basenames) - 1:
# print('suivant',files_dict[sorted_basenames[i + 1]])
files_dict[basename]['next'] = sorted_basenames[i + 1]
with open(destination_json+'/articles_info.json', 'w', encoding='utf-8') as json_file:
os.makedirs(destination_json, exist_ok=True)
json_file=destination_json+'/articles_info.json'
with open( json_file, 'w', encoding='utf-8') as json_file:
files_dict_serialized = json.dumps(files_dict, ensure_ascii=False, indent=4)
json_file.write(files_dict_serialized)
@ -204,9 +224,12 @@ def generate_blog_index(json_file, template_file, output_file):
template = env.get_template(template_file)
articles_others = sorted(articles_info.values(), key=lambda x: x['date'], reverse=True)[10:]
template_content = get_blog_template_conf(args.blog)
# Rendre le template avec les données
output_index_html = template.render(
template_content=configs_sites[args.blog],
template_content=template_content,
articles=sorted_articles[:global_config['posts_per_page']],
articles_others=articles_others
)
@ -214,26 +237,22 @@ def generate_blog_index(json_file, template_file, output_file):
gmi_list_articles = ''
for basename, article in files_dict.items():
# gmi_list_articles += f"\n=> article.gmi"
gmi_list_articles += f"\n=> {article['slug']}.gmi "
# {article.date_formatee} {article.title}"
print('global_config[args.blog]', configs_sites[args.blog])
output_index_gmi = f"""
# {configs_sites[args.blog]['BLOG_TITLE']}
# {template_content['BLOG_TITLE']}
===============================================
{configs_sites[args.blog]['BANNIERE_ENTETE']}
Par {configs_sites[args.blog]['AUTHOR']}
{template_content['BANNIERE_ENTETE']}
Par {template_content['AUTHOR']}
Dernière mise à jour: {datetime.now()}
***********************************************
{configs_sites[args.blog]['DESCRIPTION']}
{template_content['DESCRIPTION']}
**************************************************************
{configs_sites[args.blog]['SITE_ICON']}
{template_content['SITE_ICON']}
@ -282,7 +301,7 @@ def generate_article_pages(json_file, template_file, output_dir):
# Générer les pages pour chaque article
for article in articles_info.values():
output_html = template.render(
template_content=configs_sites[args.blog],
template_content=get_blog_template_conf(args.blog),
article=article,
all_articles=articles_info
)