-
Notifications
You must be signed in to change notification settings - Fork 1
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
Add support for workflow code cells #80
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @glopesdev, cool stuff! I tried this out both locally and on my fork by copying the example in Bonsai.Sleap.PredictCentroids, but the URL seems to be broken. I made a suggestion to use relative URLs instead.
It would also be nice to have this documented in the contributing guidelines. Atm the docs guidelines only exist in this open PR. For now we should open an issue to remind us to do so once this feature is merged.
@lochhh I have rewritten the approach to use a custom extension for consistency with the image handling pipeline. Relative and deep paths should not be affected anymore, can you give your example another try? P.S.: no need for the |
Thanks @glopesdev this is a great idea and works well with .md. I'm not sure how it works with .rst files though. In my mind I would like to have for .rst files: .. workflow:: ../../workflows/CentroidModel.bonsai
:alt: PredictCentroids and .md files: :::{workflow} ../../workflows/CentroidModel.bonsai
:alt: PredictCentroids
::: Here is my attempt at adapting your WorkflowImageConverter for a custom WorkflowDirective (2bbc53b). |
@lochhh I understand the idea but are we going to have people write documentation directly in rst syntax? I would actually actively discourage this, since rst is only a standard in python, whereas markdown is more accessible. The syntax proposed in this PR is identical between docfx markdown and sphinx markdown, so I feel it might be best to unify how we document bonsai code blocks between docfx and sphinx than to force md to be compatible with rst. Ultimately all MyST code must have an equivalent in rST. Do you know what would be the .rst equivalent of the current .md syntax? |
@lochhh actually it looks like admonitions in MyST now support colon fences without curly brackets (executablebooks/MyST-Parser#271) which seem to be common across markdig, pandoc and now myst. |
Thanks again @glopesdev. I totally agree with your point of having a consistent markdown syntax between docfx and sphinx. From what I understand, the current approach is that we place an "image" in a custom "workflow" container and manipulate this image via the WorkflowImageConverter, and then workflow.js finds the matching container and adds the copy button. What I'm unsure about is implementing this as an ImageConverter, as something like the below (i.e. without the ![PredictCentroids](../workflows/CentroidModel.bonsai) My suggestion for a directive is to have something similar to embedding mermaid diagrams: instead of providing mermaid file/code, we provide the workflow file, and the image would be rendered. I learnt from sphinx's mermaid extension that setting ```workflow
../workflows/CentroidModel.bonsai
``` This syntax is also similar to that for docfx's mermaid diagram. With a directive, we also get a similar RST syntax "for free" (even if we don't need it).
The closing comment suggests the curly braces are necessary to distinguish between highlighting languages (```python) and directives(```{python}).
The rst equivalent for the current custom container syntax would be: .. container:: workflow
.. raw:: html
<p>
.. image:: ../workflows/CentroidModel.bonsai
:alt: Alternative text
.. raw:: html
</p> (☝️ This definitely gives us another reason to discourage documenting bonsai workflows in rst.) .. workflow::
:alt: Alternative text
../workflows/CentroidModel.bonsai to get to: <div class="workflow docutils container">
<p>
<img alt="Alternative text" src="../_images/CentroidModel.svg">
</p>
</div> |
This PR introduces a custom Sphinx extension and a new JS module for the generated website to enable rendering workflow containers. The script mimics the main features of the DocFX version, but reuses heavily the sphinx-copybutton extension.
Specifically, the markdown syntax for inserting a workflow code cell is identical to the DocFX version:
The extension expects an SVG file with the same name to be located next to the workflow, e.g. the image for the workflow above is expected at
workflows/workflow.svg
.Note
Due to quirks with JS working with local files, the
fetch
function to read contents only works if the website is being hosted from a webserver (i.e. not when opening HTML directly from files). This only affects the copy action and not the image rendering so I left it for now. Workaround is to preview the website by calling the built-in python webserverpython -m http.server
from the generateddocs/html
folder.Fixes #68