realm / jazzy

Soulful docs for Swift & Objective-C
https://realm.io
MIT License
7.35k stars 413 forks source link

Group top-level declarations by folder structure #105

Open luketheobscure opened 9 years ago

luketheobscure commented 9 years ago

I'm looking into using Jazzy to document an app, and it sure would be nice to split the lefthand menu into logical groups like the folder structure of the app. It's not that helpful to see the app delegate in the same view as the models and view controllers.

I'm not sure what this feature would look like... An inline directive for jazzy in the comment? A command line argument that looks for folder names?

jpsim commented 9 years ago

It would be awesome to parse the project's directory structure to group top-level declarations together. This would have to be type-agnostic (functions, classes, enums, structs, etc.) rather than just for classes.

Depending on the project (e.g. app vs library), the menu on the left might be better structured or flat. Perhaps both should always be available by toggling a switch in the docs' UI? Or maybe there should be a command line argument to explicitly specify to use directory structure like you mentioned.

Do you have any further thoughts as to how this might work, @luketheobscure?

jpsim commented 9 years ago

We'd have to determine how arbitrarily-deep nested subfolders are handled. Given how little horizontal space there is in the current design, this could be tricky.

luketheobscure commented 9 years ago

In my use-case, grouping everything by folder would make a lot of sense. You can see the generated documentation for the app I'm working on here. Without the context of the "Model" folder, it's a little hard to know what some of the classes do. Once the inheritance tree is implemented, it will be a little bit easier, but having the folders show up would be rad.

pigeon-archive commented 7 years ago

What's the status on this?

jpsim commented 7 years ago

Custom Categories (#281) provide a way to control the grouping in the sidebar, which can be used to mirror the folder structure of a project, but is much more flexible than that.

ReSwift's docs uses this to great effect IMO:

image


However, that's not the same as offering a mode that automatically does this without the need to maintain custom_categories entries in the jazzy config file, which is why this ticket is still open.

No work has been done to do this automatically AFAICT.

pigeon-archive commented 7 years ago

Sounds good to me. I think the current functionality is a good middle ground for now. We can leave this feature on the back burner and (when we get around to it), write up a road map that could include this automatic functionality at a future time.