mirror of
https://forge.chapril.org/tykayn/orgmode-to-gemini-blog
synced 2025-06-20 09:04:42 +02:00
up
This commit is contained in:
parent
672f61f2bb
commit
6d77de4696
15 changed files with 203 additions and 506 deletions
|
@ -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
|
||||
)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue