generated from vbharadwaj-bk/al-folio-python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
pelicanconf.py
160 lines (123 loc) · 4 KB
/
pelicanconf.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
import yaml
import sys, os
from datetime import datetime
sys.path.append('.')
from py_code.cache_buster import *
from py_code.render_main_scss import *
from py_code.slugify import *
from py_code.parse_bib import *
from py_code.toc_md_reader import TOCMarkdownReader
from py_code.filter_projects import filter_projects
from py_code.template_block import *
from py_code import al_folio_extension
from py_code.urls_dev import relative_url, absolute_url
SITE = None
with open("content/config.yml", "rb") as stream:
SITE = yaml.safe_load(stream)
PLUGINS = ['pelican.plugins.webassets',
'pelican.plugins.sitemap',
al_folio_extension]
name_fields = ["first_name", "middle_name", "last_name"]
AUTHOR = ' '.join([SITE[field] for field in name_fields if field in SITE and SITE[field] is not None])
SITENAME = SITE["title"]
if SITENAME is None:
SITENAME = AUTHOR
SITEURL = ''
THEME = 'al_folio_theme'
PATH = 'content'
TIMEZONE = 'America/Ensenada'
DEFAULT_LANG = 'en'
ARTICLE_URL = 'posts/{date:%Y}/{slug}/'
ARTICLE_SAVE_AS = 'posts/{date:%Y}/{slug}/index.html'
FORMATTED_FIELDS = []
if SITE["blog_enabled"]:
INDEX_SAVE_AS = '/posts/index.html'
ARTICLE_PATHS=['posts']
CATEGORY_URL = 'posts/category/{slug}/'
CATEGORY_SAVE_AS = 'posts/category/{slug}/index.html'
TAG_URL = 'posts/tag/{slug}/'
TAG_SAVE_AS = 'posts/tag/{slug}/index.html'
YEAR_ARCHIVE_SAVE_AS = 'posts/{date:%Y}/index.html'
PAGINATED_TEMPLATES = {'index': None, 'tag': 10, 'category': 10, 'author': 10, 'period_archives': 10}
CATEGORIES_SAVE_AS = 'posts/category/index.html'
TAGS_SAVE_AS = 'posts/tag/index.html'
else:
INDEX_SAVE_AS = ''
ARTICLE_PATHS=[]
CATEGORY_URL = ''
CATEGORY_SAVE_AS = ''
TAG_URL = ''
TAG_SAVE_AS = ''
PAGINATED_TEMPLATES = {}
FORMATTED_FIELDS = []
CATEGORIES_SAVE_AS = ''
TAGS_SAVE_AS = ''
# Suppress generation of these pages.
AUTHOR_URL = AUTHOR_SAVE_AS = ''
AUTHORS_SAVE_AS = ''
ARCHIVES_SAVE_AS = ''
PAGE_PATHS = ['pages', 'projects']
PATH_METADATA = '(?P<path_no_ext>.*)\..*'
PAGE_URL = '{path_no_ext}/'
PAGE_SAVE_AS = '{path_no_ext}/index.html'
STATIC_PATHS = ['images', 'pdf', 'json']
# Feed generation is usually not desired when developing
FEED_ALL_ATOM = None
CATEGORY_FEED_ATOM = None
TRANSLATION_FEED_ATOM = None
AUTHOR_FEED_ATOM = None
AUTHOR_FEED_RSS = None
DEFAULT_PAGINATION = 5
PAGINATION_PATTERNS = (
(1, '{base_name}', '{base_name}/index.html'),
(2, '{base_name}/page/{number}/', '{base_name}/page/{number}/index.html'),
)
# Should extend to getting all data from the folder
SITE["data"] = {}
for data_name in ["cv", "venues", "coauthors", "talks"]:
with open(f"content/data/{data_name}.yml", "rb") as stream:
SITE["data"][data_name] = yaml.safe_load(stream)
SITE["time"] = datetime.now()
parse_bibliography("content/pages/publications.bib", 'publications', SITE)
render_main_scss(SITE)
JINJA_FILTERS = {
'relative_url': relative_url,
'absolute_url': absolute_url,
'bust_file_cache': bust_file_cache,
'slugify': slugify,
'filter_projects': filter_projects
}
MARKDOWN = {
'extensions': ['codehilite', 'extra', 'meta', 'admonition', 'toc',
TemplateBlockExtension(filters=JINJA_FILTERS)],
'extension_configs': {
'codehilite': {'css_class': 'highlight'},
'extra': {'attr_list': {}},
'meta': {},
'admonition': {},
'toc': {}
},
'output_format': 'html5',
}
SITEMAP = {
"format": "xml",
"priorities": {
"pages": 0.7,
"indexes": 0.5,
"articles": 0.3
},
"changefreqs": {
"indexes": "daily",
"pages": "monthly",
"articles": "monthly",
},
"exclude": [
"^/noindex/", # starts with "/noindex/"
"posts/\d+/$",
"posts/category/",
"posts/page/",
"posts/tag/",
"404.html$",
]
}
READERS = {'md': TOCMarkdownReader}