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

Switch docs theme #4276

Merged
merged 31 commits into from
Sep 5, 2023
Merged

Switch docs theme #4276

merged 31 commits into from
Sep 5, 2023

Conversation

lilyminium
Copy link
Member

@lilyminium lilyminium commented Sep 4, 2023

Fixes MDAnalysis/mdanalysis-sphinx-theme#33
Fixes #4199

Changes made in this Pull Request:

PR Checklist

  • Tests?
  • Docs?
  • CHANGELOG updated?
  • Issue raised/referenced?

Developers certificate of origin


📚 Documentation preview 📚: https://mdanalysis--4276.org.readthedocs.build/en/4276/

@github-actions
Copy link

github-actions bot commented Sep 4, 2023

Linter Bot Results:

Hi @lilyminium! Thanks for making this PR. We linted your code and found the following:

Some issues were found with the formatting of your code.

Code Location Outcome
main package ⚠️ Possible failure
testsuite ✅ Passed

Please have a look at the darker-main-code and darker-test-code steps here for more details: https://github.com/MDAnalysis/mdanalysis/actions/runs/6077561192/job/16496321590


Please note: The black linter is purely informational, you can safely ignore these outcomes if there are no flake8 failures!

Copy link
Member

@IAlibay IAlibay left a comment

Choose a reason for hiding this comment

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

Thanks @lilyminium, awesome work!

.github/workflows/gh-ci.yaml Outdated Show resolved Hide resolved
@codecov
Copy link

codecov bot commented Sep 4, 2023

Codecov Report

Patch and project coverage have no change.

Comparison is base (b2b3eb9) 93.40% compared to head (a48a41c) 93.40%.
Report is 13 commits behind head on develop.

Additional details and impacted files
@@            Coverage Diff             @@
##           develop    #4276     +/-   ##
==========================================
  Coverage    93.40%   93.40%             
==========================================
  Files          170      184     +14     
  Lines        22250    23358   +1108     
  Branches      4071     4071             
==========================================
+ Hits         20783    21818   +1035     
- Misses         951     1024     +73     
  Partials       516      516             
Files Changed Coverage Δ
package/MDAnalysis/analysis/bat.py 94.57% <ø> (ø)
package/MDAnalysis/analysis/contacts.py 100.00% <ø> (ø)
package/MDAnalysis/analysis/data/filenames.py 100.00% <ø> (ø)
package/MDAnalysis/analysis/diffusionmap.py 100.00% <ø> (ø)
package/MDAnalysis/analysis/dihedrals.py 97.05% <ø> (ø)
package/MDAnalysis/analysis/encore/similarity.py 85.62% <ø> (ø)
package/MDAnalysis/analysis/gnm.py 97.61% <ø> (ø)
package/MDAnalysis/analysis/helix_analysis.py 98.65% <ø> (ø)
package/MDAnalysis/analysis/hole2/__init__.py 100.00% <ø> (ø)
...DAnalysis/analysis/hydrogenbonds/hbond_analysis.py 97.22% <ø> (ø)
... and 28 more

... and 14 files with indirect coverage changes

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@lilyminium
Copy link
Member Author

lilyminium commented Sep 4, 2023

On ReadTheDocs, we have some remnant blue boxes:

Screenshot 2023-09-04 at 9 29 36 pm

On my machine (TM), we do not:
Screenshot 2023-09-04 at 9 30 15 pm

Moving to draft status while I figure it out...

Edit: Ok, I can reproduce this if I use the same bewilderingly old version of sphinx_rtd_theme (0.4.3) that RTD is using.

@lilyminium lilyminium marked this pull request as draft September 4, 2023 11:31
@IAlibay
Copy link
Member

IAlibay commented Sep 4, 2023

Ok, I can reproduce this if I use the same bewilderingly old version of sphinx_rtd_theme (0.4.3) that RTD is using.

Is this one of those where we can just say we don't care and it'll go away soon or is that being too hopeful?

@lilyminium
Copy link
Member Author

lilyminium commented Sep 4, 2023

Is this one of those where we can just say we don't care and it'll go away soon or is that being too hopeful?

I could maybe pin sphinx_rtd_theme >=1 with mdanalysis_sphinx_theme to resolve this? (or would RTD just ignore that version and go for the more permissive variant?) It is a very weirdly old version (released 2019, sphinx_rtd_theme is on 2.0.0rc2 atm) and I'm curious why RTD has picked it. It'd be a bit annoying if we couldn't preview our docs properly there.

User guide is picking up the same 0.4.3...

@IAlibay
Copy link
Member

IAlibay commented Sep 4, 2023

Is this one of those where we can just say we don't care and it'll go away soon or is that being too hopeful?

I could maybe pin sphinx_rtd_theme >=1 with mdanalysis_sphinx_theme to resolve this? (or would RTD just ignore that version and go for the more permissive variant?) It is a very weirdly old version (released 2019, sphinx_rtd_theme is on 2.0.0rc2 atm) and I'm curious why RTD has picked it. It'd be a bit annoying if we couldn't preview our docs properly there.

I guess you could try just override the version in the yaml file here for now and see what happens? If that doesn't work then they are doing some annoying black magic in the background that is unlikely get fixed with pinning upstream.

@IAlibay
Copy link
Member

IAlibay commented Sep 4, 2023

 + sphinx_rtd_theme                      1.3.0  pyha770c72_0        conda-forge/noarch         2 MB

Seems to have done a thing?

TIL RTD actually advocates for pinning the sphinx_rtd_theme version: https://docs.readthedocs.io/en/stable/guides/reproducible-builds.html#id2

@lilyminium
Copy link
Member Author

lilyminium commented Sep 4, 2023

Oh nice! I was just tracking stuff down myself, since everywhere seemed to be picking up the 0.4.3 version. I think it might be preferring anaconda/noarch (https://anaconda.org/anaconda/sphinx_rtd_theme), which tops out at 0.4.3, over conda-forge (https://anaconda.org/conda-forge/sphinx_rtd_theme).
So we could either pin the lower bound of sphinx_rtd_theme, or keep pinning every version as they release (a minor pain...), and I assume as long as it's above a certain version it should pick up the conda-forge one? Do you have any preference -- I know you generally prefer as few pins as possible?

Edit: whoops, I should have let RTD finish building before pushing the rebase :/ sorry for the wait

@IAlibay
Copy link
Member

IAlibay commented Sep 4, 2023

So we could either pin the lower bound of sphinx_rtd_theme, or keep pinning every version as they release (a minor pain...), and I assume as long as it's above a certain version it should pick up the conda-forge one? Do you have any preference -- I know you generally prefer as few pins as possible?

Less work is better work. I would just go with the lower bound pin? Would it make sense to just have the pin upstream in the new theme? It's annoying to add a dependency, but it would probably save you some headaches later?

@lilyminium
Copy link
Member Author

Yeah I'll pin upstream.

@IAlibay IAlibay closed this Sep 4, 2023
@IAlibay IAlibay reopened this Sep 4, 2023
Copy link
Member

@orbeckst orbeckst left a comment

Choose a reason for hiding this comment

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

This looks super-nice already on RTD. Great work! I look forward to seeing it merged.

@lilyminium
Copy link
Member Author

Thanks! I think this is ready for review now. The theme fixes a few small annoying issues, plus the docutils incompatibility. There are also minor docs fixes I noticed from previewing docs.

Old
Screenshot 2023-09-05 at 11 00 14 am

New
Screenshot 2023-09-05 at 11 01 01 am

@lilyminium lilyminium marked this pull request as ready for review September 5, 2023 01:03
Copy link
Member

@IAlibay IAlibay left a comment

Choose a reason for hiding this comment

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

Could you tick the lgplv2 box?

Otherwise, lgtm! This is really awesome, thanks @lilyminium ! 🎉

@@ -31,11 +31,11 @@

This module contains classes for interconverting between Cartesian and an
internal coordinate system, Bond-Angle-Torsion (BAT) coordinates
:cite:p:`Chang2003`, for a given set of atoms or residues. This coordinate
:footcite:p:`Chang2003`, for a given set of atoms or residues. This coordinate
Copy link
Member

Choose a reason for hiding this comment

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

Do we document how we do citations anywhere in our docs? We probably should tell folks that cite -> footcite now

Copy link
Member

Choose a reason for hiding this comment

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

Are there any peculiarities to footbibliography that should be stated somewhere? (I don't know how/if it differs from the old approach)

Copy link
Member Author

Choose a reason for hiding this comment

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

Ticked :)

I don't think so, no more than bibliography is. The footbib is used for local bibliographies (on the same page as the reference), so we can remove stuff like the a- and b- prefixes we had before. The normal bibliography is for global bibliographies, so one reference list for the entire repo. This is all readily available on the sphinx bibtex extension docs though. I was planning to add in some notes in the mdanalysis-sphinx-theme -- MDAnalysis/mdanalysis-sphinx-theme#26

The one catch is that there's meant to be one footbib per reference per page, so if footbibliographies are created multiple times for the same reference, then only the first one will ahve the reference and all links will go there. Again I got this from the official docs.

Copy link
Member

Choose a reason for hiding this comment

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

Could you maybe raise an issue in the userguide for docs on this? This is the kind of info any contributor new or old should be told to look at so imho, even if it's just a reference to the theme docs, your above explanation should exist there in some way.

Copy link
Member Author

Choose a reason for hiding this comment

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

Sure, done

@IAlibay IAlibay merged commit c289b7f into MDAnalysis:develop Sep 5, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Start using MDA theme in official repos Docs need updating to modern docutils
3 participants