Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rstudio/nomnoml
Sassy 'UML' Diagrams for R
https://github.com/rstudio/nomnoml
diagrams htmlwidgets nomnoml r rstats uml
Last synced: 4 days ago
JSON representation
Sassy 'UML' Diagrams for R
- Host: GitHub
- URL: https://github.com/rstudio/nomnoml
- Owner: rstudio
- License: other
- Created: 2018-10-12T03:11:05.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-12-11T13:24:32.000Z (about 2 months ago)
- Last Synced: 2025-01-15T15:20:56.544Z (11 days ago)
- Topics: diagrams, htmlwidgets, nomnoml, r, rstats, uml
- Language: JavaScript
- Homepage: https://rstudio.github.io/nomnoml/
- Size: 5.44 MB
- Stars: 221
- Watchers: 7
- Forks: 18
- Open Issues: 2
-
Metadata Files:
- Readme: README.Rmd
- Changelog: NEWS.md
- License: LICENSE
Awesome Lists containing this project
- awesome-shiny-extensions - nomnoml - R interface to nomnoml, a tool for drawing sassy UML diagrams based on syntax with customizable styling. (Visualization / Diagrams)
- jimsghstars - rstudio/nomnoml - Sassy 'UML' Diagrams for R (JavaScript)
README
---
output:
github_document:
fig_width: 4
fig_height: 1
format: gfm
default-image-extension: ""
---```{r setup, include=FALSE}
library(nomnoml)
knitr::opts_chunk$set(eval = TRUE)
knitr::opts_chunk$set(fig.path = "man/figures/readme/", dev = "png")
```# nomnoml
[![CRAN status](https://www.r-pkg.org/badges/version/nomnoml)](https://CRAN.R-project.org/package=nomnoml)
[![CRAN RStudio mirror downloads](https://cranlogs.r-pkg.org/badges/nomnoml)](https://www.r-pkg.org/pkg/nomnoml)
[![R-CMD-check](https://github.com/rstudio/nomnoml/workflows/R-CMD-check/badge.svg)](https://github.com/rstudio/nomnoml/actions)
[![Codecov test coverage](https://codecov.io/gh/rstudio/nomnoml/branch/main/graph/badge.svg)](https://app.codecov.io/gh/rstudio/nomnoml?branch=main)
[![Lifecycle: experimental](https://img.shields.io/badge/lifecycle-experimental-orange.svg)](https://lifecycle.r-lib.org/articles/stages.html)**nomnoml** provides an R interface to [nomnoml.js](https://www.nomnoml.com/), a tool for drawing sassy UML diagrams based on syntax with customizable styling.
## Installation
Install from CRAN:
```{r eval=FALSE}
install.packages("nomnoml")
```Or from GitHub using:
```r
install.packages("remotes")
remotes::install_github("rstudio/nomnoml")
```**You need a chromium based browser installed on your system**
In previous releases of `nomnoml` (prior to v0.3.0) we used the `phantom.js` headless browser to capture screenshots. In version 0.3.0 we switched to using `webshot2`.
This means you need a chromium-based browser, e.g. Chromium itself, Chrome, Edge, Vivaldi, Brave, or Opera.
## Getting Started
You can create your first diagram by running:
```{r eval=FALSE}
nomnoml::nomnoml("[Hello]-[World!]")
``````{nomnoml nomnoml-simple, width="250px", height="75px", echo=FALSE}
[Hello]-[World!]
```To make the diagram flow vertically, the default at [nomnoml.com](https://www.nomnoml.com/), add the [direction](https://github.com/rstudio/nomnoml/issues/5) directive:
```{nomnoml nomnoml-vertical, width="200px", height="200px", echo=TRUE}
#direction: down
[Hello]-[World!]
```You can also use `nomnoml` in R Markdown:
````markdown
---
title: "A Diagram"
output: html_document
---`r ''````{r, setup, include=FALSE}
library(nomnoml)
````r ''````{nomnoml}
#stroke: orange
#.box: fill=#8f8 dashed visual=ellipse[A]-[B]-[C]
```
```````{nomnoml nomnoml-multiline, width="300px", height="100px", echo=FALSE}
#stroke: orange
#.highlight: fill=#8f8 dashed visual=ellipse[A]-[B]-[C]
```### SVG
To render using SVG, add `svg = TRUE`
```{r, eval=FALSE}
nomnoml(diagram, svg = TRUE)
```To render a `nomnoml` chunk in R Markdown, add `svg=TRUE` to the chunk options
````markdown
`r ''````{nomnoml, svg=TRUE}
#stroke: orange
#.box: fill=#8f8 dashed visual=ellipse[A]-[B]-[C]
```
```````{nomnoml nomnoml-svg, width="400px", height="100px", svg=TRUE, echo=FALSE}
#stroke: orange
#.highlight: fill=#8f8 dashed visual=ellipse[A]-[B]-[C]
```### Advanced
Notice that much more complex diagrams can be designed using `nomnoml` by
combining association types, classifier types, directives and custom
classifier styles.```{nomnoml nomnoml-decorator, width="250px", height="250px", svg=TRUE}
#stroke: #a86128
#direction: down
[Decorator pattern|
[Component||+ operation()]
[Client] depends --> [Component]
[Decorator|- next: Component]
[Decorator] decorates -- [ConcreteComponent]
[Component] <:- [Decorator]
[Component] <:- [ConcreteComponent]
]
```## Nomnoml documentation
### Association types
- association
-> association
<-> association
--> dependency
<--> dependency
-:> generalization
<:- generalization
--:> implementation
<:-- implementation
+- composition
+-> composition
o- aggregation
o-> aggregation
-o) ball and socket
o<-) ball and socket
->o ball and socket
-- note
-/- hidden
_> weightless edge
__ weightless dashed edge### Classifier types
[name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ lollipop]
[ name]
[ socket]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name]
[ name| a | 5 || b | 7]
### Directives
#import: my-common-styles.nomnoml
#arrowSize: 1
#bendSize: 0.3
#direction: down | right
#gutter: 5
#edgeMargin: 0
#gravity: 1
#edges: hard | rounded
#background: transparent
#fill: #eee8d5; #fdf6e3
#fillArrows: false
#font: Calibri
#fontSize: 12
#leading: 1.25
#lineWidth: 3
#padding: 8
#spacing: 40
#stroke: #33322E
#title: filename
#zoom: 1
#acyclicer: greedy
#ranker: network-simplex | tight-tree | longest-pathDirectives only available when using the command line interface
#import: my-common-styles.nomnoml
### Custom classifier styles
A directive that starts with "." define a classifier style.
#.box: fill=#88ff88
#.blob: fill=pink visual=ellipse italic bold dashed
[ GreenBox]
[ HideousBlob]Available key/value pairs:
fill=(any css color)
stroke=(any css color)
align=center
align=left
direction=right
direction=down
visual=actor
visual=class
visual=database
visual=ellipse
visual=end
visual=frame
visual=hidden
visual=input
visual=none
visual=note
visual=package
visual=receiver
visual=rhomb
visual=roundrect
visual=sender
visual=start
visual=table
visual=transceiverAvailable modifiers are
center
bold
underline
italic
dashed
empty