Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support glossary / term and sphinxcontrib-bibtex #149

Merged
merged 1 commit into from
Sep 28, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -50,8 +50,11 @@
'hoverxref.extension',
'versionwarning.extension',
'notfound.extension',
'sphinxcontrib.bibtex',
]

bibtex_bibfiles = ['refs.bib']

intersphinx_mapping = {
'readthedocs': ('https://docs.readthedocs.io/en/stable/', None),
'sphinx': ('https://www.sphinx-doc.org/en/master/', None),
Expand Down Expand Up @@ -95,6 +98,7 @@
hoverxref_auto_ref = True
hoverxref_roles = [
'confval',
'term',
]

hoverxref_role_types = {
Expand All @@ -107,6 +111,7 @@
}
hoverxref_domains = [
'py',
'cite',
]
hoverxref_sphinxtabs = True
hoverxref_mathjax = True
Expand Down
4 changes: 0 additions & 4 deletions docs/configuration.rst
Original file line number Diff line number Diff line change
Expand Up @@ -65,10 +65,6 @@ These settings are global and have effect on both, tooltips and modal dialogues.

Description: List containing the Sphinx Domain's names where ``hoverxref`` has to be applied.

.. warning::

Only Python Domain (``py``) is currently supported.

Default: ``[]``

Type: list
Expand Down
6 changes: 6 additions & 0 deletions docs/refs.bib
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
@Book{1987:nelson,
author = {Edward Nelson},
title = {Radically Elementary Probability Theory},
publisher = {Princeton University Press},
year = {1987}
}
1 change: 1 addition & 0 deletions docs/requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -6,3 +6,4 @@ sphinx-prompt==1.4.0
sphinx-version-warning==1.1.2
sphinx-notfound-page==0.7.1
sphinx-autobuild==2021.3.14
sphinxcontrib-bibtex==2.4.1
38 changes: 38 additions & 0 deletions docs/usage.rst
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,44 @@ To enable ``hoverxref`` on a domain, you need to use the config :confval:`hoverx
indicating which are the domains you desire.


Tooltip on glossary terms
-------------------------

You can add tooltips to glossary terms:

.. code-block:: rst

See the :term:`sphinx:environment` definition in the glossary.

That will render to:

See the :term:`sphinx:environment` definition in the glossary.

To enable ``hoverxref`` on glossary terms, you need to add ``'term'`` to :confval:`hoverxref_roles`.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this enabled by default? I feel like it should be..

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I prefer to not enable tooltips by default. The extension itself has a :hoverxref: role where you can manually specify which references you want to show tooltips on.

Besides, it has a simplified way to enable tooltips on all references by using hoverxref_auto_ref = True in your config file or selectively by role using hoverxref_roles.



Tooltip on sphinxcontrib-bibtex cites
-------------------------------------

If you want to show a tooltip on `sphinxcontrib-bibtex <https://sphinxcontrib-bibtex.readthedocs.io/en/latest/>`_ cites,
you just need to enable it in :confval:`hoverxref_domains` by adding ``'cite'`` to that list.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should standardize where we put this info. It's at the bottom of the previous section, and top here. Probably a subhead like Enable this feature or similar?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Probably a Enable this feature section may be too big for each of them since the content itself is really small. However, standardizing where to describe how to enable them makes sense to me.

Example:

.. code-block:: rst

See :cite:t:`1987:nelson` for an introduction to non-standard analysis.
Non-standard analysis is fun :cite:p:`1987:nelson`.

See :cite:t:`1987:nelson` for an introduction to non-standard analysis.
Non-standard analysis is fun :cite:p:`1987:nelson`.

.. note::

Note that tooltips on sphinxcontrib-bibtex are supported on ``Sphinx>=2.1`` only.

.. bibliography::


Tooltip with content that needs extra rendering steps
-----------------------------------------------------

Expand Down
37 changes: 37 additions & 0 deletions hoverxref/domains.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
import docutils

from sphinx.util import logging

logger = logging.getLogger(__name__)
Expand Down Expand Up @@ -138,3 +140,38 @@ def _resolve_numref_xref(self, env, fromdocname, builder, typ, target, node, con

self._inject_hoverxref_data(env, refnode, typ)
return refnode


class HoverXRefBibtexDomainMixin(HoverXRefBaseDomain):
"""
Mixin for ``BibtexDomain`` to save the values after the xref resolution.

This class add the required ``hoverxref`` and ``modal``/``tooltip`` to tell
the frontend to show a modal/tooltip on this element.

https://github.com/mcmtroffaes/sphinxcontrib-bibtex/blob/2.4.1/src/sphinxcontrib/bibtex/domain.py#L281
"""

def resolve_xref(self, env, fromdocname, builder, typ, target, node, contnode):
textnode = super().resolve_xref(env, fromdocname, builder, typ, target, node, contnode)
if textnode is None:
return textnode
humitos marked this conversation as resolved.
Show resolved Hide resolved

if any([
self._is_ignored_ref(env, target),
not (env.config.hoverxref_auto_ref or typ in self.hoverxref_types or 'cite' in env.config.hoverxref_domains)
]):
return textnode

# The structure of the node generated by bibtex is between two
# ``#text`` nodes and we need to add the classes into the ``reference``
# node to get the ``href=`` attribute from it
#
# (Pdb++) textnode.children
# [<#text: 'Nelson ['>, <reference: <#text: 'Nel87'>>, <#text: ']'>]
refnode_index = textnode.first_child_matching_class(docutils.nodes.reference)
if refnode_index:
refnode = textnode.children[refnode_index]
self._inject_hoverxref_data(env, refnode, typ)

return textnode
12 changes: 12 additions & 0 deletions hoverxref/extension.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
from . import version
from .domains import (
HoverXRefBaseDomain,
HoverXRefBibtexDomainMixin,
HoverXRefPythonDomainMixin,
HoverXRefStandardDomainMixin,
)
Expand Down Expand Up @@ -119,6 +120,17 @@ def setup_domains(app, config):
)
app.add_domain(domain, override=True)

if 'cite' in app.config.hoverxref_domains:
domain = types.new_class(
'HoverXRefBibtexDomain',
(
HoverXRefBibtexDomainMixin,
app.registry.domains.get('cite'),
),
{}
)
app.add_domain(domain, override=True)


def setup_sphinx_tabs(app, config):
"""
Expand Down
11 changes: 11 additions & 0 deletions tests/examples/bibtex-domain/conf.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# conf.py to run tests

master_doc = 'index'
extensions = [
'sphinx.ext.autodoc',
'sphinx.ext.autosectionlabel',
'hoverxref.extension',
'sphinxcontrib.bibtex',
]

bibtex_bibfiles = ['refs.bib']
10 changes: 10 additions & 0 deletions tests/examples/bibtex-domain/index.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
sphinxcontrib-bibtex Domain
===========================

This is an example page with a sphinxcontrib-bibtex Domain role usage.

See :cite:t:`1987:nelson` for an introduction to non-standard analysis.
Non-standard analysis is fun :cite:p:`1987:nelson`.


.. bibliography::
6 changes: 6 additions & 0 deletions tests/examples/bibtex-domain/refs.bib
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
@Book{1987:nelson,
author = {Edward Nelson},
title = {Radically Elementary Probability Theory},
publisher = {Princeton University Press},
year = {1987}
}
25 changes: 25 additions & 0 deletions tests/examples/default/glossary.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
Glossary
========

Example page showing the usage of ``.. glossary`` and ``term``.

See definition :term:`builder` for more information.

.. copied from https://www.sphinx-doc.org/en/master/glossary.html

.. glossary::

builder
A class (inheriting from :class:`~sphinx.builders.Builder`) that takes
parsed documents and performs an action on them. Normally, builders
translate the documents to an output format, but it is also possible to
use builders that e.g. check for broken links in the documentation, or
build coverage information.

See :doc:`/usage/builders/index` for an overview over Sphinx's built-in
builders.

configuration directory
The directory containing :file:`conf.py`. By default, this is the same as
the :term:`source directory`, but can be set differently with the **-c**
command-line option.
46 changes: 45 additions & 1 deletion tests/test_htmltag.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import sphinx
import textwrap

from .utils import srcdir, prefixdocumentsrcdir, customobjectsrcdir, pythondomainsrcdir, intersphinxsrc
from .utils import srcdir, prefixdocumentsrcdir, customobjectsrcdir, pythondomainsrcdir, intersphinxsrc, bibtexdomainsrcdir


@pytest.mark.sphinx(
Expand Down Expand Up @@ -121,6 +121,50 @@ def test_python_domain(app, status, warning):
assert chunk in content


@pytest.mark.skipif(
sphinx.version_info < (2, 1, 0),
reason='sphinxcontrib-bibtex requires Sphinx>=2.1 to work',
)
@pytest.mark.sphinx(
srcdir=bibtexdomainsrcdir,
confoverrides={
'hoverxref_domains': ['cite'],
},
)
def test_bibtex_domain(app, status, warning):
app.build()
path = app.outdir / 'index.html'
assert path.exists() is True
content = open(path).read()

chunks = [
'<p>See <span id="id1">Nelson [<a class="hoverxref tooltip reference internal" href="#id4" title="Edward Nelson. Radically Elementary Probability Theory. Princeton University Press, 1987.">Nel87</a>]</span> for an introduction to non-standard analysis.\nNon-standard analysis is fun <span id="id2">[<a class="hoverxref tooltip reference internal" href="#id4" title="Edward Nelson. Radically Elementary Probability Theory. Princeton University Press, 1987.">Nel87</a>]</span>.</p>',
]

for chunk in chunks:
assert chunk in content


@pytest.mark.sphinx(
srcdir=srcdir,
confoverrides={
'hoverxref_roles': ['term'],
},
)
def test_glossary_term_domain(app, status, warning):
app.build()
path = app.outdir / 'glossary.html'
assert path.exists() is True
content = open(path).read()

chunks = [
'<p>See definition <a class="hoverxref tooltip reference internal" href="#term-builder"><span class="xref std std-term">builder</span></a> for more information.</p>',
]

for chunk in chunks:
assert chunk in content


@pytest.mark.sphinx(
srcdir=srcdir,
confoverrides={
Expand Down
7 changes: 7 additions & 0 deletions tests/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,13 @@
'python-domain',
)

# srcdir with ``:cite:`` call
bibtexdomainsrcdir = os.path.join(
os.path.dirname(os.path.abspath(__file__)),
'examples',
'bibtex-domain',
)

# srcdir with intersphinx configured
intersphinxsrc = os.path.join(
os.path.dirname(os.path.abspath(__file__)),
Expand Down
1 change: 1 addition & 0 deletions tox.ini
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ envlist =
deps =
pytest
pdbpp
sphinxcontrib-bibtex
.
sphinx18: sphinx~=1.8.0
sphinx20: sphinx~=2.0.0
Expand Down