TL;DR:React components can be diagramming in a UML-like format, depicting Components, Component calls (with props and render props), Functions and Types or Interfaces.
After working on a Typescript diagram format I wanted to focus on a React equivalent.
Diagrams can be useful for various purposes:
In this article I'll describe a UML-influenced diagramming format for React.
The format consistent of the following elements:
A component is depicted with a depicted with a rectangle with <<Component>>
descriptor and title at the top and, optionally, props underneath.
A component can render another component – here this is referred to as a "component call".
A component call is depicted with a line from the caller component rectangle to the callee component rectangle, terminating in a filled arrow symbol.
A component can pass props to another component – here this is referred to as a "component call with props".
A component call with props is depicted with a line from the caller component rectangle to a props rectangle and another line from the props rectangle to the callee component rectangle, terminating in a filled arrow symbol.
The props are depicted in a props rectangle, in which each prop has its own rectangle. This allows any individual prop to be linked to a type, function or component rectangle.
Render props are props for which we pass a React component, a function which renders a component or a React node.
A render prop is depicted with a line from the prop box to a Component or Function rectangle, terminating in a dot symbol.
Same as in the Typescript diagram format, a function is depicted with a rectangle with <<Function>>
descriptor and title at the top and, optionally, parameters underneath.
Same as in the Typescript diagram format, a type or interface is depicted with a rectangle with <<Type>>
or <<Interface>>
descriptor and title at the top and, optionally, fields underneath.
A composition relationship between types or an inheritance relationship between interfaces is depicted with a line from the composer/inheritor to the composed/inherited type/interface, terminating in an empty arrow symbol.
A reference relationship between two components, functions, types or interfaces is depicted with a line from the referencer to the referenced, terminating in an arrow symbol.
Here's an example of a React diagram depicting components that make up a contacts list.
To make it easier to use this format, I've implemented them in the following formats, with downloadable templates: