Options

Configuration Structure

Options: {
theme: ThemeMode,
annotationBgColor: string,
annotationOrientation: Orientation,
annotations: Annotation[],
bgColor: string,
borderColor: string,
borderDashArray: number,
borderWidth: number,
label: AnnotationLabel,
fontColor: string,
fontFamily: string,
fontSize: string,
fontWeight: string,
orientation: Orientation,
text: string,
x1: string,
x2: null | string,
enableProjectBoundary: boolean,
arrowColor: string,
backgroundColor: string,
barBackgroundColor: string,
barBorderRadius: string,
barLabel: BarLabelOptions,
position: BarLabelPosition,
field: Task,
render: BarLabelRenderer,
className: string,
leadingPadding: number,
barMargin: number,
barTextColor: string,
summaryBarColor: string,
milestoneColor: string,
baseline: { ... },
enabled: boolean,
color: string,
dependencies: DependencyOptions,
cornerRadius: number,
hitWidth: number,
classBuilder: DependencyClassBuilder,
tooltipTemplate: DependencyTooltipTemplate,
borderColor: string,
canvasStyle: string,
criticalBarColor: string,
criticalArrowColor: string,
enableCriticalPath: boolean,
enableCrosshair: boolean,
crosshairColor: string,
crosshairLabelFormat: CrosshairLabelFormatter,
cellBorderColor: string,
cellBorderWidth: string,
columnConfig: ColumnListItem[],
key: ColumnKey | string,
title: string,
minWidth: string,
flexGrow: number,
visible: boolean,
render: ColumnRenderer,
accessor: Function,
columnLines: boolean,
enableRollups: boolean,
enableInlineEdit: boolean,
enableSelection: boolean,
enableExport: boolean,
enableResize: boolean,
enableTaskDrag: boolean,
enableTaskEdit: boolean,
enableTaskResize: boolean,
enableProgressDrag: boolean,
enableTooltip: boolean,
fontColor: string,
fontFamily: string,
fontSize: string,
fontWeight: string,
headerBackground: string,
height: number | string,
inputDateFormat: string,
rowBackgroundColors: string[],
rowHeight: number,
series: Array,
id: string,
name: string,
startTime: string,
endTime: string,
progress: number,
type: TaskType,
parentId: string,
dependency: string | TaskDependency,
barBackgroundColor: string,
rowBackgroundColor: string,
baseline: BaselineInput,
start: string,
end: string,
collapsed: boolean,
showSummaryBar: boolean,
assignees: Assignee[],
tasksContainerWidth: number,
tooltipBGColor: string,
tooltipBorderColor: string,
tooltipId: string,
tooltipTemplate: Function,
pixelsPerDay: number,
width: number | string,
parsing: ParsingConfig,
id: ParsingValue,
name: ParsingValue,
startTime: ParsingValue,
endTime: ParsingValue,
progress: ParsingValue,
type: ParsingValue,
parentId: ParsingValue,
dependency: ParsingValue,
barBackgroundColor: ParsingValue,
rowBackgroundColor: ParsingValue,
collapsed: ParsingValue,
showCheckboxColumn: boolean,
snapUnit: SnapUnit,
snapValue: number,
toolbarItems: ToolbarItem[],
taskListAriaLabel: string,
}

theme

Default: 'light'

Color theme preset.

Available Options:

  • light (default)
  • dark

width

Default: '100%'

Width of the chart. Accepts a pixel number or a CSS string.

height

Default: '500px'

Height of the chart. Accepts a pixel number or a CSS string.

canvasStyle

Default: 'border: 1px solid #CACED0; box-sizing: border-box'

Arbitrary CSS injected onto the root container element.

pixelsPerDay

Initial zoom level expressed as pixels per day. Continuous — the timeline header automatically picks calendar tiers (year, quarter, month, week, day, halfday, hour, minute) based on the current value. Bounds are clamped to roughly [0.25, 1280] px/day.

Reference values calibrated against the legacy presets:

  • Year ≈ 0.5
  • Quarter ≈ 1.6
  • Month ≈ 4.9
  • Week ≈ 25.7
  • Day = 80

When omitted, the chart auto-fits the full data range into the visible timeline area on first render. Supply an explicit value (or use the toolbar zoom controls) to take control.

backgroundColor

Default: '#FFFFFF'

Background color of the whole chart container.

headerBackground

Default: '#EBF3FB'

Background color of the timeline and task-list header row.

borderColor

Default: '#DFE0E1'

Color of the cell and row divider lines.

cellBorderColor

Default: '#D0D7DE'

Border color for all cells in the task table and timeline grid.

cellBorderWidth

Default: '1px'

CSS border-width for all cell lines.

columnLines

Default: true

Whether to draw vertical lines between timeline columns. Set to false for a cleaner aesthetic that keeps only the horizontal row dividers.

Available Options:

  • true (default)
  • false

inputDateFormat

Default: 'MM-DD-YYYY'

dayjs-compatible format string used to parse startTime / endTime values. Include time tokens (e.g. 'YYYY-MM-DD HH:mm') to enable sub-day scheduling; end-times are then treated as exclusive timestamps and inline editors switch to datetime-local inputs.

tasksContainerWidth

Default: 425

Initial pixel width of the task-list panel.

enableResize

Default: true

Allow the task-list panel to be resized by dragging the divider.

enableExport

Default: true

Show the SVG export button in the toolbar.

arrowColor

Default: '#94A3B8'

Color of dependency arrows between tasks.

barBackgroundColor

Default: '#87B7FE'

Default background fill color for task bars. Theme-aware: a different default applies in the dark theme.

barBorderRadius

Default: '5px'

CSS border-radius applied to task bars.

barMargin

Default: 8

Top and bottom margin inside each row for the task bar in pixels.

barTextColor

Default: '#FFFFFF'

Text color rendered inside task bars.

summaryBarColor

Default: '#B9CECE'

Fill color for summary (group) bars. Renders distinct from regular task bars to make the parent/child hierarchy visually obvious. Theme-aware.

milestoneColor

Default: '#7C3AED'

Fill color for milestone diamonds. Theme-aware.

barLabel

Per-task bar label. By default the task name renders to the right of the bar so narrow bars don't clip their text. Set position: 'inside' to render centered inside the bar, 'auto' to pick automatically based on bar width, or supply render to compose names with chips, icons, or owner info.

barLabel: {
  position: 'auto',
  render: (task) => `<span>${task.name} · ${task.progress}%</span>`,
}

position

Options.barLabel.position
Default: 'right'

Where to render the label relative to the bar.

Available Options:

  • right (default) — rendered immediately to the right of the bar; always visible regardless of bar width
  • inside — centered inside the bar; clipped when the bar is narrower than the text
  • left — rendered immediately to the left of the bar
  • autoinside when the label fits, otherwise right

field

Options.barLabel.field
Default: 'name'

Task field whose value populates the label when render is not set.

render

Options.barLabel.render

Custom renderer for the bar label. Receives the resolved task and returns an HTML string (assigned via innerHTML — escape user input yourself) or an HTMLElement. Returning null or undefined falls back to rendering barLabel.field.

className

Options.barLabel.className

Extra CSS class added to the label element.

leadingPadding

Options.barLabel.leadingPadding
Default: 0

Pixels of empty space added to the start of the timeline so left-side labels have room to render without being hidden behind the task-list panel. Auto-defaults to 120 when position is 'left', and 0 otherwise. Set explicitly to 0 to disable the padding.

rowBackgroundColors

Default: ['#FFFFFF']

Alternating row background colors. The pattern cycles automatically.

rowHeight

Default: 38

Height of each task row in pixels.

enableTaskDrag

Default: true

Allow tasks to be reordered by dragging rows in the task list.

enableTaskEdit

Default: false

Show the inline task-edit form when a task row is clicked.

enableInlineEdit

Default: false

Allow editing task fields directly in task-list cells. When true, double-clicking a name, startTime, endTime, duration, or progress cell swaps the cell for an input — commit with Enter or blur, cancel with Escape. Summary rows, milestones, and empty rows are not editable. Auto-enabled when enableTaskEdit is true unless explicitly set to false.

Available Options:

  • false (default)
  • true

enableTaskResize

Default: true

Allow task bars to be resized by dragging their handles.

enableProgressDrag

Default: true

Allow editing task progress by dragging the small handle at the bottom of the bar. The handle becomes visible on bar hover and snaps to whole percent on commit. Emits a taskProgressChanged event.

Available Options:

  • true (default)
  • false

snapUnit

Default: 'day'

Granularity at which task drag, resize, and inline edits snap. Affects data updates only — the timeline header tier follows pixelsPerDay independently. Use 'hour' or 'minute' together with snapValue for sub-day scheduling; end-times are treated as exclusive timestamps when inputDateFormat includes time tokens.

Available Options:

  • day (default)
  • hour
  • minute

snapValue

Default: 1

Multiplier applied to snapUnit. Examples: snapUnit: 'minute', snapValue: 15 snaps to 15-minute increments; snapUnit: 'hour', snapValue: 6 snaps to 6-hour increments.

enableSelection

Default: false

Enable row selection (click, Ctrl+Click, Shift+Click, keyboard).

showCheckboxColumn

Default: true

Show a checkbox column for multi-select. Only applies when enableSelection is true.

enableCriticalPath

Default: false

When true, calculates and highlights the critical path through dependent tasks.

criticalBarColor

Default: '#e53935'

Fill color for task bars on the critical path (requires enableCriticalPath: true).

criticalArrowColor

Default: '#e53935'

Stroke color for dependency arrows on the critical path.

enableRollups

Default: false

When true, summary (parent) rows display thin rollup markers below the summary bar at each leaf descendant's date range — a glance-able overview of children that stays visible even when the parent is collapsed.

Available Options:

  • false (default)
  • true

baseline

Baseline options. When enabled is true, tasks with a baseline field render a thin bar below the actual bar to show schedule variance.

enabled

Options.baseline.enabled
Default: false

Whether to render baseline bars below actual bars.

color

Options.baseline.color
Default: '#BBD5DA'

Color of the baseline bar.

dependencies

Visual and interaction options for dependency arrows. Tune cornerRadius for tighter or looser joints, set hitWidth to add an invisible thicker target zone for hover/click on thin strokes, and use tooltipTemplate / classBuilder for per-arrow content and styling.

dependencies: {
  cornerRadius: 6,
  hitWidth: 12,
  classBuilder: (ctx) => ctx.fromTask.team !== ctx.toTask.team ? 'cross-team' : '',
  tooltipTemplate: (ctx) => `<b>${ctx.fromTask.name}</b> → <b>${ctx.toTask.name}</b>`,
}

cornerRadius

Options.dependencies.cornerRadius
Default: 4

Pixel radius for rounded joints on dependency arrows. 0 produces sharp 90° corners; larger values produce smoother arcs (clamped per-corner to half the shorter adjacent segment so an arc never overshoots).

hitWidth

Options.dependencies.hitWidth
Default: 0

Invisible hit-area thickness in pixels. When greater than 0, each arrow renders an additional transparent path of this width that captures pointer events, making the thin visible stroke easier to hover or click. Required for tooltipTemplate to fire.

classBuilder

Options.dependencies.classBuilder

Returns CSS class name(s) for each arrow. Receives a DependencyContext (fromTask, toTask, type, lag) and returns a class name string, an array of class names, or undefined. Use to tag arrows by relationship — cross-team, blocked, optional — and style them via custom CSS.

tooltipTemplate

Options.dependencies.tooltipTemplate

Returns an HTML string shown when the user hovers an arrow. Receives a DependencyContext (fromTask, toTask, type, lag). Requires a non-zero hitWidth so the hover hit area is large enough to register reliably.

enableCrosshair

Default: false

Show a vertical crosshair line that follows the cursor across the timeline, with a label displaying the precise date or time at the pointer position.

Available Options:

  • false (default)
  • true

crosshairColor

Default: '#87B7FE'

Color of the crosshair line and label background. Theme-aware.

crosshairLabelFormat

Custom formatter for the crosshair label text. Receives the date under the cursor and the current sub-tier of the timeline header ('minute' | 'hour' | 'halfday' | 'day' | 'week' | 'month' | 'quarter' | 'year'). When omitted, the label auto-adapts to the active tier — coarse formats for week-and-above, HH:mm for halfday, hour, or minute tiers.

crosshairLabelFormat(date, tier) {
  return `${tier}: ${date.toISOString()}`;
}

enableTooltip

Default: true

Show a tooltip on task-bar hover.

tooltipId

Default: 'apexgantt-tooltip-container'

HTML id for the tooltip container element.

tooltipTemplate

Custom function returning an HTML string for the task tooltip.

tooltipTemplate(task, dateFormat) {
  return `
    <div>
      <div><strong>Task:</strong> ${task.name}</div>
      <div><strong>Start:</strong> ${task.startTime}</div>
      <div><strong>End:</strong> ${task.endTime}</div>
      <div><strong>Progress:</strong> ${task.progress}%</div>
    </div>
  `;
}

tooltipBGColor

Default: '#FFFFFF'

Background color of the hover tooltip.

tooltipBorderColor

Default: '#BCBCBC'

Border color of the hover tooltip.

fontColor

Default: '#000000'

Color for all text in the chart.

fontFamily

Default: 'sans-serif'

CSS font-family for the chart. Falls back to the page default when empty.

fontSize

Default: '14px'

CSS font-size for the chart.

fontWeight

Default: '400'

CSS font-weight for the chart.

annotationBgColor

Default: '#DBEAFE'

Background color of annotation markers.

annotationBorderColor

Default: '#60A5FA'

Border color of annotation markers.

annotationBorderDashArray

Default: []

SVG stroke-dasharray for annotation borders, e.g. [6, 3].

annotationBorderWidth

Default: 2

Border width of annotation markers in pixels.

annotationOrientation

Default: 'horizontal'

Whether annotation lines are drawn horizontally or vertically.

Available Options:

  • horizontal (default)
  • vertical

enableProjectBoundary

Default: false

When true, two vertical lines mark the project's earliest start and latest end across all rows. Auto-recomputes when tasks are added, removed, or rescheduled.

Available Options:

  • false (default)
  • true

projectBoundaryColor

Default: '#7C3AED'

Stroke color for the project-boundary lines. Falls back to annotationBorderColor when omitted.

columnConfig

Custom column definitions for the task-list panel. When omitted, all default columns are shown.

key

Options.columnConfig.key

Column identifier. Use a ColumnKey value for built-ins ('name', 'startTime', 'endTime', 'duration', 'progress', 'progressRing', 'wbs') or any other string for a custom column paired with a render function.

title

Options.columnConfig.title

Header label displayed at the top of the column.

minWidth

Options.columnConfig.minWidth

CSS min-width for the column, e.g. '120px'.

flexGrow

Options.columnConfig.flexGrow

CSS flex-grow factor for the column.

visible

Options.columnConfig.visible

Whether the column is visible. Defaults to true.

render

Options.columnConfig.render

Custom cell renderer. Required for custom columns; ignored for built-in columns. Receives a context object (task, options, rowIndex, isSummary, isMilestone) and the cell element. Return an HTML string to set innerHTML, return void if you mounted DOM yourself, or return a cleanup function () => void that the library will invoke on row eviction, full re-render, and destroy() — required for framework adapters (React.createRoot().unmount(), Vue.app.unmount(), etc.).

accessor

Options.columnConfig.accessor

Extracts the underlying value of the cell from the task. Used by SVG export and reserved for future sort/filter features.

toolbarItems

Default: []

Custom controls rendered in the toolbar alongside the built-in zoom and export buttons. Each item can be a ToolbarButton, ToolbarSelect, or ToolbarSeparator. Use position: 'left' to insert before the built-in controls (default is 'right').

taskListAriaLabel

Default: 'Task list'

aria-label for the task-list table, used by screen readers.

parsing

Field-mapping config to parse non-standard task shapes without manual data transformation.

parsing: {
  id: 'task_id',
  name: 'title',
  startTime: 'start_date',
  endTime: 'end_date',
  progress: { key: 'pct_complete', transform: Number },
}

id

Options.parsing.id

Path to the unique task identifier in the raw data object.

name

Options.parsing.name

Path to the task display name in the raw data object.

startTime

Options.parsing.startTime

Path to the task start date in the raw data object.

endTime

Options.parsing.endTime

Path to the task end date in the raw data object.

progress

Options.parsing.progress

Path to the task progress value in the raw data object.

type

Options.parsing.type

Path to the task type ('task' or 'milestone') in the raw data object.

parentId

Options.parsing.parentId

Path to the parent task ID in the raw data object.

dependency

Options.parsing.dependency

Path to the dependency field in the raw data object.

barBackgroundColor

Options.parsing.barBackgroundColor

Path to a per-task bar color override in the raw data object.

rowBackgroundColor

Options.parsing.rowBackgroundColor

Path to a per-task row background color override in the raw data object.

collapsed

Options.parsing.collapsed

Path to the collapsed state in the raw data object.

series

Task data array. Each item must satisfy TaskInput, or use parsing to map custom field names.

series: [
  {
    id: 'task-1',
    name: 'Design Phase',
    startTime: '01-01-2026',
    endTime: '01-15-2026',
    progress: 65,
  },
  {
    id: 'task-2',
    name: 'Development',
    startTime: '01-10-2026',
    endTime: '02-01-2026',
    parentId: 'task-1',
    progress: 30,
    dependency: 'task-1',
  },
]

id

Options.series.id

Unique identifier for the task. Must be stable across renders.

name

Options.series.name

Display name shown in the task list column and task bar.

startTime

Options.series.startTime

Task start date string. Parsed using inputDateFormat.

endTime

Options.series.endTime

Task end date string. Parsed using inputDateFormat. When omitted, the task renders as a milestone on startTime.

progress

Options.series.progress

Completion percentage (0–100). Renders a filled progress portion inside the task bar.

type

Options.series.type

Visual type of the task.

Available Options:

  • task — renders a bar (default)
  • milestone — renders a diamond marker

parentId

Options.series.parentId

ID of the parent task. Nested tasks are rendered as children in the task list.

dependency

Options.series.dependency

Dependency on another task. Accepts either a plain task ID string (treated as Finish-to-Start with 0 lag) or a full TaskDependency object for typed dependency with lag/lead support.

// Simple string dependency
dependency: 'task-2'

// Full dependency object
dependency: { taskId: 'task-2', type: 'FS', lag: 2 }

barBackgroundColor

Options.series.barBackgroundColor

Override the task bar fill color for this specific task.

rowBackgroundColor

Options.series.rowBackgroundColor

Override the row background color for this specific task row.

baseline

Options.series.baseline

Baseline (planned) dates for comparison against actual dates. Rendered as a thin bar below the actual task bar when baseline.enabled is true.

start

Options.series.baseline.start

Planned (baseline) start date of the task.

end

Options.series.baseline.end

Planned (baseline) end date of the task.

collapsed

Options.series.collapsed

Whether this task's child tasks are collapsed (hidden) in the task list.

showSummaryBar

Options.series.showSummaryBar

When true (the default), a task with children renders as a summary (group) bar whose date range is automatically computed from the earliest start and latest end of all its descendants — the task's own startTime / endTime are ignored. Drag, resize, and progress edits are disabled on summary bars. Set to false to opt the parent out of the auto-derived summary bar and render it as a normal task bar instead.

assignees

Options.series.assignees

People (or teams) assigned to this task. Consumed by the built-in renderers.avatars column renderer; ignored unless an avatar-style column is configured via columnConfig. Each Assignee carries name, optional avatarUrl, optional initials, and optional fallback color.

annotations

Array of annotation objects to overlay on the timeline.

annotations: [
  {
    x1: '01-15-2026',
    x2: '01-20-2026',
    label: { text: 'Sprint Review' },
  },
  {
    x1: '02-01-2026',
    label: { text: 'Deadline' },
  },
]

x1

Options.annotations.x1

Start date of annotation.

x2

Options.annotations.x2

End date of annotation. If present, draws a rect from x1 to x2. If null or omitted, only draws a line on x1.

bgColor

Options.annotations.bgColor

Background color of this annotation. Overrides the global annotationBgColor.

borderColor

Options.annotations.borderColor

Border color of this annotation. Overrides the global annotationBorderColor.

borderDashArray

Options.annotations.borderDashArray

SVG stroke-dasharray for this annotation's border.

borderWidth

Options.annotations.borderWidth

Border width of this annotation in pixels.

label

Options.annotations.label

Label configuration for the annotation.

text

Options.annotations.label.text

Label text for the annotation.

fontColor

Options.annotations.label.fontColor

Font color for the annotation label.

fontFamily

Options.annotations.label.fontFamily

Font family for the annotation label.

fontSize

Options.annotations.label.fontSize

Font size for the annotation label.

fontWeight

Options.annotations.label.fontWeight

Font weight for the annotation label.

orientation

Options.annotations.label.orientation

Text orientation of the annotation label.

Available Options:

  • horizontal
  • vertical