JavaScript/jQuery Gantt Options
accessKey
The value of this property will be passed to the accesskey
attribute of the HTML element that underlies the UI component.
allowSelection
jQuery
$(function() { $("#gantt").dxGantt({ allowSelection: false, // ... }); });
Angular
<dx-gantt [allowSelection]="false"> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :allow-selection="false" > <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt allowSelection={false} > {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .AllowSelection(false) // ... )
ASP.NET MVC Controls
<!-- Razor C# --> @(Html.DevExtreme().Gantt() .AllowSelection(false) // ... )
See Also
columns
The columns property accepts an array of columns. To configure a column, use a dxTreeListColumn object or specify a data source field (as a string value) to which the column is bound.
jQuery
$(function() { $("#gantt").dxGantt({ columns: [{ dataField: "title", caption: "Subject", width: 300 }, { dataField: "start", caption: "Start Date" }, { dataField: "end", caption: "End Date" }], // ... }); });
Angular
<dx-gantt> <dxi-column dataField="title" caption="Subject" [width]="300"></dxi-column> <dxi-column dataField="start" caption="Start Date"></dxi-column> <dxi-column dataField="end" caption="End Date"></dxi-column> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :allow-selection="false" > <DxColumn :width="300" data-field="title" caption="Subject" /> <DxColumn data-field="start" caption="Start Date" /> <DxColumn data-field="end" caption="End Date" /> <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt, DxColumn // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt, DxColumn // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt <Column dataField="title" caption="Subject" width={300} /> <Column dataField="start" caption="Start Date" /> <Column dataField="end" caption="End Date" /> {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .Columns(columns => { columns.AddFor(m => m.Title) .Caption("Subject") .Width(300); columns.AddFor(m => m.Start) .Caption("Start Date"); columns.AddFor(m => m.End) .Caption("End Date"); }) // ... )
ASP.NET MVC Controls
@(Html.DevExtreme().Gantt() .Columns(columns => { columns.AddFor(m => m.Title) .Caption("Subject") .Width(300); columns.AddFor(m => m.Start) .Caption("Start Date"); columns.AddFor(m => m.End) .Caption("End Date"); }) // ... )
dependencies
Dependencies specify the relationships between tasks. The following image illustrates how the Gantt displays dependencies in the chart:
The Gantt UI component supports the following dependency types:
Finish to Start (FS) - The predecessor task's endpoint specifies the successor task's start point.
Start to Start (SS) - The predecessor task's start point specifies the successor task's start point.
Finish to Finish (FF) - The predecessor task's end point specifies the successor task's end point.
Start to Finish (SF) - The predecessor task's start point specifies the successor task's end point.
In a database, you can use any of the following formats (digit or string) to store dependency types:
Dependency Type | Supported Values |
---|---|
Finish to Start (FS) | 0, "0", "FS", "fs" |
Start to Start (SS) | 1, "1", "SS", "ss" |
Finish to Finish (FF) | 2, "2", "FF", "ff" |
Start to Finish (SF) | 3, "3", "SF", "sf" |
Use the dataSource property to bind the UI component to a data source, which contains information about dependency types. If the field names in your data source differ from the 'id', 'type', 'predecessorId' and 'successorId' default names, use the keyExpr, typeExpr properties to map data fields.
See Also
jQuery
$(function() { $("#gantt").dxGantt({ dependencies: { dataSource: dependencies, keyExpr: "dependencyId", typeExpr: "dependencyType", predecessorIdExpr: "taskPredecessorId", successorIdExpr: "taskSuccessorId" }, //... }); });
var dependencies = [{ 'dependencyId': 0, 'taskPredecessorId': 1, 'taskSuccessorId': 2, 'dependencyType': 0 }, // ... ];
Angular
<dx-gantt ... > <dxo-dependencies [dataSource]="dependencies" keyExpr="dependencyId" typeExpr="dependencyType" predecessorIdExpr="taskPredecessorId" successorIdExpr="taskSuccessorId" > </dxo-dependencies> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { dependencies: Dependency[]; // ... constructor(service: Service) { this.dependencies = service.getDependencies(); // ... } }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; import { Service, Dependency, ... } from './app.service'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], providers: [Service], bootstrap: [AppComponent] }) export class AppModule { }
import { Injectable } from '@angular/core'; export class Dependency { dependencyId: number; taskPredecessorId: number; taskSuccessorId: number; dependencyType: number; } let dependencies: Dependency[] = [{ 'dependencyId': 0, 'taskPredecessorId': 1, 'taskSuccessorId': 2, 'dependencyType': 0 }, // ... ]; @Injectable() export class Service { getDependencies(): Dependency[] { return dependencies; } }
{ "projects": { "ProjectName": { "architect": { "build": { "options": { "styles": [ "node_modules/devextreme/dist/css/dx.common.css", "node_modules/devextreme/dist/css/dx.light.css", "node_modules/devexpress-gantt/dist/dx-gantt.css", "src/styles.css" ], ... }, ... }, ... } }, ... }, ... }
Vue
<template> <DxGantt ... > <DxDependencies :data-source="dependencies" key-expr="dependencyId" type-expr="dependencyType" predecessor-id-expr="taskPredecessorId" successor-id-expr="taskSuccessorId" /> <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt, DxDependencies, // ... } from 'devextreme-vue/gantt'; import { dependencies, // ... } from './data.js'; export default { components: { DxGantt, DxDependencies, // ... }, data() { return { dependencies, // ... }; } }; </script>
export const dependencies = [{ 'dependencyId': 0, 'taskPredecessorId': 1, 'taskSuccessorId': 2, 'dependencyType': 0 }, // ... ];
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { Dependencies, // ... } from 'devextreme-react/gantt'; import { dependencies, // ... } from './data.js'; const App = () => { return ( <Gantt ... > <Dependencies dataSource={dependencies} keyExpr="dependencyId" typeExpr="dependencyType" predecessorIdExpr="taskPredecessorId" successorIdExpr="taskSuccessorId" /> {/* ... */} </Gantt> ); }; export default App;
export const dependencies = [{ 'dependencyId': 0, 'taskPredecessorId': 1, 'taskSuccessorId': 2, 'dependencyType': 0 }, // ... ];
ASP.NET Core Controls
@(Html.DevExtreme().Gantt<Gantt.Task>() .Dependencies(d => d .DataSource(ds => ds.Array().Data(SampleData.GanttDependencies).Key("ID")) .KeyExpr("ID") .PredecessorIdExpr("PredecessorId") .SuccessorIdExpr("SuccessorId") .TypeExpr("Type") ) // ... ) <!-- C# --> public partial class SampleData { public static readonly IEnumerable<Dependency> GanttDependencies = new[] { new Dependency { ID = 1, PredecessorId = 3, SuccessorId = 4, Type = 0 }, new Dependency { ID = 2, PredecessorId = 4, SuccessorId = 5, Type = 0 }, // ... } // ... }
ASP.NET MVC Controls
@(Html.DevExtreme().Gantt<Task>() .Dependencies(d => d .DataSource(ds => ds.Array().Data(SampleData.GanttDependencies).Key("ID")) .KeyExpr("ID") .PredecessorIdExpr("PredecessorId") .SuccessorIdExpr("SuccessorId") .TypeExpr("Type") ) // ... ) <!-- C# --> public partial class SampleData { public static readonly IEnumerable<Dependency> GanttDependencies = new[] { new Dependency { ID = 1, PredecessorId = 3, SuccessorId = 4, Type = 0 }, new Dependency { ID = 2, PredecessorId = 4, SuccessorId = 5, Type = 0 }, // ... } // ... }
editing
The UI component allows users to add, modify and delete tasks, resources and dependencies. Set the enabled property to true to enable edit functionality.
jQuery
$(function() { $("#gantt").dxGantt({ editing: { enabled: true, allowDependencyAdding: false, allowDependencyDeleting: false, allowResourceAdding: false, allowResourceDeleting: false, allowTaskAdding: false, allowTaskDeleting: false, allowTaskResourceUpdating: false, allowTaskUpdating: false } }); });
Angular
<dx-gantt ... > <dxo-editing [enabled]="true" [allowDependencyAdding]="false" [allowDependencyDeleting]="false" [allowResourceAdding]="false" [allowResourceDeleting]="false" [allowTaskAdding]="false" [allowTaskDeleting]="false" [allowTaskResourceUpdating]="false" [allowTaskUpdating]="false"> </dxo-editing> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt ... > <DxEditing :enabled="true" :allow-dependency-adding="false" :allow-dependency-deleting="false" :allow-resource-adding="false" :allow-resource-deleting="false" :allow-task-adding="false" :allow-task-deleting="false" :allow-task-resource-updating="false" :allow-task-updating="false" /> <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt, DxEditing, // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt, DxEditing, // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { Editing, // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt ... > <Editing enabled={true} allowDependencyAdding={false} allowDependencyDeleting={false} allowResourceAdding={false} allowResourceDeleting={false} allowTaskAdding={false} allowTaskDeleting={false} allowTaskResourceUpdating={false} allowTaskUpdating={false} /> {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .Editing(e => { e.Enabled(true) e.AllowDependencyAdding(false) e.AllowDependencyDeleting(false) e.AllowResourceAdding(false) e.AllowResourceDeleting(false) e.AllowTaskAdding(false) e.AllowTaskDeleting(false) e.AllowTaskResourceUpdating(false) e.AllowTaskUpdating(false) }) // ... )
See Also
elementAttr
Specifies the global attributes to be attached to the UI component's container element.
jQuery
$(function(){ $("#ganttContainer").dxGantt({ // ... elementAttr: { id: "elementId", class: "class-name" } }); });
Angular
<dx-gantt ... [elementAttr]="{ id: 'elementId', class: 'class-name' }"> </dx-gantt>
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { // ... } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
Vue
<template> <DxGantt ... :element-attr="ganttAttributes"> </DxGantt> </template> <script> import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, data() { return { ganttAttributes: { id: 'elementId', class: 'class-name' } } } } </script>
React
import React from 'react'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { ganttAttributes = { id: 'elementId', class: 'class-name' } render() { return ( <Gantt ... elementAttr={this.ganttAttributes}> </Gantt> ); } } export default App;
firstDayOfWeek
The property's value can be from 0 to 6.
- 0 - Sunday
- 1 - Monday
- 2 - Tuesday
- 3 - Wednesday
- 4 - Thursday
- 5 - Friday
- 6 - Saturday
The culture settings specify the property's default value.
jQuery
$(function() { $("#gantt").dxGantt({ firstDayOfWeek: 1, // ... }); });
Angular
<dx-gantt [firstDayOfWeek]="1"> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :first-day-of-week="1" > <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt firstDayOfWeek={1} > {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .FirstDayOfWeek(FirstDayOfWeek.Monday) // ... )
ASP.NET MVC Controls
@(Html.DevExtreme().Gantt() .FirstDayOfWeek(FirstDayOfWeek.Monday) // ... )
height
This property accepts a value of one of the following types:
Number
The height in pixels.String
A CSS-accepted measurement of height. For example,"55px"
,"80%"
,"inherit"
.Function
A function returning either of the above. For example:JavaScriptheight: function() { return window.innerHeight / 1.5; }
onContentReady
A function that is executed when the UI component's content is ready and each time the content is changed.
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
Model data. Available only when using Knockout. |
onContextMenuPreparing
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel showing the context menu. |
|
component |
The UI component's instance. |
|
data | any |
Data of the right-clicked task or dependency. |
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
event | Event (jQuery or EventObject) |
The event that caused the function to execute. It is a dxEvent or a jQuery.Event when you use jQuery. |
items |
Items to be displayed in the context menu. |
|
targetKey | any |
The key of the right-clicked task or dependency. |
targetType |
The type of right-clicked task or dependency. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onContextMenuPreparing: function (e) { // your code e.cancel = true; } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onContextMenuPreparing(e) { // your code e.cancel = true; } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onContextMenuPreparing)="onContextMenuPreparing($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @context-menu-preparing="onContextMenuPreparing" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onContextMenuPreparing(e) { // your code e.cancel = true; } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onContextMenuPreparing={this.onContextMenuPreparing} /> ); } onContextMenuPreparing = (e) => { // your code e.cancel = true; } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onContextMenuPreparing("gantt_contextMenuPreparing_handler") // ... ) <script> function gantt_contextMenuPreparing_handler(e) { // your code e.cancel = true; } </script>
See Also
onCustomCommand
A function that is executed after a custom command item was clicked. Allows you to implement a custom command's functionality.
Name | Type | Description |
---|---|---|
component |
The UI component instance's name. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
name |
The name of the clicked item. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onCustomCommand: function (e) { // your code } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onCustomCommand(e) { // your code } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onCustomCommand)="onCustomCommand($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @custom-command="onCustomCommand" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onCustomCommand(e) { // your code } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onCustomCommand={this.onCustomCommand} /> ); } onCustomCommand = (e) => { // your code } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onCustomCommand("gantt_customCommand_handler") // ... ) <script> function gantt_customCommand_handler(e) { // your code } </script>
See Also
onDependencyDeleted
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the deleted dependency. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the deleted dependency. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onDependencyDeleted: function (e) { if (e.key != 1) // your code } }) })
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onDependencyDeleted(e) { if (e.key != 1) // your code } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onDependencyDeleted)="onDependencyDeleted($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @dependency-deleted="onDependencyDeleted" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onDependencyDeleted(e) { if (e.key != 1) // your code } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onDependencyDeleted={this.onDependencyDeleted} /> ); } onDependencyDeleted = (e) => { if (e.key != 1) // your code } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onDependencyDeleted("gantt_dependencyDeleted_handler") // ... ) <script> function gantt_dependencyDeleted_handler(e) { if (e.key != 1) // your code } </script>
See Also
onDependencyDeleting
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the dependency's deletion. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the deleted dependency. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the deleted dependency. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onDependencyDeleting: function (e) { if (e.key != 1) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onDependencyDeleting(e) { if (e.key != 1) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onDependencyDeleting)="onDependencyDeleting($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @dependency-deleting="onDependencyDeleting" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onDependencyDeleting(e) { if (e.key != 1) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onDependencyDeleting={this.onDependencyDeleting} /> ); } onDependencyDeleting = (e) => { if (e.key != 1) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onDependencyDeleting("gantt_dependencyDeleting_handler") // ... ) <script> function gantt_dependencyDeleting_handler(e) { if (e.key != 1) { // your code e.cancel = true; } } </script>
See Also
onDependencyInserted
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the inserted dependency. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the inserted dependency. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onDependencyInserted: function (e) { if (e.values.type == 3) { // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onDependencyInserted(e) { if (e.values.type == 3) { // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onDependencyInserted)="onDependencyInserted($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @dependency-inserted="onDependencyInserted" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onDependencyInserted(e) { if (e.values.type == 3) { // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onDependencyInserted={this.onDependencyInserted} /> ); } onDependencyInserted = (e) => { if (e.values.type == 3) { // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onDependencyInserted("gantt_dependencyInserted_handler") // ... ) <script> function gantt_dependencyInserted_handler(e) { if (e.key != 1) { // your code e.cancel = true; } } </script>
See Also
onDependencyInserting
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the dependency's insertion. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the inserted dependency. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onDependencyInserting: function (e) { if (e.values.type == 3) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onDependencyInserting(e) { if (e.values.type == 3) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onDependencyInserting)="onDependencyInserting($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @dependency-inserting="onDependencyInserting" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onDependencyInserting(e) { if (e.values.type == 3) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onDependencyInserting={this.onDependencyInserting} /> ); } onDependencyInserting = (e) => { if (e.values.type == 3) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onDependencyInserting("gantt_dependencyInserting_handler") // ... ) <script> function gantt_dependencyInserting_handler(e) { if (e.key != 1) { // your code e.cancel = true; } } </script>
See Also
onDisposing
A function that is executed before the UI component is disposed of.
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
Model data. Available only if you use Knockout. |
onInitialized
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
onOptionChanged
Name | Type | Description |
---|---|---|
model |
Model data. Available only if you use Knockout. |
|
fullName |
The path to the modified property that includes all parent properties. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
component |
The UI component's instance. |
|
name |
The modified property if it belongs to the first level. Otherwise, the first-level property it is nested into. |
|
value | any |
The modified property's new value. |
The following example shows how to subscribe to component property changes:
jQuery
$(function() { $("#ganttContainer").dxGantt({ // ... onOptionChanged: function(e) { if(e.name === "changedProperty") { // handle the property change here } } }); });
Angular
<dx-gantt ... (onOptionChanged)="handlePropertyChange($event)"> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... handlePropertyChange(e) { if(e.name === "changedProperty") { // handle the property change here } } }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule, DxGanttModule ], providers: [ ], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt ... @option-changed="handlePropertyChange" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, // ... methods: { handlePropertyChange: function(e) { if(e.name === "changedProperty") { // handle the property change here } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; const handlePropertyChange = (e) => { if(e.name === "changedProperty") { // handle the property change here } } export default function App() { return ( <Gantt ... onOptionChanged={handlePropertyChange} /> ); }
onResourceAssigned
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the inserted resource assignment. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the processed resource and task. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onResourceAssigned: function (e) { if (e.values.taskID != 0) { // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onResourceAssigned(e) { if (e.values.taskID != 0) { // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onResourceAssigned)="onResourceAssigned($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @resource-assigned="onResourceAssigned" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onResourceAssigned(e) { if (e.values.taskID != 0) { // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onResourceAssigned={this.onResourceAssigned} /> ); } onResourceAssigned = (e) => { if (e.values.taskID != 0) { // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onResourceAssigned("gantt_resourceAssigned_handler") // ... ) <script> function gantt_resourceAssigned_handler(e) { if (e.values.taskID != 0) { // your code } } </script>
See Also
onResourceAssigning
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the resource assignment. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the processed resource and task. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onResourceAssigning: function (e) { if (e.values.taskID != 0) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onResourceAssigning(e) { if (e.values.taskID != 0) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onResourceAssigning)="onResourceAssigning($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @resource-assigning="onResourceAssigning" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onResourceAssigning(e) { if (e.values.taskID != 0) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onResourceAssigning={this.onResourceAssigning} /> ); } onResourceAssigning = (e) => { if (e.values.taskID != 0) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onResourceAssigning("gantt_resourceAssigning_handler") // ... ) <script> function gantt_resourceAssigning_handler(e) { if (e.values.taskID != 0) { // your code e.cancel = true; } } </script>
See Also
onResourceDeleted
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the deleted resource. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the deleted resource. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onResourceDeleted: function (e) { if (e.key == 0) { // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onResourceDeleted(e) { if (e.key == 0) { // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onResourceDeleted)="onResourceDeleted($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @resource-deleted="onResourceDeleted" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onResourceDeleted(e) { if (e.key == 0) { // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onResourceDeleted={this.onResourceDeleted} /> ); } onResourceDeleted = (e) => { if (e.key == 0) { // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onResourceDeleted("gantt_resourceDeleted_handler") // ... ) <script> function gantt_resourceDeleted_handler(e) { if (e.key == 0) { // your code } } </script>
See Also
onResourceDeleting
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the resource deletion. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the deleted resource. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the deleted resource. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onResourceDeleting: function (e) { if (e.key == 0) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onResourceDeleting(e) { if (e.key == 0) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onResourceDeleting)="onResourceDeleting($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @resource-deleting="onResourceDeleting" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onResourceDeleting(e) { if (e.key == 0) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onResourceDeleting={this.onResourceDeleting} /> ); } onResourceDeleting = (e) => { if (e.key == 0) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onResourceDeleting("gantt_resourceDeleting_handler") // ... ) <script> function gantt_resourceDeleting_handler(e) { if (e.key == 0) { // your code e.cancel = true; } } </script>
See Also
onResourceInserted
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the inserted resource. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the inserted resource. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onResourceInserted: function (e) { if (e.values.text == " "){ // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onResourceInserted(e) { if (e.values.text == " "){ // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onResourceInserted)="onResourceInserted($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @resource-inserted="onResourceInserted" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onResourceInserted(e) { if (e.values.text == " "){ // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onResourceInserted={this.onResourceInserted} /> ); } onResourceInserted = (e) => { if (e.values.text == " "){ // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onResourceInserted("gantt_resourceInserted_handler") // ... ) <script> function gantt_resourceInserted_handler(e) { if (e.values.text == " "){ // your code } } </script>
See Also
onResourceInserting
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the resource insertion. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the inserted resource. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onResourceInserting: function (e) { if (e.values.text == " "){ // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onResourceInserting(e) { if (e.values.text == " "){ // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onResourceInserting)="onResourceInserting($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @resource-inserting="onResourceInserting" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onResourceInserting(e) { if (e.values.text == " "){ // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onResourceInserting={this.onResourceInserting} /> ); } onResourceInserting = (e) => { if (e.values.text == " "){ // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onResourceInserting("gantt_resourceInserting_handler") // ... ) <script> function gantt_resourceInserting_handler(e) { if (e.values.text == " "){ // your code e.cancel = true; } } </script>
See Also
onResourceUnassigned
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the deleted resource assignment. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the processed resource and task. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onResourceUnassigned: function (e) { if (e.key != 0) { // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onResourceUnassigned(e) { if (e.key != 0) { // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onResourceUnassigned)="onResourceUnassigned($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @resource-unassigned="onResourceUnassigned" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onResourceUnassigned(e) { if (e.key != 0) { // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onResourceUnassigned={this.onResourceUnassigned} /> ); } onResourceUnassigned = (e) => { if (e.key != 0) { // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onResourceUnassigned("gantt_resourceUnassigned_handler") // ... ) <script> function gantt_resourceUnassigned_handler(e) { if (e.key != 0) { // your code } } </script>
See Also
onResourceUnassigning
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the resource unassignment. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the resource. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the processed resource and task. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onResourceUnassigning: function (e) { if (e.key != 0) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onResourceUnassigning(e) { if (e.key != 0) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onResourceUnassigning)="onResourceUnassigning($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @resource-unassigning="onResourceUnassigning" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onResourceUnassigning(e) { if (e.key != 0) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onResourceUnassigning={this.onResourceUnassigning} /> ); } onResourceUnassigning = (e) => { if (e.key != 0) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onResourceUnassigning("gantt_resourceUnassigning_handler") // ... ) <script> function gantt_resourceUnassigning_handler(e) { if (e.key != 0) { // your code e.cancel = true; } } </script>
See Also
onSelectionChanged
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
Model data. Available only if you use Knockout. |
|
selectedRowKey | any |
The key of the row whose selection state was changed. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onSelectionChanged: function (e) { if (e.selectedRowKey === 2) { // your code } else { // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onSelectionChanged(e) { if (e.selectedRowKey === 2) { // your code } else { // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onSelectionChanged)="onSelectionChanged($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @selection-changed="onSelectionChanged" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onSelectionChanged(e) { if (e.selectedRowKey === 2) { // your code } else { // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onSelectionChanged={this.onSelectionChanged} /> ); } onSelectionChanged = (e) => { if (e.selectedRowKey === 2) { // your code } else { // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onSelectionChanged("gantt_selectionChanged_handler") // ... ) <script> function gantt_selectionChanged_handler(e) { if (e.selectedRowKey === 2) { // your code } else { // your code } } </script>
See Also
onTaskClick
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
data | any |
The task data. |
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
event | Event (jQuery or EventObject) |
The event that caused the function to execute. It is a dxEvent or a jQuery.Event when you use jQuery. |
key | any |
The task key. |
model |
Model data. Available only if you use Knockout. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskClick: function (e) { if (e.key != 0) { // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskClick(e) { if (e.key != 0) { // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskClick)="onTaskClick($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-click="onTaskClick" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskClick(e) { if (e.key != 0) { // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskClick={this.onTaskClick} /> ); } onTaskClick = (e) => { if (e.key != 0) { // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskClick("gantt_taskClick_handler") // ... ) <script> function gantt_taskClick_handler(e) { if (e.key != 0) { // your code } } </script>
See Also
onTaskDblClick
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the resource unassignment. |
|
component |
The UI component's instance. |
|
data | any |
The task data. |
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
event | Event (jQuery or EventObject) |
The event that caused the function to execute. It is a dxEvent or a jQuery.Event when you use jQuery. |
key | any |
The task key. |
model |
Model data. Available only if you use Knockout. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskDblClick: function (e) { if (e.key != 0) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskDblClick(e) { if (e.key != 0) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskDblClick)="onTaskDblClick($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-dbl-click="onTaskDblClick" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskDblClick(e) { if (e.key != 0) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskDblClick={this.onTaskDblClick} /> ); } onTaskDblClick = (e) => { if (e.key != 0) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskDblClick("gantt_taskDblClick_handler") // ... ) <script> function gantt_taskDblClick_handler(e) { if (e.key != 0) { // your code e.cancel = true; } } </script>
See Also
onTaskDeleted
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the deleted task. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the deleted task. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskDeleted: function (e) { if (e.key != 0) { // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskDeleted(e) { if (e.key != 0) { // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskDeleted)="onTaskDeleted($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-deleted="onTaskDeleted" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskDeleted(e) { if (e.key != 0) { // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskDeleted={this.onTaskDeleted} /> ); } onTaskDeleted = (e) => { if (e.key != 0) { // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskDeleted("gantt_taskDeleted_handler") // ... ) <script> function gantt_taskDeleted_handler(e) { if (e.key != 0) { // your code } } </script>
See Also
onTaskDeleting
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the task deletion. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the deleted task. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the deleted task. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskDeleting: function (e) { if (e.key != 0) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskDeleting(e) { if (e.key != 0) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskDeleting)="onTaskDeleting($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-deleting="onTaskDeleting" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskDeleting(e) { if (e.key != 0) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskDeleting={this.onTaskDeleting} /> ); } onTaskDeleting = (e) => { if (e.key != 0) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskDeleting("gantt_taskDeleting_handler") // ... ) <script> function gantt_taskDeleting_handler(e) { if (e.key != 0) { // your code e.cancel = true; } } </script>
See Also
onTaskEditDialogShowing
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the edit dialog showing. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
hiddenFields |
An array of hidden fields. |
|
key | any |
The task key. |
model |
Model data. Available only if you use Knockout. |
|
readOnlyFields |
An array of read-only fields. |
|
values | any |
The task values. |
Note that the hiddenFields and readOnlyFields parameters affect only task fields. Use the allowTaskResourceUpdating property to hide the Resource Manager in the Task Details dialog.
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskEditDialogShowing: function (e) { if (e.key != 0) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskEditDialogShowing(e) { if (e.key != 0) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskEditDialogShowing)="onTaskEditDialogShowing($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-edit-dialog-showing="onTaskEditDialogShowing" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskEditDialogShowing(e) { if (e.key != 0) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskEditDialogShowing={this.onTaskEditDialogShowing} /> ); } onTaskEditDialogShowing = (e) => { if (e.key != 0) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskEditDialogShowing("gantt_taskEditDialogShowing_handler") // ... ) <script> function gantt_taskEditDialogShowing_handler(e) { if (e.key != 0) { // your code e.cancel = true; } } </script>
See Also
onTaskInserted
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the inserted task. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the inserted task. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskInserted: function (e) { if (e.values.text == " ") { // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskInserted(e) { if (e.values.text == " ") { // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskInserted)="onTaskInserted($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-inserted="onTaskInserted" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskInserted(e) { if (e.values.text == " ") { // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskInserted={this.onTaskInserted} /> ); } onTaskInserted = (e) => { if (e.values.text == " ") { // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskInserted("gantt_taskInserted_handler") // ... ) <script> function gantt_taskInserted_handler(e) { if (e.values.text == " ") { // your code } } </script>
See Also
onTaskInserting
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the task insertion. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
Model data. Available only if you use Knockout. |
|
values | any |
The values of the inserted task. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskInserting: function (e) { if (e.values.text == " ") { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskInserting(e) { if (e.values.text == " ") { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskInserting)="onTaskInserting($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-inserting="onTaskInserting" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskInserting(e) { if (e.values.text == " ") { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskInserting={this.onTaskInserting} /> ); } onTaskInserting = (e) => { if (e.values.text == " ") { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskInserting("gantt_taskInserting_handler") // ... ) <script> function gantt_taskInserting_handler(e) { if (e.values.text == " ") { // your code e.cancel = true; } } </script>
See Also
onTaskMoving
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the task's movement. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The task key. |
model |
Model data. Available only if you use Knockout. |
|
newValues | any |
The task values after moving. |
values | any |
The task values before moving. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskMoving: function (e) { if (e.key != 0) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskMoving(e) { if (e.key != 0) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskMoving)="onTaskMoving($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-moving="onTaskMoving" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskMoving(e) { if (e.key != 0) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskMoving={this.onTaskMoving} /> ); } onTaskMoving = (e) => { if (e.key != 0) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskMoving("gantt_taskMoving_handler") // ... ) <script> function gantt_taskMoving_handler(e) { if (e.key != 0) { // your code e.cancel = true; } } </script>
See Also
onTaskUpdated
Name | Type | Description |
---|---|---|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The key of the updated task. |
model |
Model data. Available only if you use Knockout. |
|
values | any |
The task values after update. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskUpdated: function (e) { if (e.key != 0) { // your code } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskUpdated(e) { if (e.key != 0) { // your code } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskUpdated)="onTaskUpdated($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-updated="onTaskUpdated" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskUpdated(e) { if (e.key != 0) { // your code } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskUpdated={this.onTaskUpdated} /> ); } onTaskUpdated = (e) => { if (e.key != 0) { // your code } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskUpdated("gantt_taskUpdated_handler") // ... ) <script> function gantt_taskUpdated_handler(e) { if (e.key != 0) { // your code } } </script>
See Also
onTaskUpdating
Name | Type | Description |
---|---|---|
cancel |
Allows you to cancel the task update. |
|
component |
The UI component's instance. |
|
element |
The UI component's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
key | any |
The task key. |
model |
Model data. Available only if you use Knockout. |
|
newValues | any |
The task values after update. |
values | any |
The task values before update. |
jQuery
$(function() { $("#gantt").dxGantt({ // ... onTaskUpdating: function (e) { if (e.key != 0) { // your code e.cancel = true; } } }); });
Angular
import { DxGanttModule } from "devextreme-angular"; // ... export class AppComponent { onTaskUpdating(e) { if (e.key != 0) { // your code e.cancel = true; } } } @NgModule({ imports: [ // ... DxGanttModule ], // ... })
<dx-gantt ... (onTaskUpdating)="onTaskUpdating($event)"> </dx-gantt>
Vue
<template> <DxGantt ... @task-updating="onTaskUpdating" /> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import DxGantt from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { onTaskUpdating(e) { if (e.key != 0) { // your code e.cancel = true; } } } } </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import Gantt from 'devextreme-react/gantt'; class App extends React.Component { // ... render() { return ( <Gantt //... onTaskUpdating={this.onTaskUpdating} /> ); } onTaskUpdating = (e) => { if (e.key != 0) { // your code e.cancel = true; } } } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ID("gantt") .onTaskUpdating("gantt_taskUpdating_handler") // ... ) <script> function gantt_taskUpdating_handler(e) { if (e.key != 0) { // your code e.cancel = true; } } </script>
See Also
resourceAssignments
Resource assignments define relationship between tasks and resources.
Use the dataSource property to bind the UI component to a data source, which contains resource assignments. If the field names in your data source differ from the 'id', 'resourceId' and 'taskId' default names, use the keyExpr, resourceIdExpr and/or taskIdExpr properties to map data fields.
See Also
jQuery
$(function() { $("#gantt").dxGantt({ resourceAssignments: { dataSource: resourceAssignments, keyExpr: "key", resourceIdExpr: "resourceKey", taskIdExpr: "taskKey" }, //... }); });
var resourceAssignments = [{ 'key': 0, 'taskKey': 3, 'resourceKey': 1 }, // ... ];
Angular
<dx-gantt ... > <dxo-resource-assignments [dataSource]="resourceAssignments" keyExpr="key" resourceIdExpr="resourceKey" taskIdExpr="taskKey"> </dxo-resource-assignments> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { resourceAssignments: ResourceAssignment[]; // ... constructor(service: Service) { this.resourceAssignments = service.getResourceAssignments(); // ... } }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; import { Service, ResourceAssignment, ... } from './app.service'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
import { Injectable } from '@angular/core'; export class ResourceAssignment { id: number; taskId: number; resourceId: number; } const resourceAssignments: ResourceAssignment[] = [{ 'key': 0, 'taskKey': 3, 'resourceKey': 1 }, // ... ]; @Injectable() export class Service { getResourceAssignments(): ResourceAssignment[] { return resourceAssignments; } }
{ "projects": { "ProjectName": { "architect": { "build": { "options": { "styles": [ "node_modules/devextreme/dist/css/dx.common.css", "node_modules/devextreme/dist/css/dx.light.css", "node_modules/devexpress-gantt/dist/dx-gantt.css", "src/styles.css" ], ... }, ... }, ... } }, ... }, ... }
Vue
<template> <DxGantt ... > <DxResourceAssignments :data-source="resourceAssignments" key-expr="key" resource-id-expr="resourceKey" task-id-expr="taskKey" /> <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt, DxResourceAssignments, //... } from 'devextreme-vue/gantt'; import { resourceAssignments, // ... } from './data.js'; export default { components: { DxGantt, DxResourceAssignments, //... }, data() { return { resourceAssignments, //... }; } }; </script>
export const resourceAssignments = [{ 'key': 0, 'taskKey': 3, 'resourceKey': 1 }, // ... ];
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { ResourceAssignments, //... } from 'devextreme-react/gantt'; import { resourceAssignments, //... } from './data.js'; const App = () => { return ( <Gantt ... > <ResourceAssignments dataSource={resourceAssignments} keyExpr="key" resourceIdExpr="resourceKey" taskIdExpr="taskKey" /> </Gantt> ); }; export default App;
export const resourceAssignments = [{ 'key': 0, 'taskKey': 3, 'resourceKey': 1 }, // ... ];
ASP.NET Core Controls
@(Html.DevExtreme().Gantt<Gantt.Task>() .ResourceAssignments(ra => ra .DataSource(ds => ds.Array().Data(SampleData.GanttResourceAssignments).Key("ID")) .KeyExpr("ID") .TaskIdExpr("TaskId") .ResourceIdExpr("ResourceId") ) // ... ) <!-- C# --> public partial class SampleData { public static readonly IEnumerable<ResourceAssignment> GanttResourceAssignments = new[] { new ResourceAssignment { ID = 0, TaskId = 3, ResourceId = 1 }, new ResourceAssignment { ID = 1, TaskId = 4, ResourceId = 1 }, // ... } // ... }
ASP.NET MVC Controls
@(Html.DevExtreme().Gantt<Gantt.Task>() .ResourceAssignments(ra => ra .DataSource(ds => ds.Array().Data(SampleData.GanttResourceAssignments).Key("ID")) .KeyExpr("ID") .TaskIdExpr("TaskId") .ResourceIdExpr("ResourceId") ) // ... ) <!-- C# --> public partial class SampleData { public static readonly IEnumerable<ResourceAssignment> GanttResourceAssignments = new[] { new ResourceAssignment { ID = 0, TaskId = 3, ResourceId = 1 }, new ResourceAssignment { ID = 1, TaskId = 4, ResourceId = 1 }, // ... } // ... }
resources
You can add resources to a project and assign them to tasks. Resources can be people responsible for tasks, equipment, materials, etc. The Gantt displays resources as labels on the right of the tasks.
Use the dataSource property to bind the UI component to a data source, which contains resources. If the field names in your data source differ from the 'id', 'text' and 'color' default names, use the keyExpr, textExpr and/or colorExpr properties to map data fields.
See Also
jQuery
$(function() { $("#gantt").dxGantt({ resources: { dataSource: resources, keyExpr: "resourceId", textExpr: "title", colorExpr: "resourceColor" }, //... }); });
var resources = [{ 'resourceId': 1, 'title': 'Management', 'resourceColor': 'red' }, // ... ];
Angular
<dx-gantt ... > <dxo-resources [dataSource]="resources" keyExpr="resourceId" textExpr="title" colorExpr="resourceColor" > </dxo-resources> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { resources: Resource[]; // ... constructor(service: Service) { this.resources = service.getResources(); // ... } }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; import { Service, Resource, ... } from './app.service'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], providers: [Service], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
import { Injectable } from '@angular/core'; export class Resource { resourceId: number; title: string; resourceColor: string; } const resources: Resource[] = [{ 'resourceId': 1, 'title': 'Management', 'resourceColor': 'red' }, // ... ]; @Injectable() export class Service { getResources(): Resource[] { return resources; } }
{ "projects": { "ProjectName": { "architect": { "build": { "options": { "styles": [ "node_modules/devextreme/dist/css/dx.common.css", "node_modules/devextreme/dist/css/dx.light.css", "node_modules/devexpress-gantt/dist/dx-gantt.css", "src/styles.css" ], ... }, ... }, ... } }, ... }, ... }
Vue
<template> <DxGantt ... > <DxResources :data-source="resources" key-expr="resourceId" text-expr="title" color-expr="resourceColor" /> <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt, DxResources, // ... } from 'devextreme-vue/gantt'; import { resources, // ... } from './data.js'; export default { components: { DxGantt, DxResources, // ... }, data() { return { resources, // ... }; } }; </script>
export const resources = [{ 'resourceId': 1, 'title': 'Management', 'resourceColor': 'red' }, // ... ];
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { Resources, // ... } from 'devextreme-react/gantt'; import { resources, // ... } from './data.js'; const App = () => { return ( <Gantt ... > <Resources dataSource={resources} keyExpr="resourceId" textExpr="title" colorExpr="resourceColor" /> {/* ... */} </Gantt> ); }; export default App;
export const resources = [{ 'resourceId': 1, 'title': 'Management', 'resourceColor': 'red' }, // ... ];
ASP.NET Core Controls
@(Html.DevExtreme().Gantt<Gantt.Task>() .Resources(r => r .DataSource(ds => ds.Array().Data(SampleData.GanttResources).Key("ID")) .KeyExpr("ID") .TextExpr("Text") ) // ... ) <!-- C# --> public partial class SampleData { public static readonly IEnumerable<Resource> GanttResources = new[] { new Resource { ID = 1, Text = "Management" }, new Resource { ID = 2, Text = "Project Manager" }, // ... } // ... }
ASP.NET MVC Controls
@(Html.DevExtreme().Gantt<Gantt.Task>() .Resources(r => r .DataSource(ds => ds.Array().Data(SampleData.GanttResources).Key("ID")) .KeyExpr("ID") .TextExpr("Text") ) // ... ) <!-- C# --> public partial class SampleData { public static readonly IEnumerable<Resource> GanttResources = new[] { new Resource { ID = 1, Text = "Management" }, new Resource { ID = 2, Text = "Project Manager" }, // ... } // ... }
scaleType
The scaleType property specifies the zoom level for tasks when the Gantt UI component is initialized or when you call the option() method.
jQuery
$(function() { $("#gantt").dxGantt({ scaleType: 'hours', // ... }); });
Angular
<dx-gantt [scaleType]="hours"> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :scale-type="hours" > <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt scaleType="hours" > {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ScaleType(GanttScaleType.Weeks) // ... )
If the scaleType property is set to "auto", the UI component is scaled to fit all tasks in the Gantt chart's visible area.
To browse tasks across various levels of detail in real time, hold the CTRL key and scroll the mouse wheel to zoom (in or out).
selectedRowKey
jQuery
$(function() { $("#gantt").dxGantt({ selectedRowKey: 1, // ... }); });
Angular
<dx-gantt [selectedRowKey]="1"> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :selected-row-key="1" > <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt selectedRowKey={1} > {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .SelectedRowKey(1) // ... )
See Also
showResources
Specifies whether to display task resources.
jQuery
$(function() { $("#gantt").dxGantt({ showResources: false, // ... }); });
Angular
<dx-gantt [showResources]="false"> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :show-resources="false" > <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt showResources={false} > {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ShowResources(false) // ... )
ASP.NET MVC Controls
<!-- Razor C# --> @(Html.DevExtreme().Gantt() .ShowResources(false) // ... )
showRowLines
jQuery
$(function() { $("#gantt").dxGantt({ showRowLines: false, // ... }); });
Angular
<dx-gantt [showRowLines]="false"> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :show-row-lines="false" > <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt showRowLines={false} > {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .ShowRowLines(false) // ... )
ASP.NET MVC Controls
<!-- Razor C# --> @(Html.DevExtreme().Gantt() .ShowRowLines(false) // ... )
stripLines[]
Strip lines allows you to highlight certain time or time intervals in the chart. Use the start property to specify an individual line or combine it with the end property setting to specify a time interval.
jQuery
$(function() { $("#gantt").dxGantt({ stripLines: [{ title: "Start", start: tasks[0].start }, { title: "Final Phase", start: tasks[tasks.length - 3].start, end: tasks[tasks.length - 1].end, }, { title: "Current Time", start: new Date(), cssClass: "current-time" }], //... }); });
Angular
<dx-gantt> <dxi-strip-line [start]="tasks[0].start" title="Start"> </dxi-strip-line> <dxi-strip-line [start]="tasks[tasks.length - 3].start" [end]="tasks[tasks.length - 1].end" title="Final Phase"> </dxi-strip-line> <dxi-strip-line [start]="currentTime" title="Current Time" cssClass="current-time"> </dxi-strip-line> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt > <DxStripLine :start="tasks[0].start" title="Start" /> <DxStripLine :start="tasks[tasks.length - 3].start" :end="tasks[tasks.length - 1].end" title="Final Phase" /> <DxStripLine :start="currentTime" title="Current Time" css-class="current-time" /> <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt, DxStripLine // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt, DxStripLine // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt> <StripLine start={tasks[0].start} title="Start" /> <StripLine start={tasks[tasks.length - 3].start} end={tasks[tasks.length - 1].end} title="Final Phase" /> <StripLine start={currentDate} title="Current Time" cssClass="current-time" /> {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .StripLines(s => { s.Add().Title("Start") .Start(SampleData.GanttTasksJohnsonResidence.First().Start); s.Add().Title("Final Phase") .Start(SampleData.GanttTasksJohnsonResidence.Where(t => t.ID == 20).First().Start) .End(SampleData.GanttTasksJohnsonResidence.Where(t => t.ID == 22).First().End); s.Add().Title("Current Time") .Start(DateTime.Now) .CssClass("current-time"); }) // ... )
ASP.NET MVC Controls
@(Html.DevExtreme().Gantt() .StripLines(s => { s.Add().Title("Start") .Start(SampleData.GanttTasksJohnsonResidence.First().Start); s.Add().Title("Final Phase") .Start(SampleData.GanttTasksJohnsonResidence.Where(t => t.ID == 20).First().Start) .End(SampleData.GanttTasksJohnsonResidence.Where(t => t.ID == 22).First().End); s.Add().Title("Current Time") .Start(DateTime.Now) .CssClass("current-time"); }) // ... )
tabIndex
The value of this property will be passed to the tabindex
attribute of the HTML element that underlies the UI component.
taskListWidth
jQuery
$(function() { $("#gantt").dxGantt({ taskListWidth: 200, // ... }); });
Angular
<dx-gantt [taskListWidth]="200"> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :task-list-width="200" > <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt taskListWidth={200} > {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .TaskListWidth(200) // ... )
tasks
Use the dataSource property to bind the UI component to a data source, which contains tasks. If the field names in your data source differ from default names ('id', 'parentId', 'title', 'start', 'end', 'progress', 'color'), use appropriate properties (keyExpr, parentIdExpr, etc.) to map data fields.
See Also
jQuery
$(function() { $("#gantt").dxGantt({ tasks: { dataSource: tasks, keyExpr: "taskId", parentIdExpr: "parentTaskId", titleExpr: "taskTitle", progressExpr: "taskProgress", startExpr: "startDate", endExpr: "endDate", colorExpr: "taskColor" }, //... }); });
var tasks = [{ 'taskId': 1, 'parentTaskId': 0, 'taskTitle': 'Software Development', 'startDate': new Date('2019-02-21T05:00:00.000Z'), 'endDate': new Date('2019-07-04T12:00:00.000Z'), 'taskProgress': 31 'taskColor': 'red' }, // ... ];
Angular
<dx-gantt ... > <dxo-tasks [dataSource]="tasks" keyExpr="taskId" parentIdExpr="parentTaskId" titleExpr="taskTitle" progressExpr="taskProgress" startExpr="startDate" endExpr="endDate" colorExpr="taskColor" > </dxo-tasks> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { tasks: Task[]; // ... constructor(service: Service) { this.tasks = service.getTasks(); // ... } }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; import { Service, Task, ... } from './app.service'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], providers: [Service], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
import { Injectable } from '@angular/core'; export class Task { taskId: number; parentTaskId: number; taskTitle: string; startDate: Date; endDate: Date; taskProgress: number; taskColor: string; } const tasks: Task[] = [{ 'taskId': 1, 'parentTaskId': 0, 'taskTitle': 'Software Development', 'startDate': new Date('2019-02-21T05:00:00.000Z'), 'endDate': new Date('2019-07-04T12:00:00.000Z'), 'taskProgress': 31, 'taskColor': 'red' }, // ... ]; @Injectable() export class Service { getTasks(): Task[] { return tasks; } }
{ "projects": { "ProjectName": { "architect": { "build": { "options": { "styles": [ "node_modules/devextreme/dist/css/dx.common.css", "node_modules/devextreme/dist/css/dx.light.css", "node_modules/devexpress-gantt/dist/dx-gantt.css", "src/styles.css" ], ... }, ... }, ... } }, ... }, ... }
Vue
<template> <DxGantt ... > <DxTasks :data-source="tasks" key-expr="taskId" parent-id-expr="parentTaskId" title-expr="taskTitle" progress-expr="taskProgress" start-expr="startDate" end-expr="endDate" color-expr="taskColor" /> <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt, DxTasks, // ... } from 'devextreme-vue/gantt'; import { tasks, // ... } from './data.js'; export default { components: { DxGantt, DxTasks, // ... }, data() { return { tasks, // ... }; } }; </script>
export const tasks = [{ 'taskId': 1, 'parentTaskId': 0, 'taskTitle': 'Software Development', 'startDate': new Date('2019-02-21T05:00:00.000Z'), 'endDate': new Date('2019-07-04T12:00:00.000Z'), 'taskProgress': 31, 'taskColor': 'red' }, // ... ];
React
import React from 'react'; import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { Tasks, // ... } from 'devextreme-react/gantt'; import { tasks, // ... } from './data.js'; const App = () => { return ( <Gantt ... > <Tasks dataSource={tasks} keyExpr="taskId" parentIdExpr="parentTaskId" titleExpr="taskTitle" progressExpr="taskProgress" startExpr="startDate" endExpr="endDate" colorExpr="taskColor" /> {/* ... */} </Gantt> ); }; export default App;
export const tasks = [{ 'taskId': 1, 'parentTaskId': 0, 'taskTitle': 'Software Development', 'startDate': new Date('2019-02-21T05:00:00.000Z'), 'endDate': new Date('2019-07-04T12:00:00.000Z'), 'taskProgress': 31, 'taskColor': 'red' }, // ... ];
ASP.NET Core Controls
@(Html.DevExtreme().Gantt<Gantt.Task>() .Tasks(t => t .DataSource(ds => ds.Array().Data(SampleData.GanttTasks).Key("ID")) .KeyExpr("ID") .TitleExpr("Title") .ParentIdExpr("ParentId") .StartExpr("Start") .EndExpr("End") .ProgressExpr("Progress") ) // ... ) <!-- C# --> public partial class SampleData { public static readonly IEnumerable<Task> GanttTasks = new[] { new Task { ID = 1, ParentId = 0, Title = "Software Development", Start = DateTime.Parse("2019-02-21T05:00:00.000Z"), End = DateTime.Parse("2019-07-04T12:00:00.000Z"), Progress = 31 }, // ... } // ... }
ASP.NET MVC Controls
@(Html.DevExtreme().Gantt<Gantt.Task>() .Tasks(t => t .DataSource(ds => ds.Array().Data(SampleData.GanttTasks).Key("ID")) .KeyExpr("ID") .TitleExpr("Title") .ParentIdExpr("ParentId") .StartExpr("Start") .EndExpr("End") .ProgressExpr("Progress") ) // ... ) <!-- C# --> public partial class SampleData { public static readonly IEnumerable<Task> GanttTasks = new[] { new Task { ID = 1, ParentId = 0, Title = "Software Development", Start = DateTime.Parse("2019-02-21T05:00:00.000Z"), End = DateTime.Parse("2019-07-04T12:00:00.000Z"), Progress = 31 }, // ... } // ... }
taskTitlePosition
Titles can be displayed "inside" or "outside" the the task. Set the position to "none" to hide the title.
jQuery
$(function() { $("#gantt").dxGantt({ taskTitlePosition: 'none', // ... }); });
Angular
<dx-gantt [taskTitlePosition]="none"> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :task-title-position="none" > <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt taskTitlePosition="none" > {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .TaskTitlePosition(GanttTaskTitlePosition.None) // ... )
taskTooltipContentComponent
An alias for the taskTooltipContentTemplate property specified in React. Accepts a custom component. Refer to Using a Custom Component for more information.
taskTooltipContentRender
An alias for the taskTooltipContentTemplate property specified in React. Accepts a rendering function. Refer to Using a Rendering Function for more information.
taskTooltipContentTemplate
The editor's container. It is an HTML Element or a jQuery Element when you use jQuery.
Note that the container parameter contains the content of the default tooltip. You should clear the container parameter to specify custom content for the task tooltip.
jQuery
$(function() { $("#gantt").dxGantt({ taskTooltipContentTemplate: getTaskTooltipContentTemplate, // ... }); }); function getTaskTooltipContentTemplate(task, container) { container[0].innerHTML = ""; return "<div class='custom-tooltip-title'>" + task.title + "</div>"; }
Angular
<dx-gantt taskTooltipContentTemplate="myTaskTooltipTemplate"> <div *dxTemplate="let task of 'myTaskTooltipTemplate'" class="custom-task-edit-tooltip"> <div class="custom-tooltip-title">{{task.title}}</div> <!-- ... --> </div> ... </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt :task-tooltip-content-template="myTooltipContentTemplate" > <template #myTooltipContentTemplate="{ data: task }"> <div class="custom-task-edit-tooltip"> <div class="custom-tooltip-title">{{ task.title }}</div> <!-- ... --> </div> </template> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.common.css'; import 'devextreme/dist/css/dx.light.css'; import { DxGantt } from 'devextreme-vue/gantt'; export default { components: { DxGantt }, methods: { //... }, data() { return { // ... } } } </script>
React
import React from 'react'; import Gantt from 'devextreme-react/gantt'; import { Template } from 'devextreme-react/core/template'; const TaskTooltipTemplate = (task) => { return ( <div class="custom-task-edit-tooltip"> <div class="custom-tooltip-title">{{ task.title }}</div> <!-- ... --> </div> ); } export default function App() { return ( <Gantt taskTooltipContentRender={TaskTooltipTemplate}> //... </Gantt> ); } export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .TaskTooltipContentTemplate(new JS("getTaskTooltipContentTemplate")) // ... ) <script> function getTaskTooltipContentTemplate(task, container) { var $customTooltip = $(document.createElement("div")) .addClass("custom-task-edit-tooltip"); $(document.createElement("div")) .addClass("custom-tooltip-title") .text(task.Title) .appendTo($customTooltip); // ... return $customTooltip; } </script>
validation
jQuery
$(function() { $("#gantt").dxGantt({ validation: { autoUpdateParentTasks: true, validateDependencies: true }, // ... }); });
Angular
<dx-gantt ... > <dxo-validation [autoUpdateParentTasks]="true" [validateDependencies]="true"> </dxo-validation> <!-- ... --> </dx-gantt>
import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { // ... }
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxGanttModule } from 'devextreme-angular'; @NgModule({ imports: [ BrowserModule, DxGanttModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { }
Vue
<template> <DxGantt ... > <DxValidation :auto-update-parent-tasks="true" :validate-dependencies="true" /> <!-- ... --> </DxGantt> </template> <script> import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import { DxGantt, DxValidation, // ... } from 'devextreme-vue/gantt'; export default { components: { DxGantt, DxValidation, // ... } }; </script>
React
import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import 'devexpress-gantt/dist/dx-gantt.css'; import Gantt, { Validation, // ... } from 'devextreme-react/gantt'; const App = () => { return ( <Gantt ... > <Validation autoUpdateParentTasks={true} validateDependencies={true} /> {/* ... */} </Gantt> ); }; export default App;
ASP.NET Core Controls
@(Html.DevExtreme().Gantt() .Validation(e => { e.AutoUpdateParentTasks(true) e.ValidateDependencies(true) }) // ... )
ASP.NET MVC Controls
@(Html.DevExtreme().Gantt() .Validation(e => { e.AutoUpdateParentTasks(true) e.ValidateDependencies(true) }) // ... )
width
This property accepts a value of one of the following types:
Number
The width in pixels.String
A CSS-accepted measurement of width. For example,"55px"
,"80%"
,"auto"
,"inherit"
.Function
A function returning either of the above. For example:JavaScriptwidth: function() { return window.innerWidth / 1.5; }