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

Addons flyout and old versions #11677

Open
tsibley opened this issue Oct 14, 2024 · 9 comments
Open

Addons flyout and old versions #11677

tsibley opened this issue Oct 14, 2024 · 9 comments
Labels
Support Support question

Comments

@tsibley
Copy link

tsibley commented Oct 14, 2024

Continuing a conversation started by @victorlin here, at the request of @humitos.

We have many old versions of doc projects with the older build-time RTD injections (e.g. readthedocs-doc-embed.js). These are forcibly removed and replaced by the newer on-the-fly RTD Addons injections. While the previous injections let old versions show an up-to-date flyout attached to the sidebar, the new injections only support a floating flyout in the bottom right. We can remove the floating flyout by disabling the Addons flyout, but the removal of the older injections still happens and so the result is no flyout at all for older versions. As the only way to customize the new Addons flyout is via the theme, that leaves us no way but rebuilding dozens of old doc versions if we want to maintain the previous functionality of a sidebar-attached flyout.

Would you consider making the removal of the relevant old injections conditional on if the Addons flyout is actually enabled? Or conditional on build time being after the date addons were enabled for a project?

@humitos
Copy link
Member

humitos commented Oct 15, 2024

Hi @tsibley! Currently, we don't support too much customization on the addons flyout, but we are exploring different ideas to allow users to customize it in different ways -- as you found in the issue you linked.

Note that we removed the old injected flyout because it's deprecated and will be removed in the near future. It depends on different things we are not able to maintain anymore and that was one of the reason why we re-created it as an addon. So, even if we allow the old behavior in old versions it will stop working soon.

I recommend you to use the addons floating flyout in your projects for now since it fulfill your needs of showing a version selector in all the versions, old and new ones. I understand it's not a perfect solution due to its style, but it solves the problem at least.

In the future, when we add support for extra customization, you will your projects already prepared for this.

That's the solution I can offer to you for now. However, I will talk to other Read the Docs folks and see if they have different ideas here.

@tsibley
Copy link
Author

tsibley commented Oct 15, 2024

Note that we removed the old injected flyout because it's deprecated and will be removed in the near future. It depends on different things we are not able to maintain anymore and that was one of the reason why we re-created it as an addon. So, even if we allow the old behavior in old versions it will stop working soon.

I'm confused about "removed in the near future". It's being actively removed right now.

It would be easier to not remove it by not rewriting the outgoing HTML. But I guess you're saying that RTD does not want to (or can't?) maintain the endpoint(s) the old flyout needs? It's not clear why when the new flyout has the same information.

@ericholscher
Copy link
Member

@tsibley We talked about this today, and definitely want to find a way forward to make things work well for you. We're working to build more customization in the long term, but also have a couple options in the short term.

We're able to inject a custom bit of JS into all of your versions that you can use to recreate some of the flyout, similar to the RTD theme, and then hide the new flyout for now until we can work to build a better integration for you. Does that make sense as a shortterm workaround?

Our vision for the future is for theme authors to use this data and the custom event to integrate the data directly into the theme, perhaps not having a flyout at all. We're viewing the flyout as a default implementation, but with access to the raw data, hopefully versions, translations, downloads, and search can be built into the docs explicitly (for example: https://docs.readthedocs.io/en/stable/intro/sphinx.html#configure-read-the-docs-search)

Please let me know what would make things better in the short term and we want to work with you on making the migration easier, and ensuring we end up in a better place.

@victorlin
Copy link

Hi @ericholscher, I'll respond since @tsibley is out until next week.

We would be happy to consider the short term workaround. I'm curious what "recreate some of the flyout" means. Could we first apply this on a test project? That would be https://docs.nextstrain.org/projects/sphinx-theme/ where I've already disabled the new flyout addon.

Thank you for your efforts 🙏

@ericholscher
Copy link
Member

ericholscher commented Oct 17, 2024

We would be happy to consider the short term workaround. I'm curious what "recreate some of the flyout" means. Could we first apply this on a test project? That would be https://docs.nextstrain.org/projects/sphinx-theme/ where I've already disabled the new flyout addon.

Yea, we can definitely do a test project. Mostly was referring to recreating the old HTML structure, like what the RTD theme is doing -- so that you can get the old functionality, but with the new Addons & custom event approach.

Thank you for your efforts 🙏

Appreciate the kind words. It's been a stressful week, and we're trying to get things to a better place moving forward!

@tsibley
Copy link
Author

tsibley commented Oct 22, 2024

We're able to inject a custom bit of JS into all of your versions that you can use to recreate some of the flyout, similar to the RTD theme, and then hide the new flyout for now until we can work to build a better integration for you. Does that make sense as a shortterm workaround?

Thanks for this offer. If this is a short-term (temporary?) solution, what's the long-term solution for old versions?

How should we ship the JS to you for the custom injection?

@ericholscher
Copy link
Member

We're able to inject a custom bit of JS into all of your versions that you can use to recreate some of the flyout, similar to the RTD theme, and then hide the new flyout for now until we can work to build a better integration for you. Does that make sense as a shortterm workaround?

Thanks for this offer. If this is a short-term (temporary?) solution, what's the long-term solution for old versions?

I think that solution should work long-term, but it's a fix for only a subset of projects. We're hoping to have a larger systemic solution, but still trying to figure out the best path there.

How should we ship the JS to you for the custom injection?

You can post it here, or send it via email to us at support@readthedocs.org.

@humitos
Copy link
Member

humitos commented Nov 19, 2024

Hi all 👋🏼

Today we releasing a new addon called CustomScript that allows users to inject a JavaScript file in all the versions of the documentation of a project without rebuilding any version. This is useful to perform some changes (bugfixes, updates, etc) on old documentation versions that are "frozen" and can't be rebuilt for any reason (eg. based on Git tags)

The user will need to specify the URL of the JavaScript file to be injected and the addon will injected it at render time automatically.

This addon could be used to:

  • render the old flyout on old versions of the documentation
  • fix the layout of the html
  • add a notification on an old version

Currently, we are not exposing the UI in the dashboard to configure this addon, but we are happy to give you early access to it if you want. You will only need to give us the URL for the JavaScript file to be injected by the addon.

Let us know if this would be useful for you to solve the issue with the flyout on old versions.

@mgeier
Copy link
Contributor

mgeier commented Nov 23, 2024

So are you saying a theme author (or whoever) could provide a JavaScript file at some URL which could then be used to inject the same HTML that has previously been injected automatically by RTD?
Basically re-writing the code that has previously been provided by RTD?
And therefore all the old integrations would keep working without changes?

This sounds very interesting (and like a lot of work for whoever implements this JavaScript code), but it would still require site maintainers to manually select the CustomScript addon, manually set the URL and then manually disable the default flyout (see #11688), right?

This is probably less important, but would that also allow injecting the version warnings in their old places and remove the newfangled floating and disappearing ones?

If I understand that right, the CustomScript JavaScript code could be completely theme-independent, so only one poor person would have to implement and provide it, and all interested theme authors could then take advantage of it?

So wouldn't it be possible for RTD to provide all this as a default fallback and let site maintainers (or theme authors?) opt in to the new floating flyout?
I think this would have made (and still may make) the whole transition much less painful for site maintainers (because their already published sites would simply keep working as before without intervention).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Support Support question
Projects
None yet
Development

No branches or pull requests

5 participants