I've been documenting a software package using Sphinx and reStructuredText.
Within my documents, there are some long code snippets. I want to be able to have them hidden as default, with a little "Show/Hide" button that would expand them (Example).
Is there a standard way to do that?
You don't need a custom theme. Use the built-in directive container
that allows you to add custom css-classes to blocks and override the existsting theme to add some javascript to add the show/hide-functionality.
This is _templates/page.html
:
{% extends "!page.html" %} {% block footer %} <script type="text/javascript"> $(document).ready(function() { $(".toggle > *").hide(); $(".toggle .header").show(); $(".toggle .header").click(function() { $(this).parent().children().not(".header").toggle(400); $(this).parent().children(".header").toggleClass("open"); }) }); </script> {% endblock %}
This is _static/custom.css
:
.toggle .header { display: block; clear: both; } .toggle .header:after { content: " ▶"; } .toggle .header.open:after { content: " ▼"; }
This is added to conf.py
:
def setup(app): app.add_css_file('custom.css')
Now you can show/hide a block of code.
.. container:: toggle .. container:: header **Show/Hide Code** .. code-block:: xml :linenos: from plone import api ...
I use something very similar for exercises here: https://training.plone.org/5/mastering-plone/about_mastering.html#exercises
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With