summaryrefslogtreecommitdiff
path: root/templates/shortcodes/spoiler.html
diff options
context:
space:
mode:
Diffstat (limited to 'templates/shortcodes/spoiler.html')
-rw-r--r--templates/shortcodes/spoiler.html13
1 files changed, 13 insertions, 0 deletions
diff --git a/templates/shortcodes/spoiler.html b/templates/shortcodes/spoiler.html
new file mode 100644
index 0000000..ff9e695
--- /dev/null
+++ b/templates/shortcodes/spoiler.html
@@ -0,0 +1,13 @@
+{# The `random_id` ensures that each instance of the shortcode has a "unique" id #}
+{# allowing individual interactive elements (like toggles) to function correctly. #}
+{# This avoids conflicts when multiple instances of the shortcode are used. #}
+{# More context: https://github.com/welpo/tabi/issues/82 #}
+{%- set random_id = get_random(end=100000) -%}
+{%- set fixed_blur = fixed_blur | default(value=false) -%}
+
+<label class="spoiler-container{% if fixed_blur %} fixed-blur{% endif %}">
+ <input type="checkbox" id="spoiler-{{random_id}}" class="spoiler-toggle" role="button" aria-pressed="false" />
+ <span class="spoiler-content" title="reveal spoiler" tabindex="0">
+ <span class="spoiler-hidden">{{ text | markdown | trim_start_matches(pat="<p>") | trim_start_matches(pat="</p>") | safe }}</span>
+ </span>
+</label>