summaryrefslogtreecommitdiff
path: root/megapixels/app/site/loader.py
diff options
context:
space:
mode:
Diffstat (limited to 'megapixels/app/site/loader.py')
-rw-r--r--megapixels/app/site/loader.py38
1 files changed, 38 insertions, 0 deletions
diff --git a/megapixels/app/site/loader.py b/megapixels/app/site/loader.py
index 779f68ba..701c78b2 100644
--- a/megapixels/app/site/loader.py
+++ b/megapixels/app/site/loader.py
@@ -5,6 +5,9 @@ import glob
import app.settings.app_cfg as cfg
from app.utils.file_utils import load_json
+import app.utils.sheet_utils as sheet
+
+sidebar = sheet.fetch_google_lookup("sidebar", item_key="key")
def read_metadata(fn):
"""
@@ -20,6 +23,12 @@ def read_metadata(fn):
sections = data.split("\n\n")
return parse_metadata(fn, sections)
+def domainFromUrl(url):
+ domain = url.split('/')[2].split('.')
+ if len(domain) > 2 and len(domain[-2]) == 2:
+ return ".".join(domain[-3:])
+ return ".".join(domain[-2:])
+
default_metadata = {
'status': 'published',
@@ -33,6 +42,18 @@ default_metadata = {
'tagline': '',
}
+sidebar_order = [
+ { 'key': 'published', 'title': 'Published' },
+ { 'key': 'images', 'title': 'Images' },
+ { 'key': 'videos', 'title': 'Videos' },
+ { 'key': 'identities', 'title': 'Identities' },
+ { 'key': 'purpose', 'title': 'Purpose' },
+ { 'key': 'created_by', 'title': 'Created by' },
+ { 'key': 'funded_by_short', 'title': 'Funded by' },
+ { 'key': 'size_gb', 'title': 'Download Size' },
+ { 'key': 'website', 'title': 'Website' },
+]
+
def parse_metadata(fn, sections):
"""
parse the metadata headers in a markdown file
@@ -87,8 +108,25 @@ def parse_metadata(fn, sections):
print("Bad metadata? {}".format(dataset_path))
elif 'datasets' in fn:
print("/!\\ {} does not exist!".format(dataset_path))
+
+ if metadata['slug'] in sidebar:
+ sidebar_row = sidebar[metadata['slug']]
+ if sidebar_row:
+ metadata['sidebar'] = []
+ for item in sidebar_order:
+ key = item['key']
+ value = sidebar_row[key]
+ if value:
+ value = value.replace(' - ', ' – ')
+ if key == 'size_gb':
+ value += ' GB'
+ if key == 'website':
+ value = "<a href='" + value + "' target='_blank' rel='nofollow noopener'>" + domainFromUrl(value) + "</a>"
+ metadata['sidebar'].append({ 'value': value, 'title': item['title'], })
+
if 'meta' not in metadata or not metadata['meta']: # dude
metadata['meta'] = {}
+ metadata['sidebar'] = []
return metadata, valid_sections