docsify icon indicating copy to clipboard operation
docsify copied to clipboard

Proposal: auto generate sidebar

Open anikethsaha opened this issue 5 years ago • 9 comments

Auto-generate sidebar

Summary

Auto-generate and update the sidebar i.e _sidebar.md by looking into the folders/files

Motivation

If you have a big project or a project having many markdown files. It is kind of extra work look for each file and writes the path and the file name and the text to display it. Maximum projects I have seen take each .md file as a single page and .md files under a folder inside the docs directory is a sub-page. So if we go with usual lookups through each file/folder. This is quite easy to achieve.

Detailed Design

No changes are required in the core. Only needs changes in cli. New command probably

If we have directories like this

|- <root>
       |- README.md
       |- index.html
       |- _sidebar.md
       |- a.md
       |- guide
            |- guide-a.md
       |- b.md

The sidebar command should generate the following

- [a](./a.md)
- guide
  - [a](./guide/guide-a.md)
- [b](./b.md)

We need to traverse through the directory and create an object or tree and then just print the tree as a list in the markdown.

Documentation

Update the docs in the main docs site as a separate page and create docs for the command in the cli and do a remote rendering of the page in the main docs

Drawbacks

Few

  • It won't know whether markdown file should be in the heading or in subheading if it goes out of our prediction.
  • cant do the operation for the .html files.

Backwards Compatibility Analysis

Not required as no changes in the core is being done.

Alternatives

Do the manual entry in the _sidebar.md

Open Questions

  • Should we wait for or put this in v5 ?
  • Any volunteers for taking this ?

Help Needed

None.

Frequently Asked Questions

None

Related Discussions

Couldnt find any.

anikethsaha avatar Jul 17 '20 15:07 anikethsaha

Hello, friend. I used to have the same confusion, so you can try this

https://github.com/rundocs/jekyll-rtd-theme

ghost avatar Jul 22 '20 05:07 ghost

This would be very useful. I think you will also need some sort of rule for ordering/ignoring the entries, with a prefix on the filename or some front-matter maybe.

|- <root>
       |- README.md
       |- index.html
       |- _sidebar.md
       |- 1__a.md
       |- 3__guide
            | no_prefix.md  // => Fallback  alphabetical sort
            |- 1__guide-a.md
            |- __ignore.md
       |- 2__b.md

result

- [a](./a.md)
- [b](./b.md)
- guide
  - [a](./guide/guide-a.md)
  - [no_prefix](./guide/no_prefix.md)

ajboni avatar Aug 05 '20 19:08 ajboni

Personally, I think this can be limiting and it should be optional. For example, we like that sidebars are just markdown files and we can customize it and swap it (for multilanguage docs, etc). Also, we think that sidebars that are not related to the file structure can be more useful in some situations.

This is how our sidebar looks. We added emoticons and custom HTML badges beside titles. Such level of customizations should be preserved and so, the auto-generated sidebar must be opt-in or at least, opt-out.

Screenshot 2020-09-05 at 12 20 26

equinusocio avatar Sep 05 '20 10:09 equinusocio

this is only way to support from github https://github.com/rundocs/docsify-seo-support

ghost avatar Sep 05 '20 11:09 ghost

This would be so nice! No need to update two places and everything are inferred with convention. Most of the time the directories are organized with the files anyway, if not, there is always extra cognitive load. This can be an opt-in option and would also allow the existing _sidebar.md to override if it exists so existing users can adopt it incrementally in select directories. ❤️❤️❤️

randomor avatar Jun 05 '21 01:06 randomor

We need this! please!

fangyuqiang avatar Jul 30 '21 08:07 fangyuqiang

Here is my way to generate sidebar.

I write java code to do it.

The code in .zip file Generator.zip

Download it to docsify's directory which contains .md files. And unzip it.

unzip Generator.zip

Compile java code by javac

javac -encoding UTF-8 Generator.java

Generate sidebar to stdout

java Generator build-sidebar .

Anilople avatar Oct 24 '21 10:10 Anilople

@sy-records already added an initial version of this to docsify cli in https://github.com/docsifyjs/docsify-cli/pull/130

Sy, can you update the docs here for docsify.js.org? (might be a good reason to have cli in the same repo, so we can update the docs in the same pull request, etc).

trusktr avatar Jan 26 '22 17:01 trusktr

Ok, I will add it later.

Added it in docsify-cli before

see https://github.com/docsifyjs/docsify-cli#generate-command

sy-records avatar Jan 27 '22 00:01 sy-records