2022-10-17 23:58:51 -03:00
> **Warning**
>
> ## THIS IS AN AUTOGENERATED FILE. DO NOT EDIT.
>
2022-10-29 00:46:25 +05:30
> ## Please edit the corresponding file in [/packages/mermaid/src/docs/syntax/gantt.md](../../packages/mermaid/src/docs/syntax/gantt.md).
2022-09-03 13:05:47 +05:30
2022-09-03 09:13:37 +05:30
# Gantt diagrams
> A Gantt chart is a type of bar chart, first developed by Karol Adamiecki in 1896, and independently by Henry Gantt in the 1910s, that illustrates a project schedule and the amount of time it would take for any one project to finish. Gantt charts illustrate number of days between the start and finish dates of the terminal elements and summary elements of a project.
## A note to users
Gantt Charts will record each scheduled task as one continuous bar that extends from the left to the right. The x axis represents time and the y records the different tasks and the order in which they are to be completed.
It is important to remember that when a date, day, or collection of dates specific to a task are "excluded", the Gantt Chart will accommodate those changes by extending an equal number of days, towards the right, not by creating a gap inside the task.
As shown here ![](./img/Gantt-excluded-days-within.png)
However, if the excluded dates are between two tasks that are set to start consecutively, the excluded dates will be skipped graphically and left blank, and the following task will begin after the end of the excluded dates.
As shown here ![](./img/Gantt-long-weekend-look.png)
A Gantt chart is useful for tracking the amount of time it would take before a project is finished, but it can also be used to graphically represent "non-working days", with a few tweaks.
Mermaid can render Gantt diagrams as SVG, PNG or a MarkDown link that can be pasted into docs.
```mermaid-example
gantt
title A Gantt Diagram
2023-07-08 10:45:36 +09:00
dateFormat YYYY-MM-DD
2022-09-03 09:13:37 +05:30
section Section
2023-07-08 10:45:36 +09:00
A task :a1, 2014-01-01, 30d
Another task :after a1, 20d
2022-09-03 09:13:37 +05:30
section Another
2023-07-08 10:45:36 +09:00
Task in Another :2014-01-12, 12d
another task :24d
2022-09-03 09:13:37 +05:30
```
```mermaid
gantt
title A Gantt Diagram
2023-07-08 10:45:36 +09:00
dateFormat YYYY-MM-DD
2022-09-03 09:13:37 +05:30
section Section
2023-07-08 10:45:36 +09:00
A task :a1, 2014-01-01, 30d
Another task :after a1, 20d
2022-09-03 09:13:37 +05:30
section Another
2023-07-08 10:45:36 +09:00
Task in Another :2014-01-12, 12d
another task :24d
2022-09-03 09:13:37 +05:30
```
## Syntax
```mermaid-example
gantt
dateFormat YYYY-MM-DD
title Adding GANTT diagram functionality to mermaid
excludes weekends
%% (`excludes` accepts specific dates in YYYY-MM-DD format, days of the week ("sunday") or "weekends", but not the word "weekdays".)
section A section
Completed task :done, des1, 2014-01-06,2014-01-08
Active task :active, des2, 2014-01-09, 3d
Future task : des3, after des2, 5d
Future task2 : des4, after des3, 5d
section Critical tasks
Completed task in the critical line :crit, done, 2014-01-06,24h
Implement parser and jison :crit, done, after des1, 2d
Create tests for parser :crit, active, 3d
Future task in critical line :crit, 5d
Create tests for renderer :2d
Add to mermaid :1d
Functionality added :milestone, 2014-01-25, 0d
section Documentation
Describe gantt syntax :active, a1, after des1, 3d
Add gantt diagram to demo page :after a1 , 20h
Add another diagram to demo page :doc1, after a1 , 48h
section Last section
Describe gantt syntax :after doc1, 3d
Add gantt diagram to demo page :20h
Add another diagram to demo page :48h
```
```mermaid
gantt
dateFormat YYYY-MM-DD
title Adding GANTT diagram functionality to mermaid
excludes weekends
%% (`excludes` accepts specific dates in YYYY-MM-DD format, days of the week ("sunday") or "weekends", but not the word "weekdays".)
section A section
Completed task :done, des1, 2014-01-06,2014-01-08
Active task :active, des2, 2014-01-09, 3d
Future task : des3, after des2, 5d
Future task2 : des4, after des3, 5d
section Critical tasks
Completed task in the critical line :crit, done, 2014-01-06,24h
Implement parser and jison :crit, done, after des1, 2d
Create tests for parser :crit, active, 3d
Future task in critical line :crit, 5d
Create tests for renderer :2d
Add to mermaid :1d
Functionality added :milestone, 2014-01-25, 0d
section Documentation
Describe gantt syntax :active, a1, after des1, 3d
Add gantt diagram to demo page :after a1 , 20h
Add another diagram to demo page :doc1, after a1 , 48h
section Last section
Describe gantt syntax :after doc1, 3d
Add gantt diagram to demo page :20h
Add another diagram to demo page :48h
```
It is possible to set multiple dependencies separated by space:
```mermaid-example
2023-07-08 10:45:36 +09:00
gantt
apple :a, 2017-07-20, 1w
banana :crit, b, 2017-07-23, 1d
cherry :active, c, after b a, 1d
2022-09-03 09:13:37 +05:30
```
```mermaid
2023-07-08 10:45:36 +09:00
gantt
apple :a, 2017-07-20, 1w
banana :crit, b, 2017-07-23, 1d
cherry :active, c, after b a, 1d
2022-09-03 09:13:37 +05:30
```
2022-09-05 19:48:38 +05:30
### Title
2022-09-03 13:05:47 +05:30
The `title` is an _optional_ string to be displayed at the top of the Gantt chart to describe the chart as a whole.
2022-09-03 09:13:37 +05:30
### Section statements
You can divide the chart into various sections, for example to separate different parts of a project like development and documentation.
2022-09-03 13:05:47 +05:30
To do so, start a line with the `section` keyword and give it a name. (Note that unlike with the [title for the entire chart ](#title ), this name is _required_ .
2022-09-03 09:13:37 +05:30
### Milestones
2022-09-03 13:05:47 +05:30
You can add milestones to the diagrams. Milestones differ from tasks as they represent a single instant in time and are identified by the keyword `milestone` . Below is an example on how to use milestones. As you may notice, the exact location of the milestone is determined by the initial date for the milestone and the "duration" of the task this way: _initial date_ +_duration_/2.
2022-09-03 09:13:37 +05:30
```mermaid-example
2022-09-03 13:05:47 +05:30
gantt
2023-07-08 10:45:36 +09:00
dateFormat HH:mm
axisFormat %H:%M
Initial milestone : milestone, m1, 17:49, 2m
Task A : 10m
Task B : 5m
Final milestone : milestone, m2, 18:08, 4m
2022-09-03 09:13:37 +05:30
```
2022-09-05 19:48:38 +05:30
```mermaid
gantt
2023-07-08 10:45:36 +09:00
dateFormat HH:mm
axisFormat %H:%M
Initial milestone : milestone, m1, 17:49, 2m
Task A : 10m
Task B : 5m
Final milestone : milestone, m2, 18:08, 4m
2022-09-05 19:48:38 +05:30
```
2022-09-03 09:13:37 +05:30
## Setting dates
`dateFormat` defines the format of the date **input** of your gantt elements. How these dates are represented in the rendered chart **output** are defined by `axisFormat` .
### Input date format
The default input date format is `YYYY-MM-DD` . You can define your custom `dateFormat` .
2022-12-11 20:53:14 -08:00
```markdown
dateFormat YYYY-MM-DD
```
2022-09-03 09:13:37 +05:30
The following formatting options are supported:
2022-12-21 11:24:48 -08:00
| Input | Example | Description |
| ---------- | -------------- | ------------------------------------------------------ |
| `YYYY` | 2014 | 4 digit year |
| `YY` | 14 | 2 digit year |
| `Q` | 1..4 | Quarter of year. Sets month to first month in quarter. |
| `M MM` | 1..12 | Month number |
refactor(deps): replace `moment` with `dayjs`
Replace Mermaid's dependency on `moment` with `dayjs`.
[Moment is now in maintenance mode][1], and they don't recommend
using it.
[Dayjs][2] has almost exactly the same API as moment, and is still
curently being maintained. Unlike moment, dayjs objects are immutable,
which makes our life much easier, but we need to do
`a = a.add(1, "day")` instead of just `a.add(1, "day")`.
We can't use `dayjs.duration`, because unlike `moment.duration`,
[dayjs durations always degrade to ms][3].
This causes issues with daylight savings, since it assumes that each
day is 24 hours, when some days have 23/25 hours with daylight savings.
(it also assumes that each month is 30 days).
However, `dayjs.add(1, "d");` correctly adds 1 days, even when that
day is only 23 hours long, so we can use that instead.
[1]: https://momentjs.com/docs/#/-project-status/
[2]: https://day.js.org/
[3]: https://day.js.org/docs/en/durations/durations
2023-02-16 20:17:57 +00:00
| `MMM MMMM` | January..Dec | Month name in locale set by `dayjs.locale()` |
2022-12-21 11:24:48 -08:00
| `D DD` | 1..31 | Day of month |
| `Do` | 1st..31st | Day of month with ordinal |
| `DDD DDDD` | 1..365 | Day of year |
| `X` | 1410715640.579 | Unix timestamp |
| `x` | 1410715640579 | Unix ms timestamp |
| `H HH` | 0..23 | 24 hour time |
| `h hh` | 1..12 | 12 hour time used with `a A` . |
| `a A` | am pm | Post or ante meridiem |
| `m mm` | 0..59 | Minutes |
| `s ss` | 0..59 | Seconds |
| `S` | 0..9 | Tenths of a second |
| `SS` | 0..99 | Hundreds of a second |
| `SSS` | 0..999 | Thousandths of a second |
| `Z ZZ` | +12:00 | Offset from UTC as +-HH:mm, +-HHmm, or Z |
2022-09-03 09:13:37 +05:30
refactor(deps): replace `moment` with `dayjs`
Replace Mermaid's dependency on `moment` with `dayjs`.
[Moment is now in maintenance mode][1], and they don't recommend
using it.
[Dayjs][2] has almost exactly the same API as moment, and is still
curently being maintained. Unlike moment, dayjs objects are immutable,
which makes our life much easier, but we need to do
`a = a.add(1, "day")` instead of just `a.add(1, "day")`.
We can't use `dayjs.duration`, because unlike `moment.duration`,
[dayjs durations always degrade to ms][3].
This causes issues with daylight savings, since it assumes that each
day is 24 hours, when some days have 23/25 hours with daylight savings.
(it also assumes that each month is 30 days).
However, `dayjs.add(1, "d");` correctly adds 1 days, even when that
day is only 23 hours long, so we can use that instead.
[1]: https://momentjs.com/docs/#/-project-status/
[2]: https://day.js.org/
[3]: https://day.js.org/docs/en/durations/durations
2023-02-16 20:17:57 +00:00
More info in: < https: / / day . js . org / docs / en / parse / string-format / >
2022-09-03 09:13:37 +05:30
### Output date format on the axis
2022-11-08 13:53:18 +01:00
The default output date format is `YYYY-MM-DD` . You can define your custom `axisFormat` , like `2020-Q1` for the first quarter of the year 2020.
2022-09-03 09:13:37 +05:30
2022-12-11 20:53:14 -08:00
```markdown
axisFormat %Y-%m-%d
```
2022-09-03 09:13:37 +05:30
The following formatting strings are supported:
2022-12-21 11:24:48 -08:00
| Format | Definition |
| ------ | ------------------------------------------------------------------------------------------ |
| %a | abbreviated weekday name |
| %A | full weekday name |
| %b | abbreviated month name |
| %B | full month name |
| %c | date and time, as "%a %b %e %H:%M:%S %Y" |
| %d | zero-padded day of the month as a decimal number \[01,31] |
| %e | space-padded day of the month as a decimal number \[ 1,31]; equivalent to %\_d |
| %H | hour (24-hour clock) as a decimal number \[00,23] |
| %I | hour (12-hour clock) as a decimal number \[01,12] |
| %j | day of the year as a decimal number \[001,366] |
| %m | month as a decimal number \[01,12] |
| %M | minute as a decimal number \[00,59] |
| %L | milliseconds as a decimal number \[000, 999] |
| %p | either AM or PM |
| %S | second as a decimal number \[00,61] |
| %U | week number of the year (Sunday as the first day of the week) as a decimal number \[00,53] |
| %w | weekday as a decimal number \[0(Sunday),6] |
| %W | week number of the year (Monday as the first day of the week) as a decimal number \[00,53] |
| %x | date, as "%m/%d/%Y" |
| %X | time, as "%H:%M:%S" |
| %y | year without century as a decimal number \[00,99] |
| %Y | year with century as a decimal number |
| %Z | time zone offset, such as "-0700" |
| %% | a literal "%" character |
2022-09-03 09:13:37 +05:30
2022-11-08 13:53:18 +01:00
More info in: < https: // github . com / d3 / d3-time-format / tree / v4 . 0 . 0 #locale_format >
2022-09-03 09:13:37 +05:30
2022-10-27 16:43:44 +08:00
### Axis ticks
The default output ticks are auto. You can custom your `tickInterval` , like `1day` or `1week` .
2022-12-11 20:53:14 -08:00
```markdown
tickInterval 1day
```
2022-10-27 16:43:44 +08:00
The pattern is:
2022-12-21 11:24:48 -08:00
```javascript
/^([1-9][0-9]*)(minute|hour|day|week|month)$/;
2022-12-11 20:53:14 -08:00
```
2022-10-27 16:43:44 +08:00
More info in: < https: // github . com / d3 / d3-time #interval_every >
2023-03-24 00:09:06 +01:00
## Output in compact mode
2023-03-25 01:56:50 +01:00
The compact mode allows you to display multiple tasks in the same row. Compact mode can be enabled for a gantt chart by setting the display mode of the graph via preceeding YAML settings.
2023-03-24 00:09:06 +01:00
```mermaid-example
2023-03-25 01:56:50 +01:00
---
displayMode: compact
---
2023-03-24 00:09:06 +01:00
gantt
title A Gantt Diagram
dateFormat YYYY-MM-DD
section Section
A task :a1, 2014-01-01, 30d
Another task :a2, 2014-01-20, 25d
Another one :a3, 2014-02-10, 20d
```
```mermaid
2023-03-25 01:56:50 +01:00
---
displayMode: compact
---
2023-03-24 00:09:06 +01:00
gantt
title A Gantt Diagram
dateFormat YYYY-MM-DD
section Section
A task :a1, 2014-01-01, 30d
Another task :a2, 2014-01-20, 25d
Another one :a3, 2014-02-10, 20d
```
2022-09-03 09:13:37 +05:30
## Comments
2023-03-24 00:09:06 +01:00
Comments can be entered within a gantt chart, 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 after the start of the comment to the next newline will be treated as a comment, including any diagram syntax.
2022-09-03 09:13:37 +05:30
2022-09-20 23:01:05 +05:30
```mermaid-example
gantt
title A Gantt Diagram
2023-07-08 10:45:36 +09:00
%% This is a comment
dateFormat YYYY-MM-DD
2022-09-20 23:01:05 +05:30
section Section
2023-07-08 10:45:36 +09:00
A task :a1, 2014-01-01, 30d
Another task :after a1, 20d
2022-09-20 23:01:05 +05:30
section Another
2023-07-08 10:45:36 +09:00
Task in Another :2014-01-12, 12d
another task :24d
2022-09-20 23:01:05 +05:30
```
```mermaid
2022-09-03 09:13:37 +05:30
gantt
title A Gantt Diagram
2023-07-08 10:45:36 +09:00
%% This is a comment
dateFormat YYYY-MM-DD
2022-09-03 09:13:37 +05:30
section Section
2023-07-08 10:45:36 +09:00
A task :a1, 2014-01-01, 30d
Another task :after a1, 20d
2022-09-03 09:13:37 +05:30
section Another
2023-07-08 10:45:36 +09:00
Task in Another :2014-01-12, 12d
another task :24d
2022-09-03 09:13:37 +05:30
```
## Styling
2022-11-04 11:45:20 +05:30
Styling of the Gantt diagram is done by defining a number of CSS classes. During rendering, these classes are extracted from the file located at src/diagrams/gantt/styles.js
2022-09-03 09:13:37 +05:30
### Classes used
2022-09-03 13:30:16 +05:30
| Class | Description |
| --------------------- | ---------------------------------------------------------------------- |
| grid.tick | Styling for the Grid Lines |
| grid.path | Styling for the Grid's borders |
| .taskText | Task Text Styling |
| .taskTextOutsideRight | Styling for Task Text that exceeds the activity bar towards the right. |
| .taskTextOutsideLeft | Styling for Task Text that exceeds the activity bar, towards the left. |
| todayMarker | Toggle and Styling for the "Today Marker" |
2022-09-03 09:13:37 +05:30
### Sample stylesheet
```css
.grid .tick {
2022-09-03 13:30:16 +05:30
stroke: lightgrey;
opacity: 0.3;
shape-rendering: crispEdges;
2022-09-03 09:13:37 +05:30
}
.grid path {
2022-09-03 13:30:16 +05:30
stroke-width: 0;
2022-09-03 09:13:37 +05:30
}
#tag {
2022-09-03 13:30:16 +05:30
color: white;
background: #fa283d ;
width: 150px;
position: absolute;
display: none;
padding: 3px 6px;
margin-left: -80px;
font-size: 11px;
2022-09-03 09:13:37 +05:30
}
#tag:before {
2022-09-03 13:30:16 +05:30
border: solid transparent;
content: ' ';
height: 0;
left: 50%;
margin-left: -5px;
position: absolute;
width: 0;
border-width: 10px;
border-bottom-color: #fa283d ;
top: -20px;
2022-09-03 09:13:37 +05:30
}
.taskText {
2022-09-03 13:30:16 +05:30
fill: white;
text-anchor: middle;
2022-09-03 09:13:37 +05:30
}
.taskTextOutsideRight {
2022-09-03 13:30:16 +05:30
fill: black;
text-anchor: start;
2022-09-03 09:13:37 +05:30
}
.taskTextOutsideLeft {
2022-09-03 13:30:16 +05:30
fill: black;
text-anchor: end;
2022-09-03 09:13:37 +05:30
}
```
## Today marker
You can style or hide the marker for the current date. To style it, add a value for the `todayMarker` key.
todayMarker stroke-width:5px,stroke:#0f0 ,opacity:0.5
To hide the marker, set `todayMarker` to `off` .
todayMarker off
## Configuration
It is possible to adjust the margins for rendering the gantt diagram.
This is done by defining the `ganttConfig` part of the configuration object.
2022-11-08 13:53:18 +01:00
How to use the CLI is described in the [mermaidCLI ](../config/mermaidCLI.md ) page.
2022-09-03 09:13:37 +05:30
mermaid.ganttConfig can be set to a JSON string with config parameters or the corresponding object.
```javascript
mermaid.ganttConfig = {
2022-09-03 13:30:16 +05:30
titleTopMargin: 25,
barHeight: 20,
barGap: 4,
topPadding: 75,
sidePadding: 75,
2022-09-03 13:05:47 +05:30
};
2022-09-03 09:13:37 +05:30
```
### Possible configuration params:
2022-09-03 13:30:16 +05:30
| Param | Description | Default value |
| --------------- | ------------------------------------------------------------------------------------------------------------------------------------------ | ------------- |
| mirrorActor | Turns on/off the rendering of actors below the diagram as well as above it | false |
| bottomMarginAdj | Adjusts how far down the graph ended. Wide borders styles with css could generate unwanted clipping which is why this config param exists. | 1 |
2022-09-03 09:13:37 +05:30
## Interaction
It is possible to bind a click event to a task. The click can lead to either a javascript callback or to a link which will be opened in the current browser tab. **Note** : This functionality is disabled when using `securityLevel='strict'` and enabled when using `securityLevel='loose'` .
click taskId call callback(arguments)
click taskId href URL
2022-09-03 13:30:16 +05:30
- taskId is the id of the task
- callback is the name of a javascript function defined on the page displaying the graph, the function will be called with the taskId as the parameter if no other arguments are specified.
2022-09-03 09:13:37 +05:30
Beginner's tip—a full example using interactive links in an html context:
```html
< body >
2022-09-05 01:25:28 +05:30
< pre class = "mermaid" >
gantt
dateFormat YYYY-MM-DD
section Clickable
2023-07-08 10:45:36 +09:00
Visit mermaidjs :active, cl1, 2014-01-07, 3d
2022-09-05 01:25:28 +05:30
Print arguments :cl2, after cl1, 3d
Print task :cl3, after cl2, 3d
click cl1 href "https://mermaidjs.github.io/"
click cl2 call printArguments("test1", "test2", test3)
click cl3 call printTask()
< / pre >
2022-09-03 13:30:16 +05:30
< script >
2022-10-09 22:08:32 +08:00
const printArguments = function (arg1, arg2, arg3) {
2022-09-03 13:30:16 +05:30
alert('printArguments called with arguments: ' + arg1 + ', ' + arg2 + ', ' + arg3);
};
2022-10-09 22:08:32 +08:00
const printTask = function (taskId) {
2022-09-03 13:30:16 +05:30
alert('taskId: ' + taskId);
};
2022-10-09 22:08:32 +08:00
const config = {
2022-09-03 13:30:16 +05:30
startOnLoad: true,
securityLevel: 'loose',
};
mermaid.initialize(config);
< / script >
2022-09-03 09:13:37 +05:30
< / body >
```
2023-04-05 11:26:28 +10:00
2023-04-05 11:31:44 +10:00
## Examples
### Bar chart (using gantt chart)
```mermaid-example
gantt
title Git Issues - days since last update
dateFormat X
2023-04-05 13:11:22 +10:00
axisFormat %s
section Issue19062
2023-04-05 11:31:44 +10:00
71 : 0, 71
section Issue19401
36 : 0, 36
section Issue193
34 : 0, 34
section Issue7441
9 : 0, 9
section Issue1300
5 : 0, 5
```
2023-04-05 11:26:28 +10:00
```mermaid
gantt
2023-04-05 11:31:44 +10:00
title Git Issues - days since last update
2023-04-05 11:26:28 +10:00
dateFormat X
axisFormat %s
section Issue19062
71 : 0, 71
section Issue19401
2023-04-05 13:11:22 +10:00
36 : 0, 36
section Issue193
2023-04-05 11:26:28 +10:00
34 : 0, 34
section Issue7441
2023-04-05 11:31:44 +10:00
9 : 0, 9
2023-04-05 11:26:28 +10:00
section Issue1300
5 : 0, 5
```