Plugin for TypeDoc that generates images for PlantUML diagrams embedded in comments.
Notes for this fork:
What I did so far:
- added support for automatically generating class diagrams from typescript source
- in case of local plantuml the RemoteURL is not first inserted and then searched & replaced again
- user can also specify another remote url
- added progress bar while generating uml
- added following configuration options:
--umlClassicHierarchy none,before,behind
--umlComplete none,simple,detail
--umlFormat png,svg
--umlHierarchy none,simple,detail,alldetail
--umlHierarchyDepthDown [-1,∞)
--umlHierarchyDepthUp [-1,∞)
--umlLocation /^local|remote|(?:https?:\/\/)?[^ "]*$/
--umlSeperateClassDetailView true|false
--umlShowSpot true|false
--umlTag true|false
--umlThreads [1,∞)
--umlVisibilityIcons none,ascii,graphic
- added lots of documentation for lots of changes
(Sorry, working on a business project - I am not allowed to share the fancier class diagrams, but it works - even multiple implements/extends-paths...)
What still is open, before I submit a pull request:
- I'd like to switch to typescript soon
- The test script is broken, I have to look into this...
- I'd like to add some more modularity (eventually after moving to TypeScript), if you agree
- The members-generation for class diagrams (generics, types, abstract, visibility) is not yet implemented
- Probably more, if it comes to my mind, I will add it.
- does it also work in --mode modules and with other templates?
The plugin can then be installed using npm:
$ npm install typedoc-plantuml --save-dev
TypeDoc automatically detects plugins installed via npm. After installation TypeDoc can be used normally and UML diagrams in comments will be processed.
The start of a UML diagram is indicated by the <uml>
tag and closed by the </uml>
tag. Alternate text for the
generated image can optionally be specified using the alt
attribute. For example <uml alt="Some diagram">
.
Note that the parser that finds the xml tags in the comment text is not very smart, so avoid unnecessary whitespace or other attributes to the tag.
The following is an example of embedding a sequence diagram in a class description.
/**
* Some class in a project.
*
* <uml>
* Bob->Alice : hello
* </uml>
*/
export class SomeClass {
}
You can view the generated documentation here.
Please refer to the plantuml website for a full reference on the supported UML syntax.
The following options are added to TypeDoc when the plugin is installed:
--umlLocation <local|remote>
Specifies the location of the generated uml images. Iflocal
then local image files are created in the assets directory of the generated documentation. Ifremote
then the image tag uses an encoded link to the plantuml server. Default islocal
.--umlFormat <png|svg>
Specifies the image format to use. Default is PNG.
Licensed under the Apache License 2.0.