summaryrefslogtreecommitdiff
path: root/sysret.org/themes/tabi-lean/templates/shortcodes/invertible_image.html
diff options
context:
space:
mode:
authorAlejandro Soto <alejandro@34project.org>2025-09-13 15:01:06 -0600
committerAlejandro Soto <alejandro@34project.org>2025-09-13 15:01:06 -0600
commitf4fcda54638685899c730b3fa90a87d80d6dbef5 (patch)
tree0737e627cce304c3a9c4e757bc5f6571a7456091 /sysret.org/themes/tabi-lean/templates/shortcodes/invertible_image.html
parentd8b9cf1f61cc07d625f1c37ccc28adfd58918416 (diff)
parent2c13119932765c6d788f08fb53abc244407c0d80 (diff)
Merge commit '6a7d3111b31e73fc66af5360149d41f690fbcaa4'
Diffstat (limited to 'sysret.org/themes/tabi-lean/templates/shortcodes/invertible_image.html')
-rw-r--r--sysret.org/themes/tabi-lean/templates/shortcodes/invertible_image.html32
1 files changed, 32 insertions, 0 deletions
diff --git a/sysret.org/themes/tabi-lean/templates/shortcodes/invertible_image.html b/sysret.org/themes/tabi-lean/templates/shortcodes/invertible_image.html
new file mode 100644
index 0000000..0e3c920
--- /dev/null
+++ b/sysret.org/themes/tabi-lean/templates/shortcodes/invertible_image.html
@@ -0,0 +1,32 @@
+{#- Determine if src is a remote URL or a local path -#}
+{%- if src is starting_with("http") or raw_path -%}
+ {%- set image_url = src -%}
+{%- else -%}
+ {%- set colocated_path = page.colocated_path | default(value="") -%}
+ {%- set relative_path = colocated_path ~ src -%}
+ {%- set meta = get_image_metadata(path=relative_path, allow_missing=true) -%}
+
+ {#- Fallback to absolute path if relative path doesn't work -#}
+ {%- if not meta -%}
+ {%- set meta = get_image_metadata(path=src, allow_missing=true) -%}
+ {%- set image_url = get_url(path=src, cachebust=true) -%}
+ {%- else %}
+ {%- set image_url = get_url(path=relative_path, cachebust=true) -%}
+ {%- endif -%}
+{%- endif -%}
+
+{%- set lazy_loading = lazy_loading | default(value=true) -%}
+{%- set inline = inline | default(value=false) -%}
+
+{%- set class_list = "invertible-image" -%}
+{%- if inline -%}
+ {%- set class_list = class_list ~ " inline" -%}
+{%- endif -%}
+
+{%- if full_width -%}
+ <div class="full-width">
+{%- endif -%}
+<img class="{{ class_list }}" src="{{ image_url }}"{% if lazy_loading %} loading="lazy"{% endif %}{% if alt %} alt="{{ alt }}"{% endif %}{% if meta.width %} width="{{ meta.width }}"{% endif %}{% if meta.height %} height="{{ meta.height }}" {% endif %}/>
+{%- if full_width -%}
+ </div>
+{%- endif -%}