Skip to content
Snippets Groups Projects
Verified Commit 9d1e72e2 authored by Jake's avatar Jake :speech_balloon:
Browse files

added improved link parser and renderer

parent 3327a65d
No related branches found
No related tags found
No related merge requests found
<!DOCTYPE html>
{%- import 'macros/getters.html' as get with context -%}
{%- import 'macros/link.html' as link with context -%}
{%- import 'macros/cards.html' as cards with context -%}
{%- import 'macros/renderers.html' as render with context -%}
{%- import 'macros/content_renderer.html' as content_renderer with context -%}
......
......@@ -9,13 +9,13 @@
</ul>
{%- endmacro -%}
{%- macro card(title, url, catcolor, is_url_external = True) -%}
<li style="--category-color: {{ catcolor }}"><a href="{% if not is_url_external %}{{ siteurl }}/{% endif %}{{ url }}">{{ title|e }}</a></li>
{%- macro card(title, url, catcolor, lang) -%}
<li style="--category-color: {{ catcolor }}">{{ link.render(url, title, lang) }}</li>
{%- endmacro -%}
{%- macro card_from_page(page, lang) -%}
{%- call(cattitle, catcolor, caturl, catpage, catpages) get.tag_by_name(page.category, l) -%}
{{ card(title=page.title, url=page.url, catcolor=catcolor, is_url_external = False) }}
{%- call(cattitle, catcolor, caturl, catpage, catpages) get.tag_by_name(page.category, lang) -%}
{{ card(title=page.title, url=['slug',page.slug,page.lang]|join(':'), catcolor=catcolor, lang=lang) }}
{%- endcall -%}
{%- endmacro -%}
......@@ -25,7 +25,7 @@
{%- endif -%}
{%- for page in pages -%}
{%- if max == None or loop.index < max -%}
{{ cards.card_from_page(page) }}
{{ cards.card_from_page(page, lang) }}
{%- endif -%}
{%- endfor -%}
{%- if standalone -%}
......
......@@ -22,7 +22,7 @@
{%- set attr_extra = attr['extra']|d({}) -%}
{%- if id %} id="{{ id }}"{%- endif -%}
{%- if classes|length > 0 %} class="{{ classes|join(' ') }}"{%- endif -%}
{%- if classes|length %} class="{{ classes|join(' ') }}"{%- endif -%}
{%- for key, value in attr_extra.items() -%}
{%- if key not in extra -%}
{{ render_attr_extra(key, value, lang) }}
......@@ -45,16 +45,6 @@
{%- endif -%}
{%- endmacro -%}
{%- macro render_link(url, content, lang, attr = None, title = None) -%}
<a {{ render_attr(attr, lang, extra={"href": url, "title": {"value":title, "escape": true}}) }}>
{%- if content is string -%}
{{ content|e }}
{%- else -%}
{{ render_blocks_or_inlines(content, lang) }}
{%- endif -%}
</a>
{%- endmacro -%}
{%- macro render_image(url, alt, lang, attr = None, title = None) -%}
<img {{ render_attr(attr, lang, extra={"src": url, "title": {"value":title, "escape": true}}) }} alt="
{%- if alt is string -%}
......@@ -322,7 +312,7 @@
{%- set content = inline['content'] -%}
{%- set url = inline['url'] -%}
{%- set title = inline['title'] -%}
{{ render_link(url, content, lang, attr, title) }}
{{ link.render(url, content, lang, attr, title) }}
{%- endmacro -%}
{%- macro render_inline_image(inline, lang) -%}
......
{%- import 'macros/content_renderer.html' as content_renderer with context -%}
{%- import 'macros/getters.html' as get with context -%}
{%- macro render(url, content, lang, attr = None, title = None) -%}
{%- call(parsedurl, anchor, reflang, is_external, reftype, refid, refpage, tagtitle, tagcolor) parse_url(url, lang) -%}
{%- set ns = namespace(extraclass=None, fullurl=parsedurl) -%}
{%- if anchor -%}
{%- set ns.fullurl = [parsedurl, anchor]|join('#') -%}
{%- endif -%}
{%- if is_external -%}
{%- set ns.extraclass = "external" -%}
{%- else -%}
{%- set ns.extraclass = "internal" -%}
{%- endif -%}
<a {{ content_renderer.render_attr(attr, lang, extra_classes=[ns.extraclass], extra={"href": ns.fullurl, "title": {"value":title, "escape": true}}) }}>
{%- if content is string -%}
{%- if content|length -%}
{{ content|e }}
{%- else -%}
{%- if tagtitle -%}
{{ tagtitle|e }}
{%- else -%}
{{ refpage.title|e }}
{%- endif -%}
{%- endif -%}
{%- else -%}
{{ content_renderer.render_blocks_or_inlines(content, lang) }}
{%- endif -%}
</a>
{%- endcall -%}
{%- endmacro -%}
{#- returns: (url, anchor, reflang, is_external, reftype, refid, refpage, tagtitle, tagcolor)-#}
{%- macro parse_url(rawurl, lang) -%}
{%- set urlsplit = rawurl.split('#') -%}
{%- set anchor = urlsplit[1]|d(None) -%}
{%- set urlwoa = urlsplit[0] -%} {#- url without anchor -#}
{%- set components = urlwoa.split(':') -%}
{%- if components|length == 1 -%}
{%- set url = ['https://', urlwoa]|join('') -%}
{{- caller(url, anchor, lang, True, None, None, None, None, None) -}}
{%- else -%}
{%- set reftype = components[0] -%}
{%- set refid = components[1] -%}
{%- set reflang = components[2]|d(lang) -%}
{%- set ns = namespace(url=None, page=None, tagtitle=None, tagcolor=None, tagpage=None) -%}
{%- if reftype == "slug" -%}
{%- call(page) get.page_by_slug(refid, reflang) -%}
{%- set ns.url = [siteurl, page.url]|join('/') -%}
{%- set ns.page = page -%}
{%- endcall -%}
{{- caller(ns.url, anchor, reflang, False, reftype, refid, ns.page, None, None) -}}
{%- elif reftype == "tag" -%}
{%- call(tagtitle, tagcolor, tagurl, tagpage, tagpages) get.tag_by_name(refid, reflang) -%}
{%- set ns.url = [siteurl, tagurl]|join('/') -%}
{%- set ns.tagtitle = tagtitle -%}
{%- set ns.tagcolor = tagcolor -%}
{%- set ns.tagpage = tagpage -%}
{%- endcall -%}
{{- caller(ns.url, anchor, reflang, False, reftype, refid, ns.tagpage, ns.tagtitle, ns.tagcolor) -}}
{%- else -%}
{{- caller(urlwoa, anchor, reflang, True, None, None, None, None, None) -}}
{%- endif -%}
{%- endif -%}
{%- endmacro -%}
......@@ -9,7 +9,7 @@
{%- macro section_custom(s, lang) -%}
{{ cards.open() }}
{%- for c in s.content -%}
{{ cards.card(title=c[lang], url=c.url, catcolor=c.color) }}
{{ cards.card(title=c[lang], url=c.url, catcolor=c.color, lang=lang) }}
{%- endfor -%}
{{ cards.close() }}
{%- endmacro -%}
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment