diff --git a/content/blog/shortcodes/index.ca.md b/content/blog/shortcodes/index.ca.md
index 57862e1..9a360ca 100644
--- a/content/blog/shortcodes/index.ca.md
+++ b/content/blog/shortcodes/index.ca.md
@@ -1,7 +1,7 @@
+++
title = "Shortcodes personalitzats"
date = 2023-02-19
-updated = 2023-11-24
+updated = 2024-02-16
description = "Aquest tema inclou alguns shortcodes personalitzats útils que pots utilitzar per millorar les teves publicacions. Ja sigui per mostrar imatges que s'adapten als temes clar i fosc, o per donar format a una secció de referències amb un aspecte professional, aquests shortcodes personalitzats t'ajudaran."
[taxonomies]
@@ -20,6 +20,8 @@ social_media_card = "social_cards/ca_blog_shortcodes.jpg"
**Nota 2**: a partir del [PR #222](https://github.com/welpo/tabi/pull/222) (commit [7796162](https://github.com/welpo/tabi/commit/7796162e378cacb9b4d6129f95138121224714f1)), tots els shortcodes d'imatges suporten rutes relatives pel paràmetre `src`.
+**Nota 3**: a partir del [PR #280](https://github.com/welpo/tabi/pull/280), tots els shortcodes d'imatges admeten imatges remotes pel paràmetre `src`.
+
### Imatges per a temes duals
Útil si vols utilitzar una imatge diferent pels temes clar i fosc:
diff --git a/content/blog/shortcodes/index.es.md b/content/blog/shortcodes/index.es.md
index f94cf79..ab52074 100644
--- a/content/blog/shortcodes/index.es.md
+++ b/content/blog/shortcodes/index.es.md
@@ -1,7 +1,7 @@
+++
title = "Shortcodes personalizados"
date = 2023-02-19
-updated = 2023-11-24
+updated = 2024-02-16
description = "Este tema incluye algunos shortcodes personalizados útiles que puedes utilizar para mejorar tus publicaciones. Puedes mostrar imágenes que se adapten a los temas claro y oscuro, dar formato a una sección de referencias con un aspecto profesional, y más."
[taxonomies]
@@ -20,6 +20,8 @@ social_media_card = "social_cards/es_blog_shortcodes.jpg"
**Nota 2**: a partir del [PR #222](https://github.com/welpo/tabi/pull/222) (commit [7796162](https://github.com/welpo/tabi/commit/7796162e378cacb9b4d6129f95138121224714f1)), todos los shortcodes de imágenes admiten rutas relativas en el parámetro `src`.
+**Nota 3**: a partir del [PR #280](https://github.com/welpo/tabi/pull/280), todos los shortcodes de imágenes admiten imágenes remotas en el parámetro `src`.
+
### Imágenes de doble tema
Útil si deseas usar una imagen diferente para los temas claro y oscuro:
diff --git a/content/blog/shortcodes/index.md b/content/blog/shortcodes/index.md
index 507f831..99b881c 100644
--- a/content/blog/shortcodes/index.md
+++ b/content/blog/shortcodes/index.md
@@ -1,7 +1,7 @@
+++
title = "Custom shortcodes"
date = 2023-02-19
-updated = 2023-11-24
+updated = 2024-02-16
description = "This theme includes some useful custom shortcodes that you can use to enhance your posts. Whether you want to display images that adapt to light and dark themes, or format a professional-looking reference section, these custom shortcodes have got you covered."
[taxonomies]
@@ -20,6 +20,8 @@ social_media_card = "social_cards/blog_shortcodes.jpg"
**Note 2**: as of [PR #222](https://github.com/welpo/tabi/pull/222) (commit [7796162](https://github.com/welpo/tabi/commit/7796162e378cacb9b4d6129f95138121224714f1)), all image shortcodes support relative paths in the `src` parameter.
+**Note 3**: as of [PR #280](https://github.com/welpo/tabi/pull/280), all image shortcodes support remote images in the `src` parameter.
+
### Dual theme images
Useful if you want to use a different image for the light and dark themes:
diff --git a/templates/shortcodes/dimmable_image.html b/templates/shortcodes/dimmable_image.html
index be8ef5c..125699a 100644
--- a/templates/shortcodes/dimmable_image.html
+++ b/templates/shortcodes/dimmable_image.html
@@ -1,21 +1,26 @@
-{%- 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_path = src -%}
+{#- Determine image path based on whether the src is remote or local -#}
+{%- if src is starting_with("http") -%}
+ {%- set image_url = src -%}
{%- else -%}
- {%- set image_path = relative_path -%}
+ {%- 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) -%}
+ {%- else -%}
+ {%- set image_url = get_url(path=relative_path) -%}
+ {%- endif -%}
{%- endif -%}
{%- set lazy_loading = lazy_loading | default(value=true) -%}
-{%- if full_width | default(value=false) -%}
+{%- if full_width -%}
{%- endif -%}
-
data:image/s3,"s3://crabby-images/13547/135478bd7d158ec1b357b8348029eca41fa55900" alt="" }})
-{%- if full_width | default(value=false) -%}
+
data:image/s3,"s3://crabby-images/3aa3d/3aa3d09a2587044aa1022c7d73ceadde390e02b6" alt=""
+{%- if full_width -%}
{%- endif -%}
diff --git a/templates/shortcodes/dual_theme_image.html b/templates/shortcodes/dual_theme_image.html
index fba3529..bad33d6 100644
--- a/templates/shortcodes/dual_theme_image.html
+++ b/templates/shortcodes/dual_theme_image.html
@@ -1,30 +1,37 @@
{%- set colocated_path = page.colocated_path | default(value="") -%}
-{%- set relative_light_path = colocated_path ~ light_src -%}
-{%- set relative_dark_path = colocated_path ~ dark_src -%}
+{%- set lazy_loading = lazy_loading | default(value=true) -%}
-{%- set light_meta = get_image_metadata(path=relative_light_path, allow_missing=true) -%}
-{%- if not light_meta -%}
- {%- set light_meta = get_image_metadata(path=light_src, allow_missing=true) -%}
- {%- set light_image_path = light_src -%}
+{# Handling for light mode image #}
+{%- if light_src is starting_with("http") -%}
+ {%- set light_image_url = light_src -%}
{%- else -%}
- {%- set light_image_path = relative_light_path -%}
+ {%- set relative_light_path = colocated_path ~ light_src -%}
+ {%- set light_meta = get_image_metadata(path=relative_light_path, allow_missing=true) -%}
+ {%- if not light_meta -%}
+ {%- set light_image_url = get_url(path=light_src) -%}
+ {%- else -%}
+ {%- set light_image_url = get_url(path=relative_light_path) -%}
+ {%- endif -%}
{%- endif -%}
-{%- set dark_meta = get_image_metadata(path=relative_dark_path, allow_missing=true) -%}
-{%- if not dark_meta -%}
- {%- set dark_meta = get_image_metadata(path=dark_src, allow_missing=true) -%}
- {%- set dark_image_path = dark_src -%}
+{# Handling for dark mode image #}
+{%- if dark_src is starting_with("http") -%}
+ {%- set dark_image_url = dark_src -%}
{%- else -%}
- {%- set dark_image_path = relative_dark_path -%}
+ {%- set relative_dark_path = colocated_path ~ dark_src -%}
+ {%- set dark_meta = get_image_metadata(path=relative_dark_path, allow_missing=true) -%}
+ {%- if not dark_meta -%}
+ {%- set dark_image_url = get_url(path=dark_src) -%}
+ {%- else -%}
+ {%- set dark_image_url = get_url(path=relative_dark_path) -%}
+ {%- endif -%}
{%- endif -%}
-{%- set lazy_loading = lazy_loading | default(value=true) -%}
-
-{%- if full_width | default(value=false) -%}
+{%- if full_width -%}
{%- endif -%}
-
data:image/s3,"s3://crabby-images/d8221/d822165edb4df6167653c504f1c7d928d4ff9f53" alt="" }})
-
data:image/s3,"s3://crabby-images/df3bd/df3bd819d36c3d0f8ff14c86cf1473c150047d78" alt="" }})
-{%- if full_width | default(value=false) -%}
+
data:image/s3,"s3://crabby-images/3aa7e/3aa7eebc3db162de8b4aa99abf00eabecc322054" alt=""
+
data:image/s3,"s3://crabby-images/29a4c/29a4c15f1d722d492481f5601d8b2ad469f7309d" alt=""
+{%- if full_width -%}
{%- endif -%}
diff --git a/templates/shortcodes/full_width_image.html b/templates/shortcodes/full_width_image.html
index 36ddb2c..41809a7 100644
--- a/templates/shortcodes/full_width_image.html
+++ b/templates/shortcodes/full_width_image.html
@@ -1,17 +1,22 @@
-{%- 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) -%}
+{#- Set paths based on whether the src is remote or local -#}
+{%- if src is starting_with("http") -%}
+ {%- 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_path = src -%}
-{%- else %}
- {%- set image_path = relative_path -%}
+ {#- 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) -%}
+ {%- else %}
+ {%- set image_url = get_url(path=relative_path) -%}
+ {%- endif -%}
{%- endif -%}
{%- set lazy_loading = lazy_loading | default(value=true) -%}
-
data:image/s3,"s3://crabby-images/13547/135478bd7d158ec1b357b8348029eca41fa55900" alt="" }})
+
diff --git a/templates/shortcodes/image_hover.html b/templates/shortcodes/image_hover.html
index 615c2f0..dff7f72 100644
--- a/templates/shortcodes/image_hover.html
+++ b/templates/shortcodes/image_hover.html
@@ -1,30 +1,37 @@
{%- set colocated_path = page.colocated_path | default(value="") -%}
-{%- set relative_default_path = colocated_path ~ default_src -%}
-{%- set relative_hovered_path = colocated_path ~ hovered_src -%}
+{%- set lazy_loading = lazy_loading | default(value=true) -%}
-{%- set default_meta = get_image_metadata(path=relative_default_path, allow_missing=true) -%}
-{%- if not default_meta -%}
- {%- set default_meta = get_image_metadata(path=default_src, allow_missing=true) -%}
- {%- set default_image_path = default_src -%}
+{#- Direct or relative URL handling for default image -#}
+{%- if default_src is starting_with("http") -%}
+ {%- set default_image_url = default_src -%}
{%- else -%}
- {%- set default_image_path = relative_default_path -%}
+ {%- set relative_default_path = colocated_path ~ default_src -%}
+ {%- set default_meta = get_image_metadata(path=relative_default_path, allow_missing=true) -%}
+ {%- if not default_meta -%}
+ {%- set default_image_url = get_url(path=default_src) -%}
+ {%- else -%}
+ {%- set default_image_url = get_url(path=relative_default_path) -%}
+ {%- endif -%}
{%- endif -%}
-{%- set hovered_meta = get_image_metadata(path=relative_hovered_path, allow_missing=true) -%}
-{%- if not hovered_meta -%}
- {%- set hovered_meta = get_image_metadata(path=hovered_src, allow_missing=true) -%}
- {%- set hovered_image_path = hovered_src -%}
+{#- Direct or relative URL handling for hovered image -#}
+{%- if hovered_src is starting_with("http") -%}
+ {%- set hovered_image_url = hovered_src -%}
{%- else -%}
- {%- set hovered_image_path = relative_hovered_path -%}
+ {%- set relative_hovered_path = colocated_path ~ hovered_src -%}
+ {%- set hovered_meta = get_image_metadata(path=relative_hovered_path, allow_missing=true) -%}
+ {%- if not hovered_meta -%}
+ {%- set hovered_image_url = get_url(path=hovered_src) -%}
+ {%- else -%}
+ {%- set hovered_image_url = get_url(path=relative_hovered_path) -%}
+ {%- endif -%}
{%- endif -%}
-{%- set lazy_loading = lazy_loading | default(value=true) -%}
-
-
+
diff --git a/templates/shortcodes/image_toggler.html b/templates/shortcodes/image_toggler.html
index bb2cd20..82c542b 100644
--- a/templates/shortcodes/image_toggler.html
+++ b/templates/shortcodes/image_toggler.html
@@ -3,35 +3,42 @@
{# This avoids conflicts when multiple instances of the shortcode are used. #}
{%- set random_id = get_random(end=100000) -%}
{%- set colocated_path = page.colocated_path | default(value="") -%}
-{%- set relative_default_path = colocated_path ~ default_src -%}
-{%- set relative_toggled_path = colocated_path ~ toggled_src -%}
+{%- set lazy_loading = lazy_loading | default(value=true) -%}
-{%- set default_meta = get_image_metadata(path=relative_default_path, allow_missing=true) -%}
-{%- if not default_meta -%}
- {%- set default_meta = get_image_metadata(path=default_src, allow_missing=true) -%}
- {%- set default_image_path = default_src -%}
+{# Direct or relative URL handling for default image #}
+{%- if default_src is starting_with("http") -%}
+ {%- set default_image_url = default_src -%}
{%- else -%}
- {%- set default_image_path = relative_default_path -%}
+ {%- set relative_default_path = colocated_path ~ default_src -%}
+ {%- set default_meta = get_image_metadata(path=relative_default_path, allow_missing=true) -%}
+ {%- if not default_meta -%}
+ {%- set default_image_url = get_url(path=default_src) -%}
+ {%- else -%}
+ {%- set default_image_url = get_url(path=relative_default_path) -%}
+ {%- endif -%}
{%- endif -%}
-{%- set toggled_meta = get_image_metadata(path=relative_toggled_path, allow_missing=true) -%}
-{%- if not toggled_meta -%}
- {%- set toggled_meta = get_image_metadata(path=toggled_src, allow_missing=true) -%}
- {%- set toggled_image_path = toggled_src -%}
+{# Direct or relative URL handling for toggled image #}
+{%- if toggled_src is starting_with("http") -%}
+ {%- set toggled_image_url = toggled_src -%}
{%- else -%}
- {%- set toggled_image_path = relative_toggled_path -%}
+ {%- set relative_toggled_path = colocated_path ~ toggled_src -%}
+ {%- set toggled_meta = get_image_metadata(path=relative_toggled_path, allow_missing=true) -%}
+ {%- if not toggled_meta -%}
+ {%- set toggled_image_url = get_url(path=toggled_src) -%}
+ {%- else -%}
+ {%- set toggled_image_url = get_url(path=relative_toggled_path) -%}
+ {%- endif -%}
{%- endif -%}
-{%- set lazy_loading = lazy_loading | default(value=true) -%}
-
-
+
diff --git a/templates/shortcodes/invertible_image.html b/templates/shortcodes/invertible_image.html
index de67fa0..317d836 100644
--- a/templates/shortcodes/invertible_image.html
+++ b/templates/shortcodes/invertible_image.html
@@ -1,21 +1,26 @@
-{%- 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_path = src -%}
+{#- Determine if src is a remote URL or a local path -#}
+{%- if src is starting_with("http") -%}
+ {%- set image_url = src -%}
{%- else -%}
- {%- set image_path = relative_path -%}
+ {%- 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) -%}
+ {%- else %}
+ {%- set image_url = get_url(path=relative_path) -%}
+ {%- endif -%}
{%- endif -%}
{%- set lazy_loading = lazy_loading | default(value=true) -%}
-{%- if full_width | default(value=false) -%}
+{%- if full_width -%}
{%- endif -%}
-
data:image/s3,"s3://crabby-images/13547/135478bd7d158ec1b357b8348029eca41fa55900" alt="" }})
-{%- if full_width | default(value=false) -%}
+
data:image/s3,"s3://crabby-images/3aa3d/3aa3d09a2587044aa1022c7d73ceadde390e02b6" alt=""
+{%- if full_width -%}
{%- endif -%}