Issue: I find using the help style guide (Node help style guide : Node-RED) cumbersome. It takes time to document about the node using html tags.
Ask: Since the documentation is converted into markdown anyway, is there a way I can use markdown directly within <script type="text/html" data-help-name="jwt-gen1">....?
I don't think the editor currently has any mechanism to do that.
For uibuilder, I have a user API that delivers a set of documentation separately with the help of docsify. Docsify renders markdown to html dynamically and you only need to serve it's index.html.
I'm not certain (haven't tried either) but as the nodes/flows built in markdown documenter is displayed as HTML in the side-bar there is at least a possibility (just might not be hooked up to the custom nodes documentation or might require some tag to indicate markdown)?
But the point remains, the style guide exists to ensure a consistent format of help for users. You cannot adhere to the style guide with plain markdown.
If you are writing a node, the help isn't meant to be an inconvenience to spend time on. It's a critical part of your node and worth putting effort in for users of your node.
I'm open to suggestions for how to improve it, but don't forget why the style guide exists.
I think what might be interesting would be an easy way to have some extended documentation in the sidebar. I'd not really thought about that. I was delighted when I discovered how easy it was to serve up a docs folder containing markdown as a website accessible directly from the editor.
I would indeed be interesting to serve that straight into the sidebar. Then the current help could be left alone to give the nice formatted summary help with tons more available if the node called for it.
Totally agree with you. The documentation is v important, consistency is the key and it shoudn't be inconvenient. But you also have to agree that markdown is quicker to adopt as compared to html tags for someone like me who isnt a front end dev.
I had a bit play and it is possible to support existing style guide. Here is 2 quick demos...
The markdown entered in function node description...
Send data via a local serial port.
### Inputs
: payload (string | buffer) : data to be sent via the serial port
: *baudrate* (string) : baudrate of the serial port (optional)
The rendered html...
The markdown entered in custom nodes HTML file...
<script type="text/markdown" data-help-name="C-Mode Command">
OMRON C-Mode Command builder.
### Inputs
: payload (string | buffer) : data to be sent with the command
: *hostNumber* (string) : The host number to send this command to (optional, defaults to 00)
: *headerCode* (string) : The header code (command) to issue (optional, defaults to RR)
</script>
No, nothing has been added to the backlog yet, but I'd be happy to see this move forward in someway.
@Steve-Mcl that looks good in principle. We just need to think through how it works in practice. For example, whether this should be applied globally to any and all markdown we render in the editor, or should it be limited to node help in some way?
Good point. Not 100% certain we can switch extensions on and off. Assuming we can, I think we would need an options object in the renderMarkdown function to indicate we want to parse the extended markup (or not).
While on this, how do you feel about adding some table style (current a markdown table renders very much un-styled and is hard to tell it is even a table) and code colourisation?
One piece at a time. If you're going to move this forward, then let's move the discussion onto GitHub. Please raise a new discussion here: node-red/designs · Discussions · GitHub
(Just be aware I'm away for a few days so responses will be limited)