2020-08-21 01:01:06 +08:00
# Class diagrams
2019-10-14 22:59:26 +02:00
2019-10-15 00:05:49 +02:00
> "In software engineering, a class diagram in the Unified Modeling Language (UML) is a type of static structure diagram that describes the structure of a system by showing the system's classes, their attributes, operations (or methods), and the relationships among objects."
2020-08-03 12:41:10 -07:00
> Wikipedia
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
The class diagram is the main building block of object-oriented modeling. It is used for general conceptual modeling of the structure of the application, and for detailed modeling to translate the models into programming code. Class diagrams can also be used for data modeling. The classes in a class diagram represent both the main elements, interactions in the application, and the classes to be programmed.
2019-10-14 22:59:26 +02:00
Mermaid can render class diagrams.
2021-11-01 20:18:18 -07:00
```mermaid-example
2022-05-13 15:59:35 -04:00
classDiagram
Animal < |-- Duck
Animal < |-- Fish
Animal < |-- Zebra
Animal : +int age
Animal : +String gender
Animal: +isMammal()
Animal: +mate()
class Duck{
+String beakColor
+swim()
+quack()
}
class Fish{
-int sizeInFeet
-canEat()
}
class Zebra{
+bool is_wild
+run()
}
2019-10-14 22:59:26 +02:00
```
## Syntax
### Class
UML provides mechanisms to represent class members, such as attributes and methods, and additional information about them.
2019-10-15 00:05:49 +02:00
A single instance of a class in the diagram contains three compartments:
2020-08-03 12:41:10 -07:00
- The top compartment contains the name of the class. It is printed in bold and centered, and the first letter is capitalized. It may also contain optional annotation text describing the nature of the class.
- The middle compartment contains the attributes of the class. They are left-aligned and the first letter is lowercase.
2022-02-08 00:02:40 +05:00
- The bottom compartment contains the operations the class can execute. They are also left-aligned and the first letter is lowercase.
2019-10-14 22:59:26 +02:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2019-10-14 22:59:26 +02:00
classDiagram
class BankAccount
2019-10-29 17:50:19 +01:00
BankAccount : +String owner
2019-10-14 22:59:26 +02:00
BankAccount : +Bigdecimal balance
BankAccount : +deposit(amount)
2022-06-26 05:12:35 -04:00
BankAccount : +withdrawal(amount)
2020-08-03 12:41:10 -07:00
2019-10-14 22:59:26 +02:00
```
2020-08-03 12:41:10 -07:00
2019-10-14 22:59:26 +02:00
## Define a class
There are two ways to define a class:
2020-08-03 12:41:10 -07:00
2022-08-19 17:55:50 +01:00
- Explicitly using keyword **class** like `class Animal` which would define the Animal class.
- Via a **relationship** which defines two classes at a time along with their relationship. For instance, `Vehicle <|-- Car` .
2019-10-14 22:59:26 +02:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2019-10-14 22:59:26 +02:00
classDiagram
class Animal
Vehicle < |-- Car
```
2019-10-29 17:50:19 +01:00
2022-08-19 17:55:50 +01:00
Naming convention: a class name should be composed only of alphanumeric characters (including unicode), and underscores.
2019-10-29 17:50:19 +01:00
2019-10-15 00:05:49 +02:00
## Defining Members of a class
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
UML provides mechanisms to represent class members such as attributes and methods, as well as additional information about them.
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
Mermaid distinguishes between attributes and functions/methods based on if the **parenthesis** `()` are present or not. The ones with `()` are treated as functions/methods, and all others as attributes.
2019-10-14 22:59:26 +02:00
2019-12-09 17:41:26 -08:00
There are two ways to define the members of a class, and regardless of whichever syntax is used to define the members, the output will still be same. The two different ways are :
2020-08-03 12:41:10 -07:00
2020-01-11 09:47:51 +01:00
- Associate a member of a class using ** :** (colon) followed by member name, useful to define one member at a time. For example:
2019-10-14 22:59:26 +02:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2022-05-13 15:59:35 -04:00
classDiagram
class BankAccount
BankAccount : +String owner
BankAccount : +BigDecimal balance
BankAccount : +deposit(amount)
BankAccount : +withdrawal(amount)
2020-08-03 12:41:10 -07:00
```
2019-10-15 00:05:49 +02:00
- Associate members of a class using ** {}** brackets, where members are grouped within curly brackets. Suitable for defining multiple members at once. For example:
2020-08-03 12:41:10 -07:00
2021-11-01 20:18:18 -07:00
```mermaid-example
classDiagram
2019-10-14 22:59:26 +02:00
class BankAccount{
2019-10-29 17:50:19 +01:00
+String owner
2019-10-14 22:59:26 +02:00
+BigDecimal balance
2021-02-25 22:11:51 +01:00
+deposit(amount)
2022-06-26 05:12:35 -04:00
+withdrawal(amount)
2019-10-14 22:59:26 +02:00
}
```
2020-08-03 12:41:10 -07:00
2020-01-13 16:04:26 -08:00
#### Return Type
2020-08-03 12:41:10 -07:00
2022-09-05 11:22:17 +02:00
Optionally you can end a method/function definition with the data type that will be returned (note: there must be a space between the final `)` and the return type). An example:
2020-08-03 12:41:10 -07:00
2021-11-01 20:18:18 -07:00
```mermaid-example
classDiagram
2020-01-13 16:04:26 -08:00
class BankAccount{
+String owner
+BigDecimal balance
+deposit(amount) bool
2022-06-26 05:12:35 -04:00
+withdrawal(amount) int
2020-01-13 16:04:26 -08:00
}
```
2020-08-03 12:41:10 -07:00
2020-01-13 16:04:26 -08:00
#### Generic Types
2020-08-03 12:41:10 -07:00
2022-08-19 17:55:50 +01:00
Members can be defined using generic types, such as `List<int>` , for fields, parameters, and return types by enclosing the type within `~` (**tilde**). Note: **nested** type declarations such as `List<List<int>>` are not currently supported.
2020-01-13 16:04:26 -08:00
2022-08-19 17:55:50 +01:00
Generics can be represented as part of a class definition and also in the parameters or the return value of a method/function:
2020-01-13 16:04:26 -08:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2020-01-13 16:04:26 -08:00
classDiagram
class Square~Shape~{
int id
List~int~ position
setPoints(List~int~ points)
getPoints() List~int~
}
Square : -List~string~ messages
Square : +setMessages(List~string~ messages)
Square : +getMessages() List~string~
```
2019-12-09 17:41:26 -08:00
2020-01-06 16:21:11 -08:00
#### Return Type
2020-08-03 12:41:10 -07:00
2022-08-19 17:55:50 +01:00
Optionally you can end the method/function definition with the data type that will be returned.
2020-01-06 16:21:11 -08:00
2019-12-09 17:41:26 -08:00
#### Visibility
2020-08-03 12:41:10 -07:00
2022-08-19 17:55:50 +01:00
To describe the visibility (or encapsulation) of an attribute or method/function that is a part of a class (i.e. a class member), optional notation may be placed before that members' name:
2019-12-09 17:41:26 -08:00
2020-08-03 12:41:10 -07:00
- `+` Public
- `-` Private
- `#` Protected
- `~` Package/Internal
2022-08-19 17:55:50 +01:00
> _note_ you can also include additional _classifiers_ to a method definition by adding the following notation to the _end_ of the method, i.e.: after the `()`:
2022-09-05 11:22:17 +02:00
>
2019-12-09 18:13:06 -08:00
> - `*` Abstract e.g.: `someAbstractMethod()*`
> - `$` Static e.g.: `someStaticMethod()$`
2019-12-09 17:41:26 -08:00
2022-08-19 17:55:50 +01:00
> _note_ you can also include additional _classifiers_ to a field definition by adding the following notation to the end of its name:
2022-09-05 11:22:17 +02:00
>
2021-09-28 17:06:48 -07:00
> - `$` Static e.g.: `String someField$`
2021-08-26 11:42:11 +02:00
2019-10-14 22:59:26 +02:00
## Defining Relationship
2020-08-03 12:41:10 -07:00
2020-01-11 09:47:51 +01:00
A relationship is a general term covering the specific types of logical connections found on class and object diagrams.
2020-08-03 12:41:10 -07:00
2021-11-01 20:18:18 -07:00
```
2021-10-03 15:10:15 -07:00
[classA][Arrow][ClassB]
2019-10-14 22:59:26 +02:00
```
2022-08-19 17:55:50 +01:00
There are eight different types of relations defined for classes under UML which are currently supported:
2019-10-14 22:59:26 +02:00
2020-08-03 12:41:10 -07:00
| Type | Description |
| ----- | ------------- |
| < \|-- | Inheritance |
| \*-- | Composition |
| o-- | Aggregation |
| --> | Association |
| -- | Link (Solid) |
| ..> | Dependency |
| ..\|> | Realization |
| .. | Link (Dashed) |
2019-10-14 22:59:26 +02:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2019-10-14 22:59:26 +02:00
classDiagram
classA < |-- classB
classC *-- classD
classE o-- classF
classG < -- classH
2020-01-02 19:35:22 +01:00
classI -- classJ
classK < .. classL
classM < |.. classN
classO .. classP
2019-10-14 22:59:26 +02:00
```
2020-08-03 12:41:10 -07:00
2022-08-19 17:55:50 +01:00
We can use the labels to describe the nature of the relation between two classes. Also, arrowheads can be used in the opposite direction as well:
2020-08-03 12:41:10 -07:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2019-10-14 22:59:26 +02:00
classDiagram
2020-01-02 19:35:22 +01:00
classA --|> classB : Inheritance
classC --* classD : Composition
classE --o classF : Aggregation
classG --> classH : Association
classI -- classJ : Link(Solid)
classK ..> classL : Dependency
classM ..|> classN : Realization
classO .. classP : Link(Dashed)
2019-10-14 22:59:26 +02:00
```
2021-10-03 15:10:15 -07:00
### Labels on Relations
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
It is possible to add label text to a relation:
2020-08-03 12:41:10 -07:00
2019-10-14 22:59:26 +02:00
```
[classA][Arrow][ClassB]:LabelText
```
2020-08-03 12:41:10 -07:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2019-10-14 22:59:26 +02:00
classDiagram
classA < |-- classB : implements
classC *-- classD : composition
2022-03-27 12:13:30 +02:00
classE o-- classF : aggregation
2019-10-14 22:59:26 +02:00
```
2020-08-03 12:41:10 -07:00
2021-10-03 15:10:15 -07:00
### Two-way relations
2022-08-19 17:55:50 +01:00
Relations can logically represent an N:M association:
2021-10-03 15:10:15 -07:00
2021-11-10 18:04:40 -08:00
```mmd
2021-10-03 15:10:15 -07:00
classDiagram
Animal < |--|> Zebra
```
Here is the syntax:
```
[Relation Type][Link][Relation Type]
```
Where `Relation Type` can be one of:
| Type | Description |
| ---- | ----------- |
| < \| | Inheritance |
| \* | Composition |
| o | Aggregation |
| > | Association |
2021-10-03 15:11:57 -07:00
| < | Association |
2021-10-03 15:10:15 -07:00
| \|> | Realization |
And `Link` can be one of:
| Type | Description |
| ---- | ----------- |
| -- | Solid |
| .. | Dashed |
2019-10-14 22:59:26 +02:00
## Cardinality / Multiplicity on relations
2020-08-03 12:41:10 -07:00
2022-08-19 17:55:50 +01:00
Multiplicity or cardinality in class diagrams indicates the number of instances of one class that can be linked to an instance of the other class. For example, each company will have one or more employees (not zero), and each employee currently works for zero or one companies.
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
Multiplicity notations are placed near the end of an association.
2019-10-14 22:59:26 +02:00
The different cardinality options are :
2020-08-03 12:41:10 -07:00
- `1` Only 1
- `0..1` Zero or One
- `1..*` One or more
- `*` Many
- `n` n {where n>1}
- `0..n` zero to n {where n>1}
- `1..n` one to n {where n>1}
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
Cardinality can be easily defined by placing the text option within quotes `"` before or after a given arrow. For example:
2020-08-03 12:41:10 -07:00
2019-10-14 22:59:26 +02:00
```
[classA] "cardinality1" [Arrow] "cardinality2" [ClassB]:LabelText
```
2020-08-03 12:41:10 -07:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2019-10-14 22:59:26 +02:00
classDiagram
Customer "1" --> "*" Ticket
Student "1" --> "1..*" Course
Galaxy --> "many" Star : Contains
```
2020-08-03 12:41:10 -07:00
2020-01-11 09:47:51 +01:00
## Annotations on classes
2019-10-14 22:59:26 +02:00
2022-09-05 11:22:17 +02:00
It is possible to annotate classes with markers to provide additional metadata about the class. This can give a clearer indication about its nature. Some common annotations include:
2020-08-03 12:41:10 -07:00
- `<<Interface>>` To represent an Interface class
2022-08-19 17:55:50 +01:00
- `<<Abstract>>` To represent an abstract class
2020-08-03 12:41:10 -07:00
- `<<Service>>` To represent a service class
2022-08-19 17:55:50 +01:00
- `<<Enumeration>>` To represent an enum
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
Annotations are defined within the opening `<<` and closing `>>` . There are two ways to add an annotation to a class, and either way the output will be same:
2020-08-03 12:41:10 -07:00
2022-08-19 17:55:50 +01:00
- In a **_separate line_** after a class is defined:
2020-08-03 12:41:10 -07:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2019-10-14 22:59:26 +02:00
classDiagram
class Shape
< < interface > > Shape
Shape : noOfVertices
Shape : draw()
```
2020-08-03 12:41:10 -07:00
2022-08-19 17:55:50 +01:00
- In a **_nested structure_** along with the class definition:
2019-10-14 22:59:26 +02:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2019-10-14 22:59:26 +02:00
classDiagram
class Shape{
< < interface > >
noOfVertices
draw()
}
2019-10-15 00:05:49 +02:00
class Color{
< < enumeration > >
RED
BLUE
GREEN
WHITE
BLACK
}
2019-10-14 22:59:26 +02:00
```
2019-11-26 15:34:52 -08:00
## Comments
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
Comments can be entered within a class diagram, which will be ignored by the parser. Comments need to be on their own line, and must be prefaced with `%%` (double percent signs). Any text until the next newline will be treated as a comment, including any class diagram syntax.
2019-11-26 15:34:52 -08:00
2021-11-10 18:04:40 -08:00
```mmd
2019-11-26 15:34:52 -08:00
classDiagram
%% This whole line is a comment classDiagram class Shape < < interface > >
class Shape{
< < interface > >
noOfVertices
draw()
}
```
2019-10-14 22:59:26 +02:00
2021-08-26 17:27:34 +02:00
## Setting the direction of the diagram
2022-08-19 17:55:50 +01:00
With class diagrams you can use the direction statement to set the direction in which the diagram will render:
2021-08-26 17:27:34 +02:00
2021-11-01 20:18:18 -07:00
```mermaid-example
2021-08-26 17:27:34 +02:00
classDiagram
direction RL
class Student {
-idCard : IdCard
}
class IdCard{
-id : int
-name : string
}
class Bike{
-id : int
-name : string
}
Student "1" --o "1" IdCard : carries
Student "1" --o "1" Bike : rides
2022-09-05 11:22:17 +02:00
```
2021-08-26 17:27:34 +02:00
2020-01-03 10:14:07 -08:00
## Interaction
2022-08-19 17:55:50 +01:00
It is possible to bind a click event to a node. The click can lead to either a javascript callback or to a link which will be opened in a new browser tab. **Note** : This functionality is disabled when using `securityLevel='strict'` and enabled when using `securityLevel='loose'` .
2020-01-03 10:14:07 -08:00
2020-01-11 09:47:51 +01:00
You would define these actions on a separate line after all classes have been declared.
2020-01-03 10:14:07 -08:00
```
action className "reference" "tooltip"
2020-12-17 20:26:12 +01:00
click className call callback() "tooltip"
click className href "url" "tooltip"
2020-01-03 10:14:07 -08:00
```
2022-09-05 11:22:17 +02:00
2020-08-03 12:41:10 -07:00
- _action_ is either `link` or `callback` , depending on which type of interaction you want to have called
- _className_ is the id of the node that the action will be associated with
2020-12-17 20:26:12 +01:00
- _reference_ is either the url link, or the function name for callback.
2020-08-03 12:41:10 -07:00
- (_optional_) tooltip is a string to be displayed when hovering over element (note: The styles of the tooltip are set by the class .mermaidTooltip.)
2020-12-17 20:26:12 +01:00
- note: callback function will be called with the nodeId as parameter.
2020-01-03 10:14:07 -08:00
2020-08-03 12:41:10 -07:00
### Examples
2020-01-03 10:14:07 -08:00
2020-08-03 12:41:10 -07:00
_URL Link:_
2020-01-03 10:14:07 -08:00
2021-11-10 18:04:40 -08:00
```mmd
2020-01-03 10:14:07 -08:00
classDiagram
class Shape
2022-05-31 23:18:45 +02:00
link Shape "https://www.github.com" "This is a tooltip for a link"
2020-12-17 20:26:12 +01:00
class Shape2
2022-05-31 23:18:45 +02:00
click Shape2 href "https://www.github.com" "This is a tooltip for a link"
2020-01-03 10:14:07 -08:00
```
2020-08-03 12:41:10 -07:00
_Callback:_
2020-01-03 10:14:07 -08:00
2021-11-10 18:04:40 -08:00
```mmd
2020-01-03 10:14:07 -08:00
classDiagram
class Shape
callback Shape "callbackFunction" "This is a tooltip for a callback"
2020-12-17 20:26:12 +01:00
class Shape2
click Shape2 call callbackFunction() "This is a tooltip for a callback"
2020-01-03 10:14:07 -08:00
```
2021-11-01 20:18:18 -07:00
```html
2020-01-03 10:14:07 -08:00
< script >
2022-09-05 11:22:17 +02:00
var callbackFunction = function () {
alert('A callback was triggered');
};
2022-05-11 02:52:55 +02:00
< / script >
2020-01-03 10:14:07 -08:00
```
```mermaid
classDiagram
class Class01
class Class02
callback Class01 "callbackFunction" "Callback tooltip"
2022-05-31 23:18:45 +02:00
link Class02 "https://www.github.com" "This is a link"
2020-12-17 20:26:12 +01:00
class Class03
class Class04
click Class03 call callbackFunction() "Callback tooltip"
2022-05-31 23:18:45 +02:00
click Class04 href "https://www.github.com" "This is a link"
2020-01-03 10:14:07 -08:00
```
> **Success** The tooltip functionality and the ability to link to urls are available from version 0.5.2.
2022-08-19 17:55:50 +01:00
Beginner's tip—a full example using interactive links in an HTML page:
2020-08-03 12:41:10 -07:00
2021-10-31 14:45:41 -07:00
```html
2020-01-03 10:14:07 -08:00
< body >
2022-09-05 11:22:17 +02:00
< pre class = "mermaid" >
2020-01-03 10:14:07 -08:00
classDiagram
Animal < |-- Duck
Animal < |-- Fish
Animal < |-- Zebra
Animal : +int age
Animal : +String gender
Animal: +isMammal()
Animal: +mate()
class Duck{
+String beakColor
+swim()
+quack()
}
class Fish{
-int sizeInFeet
-canEat()
}
class Zebra{
+bool is_wild
+run()
}
2020-08-03 12:41:10 -07:00
callback Duck callback "Tooltip"
2022-05-31 23:18:45 +02:00
link Zebra "https://www.github.com" "This is a link"
2022-09-05 11:22:17 +02:00
< / pre >
2020-01-03 10:14:07 -08:00
< script >
2022-05-10 18:08:32 -07:00
var callback = function () {
2022-09-05 11:22:17 +02:00
alert('A callback was triggered');
2022-05-10 18:08:32 -07:00
};
var config = {
2022-09-05 11:22:17 +02:00
startOnLoad: true,
securityLevel: 'loose',
2022-05-10 18:08:32 -07:00
};
mermaid.initialize(config);
2020-01-03 10:14:07 -08:00
< / script >
< / body >
```
2019-10-14 22:59:26 +02:00
## Styling
2020-08-03 12:41:10 -07:00
### Styling a node
2022-08-19 17:55:50 +01:00
It is possible to apply specific styles such as a thicker border or a different background color to individual nodes. This is done by predefining classes in css styles that can be applied from the graph definition:
2019-10-14 22:59:26 +02:00
2020-08-03 12:41:10 -07:00
```html
< style >
2022-09-05 11:22:17 +02:00
.cssClass > rect {
fill: #ff0000 ;
stroke: #ffff00 ;
stroke-width: 4px;
}
2020-08-03 12:41:10 -07:00
< / style >
```
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
Then attaching that class to a specific node:
2019-10-14 22:59:26 +02:00
2020-08-03 12:41:10 -07:00
```
cssClass "nodeId1" cssClass;
```
2019-10-14 22:59:26 +02:00
2020-08-03 12:41:10 -07:00
It is also possible to attach a class to a list of nodes in one statement:
2019-10-14 22:59:26 +02:00
2020-08-03 12:41:10 -07:00
```
cssClass "nodeId1,nodeId2" cssClass;
```
2019-10-14 22:59:26 +02:00
2022-08-19 17:55:50 +01:00
A shorter form of adding a class is to attach the classname to the node using the `:::` operator:
2020-08-03 12:41:10 -07:00
2021-11-10 18:04:40 -08:00
```mmd
2020-08-03 12:41:10 -07:00
classDiagram
class Animal:::cssClass
```
Or:
2021-11-10 18:04:40 -08:00
```mmd
2020-08-03 12:41:10 -07:00
classDiagram
class Animal:::cssClass {
-int sizeInFeet
-canEat()
}
```
2020-08-04 12:05:56 -07:00
?> cssClasses cannot be added using this shorthand method at the same time as a relation statement.
2020-08-03 12:41:10 -07:00
2022-09-05 11:22:17 +02:00
?> Due to limitations with existing markup for class diagrams, it is not currently possible to define css classes within the diagram itself. **_Coming soon!_**
2020-08-03 12:41:10 -07:00
### Default Styles
The main styling of the class diagram is done with a preset number of css classes. During rendering these classes are extracted from the file located at src/themes/class.scss. The classes used here are described below:
| Class | Description |
| ------------------ | ----------------------------------------------------------------- |
| g.classGroup text | Styles for general class text |
| classGroup .title | Styles for general class title |
| g.classGroup rect | Styles for class diagram rectangle |
| g.classGroup line | Styles for class diagram line |
| .classLabel .box | Styles for class label box |
| .classLabel .label | Styles for class label text |
2020-10-14 14:41:15 +02:00
| composition | Styles for composition arrow head and arrow line |
2020-08-03 12:41:10 -07:00
| aggregation | Styles for aggregation arrow head and arrow line(dashed or solid) |
| dependency | Styles for dependency arrow head and arrow line |
#### Sample stylesheet
2019-10-14 22:59:26 +02:00
2020-09-07 14:02:09 +08:00
```scss
2019-10-14 22:59:26 +02:00
body {
2022-09-05 11:22:17 +02:00
background: white;
2019-10-14 22:59:26 +02:00
}
g.classGroup text {
2022-09-05 11:22:17 +02:00
fill: $nodeBorder;
stroke: none;
font-family: 'trebuchet ms', verdana, arial;
font-family: var(--mermaid-font-family);
font-size: 10px;
.title {
font-weight: bolder;
}
2019-10-14 22:59:26 +02:00
}
g.classGroup rect {
2022-09-05 11:22:17 +02:00
fill: $nodeBkg;
stroke: $nodeBorder;
2019-10-14 22:59:26 +02:00
}
g.classGroup line {
2022-09-05 11:22:17 +02:00
stroke: $nodeBorder;
stroke-width: 1;
2019-10-14 22:59:26 +02:00
}
.classLabel .box {
2022-09-05 11:22:17 +02:00
stroke: none;
stroke-width: 0;
fill: $nodeBkg;
opacity: 0.5;
2019-10-14 22:59:26 +02:00
}
.classLabel .label {
2022-09-05 11:22:17 +02:00
fill: $nodeBorder;
font-size: 10px;
2019-10-14 22:59:26 +02:00
}
.relation {
2022-09-05 11:22:17 +02:00
stroke: $nodeBorder;
stroke-width: 1;
fill: none;
2019-10-14 22:59:26 +02:00
}
@mixin composition {
2022-09-05 11:22:17 +02:00
fill: $nodeBorder;
stroke: $nodeBorder;
stroke-width: 1;
2019-10-14 22:59:26 +02:00
}
#compositionStart {
2022-09-05 11:22:17 +02:00
@include composition;
2019-10-14 22:59:26 +02:00
}
#compositionEnd {
2022-09-05 11:22:17 +02:00
@include composition;
2019-10-14 22:59:26 +02:00
}
@mixin aggregation {
2022-09-05 11:22:17 +02:00
fill: $nodeBkg;
stroke: $nodeBorder;
stroke-width: 1;
2019-10-14 22:59:26 +02:00
}
#aggregationStart {
2022-09-05 11:22:17 +02:00
@include aggregation;
2019-10-14 22:59:26 +02:00
}
#aggregationEnd {
2022-09-05 11:22:17 +02:00
@include aggregation;
2019-10-14 22:59:26 +02:00
}
#dependencyStart {
2022-09-05 11:22:17 +02:00
@include composition;
2019-10-14 22:59:26 +02:00
}
#dependencyEnd {
2022-09-05 11:22:17 +02:00
@include composition;
2019-10-14 22:59:26 +02:00
}
#extensionStart {
2022-09-05 11:22:17 +02:00
@include composition;
2019-10-14 22:59:26 +02:00
}
#extensionEnd {
2022-09-05 11:22:17 +02:00
@include composition;
2019-10-14 22:59:26 +02:00
}
```
## Configuration
2020-08-03 12:41:10 -07:00
`Coming soon`